typescript-express-starter 10.2.1 → 11.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.kr.md +136 -287
- package/README.md +134 -274
- package/bin/ast-utils.js +226 -0
- package/bin/common.js +312 -0
- package/bin/config.js +80 -0
- package/bin/db-map.js +169 -0
- package/bin/errors.js +129 -0
- package/bin/performance.js +203 -0
- package/bin/starter.js +359 -0
- package/bin/validators.js +146 -0
- package/devtools/biome/.biome.json +34 -0
- package/devtools/biome/.biomeignore +29 -0
- package/devtools/docker/.dockerignore +27 -0
- package/devtools/docker/Dockerfile.dev +20 -0
- package/devtools/docker/Dockerfile.prod +35 -0
- package/{lib/default → devtools/docker}/Makefile +3 -0
- package/devtools/docker/nginx.conf +67 -0
- package/devtools/eslint/eslint.config.cjs +23 -0
- package/devtools/husky/.husky/commit-msg +4 -0
- package/devtools/husky/.husky/pre-commit +4 -0
- package/devtools/husky/.husky/pre-push +4 -0
- package/devtools/jest/jest.config.cjs +2 -0
- package/devtools/jest/jest.config.ts +25 -0
- package/devtools/jest/src/test/e2e/auth.e2e.spec.ts +40 -0
- package/devtools/jest/src/test/e2e/users.e2e.spec.ts +63 -0
- package/devtools/jest/src/test/setup.ts +31 -0
- package/devtools/jest/src/test/unit/entities/user.entity.spec.ts +279 -0
- package/devtools/jest/src/test/unit/services/auth.service.spec.ts +75 -0
- package/devtools/jest/src/test/unit/services/users.service.spec.ts +109 -0
- package/devtools/oxlint/.oxlintrc.json +57 -0
- package/devtools/pm2/ecosystem.config.js +59 -0
- package/devtools/swagger/swagger.yaml +124 -0
- package/{lib/prisma → devtools/swc}/.swcrc +2 -1
- package/devtools/tsup/tsup.config.ts +15 -0
- package/devtools/vitest/src/test/e2e/auth.e2e.spec.ts +41 -0
- package/devtools/vitest/src/test/e2e/users.e2e.spec.ts +64 -0
- package/devtools/vitest/src/test/setup.ts +31 -0
- package/devtools/vitest/src/test/unit/services/auth.service.spec.ts +70 -0
- package/devtools/vitest/src/test/unit/services/users.service.spec.ts +90 -0
- package/devtools/vitest/vitest.config.ts +22 -0
- package/package.json +24 -11
- package/templates/default/nodemon.json +7 -0
- package/templates/default/package.json +48 -0
- package/templates/default/src/app.ts +118 -0
- package/templates/default/src/config/env.ts +78 -0
- package/templates/default/src/controllers/auth.controller.ts +40 -0
- package/templates/default/src/controllers/users.controller.ts +46 -0
- package/templates/default/src/dtos/users.dto.ts +42 -0
- package/templates/default/src/entities/user.entity.ts +190 -0
- package/templates/default/src/exceptions/httpException.ts +14 -0
- package/{lib/knex → templates/default}/src/interfaces/auth.interface.ts +3 -3
- package/templates/default/src/interfaces/users.interface.ts +9 -0
- package/templates/default/src/middlewares/auth.middleware.ts +49 -0
- package/templates/default/src/middlewares/error.middleware.ts +89 -0
- package/templates/default/src/middlewares/notFound.middleware.ts +6 -0
- package/templates/default/src/middlewares/validation.middleware.ts +15 -0
- package/templates/default/src/repositories/users.repository.ts +55 -0
- package/templates/default/src/routes/auth.route.ts +31 -0
- package/templates/default/src/routes/users.route.ts +32 -0
- package/templates/default/src/server.ts +35 -0
- package/templates/default/src/services/auth.service.ts +67 -0
- package/templates/default/src/services/users.service.ts +48 -0
- package/templates/default/src/utils/asyncHandler.ts +8 -0
- package/templates/default/src/utils/logger.ts +113 -0
- package/{lib/typeorm → templates/default}/tsconfig.json +23 -22
- package/CONTRIBUTORS.md +0 -69
- package/bin/cli.js +0 -18
- package/lib/default/.dockerignore +0 -18
- package/lib/default/.editorconfig +0 -9
- package/lib/default/.env.development.local +0 -13
- package/lib/default/.env.production.local +0 -13
- package/lib/default/.env.test.local +0 -13
- package/lib/default/.eslintignore +0 -1
- package/lib/default/.eslintrc +0 -18
- package/lib/default/.huskyrc +0 -5
- package/lib/default/.lintstagedrc.json +0 -5
- package/lib/default/.prettierrc +0 -8
- package/lib/default/.swcrc +0 -39
- package/lib/default/.vscode/launch.json +0 -35
- package/lib/default/.vscode/settings.json +0 -6
- package/lib/default/Dockerfile.dev +0 -18
- package/lib/default/Dockerfile.prod +0 -18
- package/lib/default/docker-compose.yml +0 -35
- package/lib/default/ecosystem.config.js +0 -57
- package/lib/default/jest.config.js +0 -12
- package/lib/default/nginx.conf +0 -40
- package/lib/default/nodemon.json +0 -12
- package/lib/default/package.json +0 -76
- package/lib/default/src/app.ts +0 -81
- package/lib/default/src/config/index.ts +0 -5
- package/lib/default/src/controllers/auth.controller.ts +0 -44
- package/lib/default/src/controllers/users.controller.ts +0 -63
- package/lib/default/src/dtos/users.dto.ts +0 -20
- package/lib/default/src/exceptions/HttpException.ts +0 -10
- package/lib/default/src/http/auth.http +0 -27
- package/lib/default/src/http/users.http +0 -34
- package/lib/default/src/interfaces/auth.interface.ts +0 -15
- package/lib/default/src/interfaces/users.interface.ts +0 -5
- package/lib/default/src/middlewares/auth.middleware.ts +0 -38
- package/lib/default/src/middlewares/error.middleware.ts +0 -15
- package/lib/default/src/middlewares/validation.middleware.ts +0 -27
- package/lib/default/src/models/users.model.ts +0 -9
- package/lib/default/src/routes/auth.route.ts +0 -21
- package/lib/default/src/routes/users.route.ts +0 -23
- package/lib/default/src/server.ts +0 -10
- package/lib/default/src/services/auth.service.ts +0 -52
- package/lib/default/src/services/users.service.ts +0 -51
- package/lib/default/src/test/auth.test.ts +0 -52
- package/lib/default/src/test/users.test.ts +0 -62
- package/lib/default/src/utils/logger.ts +0 -65
- package/lib/default/src/utils/validateEnv.ts +0 -8
- package/lib/default/swagger.yaml +0 -123
- package/lib/default/tsconfig.json +0 -39
- package/lib/graphql/.dockerignore +0 -18
- package/lib/graphql/.editorconfig +0 -9
- package/lib/graphql/.env.development.local +0 -20
- package/lib/graphql/.env.production.local +0 -20
- package/lib/graphql/.env.test.local +0 -20
- package/lib/graphql/.eslintignore +0 -1
- package/lib/graphql/.eslintrc +0 -18
- package/lib/graphql/.huskyrc +0 -5
- package/lib/graphql/.lintstagedrc.json +0 -5
- package/lib/graphql/.prettierrc +0 -8
- package/lib/graphql/.swcrc +0 -40
- package/lib/graphql/.vscode/launch.json +0 -35
- package/lib/graphql/.vscode/settings.json +0 -6
- package/lib/graphql/Dockerfile.dev +0 -19
- package/lib/graphql/Dockerfile.prod +0 -19
- package/lib/graphql/Makefile +0 -46
- package/lib/graphql/docker-compose.yml +0 -58
- package/lib/graphql/ecosystem.config.js +0 -59
- package/lib/graphql/jest.config.js +0 -12
- package/lib/graphql/nginx.conf +0 -40
- package/lib/graphql/nodemon.json +0 -12
- package/lib/graphql/package.json +0 -75
- package/lib/graphql/src/app.ts +0 -107
- package/lib/graphql/src/config/index.ts +0 -6
- package/lib/graphql/src/database/index.ts +0 -26
- package/lib/graphql/src/dtos/users.dto.ts +0 -27
- package/lib/graphql/src/entities/users.entity.ts +0 -26
- package/lib/graphql/src/exceptions/HttpException.ts +0 -10
- package/lib/graphql/src/http/auth.http +0 -49
- package/lib/graphql/src/http/users.http +0 -78
- package/lib/graphql/src/interfaces/auth.interface.ts +0 -14
- package/lib/graphql/src/interfaces/users.interface.ts +0 -5
- package/lib/graphql/src/middlewares/auth.middleware.ts +0 -42
- package/lib/graphql/src/middlewares/error.middleware.ts +0 -15
- package/lib/graphql/src/repositories/auth.repository.ts +0 -53
- package/lib/graphql/src/repositories/users.repository.ts +0 -51
- package/lib/graphql/src/resolvers/auth.resolver.ts +0 -32
- package/lib/graphql/src/resolvers/users.resolver.ts +0 -47
- package/lib/graphql/src/server.ts +0 -10
- package/lib/graphql/src/test/auth.test.ts +0 -10
- package/lib/graphql/src/test/users.test.ts +0 -11
- package/lib/graphql/src/typedefs/users.type.ts +0 -13
- package/lib/graphql/src/utils/logger.ts +0 -77
- package/lib/graphql/src/utils/validateEnv.ts +0 -8
- package/lib/graphql/tsconfig.json +0 -40
- package/lib/knex/.dockerignore +0 -18
- package/lib/knex/.editorconfig +0 -9
- package/lib/knex/.env.development.local +0 -20
- package/lib/knex/.env.production.local +0 -20
- package/lib/knex/.env.test.local +0 -20
- package/lib/knex/.eslintignore +0 -1
- package/lib/knex/.eslintrc +0 -18
- package/lib/knex/.huskyrc +0 -5
- package/lib/knex/.lintstagedrc.json +0 -5
- package/lib/knex/.prettierrc +0 -8
- package/lib/knex/.swcrc +0 -40
- package/lib/knex/.vscode/launch.json +0 -35
- package/lib/knex/.vscode/settings.json +0 -6
- package/lib/knex/Dockerfile.dev +0 -19
- package/lib/knex/Dockerfile.prod +0 -19
- package/lib/knex/Makefile +0 -46
- package/lib/knex/docker-compose.yml +0 -55
- package/lib/knex/ecosystem.config.js +0 -57
- package/lib/knex/jest.config.js +0 -12
- package/lib/knex/knexfile.ts +0 -23
- package/lib/knex/nginx.conf +0 -40
- package/lib/knex/nodemon.json +0 -12
- package/lib/knex/package.json +0 -85
- package/lib/knex/src/app.ts +0 -87
- package/lib/knex/src/config/index.ts +0 -6
- package/lib/knex/src/controllers/auth.controller.ts +0 -44
- package/lib/knex/src/controllers/users.controller.ts +0 -63
- package/lib/knex/src/database/index.ts +0 -24
- package/lib/knex/src/database/migrations/.gitkeep +0 -0
- package/lib/knex/src/database/migrations/20210713110926_initial.ts +0 -17
- package/lib/knex/src/database/seeds/.gitkeep +0 -0
- package/lib/knex/src/dtos/users.dto.ts +0 -20
- package/lib/knex/src/exceptions/HttpException.ts +0 -10
- package/lib/knex/src/http/auth.http +0 -27
- package/lib/knex/src/http/users.http +0 -34
- package/lib/knex/src/interfaces/routes.interface.ts +0 -6
- package/lib/knex/src/interfaces/users.interface.ts +0 -5
- package/lib/knex/src/middlewares/auth.middleware.ts +0 -40
- package/lib/knex/src/middlewares/error.middleware.ts +0 -15
- package/lib/knex/src/middlewares/validation.middleware.ts +0 -27
- package/lib/knex/src/models/users.model.ts +0 -13
- package/lib/knex/src/routes/auth.route.ts +0 -22
- package/lib/knex/src/routes/users.route.ts +0 -23
- package/lib/knex/src/server.ts +0 -10
- package/lib/knex/src/services/auth.service.ts +0 -60
- package/lib/knex/src/services/users.service.ts +0 -55
- package/lib/knex/src/test/auth.test.ts +0 -51
- package/lib/knex/src/test/users.test.ts +0 -65
- package/lib/knex/src/utils/logger.ts +0 -65
- package/lib/knex/src/utils/validateEnv.ts +0 -8
- package/lib/knex/swagger.yaml +0 -123
- package/lib/knex/tsconfig.json +0 -40
- package/lib/mikro-orm/.dockerignore +0 -18
- package/lib/mikro-orm/.editorconfig +0 -9
- package/lib/mikro-orm/.env.development.local +0 -18
- package/lib/mikro-orm/.env.production.local +0 -18
- package/lib/mikro-orm/.env.test.local +0 -18
- package/lib/mikro-orm/.eslintignore +0 -1
- package/lib/mikro-orm/.eslintrc +0 -18
- package/lib/mikro-orm/.huskyrc +0 -5
- package/lib/mikro-orm/.lintstagedrc.json +0 -5
- package/lib/mikro-orm/.prettierrc +0 -8
- package/lib/mikro-orm/.swcrc +0 -41
- package/lib/mikro-orm/.vscode/launch.json +0 -35
- package/lib/mikro-orm/.vscode/settings.json +0 -6
- package/lib/mikro-orm/Dockerfile.dev +0 -19
- package/lib/mikro-orm/Dockerfile.prod +0 -19
- package/lib/mikro-orm/Makefile +0 -46
- package/lib/mikro-orm/docker-compose.yml +0 -55
- package/lib/mikro-orm/ecosystem.config.js +0 -57
- package/lib/mikro-orm/jest.config.js +0 -12
- package/lib/mikro-orm/nginx.conf +0 -40
- package/lib/mikro-orm/nodemon.json +0 -12
- package/lib/mikro-orm/package.json +0 -79
- package/lib/mikro-orm/src/app.ts +0 -97
- package/lib/mikro-orm/src/config/index.ts +0 -6
- package/lib/mikro-orm/src/controllers/auth.controller.ts +0 -44
- package/lib/mikro-orm/src/controllers/users.controller.ts +0 -63
- package/lib/mikro-orm/src/database/index.ts +0 -19
- package/lib/mikro-orm/src/dtos/users.dto.ts +0 -20
- package/lib/mikro-orm/src/entities/base.entity.ts +0 -16
- package/lib/mikro-orm/src/entities/users.entity.ts +0 -17
- package/lib/mikro-orm/src/exceptions/HttpException.ts +0 -10
- package/lib/mikro-orm/src/http/auth.http +0 -32
- package/lib/mikro-orm/src/http/users.http +0 -34
- package/lib/mikro-orm/src/interfaces/auth.interface.ts +0 -15
- package/lib/mikro-orm/src/interfaces/routes.interface.ts +0 -6
- package/lib/mikro-orm/src/interfaces/users.interface.ts +0 -5
- package/lib/mikro-orm/src/middlewares/auth.middleware.ts +0 -39
- package/lib/mikro-orm/src/middlewares/error.middleware.ts +0 -15
- package/lib/mikro-orm/src/middlewares/validation.middleware.ts +0 -27
- package/lib/mikro-orm/src/routes/auth.route.ts +0 -22
- package/lib/mikro-orm/src/routes/users.route.ts +0 -23
- package/lib/mikro-orm/src/server.ts +0 -10
- package/lib/mikro-orm/src/services/auth.service.ts +0 -53
- package/lib/mikro-orm/src/services/users.service.ts +0 -60
- package/lib/mikro-orm/src/test/auth.test.ts +0 -65
- package/lib/mikro-orm/src/test/users.test.ts +0 -69
- package/lib/mikro-orm/src/utils/logger.ts +0 -65
- package/lib/mikro-orm/src/utils/validateEnv.ts +0 -8
- package/lib/mikro-orm/swagger.yaml +0 -122
- package/lib/mikro-orm/tsconfig.json +0 -41
- package/lib/mongoose/.dockerignore +0 -18
- package/lib/mongoose/.editorconfig +0 -9
- package/lib/mongoose/.env.development.local +0 -18
- package/lib/mongoose/.env.production.local +0 -18
- package/lib/mongoose/.env.test.local +0 -18
- package/lib/mongoose/.eslintignore +0 -1
- package/lib/mongoose/.eslintrc +0 -18
- package/lib/mongoose/.huskyrc +0 -5
- package/lib/mongoose/.lintstagedrc.json +0 -5
- package/lib/mongoose/.prettierrc +0 -8
- package/lib/mongoose/.swcrc +0 -40
- package/lib/mongoose/.vscode/launch.json +0 -35
- package/lib/mongoose/.vscode/settings.json +0 -6
- package/lib/mongoose/Dockerfile.dev +0 -19
- package/lib/mongoose/Dockerfile.prod +0 -19
- package/lib/mongoose/Makefile +0 -46
- package/lib/mongoose/docker-compose.yml +0 -55
- package/lib/mongoose/ecosystem.config.js +0 -57
- package/lib/mongoose/jest.config.js +0 -12
- package/lib/mongoose/nginx.conf +0 -40
- package/lib/mongoose/nodemon.json +0 -12
- package/lib/mongoose/package.json +0 -78
- package/lib/mongoose/src/app.ts +0 -87
- package/lib/mongoose/src/config/index.ts +0 -6
- package/lib/mongoose/src/controllers/auth.controller.ts +0 -44
- package/lib/mongoose/src/controllers/users.controller.ts +0 -63
- package/lib/mongoose/src/database/index.ts +0 -18
- package/lib/mongoose/src/dtos/users.dto.ts +0 -20
- package/lib/mongoose/src/exceptions/HttpException.ts +0 -10
- package/lib/mongoose/src/http/auth.http +0 -27
- package/lib/mongoose/src/http/users.http +0 -34
- package/lib/mongoose/src/interfaces/auth.interface.ts +0 -15
- package/lib/mongoose/src/interfaces/routes.interface.ts +0 -6
- package/lib/mongoose/src/interfaces/users.interface.ts +0 -5
- package/lib/mongoose/src/middlewares/auth.middleware.ts +0 -39
- package/lib/mongoose/src/middlewares/error.middleware.ts +0 -15
- package/lib/mongoose/src/middlewares/validation.middleware.ts +0 -27
- package/lib/mongoose/src/models/users.model.ts +0 -16
- package/lib/mongoose/src/routes/auth.route.ts +0 -22
- package/lib/mongoose/src/routes/users.route.ts +0 -23
- package/lib/mongoose/src/server.ts +0 -10
- package/lib/mongoose/src/services/auth.service.ts +0 -52
- package/lib/mongoose/src/services/users.service.ts +0 -54
- package/lib/mongoose/src/test/auth.test.ts +0 -83
- package/lib/mongoose/src/test/index.test.ts +0 -18
- package/lib/mongoose/src/test/users.test.ts +0 -133
- package/lib/mongoose/src/utils/logger.ts +0 -65
- package/lib/mongoose/src/utils/validateEnv.ts +0 -8
- package/lib/mongoose/swagger.yaml +0 -120
- package/lib/mongoose/tsconfig.json +0 -40
- package/lib/node-postgres/.dockerignore +0 -18
- package/lib/node-postgres/.editorconfig +0 -9
- package/lib/node-postgres/.env.development.local +0 -20
- package/lib/node-postgres/.env.production.local +0 -20
- package/lib/node-postgres/.env.test.local +0 -20
- package/lib/node-postgres/.eslintignore +0 -1
- package/lib/node-postgres/.eslintrc +0 -18
- package/lib/node-postgres/.huskyrc +0 -5
- package/lib/node-postgres/.lintstagedrc.json +0 -5
- package/lib/node-postgres/.prettierrc +0 -8
- package/lib/node-postgres/.swcrc +0 -38
- package/lib/node-postgres/.vscode/launch.json +0 -35
- package/lib/node-postgres/.vscode/settings.json +0 -6
- package/lib/node-postgres/Dockerfile.dev +0 -17
- package/lib/node-postgres/Dockerfile.prod +0 -17
- package/lib/node-postgres/Makefile +0 -46
- package/lib/node-postgres/docker-compose.yml +0 -61
- package/lib/node-postgres/ecosystem.config.js +0 -57
- package/lib/node-postgres/jest.config.js +0 -12
- package/lib/node-postgres/nginx.conf +0 -40
- package/lib/node-postgres/nodemon.json +0 -12
- package/lib/node-postgres/package.json +0 -78
- package/lib/node-postgres/src/app.ts +0 -81
- package/lib/node-postgres/src/config/index.ts +0 -6
- package/lib/node-postgres/src/controllers/auth.controller.ts +0 -44
- package/lib/node-postgres/src/controllers/users.controller.ts +0 -63
- package/lib/node-postgres/src/database/index.ts +0 -10
- package/lib/node-postgres/src/database/init.sql +0 -13
- package/lib/node-postgres/src/dtos/users.dto.ts +0 -20
- package/lib/node-postgres/src/exceptions/httpException.ts +0 -10
- package/lib/node-postgres/src/http/auth.http +0 -27
- package/lib/node-postgres/src/http/users.http +0 -34
- package/lib/node-postgres/src/interfaces/auth.interface.ts +0 -15
- package/lib/node-postgres/src/interfaces/routes.interface.ts +0 -6
- package/lib/node-postgres/src/interfaces/users.interface.ts +0 -5
- package/lib/node-postgres/src/middlewares/auth.middleware.ts +0 -46
- package/lib/node-postgres/src/middlewares/error.middleware.ts +0 -15
- package/lib/node-postgres/src/middlewares/validation.middleware.ts +0 -27
- package/lib/node-postgres/src/routes/auth.route.ts +0 -21
- package/lib/node-postgres/src/routes/users.route.ts +0 -23
- package/lib/node-postgres/src/server.ts +0 -10
- package/lib/node-postgres/src/services/auth.service.ts +0 -103
- package/lib/node-postgres/src/services/users.service.ts +0 -133
- package/lib/node-postgres/src/test/auth.test.ts +0 -57
- package/lib/node-postgres/src/test/users.test.ts +0 -72
- package/lib/node-postgres/src/utils/logger.ts +0 -65
- package/lib/node-postgres/src/utils/validateEnv.ts +0 -8
- package/lib/node-postgres/swagger.yaml +0 -123
- package/lib/node-postgres/tsconfig.json +0 -39
- package/lib/prisma/.dockerignore +0 -18
- package/lib/prisma/.editorconfig +0 -9
- package/lib/prisma/.env.development.local +0 -16
- package/lib/prisma/.env.production.local +0 -16
- package/lib/prisma/.env.test.local +0 -16
- package/lib/prisma/.eslintignore +0 -1
- package/lib/prisma/.eslintrc +0 -18
- package/lib/prisma/.huskyrc +0 -5
- package/lib/prisma/.lintstagedrc.json +0 -5
- package/lib/prisma/.prettierrc +0 -8
- package/lib/prisma/.vscode/launch.json +0 -35
- package/lib/prisma/.vscode/settings.json +0 -6
- package/lib/prisma/Dockerfile.dev +0 -19
- package/lib/prisma/Dockerfile.prod +0 -19
- package/lib/prisma/Makefile +0 -46
- package/lib/prisma/docker-compose.yml +0 -51
- package/lib/prisma/ecosystem.config.js +0 -57
- package/lib/prisma/jest.config.js +0 -12
- package/lib/prisma/nginx.conf +0 -40
- package/lib/prisma/nodemon.json +0 -12
- package/lib/prisma/package.json +0 -84
- package/lib/prisma/src/app.ts +0 -81
- package/lib/prisma/src/config/index.ts +0 -5
- package/lib/prisma/src/controllers/auth.controller.ts +0 -44
- package/lib/prisma/src/controllers/users.controller.ts +0 -63
- package/lib/prisma/src/dtos/users.dto.ts +0 -20
- package/lib/prisma/src/exceptions/HttpException.ts +0 -10
- package/lib/prisma/src/http/auth.http +0 -27
- package/lib/prisma/src/http/users.http +0 -34
- package/lib/prisma/src/interfaces/auth.interface.ts +0 -15
- package/lib/prisma/src/interfaces/routes.interface.ts +0 -6
- package/lib/prisma/src/interfaces/users.interface.ts +0 -5
- package/lib/prisma/src/middlewares/auth.middleware.ts +0 -39
- package/lib/prisma/src/middlewares/error.middleware.ts +0 -15
- package/lib/prisma/src/middlewares/validation.middleware.ts +0 -27
- package/lib/prisma/src/prisma/migrations/20210314081925_initial/migration.sql +0 -9
- package/lib/prisma/src/prisma/migrations/migration_lock.toml +0 -3
- package/lib/prisma/src/prisma/schema.prisma +0 -17
- package/lib/prisma/src/routes/auth.route.ts +0 -22
- package/lib/prisma/src/routes/users.route.ts +0 -23
- package/lib/prisma/src/server.ts +0 -10
- package/lib/prisma/src/services/auth.service.ts +0 -56
- package/lib/prisma/src/services/users.service.ts +0 -49
- package/lib/prisma/src/test/auth.test.ts +0 -81
- package/lib/prisma/src/test/index.test.ts +0 -18
- package/lib/prisma/src/test/users.test.ts +0 -134
- package/lib/prisma/src/utils/logger.ts +0 -65
- package/lib/prisma/src/utils/validateEnv.ts +0 -8
- package/lib/prisma/swagger.yaml +0 -123
- package/lib/prisma/tsconfig.json +0 -38
- package/lib/routing-controllers/.dockerignore +0 -18
- package/lib/routing-controllers/.editorconfig +0 -9
- package/lib/routing-controllers/.env.development.local +0 -13
- package/lib/routing-controllers/.env.production.local +0 -13
- package/lib/routing-controllers/.env.test.local +0 -13
- package/lib/routing-controllers/.eslintignore +0 -1
- package/lib/routing-controllers/.eslintrc +0 -18
- package/lib/routing-controllers/.huskyrc +0 -5
- package/lib/routing-controllers/.lintstagedrc.json +0 -5
- package/lib/routing-controllers/.prettierrc +0 -8
- package/lib/routing-controllers/.swcrc +0 -38
- package/lib/routing-controllers/.vscode/launch.json +0 -35
- package/lib/routing-controllers/.vscode/settings.json +0 -6
- package/lib/routing-controllers/Dockerfile.dev +0 -19
- package/lib/routing-controllers/Dockerfile.prod +0 -19
- package/lib/routing-controllers/Makefile +0 -42
- package/lib/routing-controllers/docker-compose.yml +0 -35
- package/lib/routing-controllers/ecosystem.config.js +0 -57
- package/lib/routing-controllers/jest.config.js +0 -12
- package/lib/routing-controllers/nginx.conf +0 -40
- package/lib/routing-controllers/nodemon.json +0 -12
- package/lib/routing-controllers/package.json +0 -77
- package/lib/routing-controllers/src/app.ts +0 -101
- package/lib/routing-controllers/src/config/index.ts +0 -5
- package/lib/routing-controllers/src/controllers/auth.controller.ts +0 -41
- package/lib/routing-controllers/src/controllers/users.controller.ts +0 -51
- package/lib/routing-controllers/src/dtos/users.dto.ts +0 -20
- package/lib/routing-controllers/src/exceptions/HttpException.ts +0 -12
- package/lib/routing-controllers/src/http/auth.http +0 -27
- package/lib/routing-controllers/src/http/users.http +0 -34
- package/lib/routing-controllers/src/interfaces/auth.interface.ts +0 -15
- package/lib/routing-controllers/src/interfaces/users.interface.ts +0 -5
- package/lib/routing-controllers/src/middlewares/auth.middleware.ts +0 -38
- package/lib/routing-controllers/src/middlewares/error.middleware.ts +0 -15
- package/lib/routing-controllers/src/middlewares/validation.middleware.ts +0 -27
- package/lib/routing-controllers/src/models/users.model.ts +0 -9
- package/lib/routing-controllers/src/server.ts +0 -9
- package/lib/routing-controllers/src/services/auth.service.ts +0 -53
- package/lib/routing-controllers/src/services/users.service.ts +0 -52
- package/lib/routing-controllers/src/test/auth.test.ts +0 -49
- package/lib/routing-controllers/src/test/users.test.ts +0 -65
- package/lib/routing-controllers/src/utils/logger.ts +0 -65
- package/lib/routing-controllers/src/utils/validateEnv.ts +0 -8
- package/lib/routing-controllers/tsconfig.json +0 -38
- package/lib/sequelize/.dockerignore +0 -18
- package/lib/sequelize/.editorconfig +0 -9
- package/lib/sequelize/.env.development.local +0 -20
- package/lib/sequelize/.env.production.local +0 -20
- package/lib/sequelize/.env.test.local +0 -20
- package/lib/sequelize/.eslintignore +0 -1
- package/lib/sequelize/.eslintrc +0 -18
- package/lib/sequelize/.huskyrc +0 -5
- package/lib/sequelize/.lintstagedrc.json +0 -5
- package/lib/sequelize/.prettierrc +0 -8
- package/lib/sequelize/.sequelizerc +0 -8
- package/lib/sequelize/.swcrc +0 -40
- package/lib/sequelize/.vscode/launch.json +0 -35
- package/lib/sequelize/.vscode/settings.json +0 -6
- package/lib/sequelize/Dockerfile.dev +0 -23
- package/lib/sequelize/Dockerfile.prod +0 -23
- package/lib/sequelize/Makefile +0 -46
- package/lib/sequelize/docker-compose.yml +0 -55
- package/lib/sequelize/docker-entrypoint.sh +0 -5
- package/lib/sequelize/ecosystem.config.js +0 -57
- package/lib/sequelize/jest.config.js +0 -12
- package/lib/sequelize/nginx.conf +0 -40
- package/lib/sequelize/nodemon.json +0 -12
- package/lib/sequelize/package.json +0 -82
- package/lib/sequelize/src/app.ts +0 -87
- package/lib/sequelize/src/config/index.ts +0 -6
- package/lib/sequelize/src/config/sequelize-cli.js +0 -15
- package/lib/sequelize/src/controllers/auth.controller.ts +0 -45
- package/lib/sequelize/src/controllers/users.controller.ts +0 -64
- package/lib/sequelize/src/database/index.ts +0 -34
- package/lib/sequelize/src/database/migrations/.gitkeep +0 -0
- package/lib/sequelize/src/database/seeders/.gitkeep +0 -0
- package/lib/sequelize/src/dtos/users.dto.ts +0 -20
- package/lib/sequelize/src/exceptions/HttpException.ts +0 -10
- package/lib/sequelize/src/http/auth.http +0 -27
- package/lib/sequelize/src/http/users.http +0 -34
- package/lib/sequelize/src/interfaces/auth.interface.ts +0 -15
- package/lib/sequelize/src/interfaces/routes.interface.ts +0 -6
- package/lib/sequelize/src/interfaces/users.interface.ts +0 -5
- package/lib/sequelize/src/middlewares/auth.middleware.ts +0 -38
- package/lib/sequelize/src/middlewares/error.middleware.ts +0 -15
- package/lib/sequelize/src/middlewares/validation.middleware.ts +0 -27
- package/lib/sequelize/src/models/users.model.ts +0 -39
- package/lib/sequelize/src/routes/auth.route.ts +0 -21
- package/lib/sequelize/src/routes/users.route.ts +0 -23
- package/lib/sequelize/src/server.ts +0 -10
- package/lib/sequelize/src/services/auth.service.ts +0 -52
- package/lib/sequelize/src/services/users.service.ts +0 -50
- package/lib/sequelize/src/test/auth.test.ts +0 -71
- package/lib/sequelize/src/test/users.test.ts +0 -131
- package/lib/sequelize/src/utils/logger.ts +0 -65
- package/lib/sequelize/src/utils/validateEnv.ts +0 -8
- package/lib/sequelize/swagger.yaml +0 -123
- package/lib/sequelize/tsconfig.json +0 -40
- package/lib/starter.js +0 -262
- package/lib/typegoose/.dockerignore +0 -18
- package/lib/typegoose/.editorconfig +0 -9
- package/lib/typegoose/.env.development.local +0 -18
- package/lib/typegoose/.env.production.local +0 -18
- package/lib/typegoose/.env.test.local +0 -18
- package/lib/typegoose/.eslintignore +0 -1
- package/lib/typegoose/.eslintrc +0 -18
- package/lib/typegoose/.huskyrc +0 -5
- package/lib/typegoose/.lintstagedrc.json +0 -5
- package/lib/typegoose/.prettierrc +0 -8
- package/lib/typegoose/.swcrc +0 -40
- package/lib/typegoose/.vscode/launch.json +0 -35
- package/lib/typegoose/.vscode/settings.json +0 -6
- package/lib/typegoose/Dockerfile.dev +0 -19
- package/lib/typegoose/Dockerfile.prod +0 -19
- package/lib/typegoose/Makefile +0 -46
- package/lib/typegoose/docker-compose.yml +0 -55
- package/lib/typegoose/ecosystem.config.js +0 -57
- package/lib/typegoose/jest.config.js +0 -12
- package/lib/typegoose/nginx.conf +0 -40
- package/lib/typegoose/nodemon.json +0 -12
- package/lib/typegoose/package.json +0 -79
- package/lib/typegoose/src/app.ts +0 -90
- package/lib/typegoose/src/config/index.ts +0 -6
- package/lib/typegoose/src/controllers/auth.controller.ts +0 -44
- package/lib/typegoose/src/controllers/users.controller.ts +0 -63
- package/lib/typegoose/src/database/index.ts +0 -18
- package/lib/typegoose/src/dtos/users.dto.ts +0 -20
- package/lib/typegoose/src/exceptions/HttpException.ts +0 -10
- package/lib/typegoose/src/http/auth.http +0 -27
- package/lib/typegoose/src/http/users.http +0 -34
- package/lib/typegoose/src/interfaces/auth.interface.ts +0 -15
- package/lib/typegoose/src/interfaces/routes.interface.ts +0 -6
- package/lib/typegoose/src/interfaces/users.interface.ts +0 -5
- package/lib/typegoose/src/middlewares/auth.middleware.ts +0 -38
- package/lib/typegoose/src/middlewares/error.middleware.ts +0 -15
- package/lib/typegoose/src/middlewares/validation.middleware.ts +0 -27
- package/lib/typegoose/src/models/users.model.ts +0 -16
- package/lib/typegoose/src/routes/auth.route.ts +0 -21
- package/lib/typegoose/src/routes/users.route.ts +0 -23
- package/lib/typegoose/src/server.ts +0 -10
- package/lib/typegoose/src/services/auth.service.ts +0 -52
- package/lib/typegoose/src/services/users.service.ts +0 -55
- package/lib/typegoose/src/test/auth.test.ts +0 -83
- package/lib/typegoose/src/test/users.test.ts +0 -133
- package/lib/typegoose/src/utils/logger.ts +0 -65
- package/lib/typegoose/src/utils/validateEnv.ts +0 -8
- package/lib/typegoose/swagger.yaml +0 -120
- package/lib/typegoose/tsconfig.json +0 -40
- package/lib/typeorm/.dockerignore +0 -18
- package/lib/typeorm/.editorconfig +0 -9
- package/lib/typeorm/.env.development.local +0 -20
- package/lib/typeorm/.env.production.local +0 -20
- package/lib/typeorm/.env.test.local +0 -20
- package/lib/typeorm/.eslintignore +0 -1
- package/lib/typeorm/.eslintrc +0 -18
- package/lib/typeorm/.huskyrc +0 -5
- package/lib/typeorm/.lintstagedrc.json +0 -5
- package/lib/typeorm/.prettierrc +0 -8
- package/lib/typeorm/.swcrc +0 -40
- package/lib/typeorm/.vscode/launch.json +0 -35
- package/lib/typeorm/.vscode/settings.json +0 -6
- package/lib/typeorm/Dockerfile.dev +0 -19
- package/lib/typeorm/Dockerfile.prod +0 -19
- package/lib/typeorm/Makefile +0 -46
- package/lib/typeorm/docker-compose.yml +0 -57
- package/lib/typeorm/ecosystem.config.js +0 -57
- package/lib/typeorm/jest.config.js +0 -12
- package/lib/typeorm/nginx.conf +0 -40
- package/lib/typeorm/nodemon.json +0 -12
- package/lib/typeorm/package.json +0 -78
- package/lib/typeorm/src/app.ts +0 -87
- package/lib/typeorm/src/config/index.ts +0 -6
- package/lib/typeorm/src/controllers/auth.controller.ts +0 -44
- package/lib/typeorm/src/controllers/users.controller.ts +0 -63
- package/lib/typeorm/src/database/index.ts +0 -26
- package/lib/typeorm/src/database/migrations/.gitkeep +0 -0
- package/lib/typeorm/src/dtos/users.dto.ts +0 -20
- package/lib/typeorm/src/entities/users.entity.ts +0 -26
- package/lib/typeorm/src/exceptions/HttpException.ts +0 -10
- package/lib/typeorm/src/http/auth.http +0 -27
- package/lib/typeorm/src/http/users.http +0 -34
- package/lib/typeorm/src/interfaces/auth.interface.ts +0 -15
- package/lib/typeorm/src/interfaces/routes.interface.ts +0 -6
- package/lib/typeorm/src/interfaces/users.interface.ts +0 -5
- package/lib/typeorm/src/middlewares/auth.middleware.ts +0 -38
- package/lib/typeorm/src/middlewares/error.middleware.ts +0 -15
- package/lib/typeorm/src/middlewares/validation.middleware.ts +0 -27
- package/lib/typeorm/src/routes/auth.route.ts +0 -21
- package/lib/typeorm/src/routes/users.route.ts +0 -23
- package/lib/typeorm/src/server.ts +0 -10
- package/lib/typeorm/src/services/auth.service.ts +0 -54
- package/lib/typeorm/src/services/users.service.ts +0 -51
- package/lib/typeorm/src/test/auth.test.ts +0 -75
- package/lib/typeorm/src/test/users.test.ts +0 -136
- package/lib/typeorm/src/utils/logger.ts +0 -65
- package/lib/typeorm/src/utils/validateEnv.ts +0 -8
- package/lib/typeorm/swagger.yaml +0 -123
- /package/{lib → templates}/default/src/interfaces/routes.interface.ts +0 -0
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
import { User, type UserCreateData } from '@entities/user.entity';
|
|
2
|
+
import { UsersRepository } from '@repositories/users.repository';
|
|
3
|
+
import { UsersService } from '@services/users.service';
|
|
4
|
+
|
|
5
|
+
describe('UsersService (with UsersRepository)', () => {
|
|
6
|
+
let usersService: UsersService;
|
|
7
|
+
let userRepo: UsersRepository;
|
|
8
|
+
|
|
9
|
+
beforeEach(async () => {
|
|
10
|
+
userRepo = new UsersRepository();
|
|
11
|
+
userRepo.reset();
|
|
12
|
+
|
|
13
|
+
// Create test users using Entity
|
|
14
|
+
const user1 = await User.create({
|
|
15
|
+
email: 'one@example.com',
|
|
16
|
+
password: 'password1',
|
|
17
|
+
});
|
|
18
|
+
const user2 = await User.create({
|
|
19
|
+
email: 'two@example.com',
|
|
20
|
+
password: 'password2',
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
await userRepo.save(user1);
|
|
24
|
+
await userRepo.save(user2);
|
|
25
|
+
usersService = new UsersService(userRepo);
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
it('getAllUsers: should return all users', async () => {
|
|
29
|
+
const users = await usersService.getAllUsers();
|
|
30
|
+
expect(users.length).toBe(2);
|
|
31
|
+
expect(users.map((u) => u.email)).toContain('one@example.com');
|
|
32
|
+
expect(users.map((u) => u.email)).toContain('two@example.com');
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
it('getUserById: should return user by ID', async () => {
|
|
36
|
+
const users = await usersService.getAllUsers();
|
|
37
|
+
const targetUser = users.find((u) => u.email === 'two@example.com');
|
|
38
|
+
expect(targetUser).toBeDefined();
|
|
39
|
+
|
|
40
|
+
const user = await usersService.getUserById(targetUser!.id);
|
|
41
|
+
expect(user.email).toBe('two@example.com');
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
it('getUserById: should throw if ID does not exist', async () => {
|
|
45
|
+
await expect(usersService.getUserById('999')).rejects.toThrow(/not found/);
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
it('createUser: should add a new user', async () => {
|
|
49
|
+
const userData: UserCreateData = {
|
|
50
|
+
email: 'new@example.com',
|
|
51
|
+
password: 'newpass3',
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
const created = await usersService.createUser(userData);
|
|
55
|
+
expect(created.email).toBe('new@example.com');
|
|
56
|
+
const all = await usersService.getAllUsers();
|
|
57
|
+
expect(all.length).toBe(3);
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
it('createUser: should throw if email already exists', async () => {
|
|
61
|
+
const userData: UserCreateData = {
|
|
62
|
+
email: 'one@example.com', // already exists
|
|
63
|
+
password: 'password9',
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
await expect(usersService.createUser(userData)).rejects.toThrow(/exists/);
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
it('updateUser: should update user password', async () => {
|
|
70
|
+
const users = await usersService.getAllUsers();
|
|
71
|
+
const targetUser = users.find((u) => u.email === 'two@example.com');
|
|
72
|
+
expect(targetUser).toBeDefined();
|
|
73
|
+
|
|
74
|
+
const updateData = {
|
|
75
|
+
email: 'updated@example.com',
|
|
76
|
+
password: 'newpass1',
|
|
77
|
+
};
|
|
78
|
+
|
|
79
|
+
const updated = await usersService.updateUser(targetUser!.id, updateData);
|
|
80
|
+
expect(updated).toBeDefined();
|
|
81
|
+
expect(updated.email).toBe('updated@example.com');
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
it('updateUser: should throw if ID does not exist', async () => {
|
|
85
|
+
const updateData = {
|
|
86
|
+
email: 'no@no.com',
|
|
87
|
+
password: 'nopass12',
|
|
88
|
+
};
|
|
89
|
+
|
|
90
|
+
await expect(usersService.updateUser('nonexistent-id', updateData)).rejects.toThrow(
|
|
91
|
+
/not found/,
|
|
92
|
+
);
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
it('deleteUser: should delete user successfully', async () => {
|
|
96
|
+
const users = await usersService.getAllUsers();
|
|
97
|
+
const userToDelete = users.find((u) => u.email === 'one@example.com');
|
|
98
|
+
expect(userToDelete).toBeDefined();
|
|
99
|
+
|
|
100
|
+
await usersService.deleteUser(userToDelete!.id);
|
|
101
|
+
const remaining = await usersService.getAllUsers();
|
|
102
|
+
expect(remaining.length).toBe(1);
|
|
103
|
+
expect(remaining.find((u) => u.id === userToDelete!.id)).toBeUndefined();
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
it('deleteUser: should throw if ID does not exist', async () => {
|
|
107
|
+
await expect(usersService.deleteUser('nonexistent-id')).rejects.toThrow(/not found/);
|
|
108
|
+
});
|
|
109
|
+
});
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "./node_modules/oxlint/configuration_schema.json",
|
|
3
|
+
"ignorePatterns": [
|
|
4
|
+
"node_modules/**",
|
|
5
|
+
"dist/**",
|
|
6
|
+
"build/**",
|
|
7
|
+
"coverage/**",
|
|
8
|
+
"logs/**",
|
|
9
|
+
"*.config.js",
|
|
10
|
+
"*.config.ts",
|
|
11
|
+
".env",
|
|
12
|
+
".env.*",
|
|
13
|
+
"!.eslintrc.js"
|
|
14
|
+
],
|
|
15
|
+
"env": {
|
|
16
|
+
"node": true,
|
|
17
|
+
"es2022": true
|
|
18
|
+
},
|
|
19
|
+
"plugins": [
|
|
20
|
+
"typescript",
|
|
21
|
+
"unicorn",
|
|
22
|
+
"oxc",
|
|
23
|
+
"import",
|
|
24
|
+
"node",
|
|
25
|
+
"promise"
|
|
26
|
+
],
|
|
27
|
+
"categories": {
|
|
28
|
+
"correctness": "error",
|
|
29
|
+
"suspicious": "warn",
|
|
30
|
+
"style": "off"
|
|
31
|
+
},
|
|
32
|
+
"rules": {
|
|
33
|
+
"eqeqeq": "warn"
|
|
34
|
+
},
|
|
35
|
+
"overrides": [
|
|
36
|
+
{
|
|
37
|
+
"files": [
|
|
38
|
+
"**/*.ts",
|
|
39
|
+
"**/*.tsx"
|
|
40
|
+
],
|
|
41
|
+
"rules": {
|
|
42
|
+
"typescript/no-explicit-any": "off",
|
|
43
|
+
"typescript/explicit-module-boundary-types": "off",
|
|
44
|
+
"typescript/ban-types": "off",
|
|
45
|
+
"typescript/no-var-requires": "off"
|
|
46
|
+
}
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
"files": [
|
|
50
|
+
"**/*.{spec,test}.ts"
|
|
51
|
+
],
|
|
52
|
+
"rules": {
|
|
53
|
+
"no-console": "off"
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
]
|
|
57
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
module.exports = {
|
|
2
|
+
apps: [
|
|
3
|
+
// --- PRODUCTION ---
|
|
4
|
+
{
|
|
5
|
+
name: 'prod',
|
|
6
|
+
script: 'dist/server.js',
|
|
7
|
+
exec_mode: 'cluster',
|
|
8
|
+
instances: 'max',
|
|
9
|
+
autorestart: true,
|
|
10
|
+
watch: false,
|
|
11
|
+
max_memory_restart: '1G',
|
|
12
|
+
output: './logs/access.log',
|
|
13
|
+
error: './logs/error.log',
|
|
14
|
+
merge_logs: true,
|
|
15
|
+
time: true, // 로그에 타임스탬프
|
|
16
|
+
log_date_format: 'YYYY-MM-DD HH:mm:ss.SSS',
|
|
17
|
+
node_args: '--enable-source-maps', // 소스맵 스택트레이스
|
|
18
|
+
env: {
|
|
19
|
+
PORT: 3000,
|
|
20
|
+
NODE_ENV: 'production',
|
|
21
|
+
},
|
|
22
|
+
// env_production: { ... } // 필요 시 분리도 가능
|
|
23
|
+
},
|
|
24
|
+
|
|
25
|
+
// --- DEVELOPMENT ---
|
|
26
|
+
{
|
|
27
|
+
name: 'dev',
|
|
28
|
+
script: 'src/server.ts',
|
|
29
|
+
interpreter: 'node',
|
|
30
|
+
node_args: '-r ts-node/register -r tsconfig-paths/register --enable-source-maps',
|
|
31
|
+
exec_mode: 'fork',
|
|
32
|
+
instances: 1,
|
|
33
|
+
autorestart: true,
|
|
34
|
+
watch: ['src'],
|
|
35
|
+
watch_delay: 300, // 저장 폭주 시 완충
|
|
36
|
+
ignore_watch: ['node_modules', 'logs', 'dist'],
|
|
37
|
+
max_memory_restart: '1G',
|
|
38
|
+
output: './logs/access.log',
|
|
39
|
+
error: './logs/error.log',
|
|
40
|
+
merge_logs: true,
|
|
41
|
+
time: true,
|
|
42
|
+
env: {
|
|
43
|
+
PORT: 3000,
|
|
44
|
+
NODE_ENV: 'development',
|
|
45
|
+
},
|
|
46
|
+
},
|
|
47
|
+
],
|
|
48
|
+
|
|
49
|
+
deploy: {
|
|
50
|
+
production: {
|
|
51
|
+
user: 'user',
|
|
52
|
+
host: '0.0.0.0',
|
|
53
|
+
ref: 'origin/master',
|
|
54
|
+
repo: 'git@github.com:repo.git',
|
|
55
|
+
path: '/home/user/app',
|
|
56
|
+
'post-deploy': 'npm install && npm run build && pm2 reload ecosystem.config.js --env production',
|
|
57
|
+
},
|
|
58
|
+
},
|
|
59
|
+
};
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
openapi: 3.0.0
|
|
2
|
+
info:
|
|
3
|
+
title: Express Typescript API
|
|
4
|
+
description: User API Docs
|
|
5
|
+
version: "1.0.0"
|
|
6
|
+
schemes:
|
|
7
|
+
- https
|
|
8
|
+
- http
|
|
9
|
+
tags:
|
|
10
|
+
- name: users
|
|
11
|
+
description: users API
|
|
12
|
+
paths:
|
|
13
|
+
/users:
|
|
14
|
+
get:
|
|
15
|
+
tags: [users]
|
|
16
|
+
summary: Find All Users
|
|
17
|
+
responses:
|
|
18
|
+
200:
|
|
19
|
+
description: OK
|
|
20
|
+
content:
|
|
21
|
+
application/json:
|
|
22
|
+
schema:
|
|
23
|
+
type: array
|
|
24
|
+
items:
|
|
25
|
+
$ref: '#/components/schemas/User'
|
|
26
|
+
500:
|
|
27
|
+
description: Server Error
|
|
28
|
+
post:
|
|
29
|
+
tags: [users]
|
|
30
|
+
summary: Add User
|
|
31
|
+
requestBody:
|
|
32
|
+
required: true
|
|
33
|
+
content:
|
|
34
|
+
application/json:
|
|
35
|
+
schema:
|
|
36
|
+
$ref: '#/components/schemas/User'
|
|
37
|
+
responses:
|
|
38
|
+
201:
|
|
39
|
+
description: Created
|
|
40
|
+
400:
|
|
41
|
+
description: Bad Request
|
|
42
|
+
409:
|
|
43
|
+
description: Conflict
|
|
44
|
+
500:
|
|
45
|
+
description: Server Error
|
|
46
|
+
/users/{id}:
|
|
47
|
+
get:
|
|
48
|
+
tags: [users]
|
|
49
|
+
summary: Find User By Id
|
|
50
|
+
parameters:
|
|
51
|
+
- name: id
|
|
52
|
+
in: path
|
|
53
|
+
description: User Id
|
|
54
|
+
required: true
|
|
55
|
+
schema:
|
|
56
|
+
type: string
|
|
57
|
+
responses:
|
|
58
|
+
200:
|
|
59
|
+
description: OK
|
|
60
|
+
content:
|
|
61
|
+
application/json:
|
|
62
|
+
schema:
|
|
63
|
+
$ref: '#/components/schemas/User'
|
|
64
|
+
404:
|
|
65
|
+
description: Not Found
|
|
66
|
+
500:
|
|
67
|
+
description: Server Error
|
|
68
|
+
put:
|
|
69
|
+
tags: [users]
|
|
70
|
+
summary: Update User By Id
|
|
71
|
+
parameters:
|
|
72
|
+
- name: id
|
|
73
|
+
in: path
|
|
74
|
+
description: user Id
|
|
75
|
+
required: true
|
|
76
|
+
schema:
|
|
77
|
+
type: string
|
|
78
|
+
requestBody:
|
|
79
|
+
required: true
|
|
80
|
+
content:
|
|
81
|
+
application/json:
|
|
82
|
+
schema:
|
|
83
|
+
$ref: '#/components/schemas/User'
|
|
84
|
+
responses:
|
|
85
|
+
200:
|
|
86
|
+
description: OK
|
|
87
|
+
400:
|
|
88
|
+
description: Bad Request
|
|
89
|
+
409:
|
|
90
|
+
description: Conflict
|
|
91
|
+
500:
|
|
92
|
+
description: Server Error
|
|
93
|
+
delete:
|
|
94
|
+
tags: [users]
|
|
95
|
+
summary: Delete User By Id
|
|
96
|
+
parameters:
|
|
97
|
+
- name: id
|
|
98
|
+
in: path
|
|
99
|
+
description: user Id
|
|
100
|
+
required: true
|
|
101
|
+
schema:
|
|
102
|
+
type: string
|
|
103
|
+
responses:
|
|
104
|
+
204:
|
|
105
|
+
description: No Content
|
|
106
|
+
404:
|
|
107
|
+
description: Not Found
|
|
108
|
+
500:
|
|
109
|
+
description: Server Error
|
|
110
|
+
|
|
111
|
+
components:
|
|
112
|
+
schemas:
|
|
113
|
+
User:
|
|
114
|
+
type: object
|
|
115
|
+
required:
|
|
116
|
+
- email
|
|
117
|
+
- password
|
|
118
|
+
properties:
|
|
119
|
+
id:
|
|
120
|
+
type: string
|
|
121
|
+
email:
|
|
122
|
+
type: string
|
|
123
|
+
password:
|
|
124
|
+
type: string
|
|
@@ -21,12 +21,13 @@
|
|
|
21
21
|
"baseUrl": "src",
|
|
22
22
|
"paths": {
|
|
23
23
|
"@/*": ["*"],
|
|
24
|
-
"@config": ["config"],
|
|
24
|
+
"@config/*": ["config/*"],
|
|
25
25
|
"@controllers/*": ["controllers/*"],
|
|
26
26
|
"@dtos/*": ["dtos/*"],
|
|
27
27
|
"@exceptions/*": ["exceptions/*"],
|
|
28
28
|
"@interfaces/*": ["interfaces/*"],
|
|
29
29
|
"@middlewares/*": ["middlewares/*"],
|
|
30
|
+
"@repositories/*": ["repositories/*"],
|
|
30
31
|
"@routes/*": ["routes/*"],
|
|
31
32
|
"@services/*": ["services/*"],
|
|
32
33
|
"@utils/*": ["utils/*"]
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { defineConfig } from 'tsup';
|
|
2
|
+
|
|
3
|
+
export default defineConfig({
|
|
4
|
+
entry: ['src/server.ts'], // CLI 등 추가시 여러 entry도 가능
|
|
5
|
+
outDir: 'dist', // 출력 디렉토리
|
|
6
|
+
format: ['cjs'], // 필요시 'esm'도 ['cjs', 'esm']
|
|
7
|
+
dts: true, // 타입 선언 파일(.d.ts) 생성
|
|
8
|
+
sourcemap: true, // 소스맵 생성
|
|
9
|
+
clean: true, // 빌드 전 dist 폴더 정리
|
|
10
|
+
target: 'es2020', // 트랜스파일 대상
|
|
11
|
+
minify: false, // JS 파일을 압축(minify) 해서 더 작게 만듭니다.
|
|
12
|
+
treeshake: true, //사용하지 않는 코드를 제거합니다. 기본은 true지만 명시
|
|
13
|
+
// alias, swc 옵션은 tsconfig.json 기준으로 자동 적용
|
|
14
|
+
// external: [], // node_modules 제외하고 싶을 때
|
|
15
|
+
});
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import request from 'supertest';
|
|
2
|
+
import { describe, it, expect, beforeAll, beforeEach } from 'vitest';
|
|
3
|
+
import { createTestApp, resetUserDB } from '@/test/setup';
|
|
4
|
+
|
|
5
|
+
describe('Auth API', () => {
|
|
6
|
+
let server: any;
|
|
7
|
+
const prefix = '/api/v1';
|
|
8
|
+
|
|
9
|
+
beforeAll(() => {
|
|
10
|
+
server = createTestApp(); // Use shared repository for testing
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
beforeEach(() => {
|
|
14
|
+
resetUserDB(); // Reset repository before each test
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
const user = { email: 'authuser@example.com', password: 'authpassword123' };
|
|
18
|
+
|
|
19
|
+
it('should successfully register a new user', async () => {
|
|
20
|
+
const res = await request(server).post(`${prefix}/auth/signup`).send(user);
|
|
21
|
+
expect(res.statusCode).toBe(201);
|
|
22
|
+
expect(res.body.data.email).toBe(user.email);
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
it('should login a user and set a cookie', async () => {
|
|
26
|
+
await request(server).post(`${prefix}/auth/signup`).send(user);
|
|
27
|
+
const res = await request(server).post(`${prefix}/auth/login`).send(user);
|
|
28
|
+
expect(res.statusCode).toBe(200);
|
|
29
|
+
expect(res.body.data.email).toBe(user.email);
|
|
30
|
+
expect(res.header['set-cookie']).toBeDefined();
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
it('should logout a user', async () => {
|
|
34
|
+
await request(server).post(`${prefix}/auth/signup`).send(user);
|
|
35
|
+
const loginRes = await request(server).post(`${prefix}/auth/login`).send(user);
|
|
36
|
+
const cookie = loginRes.headers['set-cookie'];
|
|
37
|
+
const logoutRes = await request(server).post(`${prefix}/auth/logout`).set('Cookie', cookie[0]);
|
|
38
|
+
expect(logoutRes.statusCode).toBe(200);
|
|
39
|
+
expect(logoutRes.body.message).toBe('logout');
|
|
40
|
+
});
|
|
41
|
+
});
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import request from 'supertest';
|
|
2
|
+
import { describe, it, expect, beforeAll, beforeEach } from 'vitest';
|
|
3
|
+
import { createTestApp, resetUserDB } from '@/test/setup';
|
|
4
|
+
|
|
5
|
+
describe('Users API', () => {
|
|
6
|
+
let server: any;
|
|
7
|
+
const prefix = '/api/v1';
|
|
8
|
+
|
|
9
|
+
beforeAll(() => {
|
|
10
|
+
server = createTestApp(); // Initialize server with shared repository
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
beforeEach(() => {
|
|
14
|
+
resetUserDB(); // Reset repository before each test
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
const user = { email: 'user1@example.com', password: 'password123' };
|
|
18
|
+
|
|
19
|
+
it('should create a new user', async () => {
|
|
20
|
+
const res = await request(server).post(`${prefix}/users`).send(user);
|
|
21
|
+
expect(res.statusCode).toBe(201);
|
|
22
|
+
expect(res.body.data.email).toBe(user.email);
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
it('should retrieve all users', async () => {
|
|
26
|
+
await request(server).post(`${prefix}/users`).send(user);
|
|
27
|
+
const res = await request(server).get(`${prefix}/users`);
|
|
28
|
+
expect(res.statusCode).toBe(200);
|
|
29
|
+
expect(Array.isArray(res.body.data)).toBe(true);
|
|
30
|
+
expect(res.body.data[0].email).toBe(user.email);
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
it('should retrieve a user by id', async () => {
|
|
34
|
+
const createRes = await request(server).post(`${prefix}/users`).send(user);
|
|
35
|
+
const id = createRes.body.data.id;
|
|
36
|
+
|
|
37
|
+
const res = await request(server).get(`${prefix}/users/${id}`);
|
|
38
|
+
expect(res.statusCode).toBe(200);
|
|
39
|
+
expect(res.body.data.email).toBe(user.email);
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
it('should update user information', async () => {
|
|
43
|
+
const createRes = await request(server).post(`${prefix}/users`).send(user);
|
|
44
|
+
const id = createRes.body.data.id;
|
|
45
|
+
|
|
46
|
+
const newPassword = 'newpassword123';
|
|
47
|
+
const res = await request(server).put(`${prefix}/users/${id}`).send({ password: newPassword });
|
|
48
|
+
expect(res.statusCode).toBe(200);
|
|
49
|
+
expect(res.body.data.id).toBe(id);
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
it('should delete a user', async () => {
|
|
53
|
+
const createRes = await request(server).post(`${prefix}/users`).send(user);
|
|
54
|
+
const id = createRes.body.data.id;
|
|
55
|
+
|
|
56
|
+
const res = await request(server).delete(`${prefix}/users/${id}`);
|
|
57
|
+
expect(res.statusCode).toBe(204);
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
it('should return 404 if user does not exist', async () => {
|
|
61
|
+
const res = await request(server).get(`${prefix}/users/invalid-id`);
|
|
62
|
+
expect(res.statusCode).toBe(404);
|
|
63
|
+
});
|
|
64
|
+
});
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import 'reflect-metadata';
|
|
2
|
+
import { container } from 'tsyringe';
|
|
3
|
+
import App from '@/app';
|
|
4
|
+
import { AuthRoute } from '@routes/auth.route';
|
|
5
|
+
import { UsersRoute } from '@routes/users.route';
|
|
6
|
+
import { UsersRepository, IUsersRepository } from '@repositories/users.repository';
|
|
7
|
+
|
|
8
|
+
let sharedRepo: UsersRepository;
|
|
9
|
+
|
|
10
|
+
export function createTestApp({ mockRepo }: { mockRepo?: IUsersRepository } = {}) {
|
|
11
|
+
// 항상 새로운 인스턴스를 주입하고 싶으면 reset logic 추가 필요
|
|
12
|
+
if (!sharedRepo) {
|
|
13
|
+
sharedRepo = new UsersRepository();
|
|
14
|
+
container.registerInstance(UsersRepository, sharedRepo);
|
|
15
|
+
}
|
|
16
|
+
// mockRepo가 있으면 주입
|
|
17
|
+
if (mockRepo) {
|
|
18
|
+
container.registerInstance(UsersRepository, mockRepo as UsersRepository);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
// 클래스 타입을 직접 주입
|
|
22
|
+
const routes = [container.resolve(UsersRoute), container.resolve(AuthRoute)];
|
|
23
|
+
const appInstance = new App(routes);
|
|
24
|
+
return appInstance.getServer();
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
export function resetUserDB() {
|
|
28
|
+
if (sharedRepo) {
|
|
29
|
+
sharedRepo.reset();
|
|
30
|
+
}
|
|
31
|
+
}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { compare, hash } from 'bcryptjs';
|
|
2
|
+
import { describe, it, expect, beforeEach } from 'vitest';
|
|
3
|
+
import { CreateUserDto } from '@dtos/users.dto';
|
|
4
|
+
import { User } from '@interfaces/users.interface';
|
|
5
|
+
import { UsersRepository } from '@repositories/users.repository';
|
|
6
|
+
import { AuthService } from '@services/auth.service';
|
|
7
|
+
|
|
8
|
+
describe('AuthService (with UserMemoryRepository)', () => {
|
|
9
|
+
let authService: AuthService;
|
|
10
|
+
let userRepo: UsersRepository;
|
|
11
|
+
const testUser: User = {
|
|
12
|
+
id: '1',
|
|
13
|
+
email: 'authuser@example.com',
|
|
14
|
+
password: '', // will be replaced with actual hash
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
beforeEach(async () => {
|
|
18
|
+
userRepo = new UsersRepository();
|
|
19
|
+
testUser.password = await hash('plainpw', 10);
|
|
20
|
+
// Add initial user
|
|
21
|
+
await userRepo.save({ ...testUser });
|
|
22
|
+
authService = new AuthService(userRepo); // inject repo
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
it('should sign up a new user', async () => {
|
|
26
|
+
const dto: CreateUserDto = {
|
|
27
|
+
email: 'newuser@example.com',
|
|
28
|
+
password: 'newpassword123',
|
|
29
|
+
};
|
|
30
|
+
const created = await authService.signup(dto);
|
|
31
|
+
expect(created.email).toBe(dto.email);
|
|
32
|
+
|
|
33
|
+
const found = await userRepo.findByEmail(dto.email);
|
|
34
|
+
expect(found).toBeDefined();
|
|
35
|
+
expect(await compare(dto.password, found!.password)).toBe(true);
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
it('should throw an error if email is already in use', async () => {
|
|
39
|
+
const dto: CreateUserDto = {
|
|
40
|
+
email: testUser.email,
|
|
41
|
+
password: 'anypw',
|
|
42
|
+
};
|
|
43
|
+
await expect(authService.signup(dto)).rejects.toThrow(/already in use/);
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
it('should return user and cookie on successful login', async () => {
|
|
47
|
+
// Create user with hashed password
|
|
48
|
+
const plainPassword = 'mySecret123';
|
|
49
|
+
const email = 'loginuser@example.com';
|
|
50
|
+
const hashed = await hash(plainPassword, 10);
|
|
51
|
+
await userRepo.save({ id: '2', email, password: hashed });
|
|
52
|
+
|
|
53
|
+
const result = await authService.login({ email, password: plainPassword });
|
|
54
|
+
expect(result.user.email).toBe(email);
|
|
55
|
+
expect(result.cookie).toContain('Authorization=');
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
it('should throw an error if email or password is incorrect', async () => {
|
|
59
|
+
// Non-existing email
|
|
60
|
+
await expect(authService.login({ email: 'nobody@example.com', password: 'xxx' })).rejects.toThrow(/Invalid email or password/i);
|
|
61
|
+
|
|
62
|
+
// Incorrect password
|
|
63
|
+
const email = testUser.email;
|
|
64
|
+
await expect(authService.login({ email, password: 'wrongpw' })).rejects.toThrow(/password/i);
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
it('should successfully logout without errors', async () => {
|
|
68
|
+
await expect(authService.logout(testUser)).resolves.toBeUndefined();
|
|
69
|
+
});
|
|
70
|
+
});
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach } from 'vitest';
|
|
2
|
+
import { User } from '@interfaces/users.interface';
|
|
3
|
+
import { UsersRepository } from '@repositories/users.repository';
|
|
4
|
+
import { UsersService } from '@services/users.service';
|
|
5
|
+
|
|
6
|
+
describe('UsersService (with UsersRepository)', () => {
|
|
7
|
+
let usersService: UsersService;
|
|
8
|
+
let userRepo: UsersRepository;
|
|
9
|
+
|
|
10
|
+
// Sample user data
|
|
11
|
+
const user1: User & { id: string } = { id: '1', email: 'one@example.com', password: 'pw1' };
|
|
12
|
+
const user2: User & { id: string } = { id: '2', email: 'two@example.com', password: 'pw2' };
|
|
13
|
+
|
|
14
|
+
beforeEach(async () => {
|
|
15
|
+
userRepo = new UsersRepository();
|
|
16
|
+
userRepo.reset();
|
|
17
|
+
// Directly save users (save is async but await is optional for init)
|
|
18
|
+
await userRepo.save({ ...user1 });
|
|
19
|
+
await userRepo.save({ ...user2 });
|
|
20
|
+
usersService = new UsersService(userRepo);
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
it('getAllUsers: should return all users', async () => {
|
|
24
|
+
const users = await usersService.getAllUsers();
|
|
25
|
+
expect(users.length).toBe(2);
|
|
26
|
+
expect(users[0].email).toBe(user1.email);
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
it('getUserById: should return user by ID', async () => {
|
|
30
|
+
const user = await usersService.getUserById('2');
|
|
31
|
+
expect(user.email).toBe(user2.email);
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
it('getUserById: should throw if ID does not exist', async () => {
|
|
35
|
+
await expect(usersService.getUserById('999')).rejects.toThrow(/not found/);
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
it('createUser: should add a new user', async () => {
|
|
39
|
+
const created = await usersService.createUser({
|
|
40
|
+
id: '', // ignored
|
|
41
|
+
email: 'new@example.com',
|
|
42
|
+
password: 'pw3',
|
|
43
|
+
});
|
|
44
|
+
expect(created.email).toBe('new@example.com');
|
|
45
|
+
const all = await usersService.getAllUsers();
|
|
46
|
+
expect(all.length).toBe(3);
|
|
47
|
+
});
|
|
48
|
+
|
|
49
|
+
it('createUser: should throw if email already exists', async () => {
|
|
50
|
+
await expect(
|
|
51
|
+
usersService.createUser({
|
|
52
|
+
id: '',
|
|
53
|
+
email: user1.email,
|
|
54
|
+
password: 'pwX',
|
|
55
|
+
}),
|
|
56
|
+
).rejects.toThrow(/exists/);
|
|
57
|
+
});
|
|
58
|
+
|
|
59
|
+
it('updateUser: should update user password', async () => {
|
|
60
|
+
const newPassword = 'newpw';
|
|
61
|
+
const updated = await usersService.updateUser(user2.id as string, {
|
|
62
|
+
id: user2.id as string,
|
|
63
|
+
email: user2.email,
|
|
64
|
+
password: newPassword,
|
|
65
|
+
});
|
|
66
|
+
expect(updated).toBeDefined();
|
|
67
|
+
expect(updated!.password).not.toBe(user2.password); // changed to hashed value
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
it('updateUser: should throw if ID does not exist', async () => {
|
|
71
|
+
await expect(
|
|
72
|
+
usersService.updateUser('999', {
|
|
73
|
+
id: '999',
|
|
74
|
+
email: 'no@no.com',
|
|
75
|
+
password: 'no',
|
|
76
|
+
}),
|
|
77
|
+
).rejects.toThrow(/not found/);
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
it('deleteUser: should delete user successfully', async () => {
|
|
81
|
+
await usersService.deleteUser(user1.id as string);
|
|
82
|
+
const users = await usersService.getAllUsers();
|
|
83
|
+
expect(users.length).toBe(1);
|
|
84
|
+
expect(users[0].id).toBe(user2.id);
|
|
85
|
+
});
|
|
86
|
+
|
|
87
|
+
it('deleteUser: should throw if ID does not exist', async () => {
|
|
88
|
+
await expect(usersService.deleteUser('999')).rejects.toThrow(/not found/);
|
|
89
|
+
});
|
|
90
|
+
});
|