typescript-express-starter 6.2.0 → 8.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.
Files changed (222) hide show
  1. package/README.kr.md +55 -26
  2. package/README.md +54 -25
  3. package/bin/cli.js +4 -3
  4. package/lib/default/.swcrc +41 -0
  5. package/lib/default/nodemon.json +2 -2
  6. package/lib/default/package.json +12 -8
  7. package/lib/default/src/app.ts +1 -2
  8. package/lib/default/src/http/auth.http +12 -15
  9. package/lib/default/src/http/users.http +12 -16
  10. package/lib/default/src/index.ts +1 -0
  11. package/lib/default/src/middlewares/auth.middleware.ts +3 -3
  12. package/lib/default/src/models/users.model.ts +5 -5
  13. package/lib/default/src/server.ts +1 -2
  14. package/lib/default/src/services/auth.service.ts +5 -5
  15. package/lib/default/src/services/users.service.ts +3 -3
  16. package/lib/default/src/tests/auth.test.ts +4 -4
  17. package/lib/default/src/tests/users.test.ts +4 -4
  18. package/lib/default/src/utils/logger.ts +5 -5
  19. package/lib/default/tsconfig.json +2 -2
  20. package/lib/graphql/.dockerignore +18 -0
  21. package/lib/graphql/.editorconfig +9 -0
  22. package/lib/graphql/.env +1 -0
  23. package/lib/graphql/.eslintignore +1 -0
  24. package/lib/graphql/.eslintrc +18 -0
  25. package/lib/graphql/.huskyrc +5 -0
  26. package/lib/graphql/.lintstagedrc.json +5 -0
  27. package/lib/graphql/.prettierrc +8 -0
  28. package/lib/graphql/.swcrc +39 -0
  29. package/lib/graphql/.vscode/launch.json +35 -0
  30. package/lib/graphql/.vscode/settings.json +6 -0
  31. package/lib/graphql/Dockerfile +24 -0
  32. package/lib/graphql/Makefile +6 -0
  33. package/lib/graphql/docker-compose.yml +50 -0
  34. package/lib/graphql/ecosystem.config.js +59 -0
  35. package/lib/graphql/jest.config.js +12 -0
  36. package/lib/graphql/nginx.conf +40 -0
  37. package/lib/graphql/nodemon.json +12 -0
  38. package/lib/graphql/package.json +79 -0
  39. package/lib/graphql/src/app.ts +105 -0
  40. package/lib/graphql/src/configs/development.json +19 -0
  41. package/lib/graphql/src/configs/production.json +19 -0
  42. package/lib/graphql/src/configs/test.json +19 -0
  43. package/lib/graphql/src/databases/index.ts +24 -0
  44. package/lib/graphql/src/dtos/users.dto.ts +14 -0
  45. package/lib/{typeorm/src/entity → graphql/src/entities}/users.entity.ts +3 -3
  46. package/lib/graphql/src/exceptions/HttpException.ts +10 -0
  47. package/lib/graphql/src/http/auth.http +49 -0
  48. package/lib/graphql/src/http/users.http +78 -0
  49. package/lib/graphql/src/index.ts +1 -0
  50. package/lib/graphql/src/interfaces/auth.interface.ts +14 -0
  51. package/lib/graphql/src/interfaces/db.interface.ts +7 -0
  52. package/lib/graphql/src/interfaces/users.interface.ts +5 -0
  53. package/lib/graphql/src/middlewares/auth.middleware.ts +32 -0
  54. package/lib/graphql/src/middlewares/error.middleware.ts +17 -0
  55. package/lib/graphql/src/repositories/auth.repository.ts +61 -0
  56. package/lib/graphql/src/repositories/users.repository.ts +60 -0
  57. package/lib/graphql/src/resolvers/auth.resolver.ts +32 -0
  58. package/lib/graphql/src/resolvers/users.resolver.ts +47 -0
  59. package/lib/graphql/src/server.ts +14 -0
  60. package/lib/graphql/src/tests/auth.test.ts +52 -0
  61. package/lib/graphql/src/tests/index.test.ts +18 -0
  62. package/lib/graphql/src/tests/users.test.ts +71 -0
  63. package/lib/graphql/src/typedefs/users.type.ts +13 -0
  64. package/lib/graphql/src/utils/logger.ts +75 -0
  65. package/lib/graphql/src/utils/util.ts +19 -0
  66. package/lib/graphql/src/utils/validateEnv.ts +10 -0
  67. package/lib/graphql/tsconfig.json +39 -0
  68. package/lib/knex/.swcrc +39 -0
  69. package/lib/knex/knexfile.ts +6 -6
  70. package/lib/knex/nodemon.json +2 -2
  71. package/lib/knex/package.json +11 -8
  72. package/lib/knex/src/app.ts +2 -3
  73. package/lib/knex/src/databases/index.ts +6 -6
  74. package/lib/knex/src/http/auth.http +12 -15
  75. package/lib/knex/src/http/users.http +12 -16
  76. package/lib/knex/src/index.ts +1 -0
  77. package/lib/knex/src/middlewares/auth.middleware.ts +4 -4
  78. package/lib/knex/src/server.ts +1 -2
  79. package/lib/knex/src/services/auth.service.ts +5 -5
  80. package/lib/knex/src/services/users.service.ts +3 -3
  81. package/lib/knex/src/tests/auth.test.ts +2 -2
  82. package/lib/knex/src/tests/index.test.ts +1 -1
  83. package/lib/knex/src/tests/users.test.ts +2 -2
  84. package/lib/knex/src/utils/logger.ts +5 -5
  85. package/lib/knex/tsconfig.json +2 -2
  86. package/lib/mongoose/.swcrc +39 -0
  87. package/lib/mongoose/docker-compose.yml +0 -4
  88. package/lib/mongoose/nodemon.json +2 -2
  89. package/lib/mongoose/package.json +12 -8
  90. package/lib/mongoose/src/app.ts +2 -3
  91. package/lib/mongoose/src/configs/development.json +1 -1
  92. package/lib/mongoose/src/configs/production.json +1 -1
  93. package/lib/mongoose/src/configs/test.json +1 -1
  94. package/lib/mongoose/src/http/auth.http +32 -0
  95. package/lib/mongoose/src/http/users.http +34 -0
  96. package/lib/mongoose/src/index.ts +1 -0
  97. package/lib/mongoose/src/middlewares/auth.middleware.ts +3 -3
  98. package/lib/mongoose/src/server.ts +1 -2
  99. package/lib/mongoose/src/services/auth.service.ts +5 -5
  100. package/lib/mongoose/src/services/users.service.ts +3 -3
  101. package/lib/mongoose/src/utils/logger.ts +5 -5
  102. package/lib/mongoose/tsconfig.json +2 -2
  103. package/lib/prisma/.env +1 -1
  104. package/lib/prisma/.swcrc +37 -0
  105. package/lib/prisma/docker-compose.yml +1 -6
  106. package/lib/prisma/nodemon.json +2 -2
  107. package/lib/prisma/package.json +14 -10
  108. package/lib/prisma/src/app.ts +2 -3
  109. package/lib/prisma/src/http/auth.http +12 -15
  110. package/lib/prisma/src/http/users.http +12 -16
  111. package/lib/prisma/src/index.ts +1 -0
  112. package/lib/prisma/src/middlewares/auth.middleware.ts +4 -4
  113. package/lib/prisma/src/server.ts +1 -2
  114. package/lib/prisma/src/services/auth.service.ts +5 -5
  115. package/lib/prisma/src/services/users.service.ts +3 -3
  116. package/lib/prisma/src/utils/logger.ts +5 -5
  117. package/lib/prisma/tsconfig.json +2 -2
  118. package/lib/routing-controllers/.swcrc +37 -0
  119. package/lib/routing-controllers/nodemon.json +2 -2
  120. package/lib/routing-controllers/package.json +12 -9
  121. package/lib/routing-controllers/src/app.ts +3 -4
  122. package/lib/routing-controllers/src/http/auth.http +12 -15
  123. package/lib/routing-controllers/src/http/users.http +12 -16
  124. package/lib/routing-controllers/src/index.ts +1 -0
  125. package/lib/routing-controllers/src/middlewares/auth.middleware.ts +3 -3
  126. package/lib/routing-controllers/src/middlewares/validation.middleware.ts +10 -2
  127. package/lib/routing-controllers/src/models/users.model.ts +5 -5
  128. package/lib/routing-controllers/src/server.ts +1 -3
  129. package/lib/routing-controllers/src/services/auth.service.ts +5 -5
  130. package/lib/routing-controllers/src/services/users.service.ts +3 -3
  131. package/lib/routing-controllers/src/utils/logger.ts +5 -5
  132. package/lib/routing-controllers/tsconfig.json +2 -2
  133. package/lib/sequelize/.swcrc +39 -0
  134. package/lib/sequelize/docker-compose.yml +1 -6
  135. package/lib/sequelize/nodemon.json +2 -2
  136. package/lib/sequelize/package.json +12 -8
  137. package/lib/sequelize/src/app.ts +1 -2
  138. package/lib/sequelize/src/configs/development.json +2 -2
  139. package/lib/sequelize/src/configs/production.json +1 -1
  140. package/lib/sequelize/src/configs/test.json +1 -1
  141. package/lib/sequelize/src/http/auth.http +32 -0
  142. package/lib/sequelize/src/http/users.http +34 -0
  143. package/lib/sequelize/src/index.ts +1 -0
  144. package/lib/sequelize/src/middlewares/auth.middleware.ts +4 -4
  145. package/lib/sequelize/src/server.ts +1 -2
  146. package/lib/sequelize/src/services/auth.service.ts +5 -5
  147. package/lib/sequelize/src/services/users.service.ts +3 -3
  148. package/lib/sequelize/src/utils/logger.ts +5 -5
  149. package/lib/sequelize/tsconfig.json +2 -2
  150. package/lib/starter.js +5 -9
  151. package/lib/typegoose/.dockerignore +18 -0
  152. package/lib/typegoose/.editorconfig +9 -0
  153. package/lib/typegoose/.env.development.local +18 -0
  154. package/lib/typegoose/.env.production.local +18 -0
  155. package/lib/typegoose/.env.test.local +18 -0
  156. package/lib/typegoose/.eslintignore +1 -0
  157. package/lib/typegoose/.eslintrc +18 -0
  158. package/lib/typegoose/.huskyrc +5 -0
  159. package/lib/typegoose/.lintstagedrc.json +5 -0
  160. package/lib/typegoose/.prettierrc +8 -0
  161. package/lib/typegoose/.swcrc +40 -0
  162. package/lib/typegoose/.vscode/launch.json +35 -0
  163. package/lib/typegoose/.vscode/settings.json +6 -0
  164. package/lib/typegoose/Dockerfile +24 -0
  165. package/lib/typegoose/Makefile +6 -0
  166. package/lib/typegoose/docker-compose.yml +46 -0
  167. package/lib/typegoose/ecosystem.config.js +57 -0
  168. package/lib/typegoose/jest.config.js +12 -0
  169. package/lib/typegoose/nginx.conf +40 -0
  170. package/lib/typegoose/nodemon.json +12 -0
  171. package/lib/typegoose/package.json +80 -0
  172. package/lib/typegoose/src/app.ts +93 -0
  173. package/lib/typegoose/src/config/index.ts +5 -0
  174. package/lib/typegoose/src/controllers/auth.controller.ts +46 -0
  175. package/lib/typegoose/src/controllers/index.controller.ts +13 -0
  176. package/lib/typegoose/src/controllers/users.controller.ts +65 -0
  177. package/lib/typegoose/src/databases/index.ts +3 -0
  178. package/lib/typegoose/src/dtos/users.dto.ts +9 -0
  179. package/lib/typegoose/src/exceptions/HttpException.ts +10 -0
  180. package/lib/typegoose/src/http/auth.http +32 -0
  181. package/lib/typegoose/src/http/users.http +34 -0
  182. package/lib/typegoose/src/interfaces/auth.interface.ts +15 -0
  183. package/lib/typegoose/src/interfaces/routes.interface.ts +6 -0
  184. package/lib/typegoose/src/interfaces/users.interface.ts +5 -0
  185. package/lib/typegoose/src/middlewares/auth.middleware.ts +32 -0
  186. package/lib/typegoose/src/middlewares/error.middleware.ts +17 -0
  187. package/lib/typegoose/src/middlewares/validation.middleware.ts +25 -0
  188. package/lib/typegoose/src/models/users.model.ts +18 -0
  189. package/lib/typegoose/src/routes/auth.route.ts +24 -0
  190. package/lib/typegoose/src/routes/index.route.ts +19 -0
  191. package/lib/typegoose/src/routes/users.route.ts +25 -0
  192. package/lib/typegoose/src/server.ts +11 -0
  193. package/lib/typegoose/src/services/auth.service.ts +61 -0
  194. package/lib/typegoose/src/services/users.service.ts +64 -0
  195. package/lib/typegoose/src/tests/auth.test.ts +83 -0
  196. package/lib/typegoose/src/tests/index.test.ts +18 -0
  197. package/lib/typegoose/src/tests/users.test.ts +133 -0
  198. package/lib/typegoose/src/utils/logger.ts +65 -0
  199. package/lib/typegoose/src/utils/util.ts +19 -0
  200. package/lib/typegoose/src/utils/validateEnv.ts +10 -0
  201. package/lib/typegoose/swagger.yaml +122 -0
  202. package/lib/typegoose/tsconfig.json +40 -0
  203. package/lib/typeorm/.swcrc +39 -0
  204. package/lib/typeorm/docker-compose.yml +1 -1
  205. package/lib/typeorm/nodemon.json +2 -2
  206. package/lib/typeorm/package.json +12 -8
  207. package/lib/typeorm/src/app.ts +1 -2
  208. package/lib/typeorm/src/configs/development.json +1 -1
  209. package/lib/typeorm/src/configs/production.json +1 -1
  210. package/lib/typeorm/src/configs/test.json +1 -1
  211. package/lib/typeorm/src/databases/index.ts +5 -5
  212. package/lib/typeorm/src/entities/users.entity.ts +26 -0
  213. package/lib/typeorm/src/http/auth.http +12 -15
  214. package/lib/typeorm/src/http/users.http +12 -16
  215. package/lib/typeorm/src/index.ts +1 -0
  216. package/lib/typeorm/src/middlewares/auth.middleware.ts +5 -9
  217. package/lib/typeorm/src/server.ts +1 -2
  218. package/lib/typeorm/src/services/auth.service.ts +13 -17
  219. package/lib/typeorm/src/services/users.service.ts +16 -22
  220. package/lib/typeorm/src/utils/logger.ts +5 -5
  221. package/lib/typeorm/tsconfig.json +3 -3
  222. package/package.json +14 -4
@@ -1,4 +1,4 @@
1
- import bcrypt from 'bcrypt';
1
+ import { hash } from 'bcrypt';
2
2
  import { CreateUserDto } from '@dtos/users.dto';
3
3
  import { HttpException } from '@exceptions/HttpException';
4
4
  import { User } from '@interfaces/users.interface';
@@ -24,7 +24,7 @@ class UserService {
24
24
  const findUser: User = await Users.query().select().from('users').where('email', '=', userData.email).first();
25
25
  if (findUser) throw new HttpException(409, `You're email ${userData.email} already exists`);
26
26
 
27
- const hashedPassword = await bcrypt.hash(userData.password, 10);
27
+ const hashedPassword = await hash(userData.password, 10);
28
28
  const createUserData: User = await Users.query()
29
29
  .insert({ ...userData, password: hashedPassword })
30
30
  .into('users');
@@ -38,7 +38,7 @@ class UserService {
38
38
  const findUser: User[] = await Users.query().select().from('users').where('id', '=', userId);
39
39
  if (!findUser) throw new HttpException(409, "You're not user");
40
40
 
41
- const hashedPassword = await bcrypt.hash(userData.password, 10);
41
+ const hashedPassword = await hash(userData.password, 10);
42
42
  await Users.query()
43
43
  .update({ ...userData, password: hashedPassword })
44
44
  .where('id', '=', userId)
@@ -1,7 +1,7 @@
1
1
  import request from 'supertest';
2
2
  import App from '@/app';
3
- import { CreateUserDto } from '@/dtos/users.dto';
4
- import AuthRoute from '@/routes/auth.route';
3
+ import { CreateUserDto } from '@dtos/users.dto';
4
+ import AuthRoute from '@routes/auth.route';
5
5
 
6
6
  afterAll(async () => {
7
7
  await new Promise<void>(resolve => setTimeout(() => resolve(), 500));
@@ -1,6 +1,6 @@
1
1
  import request from 'supertest';
2
2
  import App from '@/app';
3
- import IndexRoute from '@/routes/index.route';
3
+ import IndexRoute from '@routes/index.route';
4
4
 
5
5
  afterAll(async () => {
6
6
  await new Promise<void>(resolve => setTimeout(() => resolve(), 500));
@@ -1,7 +1,7 @@
1
1
  import request from 'supertest';
2
2
  import App from '@/app';
3
- import { CreateUserDto } from '@/dtos/users.dto';
4
- import UserRoute from '@/routes/users.route';
3
+ import { CreateUserDto } from '@dtos/users.dto';
4
+ import UserRoute from '@routes/users.route';
5
5
 
6
6
  afterAll(async () => {
7
7
  await new Promise<void>(resolve => setTimeout(() => resolve(), 500));
@@ -1,14 +1,14 @@
1
1
  import config from 'config';
2
- import fs from 'fs';
3
- import path from 'path';
2
+ import { existsSync, mkdirSync } from 'fs';
3
+ import { join } from 'path';
4
4
  import winston from 'winston';
5
5
  import winstonDaily from 'winston-daily-rotate-file';
6
6
 
7
7
  // logs dir
8
- const logDir: string = path.join(__dirname, config.get('log.dir'));
8
+ const logDir: string = join(__dirname, config.get('log.dir'));
9
9
 
10
- if (!fs.existsSync(logDir)) {
11
- fs.mkdirSync(logDir);
10
+ if (!existsSync(logDir)) {
11
+ mkdirSync(logDir);
12
12
  }
13
13
 
14
14
  // Define log format
@@ -13,7 +13,7 @@
13
13
  "pretty": true,
14
14
  "sourceMap": true,
15
15
  "declaration": true,
16
- "outDir": "./dist",
16
+ "outDir": "dist",
17
17
  "allowJs": true,
18
18
  "noEmit": false,
19
19
  "esModuleInterop": true,
@@ -35,5 +35,5 @@
35
35
  }
36
36
  },
37
37
  "include": ["src/**/*.ts", "src/**/*.json", ".env"],
38
- "exclude": ["node_modules"]
38
+ "exclude": ["node_modules", "src/http", "src/logs", "src/tests"]
39
39
  }
@@ -0,0 +1,39 @@
1
+ {
2
+ "jsc": {
3
+ "parser": {
4
+ "syntax": "typescript",
5
+ "tsx": false,
6
+ "dynamicImport": true,
7
+ "decorators": true
8
+ },
9
+ "transform": {
10
+ "legacyDecorator": true,
11
+ "decoratorMetadata": true
12
+ },
13
+ "target": "es2017",
14
+ "externalHelpers": false,
15
+ "keepClassNames": true,
16
+ "loose": false,
17
+ "minify": {
18
+ "compress": false,
19
+ "mangle": false
20
+ },
21
+ "baseUrl": "src",
22
+ "paths": {
23
+ "@/*": ["*"],
24
+ "@controllers/*": ["controllers/*"],
25
+ "@databases": ["databases"],
26
+ "@dtos/*": ["dtos/*"],
27
+ "@exceptions/*": ["exceptions/*"],
28
+ "@interfaces/*": ["interfaces/*"],
29
+ "@middlewares/*": ["middlewares/*"],
30
+ "@models/*": ["models/*"],
31
+ "@routes/*": ["routes/*"],
32
+ "@services/*": ["services/*"],
33
+ "@utils/*": ["utils/*"]
34
+ }
35
+ },
36
+ "module": {
37
+ "type": "commonjs"
38
+ }
39
+ }
@@ -19,10 +19,6 @@ services:
19
19
  container_name: server
20
20
  ports:
21
21
  - '3000:3000'
22
- environment:
23
- MONGO_HOST: mongo
24
- MONGO_PORT: 27017
25
- MONGO_DATABASE: mongoose
26
22
  volumes:
27
23
  - ./:/app
28
24
  - /app/node_modules
@@ -5,8 +5,8 @@
5
5
  ],
6
6
  "ext": "js,ts,json",
7
7
  "ignore": [
8
- "src/**/*.spec.ts",
9
- "src/**/*.test.ts"
8
+ "src/logs/*",
9
+ "src/**/*.{spec,test}.ts"
10
10
  ],
11
11
  "exec": "ts-node -r tsconfig-paths/register --transpile-only src/server.ts"
12
12
  }
@@ -7,7 +7,8 @@
7
7
  "scripts": {
8
8
  "start": "npm run build && cross-env NODE_ENV=production node dist/server.js",
9
9
  "dev": "cross-env NODE_ENV=development nodemon",
10
- "build": "tsc && npx tsc-alias",
10
+ "build": "swc src -d dist --source-maps --copy-files",
11
+ "build:tsc": "tsc && tsc-alias",
11
12
  "test": "jest --forceExit --detectOpenHandles",
12
13
  "lint": "eslint --ignore-path .gitignore --ext .ts src/",
13
14
  "lint:fix": "npm run lint -- --fix",
@@ -22,26 +23,22 @@
22
23
  "config": "^3.3.6",
23
24
  "cookie-parser": "^1.4.5",
24
25
  "cors": "^2.8.5",
25
- "cross-env": "^7.0.3",
26
26
  "dotenv": "^10.0.0",
27
27
  "envalid": "^7.1.0",
28
28
  "express": "^4.17.1",
29
29
  "helmet": "^4.6.0",
30
30
  "hpp": "^0.2.3",
31
- "jest": "^27.0.6",
32
31
  "jsonwebtoken": "^8.5.1",
33
32
  "mongoose": "^5.10.1",
34
33
  "morgan": "^1.10.0",
35
- "pm2": "^5.1.0",
36
34
  "swagger-jsdoc": "^6.0.0",
37
35
  "swagger-ui-express": "^4.1.6",
38
- "ts-jest": "^27.0.3",
39
- "ts-node": "^10.0.0",
40
- "typescript": "^4.3.5",
41
36
  "winston": "^3.3.3",
42
37
  "winston-daily-rotate-file": "^4.5.5"
43
38
  },
44
39
  "devDependencies": {
40
+ "@swc/cli": "^0.1.51",
41
+ "@swc/core": "^1.2.108",
45
42
  "@types/bcrypt": "^5.0.0",
46
43
  "@types/compression": "^1.7.1",
47
44
  "@types/config": "^0.0.39",
@@ -62,16 +59,23 @@
62
59
  "@types/winston": "^2.4.4",
63
60
  "@typescript-eslint/eslint-plugin": "^4.28.2",
64
61
  "@typescript-eslint/parser": "^4.28.2",
62
+ "cross-env": "^7.0.3",
65
63
  "eslint": "^7.30.0",
66
64
  "eslint-config-prettier": "^8.3.0",
67
65
  "eslint-plugin-prettier": "^3.4.0",
68
66
  "husky": "^7.0.1",
67
+ "jest": "^27.0.6",
69
68
  "lint-staged": "^11.0.0",
70
69
  "node-config": "^0.0.2",
71
70
  "node-gyp": "^8.1.0",
72
71
  "nodemon": "^2.0.9",
72
+ "pm2": "^5.1.0",
73
73
  "prettier": "^2.3.2",
74
74
  "supertest": "^6.1.3",
75
- "tsconfig-paths": "^3.10.1"
75
+ "ts-jest": "^27.0.7",
76
+ "ts-node": "^10.4.0",
77
+ "tsc-alias": "^1.4.1",
78
+ "tsconfig-paths": "^3.10.1",
79
+ "typescript": "^4.5.2"
76
80
  }
77
81
  }
@@ -1,9 +1,8 @@
1
- process.env['NODE_CONFIG_DIR'] = __dirname + '/configs';
2
-
1
+ import '@/index';
2
+ import config from 'config';
3
3
  import compression from 'compression';
4
4
  import cookieParser from 'cookie-parser';
5
5
  import cors from 'cors';
6
- import config from 'config';
7
6
  import express from 'express';
8
7
  import helmet from 'helmet';
9
8
  import hpp from 'hpp';
@@ -2,7 +2,7 @@
2
2
  "env": "development",
3
3
  "dbConfig": {
4
4
  "host": "localhost",
5
- "database": "mongoose",
5
+ "database": "test",
6
6
  "port": 27017
7
7
  },
8
8
  "secretKey": "secretKey",
@@ -2,7 +2,7 @@
2
2
  "env": "production",
3
3
  "dbConfig": {
4
4
  "host": "localhost",
5
- "database": "mongoose",
5
+ "database": "test",
6
6
  "port": 27017
7
7
  },
8
8
  "secretKey": "secretKey",
@@ -2,7 +2,7 @@
2
2
  "env": "test",
3
3
  "dbConfig": {
4
4
  "host": "localhost",
5
- "database": "mongoose",
5
+ "database": "test",
6
6
  "port": 27017
7
7
  },
8
8
  "secretKey": "secretKey",
@@ -0,0 +1,32 @@
1
+ # baseURL
2
+ @baseURL = http://localhost:3000
3
+
4
+ ###
5
+ # User Signup
6
+ POST {{ baseURL }}/signup
7
+ Content-Type: application/json
8
+
9
+ {
10
+ "email": "example@email.com",
11
+ "password": "password"
12
+ }
13
+
14
+ ###
15
+ # User Login
16
+ POST {{ baseURL }}/login
17
+ Content-Type: application/json
18
+
19
+ {
20
+ "email": "example@email.com",
21
+ "password": "password"
22
+ }
23
+
24
+ ###
25
+ # User Logout
26
+ POST {{ baseURL }}/logout
27
+ Content-Type: application/json
28
+
29
+ {
30
+ "email": "example@email.com",
31
+ "password": "password"
32
+ }
@@ -0,0 +1,34 @@
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
@@ -0,0 +1 @@
1
+ process.env['NODE_CONFIG_DIR'] = __dirname + '/configs';
@@ -1,17 +1,17 @@
1
1
  import config from 'config';
2
2
  import { NextFunction, Response } from 'express';
3
- import jwt from 'jsonwebtoken';
3
+ import { verify } from 'jsonwebtoken';
4
4
  import { HttpException } from '@exceptions/HttpException';
5
5
  import { DataStoredInToken, RequestWithUser } from '@interfaces/auth.interface';
6
6
  import userModel from '@models/users.model';
7
7
 
8
8
  const authMiddleware = async (req: RequestWithUser, res: Response, next: NextFunction) => {
9
9
  try {
10
- const Authorization = req.cookies['Authorization'] || req.header('Authorization').split('Bearer ')[1] || null;
10
+ const Authorization = req.cookies['Authorization'] || (req.header('Authorization') ? req.header('Authorization').split('Bearer ')[1] : null);
11
11
 
12
12
  if (Authorization) {
13
13
  const secretKey: string = config.get('secretKey');
14
- const verificationResponse = (await jwt.verify(Authorization, secretKey)) as DataStoredInToken;
14
+ const verificationResponse = (await verify(Authorization, secretKey)) as DataStoredInToken;
15
15
  const userId = verificationResponse._id;
16
16
  const findUser = await userModel.findById(userId);
17
17
 
@@ -1,6 +1,5 @@
1
- process.env['NODE_CONFIG_DIR'] = __dirname + '/configs';
2
-
3
1
  import 'dotenv/config';
2
+ import '@/index';
4
3
  import App from '@/app';
5
4
  import AuthRoute from '@routes/auth.route';
6
5
  import IndexRoute from '@routes/index.route';
@@ -1,6 +1,6 @@
1
- import bcrypt from 'bcrypt';
1
+ import { hash, compare } from 'bcrypt';
2
2
  import config from 'config';
3
- import jwt from 'jsonwebtoken';
3
+ import { sign } from 'jsonwebtoken';
4
4
  import { CreateUserDto } from '@dtos/users.dto';
5
5
  import { HttpException } from '@exceptions/HttpException';
6
6
  import { DataStoredInToken, TokenData } from '@interfaces/auth.interface';
@@ -17,7 +17,7 @@ class AuthService {
17
17
  const findUser: User = await this.users.findOne({ email: userData.email });
18
18
  if (findUser) throw new HttpException(409, `You're email ${userData.email} already exists`);
19
19
 
20
- const hashedPassword = await bcrypt.hash(userData.password, 10);
20
+ const hashedPassword = await hash(userData.password, 10);
21
21
  const createUserData: User = await this.users.create({ ...userData, password: hashedPassword });
22
22
 
23
23
  return createUserData;
@@ -29,7 +29,7 @@ class AuthService {
29
29
  const findUser: User = await this.users.findOne({ email: userData.email });
30
30
  if (!findUser) throw new HttpException(409, `You're email ${userData.email} not found`);
31
31
 
32
- const isPasswordMatching: boolean = await bcrypt.compare(userData.password, findUser.password);
32
+ const isPasswordMatching: boolean = await compare(userData.password, findUser.password);
33
33
  if (!isPasswordMatching) throw new HttpException(409, "You're password not matching");
34
34
 
35
35
  const tokenData = this.createToken(findUser);
@@ -52,7 +52,7 @@ class AuthService {
52
52
  const secretKey: string = config.get('secretKey');
53
53
  const expiresIn: number = 60 * 60;
54
54
 
55
- return { expiresIn, token: jwt.sign(dataStoredInToken, secretKey, { expiresIn }) };
55
+ return { expiresIn, token: sign(dataStoredInToken, secretKey, { expiresIn }) };
56
56
  }
57
57
 
58
58
  public createCookie(tokenData: TokenData): string {
@@ -1,4 +1,4 @@
1
- import bcrypt from 'bcrypt';
1
+ import { hash } from 'bcrypt';
2
2
  import { CreateUserDto } from '@dtos/users.dto';
3
3
  import { HttpException } from '@exceptions/HttpException';
4
4
  import { User } from '@interfaces/users.interface';
@@ -28,7 +28,7 @@ class UserService {
28
28
  const findUser: User = await this.users.findOne({ email: userData.email });
29
29
  if (findUser) throw new HttpException(409, `You're email ${userData.email} already exists`);
30
30
 
31
- const hashedPassword = await bcrypt.hash(userData.password, 10);
31
+ const hashedPassword = await hash(userData.password, 10);
32
32
  const createUserData: User = await this.users.create({ ...userData, password: hashedPassword });
33
33
 
34
34
  return createUserData;
@@ -43,7 +43,7 @@ class UserService {
43
43
  }
44
44
 
45
45
  if (userData.password) {
46
- const hashedPassword = await bcrypt.hash(userData.password, 10);
46
+ const hashedPassword = await hash(userData.password, 10);
47
47
  userData = { ...userData, password: hashedPassword };
48
48
  }
49
49
 
@@ -1,14 +1,14 @@
1
1
  import config from 'config';
2
- import fs from 'fs';
3
- import path from 'path';
2
+ import { existsSync, mkdirSync } from 'fs';
3
+ import { join } from 'path';
4
4
  import winston from 'winston';
5
5
  import winstonDaily from 'winston-daily-rotate-file';
6
6
 
7
7
  // logs dir
8
- const logDir: string = path.join(__dirname, config.get('log.dir'));
8
+ const logDir: string = join(__dirname, config.get('log.dir'));
9
9
 
10
- if (!fs.existsSync(logDir)) {
11
- fs.mkdirSync(logDir);
10
+ if (!existsSync(logDir)) {
11
+ mkdirSync(logDir);
12
12
  }
13
13
 
14
14
  // Define log format
@@ -13,7 +13,7 @@
13
13
  "pretty": true,
14
14
  "sourceMap": true,
15
15
  "declaration": true,
16
- "outDir": "./dist",
16
+ "outDir": "dist",
17
17
  "allowJs": true,
18
18
  "noEmit": false,
19
19
  "esModuleInterop": true,
@@ -35,5 +35,5 @@
35
35
  }
36
36
  },
37
37
  "include": ["src/**/*.ts", "src/**/*.json", ".env"],
38
- "exclude": ["node_modules"]
38
+ "exclude": ["node_modules", "src/http", "src/logs", "src/tests"]
39
39
  }
package/lib/prisma/.env CHANGED
@@ -7,4 +7,4 @@ PORT=3000
7
7
  # Prisma supports the native connection string format for PostgreSQL, MySQL and SQLite.
8
8
  # See the documentation for all the connection string options: https://pris.ly/d/connection-strings
9
9
 
10
- DATABASE_URL="mysql://root:password@localhost:3306/prisma"
10
+ DATABASE_URL="mysql://root:password@localhost:3306/test"
@@ -0,0 +1,37 @@
1
+ {
2
+ "jsc": {
3
+ "parser": {
4
+ "syntax": "typescript",
5
+ "tsx": false,
6
+ "dynamicImport": true,
7
+ "decorators": true
8
+ },
9
+ "transform": {
10
+ "legacyDecorator": true,
11
+ "decoratorMetadata": true
12
+ },
13
+ "target": "es2017",
14
+ "externalHelpers": false,
15
+ "keepClassNames": true,
16
+ "loose": false,
17
+ "minify": {
18
+ "compress": false,
19
+ "mangle": false
20
+ },
21
+ "baseUrl": "src",
22
+ "paths": {
23
+ "@/*": ["*"],
24
+ "@controllers/*": ["controllers/*"],
25
+ "@dtos/*": ["dtos/*"],
26
+ "@exceptions/*": ["exceptions/*"],
27
+ "@interfaces/*": ["interfaces/*"],
28
+ "@middlewares/*": ["middlewares/*"],
29
+ "@routes/*": ["routes/*"],
30
+ "@services/*": ["services/*"],
31
+ "@utils/*": ["utils/*"]
32
+ }
33
+ },
34
+ "module": {
35
+ "type": "commonjs"
36
+ }
37
+ }
@@ -19,11 +19,6 @@ services:
19
19
  container_name: server
20
20
  ports:
21
21
  - '3000:3000'
22
- environment:
23
- MYSQL_USER: root
24
- MYSQL_PASSWORD: password
25
- MYSQL_HOST: mysql
26
- MYSQL_DATABASE: prisma
27
22
  volumes:
28
23
  - ./:/app
29
24
  - /app/node_modules
@@ -40,7 +35,7 @@ services:
40
35
  environment:
41
36
  MYSQL_ROOT_USER: root
42
37
  MYSQL_ROOT_PASSWORD: password
43
- MYSQL_DATABASE: prisma
38
+ MYSQL_DATABASE: test
44
39
  ports:
45
40
  - '3306:3306'
46
41
  networks:
@@ -5,8 +5,8 @@
5
5
  ],
6
6
  "ext": "js,ts,json",
7
7
  "ignore": [
8
- "src/**/*.spec.ts",
9
- "src/**/*.test.ts"
8
+ "src/logs/*",
9
+ "src/**/*.{spec,test}.ts"
10
10
  ],
11
11
  "exec": "ts-node -r tsconfig-paths/register --transpile-only src/server.ts"
12
12
  }
@@ -7,7 +7,8 @@
7
7
  "scripts": {
8
8
  "start": "npm run build && cross-env NODE_ENV=production node dist/server.js",
9
9
  "dev": "cross-env NODE_ENV=development nodemon",
10
- "build": "tsc && npx tsc-alias",
10
+ "build": "swc src -d dist --source-maps --copy-files",
11
+ "build:tsc": "tsc && tsc-alias",
11
12
  "test": "jest --forceExit --detectOpenHandles",
12
13
  "lint": "eslint --ignore-path .gitignore --ext .ts src/",
13
14
  "lint:fix": "npm run lint -- --fix",
@@ -21,7 +22,7 @@
21
22
  "schema": "src/prisma/schema.prisma"
22
23
  },
23
24
  "dependencies": {
24
- "@prisma/client": "^2.26.0",
25
+ "@prisma/client": "^3.7.0",
25
26
  "bcrypt": "^5.0.1",
26
27
  "class-transformer": "^0.4.0",
27
28
  "class-validator": "^0.13.1",
@@ -29,25 +30,21 @@
29
30
  "config": "^3.3.6",
30
31
  "cookie-parser": "^1.4.5",
31
32
  "cors": "^2.8.5",
32
- "cross-env": "^7.0.3",
33
33
  "dotenv": "^10.0.0",
34
34
  "envalid": "^7.1.0",
35
35
  "express": "^4.17.1",
36
36
  "helmet": "^4.6.0",
37
37
  "hpp": "^0.2.3",
38
- "jest": "^27.0.6",
39
38
  "jsonwebtoken": "^8.5.1",
40
39
  "morgan": "^1.10.0",
41
- "pm2": "^5.1.0",
42
40
  "swagger-jsdoc": "^6.0.0",
43
41
  "swagger-ui-express": "^4.1.6",
44
- "ts-jest": "^27.0.3",
45
- "ts-node": "^10.0.0",
46
- "typescript": "^4.3.5",
47
42
  "winston": "^3.3.3",
48
43
  "winston-daily-rotate-file": "^4.5.5"
49
44
  },
50
45
  "devDependencies": {
46
+ "@swc/cli": "^0.1.51",
47
+ "@swc/core": "^1.2.108",
51
48
  "@types/bcrypt": "^5.0.0",
52
49
  "@types/compression": "^1.7.1",
53
50
  "@types/config": "^0.0.39",
@@ -67,17 +64,24 @@
67
64
  "@types/winston": "^2.4.4",
68
65
  "@typescript-eslint/eslint-plugin": "^4.28.2",
69
66
  "@typescript-eslint/parser": "^4.28.2",
67
+ "cross-env": "^7.0.3",
70
68
  "eslint": "^7.30.0",
71
69
  "eslint-config-prettier": "^8.3.0",
72
70
  "eslint-plugin-prettier": "^3.4.0",
73
71
  "husky": "^7.0.1",
72
+ "jest": "^27.0.6",
74
73
  "lint-staged": "^11.0.0",
75
74
  "node-config": "^0.0.2",
76
75
  "node-gyp": "^8.1.0",
77
76
  "nodemon": "^2.0.9",
77
+ "pm2": "^5.1.0",
78
78
  "prettier": "^2.3.2",
79
- "prisma": "^2.26.0",
79
+ "prisma": "^3.7.0",
80
80
  "supertest": "^6.1.3",
81
- "tsconfig-paths": "^3.10.1"
81
+ "ts-jest": "^27.0.7",
82
+ "ts-node": "^10.4.0",
83
+ "tsc-alias": "^1.4.1",
84
+ "tsconfig-paths": "^3.10.1",
85
+ "typescript": "^4.5.2"
82
86
  }
83
87
  }
@@ -1,9 +1,8 @@
1
- process.env['NODE_CONFIG_DIR'] = __dirname + '/configs';
2
-
1
+ import '@/index';
2
+ import config from 'config';
3
3
  import compression from 'compression';
4
4
  import cookieParser from 'cookie-parser';
5
5
  import cors from 'cors';
6
- import config from 'config';
7
6
  import express from 'express';
8
7
  import helmet from 'helmet';
9
8
  import hpp from 'hpp';