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
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
# baseURL
|
|
2
|
-
@baseURL = http://localhost:3000
|
|
3
|
-
|
|
4
|
-
###
|
|
5
|
-
# Find All Users
|
|
6
|
-
GET {{ baseURL }}/users
|
|
7
|
-
|
|
8
|
-
###
|
|
9
|
-
# Find User By Id
|
|
10
|
-
GET {{ baseURL }}/users/1
|
|
11
|
-
|
|
12
|
-
###
|
|
13
|
-
# Create User
|
|
14
|
-
POST {{ baseURL }}/users
|
|
15
|
-
Content-Type: application/json
|
|
16
|
-
|
|
17
|
-
{
|
|
18
|
-
"email": "example@email.com",
|
|
19
|
-
"password": "password"
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
###
|
|
23
|
-
# Modify User By Id
|
|
24
|
-
PUT {{ baseURL }}/users/1
|
|
25
|
-
Content-Type: application/json
|
|
26
|
-
|
|
27
|
-
{
|
|
28
|
-
"email": "example@email.com",
|
|
29
|
-
"password": "password"
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
###
|
|
33
|
-
# Delete User By Id
|
|
34
|
-
DELETE {{ baseURL }}/users/1
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { Request } from 'express';
|
|
2
|
-
import { User } from '@interfaces/users.interface';
|
|
3
|
-
|
|
4
|
-
export interface DataStoredInToken {
|
|
5
|
-
id: number;
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
export interface TokenData {
|
|
9
|
-
token: string;
|
|
10
|
-
expiresIn: number;
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
export interface RequestWithUser extends Request {
|
|
14
|
-
user: User;
|
|
15
|
-
}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import { NextFunction, Response } from 'express';
|
|
2
|
-
import { verify } from 'jsonwebtoken';
|
|
3
|
-
import { SECRET_KEY } from '@config';
|
|
4
|
-
import { DB } from '@database';
|
|
5
|
-
import { HttpException } from '@exceptions/httpException';
|
|
6
|
-
import { DataStoredInToken, RequestWithUser } from '@interfaces/auth.interface';
|
|
7
|
-
|
|
8
|
-
const getAuthorization = (req) => {
|
|
9
|
-
const coockie = req.cookies['Authorization'];
|
|
10
|
-
if (coockie) return coockie;
|
|
11
|
-
|
|
12
|
-
const header = req.header('Authorization');
|
|
13
|
-
if (header) return header.split('Bearer ')[1];
|
|
14
|
-
|
|
15
|
-
return null;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
export const AuthMiddleware = async (req: RequestWithUser, res: Response, next: NextFunction) => {
|
|
19
|
-
try {
|
|
20
|
-
const Authorization = getAuthorization(req);
|
|
21
|
-
|
|
22
|
-
if (Authorization) {
|
|
23
|
-
const { id } = verify(Authorization, SECRET_KEY) as DataStoredInToken;
|
|
24
|
-
const findUser = await DB.Users.findByPk(id);
|
|
25
|
-
|
|
26
|
-
if (findUser) {
|
|
27
|
-
req.user = findUser;
|
|
28
|
-
next();
|
|
29
|
-
} else {
|
|
30
|
-
next(new HttpException(401, 'Wrong authentication token'));
|
|
31
|
-
}
|
|
32
|
-
} else {
|
|
33
|
-
next(new HttpException(404, 'Authentication token missing'));
|
|
34
|
-
}
|
|
35
|
-
} catch (error) {
|
|
36
|
-
next(new HttpException(401, 'Wrong authentication token'));
|
|
37
|
-
}
|
|
38
|
-
};
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { NextFunction, Request, Response } from 'express';
|
|
2
|
-
import { HttpException } from '@/exceptions/httpException';
|
|
3
|
-
import { logger } from '@utils/logger';
|
|
4
|
-
|
|
5
|
-
export const ErrorMiddleware = (error: HttpException, req: Request, res: Response, next: NextFunction) => {
|
|
6
|
-
try {
|
|
7
|
-
const status: number = error.status || 500;
|
|
8
|
-
const message: string = error.message || 'Something went wrong';
|
|
9
|
-
|
|
10
|
-
logger.error(`[${req.method}] ${req.path} >> StatusCode:: ${status}, Message:: ${message}`);
|
|
11
|
-
res.status(status).json({ message });
|
|
12
|
-
} catch (error) {
|
|
13
|
-
next(error);
|
|
14
|
-
}
|
|
15
|
-
};
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { plainToInstance } from 'class-transformer';
|
|
2
|
-
import { validateOrReject, ValidationError } from 'class-validator';
|
|
3
|
-
import { NextFunction, Request, Response } from 'express';
|
|
4
|
-
import { HttpException } from '@exceptions/httpException';
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* @name ValidationMiddleware
|
|
8
|
-
* @description Allows use of decorator and non-decorator based validation
|
|
9
|
-
* @param type dto
|
|
10
|
-
* @param skipMissingProperties When skipping missing properties
|
|
11
|
-
* @param whitelist Even if your object is an instance of a validation class it can contain additional properties that are not defined
|
|
12
|
-
* @param forbidNonWhitelisted If you would rather to have an error thrown when any non-whitelisted properties are present
|
|
13
|
-
*/
|
|
14
|
-
export const ValidationMiddleware = (type: any, skipMissingProperties = false, whitelist = false, forbidNonWhitelisted = false) => {
|
|
15
|
-
return (req: Request, res: Response, next: NextFunction) => {
|
|
16
|
-
const dto = plainToInstance(type, req.body);
|
|
17
|
-
validateOrReject(dto, { skipMissingProperties, whitelist, forbidNonWhitelisted })
|
|
18
|
-
.then(() => {
|
|
19
|
-
req.body = dto;
|
|
20
|
-
next();
|
|
21
|
-
})
|
|
22
|
-
.catch((errors: ValidationError[]) => {
|
|
23
|
-
const message = errors.map((error: ValidationError) => Object.values(error.constraints)).join(', ');
|
|
24
|
-
next(new HttpException(400, message));
|
|
25
|
-
});
|
|
26
|
-
};
|
|
27
|
-
};
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
import { Sequelize, DataTypes, Model, Optional } from 'sequelize';
|
|
2
|
-
import { User } from '@interfaces/users.interface';
|
|
3
|
-
|
|
4
|
-
export type UserCreationAttributes = Optional<User, 'id' | 'email' | 'password'>;
|
|
5
|
-
|
|
6
|
-
export class UserModel extends Model<User, UserCreationAttributes> implements User {
|
|
7
|
-
public id: number;
|
|
8
|
-
public email: string;
|
|
9
|
-
public password: string;
|
|
10
|
-
|
|
11
|
-
public readonly createdAt!: Date;
|
|
12
|
-
public readonly updatedAt!: Date;
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
export default function (sequelize: Sequelize): typeof UserModel {
|
|
16
|
-
UserModel.init(
|
|
17
|
-
{
|
|
18
|
-
id: {
|
|
19
|
-
autoIncrement: true,
|
|
20
|
-
primaryKey: true,
|
|
21
|
-
type: DataTypes.INTEGER,
|
|
22
|
-
},
|
|
23
|
-
email: {
|
|
24
|
-
allowNull: false,
|
|
25
|
-
type: DataTypes.STRING(45),
|
|
26
|
-
},
|
|
27
|
-
password: {
|
|
28
|
-
allowNull: false,
|
|
29
|
-
type: DataTypes.STRING(255),
|
|
30
|
-
},
|
|
31
|
-
},
|
|
32
|
-
{
|
|
33
|
-
tableName: 'users',
|
|
34
|
-
sequelize,
|
|
35
|
-
},
|
|
36
|
-
);
|
|
37
|
-
|
|
38
|
-
return UserModel;
|
|
39
|
-
}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { Router } from 'express';
|
|
2
|
-
import { AuthController } from '@controllers/auth.controller';
|
|
3
|
-
import { CreateUserDto } from '@dtos/users.dto';
|
|
4
|
-
import { Routes } from '@interfaces/routes.interface';
|
|
5
|
-
import { AuthMiddleware } from '@middlewares/auth.middleware';
|
|
6
|
-
import { ValidationMiddleware } from '@middlewares/validation.middleware';
|
|
7
|
-
|
|
8
|
-
export class AuthRoute implements Routes {
|
|
9
|
-
public router = Router();
|
|
10
|
-
public auth = new AuthController();
|
|
11
|
-
|
|
12
|
-
constructor() {
|
|
13
|
-
this.initializeRoutes();
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
private initializeRoutes() {
|
|
17
|
-
this.router.post('/signup', ValidationMiddleware(CreateUserDto), this.auth.signUp);
|
|
18
|
-
this.router.post('/login', ValidationMiddleware(CreateUserDto), this.auth.logIn);
|
|
19
|
-
this.router.post('/logout', AuthMiddleware, this.auth.logOut);
|
|
20
|
-
}
|
|
21
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import { Router } from 'express';
|
|
2
|
-
import { UserController } from '@controllers/users.controller';
|
|
3
|
-
import { CreateUserDto } from '@dtos/users.dto';
|
|
4
|
-
import { Routes } from '@interfaces/routes.interface';
|
|
5
|
-
import { ValidationMiddleware } from '@middlewares/validation.middleware';
|
|
6
|
-
|
|
7
|
-
export class UserRoute implements Routes {
|
|
8
|
-
public path = '/users';
|
|
9
|
-
public router = Router();
|
|
10
|
-
public user = new UserController();
|
|
11
|
-
|
|
12
|
-
constructor() {
|
|
13
|
-
this.initializeRoutes();
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
private initializeRoutes() {
|
|
17
|
-
this.router.get(`${this.path}`, this.user.getUsers);
|
|
18
|
-
this.router.get(`${this.path}/:id(\\d+)`, this.user.getUserById);
|
|
19
|
-
this.router.post(`${this.path}`, ValidationMiddleware(CreateUserDto), this.user.createUser);
|
|
20
|
-
this.router.put(`${this.path}/:id(\\d+)`, ValidationMiddleware(CreateUserDto, true), this.user.updateUser);
|
|
21
|
-
this.router.delete(`${this.path}/:id(\\d+)`, this.user.deleteUser);
|
|
22
|
-
}
|
|
23
|
-
}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { App } from '@/app';
|
|
2
|
-
import { AuthRoute } from '@routes/auth.route';
|
|
3
|
-
import { UserRoute } from '@routes/users.route';
|
|
4
|
-
import { ValidateEnv } from '@utils/validateEnv';
|
|
5
|
-
|
|
6
|
-
ValidateEnv();
|
|
7
|
-
|
|
8
|
-
const app = new App([new AuthRoute(), new UserRoute()]);
|
|
9
|
-
|
|
10
|
-
app.listen();
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
import { compare, hash } from 'bcrypt';
|
|
2
|
-
import { sign } from 'jsonwebtoken';
|
|
3
|
-
import { Service } from 'typedi';
|
|
4
|
-
import { SECRET_KEY } from '@config';
|
|
5
|
-
import { DB } from '@database';
|
|
6
|
-
import { CreateUserDto } from '@dtos/users.dto';
|
|
7
|
-
import { HttpException } from '@/exceptions/httpException';
|
|
8
|
-
import { DataStoredInToken, TokenData } from '@interfaces/auth.interface';
|
|
9
|
-
import { User } from '@interfaces/users.interface';
|
|
10
|
-
|
|
11
|
-
const createToken = (user: User): TokenData => {
|
|
12
|
-
const dataStoredInToken: DataStoredInToken = { id: user.id };
|
|
13
|
-
const expiresIn: number = 60 * 60;
|
|
14
|
-
|
|
15
|
-
return { expiresIn, token: sign(dataStoredInToken, SECRET_KEY, { expiresIn }) };
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
const createCookie = (tokenData: TokenData): string => {
|
|
19
|
-
return `Authorization=${tokenData.token}; HttpOnly; Max-Age=${tokenData.expiresIn};`;
|
|
20
|
-
}
|
|
21
|
-
@Service()
|
|
22
|
-
export class AuthService {
|
|
23
|
-
public async signup(userData: CreateUserDto): Promise<User> {
|
|
24
|
-
const findUser: User = await DB.Users.findOne({ where: { email: userData.email } });
|
|
25
|
-
if (findUser) throw new HttpException(409, `This email ${userData.email} already exists`);
|
|
26
|
-
|
|
27
|
-
const hashedPassword = await hash(userData.password, 10);
|
|
28
|
-
const createUserData: User = await DB.Users.create({ ...userData, password: hashedPassword });
|
|
29
|
-
|
|
30
|
-
return createUserData;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
public async login(userData: CreateUserDto): Promise<{ cookie: string; findUser: User }> {
|
|
34
|
-
const findUser: User = await DB.Users.findOne({ where: { email: userData.email } });
|
|
35
|
-
if (!findUser) throw new HttpException(409, `This email ${userData.email} was not found`);
|
|
36
|
-
|
|
37
|
-
const isPasswordMatching: boolean = await compare(userData.password, findUser.password);
|
|
38
|
-
if (!isPasswordMatching) throw new HttpException(409, "Password not matching");
|
|
39
|
-
|
|
40
|
-
const tokenData = createToken(findUser);
|
|
41
|
-
const cookie = createCookie(tokenData);
|
|
42
|
-
|
|
43
|
-
return { cookie, findUser };
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
public async logout(userData: User): Promise<User> {
|
|
47
|
-
const findUser: User = await DB.Users.findOne({ where: { email: userData.email, password: userData.password } });
|
|
48
|
-
if (!findUser) throw new HttpException(409, "User doesn't exist");
|
|
49
|
-
|
|
50
|
-
return findUser;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
import { hash } from 'bcrypt';
|
|
2
|
-
import { Service } from 'typedi';
|
|
3
|
-
import { DB } from '@database';
|
|
4
|
-
import { CreateUserDto } from '@dtos/users.dto';
|
|
5
|
-
import { HttpException } from '@/exceptions/httpException';
|
|
6
|
-
import { User } from '@interfaces/users.interface';
|
|
7
|
-
|
|
8
|
-
@Service()
|
|
9
|
-
export class UserService {
|
|
10
|
-
public async findAllUser(): Promise<User[]> {
|
|
11
|
-
const allUser: User[] = await DB.Users.findAll();
|
|
12
|
-
return allUser;
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
public async findUserById(userId: number): Promise<User> {
|
|
16
|
-
const findUser: User = await DB.Users.findByPk(userId);
|
|
17
|
-
if (!findUser) throw new HttpException(409, "User doesn't exist");
|
|
18
|
-
|
|
19
|
-
return findUser;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
public async createUser(userData: CreateUserDto): Promise<User> {
|
|
23
|
-
const findUser: User = await DB.Users.findOne({ where: { email: userData.email } });
|
|
24
|
-
if (findUser) throw new HttpException(409, `This email ${userData.email} already exists`);
|
|
25
|
-
|
|
26
|
-
const hashedPassword = await hash(userData.password, 10);
|
|
27
|
-
const createUserData: User = await DB.Users.create({ ...userData, password: hashedPassword });
|
|
28
|
-
return createUserData;
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
public async updateUser(userId: number, userData: CreateUserDto): Promise<User> {
|
|
32
|
-
const findUser: User = await DB.Users.findByPk(userId);
|
|
33
|
-
if (!findUser) throw new HttpException(409, "User doesn't exist");
|
|
34
|
-
|
|
35
|
-
const hashedPassword = await hash(userData.password, 10);
|
|
36
|
-
await DB.Users.update({ ...userData, password: hashedPassword }, { where: { id: userId } });
|
|
37
|
-
|
|
38
|
-
const updateUser: User = await DB.Users.findByPk(userId);
|
|
39
|
-
return updateUser;
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
public async deleteUser(userId: number): Promise<User> {
|
|
43
|
-
const findUser: User = await DB.Users.findByPk(userId);
|
|
44
|
-
if (!findUser) throw new HttpException(409, "User doesn't exist");
|
|
45
|
-
|
|
46
|
-
await DB.Users.destroy({ where: { id: userId } });
|
|
47
|
-
|
|
48
|
-
return findUser;
|
|
49
|
-
}
|
|
50
|
-
}
|
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
import bcrypt from 'bcrypt';
|
|
2
|
-
import { Sequelize } from 'sequelize';
|
|
3
|
-
import request from 'supertest';
|
|
4
|
-
import { App } from '@/app';
|
|
5
|
-
import { CreateUserDto } from '@dtos/users.dto';
|
|
6
|
-
import { AuthRoute } from '@routes/auth.route';
|
|
7
|
-
|
|
8
|
-
afterAll(async () => {
|
|
9
|
-
await new Promise<void>(resolve => setTimeout(() => resolve(), 500));
|
|
10
|
-
});
|
|
11
|
-
|
|
12
|
-
describe('Testing Auth', () => {
|
|
13
|
-
describe('[POST] /signup', () => {
|
|
14
|
-
it('response should have the Create userData', async () => {
|
|
15
|
-
const userData: CreateUserDto = {
|
|
16
|
-
email: 'test@email.com',
|
|
17
|
-
password: 'q1w2e3r4!',
|
|
18
|
-
};
|
|
19
|
-
|
|
20
|
-
const authRoute = new AuthRoute();
|
|
21
|
-
const users = authRoute.authController.authService.users;
|
|
22
|
-
|
|
23
|
-
users.findOne = jest.fn().mockReturnValue(null);
|
|
24
|
-
users.create = jest.fn().mockReturnValue({
|
|
25
|
-
id: 1,
|
|
26
|
-
email: userData.email,
|
|
27
|
-
password: await bcrypt.hash(userData.password, 10),
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
(Sequelize as any).authenticate = jest.fn();
|
|
31
|
-
const app = new App([authRoute]);
|
|
32
|
-
return request(app.getServer()).post(`${authRoute.path}signup`).send(userData).expect(201);
|
|
33
|
-
});
|
|
34
|
-
});
|
|
35
|
-
|
|
36
|
-
describe('[POST] /login', () => {
|
|
37
|
-
it('response should have the Set-Cookie header with the Authorization token', async () => {
|
|
38
|
-
const userData: CreateUserDto = {
|
|
39
|
-
email: 'test@email.com',
|
|
40
|
-
password: 'q1w2e3r4!',
|
|
41
|
-
};
|
|
42
|
-
|
|
43
|
-
const authRoute = new AuthRoute();
|
|
44
|
-
const users = authRoute.authController.authService.users;
|
|
45
|
-
|
|
46
|
-
users.findOne = jest.fn().mockReturnValue({
|
|
47
|
-
id: 1,
|
|
48
|
-
email: userData.email,
|
|
49
|
-
password: await bcrypt.hash(userData.password, 10),
|
|
50
|
-
});
|
|
51
|
-
|
|
52
|
-
(Sequelize as any).authenticate = jest.fn();
|
|
53
|
-
const app = new App([authRoute]);
|
|
54
|
-
return request(app.getServer())
|
|
55
|
-
.post(`${authRoute.path}login`)
|
|
56
|
-
.send(userData)
|
|
57
|
-
.expect('Set-Cookie', /^Authorization=.+/);
|
|
58
|
-
});
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
// describe('[POST] /logout', () => {
|
|
62
|
-
// it('logout Set-Cookie Authorization=; Max-age=0', async () => {
|
|
63
|
-
// const authRoute = new AuthRoute();
|
|
64
|
-
|
|
65
|
-
// const app = new App([authRoute]);
|
|
66
|
-
// return request(app.getServer())
|
|
67
|
-
// .post(`${authRoute.path}logout`)
|
|
68
|
-
// .expect('Set-Cookie', /^Authorization=\;/);
|
|
69
|
-
// });
|
|
70
|
-
// });
|
|
71
|
-
});
|
|
@@ -1,131 +0,0 @@
|
|
|
1
|
-
import bcrypt from 'bcrypt';
|
|
2
|
-
import { Sequelize } from 'sequelize';
|
|
3
|
-
import request from 'supertest';
|
|
4
|
-
import { App } from '@/app';
|
|
5
|
-
import { CreateUserDto } from '@dtos/users.dto';
|
|
6
|
-
import { UserRoute } from '@routes/users.route';
|
|
7
|
-
|
|
8
|
-
afterAll(async () => {
|
|
9
|
-
await new Promise<void>(resolve => setTimeout(() => resolve(), 500));
|
|
10
|
-
});
|
|
11
|
-
|
|
12
|
-
describe('Testing Users', () => {
|
|
13
|
-
describe('[GET] /users', () => {
|
|
14
|
-
it('response findAll users', async () => {
|
|
15
|
-
const usersRoute = new UserRoute();
|
|
16
|
-
const users = usersRoute.usersController.userService.users;
|
|
17
|
-
|
|
18
|
-
users.findAll = jest.fn().mockReturnValue([
|
|
19
|
-
{
|
|
20
|
-
id: 1,
|
|
21
|
-
email: 'a@email.com',
|
|
22
|
-
password: await bcrypt.hash('q1w2e3r4!', 10),
|
|
23
|
-
},
|
|
24
|
-
{
|
|
25
|
-
id: 2,
|
|
26
|
-
email: 'b@email.com',
|
|
27
|
-
password: await bcrypt.hash('a1s2d3f4!', 10),
|
|
28
|
-
},
|
|
29
|
-
{
|
|
30
|
-
id: 3,
|
|
31
|
-
email: 'c@email.com',
|
|
32
|
-
password: await bcrypt.hash('z1x2c3v4!', 10),
|
|
33
|
-
},
|
|
34
|
-
]);
|
|
35
|
-
|
|
36
|
-
(Sequelize as any).authenticate = jest.fn();
|
|
37
|
-
const app = new App([usersRoute]);
|
|
38
|
-
return request(app.getServer()).get(`${usersRoute.path}`).expect(200);
|
|
39
|
-
});
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
describe('[GET] /users/:id', () => {
|
|
43
|
-
it('response findOne user', async () => {
|
|
44
|
-
const userId = 1;
|
|
45
|
-
|
|
46
|
-
const usersRoute = new UserRoute();
|
|
47
|
-
const users = usersRoute.usersController.userService.users;
|
|
48
|
-
|
|
49
|
-
users.findByPk = jest.fn().mockReturnValue({
|
|
50
|
-
id: 1,
|
|
51
|
-
email: 'a@email.com',
|
|
52
|
-
password: await bcrypt.hash('q1w2e3r4!', 10),
|
|
53
|
-
});
|
|
54
|
-
|
|
55
|
-
(Sequelize as any).authenticate = jest.fn();
|
|
56
|
-
const app = new App([usersRoute]);
|
|
57
|
-
return request(app.getServer()).get(`${usersRoute.path}/${userId}`).expect(200);
|
|
58
|
-
});
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
describe('[POST] /users', () => {
|
|
62
|
-
it('response Create user', async () => {
|
|
63
|
-
const userData: CreateUserDto = {
|
|
64
|
-
email: 'test@email.com',
|
|
65
|
-
password: 'q1w2e3r4!',
|
|
66
|
-
};
|
|
67
|
-
|
|
68
|
-
const usersRoute = new UserRoute();
|
|
69
|
-
const users = usersRoute.usersController.userService.users;
|
|
70
|
-
|
|
71
|
-
users.findOne = jest.fn().mockReturnValue(null);
|
|
72
|
-
users.create = jest.fn().mockReturnValue({
|
|
73
|
-
id: 1,
|
|
74
|
-
email: userData.email,
|
|
75
|
-
password: await bcrypt.hash(userData.password, 10),
|
|
76
|
-
});
|
|
77
|
-
|
|
78
|
-
(Sequelize as any).authenticate = jest.fn();
|
|
79
|
-
const app = new App([usersRoute]);
|
|
80
|
-
return request(app.getServer()).post(`${usersRoute.path}`).send(userData).expect(201);
|
|
81
|
-
});
|
|
82
|
-
});
|
|
83
|
-
|
|
84
|
-
describe('[PUT] /users/:id', () => {
|
|
85
|
-
it('response Update user', async () => {
|
|
86
|
-
const userId = 1;
|
|
87
|
-
const userData: CreateUserDto = {
|
|
88
|
-
email: 'test@email.com',
|
|
89
|
-
password: '1q2w3e4r!',
|
|
90
|
-
};
|
|
91
|
-
|
|
92
|
-
const usersRoute = new UserRoute();
|
|
93
|
-
const users = usersRoute.usersController.userService.users;
|
|
94
|
-
|
|
95
|
-
users.findByPk = jest.fn().mockReturnValue({
|
|
96
|
-
id: userId,
|
|
97
|
-
email: userData.email,
|
|
98
|
-
password: await bcrypt.hash(userData.password, 10),
|
|
99
|
-
});
|
|
100
|
-
users.update = jest.fn().mockReturnValue([1]);
|
|
101
|
-
users.findByPk = jest.fn().mockReturnValue({
|
|
102
|
-
id: userId,
|
|
103
|
-
email: userData.email,
|
|
104
|
-
password: await bcrypt.hash(userData.password, 10),
|
|
105
|
-
});
|
|
106
|
-
|
|
107
|
-
(Sequelize as any).authenticate = jest.fn();
|
|
108
|
-
const app = new App([usersRoute]);
|
|
109
|
-
return request(app.getServer()).put(`${usersRoute.path}/${userId}`).send(userData).expect(200);
|
|
110
|
-
});
|
|
111
|
-
});
|
|
112
|
-
|
|
113
|
-
describe('[DELETE] /users/:id', () => {
|
|
114
|
-
it('response Delete user', async () => {
|
|
115
|
-
const userId = 1;
|
|
116
|
-
|
|
117
|
-
const usersRoute = new UserRoute();
|
|
118
|
-
const users = usersRoute.usersController.userService.users;
|
|
119
|
-
|
|
120
|
-
users.findByPk = jest.fn().mockReturnValue({
|
|
121
|
-
id: userId,
|
|
122
|
-
email: 'a@email.com',
|
|
123
|
-
password: await bcrypt.hash('q1w2e3r4!', 10),
|
|
124
|
-
});
|
|
125
|
-
|
|
126
|
-
(Sequelize as any).authenticate = jest.fn();
|
|
127
|
-
const app = new App([usersRoute]);
|
|
128
|
-
return request(app.getServer()).delete(`${usersRoute.path}/${userId}`).expect(200);
|
|
129
|
-
});
|
|
130
|
-
});
|
|
131
|
-
});
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
import { existsSync, mkdirSync } from 'fs';
|
|
2
|
-
import { join } from 'path';
|
|
3
|
-
import winston from 'winston';
|
|
4
|
-
import winstonDaily from 'winston-daily-rotate-file';
|
|
5
|
-
import { LOG_DIR } from '@config';
|
|
6
|
-
|
|
7
|
-
// logs dir
|
|
8
|
-
const logDir: string = join(__dirname, LOG_DIR);
|
|
9
|
-
|
|
10
|
-
if (!existsSync(logDir)) {
|
|
11
|
-
mkdirSync(logDir);
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
// Define log format
|
|
15
|
-
const logFormat = winston.format.printf(({ timestamp, level, message }) => `${timestamp} ${level}: ${message}`);
|
|
16
|
-
|
|
17
|
-
/*
|
|
18
|
-
* Log Level
|
|
19
|
-
* error: 0, warn: 1, info: 2, http: 3, verbose: 4, debug: 5, silly: 6
|
|
20
|
-
*/
|
|
21
|
-
const logger = winston.createLogger({
|
|
22
|
-
format: winston.format.combine(
|
|
23
|
-
winston.format.timestamp({
|
|
24
|
-
format: 'YYYY-MM-DD HH:mm:ss',
|
|
25
|
-
}),
|
|
26
|
-
logFormat,
|
|
27
|
-
),
|
|
28
|
-
transports: [
|
|
29
|
-
// debug log setting
|
|
30
|
-
new winstonDaily({
|
|
31
|
-
level: 'debug',
|
|
32
|
-
datePattern: 'YYYY-MM-DD',
|
|
33
|
-
dirname: logDir + '/debug', // log file /logs/debug/*.log in save
|
|
34
|
-
filename: `%DATE%.log`,
|
|
35
|
-
maxFiles: 30, // 30 Days saved
|
|
36
|
-
json: false,
|
|
37
|
-
zippedArchive: true,
|
|
38
|
-
}),
|
|
39
|
-
// error log setting
|
|
40
|
-
new winstonDaily({
|
|
41
|
-
level: 'error',
|
|
42
|
-
datePattern: 'YYYY-MM-DD',
|
|
43
|
-
dirname: logDir + '/error', // log file /logs/error/*.log in save
|
|
44
|
-
filename: `%DATE%.log`,
|
|
45
|
-
maxFiles: 30, // 30 Days saved
|
|
46
|
-
handleExceptions: true,
|
|
47
|
-
json: false,
|
|
48
|
-
zippedArchive: true,
|
|
49
|
-
}),
|
|
50
|
-
],
|
|
51
|
-
});
|
|
52
|
-
|
|
53
|
-
logger.add(
|
|
54
|
-
new winston.transports.Console({
|
|
55
|
-
format: winston.format.combine(winston.format.splat(), winston.format.colorize()),
|
|
56
|
-
}),
|
|
57
|
-
);
|
|
58
|
-
|
|
59
|
-
const stream = {
|
|
60
|
-
write: (message: string) => {
|
|
61
|
-
logger.info(message.substring(0, message.lastIndexOf('\n')));
|
|
62
|
-
},
|
|
63
|
-
};
|
|
64
|
-
|
|
65
|
-
export { logger, stream };
|