arkos 0.0.13 → 0.0.15

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 (285) hide show
  1. package/dist/app.d.ts.map +1 -0
  2. package/dist/app.js.map +1 -0
  3. package/dist/modules/auth/auth.controller.d.ts.map +1 -0
  4. package/dist/modules/auth/auth.controller.js.map +1 -0
  5. package/dist/modules/auth/auth.router.d.ts.map +1 -0
  6. package/dist/modules/auth/auth.router.js.map +1 -0
  7. package/dist/modules/auth/auth.service.d.ts.map +1 -0
  8. package/dist/modules/auth/auth.service.js.map +1 -0
  9. package/dist/modules/base/base.controller.d.ts.map +1 -0
  10. package/dist/modules/base/base.controller.js.map +1 -0
  11. package/dist/modules/base/base.middlewares.d.ts.map +1 -0
  12. package/dist/modules/base/base.middlewares.js.map +1 -0
  13. package/dist/modules/base/base.router.d.ts.map +1 -0
  14. package/dist/modules/base/base.router.js.map +1 -0
  15. package/dist/modules/base/base.service.d.ts.map +1 -0
  16. package/dist/modules/base/base.service.js.map +1 -0
  17. package/dist/modules/base/utils/base.helpers.d.ts.map +1 -0
  18. package/dist/modules/base/utils/base.helpers.js.map +1 -0
  19. package/dist/modules/email/email.service.d.ts.map +1 -0
  20. package/dist/modules/email/email.service.js.map +1 -0
  21. package/dist/modules/email/utils/helpers/email.helpers.d.ts.map +1 -0
  22. package/dist/modules/email/utils/helpers/email.helpers.js.map +1 -0
  23. package/dist/modules/error-handler/error-handler.controller.d.ts.map +1 -0
  24. package/dist/modules/error-handler/error-handler.controller.js.map +1 -0
  25. package/dist/modules/error-handler/utils/app-error.d.ts.map +1 -0
  26. package/dist/modules/error-handler/utils/app-error.js.map +1 -0
  27. package/dist/modules/error-handler/utils/catch-async.d.ts.map +1 -0
  28. package/dist/modules/error-handler/utils/catch-async.js.map +1 -0
  29. package/dist/modules/error-handler/utils/error-handler.helpers.d.ts.map +1 -0
  30. package/dist/modules/error-handler/utils/error-handler.helpers.js.map +1 -0
  31. package/dist/modules/file-uploader/file-uploader.service.d.ts.map +1 -0
  32. package/dist/modules/file-uploader/file-uploader.service.js.map +1 -0
  33. package/dist/paths.d.ts.map +1 -0
  34. package/dist/paths.js.map +1 -0
  35. package/dist/server.d.ts.map +1 -0
  36. package/dist/server.js.map +1 -0
  37. package/dist/utils/features/api.features.d.ts.map +1 -0
  38. package/dist/utils/features/api.features.js.map +1 -0
  39. package/dist/utils/features/prisma.helpers.d.ts.map +1 -0
  40. package/dist/utils/features/prisma.helpers.js.map +1 -0
  41. package/dist/utils/helpers/api.features.helpers.d.ts.map +1 -0
  42. package/dist/utils/helpers/api.features.helpers.js.map +1 -0
  43. package/dist/utils/helpers/models.helpers.d.ts.map +1 -0
  44. package/dist/utils/helpers/models.helpers.js.map +1 -0
  45. package/dist/utils/helpers/text.helpers.d.ts.map +1 -0
  46. package/dist/utils/helpers/text.helpers.js.map +1 -0
  47. package/dist/utils/permissions/index.d.ts.map +1 -0
  48. package/dist/utils/permissions/index.js.map +1 -0
  49. package/dist/utils/scripts/export-prisma-types.d.ts.map +1 -0
  50. package/dist/utils/scripts/export-prisma-types.js.map +1 -0
  51. package/dist/utils/scripts/generate-zod-schemas.d.ts.map +1 -0
  52. package/dist/utils/scripts/generate-zod-schemas.js.map +1 -0
  53. package/dist/utils/scripts/prisma-db-push.d.ts.map +1 -0
  54. package/dist/utils/scripts/prisma-db-push.js.map +1 -0
  55. package/dist/utils/validate-dto.d.ts.map +1 -0
  56. package/dist/utils/validate-dto.js.map +1 -0
  57. package/package.json +1 -1
  58. package/dist/main/app.d.ts +0 -11
  59. package/dist/main/app.d.ts.map +0 -1
  60. package/dist/main/app.js +0 -121
  61. package/dist/main/app.js.map +0 -1
  62. package/dist/main/modules/auth/auth.controller.d.ts.map +0 -1
  63. package/dist/main/modules/auth/auth.controller.js.map +0 -1
  64. package/dist/main/modules/auth/auth.router.d.ts.map +0 -1
  65. package/dist/main/modules/auth/auth.router.js.map +0 -1
  66. package/dist/main/modules/auth/auth.service.d.ts.map +0 -1
  67. package/dist/main/modules/auth/auth.service.js.map +0 -1
  68. package/dist/main/modules/base/base.controller.d.ts.map +0 -1
  69. package/dist/main/modules/base/base.controller.js.map +0 -1
  70. package/dist/main/modules/base/base.middlewares.d.ts.map +0 -1
  71. package/dist/main/modules/base/base.middlewares.js.map +0 -1
  72. package/dist/main/modules/base/base.router.d.ts.map +0 -1
  73. package/dist/main/modules/base/base.router.js.map +0 -1
  74. package/dist/main/modules/base/base.service.d.ts.map +0 -1
  75. package/dist/main/modules/base/base.service.js.map +0 -1
  76. package/dist/main/modules/base/utils/base.helpers.d.ts.map +0 -1
  77. package/dist/main/modules/base/utils/base.helpers.js.map +0 -1
  78. package/dist/main/modules/email/email.service.d.ts.map +0 -1
  79. package/dist/main/modules/email/email.service.js.map +0 -1
  80. package/dist/main/modules/email/utils/helpers/email.helpers.d.ts.map +0 -1
  81. package/dist/main/modules/email/utils/helpers/email.helpers.js.map +0 -1
  82. package/dist/main/modules/error-handler/error-handler.controller.d.ts.map +0 -1
  83. package/dist/main/modules/error-handler/error-handler.controller.js.map +0 -1
  84. package/dist/main/modules/error-handler/utils/app-error.d.ts.map +0 -1
  85. package/dist/main/modules/error-handler/utils/app-error.js.map +0 -1
  86. package/dist/main/modules/error-handler/utils/catch-async.d.ts.map +0 -1
  87. package/dist/main/modules/error-handler/utils/catch-async.js.map +0 -1
  88. package/dist/main/modules/error-handler/utils/error-handler.helpers.d.ts.map +0 -1
  89. package/dist/main/modules/error-handler/utils/error-handler.helpers.js.map +0 -1
  90. package/dist/main/modules/file-uploader/file-uploader.service.d.ts.map +0 -1
  91. package/dist/main/modules/file-uploader/file-uploader.service.js.map +0 -1
  92. package/dist/main/paths.d.ts.map +0 -1
  93. package/dist/main/paths.js.map +0 -1
  94. package/dist/main/server.d.ts.map +0 -1
  95. package/dist/main/server.js +0 -52
  96. package/dist/main/server.js.map +0 -1
  97. package/dist/main/utils/features/api.features.d.ts.map +0 -1
  98. package/dist/main/utils/features/api.features.js.map +0 -1
  99. package/dist/main/utils/features/prisma.helpers.d.ts +0 -3
  100. package/dist/main/utils/features/prisma.helpers.d.ts.map +0 -1
  101. package/dist/main/utils/features/prisma.helpers.js +0 -20
  102. package/dist/main/utils/features/prisma.helpers.js.map +0 -1
  103. package/dist/main/utils/helpers/api.features.helpers.d.ts.map +0 -1
  104. package/dist/main/utils/helpers/api.features.helpers.js.map +0 -1
  105. package/dist/main/utils/helpers/models.helpers.d.ts.map +0 -1
  106. package/dist/main/utils/helpers/models.helpers.js.map +0 -1
  107. package/dist/main/utils/helpers/text.helpers.d.ts.map +0 -1
  108. package/dist/main/utils/helpers/text.helpers.js.map +0 -1
  109. package/dist/main/utils/permissions/index.d.ts.map +0 -1
  110. package/dist/main/utils/permissions/index.js.map +0 -1
  111. package/dist/main/utils/scripts/export-prisma-types.d.ts.map +0 -1
  112. package/dist/main/utils/scripts/export-prisma-types.js.map +0 -1
  113. package/dist/main/utils/scripts/generate-zod-schemas.d.ts.map +0 -1
  114. package/dist/main/utils/scripts/generate-zod-schemas.js.map +0 -1
  115. package/dist/main/utils/scripts/prisma-db-push.d.ts.map +0 -1
  116. package/dist/main/utils/scripts/prisma-db-push.js.map +0 -1
  117. package/dist/main/utils/validate-dto.d.ts.map +0 -1
  118. package/dist/main/utils/validate-dto.js.map +0 -1
  119. package/dist/src/app.d.ts.map +0 -1
  120. package/dist/src/app.js.map +0 -1
  121. package/dist/src/modules/auth/auth.controller.d.ts +0 -23
  122. package/dist/src/modules/auth/auth.controller.d.ts.map +0 -1
  123. package/dist/src/modules/auth/auth.controller.js +0 -310
  124. package/dist/src/modules/auth/auth.controller.js.map +0 -1
  125. package/dist/src/modules/auth/auth.router.d.ts +0 -4
  126. package/dist/src/modules/auth/auth.router.d.ts.map +0 -1
  127. package/dist/src/modules/auth/auth.router.js +0 -64
  128. package/dist/src/modules/auth/auth.router.js.map +0 -1
  129. package/dist/src/modules/auth/auth.service.d.ts +0 -16
  130. package/dist/src/modules/auth/auth.service.d.ts.map +0 -1
  131. package/dist/src/modules/auth/auth.service.js +0 -120
  132. package/dist/src/modules/auth/auth.service.js.map +0 -1
  133. package/dist/src/modules/base/base.controller.d.ts +0 -17
  134. package/dist/src/modules/base/base.controller.d.ts.map +0 -1
  135. package/dist/src/modules/base/base.controller.js +0 -296
  136. package/dist/src/modules/base/base.controller.js.map +0 -1
  137. package/dist/src/modules/base/base.middlewares.d.ts +0 -20
  138. package/dist/src/modules/base/base.middlewares.d.ts.map +0 -1
  139. package/dist/src/modules/base/base.middlewares.js +0 -86
  140. package/dist/src/modules/base/base.middlewares.js.map +0 -1
  141. package/dist/src/modules/base/base.router.d.ts +0 -4
  142. package/dist/src/modules/base/base.router.d.ts.map +0 -1
  143. package/dist/src/modules/base/base.router.js +0 -75
  144. package/dist/src/modules/base/base.router.js.map +0 -1
  145. package/dist/src/modules/base/base.service.d.ts +0 -32
  146. package/dist/src/modules/base/base.service.d.ts.map +0 -1
  147. package/dist/src/modules/base/base.service.js +0 -149
  148. package/dist/src/modules/base/base.service.js.map +0 -1
  149. package/dist/src/modules/base/utils/base.helpers.d.ts +0 -29
  150. package/dist/src/modules/base/utils/base.helpers.d.ts.map +0 -1
  151. package/dist/src/modules/base/utils/base.helpers.js +0 -106
  152. package/dist/src/modules/base/utils/base.helpers.js.map +0 -1
  153. package/dist/src/modules/email/email.service.d.ts +0 -22
  154. package/dist/src/modules/email/email.service.d.ts.map +0 -1
  155. package/dist/src/modules/email/email.service.js +0 -45
  156. package/dist/src/modules/email/email.service.js.map +0 -1
  157. package/dist/src/modules/email/utils/helpers/email.helpers.d.ts +0 -9
  158. package/dist/src/modules/email/utils/helpers/email.helpers.d.ts.map +0 -1
  159. package/dist/src/modules/email/utils/helpers/email.helpers.js +0 -25
  160. package/dist/src/modules/email/utils/helpers/email.helpers.js.map +0 -1
  161. package/dist/src/modules/error-handler/error-handler.controller.d.ts +0 -4
  162. package/dist/src/modules/error-handler/error-handler.controller.d.ts.map +0 -1
  163. package/dist/src/modules/error-handler/error-handler.controller.js +0 -182
  164. package/dist/src/modules/error-handler/error-handler.controller.js.map +0 -1
  165. package/dist/src/modules/error-handler/utils/app-error.d.ts +0 -11
  166. package/dist/src/modules/error-handler/utils/app-error.d.ts.map +0 -1
  167. package/dist/src/modules/error-handler/utils/app-error.js +0 -23
  168. package/dist/src/modules/error-handler/utils/app-error.js.map +0 -1
  169. package/dist/src/modules/error-handler/utils/catch-async.d.ts +0 -4
  170. package/dist/src/modules/error-handler/utils/catch-async.d.ts.map +0 -1
  171. package/dist/src/modules/error-handler/utils/catch-async.js +0 -9
  172. package/dist/src/modules/error-handler/utils/catch-async.js.map +0 -1
  173. package/dist/src/modules/error-handler/utils/error-handler.helpers.d.ts +0 -43
  174. package/dist/src/modules/error-handler/utils/error-handler.helpers.d.ts.map +0 -1
  175. package/dist/src/modules/error-handler/utils/error-handler.helpers.js +0 -209
  176. package/dist/src/modules/error-handler/utils/error-handler.helpers.js.map +0 -1
  177. package/dist/src/modules/file-uploader/file-uploader.service.d.ts +0 -20
  178. package/dist/src/modules/file-uploader/file-uploader.service.d.ts.map +0 -1
  179. package/dist/src/modules/file-uploader/file-uploader.service.js +0 -114
  180. package/dist/src/modules/file-uploader/file-uploader.service.js.map +0 -1
  181. package/dist/src/paths.d.ts +0 -2
  182. package/dist/src/paths.d.ts.map +0 -1
  183. package/dist/src/paths.js +0 -9
  184. package/dist/src/paths.js.map +0 -1
  185. package/dist/src/server.d.ts +0 -21
  186. package/dist/src/server.d.ts.map +0 -1
  187. package/dist/src/server.js.map +0 -1
  188. package/dist/src/utils/features/api.features.d.ts +0 -20
  189. package/dist/src/utils/features/api.features.d.ts.map +0 -1
  190. package/dist/src/utils/features/api.features.js +0 -175
  191. package/dist/src/utils/features/api.features.js.map +0 -1
  192. package/dist/src/utils/features/prisma.helpers.d.ts.map +0 -1
  193. package/dist/src/utils/features/prisma.helpers.js.map +0 -1
  194. package/dist/src/utils/helpers/api.features.helpers.d.ts +0 -41
  195. package/dist/src/utils/helpers/api.features.helpers.d.ts.map +0 -1
  196. package/dist/src/utils/helpers/api.features.helpers.js +0 -161
  197. package/dist/src/utils/helpers/api.features.helpers.js.map +0 -1
  198. package/dist/src/utils/helpers/models.helpers.d.ts +0 -21
  199. package/dist/src/utils/helpers/models.helpers.d.ts.map +0 -1
  200. package/dist/src/utils/helpers/models.helpers.js +0 -192
  201. package/dist/src/utils/helpers/models.helpers.js.map +0 -1
  202. package/dist/src/utils/helpers/text.helpers.d.ts +0 -2
  203. package/dist/src/utils/helpers/text.helpers.d.ts.map +0 -1
  204. package/dist/src/utils/helpers/text.helpers.js +0 -12
  205. package/dist/src/utils/helpers/text.helpers.js.map +0 -1
  206. package/dist/src/utils/permissions/index.d.ts +0 -3
  207. package/dist/src/utils/permissions/index.d.ts.map +0 -1
  208. package/dist/src/utils/permissions/index.js +0 -17
  209. package/dist/src/utils/permissions/index.js.map +0 -1
  210. package/dist/src/utils/prisma.d.ts +0 -3
  211. package/dist/src/utils/prisma.d.ts.map +0 -1
  212. package/dist/src/utils/prisma.js +0 -6
  213. package/dist/src/utils/prisma.js.map +0 -1
  214. package/dist/src/utils/scripts/export-prisma-types.d.ts +0 -2
  215. package/dist/src/utils/scripts/export-prisma-types.d.ts.map +0 -1
  216. package/dist/src/utils/scripts/export-prisma-types.js +0 -152
  217. package/dist/src/utils/scripts/export-prisma-types.js.map +0 -1
  218. package/dist/src/utils/scripts/generate-zod-schemas.d.ts +0 -2
  219. package/dist/src/utils/scripts/generate-zod-schemas.d.ts.map +0 -1
  220. package/dist/src/utils/scripts/generate-zod-schemas.js +0 -121
  221. package/dist/src/utils/scripts/generate-zod-schemas.js.map +0 -1
  222. package/dist/src/utils/scripts/prisma-db-push.d.ts +0 -2
  223. package/dist/src/utils/scripts/prisma-db-push.d.ts.map +0 -1
  224. package/dist/src/utils/scripts/prisma-db-push.js +0 -24
  225. package/dist/src/utils/scripts/prisma-db-push.js.map +0 -1
  226. package/dist/src/utils/validate-dto.d.ts +0 -3
  227. package/dist/src/utils/validate-dto.d.ts.map +0 -1
  228. package/dist/src/utils/validate-dto.js +0 -17
  229. package/dist/src/utils/validate-dto.js.map +0 -1
  230. /package/dist/{src/app.d.ts → app.d.ts} +0 -0
  231. /package/dist/{src/app.js → app.js} +0 -0
  232. /package/dist/{main/modules → modules}/auth/auth.controller.d.ts +0 -0
  233. /package/dist/{main/modules → modules}/auth/auth.controller.js +0 -0
  234. /package/dist/{main/modules → modules}/auth/auth.router.d.ts +0 -0
  235. /package/dist/{main/modules → modules}/auth/auth.router.js +0 -0
  236. /package/dist/{main/modules → modules}/auth/auth.service.d.ts +0 -0
  237. /package/dist/{main/modules → modules}/auth/auth.service.js +0 -0
  238. /package/dist/{main/modules → modules}/base/base.controller.d.ts +0 -0
  239. /package/dist/{main/modules → modules}/base/base.controller.js +0 -0
  240. /package/dist/{main/modules → modules}/base/base.middlewares.d.ts +0 -0
  241. /package/dist/{main/modules → modules}/base/base.middlewares.js +0 -0
  242. /package/dist/{main/modules → modules}/base/base.router.d.ts +0 -0
  243. /package/dist/{main/modules → modules}/base/base.router.js +0 -0
  244. /package/dist/{main/modules → modules}/base/base.service.d.ts +0 -0
  245. /package/dist/{main/modules → modules}/base/base.service.js +0 -0
  246. /package/dist/{main/modules → modules}/base/utils/base.helpers.d.ts +0 -0
  247. /package/dist/{main/modules → modules}/base/utils/base.helpers.js +0 -0
  248. /package/dist/{main/modules → modules}/email/email.service.d.ts +0 -0
  249. /package/dist/{main/modules → modules}/email/email.service.js +0 -0
  250. /package/dist/{main/modules → modules}/email/utils/helpers/email.helpers.d.ts +0 -0
  251. /package/dist/{main/modules → modules}/email/utils/helpers/email.helpers.js +0 -0
  252. /package/dist/{main/modules → modules}/error-handler/error-handler.controller.d.ts +0 -0
  253. /package/dist/{main/modules → modules}/error-handler/error-handler.controller.js +0 -0
  254. /package/dist/{main/modules → modules}/error-handler/utils/app-error.d.ts +0 -0
  255. /package/dist/{main/modules → modules}/error-handler/utils/app-error.js +0 -0
  256. /package/dist/{main/modules → modules}/error-handler/utils/catch-async.d.ts +0 -0
  257. /package/dist/{main/modules → modules}/error-handler/utils/catch-async.js +0 -0
  258. /package/dist/{main/modules → modules}/error-handler/utils/error-handler.helpers.d.ts +0 -0
  259. /package/dist/{main/modules → modules}/error-handler/utils/error-handler.helpers.js +0 -0
  260. /package/dist/{main/modules → modules}/file-uploader/file-uploader.service.d.ts +0 -0
  261. /package/dist/{main/modules → modules}/file-uploader/file-uploader.service.js +0 -0
  262. /package/dist/{main/paths.d.ts → paths.d.ts} +0 -0
  263. /package/dist/{main/paths.js → paths.js} +0 -0
  264. /package/dist/{main/server.d.ts → server.d.ts} +0 -0
  265. /package/dist/{src/server.js → server.js} +0 -0
  266. /package/dist/{main/utils → utils}/features/api.features.d.ts +0 -0
  267. /package/dist/{main/utils → utils}/features/api.features.js +0 -0
  268. /package/dist/{src/utils → utils}/features/prisma.helpers.d.ts +0 -0
  269. /package/dist/{src/utils → utils}/features/prisma.helpers.js +0 -0
  270. /package/dist/{main/utils → utils}/helpers/api.features.helpers.d.ts +0 -0
  271. /package/dist/{main/utils → utils}/helpers/api.features.helpers.js +0 -0
  272. /package/dist/{main/utils → utils}/helpers/models.helpers.d.ts +0 -0
  273. /package/dist/{main/utils → utils}/helpers/models.helpers.js +0 -0
  274. /package/dist/{main/utils → utils}/helpers/text.helpers.d.ts +0 -0
  275. /package/dist/{main/utils → utils}/helpers/text.helpers.js +0 -0
  276. /package/dist/{main/utils → utils}/permissions/index.d.ts +0 -0
  277. /package/dist/{main/utils → utils}/permissions/index.js +0 -0
  278. /package/dist/{main/utils → utils}/scripts/export-prisma-types.d.ts +0 -0
  279. /package/dist/{main/utils → utils}/scripts/export-prisma-types.js +0 -0
  280. /package/dist/{main/utils → utils}/scripts/generate-zod-schemas.d.ts +0 -0
  281. /package/dist/{main/utils → utils}/scripts/generate-zod-schemas.js +0 -0
  282. /package/dist/{main/utils → utils}/scripts/prisma-db-push.d.ts +0 -0
  283. /package/dist/{main/utils → utils}/scripts/prisma-db-push.js +0 -0
  284. /package/dist/{main/utils → utils}/validate-dto.d.ts +0 -0
  285. /package/dist/{main/utils → utils}/validate-dto.js +0 -0
@@ -1,310 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.authControllerFactory = exports.excludedUserFields = void 0;
7
- const catch_async_1 = __importDefault(require("../error-handler/utils/catch-async"));
8
- const app_error_1 = __importDefault(require("../error-handler/utils/app-error"));
9
- const auth_service_1 = __importDefault(require("./auth.service"));
10
- const base_service_1 = __importDefault(require("../base/base.service"));
11
- const app_1 = require("../../app");
12
- exports.excludedUserFields = {
13
- password: false,
14
- passwordChangedAt: false,
15
- passwordResetOtp: false,
16
- passwordResetOtpExpiresAt: false,
17
- verificationOtp: false,
18
- verificationOptExpiresAt: false,
19
- isVerified: false,
20
- deletedSelfAccount: false,
21
- active: false,
22
- };
23
- const authControllerFactory = (middlewares = {}) => {
24
- return {
25
- getMe: (0, catch_async_1.default)(async (req, res, next) => {
26
- Object.keys(exports.excludedUserFields).forEach((key) => {
27
- if (req.user)
28
- delete req.user[key];
29
- });
30
- if (middlewares?.afterGetMe) {
31
- req.responseData = req.user;
32
- req.responseStatus = 200;
33
- return next();
34
- }
35
- res.status(200).json(req.user);
36
- }),
37
- logout: (0, catch_async_1.default)(async (req, res, next) => {
38
- res.cookie("jwt", "no-token", {
39
- expires: new Date(Date.now() + 10 * 1000),
40
- httpOnly: true,
41
- });
42
- if (middlewares?.afterLogout) {
43
- req.responseData = null;
44
- req.responseStatus = 204;
45
- return next();
46
- }
47
- res.status(204).json();
48
- }),
49
- login: (0, catch_async_1.default)(async (req, res, next) => {
50
- const { email, password } = req.body;
51
- if (!email || !password) {
52
- return next(new app_error_1.default("Please provide an email and a password", 400));
53
- }
54
- const user = await app_1.prisma.user.findUnique({
55
- where: { email },
56
- });
57
- if (!user ||
58
- !(await auth_service_1.default.isCorrectPassword(password, user.password))) {
59
- return next(new app_error_1.default("Incorrect email or password", 401));
60
- }
61
- if (!user.isVerified)
62
- return next(new app_error_1.default("You must verifiy your email in order to proceed!", 423));
63
- const token = auth_service_1.default.signJwtToken(user.id);
64
- const cookieOptions = {
65
- expires: new Date(Date.now() +
66
- Number(process.env.JWT_COOKIE_EXPIRES_IN) * 24 * 60 * 60 * 1000),
67
- httpOnly: true,
68
- secure: req.secure || req.headers["x-forwarded-proto"] === "https",
69
- sameSite: process.env.JWT_SECURE != "false" ? "lax" : "none",
70
- };
71
- if (process.env.NODE_ENV === "production")
72
- cookieOptions.secure = true;
73
- res.cookie("jwt", token, cookieOptions);
74
- if (middlewares?.afterLogin) {
75
- req.responseData = { token };
76
- req.responseStatus = 200;
77
- return next();
78
- }
79
- res.status(200).send();
80
- }),
81
- signup: (0, catch_async_1.default)(async (req, res, next) => {
82
- const userService = base_service_1.default["user"];
83
- const user = await userService.createOne(req.body);
84
- // const user = await (prisma as any).user.create({
85
- // data: {
86
- // ...req.body,
87
- // password: await authService.hashPassword(req.body.password),
88
- // } as any,
89
- // })
90
- if (middlewares?.afterSignup) {
91
- req.responseData = { data: user };
92
- req.responseStatus = 201;
93
- return next();
94
- }
95
- Object.keys(exports.excludedUserFields).forEach((key) => {
96
- delete user[key];
97
- });
98
- res.status(201).json({ data: user });
99
- }),
100
- verifyEmail: (0, catch_async_1.default)(async (req, res, next) => {
101
- const { otp, email } = req.body;
102
- // Check if email and OTP are provided
103
- if (!email || !otp) {
104
- return next(new app_error_1.default("Email and otp are required", 400, {
105
- error: "Missing parameters",
106
- }));
107
- }
108
- const user = await app_1.prisma.user.findUnique({
109
- where: { email },
110
- });
111
- if (!user) {
112
- return next(new app_error_1.default("No account found with this email.", 400, {
113
- error: "user_not_found",
114
- }));
115
- }
116
- if (user.isVerified)
117
- return next(new app_error_1.default("Your email is already verified.", 400, {
118
- error: "already_verified",
119
- }));
120
- if (user.verificationOtp !== otp)
121
- return next(new app_error_1.default("The OTP is incorrect.", 400, {
122
- error: "invalid_otp",
123
- }));
124
- if (user.verificationOptExpiresAt &&
125
- new Date() > user.verificationOptExpiresAt)
126
- return next(new app_error_1.default("The OTP has expired. Please request a new one.", 400, {
127
- error: "expired_otp",
128
- }));
129
- await app_1.prisma.user.update({
130
- where: { email },
131
- data: {
132
- isVerified: true,
133
- verificationOtp: null,
134
- verificationOptExpiresAt: null,
135
- },
136
- });
137
- if (middlewares?.afterVerifyEmail) {
138
- req.additionalData = {
139
- user,
140
- };
141
- req.responseData = {
142
- message: "Email verified successfully.",
143
- };
144
- req.responseStatus = 200;
145
- return next();
146
- }
147
- res.status(200).json({
148
- message: "Email verified successfully.",
149
- });
150
- }),
151
- forgotPassword: (0, catch_async_1.default)(async (req, res, next) => {
152
- if (!req.body.email)
153
- return next(new app_error_1.default("Email is required in order to trigger forgot password", 400));
154
- const user = await app_1.prisma.user.findUnique({
155
- where: {
156
- email: req.body.email,
157
- },
158
- });
159
- if (!user ||
160
- user?.active === false ||
161
- user?.deletedSelfAccount === true)
162
- return next(new app_error_1.default("User not found!", 404));
163
- if (!user.isVerified)
164
- return next(new app_error_1.default("You need to verify your account to proceed", 423, {
165
- error: "email_verification_required",
166
- }));
167
- // Verifica se um OTP foi solicitado recentemente
168
- if (user.passwordResetOtpExpiresAt) {
169
- const now = new Date();
170
- const lastOtpRequestedAt = new Date(new Date(user.passwordResetOtpExpiresAt).getTime() - 15 * 60 * 1000);
171
- const timeElapsed = (now.getTime() - lastOtpRequestedAt.getTime()) / 1000;
172
- const minInterval = 2 * 60; // 2 minutos em segundos
173
- if (timeElapsed < minInterval)
174
- return next(new app_error_1.default(`Please wait ${Math.ceil(minInterval - timeElapsed)} seconds before requesting a new OTP.`, 429, {
175
- remainingTime: Math.ceil(minInterval - timeElapsed),
176
- }));
177
- }
178
- const resetOtp = Math.floor(100000 + Math.random() * 900000).toString();
179
- const resetOtpExpiresAt = new Date(Date.now() + 15 * 60 * 1000);
180
- await app_1.prisma.user.update({
181
- where: {
182
- id: user.id,
183
- },
184
- data: {
185
- passwordResetOtp: resetOtp,
186
- passwordResetOtpExpiresAt: resetOtpExpiresAt,
187
- },
188
- });
189
- if (middlewares?.afterForgotPassword) {
190
- req.additionalData = {
191
- user,
192
- resetOtp,
193
- };
194
- req.responseData = {
195
- status: "success",
196
- message: "OTP code sent successfully!",
197
- };
198
- req.responseStatus = 200;
199
- return next();
200
- }
201
- res.status(200).json({
202
- status: "success",
203
- message: "OTP code sent successfully!",
204
- });
205
- }),
206
- resetPassword: (0, catch_async_1.default)(async (req, res, next) => {
207
- const { email, otp, newPassword } = req.body;
208
- if (!otp || !email || !newPassword)
209
- return next(new app_error_1.default("email, otp and newPassword are required to reset password", 400));
210
- if (!auth_service_1.default.isPasswordStrong(newPassword))
211
- return next(new app_error_1.default("Password must contain at least one uppercase letter, one lowercase letter, and one number", 400));
212
- const user = await app_1.prisma.user.findUnique({
213
- where: { email },
214
- });
215
- if (!user?.passwordResetOtp)
216
- return next(new app_error_1.default("You must request an otp in order to reset password!", 400, {
217
- error: "no_requested_otp",
218
- }));
219
- if (await auth_service_1.default.isCorrectPassword(newPassword, user?.password))
220
- return next(new app_error_1.default("New password must not be the same as last one!", 400, {
221
- error: "new_password_equals_last_password",
222
- }));
223
- if (!user ||
224
- user?.active === false ||
225
- user?.deletedSelfAccount === true)
226
- return next(new app_error_1.default("User not found!", 404));
227
- if (!user.isVerified)
228
- return next(new app_error_1.default("You need to verify your account to proceed", 423, {
229
- error: "email_verification_required",
230
- }));
231
- if (!user.passwordResetOtp || !user.passwordResetOtpExpiresAt)
232
- return next(new app_error_1.default("Invalid or expired OTP.", 400));
233
- const now = new Date();
234
- if (now > new Date(user.passwordResetOtpExpiresAt))
235
- return next(new app_error_1.default("OTP expired. Please request a new one.", 400));
236
- if (user.passwordResetOtp != otp)
237
- return next(new app_error_1.default("Invalid OTP. Please try again.", 400));
238
- await app_1.prisma.user.update({
239
- where: { id: user.id },
240
- data: {
241
- password: await auth_service_1.default.hashPassword(newPassword),
242
- passwordResetOtp: null,
243
- passwordResetOtpExpiresAt: null,
244
- passwordChangedAt: new Date(),
245
- },
246
- });
247
- if (middlewares?.afterResetPassword) {
248
- req.additionalData = {
249
- user,
250
- };
251
- req.responseData = {
252
- status: "success",
253
- message: "Password reset successfully!",
254
- };
255
- req.responseStatus = 200;
256
- return next();
257
- }
258
- res.status(200).json({
259
- status: "success",
260
- message: "Password reset successfully!",
261
- });
262
- }),
263
- updatePassword: (0, catch_async_1.default)(async (req, res, next) => {
264
- const { currentPassword, newPassword } = req.body;
265
- if (!currentPassword || !newPassword)
266
- return next(new app_error_1.default("currentPassword and newPassword are required", 400));
267
- const user = req.user;
268
- if (!user ||
269
- user?.active === false ||
270
- user?.deletedSelfAccount === true)
271
- return next(new app_error_1.default("User not found!", 404));
272
- if (!user.isVerified)
273
- return next(new app_error_1.default("You need to verify your account to proceed", 423, {
274
- error: "email_verification_required",
275
- }));
276
- // Check if the current password is correct
277
- const isPasswordCorrect = await auth_service_1.default.isCorrectPassword(String(currentPassword), String(user.password));
278
- if (!isPasswordCorrect)
279
- return next(new app_error_1.default("Current password is incorrect.", 400));
280
- // Check password strength (optional but recommended)
281
- if (!auth_service_1.default.isPasswordStrong(String(newPassword)))
282
- return next(new app_error_1.default("Password must contain at least one uppercase letter, one lowercase letter, and one number", 400));
283
- // Update the password
284
- await app_1.prisma.user.update({
285
- where: { id: user.id },
286
- data: {
287
- password: await auth_service_1.default.hashPassword(newPassword),
288
- passwordChangedAt: new Date(),
289
- },
290
- });
291
- if (middlewares?.afterUpdatePassword) {
292
- req.additionalData = {
293
- user,
294
- };
295
- req.responseData = {
296
- status: "success",
297
- message: "Password updated successfully!",
298
- };
299
- req.responseStatus = 200;
300
- return next();
301
- }
302
- res.status(200).json({
303
- status: "success",
304
- message: "Password updated successfully!",
305
- });
306
- }),
307
- };
308
- };
309
- exports.authControllerFactory = authControllerFactory;
310
- //# sourceMappingURL=auth.controller.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"auth.controller.js","sourceRoot":"","sources":["../../../../src/modules/auth/auth.controller.ts"],"names":[],"mappings":"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"}
@@ -1,4 +0,0 @@
1
- import { Router } from "express";
2
- declare const router: Router;
3
- export default router;
4
- //# sourceMappingURL=auth.router.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"auth.router.d.ts","sourceRoot":"","sources":["../../../../src/modules/auth/auth.router.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAOjC,QAAA,MAAM,MAAM,EAAE,MAAiB,CAAC;AAmHhC,eAAe,MAAM,CAAC"}
@@ -1,64 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const express_1 = require("express");
7
- const auth_controller_1 = require("./auth.controller");
8
- const auth_service_1 = __importDefault(require("./auth.service"));
9
- const express_rate_limit_1 = __importDefault(require("express-rate-limit"));
10
- const models_helpers_1 = require("../../utils/helpers/models.helpers");
11
- const base_middlewares_1 = require("../base/base.middlewares");
12
- const router = (0, express_1.Router)();
13
- (async function () {
14
- const { middlewares } = await (0, models_helpers_1.importPrismaModelModules)("auth");
15
- const authController = (0, auth_controller_1.authControllerFactory)(middlewares);
16
- router.get("/users/me", auth_service_1.default.authenticate, middlewares?.beforeGetMe ?? authController.getMe, middlewares?.beforeGetMe
17
- ? authController.getMe
18
- : middlewares?.afterGetMe ?? base_middlewares_1.sendResponse, middlewares?.beforeGetMe && middlewares?.afterGetMe
19
- ? middlewares?.afterGetMe
20
- : base_middlewares_1.sendResponse, base_middlewares_1.sendResponse);
21
- router.use((0, express_rate_limit_1.default)({
22
- windowMs: 5000,
23
- limit: 10,
24
- standardHeaders: "draft-7",
25
- legacyHeaders: false,
26
- }));
27
- router.post("/auth/login", middlewares?.beforeLogin ?? authController.login, middlewares?.beforeLogin
28
- ? authController.login
29
- : middlewares?.afterLogin ?? base_middlewares_1.sendResponse, middlewares?.beforeLogin && middlewares?.afterLogin
30
- ? middlewares?.afterLogin
31
- : base_middlewares_1.sendResponse, base_middlewares_1.sendResponse);
32
- router.delete("/auth/logout", auth_service_1.default.authenticate, middlewares?.beforeLogout ?? authController.logout, middlewares?.beforeLogout
33
- ? authController.logout
34
- : middlewares?.afterLogout ?? base_middlewares_1.sendResponse, middlewares?.beforeLogout && middlewares?.afterLogout
35
- ? middlewares?.afterLogout
36
- : base_middlewares_1.sendResponse, base_middlewares_1.sendResponse);
37
- router.post("/auth/signup", middlewares?.beforeSignup ?? authController.signup, middlewares?.beforeSignup
38
- ? authController.signup
39
- : middlewares?.afterSignup ?? base_middlewares_1.sendResponse, middlewares?.beforeSignup && middlewares?.afterSignup
40
- ? middlewares?.afterSignup
41
- : base_middlewares_1.sendResponse, base_middlewares_1.sendResponse);
42
- router.post("/auth/verify-email", middlewares?.beforeVerifyEmail ?? authController.verifyEmail, middlewares?.beforeVerifyEmail
43
- ? authController.verifyEmail
44
- : middlewares?.afterVerifyEmail ?? base_middlewares_1.sendResponse, middlewares?.beforeVerifyEmail && middlewares?.afterVerifyEmail
45
- ? middlewares?.afterVerifyEmail
46
- : base_middlewares_1.sendResponse, base_middlewares_1.sendResponse);
47
- router.post("/auth/forgot-password", middlewares?.beforeForgotPassword ?? authController.forgotPassword, middlewares?.beforeForgotPassword
48
- ? authController.forgotPassword
49
- : middlewares?.afterForgotPassword ?? base_middlewares_1.sendResponse, middlewares?.beforeForgotPassword && middlewares?.afterForgotPassword
50
- ? middlewares?.afterForgotPassword
51
- : base_middlewares_1.sendResponse, base_middlewares_1.sendResponse);
52
- router.post("/auth/reset-password", middlewares?.beforeResetPassword ?? authController.resetPassword, middlewares?.beforeResetPassword
53
- ? authController.resetPassword
54
- : middlewares?.afterResetPassword ?? base_middlewares_1.sendResponse, middlewares?.beforeResetPassword && middlewares?.afterResetPassword
55
- ? middlewares?.afterResetPassword
56
- : base_middlewares_1.sendResponse, base_middlewares_1.sendResponse);
57
- router.post("/auth/update-password", auth_service_1.default.authenticate, middlewares?.beforeUpdatePassword ?? authController.updatePassword, middlewares?.beforeUpdatePassword
58
- ? authController.updatePassword
59
- : middlewares?.afterUpdatePassword ?? base_middlewares_1.sendResponse, middlewares?.beforeUpdatePassword && middlewares?.afterUpdatePassword
60
- ? middlewares?.afterUpdatePassword
61
- : base_middlewares_1.sendResponse, base_middlewares_1.sendResponse);
62
- })();
63
- exports.default = router;
64
- //# sourceMappingURL=auth.router.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"auth.router.js","sourceRoot":"","sources":["../../../../src/modules/auth/auth.router.ts"],"names":[],"mappings":"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"}
@@ -1,16 +0,0 @@
1
- import { AuthConfigs, AuthJwtPayload, ControllerActions, User } from "../../types";
2
- import { NextFunction, Request, Response } from "express";
3
- declare class AuthService {
4
- signJwtToken(id: number | string, expiresIn?: string | number, secret?: string): string;
5
- isCorrectPassword(candidatePassword: string, userPassword: string): Promise<boolean>;
6
- hashPassword(password: string): Promise<string>;
7
- isPasswordStrong(password: string): boolean;
8
- userChangedPasswordAfter(user: User, JWTTimestamp: number): boolean;
9
- verifyJwtToken(token: string, secret?: string): Promise<AuthJwtPayload>;
10
- handleActionAccessControl(authConfigs: AuthConfigs, action: ControllerActions, modelName: string): (req: Request, res: Response, next: NextFunction) => void;
11
- authenticate: (req: Request, res: Response, next: NextFunction) => void;
12
- handleAuthenticationControl(authConfigs: AuthConfigs | undefined, action: ControllerActions, modelName: string): (req: Request, res: Response, next: NextFunction) => void;
13
- }
14
- declare const authService: AuthService;
15
- export default authService;
16
- //# sourceMappingURL=auth.service.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"auth.service.d.ts","sourceRoot":"","sources":["../../../../src/modules/auth/auth.service.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,WAAW,EACX,cAAc,EACd,iBAAiB,EACjB,IAAI,EAEL,MAAM,aAAa,CAAC;AAErB,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAK1D,cAAM,WAAW;IACf,YAAY,CACV,EAAE,EAAE,MAAM,GAAG,MAAM,EACnB,SAAS,GAAE,MAAM,GAAG,MAA2C,EAC/D,MAAM,GAAE,MAAwD,GAC/D,MAAM;IAMH,iBAAiB,CAAC,iBAAiB,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM;IAIjE,YAAY,CAAC,QAAQ,EAAE,MAAM;IAInC,gBAAgB,CAAC,QAAQ,EAAE,MAAM;IAQjC,wBAAwB,CAAC,IAAI,EAAE,IAAI,EAAE,YAAY,EAAE,MAAM;IAYnD,cAAc,CAClB,KAAK,EAAE,MAAM,EACb,MAAM,GAAE,MAAgC,GACvC,OAAO,CAAC,cAAc,CAAC;IAS1B,yBAAyB,CACvB,WAAW,EAAE,WAAW,EACxB,MAAM,EAAE,iBAAiB,EACzB,SAAS,EAAE,MAAM;IA8BnB,YAAY,4DA2EV;IAEF,2BAA2B,CACzB,WAAW,EAAE,WAAW,GAAG,SAAS,EACpC,MAAM,EAAE,iBAAiB,EACzB,SAAS,EAAE,MAAM;CAapB;AAED,QAAA,MAAM,WAAW,aAAoB,CAAC;AAEtC,eAAe,WAAW,CAAC"}
@@ -1,120 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const jsonwebtoken_1 = __importDefault(require("jsonwebtoken"));
7
- const bcryptjs_1 = __importDefault(require("bcryptjs"));
8
- const catch_async_1 = __importDefault(require("../error-handler/utils/catch-async"));
9
- const app_error_1 = __importDefault(require("../error-handler/utils/app-error"));
10
- const base_middlewares_1 = require("../base/base.middlewares");
11
- const app_1 = require("../../app");
12
- class AuthService {
13
- signJwtToken(id, expiresIn = process.env.JWT_EXPIRES_IN || "1h", secret = process.env.JWT_SECRET || "your_default_secret") {
14
- return jsonwebtoken_1.default.sign({ id }, secret, {
15
- expiresIn: expiresIn,
16
- });
17
- }
18
- async isCorrectPassword(candidatePassword, userPassword) {
19
- return await bcryptjs_1.default.compare(candidatePassword, userPassword);
20
- }
21
- async hashPassword(password) {
22
- return await bcryptjs_1.default.hash(password, 12);
23
- }
24
- isPasswordStrong(password) {
25
- const hasUppercase = /[A-Z]/.test(password);
26
- const hasLowercase = /[a-z]/.test(password);
27
- const hasNumber = /\d/.test(password);
28
- return hasUppercase && hasLowercase && hasNumber;
29
- }
30
- userChangedPasswordAfter(user, JWTTimestamp) {
31
- if (user.passwordChangedAt) {
32
- const convertedTimestamp = parseInt(String(user.passwordChangedAt.getTime() / 1000), 10);
33
- return JWTTimestamp < convertedTimestamp;
34
- }
35
- return false;
36
- }
37
- async verifyJwtToken(token, secret = process.env.JWT_SECRET) {
38
- return new Promise((resolve, reject) => {
39
- jsonwebtoken_1.default.verify(token, secret, (err, decoded) => {
40
- if (err)
41
- reject(err);
42
- else
43
- resolve(decoded);
44
- });
45
- });
46
- }
47
- handleActionAccessControl(authConfigs, action, modelName) {
48
- return (0, catch_async_1.default)(async (req, res, next) => {
49
- if (req.user) {
50
- const user = req.user;
51
- const permissions = await app_1.prisma.authPermission.count({
52
- where: {
53
- resource: modelName,
54
- action,
55
- roleId: { in: user.roles.map((role) => role.roleId) },
56
- },
57
- });
58
- if (!permissions) {
59
- return next(new app_error_1.default("You do not have permission to perfom this action", 403));
60
- }
61
- }
62
- next();
63
- });
64
- }
65
- authenticate = (0, catch_async_1.default)(async (req, res, next) => {
66
- let token;
67
- if (req?.headers?.authorization &&
68
- req?.headers?.authorization.startsWith("Bearer")) {
69
- token = req?.headers?.authorization.split(" ")[1];
70
- }
71
- else if (req?.cookies?.jwt !== "no-token" && req.cookies) {
72
- token = req?.cookies?.jwt;
73
- }
74
- if (!token)
75
- return next(new app_error_1.default("You are not logged in! please log in to get access", 401));
76
- let decoded;
77
- try {
78
- decoded = await this.verifyJwtToken(token);
79
- }
80
- catch (err) {
81
- return next(new app_error_1.default("Your auth token is invalid, please login again.", 401));
82
- }
83
- if (!decoded?.id)
84
- return next(new app_error_1.default("Your auth token is invalid, please login again.", 401));
85
- const user = await app_1.prisma.user.findUnique({
86
- where: { id: String(decoded.id) },
87
- include: {
88
- roles: true,
89
- },
90
- });
91
- if (!user)
92
- return next(new app_error_1.default("The user belonging to this token does no longer exists", 401));
93
- if (this.userChangedPasswordAfter(user, decoded.iat) &&
94
- !req.path.includes("logout"))
95
- return next(new app_error_1.default("User recently changed password! Please log in again.", 401));
96
- if (!user.isVerified && !req.path.includes("logout"))
97
- return next(new app_error_1.default("You must verifiy your email in order to proceed!", 423, {
98
- error: "email_verification_required",
99
- }));
100
- req.user = user;
101
- next();
102
- });
103
- handleAuthenticationControl(authConfigs, action, modelName) {
104
- const authenticationControl = authConfigs?.authenticationControl;
105
- if (app_1.initConfigs?.authentication === false)
106
- return base_middlewares_1.callNext;
107
- if (authenticationControl && typeof authenticationControl === "object") {
108
- if (authenticationControl[action] === false)
109
- return base_middlewares_1.callNext;
110
- else if (authenticationControl[action] === true)
111
- return this.authenticate;
112
- }
113
- else
114
- return this.authenticate;
115
- return this.authenticate;
116
- }
117
- }
118
- const authService = new AuthService();
119
- exports.default = authService;
120
- //# sourceMappingURL=auth.service.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../../src/modules/auth/auth.service.ts"],"names":[],"mappings":"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"}
@@ -1,17 +0,0 @@
1
- import { NextFunction, Request, Response } from "express";
2
- export declare function handlerFactory(modelName: string, middlewares: any): Promise<{
3
- createOne: (req: Request, res: Response, next: NextFunction) => void;
4
- createMany: (req: Request, res: Response, next: NextFunction) => void;
5
- findMany: (req: Request, res: Response, next: NextFunction) => void;
6
- findOne: (req: Request, res: Response, next: NextFunction) => void;
7
- updateOne: (req: Request, res: Response, next: NextFunction) => void;
8
- updateMany: (req: Request, res: Response, next: NextFunction) => void;
9
- deleteOne: (req: Request, res: Response, next: NextFunction) => void;
10
- deleteMany: (req: Request, res: Response, next: NextFunction) => void;
11
- }>;
12
- export declare function getAvalibleRoutes(req: Request, res: Response, next: NextFunction): void;
13
- export declare const uploadFile: (req: Request, res: Response, next: NextFunction) => void;
14
- export declare const deleteFile: (req: Request, res: Response, next: NextFunction) => void;
15
- export declare const streamFile: (req: Request, res: Response, next: NextFunction) => void;
16
- export declare const getDatabaseModels: (req: Request, res: Response, next: NextFunction) => void;
17
- //# sourceMappingURL=base.controller.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"base.controller.d.ts","sourceRoot":"","sources":["../../../../src/modules/base/base.controller.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAyB1D,wBAAsB,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,WAAW,EAAE,GAAG;;;;;;;;;GA2KvE;AAED,wBAAgB,iBAAiB,CAC/B,GAAG,EAAE,OAAO,EACZ,GAAG,EAAE,QAAQ,EACb,IAAI,EAAE,YAAY,QAgCnB;AAED,eAAO,MAAM,UAAU,2DA2GtB,CAAC;AAEF,eAAO,MAAM,UAAU,2DAgBtB,CAAC;AAEF,eAAO,MAAM,UAAU,2DA2CtB,CAAC;AAEF,eAAO,MAAM,iBAAiB,2DAE5B,CAAC"}