typescript-express-starter 9.1.2 → 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 (401) 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 -161
  7. package/README.md +118 -157
  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/jest.config.js +1 -1
  15. package/lib/default/package.json +42 -40
  16. package/lib/default/src/app.ts +4 -5
  17. package/lib/default/src/controllers/auth.controller.ts +9 -11
  18. package/lib/default/src/controllers/users.controller.ts +11 -13
  19. package/lib/default/src/dtos/users.dto.ts +12 -1
  20. package/lib/default/src/interfaces/users.interface.ts +2 -2
  21. package/lib/default/src/middlewares/auth.middleware.ts +16 -10
  22. package/lib/default/src/middlewares/error.middleware.ts +2 -4
  23. package/lib/default/src/middlewares/validation.middleware.ts +22 -20
  24. package/lib/default/src/models/users.model.ts +6 -8
  25. package/lib/default/src/routes/auth.route.ts +8 -11
  26. package/lib/default/src/routes/users.route.ts +10 -12
  27. package/lib/default/src/server.ts +6 -7
  28. package/lib/default/src/services/auth.service.ts +25 -36
  29. package/lib/default/src/services/users.service.ts +20 -29
  30. package/lib/{graphql/src/tests → default/src/test}/auth.test.ts +21 -21
  31. package/lib/default/src/test/users.test.ts +62 -0
  32. package/lib/default/src/utils/validateEnv.ts +1 -3
  33. package/lib/default/tsconfig.json +1 -1
  34. package/lib/graphql/.env.development.local +6 -6
  35. package/lib/graphql/.env.production.local +6 -6
  36. package/lib/graphql/.env.test.local +6 -6
  37. package/lib/graphql/.swcrc +1 -1
  38. package/lib/graphql/Dockerfile.dev +19 -0
  39. package/lib/graphql/Dockerfile.prod +19 -0
  40. package/lib/graphql/Makefile +32 -15
  41. package/lib/graphql/docker-compose.yml +23 -15
  42. package/lib/graphql/jest.config.js +1 -1
  43. package/lib/graphql/package.json +42 -41
  44. package/lib/graphql/src/app.ts +14 -13
  45. package/lib/graphql/src/config/index.ts +2 -2
  46. package/lib/{typeorm/src/databases → graphql/src/database}/index.ts +6 -6
  47. package/lib/graphql/src/dtos/users.dto.ts +14 -1
  48. package/lib/graphql/src/interfaces/users.interface.ts +2 -2
  49. package/lib/graphql/src/middlewares/auth.middleware.ts +16 -6
  50. package/lib/graphql/src/middlewares/error.middleware.ts +2 -4
  51. package/lib/graphql/src/repositories/auth.repository.ts +19 -27
  52. package/lib/graphql/src/repositories/users.repository.ts +9 -18
  53. package/lib/graphql/src/resolvers/auth.resolver.ts +2 -2
  54. package/lib/graphql/src/resolvers/users.resolver.ts +4 -4
  55. package/lib/graphql/src/server.ts +6 -7
  56. package/lib/graphql/src/test/auth.test.ts +10 -0
  57. package/lib/graphql/src/test/users.test.ts +11 -0
  58. package/lib/graphql/src/typedefs/users.type.ts +2 -2
  59. package/lib/graphql/src/utils/logger.ts +2 -0
  60. package/lib/graphql/src/utils/validateEnv.ts +1 -3
  61. package/lib/graphql/tsconfig.json +2 -2
  62. package/lib/knex/.env.development.local +2 -2
  63. package/lib/knex/.env.production.local +3 -3
  64. package/lib/knex/.env.test.local +3 -3
  65. package/lib/knex/.swcrc +1 -1
  66. package/lib/knex/Dockerfile.dev +19 -0
  67. package/lib/knex/Dockerfile.prod +19 -0
  68. package/lib/knex/Makefile +32 -15
  69. package/lib/knex/docker-compose.yml +19 -14
  70. package/lib/knex/jest.config.js +1 -1
  71. package/lib/knex/knexfile.ts +8 -8
  72. package/lib/knex/package.json +44 -42
  73. package/lib/knex/src/app.ts +6 -7
  74. package/lib/knex/src/config/index.ts +2 -1
  75. package/lib/knex/src/controllers/auth.controller.ts +9 -11
  76. package/lib/knex/src/controllers/users.controller.ts +10 -12
  77. package/lib/knex/src/{databases → database}/index.ts +4 -4
  78. package/lib/knex/src/database/migrations/20210713110926_initial.ts +17 -0
  79. package/lib/knex/src/dtos/users.dto.ts +12 -1
  80. package/lib/knex/src/interfaces/users.interface.ts +2 -2
  81. package/lib/knex/src/middlewares/auth.middleware.ts +17 -10
  82. package/lib/knex/src/middlewares/error.middleware.ts +2 -4
  83. package/lib/knex/src/middlewares/validation.middleware.ts +22 -20
  84. package/lib/knex/src/models/users.model.ts +2 -2
  85. package/lib/knex/src/routes/auth.route.ts +8 -10
  86. package/lib/knex/src/routes/users.route.ts +10 -12
  87. package/lib/knex/src/server.ts +6 -7
  88. package/lib/knex/src/services/auth.service.ts +27 -36
  89. package/lib/knex/src/services/users.service.ts +18 -23
  90. package/lib/knex/src/{tests → test}/auth.test.ts +2 -2
  91. package/lib/knex/src/{tests → test}/users.test.ts +2 -2
  92. package/lib/knex/src/utils/validateEnv.ts +1 -3
  93. package/lib/knex/tsconfig.json +2 -2
  94. package/lib/mikro-orm/.env.production.local +1 -1
  95. package/lib/mikro-orm/.env.test.local +1 -1
  96. package/lib/mikro-orm/.swcrc +1 -1
  97. package/lib/mikro-orm/Dockerfile.dev +19 -0
  98. package/lib/mikro-orm/Dockerfile.prod +19 -0
  99. package/lib/mikro-orm/Makefile +32 -15
  100. package/lib/mikro-orm/docker-compose.yml +20 -11
  101. package/lib/mikro-orm/package.json +42 -40
  102. package/lib/mikro-orm/src/app.ts +10 -12
  103. package/lib/mikro-orm/src/config/index.ts +2 -1
  104. package/lib/mikro-orm/src/controllers/auth.controller.ts +9 -11
  105. package/lib/mikro-orm/src/controllers/users.controller.ts +11 -13
  106. package/lib/mikro-orm/src/dtos/users.dto.ts +12 -1
  107. package/lib/mikro-orm/src/interfaces/users.interface.ts +1 -1
  108. package/lib/mikro-orm/src/middlewares/auth.middleware.ts +17 -10
  109. package/lib/mikro-orm/src/middlewares/error.middleware.ts +2 -4
  110. package/lib/mikro-orm/src/middlewares/validation.middleware.ts +22 -20
  111. package/lib/mikro-orm/src/routes/auth.route.ts +8 -10
  112. package/lib/mikro-orm/src/routes/users.route.ts +9 -11
  113. package/lib/mikro-orm/src/server.ts +6 -7
  114. package/lib/mikro-orm/src/services/auth.service.ts +23 -33
  115. package/lib/mikro-orm/src/services/users.service.ts +13 -21
  116. package/lib/mikro-orm/src/{tests → test}/auth.test.ts +3 -4
  117. package/lib/mikro-orm/src/{tests → test}/users.test.ts +4 -5
  118. package/lib/mikro-orm/src/utils/validateEnv.ts +1 -3
  119. package/lib/mikro-orm/tsconfig.json +2 -2
  120. package/lib/mongoose/.env.production.local +1 -1
  121. package/lib/mongoose/.env.test.local +1 -1
  122. package/lib/mongoose/.swcrc +1 -1
  123. package/lib/mongoose/Dockerfile.dev +19 -0
  124. package/lib/mongoose/Dockerfile.prod +19 -0
  125. package/lib/mongoose/Makefile +32 -15
  126. package/lib/mongoose/docker-compose.yml +20 -11
  127. package/lib/mongoose/jest.config.js +1 -1
  128. package/lib/mongoose/package.json +43 -41
  129. package/lib/mongoose/src/app.ts +6 -7
  130. package/lib/mongoose/src/config/index.ts +2 -1
  131. package/lib/mongoose/src/controllers/auth.controller.ts +9 -11
  132. package/lib/mongoose/src/controllers/users.controller.ts +11 -13
  133. package/lib/mongoose/src/{databases → database}/index.ts +1 -2
  134. package/lib/mongoose/src/dtos/users.dto.ts +12 -1
  135. package/lib/mongoose/src/interfaces/users.interface.ts +1 -1
  136. package/lib/mongoose/src/middlewares/auth.middleware.ts +16 -9
  137. package/lib/mongoose/src/middlewares/error.middleware.ts +2 -4
  138. package/lib/mongoose/src/middlewares/validation.middleware.ts +22 -20
  139. package/lib/mongoose/src/models/users.model.ts +2 -4
  140. package/lib/mongoose/src/routes/auth.route.ts +8 -10
  141. package/lib/mongoose/src/routes/users.route.ts +9 -11
  142. package/lib/mongoose/src/server.ts +6 -7
  143. package/lib/mongoose/src/services/auth.service.ts +26 -37
  144. package/lib/mongoose/src/services/users.service.ts +19 -29
  145. package/lib/{typegoose/src/tests → mongoose/src/test}/users.test.ts +7 -7
  146. package/lib/mongoose/src/utils/validateEnv.ts +1 -3
  147. package/lib/mongoose/tsconfig.json +2 -2
  148. package/lib/node-postgres/.dockerignore +18 -0
  149. package/lib/node-postgres/.editorconfig +9 -0
  150. package/lib/node-postgres/.env.development.local +13 -0
  151. package/lib/node-postgres/.env.production.local +13 -0
  152. package/lib/node-postgres/.env.test.local +13 -0
  153. package/lib/node-postgres/.eslintignore +1 -0
  154. package/lib/node-postgres/.eslintrc +18 -0
  155. package/lib/node-postgres/.huskyrc +5 -0
  156. package/lib/node-postgres/.lintstagedrc.json +5 -0
  157. package/lib/node-postgres/.prettierrc +8 -0
  158. package/lib/node-postgres/.swcrc +39 -0
  159. package/lib/node-postgres/.vscode/launch.json +35 -0
  160. package/lib/node-postgres/.vscode/settings.json +6 -0
  161. package/lib/node-postgres/Dockerfile.dev +17 -0
  162. package/lib/node-postgres/Dockerfile.prod +17 -0
  163. package/lib/node-postgres/Makefile +46 -0
  164. package/lib/node-postgres/docker-compose.yml +61 -0
  165. package/lib/node-postgres/ecosystem.config.js +57 -0
  166. package/lib/node-postgres/jest.config.js +12 -0
  167. package/lib/node-postgres/nginx.conf +40 -0
  168. package/lib/node-postgres/nodemon.json +12 -0
  169. package/lib/node-postgres/package.json +78 -0
  170. package/lib/node-postgres/src/app.ts +87 -0
  171. package/lib/node-postgres/src/config/index.ts +6 -0
  172. package/lib/node-postgres/src/controllers/auth.controller.ts +44 -0
  173. package/lib/node-postgres/src/controllers/users.controller.ts +63 -0
  174. package/lib/node-postgres/src/database/index.ts +6 -0
  175. package/lib/node-postgres/src/database/init.sql +110 -0
  176. package/lib/node-postgres/src/dtos/users.dto.ts +20 -0
  177. package/lib/node-postgres/src/http/auth.http +27 -0
  178. package/lib/node-postgres/src/http/users.http +34 -0
  179. package/lib/node-postgres/src/interfaces/auth.interface.ts +15 -0
  180. package/lib/node-postgres/src/interfaces/routes.interface.ts +6 -0
  181. package/lib/node-postgres/src/interfaces/users.interface.ts +5 -0
  182. package/lib/node-postgres/src/middlewares/auth.middleware.ts +38 -0
  183. package/lib/node-postgres/src/middlewares/error.middleware.ts +15 -0
  184. package/lib/node-postgres/src/middlewares/validation.middleware.ts +27 -0
  185. package/lib/node-postgres/src/models/users.model.ts +9 -0
  186. package/lib/node-postgres/src/routes/auth.route.ts +21 -0
  187. package/lib/node-postgres/src/routes/users.route.ts +23 -0
  188. package/lib/node-postgres/src/server.ts +10 -0
  189. package/lib/node-postgres/src/services/auth.service.ts +52 -0
  190. package/lib/node-postgres/src/services/users.service.ts +51 -0
  191. package/lib/{default/src/tests → node-postgres/src/test}/auth.test.ts +2 -2
  192. package/lib/{default/src/tests → node-postgres/src/test}/users.test.ts +5 -5
  193. package/lib/node-postgres/src/utils/logger.ts +65 -0
  194. package/lib/node-postgres/src/utils/validateEnv.ts +8 -0
  195. package/lib/node-postgres/swagger.yaml +123 -0
  196. package/lib/node-postgres/tsconfig.json +40 -0
  197. package/lib/prisma/.env.production.local +1 -1
  198. package/lib/prisma/.env.test.local +1 -1
  199. package/lib/prisma/Dockerfile.dev +19 -0
  200. package/lib/prisma/Dockerfile.prod +19 -0
  201. package/lib/prisma/Makefile +32 -15
  202. package/lib/prisma/docker-compose.yml +15 -14
  203. package/lib/prisma/jest.config.js +1 -1
  204. package/lib/prisma/package.json +43 -41
  205. package/lib/prisma/src/app.ts +4 -5
  206. package/lib/prisma/src/controllers/auth.controller.ts +10 -12
  207. package/lib/prisma/src/controllers/users.controller.ts +12 -14
  208. package/lib/prisma/src/dtos/users.dto.ts +12 -1
  209. package/lib/prisma/src/interfaces/auth.interface.ts +1 -1
  210. package/lib/prisma/src/interfaces/users.interface.ts +5 -0
  211. package/lib/prisma/src/middlewares/auth.middleware.ts +16 -11
  212. package/lib/prisma/src/middlewares/error.middleware.ts +2 -4
  213. package/lib/prisma/src/middlewares/validation.middleware.ts +22 -20
  214. package/lib/prisma/src/routes/auth.route.ts +8 -10
  215. package/lib/prisma/src/routes/users.route.ts +9 -11
  216. package/lib/prisma/src/server.ts +6 -7
  217. package/lib/prisma/src/services/auth.service.ts +10 -16
  218. package/lib/prisma/src/services/users.service.ts +19 -27
  219. package/lib/prisma/src/utils/validateEnv.ts +1 -3
  220. package/lib/prisma/tsconfig.json +1 -1
  221. package/lib/routing-controllers/Dockerfile.dev +19 -0
  222. package/lib/routing-controllers/Dockerfile.prod +19 -0
  223. package/lib/routing-controllers/Makefile +29 -16
  224. package/lib/routing-controllers/docker-compose.yml +9 -9
  225. package/lib/routing-controllers/jest.config.js +1 -1
  226. package/lib/routing-controllers/package.json +41 -40
  227. package/lib/routing-controllers/src/app.ts +4 -6
  228. package/lib/routing-controllers/src/controllers/auth.controller.ts +13 -12
  229. package/lib/routing-controllers/src/controllers/users.controller.ts +15 -13
  230. package/lib/routing-controllers/src/dtos/users.dto.ts +12 -1
  231. package/lib/routing-controllers/src/interfaces/users.interface.ts +1 -1
  232. package/lib/routing-controllers/src/middlewares/auth.middleware.ts +16 -10
  233. package/lib/routing-controllers/src/middlewares/error.middleware.ts +2 -5
  234. package/lib/routing-controllers/src/middlewares/validation.middleware.ts +23 -27
  235. package/lib/routing-controllers/src/models/users.model.ts +1 -3
  236. package/lib/routing-controllers/src/server.ts +5 -6
  237. package/lib/routing-controllers/src/services/auth.service.ts +25 -35
  238. package/lib/routing-controllers/src/services/users.service.ts +17 -25
  239. package/lib/routing-controllers/src/{tests → test}/auth.test.ts +1 -1
  240. package/lib/routing-controllers/src/{tests → test}/users.test.ts +10 -10
  241. package/lib/routing-controllers/src/utils/validateEnv.ts +1 -3
  242. package/lib/routing-controllers/tsconfig.json +1 -1
  243. package/lib/sequelize/.env.development.local +2 -2
  244. package/lib/sequelize/.env.production.local +3 -3
  245. package/lib/sequelize/.env.test.local +3 -3
  246. package/lib/sequelize/.swcrc +1 -1
  247. package/lib/sequelize/Dockerfile.dev +23 -0
  248. package/lib/sequelize/Dockerfile.prod +23 -0
  249. package/lib/sequelize/Makefile +32 -15
  250. package/lib/sequelize/docker-compose.yml +19 -14
  251. package/lib/sequelize/jest.config.js +1 -1
  252. package/lib/sequelize/package.json +45 -43
  253. package/lib/sequelize/src/app.ts +5 -6
  254. package/lib/sequelize/src/config/index.ts +2 -1
  255. package/lib/sequelize/src/controllers/auth.controller.ts +7 -8
  256. package/lib/sequelize/src/controllers/users.controller.ts +9 -10
  257. package/lib/sequelize/src/{databases → database}/index.ts +1 -3
  258. package/lib/sequelize/src/dtos/users.dto.ts +12 -1
  259. package/lib/sequelize/src/interfaces/users.interface.ts +1 -1
  260. package/lib/sequelize/src/middlewares/auth.middleware.ts +16 -10
  261. package/lib/sequelize/src/middlewares/error.middleware.ts +2 -4
  262. package/lib/sequelize/src/middlewares/validation.middleware.ts +22 -20
  263. package/lib/sequelize/src/routes/auth.route.ts +8 -11
  264. package/lib/sequelize/src/routes/users.route.ts +9 -11
  265. package/lib/sequelize/src/server.ts +6 -7
  266. package/lib/sequelize/src/services/auth.service.ts +24 -35
  267. package/lib/sequelize/src/services/users.service.ts +18 -29
  268. package/lib/sequelize/src/{tests → test}/auth.test.ts +2 -2
  269. package/lib/sequelize/src/{tests → test}/users.test.ts +2 -2
  270. package/lib/sequelize/src/utils/validateEnv.ts +1 -3
  271. package/lib/sequelize/tsconfig.json +2 -2
  272. package/lib/starter.js +18 -27
  273. package/lib/typegoose/.env.production.local +1 -1
  274. package/lib/typegoose/.env.test.local +1 -1
  275. package/lib/typegoose/.swcrc +1 -1
  276. package/lib/typegoose/Dockerfile.dev +19 -0
  277. package/lib/typegoose/Dockerfile.prod +19 -0
  278. package/lib/typegoose/Makefile +32 -15
  279. package/lib/typegoose/docker-compose.yml +20 -11
  280. package/lib/typegoose/jest.config.js +1 -1
  281. package/lib/typegoose/package.json +41 -39
  282. package/lib/typegoose/src/app.ts +3 -2
  283. package/lib/typegoose/src/config/index.ts +2 -1
  284. package/lib/typegoose/src/controllers/auth.controller.ts +9 -11
  285. package/lib/typegoose/src/controllers/users.controller.ts +11 -13
  286. package/lib/typegoose/src/database/index.ts +11 -0
  287. package/lib/typegoose/src/dtos/users.dto.ts +12 -1
  288. package/lib/typegoose/src/interfaces/users.interface.ts +1 -1
  289. package/lib/typegoose/src/middlewares/auth.middleware.ts +16 -10
  290. package/lib/typegoose/src/middlewares/error.middleware.ts +2 -4
  291. package/lib/typegoose/src/middlewares/validation.middleware.ts +22 -20
  292. package/lib/typegoose/src/models/users.model.ts +1 -3
  293. package/lib/typegoose/src/routes/auth.route.ts +8 -11
  294. package/lib/typegoose/src/routes/users.route.ts +9 -11
  295. package/lib/typegoose/src/server.ts +5 -6
  296. package/lib/typegoose/src/services/auth.service.ts +27 -36
  297. package/lib/typegoose/src/services/users.service.ts +17 -26
  298. package/lib/typegoose/src/{tests → test}/auth.test.ts +2 -2
  299. package/lib/{mongoose/src/tests → typegoose/src/test}/users.test.ts +7 -7
  300. package/lib/typegoose/src/utils/validateEnv.ts +1 -3
  301. package/lib/typegoose/tsconfig.json +2 -2
  302. package/lib/typeorm/.env.development.local +2 -2
  303. package/lib/typeorm/.env.production.local +3 -3
  304. package/lib/typeorm/.env.test.local +3 -3
  305. package/lib/typeorm/.swcrc +1 -1
  306. package/lib/typeorm/Dockerfile.dev +19 -0
  307. package/lib/typeorm/Dockerfile.prod +19 -0
  308. package/lib/typeorm/Makefile +32 -15
  309. package/lib/typeorm/docker-compose.yml +21 -14
  310. package/lib/typeorm/jest.config.js +1 -1
  311. package/lib/typeorm/package.json +42 -41
  312. package/lib/typeorm/src/app.ts +6 -8
  313. package/lib/typeorm/src/config/index.ts +2 -1
  314. package/lib/typeorm/src/controllers/auth.controller.ts +9 -11
  315. package/lib/typeorm/src/controllers/users.controller.ts +11 -13
  316. package/lib/{graphql/src/databases → typeorm/src/database}/index.ts +3 -3
  317. package/lib/typeorm/src/dtos/users.dto.ts +12 -1
  318. package/lib/typeorm/src/exceptions/httpException.ts +10 -0
  319. package/lib/typeorm/src/interfaces/users.interface.ts +1 -1
  320. package/lib/typeorm/src/middlewares/auth.middleware.ts +14 -7
  321. package/lib/typeorm/src/middlewares/error.middleware.ts +2 -4
  322. package/lib/typeorm/src/middlewares/validation.middleware.ts +22 -20
  323. package/lib/typeorm/src/routes/auth.route.ts +8 -11
  324. package/lib/typeorm/src/routes/users.route.ts +9 -11
  325. package/lib/typeorm/src/server.ts +6 -7
  326. package/lib/typeorm/src/services/auth.service.ts +24 -32
  327. package/lib/typeorm/src/services/users.service.ts +10 -20
  328. package/lib/typeorm/src/{tests → test}/auth.test.ts +10 -11
  329. package/lib/typeorm/src/{tests → test}/users.test.ts +34 -38
  330. package/lib/typeorm/src/utils/validateEnv.ts +1 -3
  331. package/lib/typeorm/tsconfig.json +2 -2
  332. package/package.json +3 -3
  333. package/lib/default/Dockerfile +0 -24
  334. package/lib/default/src/controllers/index.controller.ts +0 -13
  335. package/lib/default/src/routes/index.route.ts +0 -19
  336. package/lib/default/src/utils/util.ts +0 -19
  337. package/lib/graphql/Dockerfile +0 -24
  338. package/lib/graphql/src/tests/index.test.ts +0 -18
  339. package/lib/graphql/src/tests/users.test.ts +0 -71
  340. package/lib/graphql/src/utils/util.ts +0 -19
  341. package/lib/knex/Dockerfile +0 -24
  342. package/lib/knex/src/controllers/index.controller.ts +0 -13
  343. package/lib/knex/src/databases/migrations/20210713110926_initial.ts +0 -13
  344. package/lib/knex/src/routes/index.route.ts +0 -19
  345. package/lib/knex/src/tests/index.test.ts +0 -17
  346. package/lib/knex/src/utils/util.ts +0 -19
  347. package/lib/mikro-orm/Dockerfile +0 -24
  348. package/lib/mikro-orm/src/controllers/index.controller.ts +0 -13
  349. package/lib/mikro-orm/src/routes/index.route.ts +0 -19
  350. package/lib/mikro-orm/src/tests/index.test.ts +0 -18
  351. package/lib/mikro-orm/src/utils/util.ts +0 -19
  352. package/lib/mongoose/Dockerfile +0 -24
  353. package/lib/mongoose/src/controllers/index.controller.ts +0 -13
  354. package/lib/mongoose/src/routes/index.route.ts +0 -19
  355. package/lib/mongoose/src/utils/util.ts +0 -19
  356. package/lib/prisma/Dockerfile +0 -24
  357. package/lib/prisma/src/controllers/index.controller.ts +0 -13
  358. package/lib/prisma/src/routes/index.route.ts +0 -19
  359. package/lib/prisma/src/tests/index.test.ts +0 -18
  360. package/lib/prisma/src/utils/util.ts +0 -19
  361. package/lib/routing-controllers/Dockerfile +0 -24
  362. package/lib/routing-controllers/src/controllers/index.controller.ts +0 -9
  363. package/lib/routing-controllers/src/tests/index.test.ts +0 -17
  364. package/lib/routing-controllers/src/utils/util.ts +0 -19
  365. package/lib/sequelize/Dockerfile +0 -28
  366. package/lib/sequelize/src/controllers/index.controller.ts +0 -13
  367. package/lib/sequelize/src/routes/index.route.ts +0 -19
  368. package/lib/sequelize/src/tests/index.test.ts +0 -18
  369. package/lib/sequelize/src/utils/util.ts +0 -19
  370. package/lib/typegoose/Dockerfile +0 -24
  371. package/lib/typegoose/src/controllers/index.controller.ts +0 -13
  372. package/lib/typegoose/src/databases/index.ts +0 -3
  373. package/lib/typegoose/src/routes/index.route.ts +0 -19
  374. package/lib/typegoose/src/tests/index.test.ts +0 -18
  375. package/lib/typegoose/src/utils/util.ts +0 -19
  376. package/lib/typeorm/Dockerfile +0 -24
  377. package/lib/typeorm/src/controllers/index.controller.ts +0 -13
  378. package/lib/typeorm/src/routes/index.route.ts +0 -19
  379. package/lib/typeorm/src/tests/index.test.ts +0 -18
  380. package/lib/typeorm/src/utils/util.ts +0 -19
  381. package/lib/default/src/exceptions/{HttpException.ts → httpException.ts} +0 -0
  382. package/lib/graphql/src/exceptions/{HttpException.ts → httpException.ts} +0 -0
  383. package/lib/knex/src/{databases → database}/migrations/.gitkeep +0 -0
  384. package/lib/knex/src/{databases → database}/seeds/.gitkeep +0 -0
  385. package/lib/knex/src/exceptions/{HttpException.ts → httpException.ts} +0 -0
  386. package/lib/mikro-orm/src/{databases → database}/index.ts +0 -0
  387. package/lib/mikro-orm/src/exceptions/{HttpException.ts → httpException.ts} +0 -0
  388. package/lib/mongoose/src/exceptions/{HttpException.ts → httpException.ts} +0 -0
  389. package/lib/mongoose/src/{tests → test}/auth.test.ts +0 -0
  390. package/lib/{default/src/tests → mongoose/src/test}/index.test.ts +0 -0
  391. package/lib/{prisma/src/exceptions/HttpException.ts → node-postgres/src/exceptions/httpException.ts} +0 -0
  392. package/lib/{sequelize/src/exceptions/HttpException.ts → prisma/src/exceptions/httpException.ts} +0 -0
  393. package/lib/prisma/src/{tests → test}/auth.test.ts +1 -1
  394. package/lib/{mongoose/src/tests → prisma/src/test}/index.test.ts +0 -0
  395. package/lib/prisma/src/{tests → test}/users.test.ts +1 -1
  396. /package/lib/routing-controllers/src/exceptions/{HttpException.ts → httpException.ts} +0 -0
  397. /package/lib/sequelize/src/{migrations → database/migrations}/.gitkeep +0 -0
  398. /package/lib/sequelize/src/{seeders → database/seeders}/.gitkeep +0 -0
  399. /package/lib/{typegoose/src/exceptions/HttpException.ts → sequelize/src/exceptions/httpException.ts} +0 -0
  400. /package/lib/{typeorm/src/exceptions/HttpException.ts → typegoose/src/exceptions/httpException.ts} +0 -0
  401. /package/lib/typeorm/src/{migration → database/migrations}/.gitkeep +0 -0
@@ -1,16 +1,17 @@
1
1
  import { NextFunction, Request, Response } from 'express';
2
+ import { Container } from 'typedi';
2
3
  import { CreateUserDto } from '@dtos/users.dto';
3
4
  import { User } from '@interfaces/users.interface';
4
5
  import { RequestWithUser } from '@interfaces/auth.interface';
5
- import AuthService from '@services/auth.service';
6
+ import { AuthService } from '@services/auth.service';
6
7
 
7
- class AuthController {
8
- public authService = new AuthService();
8
+ export class AuthController {
9
+ public auth = Container.get(AuthService);
9
10
 
10
11
  public signUp = async (req: Request, res: Response, next: NextFunction) => {
11
12
  try {
12
13
  const userData: CreateUserDto = req.body;
13
- const signUpUserData: User = await this.authService.signup(userData);
14
+ const signUpUserData: User = await this.auth.signup(userData);
14
15
 
15
16
  res.status(201).json({ data: signUpUserData, message: 'signup' });
16
17
  } catch (error) {
@@ -21,7 +22,7 @@ class AuthController {
21
22
  public logIn = async (req: Request, res: Response, next: NextFunction) => {
22
23
  try {
23
24
  const userData: CreateUserDto = req.body;
24
- const { cookie, findUser } = await this.authService.login(userData);
25
+ const { cookie, findUser } = await this.auth.login(userData);
25
26
 
26
27
  res.setHeader('Set-Cookie', [cookie]);
27
28
  res.status(200).json({ data: findUser, message: 'login' });
@@ -33,7 +34,7 @@ class AuthController {
33
34
  public logOut = async (req: RequestWithUser, res: Response, next: NextFunction) => {
34
35
  try {
35
36
  const userData: User = req.user;
36
- const logOutUserData: User = await this.authService.logout(userData);
37
+ const logOutUserData: User = await this.auth.logout(userData);
37
38
 
38
39
  res.setHeader('Set-Cookie', ['Authorization=; Max-age=0']);
39
40
  res.status(200).json({ data: logOutUserData, message: 'logout' });
@@ -42,5 +43,3 @@ class AuthController {
42
43
  }
43
44
  };
44
45
  }
45
-
46
- export default AuthController;
@@ -1,14 +1,15 @@
1
1
  import { NextFunction, Request, Response } from 'express';
2
+ import { Container } from 'typedi';
2
3
  import { CreateUserDto } from '@dtos/users.dto';
3
4
  import { User } from '@interfaces/users.interface';
4
- import userService from '@services/users.service';
5
+ import { UserService } from '@services/users.service';
5
6
 
6
- class UsersController {
7
- public userService = new userService();
7
+ export class UserController {
8
+ public user = Container.get(UserService);
8
9
 
9
10
  public getUsers = async (req: Request, res: Response, next: NextFunction) => {
10
11
  try {
11
- const findAllUsersData: User[] = await this.userService.findAllUser();
12
+ const findAllUsersData: User[] = await this.user.findAllUser();
12
13
 
13
14
  res.status(200).json({ data: findAllUsersData, message: 'findAll' });
14
15
  } catch (error) {
@@ -19,7 +20,7 @@ class UsersController {
19
20
  public getUserById = async (req: Request, res: Response, next: NextFunction) => {
20
21
  try {
21
22
  const userId = Number(req.params.id);
22
- const findOneUserData: User = await this.userService.findUserById(userId);
23
+ const findOneUserData: User = await this.user.findUserById(userId);
23
24
 
24
25
  res.status(200).json({ data: findOneUserData, message: 'findOne' });
25
26
  } catch (error) {
@@ -30,7 +31,7 @@ class UsersController {
30
31
  public createUser = async (req: Request, res: Response, next: NextFunction) => {
31
32
  try {
32
33
  const userData: CreateUserDto = req.body;
33
- const createUserData: User = await this.userService.createUser(userData);
34
+ const createUserData: User = await this.user.createUser(userData);
34
35
 
35
36
  res.status(201).json({ data: createUserData, message: 'created' });
36
37
  } catch (error) {
@@ -42,7 +43,7 @@ class UsersController {
42
43
  try {
43
44
  const userId = Number(req.params.id);
44
45
  const userData: CreateUserDto = req.body;
45
- const updateUserData: User = await this.userService.updateUser(userId, userData);
46
+ const updateUserData: User = await this.user.updateUser(userId, userData);
46
47
 
47
48
  res.status(200).json({ data: updateUserData, message: 'updated' });
48
49
  } catch (error) {
@@ -53,7 +54,7 @@ class UsersController {
53
54
  public deleteUser = async (req: Request, res: Response, next: NextFunction) => {
54
55
  try {
55
56
  const userId = Number(req.params.id);
56
- const deleteUserData: User = await this.userService.deleteUser(userId);
57
+ const deleteUserData: User = await this.user.deleteUser(userId);
57
58
 
58
59
  res.status(200).json({ data: deleteUserData, message: 'deleted' });
59
60
  } catch (error) {
@@ -61,5 +62,3 @@ class UsersController {
61
62
  }
62
63
  };
63
64
  }
64
-
65
- export default UsersController;
@@ -27,10 +27,8 @@ const sequelize = new Sequelize.Sequelize(DB_DATABASE, DB_USER, DB_PASSWORD, {
27
27
 
28
28
  sequelize.authenticate();
29
29
 
30
- const DB = {
30
+ export const DB = {
31
31
  Users: UserModel(sequelize),
32
32
  sequelize, // connection instance (RAW queries)
33
33
  Sequelize, // library
34
34
  };
35
-
36
- export default DB;
@@ -1,9 +1,20 @@
1
- import { IsString, IsEmail } from 'class-validator';
1
+ import { IsString, IsEmail, 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 DB from '@databases';
5
- import { HttpException } from '@exceptions/HttpException';
4
+ import { DB } from '@database';
5
+ import { HttpException } from '@exceptions/httpException';
6
6
  import { DataStoredInToken, RequestWithUser } from '@interfaces/auth.interface';
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 = verify(Authorization, secretKey) as DataStoredInToken;
15
- const userId = verificationResponse.id;
16
- const findUser = await DB.Users.findByPk(userId);
23
+ const { id } = verify(Authorization, SECRET_KEY) as DataStoredInToken;
24
+ const findUser = await DB.Users.findByPk(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,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,24 +1,21 @@
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 {
9
- public path = '/';
8
+ export class AuthRoute implements Routes {
10
9
  public router = Router();
11
- public authController = new AuthController();
10
+ public auth = new AuthController();
12
11
 
13
12
  constructor() {
14
13
  this.initializeRoutes();
15
14
  }
16
15
 
17
16
  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);
17
+ this.router.post('/signup', ValidationMiddleware(CreateUserDto, 'body'), this.auth.signUp);
18
+ this.router.post('/login', ValidationMiddleware(CreateUserDto, 'body'), this.auth.logIn);
19
+ this.router.post('/logout', AuthMiddleware, this.auth.logOut);
21
20
  }
22
21
  }
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(\\d+)`, this.usersController.getUserById);
19
- this.router.post(`${this.path}`, validationMiddleware(CreateUserDto, 'body'), this.usersController.createUser);
20
- this.router.put(`${this.path}/:id(\\d+)`, validationMiddleware(CreateUserDto, 'body', true), this.usersController.updateUser);
21
- this.router.delete(`${this.path}/:id(\\d+)`, this.usersController.deleteUser);
17
+ this.router.get(`${this.path}`, this.user.getUsers);
18
+ this.router.get(`${this.path}/:id(\\d+)`, this.user.getUserById);
19
+ this.router.post(`${this.path}`, ValidationMiddleware(CreateUserDto, 'body'), this.user.createUser);
20
+ this.router.put(`${this.path}/:id(\\d+)`, ValidationMiddleware(CreateUserDto, 'body', true), this.user.updateUser);
21
+ this.router.delete(`${this.path}/:id(\\d+)`, 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 AuthRoute(), new UserRoute()]);
10
9
 
11
10
  app.listen();
@@ -1,63 +1,52 @@
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
- import DB from '@databases';
5
+ import { DB } from '@database';
5
6
  import { CreateUserDto } from '@dtos/users.dto';
6
- import { HttpException } from '@exceptions/HttpException';
7
+ import { HttpException } from '@/exceptions/httpException';
7
8
  import { DataStoredInToken, TokenData } from '@interfaces/auth.interface';
8
9
  import { User } from '@interfaces/users.interface';
9
- import { isEmpty } from '@utils/util';
10
10
 
11
- class AuthService {
12
- public users = DB.Users;
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, "You're not userData");
15
+ return { expiresIn, token: sign(dataStoredInToken, SECRET_KEY, { expiresIn }) };
16
+ }
16
17
 
17
- const findUser: User = await this.users.findOne({ where: { email: userData.email } });
18
- if (findUser) throw new HttpException(409, `You're email ${userData.email} already exists`);
18
+ const createCookie = (tokenData: TokenData): string => {
19
+ return `Authorization=${tokenData.token}; HttpOnly; Max-Age=${tokenData.expiresIn};`;
20
+ }
21
+ @Service()
22
+ export class AuthService {
23
+ public async signup(userData: CreateUserDto): Promise<User> {
24
+ const findUser: User = await DB.Users.findOne({ where: { email: userData.email } });
25
+ if (findUser) throw new HttpException(409, `This email ${userData.email} already exists`);
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 DB.Users.create({ ...userData, password: hashedPassword });
22
29
 
23
30
  return createUserData;
24
31
  }
25
32
 
26
33
  public async login(userData: CreateUserDto): Promise<{ cookie: string; findUser: User }> {
27
- if (isEmpty(userData)) throw new HttpException(400, "You're not userData");
28
-
29
- const findUser: User = await this.users.findOne({ where: { email: userData.email } });
30
- if (!findUser) throw new HttpException(409, `You're email ${userData.email} not found`);
34
+ const findUser: User = await DB.Users.findOne({ where: { email: userData.email } });
35
+ if (!findUser) throw new HttpException(409, `This email ${userData.email} was not found`);
31
36
 
32
37
  const isPasswordMatching: boolean = await compare(userData.password, findUser.password);
33
- if (!isPasswordMatching) throw new HttpException(409, "You're password not matching");
38
+ if (!isPasswordMatching) throw new HttpException(409, "Password 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, "You're not userData");
43
-
44
- const findUser: User = await this.users.findOne({ where: { email: userData.email, password: userData.password } });
45
- if (!findUser) throw new HttpException(409, "You're not user");
47
+ const findUser: User = await DB.Users.findOne({ where: { email: userData.email, password: userData.password } });
48
+ if (!findUser) throw new HttpException(409, "User doesn't exist");
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;
@@ -1,61 +1,50 @@
1
1
  import { hash } from 'bcrypt';
2
- import DB from '@databases';
2
+ import { Service } from 'typedi';
3
+ import { DB } from '@database';
3
4
  import { CreateUserDto } from '@dtos/users.dto';
4
- import { HttpException } from '@exceptions/HttpException';
5
+ import { HttpException } from '@/exceptions/httpException';
5
6
  import { User } from '@interfaces/users.interface';
6
- import { isEmpty } from '@utils/util';
7
-
8
- class UserService {
9
- public users = DB.Users;
10
7
 
8
+ @Service()
9
+ export class UserService {
11
10
  public async findAllUser(): Promise<User[]> {
12
- const allUser: User[] = await this.users.findAll();
11
+ const allUser: User[] = await DB.Users.findAll();
13
12
  return allUser;
14
13
  }
15
14
 
16
15
  public async findUserById(userId: number): Promise<User> {
17
- if (isEmpty(userId)) throw new HttpException(400, "You're not userId");
18
-
19
- const findUser: User = await this.users.findByPk(userId);
20
- if (!findUser) throw new HttpException(409, "You're not user");
16
+ const findUser: User = await DB.Users.findByPk(userId);
17
+ if (!findUser) throw new HttpException(409, "User doesn't exist");
21
18
 
22
19
  return findUser;
23
20
  }
24
21
 
25
22
  public async createUser(userData: CreateUserDto): Promise<User> {
26
- if (isEmpty(userData)) throw new HttpException(400, "You're not userData");
27
-
28
- const findUser: User = await this.users.findOne({ where: { email: userData.email } });
29
- if (findUser) throw new HttpException(409, `You're email ${userData.email} already exists`);
23
+ const findUser: User = await DB.Users.findOne({ where: { email: userData.email } });
24
+ if (findUser) throw new HttpException(409, `This email ${userData.email} already exists`);
30
25
 
31
26
  const hashedPassword = await hash(userData.password, 10);
32
- const createUserData: User = await this.users.create({ ...userData, password: hashedPassword });
27
+ const createUserData: User = await DB.Users.create({ ...userData, password: hashedPassword });
33
28
  return createUserData;
34
29
  }
35
30
 
36
31
  public async updateUser(userId: number, userData: CreateUserDto): Promise<User> {
37
- if (isEmpty(userData)) throw new HttpException(400, "You're not userData");
38
-
39
- const findUser: User = await this.users.findByPk(userId);
40
- if (!findUser) throw new HttpException(409, "You're not user");
32
+ const findUser: User = await DB.Users.findByPk(userId);
33
+ if (!findUser) throw new HttpException(409, "User doesn't exist");
41
34
 
42
35
  const hashedPassword = await hash(userData.password, 10);
43
- await this.users.update({ ...userData, password: hashedPassword }, { where: { id: userId } });
36
+ await DB.Users.update({ ...userData, password: hashedPassword }, { where: { id: userId } });
44
37
 
45
- const updateUser: User = await this.users.findByPk(userId);
38
+ const updateUser: User = await DB.Users.findByPk(userId);
46
39
  return updateUser;
47
40
  }
48
41
 
49
42
  public async deleteUser(userId: number): Promise<User> {
50
- if (isEmpty(userId)) throw new HttpException(400, "You're not userId");
51
-
52
- const findUser: User = await this.users.findByPk(userId);
53
- if (!findUser) throw new HttpException(409, "You're not user");
43
+ const findUser: User = await DB.Users.findByPk(userId);
44
+ if (!findUser) throw new HttpException(409, "User doesn't exist");
54
45
 
55
- await this.users.destroy({ where: { id: userId } });
46
+ await DB.Users.destroy({ where: { id: userId } });
56
47
 
57
48
  return findUser;
58
49
  }
59
50
  }
60
-
61
- export default UserService;
@@ -1,9 +1,9 @@
1
1
  import bcrypt from 'bcrypt';
2
2
  import { Sequelize } from 'sequelize';
3
3
  import request from 'supertest';
4
- import App from '@/app';
4
+ import { App } from '@/app';
5
5
  import { CreateUserDto } from '@dtos/users.dto';
6
- import AuthRoute from '@routes/auth.route';
6
+ import { AuthRoute } from '@routes/auth.route';
7
7
 
8
8
  afterAll(async () => {
9
9
  await new Promise<void>(resolve => setTimeout(() => resolve(), 500));
@@ -1,9 +1,9 @@
1
1
  import bcrypt from 'bcrypt';
2
2
  import { Sequelize } from 'sequelize';
3
3
  import request from 'supertest';
4
- import App from '@/app';
4
+ import { App } from '@/app';
5
5
  import { CreateUserDto } from '@dtos/users.dto';
6
- import UserRoute from '@routes/users.route';
6
+ import { UserRoute } from '@routes/users.route';
7
7
 
8
8
  afterAll(async () => {
9
9
  await new Promise<void>(resolve => setTimeout(() => resolve(), 500));
@@ -1,10 +1,8 @@
1
1
  import { cleanEnv, port, str } from 'envalid';
2
2
 
3
- function validateEnv() {
3
+ export function ValidateEnv() {
4
4
  cleanEnv(process.env, {
5
5
  NODE_ENV: str(),
6
6
  PORT: port(),
7
7
  });
8
8
  }
9
-
10
- export default validateEnv;
@@ -24,7 +24,7 @@
24
24
  "@/*": ["*"],
25
25
  "@config": ["config"],
26
26
  "@controllers/*": ["controllers/*"],
27
- "@databases": ["databases"],
27
+ "@database": ["database"],
28
28
  "@dtos/*": ["dtos/*"],
29
29
  "@exceptions/*": ["exceptions/*"],
30
30
  "@interfaces/*": ["interfaces/*"],
@@ -36,5 +36,5 @@
36
36
  }
37
37
  },
38
38
  "include": ["src/**/*.ts", "src/**/*.json", ".env"],
39
- "exclude": ["node_modules", "src/http", "src/logs", "src/tests"]
39
+ "exclude": ["node_modules", "src/http", "src/logs"]
40
40
  }