typescript-express-starter 9.2.0 → 10.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 (392) hide show
  1. package/.vscode/configurationCache.log +1 -0
  2. package/.vscode/dryrun.log +6 -0
  3. package/.vscode/settings.json +3 -0
  4. package/.vscode/targets.log +239 -0
  5. package/CONTRIBUTORS.md +61 -0
  6. package/README.kr.md +122 -167
  7. package/README.md +118 -163
  8. package/bin/cli.js +1 -1
  9. package/lib/default/.swcrc +0 -3
  10. package/lib/default/Dockerfile.dev +18 -0
  11. package/lib/default/Dockerfile.prod +18 -0
  12. package/lib/default/Makefile +29 -16
  13. package/lib/default/docker-compose.yml +8 -8
  14. package/lib/default/package.json +3 -1
  15. package/lib/default/src/app.ts +4 -5
  16. package/lib/default/src/controllers/auth.controller.ts +9 -11
  17. package/lib/default/src/controllers/users.controller.ts +11 -13
  18. package/lib/default/src/dtos/users.dto.ts +12 -1
  19. package/lib/default/src/interfaces/users.interface.ts +2 -2
  20. package/lib/default/src/middlewares/auth.middleware.ts +16 -10
  21. package/lib/default/src/middlewares/error.middleware.ts +2 -4
  22. package/lib/default/src/middlewares/validation.middleware.ts +22 -20
  23. package/lib/default/src/models/users.model.ts +6 -8
  24. package/lib/default/src/routes/auth.route.ts +8 -11
  25. package/lib/default/src/routes/users.route.ts +10 -12
  26. package/lib/default/src/server.ts +6 -7
  27. package/lib/default/src/services/auth.service.ts +22 -33
  28. package/lib/default/src/services/users.service.ts +16 -25
  29. package/lib/{graphql/src/tests → default/src/test}/auth.test.ts +21 -21
  30. package/lib/default/src/test/users.test.ts +62 -0
  31. package/lib/default/src/utils/validateEnv.ts +1 -3
  32. package/lib/default/tsconfig.json +1 -1
  33. package/lib/graphql/.env.development.local +6 -6
  34. package/lib/graphql/.env.production.local +6 -6
  35. package/lib/graphql/.env.test.local +6 -6
  36. package/lib/graphql/.swcrc +1 -1
  37. package/lib/graphql/Dockerfile.dev +19 -0
  38. package/lib/graphql/Dockerfile.prod +19 -0
  39. package/lib/graphql/Makefile +32 -15
  40. package/lib/graphql/docker-compose.yml +23 -15
  41. package/lib/graphql/package.json +2 -1
  42. package/lib/graphql/src/app.ts +14 -13
  43. package/lib/graphql/src/config/index.ts +2 -2
  44. package/lib/graphql/src/{databases → database}/index.ts +6 -6
  45. package/lib/graphql/src/dtos/users.dto.ts +14 -1
  46. package/lib/graphql/src/interfaces/users.interface.ts +2 -2
  47. package/lib/graphql/src/middlewares/auth.middleware.ts +16 -6
  48. package/lib/graphql/src/middlewares/error.middleware.ts +2 -4
  49. package/lib/graphql/src/repositories/auth.repository.ts +16 -24
  50. package/lib/graphql/src/repositories/users.repository.ts +5 -14
  51. package/lib/graphql/src/resolvers/auth.resolver.ts +2 -2
  52. package/lib/graphql/src/resolvers/users.resolver.ts +4 -4
  53. package/lib/graphql/src/server.ts +6 -7
  54. package/lib/graphql/src/test/auth.test.ts +10 -0
  55. package/lib/graphql/src/test/users.test.ts +11 -0
  56. package/lib/graphql/src/typedefs/users.type.ts +2 -2
  57. package/lib/graphql/src/utils/logger.ts +2 -0
  58. package/lib/graphql/src/utils/validateEnv.ts +1 -3
  59. package/lib/graphql/tsconfig.json +2 -2
  60. package/lib/knex/.env.development.local +2 -2
  61. package/lib/knex/.env.production.local +3 -3
  62. package/lib/knex/.env.test.local +3 -3
  63. package/lib/knex/.swcrc +1 -1
  64. package/lib/knex/Dockerfile.dev +19 -0
  65. package/lib/knex/Dockerfile.prod +19 -0
  66. package/lib/knex/Makefile +32 -15
  67. package/lib/knex/docker-compose.yml +19 -14
  68. package/lib/knex/knexfile.ts +7 -9
  69. package/lib/knex/package.json +2 -0
  70. package/lib/knex/src/app.ts +6 -7
  71. package/lib/knex/src/config/index.ts +2 -1
  72. package/lib/knex/src/controllers/auth.controller.ts +9 -11
  73. package/lib/knex/src/controllers/users.controller.ts +10 -12
  74. package/lib/knex/src/{databases → database}/index.ts +4 -4
  75. package/lib/knex/src/database/migrations/20210713110926_initial.ts +17 -0
  76. package/lib/knex/src/dtos/users.dto.ts +12 -1
  77. package/lib/knex/src/interfaces/users.interface.ts +2 -2
  78. package/lib/knex/src/middlewares/auth.middleware.ts +17 -10
  79. package/lib/knex/src/middlewares/error.middleware.ts +2 -4
  80. package/lib/knex/src/middlewares/validation.middleware.ts +22 -20
  81. package/lib/knex/src/models/users.model.ts +2 -2
  82. package/lib/knex/src/routes/auth.route.ts +8 -10
  83. package/lib/knex/src/routes/users.route.ts +10 -12
  84. package/lib/knex/src/server.ts +6 -7
  85. package/lib/knex/src/services/auth.service.ts +24 -33
  86. package/lib/knex/src/services/users.service.ts +14 -19
  87. package/lib/knex/src/{tests → test}/auth.test.ts +2 -2
  88. package/lib/knex/src/{tests → test}/users.test.ts +2 -2
  89. package/lib/knex/src/utils/validateEnv.ts +1 -3
  90. package/lib/knex/tsconfig.json +2 -2
  91. package/lib/mikro-orm/.env.production.local +1 -1
  92. package/lib/mikro-orm/.env.test.local +1 -1
  93. package/lib/mikro-orm/.swcrc +1 -1
  94. package/lib/mikro-orm/Dockerfile.dev +19 -0
  95. package/lib/mikro-orm/Dockerfile.prod +19 -0
  96. package/lib/mikro-orm/Makefile +32 -15
  97. package/lib/mikro-orm/docker-compose.yml +20 -11
  98. package/lib/mikro-orm/package.json +2 -0
  99. package/lib/mikro-orm/src/app.ts +10 -12
  100. package/lib/mikro-orm/src/config/index.ts +2 -1
  101. package/lib/mikro-orm/src/controllers/auth.controller.ts +9 -11
  102. package/lib/mikro-orm/src/controllers/users.controller.ts +11 -13
  103. package/lib/mikro-orm/src/dtos/users.dto.ts +12 -1
  104. package/lib/mikro-orm/src/interfaces/users.interface.ts +1 -1
  105. package/lib/mikro-orm/src/middlewares/auth.middleware.ts +17 -10
  106. package/lib/mikro-orm/src/middlewares/error.middleware.ts +2 -4
  107. package/lib/mikro-orm/src/middlewares/validation.middleware.ts +22 -20
  108. package/lib/mikro-orm/src/routes/auth.route.ts +8 -10
  109. package/lib/mikro-orm/src/routes/users.route.ts +9 -11
  110. package/lib/mikro-orm/src/server.ts +6 -7
  111. package/lib/mikro-orm/src/services/auth.service.ts +19 -29
  112. package/lib/mikro-orm/src/services/users.service.ts +8 -16
  113. package/lib/mikro-orm/src/{tests → test}/auth.test.ts +3 -4
  114. package/lib/mikro-orm/src/{tests → test}/users.test.ts +4 -5
  115. package/lib/mikro-orm/src/utils/validateEnv.ts +1 -3
  116. package/lib/mikro-orm/tsconfig.json +2 -2
  117. package/lib/mongoose/.env.production.local +1 -1
  118. package/lib/mongoose/.env.test.local +1 -1
  119. package/lib/mongoose/.swcrc +1 -1
  120. package/lib/mongoose/Dockerfile.dev +19 -0
  121. package/lib/mongoose/Dockerfile.prod +19 -0
  122. package/lib/mongoose/Makefile +32 -15
  123. package/lib/mongoose/docker-compose.yml +20 -11
  124. package/lib/mongoose/package.json +2 -0
  125. package/lib/mongoose/src/app.ts +6 -7
  126. package/lib/mongoose/src/config/index.ts +2 -1
  127. package/lib/mongoose/src/controllers/auth.controller.ts +9 -11
  128. package/lib/mongoose/src/controllers/users.controller.ts +11 -13
  129. package/lib/mongoose/src/dtos/users.dto.ts +12 -1
  130. package/lib/mongoose/src/interfaces/users.interface.ts +1 -1
  131. package/lib/mongoose/src/middlewares/auth.middleware.ts +16 -9
  132. package/lib/mongoose/src/middlewares/error.middleware.ts +2 -4
  133. package/lib/mongoose/src/middlewares/validation.middleware.ts +22 -20
  134. package/lib/mongoose/src/models/users.model.ts +2 -4
  135. package/lib/mongoose/src/routes/auth.route.ts +8 -10
  136. package/lib/mongoose/src/routes/users.route.ts +9 -11
  137. package/lib/mongoose/src/server.ts +6 -7
  138. package/lib/mongoose/src/services/auth.service.ts +22 -33
  139. package/lib/mongoose/src/services/users.service.ts +14 -24
  140. package/lib/{typegoose/src/tests → mongoose/src/test}/users.test.ts +7 -7
  141. package/lib/mongoose/src/utils/validateEnv.ts +1 -3
  142. package/lib/mongoose/tsconfig.json +2 -2
  143. package/lib/node-postgres/.dockerignore +18 -0
  144. package/lib/node-postgres/.editorconfig +9 -0
  145. package/lib/node-postgres/.env.development.local +13 -0
  146. package/lib/node-postgres/.env.production.local +13 -0
  147. package/lib/node-postgres/.env.test.local +13 -0
  148. package/lib/node-postgres/.eslintignore +1 -0
  149. package/lib/node-postgres/.eslintrc +18 -0
  150. package/lib/node-postgres/.huskyrc +5 -0
  151. package/lib/node-postgres/.lintstagedrc.json +5 -0
  152. package/lib/node-postgres/.prettierrc +8 -0
  153. package/lib/node-postgres/.swcrc +39 -0
  154. package/lib/node-postgres/.vscode/launch.json +35 -0
  155. package/lib/node-postgres/.vscode/settings.json +6 -0
  156. package/lib/node-postgres/Dockerfile.dev +17 -0
  157. package/lib/node-postgres/Dockerfile.prod +17 -0
  158. package/lib/node-postgres/Makefile +46 -0
  159. package/lib/node-postgres/docker-compose.yml +61 -0
  160. package/lib/node-postgres/ecosystem.config.js +57 -0
  161. package/lib/node-postgres/jest.config.js +12 -0
  162. package/lib/node-postgres/nginx.conf +40 -0
  163. package/lib/node-postgres/nodemon.json +12 -0
  164. package/lib/node-postgres/package.json +78 -0
  165. package/lib/node-postgres/src/app.ts +87 -0
  166. package/lib/node-postgres/src/config/index.ts +6 -0
  167. package/lib/node-postgres/src/controllers/auth.controller.ts +44 -0
  168. package/lib/node-postgres/src/controllers/users.controller.ts +63 -0
  169. package/lib/node-postgres/src/database/index.ts +6 -0
  170. package/lib/node-postgres/src/database/init.sql +110 -0
  171. package/lib/node-postgres/src/dtos/users.dto.ts +20 -0
  172. package/lib/node-postgres/src/http/auth.http +27 -0
  173. package/lib/node-postgres/src/http/users.http +34 -0
  174. package/lib/node-postgres/src/interfaces/auth.interface.ts +15 -0
  175. package/lib/node-postgres/src/interfaces/routes.interface.ts +6 -0
  176. package/lib/node-postgres/src/interfaces/users.interface.ts +5 -0
  177. package/lib/node-postgres/src/middlewares/auth.middleware.ts +38 -0
  178. package/lib/node-postgres/src/middlewares/error.middleware.ts +15 -0
  179. package/lib/node-postgres/src/middlewares/validation.middleware.ts +27 -0
  180. package/lib/node-postgres/src/models/users.model.ts +9 -0
  181. package/lib/node-postgres/src/routes/auth.route.ts +21 -0
  182. package/lib/node-postgres/src/routes/users.route.ts +23 -0
  183. package/lib/node-postgres/src/server.ts +10 -0
  184. package/lib/node-postgres/src/services/auth.service.ts +52 -0
  185. package/lib/node-postgres/src/services/users.service.ts +51 -0
  186. package/lib/{default/src/tests → node-postgres/src/test}/auth.test.ts +2 -2
  187. package/lib/{default/src/tests → node-postgres/src/test}/users.test.ts +5 -5
  188. package/lib/node-postgres/src/utils/logger.ts +65 -0
  189. package/lib/node-postgres/src/utils/validateEnv.ts +8 -0
  190. package/lib/node-postgres/swagger.yaml +123 -0
  191. package/lib/node-postgres/tsconfig.json +40 -0
  192. package/lib/prisma/.env.production.local +1 -1
  193. package/lib/prisma/.env.test.local +1 -1
  194. package/lib/prisma/Dockerfile.dev +19 -0
  195. package/lib/prisma/Dockerfile.prod +19 -0
  196. package/lib/prisma/Makefile +32 -15
  197. package/lib/prisma/docker-compose.yml +15 -14
  198. package/lib/prisma/package.json +2 -0
  199. package/lib/prisma/src/app.ts +4 -5
  200. package/lib/prisma/src/controllers/auth.controller.ts +10 -12
  201. package/lib/prisma/src/controllers/users.controller.ts +12 -14
  202. package/lib/prisma/src/dtos/users.dto.ts +12 -1
  203. package/lib/prisma/src/interfaces/auth.interface.ts +1 -1
  204. package/lib/prisma/src/interfaces/users.interface.ts +5 -0
  205. package/lib/prisma/src/middlewares/auth.middleware.ts +16 -11
  206. package/lib/prisma/src/middlewares/error.middleware.ts +2 -4
  207. package/lib/prisma/src/middlewares/validation.middleware.ts +22 -20
  208. package/lib/prisma/src/routes/auth.route.ts +8 -10
  209. package/lib/prisma/src/routes/users.route.ts +9 -11
  210. package/lib/prisma/src/server.ts +6 -7
  211. package/lib/prisma/src/services/auth.service.ts +6 -12
  212. package/lib/prisma/src/services/users.service.ts +15 -23
  213. package/lib/prisma/src/utils/validateEnv.ts +1 -3
  214. package/lib/prisma/tsconfig.json +1 -1
  215. package/lib/routing-controllers/Dockerfile.dev +19 -0
  216. package/lib/routing-controllers/Dockerfile.prod +19 -0
  217. package/lib/routing-controllers/Makefile +29 -16
  218. package/lib/routing-controllers/docker-compose.yml +9 -9
  219. package/lib/routing-controllers/package.json +1 -0
  220. package/lib/routing-controllers/src/app.ts +4 -6
  221. package/lib/routing-controllers/src/controllers/auth.controller.ts +13 -12
  222. package/lib/routing-controllers/src/controllers/users.controller.ts +15 -13
  223. package/lib/routing-controllers/src/dtos/users.dto.ts +12 -1
  224. package/lib/routing-controllers/src/interfaces/users.interface.ts +1 -1
  225. package/lib/routing-controllers/src/middlewares/auth.middleware.ts +16 -10
  226. package/lib/routing-controllers/src/middlewares/error.middleware.ts +2 -5
  227. package/lib/routing-controllers/src/middlewares/validation.middleware.ts +23 -27
  228. package/lib/routing-controllers/src/models/users.model.ts +1 -3
  229. package/lib/routing-controllers/src/server.ts +5 -6
  230. package/lib/routing-controllers/src/services/auth.service.ts +21 -31
  231. package/lib/routing-controllers/src/services/users.service.ts +13 -21
  232. package/lib/routing-controllers/src/{tests → test}/auth.test.ts +1 -1
  233. package/lib/routing-controllers/src/{tests → test}/users.test.ts +10 -10
  234. package/lib/routing-controllers/src/utils/validateEnv.ts +1 -3
  235. package/lib/routing-controllers/tsconfig.json +1 -1
  236. package/lib/sequelize/.env.development.local +2 -2
  237. package/lib/sequelize/.env.production.local +3 -3
  238. package/lib/sequelize/.env.test.local +3 -3
  239. package/lib/sequelize/.swcrc +1 -1
  240. package/lib/sequelize/Dockerfile.dev +23 -0
  241. package/lib/sequelize/Dockerfile.prod +23 -0
  242. package/lib/sequelize/Makefile +32 -15
  243. package/lib/sequelize/docker-compose.yml +19 -14
  244. package/lib/sequelize/package.json +2 -0
  245. package/lib/sequelize/src/app.ts +5 -6
  246. package/lib/sequelize/src/config/index.ts +2 -1
  247. package/lib/sequelize/src/controllers/auth.controller.ts +7 -8
  248. package/lib/sequelize/src/controllers/users.controller.ts +9 -10
  249. package/lib/sequelize/src/{databases → database}/index.ts +1 -3
  250. package/lib/sequelize/src/dtos/users.dto.ts +12 -1
  251. package/lib/sequelize/src/interfaces/users.interface.ts +1 -1
  252. package/lib/sequelize/src/middlewares/auth.middleware.ts +16 -10
  253. package/lib/sequelize/src/middlewares/error.middleware.ts +2 -4
  254. package/lib/sequelize/src/middlewares/validation.middleware.ts +22 -20
  255. package/lib/sequelize/src/routes/auth.route.ts +8 -11
  256. package/lib/sequelize/src/routes/users.route.ts +9 -11
  257. package/lib/sequelize/src/server.ts +6 -7
  258. package/lib/sequelize/src/services/auth.service.ts +20 -31
  259. package/lib/sequelize/src/services/users.service.ts +14 -25
  260. package/lib/sequelize/src/{tests → test}/auth.test.ts +2 -2
  261. package/lib/sequelize/src/{tests → test}/users.test.ts +2 -2
  262. package/lib/sequelize/src/utils/validateEnv.ts +1 -3
  263. package/lib/sequelize/tsconfig.json +2 -2
  264. package/lib/starter.js +17 -26
  265. package/lib/typegoose/.env.production.local +1 -1
  266. package/lib/typegoose/.env.test.local +1 -1
  267. package/lib/typegoose/.swcrc +1 -1
  268. package/lib/typegoose/Dockerfile.dev +19 -0
  269. package/lib/typegoose/Dockerfile.prod +19 -0
  270. package/lib/typegoose/Makefile +32 -15
  271. package/lib/typegoose/docker-compose.yml +20 -11
  272. package/lib/typegoose/package.json +2 -0
  273. package/lib/typegoose/src/app.ts +3 -2
  274. package/lib/typegoose/src/config/index.ts +2 -1
  275. package/lib/typegoose/src/controllers/auth.controller.ts +9 -11
  276. package/lib/typegoose/src/controllers/users.controller.ts +11 -13
  277. package/lib/typegoose/src/database/index.ts +11 -0
  278. package/lib/typegoose/src/dtos/users.dto.ts +12 -1
  279. package/lib/typegoose/src/interfaces/users.interface.ts +1 -1
  280. package/lib/typegoose/src/middlewares/auth.middleware.ts +16 -10
  281. package/lib/typegoose/src/middlewares/error.middleware.ts +2 -4
  282. package/lib/typegoose/src/middlewares/validation.middleware.ts +22 -20
  283. package/lib/typegoose/src/models/users.model.ts +1 -3
  284. package/lib/typegoose/src/routes/auth.route.ts +8 -11
  285. package/lib/typegoose/src/routes/users.route.ts +9 -11
  286. package/lib/typegoose/src/server.ts +5 -6
  287. package/lib/typegoose/src/services/auth.service.ts +23 -32
  288. package/lib/typegoose/src/services/users.service.ts +12 -21
  289. package/lib/typegoose/src/{tests → test}/auth.test.ts +2 -2
  290. package/lib/{mongoose/src/tests → typegoose/src/test}/users.test.ts +7 -7
  291. package/lib/typegoose/src/utils/validateEnv.ts +1 -3
  292. package/lib/typegoose/tsconfig.json +2 -2
  293. package/lib/typeorm/.env.development.local +2 -2
  294. package/lib/typeorm/.env.production.local +3 -3
  295. package/lib/typeorm/.env.test.local +3 -3
  296. package/lib/typeorm/.swcrc +1 -1
  297. package/lib/typeorm/Dockerfile.dev +19 -0
  298. package/lib/typeorm/Dockerfile.prod +19 -0
  299. package/lib/typeorm/Makefile +32 -15
  300. package/lib/typeorm/docker-compose.yml +21 -14
  301. package/lib/typeorm/package.json +1 -0
  302. package/lib/typeorm/src/app.ts +6 -8
  303. package/lib/typeorm/src/config/index.ts +2 -1
  304. package/lib/typeorm/src/controllers/auth.controller.ts +9 -11
  305. package/lib/typeorm/src/controllers/users.controller.ts +11 -13
  306. package/lib/typeorm/src/{databases → database}/index.ts +3 -3
  307. package/lib/typeorm/src/dtos/users.dto.ts +12 -1
  308. package/lib/typeorm/src/exceptions/httpException.ts +10 -0
  309. package/lib/typeorm/src/interfaces/users.interface.ts +1 -1
  310. package/lib/typeorm/src/middlewares/auth.middleware.ts +14 -7
  311. package/lib/typeorm/src/middlewares/error.middleware.ts +2 -4
  312. package/lib/typeorm/src/middlewares/validation.middleware.ts +22 -20
  313. package/lib/typeorm/src/routes/auth.route.ts +8 -11
  314. package/lib/typeorm/src/routes/users.route.ts +9 -11
  315. package/lib/typeorm/src/server.ts +6 -7
  316. package/lib/typeorm/src/services/auth.service.ts +20 -28
  317. package/lib/typeorm/src/services/users.service.ts +6 -16
  318. package/lib/typeorm/src/{tests → test}/auth.test.ts +5 -5
  319. package/lib/typeorm/src/{tests → test}/users.test.ts +5 -5
  320. package/lib/typeorm/src/utils/validateEnv.ts +1 -3
  321. package/lib/typeorm/tsconfig.json +2 -2
  322. package/package.json +2 -1
  323. package/lib/default/Dockerfile +0 -24
  324. package/lib/default/src/controllers/index.controller.ts +0 -13
  325. package/lib/default/src/routes/index.route.ts +0 -19
  326. package/lib/default/src/utils/util.ts +0 -19
  327. package/lib/graphql/Dockerfile +0 -24
  328. package/lib/graphql/src/tests/index.test.ts +0 -18
  329. package/lib/graphql/src/tests/users.test.ts +0 -71
  330. package/lib/graphql/src/utils/util.ts +0 -19
  331. package/lib/knex/Dockerfile +0 -24
  332. package/lib/knex/src/controllers/index.controller.ts +0 -13
  333. package/lib/knex/src/databases/migrations/20210713110926_initial.ts +0 -13
  334. package/lib/knex/src/routes/index.route.ts +0 -19
  335. package/lib/knex/src/tests/index.test.ts +0 -17
  336. package/lib/knex/src/utils/util.ts +0 -19
  337. package/lib/mikro-orm/Dockerfile +0 -24
  338. package/lib/mikro-orm/src/controllers/index.controller.ts +0 -13
  339. package/lib/mikro-orm/src/routes/index.route.ts +0 -19
  340. package/lib/mikro-orm/src/tests/index.test.ts +0 -18
  341. package/lib/mikro-orm/src/utils/util.ts +0 -19
  342. package/lib/mongoose/Dockerfile +0 -24
  343. package/lib/mongoose/src/controllers/index.controller.ts +0 -13
  344. package/lib/mongoose/src/routes/index.route.ts +0 -19
  345. package/lib/mongoose/src/utils/util.ts +0 -19
  346. package/lib/prisma/Dockerfile +0 -24
  347. package/lib/prisma/src/controllers/index.controller.ts +0 -13
  348. package/lib/prisma/src/routes/index.route.ts +0 -19
  349. package/lib/prisma/src/tests/index.test.ts +0 -18
  350. package/lib/prisma/src/utils/util.ts +0 -19
  351. package/lib/routing-controllers/Dockerfile +0 -24
  352. package/lib/routing-controllers/src/controllers/index.controller.ts +0 -9
  353. package/lib/routing-controllers/src/tests/index.test.ts +0 -17
  354. package/lib/routing-controllers/src/utils/util.ts +0 -19
  355. package/lib/sequelize/Dockerfile +0 -28
  356. package/lib/sequelize/src/controllers/index.controller.ts +0 -13
  357. package/lib/sequelize/src/routes/index.route.ts +0 -19
  358. package/lib/sequelize/src/tests/index.test.ts +0 -18
  359. package/lib/sequelize/src/utils/util.ts +0 -19
  360. package/lib/typegoose/Dockerfile +0 -24
  361. package/lib/typegoose/src/controllers/index.controller.ts +0 -13
  362. package/lib/typegoose/src/databases/index.ts +0 -3
  363. package/lib/typegoose/src/routes/index.route.ts +0 -19
  364. package/lib/typegoose/src/tests/index.test.ts +0 -18
  365. package/lib/typegoose/src/utils/util.ts +0 -19
  366. package/lib/typeorm/Dockerfile +0 -24
  367. package/lib/typeorm/src/controllers/index.controller.ts +0 -13
  368. package/lib/typeorm/src/routes/index.route.ts +0 -19
  369. package/lib/typeorm/src/tests/index.test.ts +0 -18
  370. package/lib/typeorm/src/utils/util.ts +0 -19
  371. package/lib/default/src/exceptions/{HttpException.ts → httpException.ts} +0 -0
  372. package/lib/graphql/src/exceptions/{HttpException.ts → httpException.ts} +0 -0
  373. package/lib/knex/src/{databases → database}/migrations/.gitkeep +0 -0
  374. package/lib/knex/src/{databases → database}/seeds/.gitkeep +0 -0
  375. package/lib/knex/src/exceptions/{HttpException.ts → httpException.ts} +0 -0
  376. package/lib/mikro-orm/src/{databases → database}/index.ts +0 -0
  377. package/lib/mikro-orm/src/exceptions/{HttpException.ts → httpException.ts} +0 -0
  378. package/lib/mongoose/src/{databases → database}/index.ts +0 -0
  379. package/lib/mongoose/src/exceptions/{HttpException.ts → httpException.ts} +0 -0
  380. package/lib/mongoose/src/{tests → test}/auth.test.ts +0 -0
  381. package/lib/{default/src/tests → mongoose/src/test}/index.test.ts +0 -0
  382. package/lib/{prisma/src/exceptions/HttpException.ts → node-postgres/src/exceptions/httpException.ts} +0 -0
  383. package/lib/{sequelize/src/exceptions/HttpException.ts → prisma/src/exceptions/httpException.ts} +0 -0
  384. package/lib/prisma/src/{tests → test}/auth.test.ts +1 -1
  385. package/lib/{mongoose/src/tests → prisma/src/test}/index.test.ts +0 -0
  386. package/lib/prisma/src/{tests → test}/users.test.ts +1 -1
  387. /package/lib/routing-controllers/src/exceptions/{HttpException.ts → httpException.ts} +0 -0
  388. /package/lib/sequelize/src/{migrations → database/migrations}/.gitkeep +0 -0
  389. /package/lib/sequelize/src/{seeders → database/seeders}/.gitkeep +0 -0
  390. /package/lib/{typegoose/src/exceptions/HttpException.ts → sequelize/src/exceptions/httpException.ts} +0 -0
  391. /package/lib/{typeorm/src/exceptions/HttpException.ts → typegoose/src/exceptions/httpException.ts} +0 -0
  392. /package/lib/typeorm/src/{migration → database/migrations}/.gitkeep +0 -0
@@ -2,28 +2,45 @@
2
2
  # ex) production-stage: make build APP_NAME=<APP_NAME>
3
3
  # ex) development-stage: make build-dev APP_NAME=<APP_NAME>
4
4
 
5
+ SHELL := /bin/bash
6
+
5
7
  APP_NAME = typescript-express
6
8
  APP_NAME := $(APP_NAME)
7
9
 
8
- .PHONY: build
9
- # Build the container image - Dvelopment
10
- build-dev:
10
+ .PHONY: help start clean db test
11
+
12
+ help:
13
+ @grep -E '^[1-9a-zA-Z_-]+:.*?## .*$$|(^#--)' $(MAKEFILE_LIST) \
14
+ | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[32m %-43s\033[0m %s\n", $$1, $$2}' \
15
+ | sed -e 's/\[32m #-- /[33m/'
16
+
17
+ #-- Docker
18
+ up: ## Up the container images
19
+ docker-compose up -d
20
+
21
+ down: ## Down the container images
22
+ docker-compose down
23
+
24
+ build: ## Build the container image - Production
11
25
  docker build -t ${APP_NAME}\
12
- --target development-build-stage\
13
- -f Dockerfile .
26
+ -f Dockerfile.prod .
14
27
 
15
- # Build the container image - Production
16
- build:
28
+ build-dev: ## Build the container image - Dvelopment
17
29
  docker build -t ${APP_NAME}\
18
- --target production-build-stage\
19
- -f Dockerfile .
30
+ -f Dockerfile.dev .
20
31
 
21
- # Clean the container image
22
- clean:
32
+ run: ## Run the container image
33
+ docker run -d -it -p 3000:3000 ${APP_NAME}
34
+
35
+ pause: ## Pause the containers
36
+ docker container rm -f ${APP_NAME}
37
+
38
+ clean: ## Clean the images
23
39
  docker rmi -f ${APP_NAME}
24
40
 
25
- # Run the container image
26
- run:
27
- docker run -d -it -p 3000:3000 ${APP_NAME}
41
+ remove: ## Remove the volumes
42
+ docker volume rm -f ${APP_NAME}
28
43
 
29
- all: build
44
+ #-- Database
45
+ db: ## Start the local database MongoDB
46
+ docker-compose up -d mongo
@@ -1,39 +1,48 @@
1
- version: '3.7'
1
+ version: "3.9"
2
2
 
3
3
  services:
4
4
  proxy:
5
- image: nginx:alpine
6
5
  container_name: proxy
6
+ image: nginx:alpine
7
7
  ports:
8
- - '80:80'
8
+ - "80:80"
9
9
  volumes:
10
10
  - ./nginx.conf:/etc/nginx/nginx.conf
11
- restart: 'unless-stopped'
11
+ restart: "unless-stopped"
12
12
  networks:
13
13
  - backend
14
+
14
15
  server:
16
+ container_name: server
15
17
  build:
16
18
  context: ./
17
- target: development-build-stage
18
- dockerfile: Dockerfile
19
- container_name: server
19
+ dockerfile: Dockerfile.dev
20
20
  ports:
21
- - '3000:3000'
21
+ - "3000:3000"
22
+ environment:
23
+ DB_HOST: localhost
24
+ DB_PORT: 27017
25
+ DB_DATABASE: dev
22
26
  volumes:
23
27
  - ./:/app
24
28
  - /app/node_modules
25
- restart: 'unless-stopped'
29
+ restart: "unless-stopped"
26
30
  networks:
27
31
  - backend
28
32
  links:
29
33
  - mongo
30
34
  depends_on:
31
35
  - mongo
36
+
32
37
  mongo:
33
- image: mvertes/alpine-mongo
34
38
  container_name: mongo
39
+ image: mongo
35
40
  ports:
36
- - '27017:27017'
41
+ - "27017:27017"
42
+ environment:
43
+ DB_HOST: localhost
44
+ DB_PORT: 27017
45
+ DB_DATABASE: dev
37
46
  networks:
38
47
  - backend
39
48
 
@@ -30,8 +30,10 @@
30
30
  "jsonwebtoken": "^8.5.1",
31
31
  "mongoose": "^6.5.0",
32
32
  "morgan": "^1.10.0",
33
+ "reflect-metadata": "^0.1.13",
33
34
  "swagger-jsdoc": "^6.2.1",
34
35
  "swagger-ui-express": "^4.5.0",
36
+ "typedi": "^0.10.0",
35
37
  "winston": "^3.8.1",
36
38
  "winston-daily-rotate-file": "^4.7.1"
37
39
  },
@@ -1,3 +1,4 @@
1
+ import 'reflect-metadata';
1
2
  import compression from 'compression';
2
3
  import cookieParser from 'cookie-parser';
3
4
  import cors from 'cors';
@@ -11,10 +12,10 @@ import swaggerUi from 'swagger-ui-express';
11
12
  import { NODE_ENV, PORT, LOG_FORMAT, ORIGIN, CREDENTIALS } from '@config';
12
13
  import { dbConnection } from '@databases';
13
14
  import { Routes } from '@interfaces/routes.interface';
14
- import errorMiddleware from '@middlewares/error.middleware';
15
+ import { ErrorMiddleware } from '@middlewares/error.middleware';
15
16
  import { logger, stream } from '@utils/logger';
16
17
 
17
- class App {
18
+ export class App {
18
19
  public app: express.Application;
19
20
  public env: string;
20
21
  public port: string | number;
@@ -44,12 +45,12 @@ class App {
44
45
  return this.app;
45
46
  }
46
47
 
47
- private connectToDatabase() {
48
+ private async connectToDatabase() {
48
49
  if (this.env !== 'production') {
49
50
  set('debug', true);
50
51
  }
51
52
 
52
- connect(dbConnection.url, dbConnection.options);
53
+ await connect(dbConnection.url, dbConnection.options);
53
54
  }
54
55
 
55
56
  private initializeMiddlewares() {
@@ -86,8 +87,6 @@ class App {
86
87
  }
87
88
 
88
89
  private initializeErrorHandling() {
89
- this.app.use(errorMiddleware);
90
+ this.app.use(ErrorMiddleware);
90
91
  }
91
92
  }
92
-
93
- export default App;
@@ -2,4 +2,5 @@ import { config } from 'dotenv';
2
2
  config({ path: `.env.${process.env.NODE_ENV || 'development'}.local` });
3
3
 
4
4
  export const CREDENTIALS = process.env.CREDENTIALS === 'true';
5
- export const { NODE_ENV, PORT, DB_HOST, DB_PORT, DB_DATABASE, SECRET_KEY, LOG_FORMAT, LOG_DIR, ORIGIN } = process.env;
5
+ export const { NODE_ENV, PORT, SECRET_KEY, LOG_FORMAT, LOG_DIR, ORIGIN } = process.env;
6
+ export const { DB_HOST, DB_PORT, DB_DATABASE } = process.env;
@@ -1,16 +1,16 @@
1
1
  import { NextFunction, Request, Response } from 'express';
2
- import { CreateUserDto } from '@dtos/users.dto';
2
+ import { Container } from 'typedi';
3
3
  import { RequestWithUser } from '@interfaces/auth.interface';
4
4
  import { User } from '@interfaces/users.interface';
5
- import AuthService from '@services/auth.service';
5
+ import { AuthService } from '@services/auth.service';
6
6
 
7
- class AuthController {
8
- public authService = new AuthService();
7
+ export class AuthController {
8
+ public auth = Container.get(AuthService);
9
9
 
10
10
  public signUp = async (req: Request, res: Response, next: NextFunction) => {
11
11
  try {
12
- const userData: CreateUserDto = req.body;
13
- const signUpUserData: User = await this.authService.signup(userData);
12
+ const userData: User = req.body;
13
+ const signUpUserData: User = await this.auth.signup(userData);
14
14
 
15
15
  res.status(201).json({ data: signUpUserData, message: 'signup' });
16
16
  } catch (error) {
@@ -20,8 +20,8 @@ class AuthController {
20
20
 
21
21
  public logIn = async (req: Request, res: Response, next: NextFunction) => {
22
22
  try {
23
- const userData: CreateUserDto = req.body;
24
- const { cookie, findUser } = await this.authService.login(userData);
23
+ const userData: User = req.body;
24
+ const { cookie, findUser } = await this.auth.login(userData);
25
25
 
26
26
  res.setHeader('Set-Cookie', [cookie]);
27
27
  res.status(200).json({ data: findUser, message: 'login' });
@@ -33,7 +33,7 @@ class AuthController {
33
33
  public logOut = async (req: RequestWithUser, res: Response, next: NextFunction) => {
34
34
  try {
35
35
  const userData: User = req.user;
36
- const logOutUserData: User = await this.authService.logout(userData);
36
+ const logOutUserData: User = await this.auth.logout(userData);
37
37
 
38
38
  res.setHeader('Set-Cookie', ['Authorization=; Max-age=0']);
39
39
  res.status(200).json({ data: logOutUserData, message: 'logout' });
@@ -42,5 +42,3 @@ class AuthController {
42
42
  }
43
43
  };
44
44
  }
45
-
46
- export default AuthController;
@@ -1,14 +1,14 @@
1
1
  import { NextFunction, Request, Response } from 'express';
2
- import { CreateUserDto } from '@dtos/users.dto';
2
+ import { Container } from 'typedi';
3
3
  import { User } from '@interfaces/users.interface';
4
- import userService from '@services/users.service';
4
+ import { UserService } from '@services/users.service';
5
5
 
6
- class UsersController {
7
- public userService = new userService();
6
+ export class UserController {
7
+ public user = Container.get(UserService);
8
8
 
9
9
  public getUsers = async (req: Request, res: Response, next: NextFunction) => {
10
10
  try {
11
- const findAllUsersData: User[] = await this.userService.findAllUser();
11
+ const findAllUsersData: User[] = await this.user.findAllUser();
12
12
 
13
13
  res.status(200).json({ data: findAllUsersData, message: 'findAll' });
14
14
  } catch (error) {
@@ -19,7 +19,7 @@ class UsersController {
19
19
  public getUserById = async (req: Request, res: Response, next: NextFunction) => {
20
20
  try {
21
21
  const userId: string = req.params.id;
22
- const findOneUserData: User = await this.userService.findUserById(userId);
22
+ const findOneUserData: User = await this.user.findUserById(userId);
23
23
 
24
24
  res.status(200).json({ data: findOneUserData, message: 'findOne' });
25
25
  } catch (error) {
@@ -29,8 +29,8 @@ class UsersController {
29
29
 
30
30
  public createUser = async (req: Request, res: Response, next: NextFunction) => {
31
31
  try {
32
- const userData: CreateUserDto = req.body;
33
- const createUserData: User = await this.userService.createUser(userData);
32
+ const userData: User = req.body;
33
+ const createUserData: User = await this.user.createUser(userData);
34
34
 
35
35
  res.status(201).json({ data: createUserData, message: 'created' });
36
36
  } catch (error) {
@@ -41,8 +41,8 @@ class UsersController {
41
41
  public updateUser = async (req: Request, res: Response, next: NextFunction) => {
42
42
  try {
43
43
  const userId: string = req.params.id;
44
- const userData: CreateUserDto = req.body;
45
- const updateUserData: User = await this.userService.updateUser(userId, userData);
44
+ const userData: User = req.body;
45
+ const updateUserData: User = await this.user.updateUser(userId, userData);
46
46
 
47
47
  res.status(200).json({ data: updateUserData, message: 'updated' });
48
48
  } catch (error) {
@@ -53,7 +53,7 @@ class UsersController {
53
53
  public deleteUser = async (req: Request, res: Response, next: NextFunction) => {
54
54
  try {
55
55
  const userId: string = req.params.id;
56
- const deleteUserData: User = await this.userService.deleteUser(userId);
56
+ const deleteUserData: User = await this.user.deleteUser(userId);
57
57
 
58
58
  res.status(200).json({ data: deleteUserData, message: 'deleted' });
59
59
  } catch (error) {
@@ -61,5 +61,3 @@ class UsersController {
61
61
  }
62
62
  };
63
63
  }
64
-
65
- export default UsersController;
@@ -1,9 +1,20 @@
1
- import { IsEmail, IsString } from 'class-validator';
1
+ import { IsEmail, IsString, IsNotEmpty, MinLength, MaxLength } from 'class-validator';
2
2
 
3
3
  export class CreateUserDto {
4
4
  @IsEmail()
5
5
  public email: string;
6
6
 
7
7
  @IsString()
8
+ @IsNotEmpty()
9
+ @MinLength(9)
10
+ @MaxLength(32)
8
11
  public password: string;
9
12
  }
13
+
14
+ export class UpdateUserDto {
15
+ @IsString()
16
+ @IsNotEmpty()
17
+ @MinLength(9)
18
+ @MaxLength(32)
19
+ public password: string;
20
+ }
@@ -1,5 +1,5 @@
1
1
  export interface User {
2
- _id: string;
2
+ _id?: string;
3
3
  email: string;
4
4
  password: string;
5
5
  }
@@ -1,19 +1,27 @@
1
1
  import { NextFunction, Response } from 'express';
2
2
  import { verify } from 'jsonwebtoken';
3
3
  import { SECRET_KEY } from '@config';
4
- import { HttpException } from '@exceptions/HttpException';
4
+ import { HttpException } from '@exceptions/httpException';
5
5
  import { DataStoredInToken, RequestWithUser } from '@interfaces/auth.interface';
6
- import userModel from '@models/users.model';
6
+ import { UserModel } from '@models/users.model';
7
7
 
8
- const authMiddleware = async (req: RequestWithUser, res: Response, next: NextFunction) => {
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) => {
9
19
  try {
10
- const Authorization = req.cookies['Authorization'] || (req.header('Authorization') ? req.header('Authorization').split('Bearer ')[1] : null);
20
+ const Authorization = getAuthorization(req);
11
21
 
12
22
  if (Authorization) {
13
- const secretKey: string = SECRET_KEY;
14
- const verificationResponse = (await verify(Authorization, secretKey)) as DataStoredInToken;
15
- const userId = verificationResponse._id;
16
- const findUser = await userModel.findById(userId);
23
+ const { _id } = (await verify(Authorization, SECRET_KEY)) as DataStoredInToken;
24
+ const findUser = await UserModel.findById(_id);
17
25
 
18
26
  if (findUser) {
19
27
  req.user = findUser;
@@ -29,4 +37,3 @@ const authMiddleware = async (req: RequestWithUser, res: Response, next: NextFun
29
37
  }
30
38
  };
31
39
 
32
- export default authMiddleware;
@@ -1,8 +1,8 @@
1
1
  import { NextFunction, Request, Response } from 'express';
2
- import { HttpException } from '@exceptions/HttpException';
2
+ import { HttpException } from '@exceptions/httpException';
3
3
  import { logger } from '@utils/logger';
4
4
 
5
- const errorMiddleware = (error: HttpException, req: Request, res: Response, next: NextFunction) => {
5
+ export const ErrorMiddleware = (error: HttpException, req: Request, res: Response, next: NextFunction) => {
6
6
  try {
7
7
  const status: number = error.status || 500;
8
8
  const message: string = error.message || 'Something went wrong';
@@ -13,5 +13,3 @@ const errorMiddleware = (error: HttpException, req: Request, res: Response, next
13
13
  next(error);
14
14
  }
15
15
  };
16
-
17
- export default errorMiddleware;
@@ -1,25 +1,27 @@
1
- import { plainToClass } from 'class-transformer';
2
- import { validate, ValidationError } from 'class-validator';
3
- import { RequestHandler } from 'express';
4
- import { HttpException } from '@exceptions/HttpException';
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
5
 
6
- const validationMiddleware = (
7
- type: any,
8
- value: string | 'body' | 'query' | 'params' = 'body',
9
- skipMissingProperties = false,
10
- whitelist = true,
11
- forbidNonWhitelisted = true,
12
- ): RequestHandler => {
13
- return (req, res, next) => {
14
- validate(plainToClass(type, req[value]), { skipMissingProperties, whitelist, forbidNonWhitelisted }).then((errors: ValidationError[]) => {
15
- if (errors.length > 0) {
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[]) => {
16
23
  const message = errors.map((error: ValidationError) => Object.values(error.constraints)).join(', ');
17
24
  next(new HttpException(400, message));
18
- } else {
19
- next();
20
- }
21
- });
25
+ });
22
26
  };
23
27
  };
24
-
25
- export default validationMiddleware;
@@ -1,7 +1,7 @@
1
1
  import { model, Schema, Document } from 'mongoose';
2
2
  import { User } from '@interfaces/users.interface';
3
3
 
4
- const userSchema: Schema = new Schema({
4
+ const UserSchema: Schema = new Schema({
5
5
  email: {
6
6
  type: String,
7
7
  required: true,
@@ -13,6 +13,4 @@ const userSchema: Schema = new Schema({
13
13
  },
14
14
  });
15
15
 
16
- const userModel = model<User & Document>('User', userSchema);
17
-
18
- export default userModel;
16
+ export const UserModel = model<User & Document>('User', UserSchema);
@@ -1,24 +1,22 @@
1
1
  import { Router } from 'express';
2
- import AuthController from '@controllers/auth.controller';
2
+ import { AuthController } from '@controllers/auth.controller';
3
3
  import { CreateUserDto } from '@dtos/users.dto';
4
4
  import { Routes } from '@interfaces/routes.interface';
5
- import authMiddleware from '@middlewares/auth.middleware';
6
- import validationMiddleware from '@middlewares/validation.middleware';
5
+ import { AuthMiddleware } from '@middlewares/auth.middleware';
6
+ import { ValidationMiddleware } from '@middlewares/validation.middleware';
7
7
 
8
- class AuthRoute implements Routes {
8
+ export class AuthRoute implements Routes {
9
9
  public path = '/';
10
10
  public router = Router();
11
- public authController = new AuthController();
11
+ public auth = new AuthController();
12
12
 
13
13
  constructor() {
14
14
  this.initializeRoutes();
15
15
  }
16
16
 
17
17
  private initializeRoutes() {
18
- this.router.post(`${this.path}signup`, validationMiddleware(CreateUserDto, 'body'), this.authController.signUp);
19
- this.router.post(`${this.path}login`, validationMiddleware(CreateUserDto, 'body'), this.authController.logIn);
20
- this.router.post(`${this.path}logout`, authMiddleware, this.authController.logOut);
18
+ this.router.post(`${this.path}signup`, ValidationMiddleware(CreateUserDto, 'body'), this.auth.signUp);
19
+ this.router.post(`${this.path}login`, ValidationMiddleware(CreateUserDto, 'body'), this.auth.logIn);
20
+ this.router.post(`${this.path}logout`, AuthMiddleware, this.auth.logOut);
21
21
  }
22
22
  }
23
-
24
- export default AuthRoute;
@@ -1,25 +1,23 @@
1
1
  import { Router } from 'express';
2
- import UsersController from '@controllers/users.controller';
2
+ import { UserController } from '@controllers/users.controller';
3
3
  import { CreateUserDto } from '@dtos/users.dto';
4
4
  import { Routes } from '@interfaces/routes.interface';
5
- import validationMiddleware from '@middlewares/validation.middleware';
5
+ import { ValidationMiddleware } from '@middlewares/validation.middleware';
6
6
 
7
- class UsersRoute implements Routes {
7
+ export class UserRoute implements Routes {
8
8
  public path = '/users';
9
9
  public router = Router();
10
- public usersController = new UsersController();
10
+ public user = new UserController();
11
11
 
12
12
  constructor() {
13
13
  this.initializeRoutes();
14
14
  }
15
15
 
16
16
  private initializeRoutes() {
17
- this.router.get(`${this.path}`, this.usersController.getUsers);
18
- this.router.get(`${this.path}/:id`, this.usersController.getUserById);
19
- this.router.post(`${this.path}`, validationMiddleware(CreateUserDto, 'body'), this.usersController.createUser);
20
- this.router.put(`${this.path}/:id`, validationMiddleware(CreateUserDto, 'body', true), this.usersController.updateUser);
21
- this.router.delete(`${this.path}/:id`, this.usersController.deleteUser);
17
+ this.router.get(`${this.path}`, this.user.getUsers);
18
+ this.router.get(`${this.path}/:id`, this.user.getUserById);
19
+ this.router.post(`${this.path}`, ValidationMiddleware(CreateUserDto, 'body'), this.user.createUser);
20
+ this.router.put(`${this.path}/:id`, ValidationMiddleware(CreateUserDto, 'body', true), this.user.updateUser);
21
+ this.router.delete(`${this.path}/:id`, this.user.deleteUser);
22
22
  }
23
23
  }
24
-
25
- export default UsersRoute;
@@ -1,11 +1,10 @@
1
- import App from '@/app';
2
- import AuthRoute from '@routes/auth.route';
3
- import IndexRoute from '@routes/index.route';
4
- import UsersRoute from '@routes/users.route';
5
- import validateEnv from '@utils/validateEnv';
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';
6
5
 
7
- validateEnv();
6
+ ValidateEnv();
8
7
 
9
- const app = new App([new IndexRoute(), new UsersRoute(), new AuthRoute()]);
8
+ const app = new App([new UserRoute(), new AuthRoute()]);
10
9
 
11
10
  app.listen();
@@ -1,63 +1,52 @@
1
1
  import { hash, compare } from 'bcrypt';
2
2
  import { sign } from 'jsonwebtoken';
3
+ import { Service } from 'typedi';
3
4
  import { SECRET_KEY } from '@config';
4
- import { CreateUserDto } from '@dtos/users.dto';
5
- import { HttpException } from '@exceptions/HttpException';
5
+ import { HttpException } from '@exceptions/httpException';
6
6
  import { DataStoredInToken, TokenData } from '@interfaces/auth.interface';
7
7
  import { User } from '@interfaces/users.interface';
8
- import userModel from '@models/users.model';
9
- import { isEmpty } from '@utils/util';
8
+ import { UserModel } from '@models/users.model';
10
9
 
11
- class AuthService {
12
- public users = userModel;
10
+ const createToken = (user: User): TokenData => {
11
+ const dataStoredInToken: DataStoredInToken = { _id: user._id };
12
+ const expiresIn: number = 60 * 60;
13
13
 
14
- public async signup(userData: CreateUserDto): Promise<User> {
15
- if (isEmpty(userData)) throw new HttpException(400, "userData is empty");
14
+ return { expiresIn, token: sign(dataStoredInToken, SECRET_KEY, { expiresIn }) };
15
+ }
16
+
17
+ const createCookie = (tokenData: TokenData): string => {
18
+ return `Authorization=${tokenData.token}; HttpOnly; Max-Age=${tokenData.expiresIn};`;
19
+ }
16
20
 
17
- const findUser: User = await this.users.findOne({ email: userData.email });
21
+ @Service()
22
+ export class AuthService {
23
+ public async signup(userData: User): Promise<User> {
24
+ const findUser: User = await UserModel.findOne({ email: userData.email });
18
25
  if (findUser) throw new HttpException(409, `This email ${userData.email} already exists`);
19
26
 
20
27
  const hashedPassword = await hash(userData.password, 10);
21
- const createUserData: User = await this.users.create({ ...userData, password: hashedPassword });
28
+ const createUserData: User = await UserModel.create({ ...userData, password: hashedPassword });
22
29
 
23
30
  return createUserData;
24
31
  }
25
32
 
26
- public async login(userData: CreateUserDto): Promise<{ cookie: string; findUser: User }> {
27
- if (isEmpty(userData)) throw new HttpException(400, "userData is empty");
28
-
29
- const findUser: User = await this.users.findOne({ email: userData.email });
33
+ public async login(userData: User): Promise<{ cookie: string; findUser: User }> {
34
+ const findUser: User = await UserModel.findOne({ email: userData.email });
30
35
  if (!findUser) throw new HttpException(409, `This email ${userData.email} was not found`);
31
36
 
32
37
  const isPasswordMatching: boolean = await compare(userData.password, findUser.password);
33
38
  if (!isPasswordMatching) throw new HttpException(409, "Password is not matching");
34
39
 
35
- const tokenData = this.createToken(findUser);
36
- const cookie = this.createCookie(tokenData);
40
+ const tokenData = createToken(findUser);
41
+ const cookie = createCookie(tokenData);
37
42
 
38
43
  return { cookie, findUser };
39
44
  }
40
45
 
41
46
  public async logout(userData: User): Promise<User> {
42
- if (isEmpty(userData)) throw new HttpException(400, "userData is empty");
43
-
44
- const findUser: User = await this.users.findOne({ email: userData.email, password: userData.password });
47
+ const findUser: User = await UserModel.findOne({ email: userData.email, password: userData.password });
45
48
  if (!findUser) throw new HttpException(409, `This email ${userData.email} was not found`);
46
49
 
47
50
  return findUser;
48
51
  }
49
-
50
- public createToken(user: User): TokenData {
51
- const dataStoredInToken: DataStoredInToken = { _id: user._id };
52
- const secretKey: string = SECRET_KEY;
53
- const expiresIn: number = 60 * 60;
54
-
55
- return { expiresIn, token: sign(dataStoredInToken, secretKey, { expiresIn }) };
56
- }
57
-
58
- public createCookie(tokenData: TokenData): string {
59
- return `Authorization=${tokenData.token}; HttpOnly; Max-Age=${tokenData.expiresIn};`;
60
- }
61
52
  }
62
-
63
- export default AuthService;