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
@@ -1,38 +1,39 @@
1
1
  import { Response } from 'express';
2
2
  import { Controller, Req, Body, Post, UseBefore, HttpCode, Res } from 'routing-controllers';
3
+ import { Container } from 'typedi';
3
4
  import { CreateUserDto } from '@dtos/users.dto';
4
5
  import { RequestWithUser } from '@interfaces/auth.interface';
5
6
  import { User } from '@interfaces/users.interface';
6
- import authMiddleware from '@middlewares/auth.middleware';
7
- import { validationMiddleware } from '@middlewares/validation.middleware';
8
- import AuthService from '@services/auth.service';
7
+ import { AuthMiddleware } from '@middlewares/auth.middleware';
8
+ import { ValidationMiddleware } from '@middlewares/validation.middleware';
9
+ import { AuthService } from '@services/auth.service';
9
10
 
10
11
  @Controller()
11
12
  export class AuthController {
12
- public authService = new AuthService();
13
+ public auth = Container.get(AuthService);
13
14
 
14
15
  @Post('/signup')
15
- @UseBefore(validationMiddleware(CreateUserDto, 'body'))
16
+ @UseBefore(ValidationMiddleware(CreateUserDto, 'body'))
16
17
  @HttpCode(201)
17
- async signUp(@Body() userData: CreateUserDto) {
18
- const signUpUserData: User = await this.authService.signup(userData);
18
+ async signUp(@Body() userData: User) {
19
+ const signUpUserData: User = await this.auth.signup(userData);
19
20
  return { data: signUpUserData, message: 'signup' };
20
21
  }
21
22
 
22
23
  @Post('/login')
23
- @UseBefore(validationMiddleware(CreateUserDto, 'body'))
24
- async logIn(@Res() res: Response, @Body() userData: CreateUserDto) {
25
- const { cookie, findUser } = await this.authService.login(userData);
24
+ @UseBefore(ValidationMiddleware(CreateUserDto, 'body'))
25
+ async logIn(@Res() res: Response, @Body() userData: User) {
26
+ const { cookie, findUser } = await this.auth.login(userData);
26
27
 
27
28
  res.setHeader('Set-Cookie', [cookie]);
28
29
  return { data: findUser, message: 'login' };
29
30
  }
30
31
 
31
32
  @Post('/logout')
32
- @UseBefore(authMiddleware)
33
+ @UseBefore(AuthMiddleware)
33
34
  async logOut(@Req() req: RequestWithUser, @Res() res: Response) {
34
35
  const userData: User = req.user;
35
- const logOutUserData: User = await this.authService.logout(userData);
36
+ const logOutUserData: User = await this.auth.logout(userData);
36
37
 
37
38
  res.setHeader('Set-Cookie', ['Authorization=; Max-age=0']);
38
39
  return { data: logOutUserData, message: 'logout' };
@@ -1,49 +1,51 @@
1
1
  import { Controller, Param, Body, Get, Post, Put, Delete, HttpCode, UseBefore } from 'routing-controllers';
2
2
  import { OpenAPI } from 'routing-controllers-openapi';
3
+ import { Container } from 'typedi';
3
4
  import { CreateUserDto } from '@dtos/users.dto';
4
5
  import { User } from '@interfaces/users.interface';
5
- import userService from '@services/users.service';
6
- import { validationMiddleware } from '@middlewares/validation.middleware';
6
+ import { ValidationMiddleware } from '@middlewares/validation.middleware';
7
+ import { UserService } from '@services/users.service';
7
8
 
8
9
  @Controller()
9
- export class UsersController {
10
- public userService = new userService();
10
+ export class UserController {
11
+ public path = '/users'
12
+ public user = Container.get(UserService);
11
13
 
12
14
  @Get('/users')
13
15
  @OpenAPI({ summary: 'Return a list of users' })
14
16
  async getUsers() {
15
- const findAllUsersData: User[] = await this.userService.findAllUser();
17
+ const findAllUsersData: User[] = await this.user.findAllUser();
16
18
  return { data: findAllUsersData, message: 'findAll' };
17
19
  }
18
20
 
19
21
  @Get('/users/:id')
20
22
  @OpenAPI({ summary: 'Return find a user' })
21
23
  async getUserById(@Param('id') userId: number) {
22
- const findOneUserData: User = await this.userService.findUserById(userId);
24
+ const findOneUserData: User = await this.user.findUserById(userId);
23
25
  return { data: findOneUserData, message: 'findOne' };
24
26
  }
25
27
 
26
28
  @Post('/users')
27
29
  @HttpCode(201)
28
- @UseBefore(validationMiddleware(CreateUserDto, 'body'))
30
+ @UseBefore(ValidationMiddleware(CreateUserDto, 'body'))
29
31
  @OpenAPI({ summary: 'Create a new user' })
30
- async createUser(@Body() userData: CreateUserDto) {
31
- const createUserData: User = await this.userService.createUser(userData);
32
+ async createUser(@Body() userData: User) {
33
+ const createUserData: User = await this.user.createUser(userData);
32
34
  return { data: createUserData, message: 'created' };
33
35
  }
34
36
 
35
37
  @Put('/users/:id')
36
- @UseBefore(validationMiddleware(CreateUserDto, 'body', true))
38
+ @UseBefore(ValidationMiddleware(CreateUserDto, 'body', true))
37
39
  @OpenAPI({ summary: 'Update a user' })
38
- async updateUser(@Param('id') userId: number, @Body() userData: CreateUserDto) {
39
- const updateUserData: User[] = await this.userService.updateUser(userId, userData);
40
+ async updateUser(@Param('id') userId: number, @Body() userData: User) {
41
+ const updateUserData: User[] = await this.user.updateUser(userId, userData);
40
42
  return { data: updateUserData, message: 'updated' };
41
43
  }
42
44
 
43
45
  @Delete('/users/:id')
44
46
  @OpenAPI({ summary: 'Delete a user' })
45
47
  async deleteUser(@Param('id') userId: number) {
46
- const deleteUserData: User[] = await this.userService.deleteUser(userId);
48
+ const deleteUserData: User[] = await this.user.deleteUser(userId);
47
49
  return { data: deleteUserData, message: 'deleted' };
48
50
  }
49
51
  }
@@ -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)
11
+ public password: string;
12
+ }
13
+
14
+ export class UpdateUserDto {
15
+ @IsString()
16
+ @IsNotEmpty()
17
+ @MinLength(9)
18
+ @MaxLength(32)
8
19
  public password: string;
9
20
  }
@@ -1,5 +1,5 @@
1
1
  export interface User {
2
- id: number;
2
+ id?: number;
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 = userModel.find(user => user.id === userId);
23
+ const { id } = (await verify(Authorization, SECRET_KEY)) as DataStoredInToken;
24
+ const findUser = UserModel.find(user => user.id === id);
17
25
 
18
26
  if (findUser) {
19
27
  req.user = findUser;
@@ -28,5 +36,3 @@ const authMiddleware = async (req: RequestWithUser, res: Response, next: NextFun
28
36
  next(new HttpException(401, 'Wrong authentication token'));
29
37
  }
30
38
  };
31
-
32
- export default authMiddleware;
@@ -1,18 +1,15 @@
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';
9
9
 
10
- console.error(`[${req.method}] ${req.path} >> StatusCode:: ${status}, Message:: ${message}`);
11
10
  logger.error(`[${req.method}] ${req.path} >> StatusCode:: ${status}, Message:: ${message}`);
12
11
  res.status(status).json({ message });
13
12
  } catch (error) {
14
13
  next(error);
15
14
  }
16
15
  };
17
-
18
- export default errorMiddleware;
@@ -1,31 +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 getAllNestedErrors = (error: ValidationError) => {
7
- if(error.constraints){
8
- return Object.values(error.constraints)
9
- }
10
- return error.children.map(getAllNestedErrors).join(',')
11
- }
12
-
13
- export const validationMiddleware = (
14
- type: any,
15
- value: string | 'body' | 'query' | 'params' = 'body',
16
- skipMissingProperties = false,
17
- whitelist = true,
18
- forbidNonWhitelisted = true,
19
- ): RequestHandler => {
20
- return (req, res, next) => {
21
- const obj = plainToClass(type, req[value]);
22
- validate(obj, { skipMissingProperties, whitelist, forbidNonWhitelisted }).then((errors: ValidationError[]) => {
23
- if (errors.length > 0) {
24
- const message = errors.map(getAllNestedErrors).join(', ');
25
- next(new HttpException(400, message));
26
- } else {
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;
27
20
  next();
28
- }
29
- });
21
+ })
22
+ .catch((errors: ValidationError[]) => {
23
+ const message = errors.map((error: ValidationError) => Object.values(error.constraints)).join(', ');
24
+ next(new HttpException(400, message));
25
+ });
30
26
  };
31
27
  };
@@ -1,11 +1,9 @@
1
1
  import { User } from '@interfaces/users.interface';
2
2
 
3
3
  // password: password
4
- const userModel: User[] = [
4
+ export const UserModel: User[] = [
5
5
  { id: 1, email: 'example1@email.com', password: '$2b$10$TBEfaCe1oo.2jfkBDWcj/usBj4oECsW2wOoDXpCa2IH9xqCpEK/hC' },
6
6
  { id: 2, email: 'example2@email.com', password: '$2b$10$TBEfaCe1oo.2jfkBDWcj/usBj4oECsW2wOoDXpCa2IH9xqCpEK/hC' },
7
7
  { id: 3, email: 'example3@email.com', password: '$2b$10$TBEfaCe1oo.2jfkBDWcj/usBj4oECsW2wOoDXpCa2IH9xqCpEK/hC' },
8
8
  { id: 4, email: 'example4@email.com', password: '$2b$10$TBEfaCe1oo.2jfkBDWcj/usBj4oECsW2wOoDXpCa2IH9xqCpEK/hC' },
9
9
  ];
10
-
11
- export default userModel;
@@ -1,10 +1,9 @@
1
- import App from '@/app';
1
+ import { App } from '@/app';
2
2
  import { AuthController } from '@controllers/auth.controller';
3
- import { IndexController } from '@controllers/index.controller';
4
- import { UsersController } from '@controllers/users.controller';
5
- import validateEnv from '@utils/validateEnv';
3
+ import { UserController } from '@controllers/users.controller';
4
+ import { ValidateEnv } from '@utils/validateEnv';
6
5
 
7
- validateEnv();
6
+ ValidateEnv();
8
7
 
9
- const app = new App([AuthController, IndexController, UsersController]);
8
+ const app = new App([AuthController, UserController]);
10
9
  app.listen();
@@ -1,63 +1,53 @@
1
1
  import { compare, hash } from 'bcrypt';
2
2
  import { sign } from 'jsonwebtoken';
3
+ import { Service } from 'typedi';
3
4
  import { SECRET_KEY } from '@config';
4
5
  import { CreateUserDto } from '@dtos/users.dto';
5
- import { HttpException } from '@exceptions/HttpException';
6
+ import { HttpException } from '@exceptions/httpException';
6
7
  import { DataStoredInToken, TokenData } from '@interfaces/auth.interface';
7
8
  import { User } from '@interfaces/users.interface';
8
- import userModel from '@models/users.model';
9
- import { isEmpty } from '@utils/util';
9
+ import { UserModel } from '@models/users.model';
10
10
 
11
- class AuthService {
12
- public users = userModel;
11
+ const createToken = (user: User): TokenData => {
12
+ const dataStoredInToken: DataStoredInToken = { id: user.id };
13
+ const expiresIn: number = 60 * 60;
13
14
 
14
- public async signup(userData: CreateUserDto): Promise<User> {
15
- if (isEmpty(userData)) throw new HttpException(400, "userData is empty");
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
+ }
16
21
 
17
- const findUser: User = this.users.find(user => user.email === userData.email);
22
+ @Service()
23
+ export class AuthService {
24
+ public async signup(userData: CreateUserDto): Promise<User> {
25
+ const findUser: User = UserModel.find(user => user.email === userData.email);
18
26
  if (findUser) throw new HttpException(409, `This email ${userData.email} already exists`);
19
27
 
20
28
  const hashedPassword = await hash(userData.password, 10);
21
- const createUserData: User = { id: this.users.length + 1, ...userData, password: hashedPassword };
29
+ const createUserData: User = { id: UserModel.length + 1, ...userData, password: hashedPassword };
22
30
 
23
31
  return createUserData;
24
32
  }
25
33
 
26
34
  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 = this.users.find(user => user.email === userData.email);
35
+ const findUser: User = UserModel.find(user => user.email === userData.email);
30
36
  if (!findUser) throw new HttpException(409, `This email ${userData.email} was not found`);
31
37
 
32
38
  const isPasswordMatching: boolean = await compare(userData.password, findUser.password);
33
39
  if (!isPasswordMatching) throw new HttpException(409, "Password is not matching");
34
40
 
35
- const tokenData = this.createToken(findUser);
36
- const cookie = this.createCookie(tokenData);
41
+ const tokenData = createToken(findUser);
42
+ const cookie = createCookie(tokenData);
37
43
 
38
44
  return { cookie, findUser };
39
45
  }
40
46
 
41
47
  public async logout(userData: User): Promise<User> {
42
- if (isEmpty(userData)) throw new HttpException(400, "userData is empty");
43
-
44
- const findUser: User = this.users.find(user => user.email === userData.email && user.password === userData.password);
48
+ const findUser: User = UserModel.find(user => user.email === userData.email && user.password === userData.password);
45
49
  if (!findUser) throw new HttpException(409, "User doesn't exist");
46
50
 
47
51
  return findUser;
48
52
  }
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
53
  }
62
-
63
- export default AuthService;
@@ -1,46 +1,40 @@
1
1
  import { hash } from 'bcrypt';
2
+ import { Service } from 'typedi';
2
3
  import { CreateUserDto } from '@dtos/users.dto';
3
- import { HttpException } from '@exceptions/HttpException';
4
+ import { HttpException } from '@exceptions/httpException';
4
5
  import { User } from '@interfaces/users.interface';
5
- import userModel from '@models/users.model';
6
- import { isEmpty } from '@utils/util';
7
-
8
- class UserService {
9
- public users = userModel;
6
+ import { UserModel } from '@models/users.model';
10
7
 
8
+ @Service()
9
+ export class UserService {
11
10
  public async findAllUser(): Promise<User[]> {
12
- const users: User[] = this.users;
11
+ const users: User[] = UserModel;
13
12
  return users;
14
13
  }
15
14
 
16
15
  public async findUserById(userId: number): Promise<User> {
17
- const findUser: User = this.users.find(user => user.id === userId);
16
+ const findUser: User = UserModel.find(user => user.id === userId);
18
17
  if (!findUser) throw new HttpException(409, "User doesn't exist");
19
18
 
20
19
  return findUser;
21
20
  }
22
21
 
23
22
  public async createUser(userData: CreateUserDto): Promise<User> {
24
- if (isEmpty(userData)) throw new HttpException(400, "userData is empty");
25
-
26
- const findUser: User = this.users.find(user => user.email === userData.email);
23
+ const findUser: User = UserModel.find(user => user.email === userData.email);
27
24
  if (findUser) throw new HttpException(409, `This email ${userData.email} already exists`);
28
25
 
29
26
  const hashedPassword = await hash(userData.password, 10);
30
- const createUserData: User = { id: this.users.length + 1, ...userData, password: hashedPassword };
31
- this.users = [...this.users, createUserData];
27
+ const createUserData: User = { id: UserModel.length + 1, ...userData, password: hashedPassword };
32
28
 
33
29
  return createUserData;
34
30
  }
35
31
 
36
32
  public async updateUser(userId: number, userData: CreateUserDto): Promise<User[]> {
37
- if (isEmpty(userData)) throw new HttpException(400, "userData is empty");
38
-
39
- const findUser: User = this.users.find(user => user.id === userId);
33
+ const findUser: User = UserModel.find(user => user.id === userId);
40
34
  if (!findUser) throw new HttpException(409, "User doesn't exist");
41
35
 
42
36
  const hashedPassword = await hash(userData.password, 10);
43
- const updateUserData: User[] = this.users.map((user: User) => {
37
+ const updateUserData: User[] = UserModel.map((user: User) => {
44
38
  if (user.id === findUser.id) user = { id: userId, ...userData, password: hashedPassword };
45
39
  return user;
46
40
  });
@@ -49,12 +43,10 @@ class UserService {
49
43
  }
50
44
 
51
45
  public async deleteUser(userId: number): Promise<User[]> {
52
- const findUser: User = this.users.find(user => user.id === userId);
46
+ const findUser: User = UserModel.find(user => user.id === userId);
53
47
  if (!findUser) throw new HttpException(409, "User doesn't exist");
54
48
 
55
- const deleteUserData: User[] = this.users.filter(user => user.id !== findUser.id);
49
+ const deleteUserData: User[] = UserModel.filter(user => user.id !== findUser.id);
56
50
  return deleteUserData;
57
51
  }
58
52
  }
59
-
60
- export default UserService;
@@ -1,5 +1,5 @@
1
1
  import request from 'supertest';
2
- import App from '@/app';
2
+ import { App } from '@/app';
3
3
  import { AuthController } from '@controllers/auth.controller';
4
4
  import { CreateUserDto } from '@dtos/users.dto';
5
5
 
@@ -1,9 +1,9 @@
1
1
  import request from 'supertest';
2
- import App from '@/app';
3
- import { UsersController } from '@controllers/users.controller';
2
+ import { App } from '@/app';
3
+ import { UserController } from '@controllers/users.controller';
4
4
  import { CreateUserDto } from '@dtos/users.dto';
5
5
  import { User } from '@interfaces/users.interface';
6
- import userModel from '@models/users.model';
6
+ import { UserModel } from '@models/users.model';
7
7
 
8
8
  afterAll(async () => {
9
9
  await new Promise<void>(resolve => setTimeout(() => resolve(), 500));
@@ -12,9 +12,9 @@ afterAll(async () => {
12
12
  describe('Testing Users', () => {
13
13
  describe('[GET] /users', () => {
14
14
  it('response statusCode 200 / findAll', () => {
15
- const findUser: User[] = userModel;
15
+ const findUser: User[] = UserModel;
16
16
 
17
- const app = new App([UsersController]);
17
+ const app = new App([UserController]);
18
18
  return request(app.getServer()).get('/users').expect(200, { data: findUser, message: 'findAll' });
19
19
  });
20
20
  });
@@ -22,9 +22,9 @@ describe('Testing Users', () => {
22
22
  describe('[GET] /users/:id', () => {
23
23
  it('response statusCode 200 / findOne', () => {
24
24
  const userId = 1;
25
- const findUser: User = userModel.find(user => user.id === userId);
25
+ const findUser: User = UserModel.find(user => user.id === userId);
26
26
 
27
- const app = new App([UsersController]);
27
+ const app = new App([UserController]);
28
28
  return request(app.getServer()).get(`/users/${userId}`).expect(200, { data: findUser, message: 'findOne' });
29
29
  });
30
30
  });
@@ -36,7 +36,7 @@ describe('Testing Users', () => {
36
36
  password: 'q1w2e3r4',
37
37
  };
38
38
 
39
- const app = new App([UsersController]);
39
+ const app = new App([UserController]);
40
40
  return request(app.getServer()).post('/users').send(userData).expect(201);
41
41
  });
42
42
  });
@@ -49,7 +49,7 @@ describe('Testing Users', () => {
49
49
  password: 'q1w2e3r4',
50
50
  };
51
51
 
52
- const app = new App([UsersController]);
52
+ const app = new App([UserController]);
53
53
  return request(app.getServer()).put(`/users/${userId}`).send(userData).expect(200);
54
54
  });
55
55
  });
@@ -58,7 +58,7 @@ describe('Testing Users', () => {
58
58
  it('response statusCode 200 / deleted', () => {
59
59
  const userId = 1;
60
60
 
61
- const app = new App([UsersController]);
61
+ const app = new App([UserController]);
62
62
  return request(app.getServer()).delete(`/users/${userId}`).expect(200);
63
63
  });
64
64
  });
@@ -1,10 +1,8 @@
1
1
  import { cleanEnv, port, str } from 'envalid';
2
2
 
3
- const validateEnv = () => {
3
+ export const ValidateEnv = () => {
4
4
  cleanEnv(process.env, {
5
5
  NODE_ENV: str(),
6
6
  PORT: port(),
7
7
  });
8
8
  };
9
-
10
- export default validateEnv;
@@ -34,5 +34,5 @@
34
34
  }
35
35
  },
36
36
  "include": ["src/**/*.ts", "src/**/*.json", ".env"],
37
- "exclude": ["node_modules", "src/http", "src/logs", "src/tests"]
37
+ "exclude": ["node_modules", "src/http", "src/logs"]
38
38
  }
@@ -2,10 +2,10 @@
2
2
  PORT = 3000
3
3
 
4
4
  # DATABASE
5
- DB_HOST = localhost
6
- DB_PORT = 3306
7
5
  DB_USER = root
8
6
  DB_PASSWORD = password
7
+ DB_HOST = localhost
8
+ DB_PORT = 3306
9
9
  DB_DATABASE = dev
10
10
 
11
11
  # TOKEN
@@ -2,11 +2,11 @@
2
2
  PORT = 3000
3
3
 
4
4
  # DATABASE
5
- DB_HOST = localhost
6
- DB_PORT = 3306
7
5
  DB_USER = root
8
6
  DB_PASSWORD = password
9
- DB_DATABASE = prod
7
+ DB_HOST = localhost
8
+ DB_PORT = 3306
9
+ DB_DATABASE = dev
10
10
 
11
11
  # TOKEN
12
12
  SECRET_KEY = secretKey
@@ -2,11 +2,11 @@
2
2
  PORT = 3000
3
3
 
4
4
  # DATABASE
5
- DB_HOST = localhost
6
- DB_PORT = 3306
7
5
  DB_USER = root
8
6
  DB_PASSWORD = password
9
- DB_DATABASE = test
7
+ DB_HOST = localhost
8
+ DB_PORT = 3306
9
+ DB_DATABASE = dev
10
10
 
11
11
  # TOKEN
12
12
  SECRET_KEY = secretKey
@@ -23,7 +23,7 @@
23
23
  "@/*": ["*"],
24
24
  "@config": ["config"],
25
25
  "@controllers/*": ["controllers/*"],
26
- "@databases": ["databases"],
26
+ "@database": ["database"],
27
27
  "@dtos/*": ["dtos/*"],
28
28
  "@exceptions/*": ["exceptions/*"],
29
29
  "@interfaces/*": ["interfaces/*"],
@@ -0,0 +1,23 @@
1
+ # NodeJS Version 16
2
+ FROM node:16.18-buster-slim
3
+
4
+ # Copy Dir
5
+ COPY . ./app
6
+
7
+ # Work to Dir
8
+ WORKDIR /app
9
+
10
+ # Install Node Package
11
+ RUN npm install --legacy-peer-deps
12
+
13
+ RUN chmod +x /app/docker-entrypoint.sh
14
+
15
+ ENTRYPOINT [ "docker-entrypoint.sh" ]
16
+
17
+ # Set Env
18
+ ENV NODE_ENV development
19
+
20
+ EXPOSE 3000
21
+
22
+ # Cmd script
23
+ CMD ["npm", "run", "dev"]