mongodb-dynamic-api 3.2.0 → 4.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 (330) hide show
  1. package/CHANGELOG.md +59 -0
  2. package/README.md +34 -3
  3. package/package.json +14 -11
  4. package/src/adapters/socket-adapter.d.ts +3 -3
  5. package/src/adapters/socket-adapter.js.map +1 -1
  6. package/src/builders/route-decorators/auth-decorators.builder.d.ts +1 -1
  7. package/src/builders/route-decorators/route-decorators.builder.d.ts +1 -1
  8. package/src/builders/route-decorators/route-decorators.builder.js.map +1 -1
  9. package/src/decorators/api-endpoint-visibility.decorator.js +1 -2
  10. package/src/decorators/api-endpoint-visibility.decorator.js.map +1 -1
  11. package/src/decorators/schema-options.decorator.js +2 -2
  12. package/src/decorators/schema-options.decorator.js.map +1 -1
  13. package/src/decorators/validator-pipe.decorator.js +1 -2
  14. package/src/decorators/validator-pipe.decorator.js.map +1 -1
  15. package/src/dynamic-api.module.js +4 -1
  16. package/src/dynamic-api.module.js.map +1 -1
  17. package/src/gateways/dynamic-api-broadcast.gateway.js +1 -2
  18. package/src/gateways/dynamic-api-broadcast.gateway.js.map +1 -1
  19. package/src/guards/base-policies.guard.d.ts +0 -25
  20. package/src/guards/jwt-socket.guard.js +1 -1
  21. package/src/guards/jwt-socket.guard.js.map +1 -1
  22. package/src/helpers/controller-ability-predicates.helper.js +1 -2
  23. package/src/helpers/controller-ability-predicates.helper.js.map +1 -1
  24. package/src/helpers/format.helper.js +6 -7
  25. package/src/helpers/format.helper.js.map +1 -1
  26. package/src/helpers/mixin-data.helper.js +1 -2
  27. package/src/helpers/mixin-data.helper.js.map +1 -1
  28. package/src/helpers/repository.helper.d.ts +0 -25
  29. package/src/helpers/repository.helper.js.map +1 -1
  30. package/src/helpers/route-decorators.helper.d.ts +1 -1
  31. package/src/helpers/route-decorators.helper.js +1 -2
  32. package/src/helpers/route-decorators.helper.js.map +1 -1
  33. package/src/helpers/route-description.helper.js +1 -2
  34. package/src/helpers/route-description.helper.js.map +1 -1
  35. package/src/helpers/schema.helper.d.ts +0 -25
  36. package/src/helpers/schema.helper.js +1 -2
  37. package/src/helpers/schema.helper.js.map +1 -1
  38. package/src/helpers/socket-config.helper.js +2 -3
  39. package/src/helpers/socket-config.helper.js.map +1 -1
  40. package/src/helpers/swagger-config.helper.js +1 -2
  41. package/src/helpers/swagger-config.helper.js.map +1 -1
  42. package/src/helpers/validation-config.helper.js +1 -2
  43. package/src/helpers/validation-config.helper.js.map +1 -1
  44. package/src/helpers/versioning-config.helper.js +2 -3
  45. package/src/helpers/versioning-config.helper.js.map +1 -1
  46. package/src/interceptors/dynamic-api-cache.interceptor.d.ts +3 -2
  47. package/src/interceptors/dynamic-api-cache.interceptor.js +4 -0
  48. package/src/interceptors/dynamic-api-cache.interceptor.js.map +1 -1
  49. package/src/interfaces/dynamic-api-decorator-builder.interface.d.ts +1 -1
  50. package/src/interfaces/dynamic-api-global-state.interface.d.ts +3 -25
  51. package/src/interfaces/dynamic-api-policy-handler.interface.d.ts +0 -25
  52. package/src/interfaces/dynamic-api-schema-options.interface.d.ts +0 -25
  53. package/src/interfaces/dynamic-api-service-callback.interface.d.ts +0 -25
  54. package/src/interfaces/dynamic-api-swagger-options.type.d.ts +1 -1
  55. package/src/mixins/entity-body.mixin.js +2 -2
  56. package/src/mixins/entity-body.mixin.js.map +1 -1
  57. package/src/mixins/entity-presenter.mixin.js +1 -2
  58. package/src/mixins/entity-presenter.mixin.js.map +1 -1
  59. package/src/mixins/policies-guard.mixin.js +2 -3
  60. package/src/mixins/policies-guard.mixin.js.map +1 -1
  61. package/src/models/base-entity.model.d.ts +0 -25
  62. package/src/modules/auth/auth-broadcast.helper.d.ts +3 -0
  63. package/src/modules/auth/auth-broadcast.helper.js +11 -0
  64. package/src/modules/auth/auth-broadcast.helper.js.map +1 -0
  65. package/src/modules/auth/auth-events.constants.d.ts +13 -0
  66. package/src/modules/auth/auth-events.constants.js +28 -0
  67. package/src/modules/auth/auth-events.constants.js.map +1 -0
  68. package/src/modules/auth/auth.helper.d.ts +19 -5
  69. package/src/modules/auth/auth.helper.js +20 -13
  70. package/src/modules/auth/auth.helper.js.map +1 -1
  71. package/src/modules/auth/auth.module.d.ts +5 -2
  72. package/src/modules/auth/auth.module.js +46 -7
  73. package/src/modules/auth/auth.module.js.map +1 -1
  74. package/src/modules/auth/guards/index.d.ts +2 -0
  75. package/src/modules/auth/guards/index.js +2 -0
  76. package/src/modules/auth/guards/index.js.map +1 -1
  77. package/src/modules/auth/guards/jwt-refresh/jwt-refresh.guard.d.ts +4 -0
  78. package/src/modules/auth/guards/jwt-refresh/jwt-refresh.guard.js +18 -0
  79. package/src/modules/auth/guards/jwt-refresh/jwt-refresh.guard.js.map +1 -0
  80. package/src/modules/auth/guards/jwt-socket-auth/jwt-socket-auth.guard.js +1 -1
  81. package/src/modules/auth/guards/jwt-socket-auth/jwt-socket-auth.guard.js.map +1 -1
  82. package/src/modules/auth/guards/jwt-socket-refresh/jwt-socket-refresh.guard.d.ts +8 -0
  83. package/src/modules/auth/guards/jwt-socket-refresh/jwt-socket-refresh.guard.js +62 -0
  84. package/src/modules/auth/guards/jwt-socket-refresh/jwt-socket-refresh.guard.js.map +1 -0
  85. package/src/modules/auth/index.d.ts +2 -0
  86. package/src/modules/auth/index.js +2 -0
  87. package/src/modules/auth/index.js.map +1 -1
  88. package/src/modules/auth/interfaces/auth-controller.interface.d.ts +19 -4
  89. package/src/modules/auth/interfaces/auth-gateway.interface.d.ts +2 -0
  90. package/src/modules/auth/interfaces/auth-options.interface.d.ts +19 -2
  91. package/src/modules/auth/interfaces/auth-service.interface.d.ts +3 -0
  92. package/src/modules/auth/mixins/auth-controller.mixin.d.ts +2 -2
  93. package/src/modules/auth/mixins/auth-controller.mixin.js +113 -20
  94. package/src/modules/auth/mixins/auth-controller.mixin.js.map +1 -1
  95. package/src/modules/auth/mixins/auth-gateway.mixin.d.ts +2 -2
  96. package/src/modules/auth/mixins/auth-gateway.mixin.js +66 -33
  97. package/src/modules/auth/mixins/auth-gateway.mixin.js.map +1 -1
  98. package/src/modules/auth/mixins/auth-policies-guard.mixin.js +2 -3
  99. package/src/modules/auth/mixins/auth-policies-guard.mixin.js.map +1 -1
  100. package/src/modules/auth/services/base-auth.service.d.ts +9 -25
  101. package/src/modules/auth/services/base-auth.service.js +74 -15
  102. package/src/modules/auth/services/base-auth.service.js.map +1 -1
  103. package/src/modules/auth/strategies/index.d.ts +1 -0
  104. package/src/modules/auth/strategies/index.js +1 -0
  105. package/src/modules/auth/strategies/index.js.map +1 -1
  106. package/src/modules/auth/strategies/jwt-refresh.strategy.d.ts +14 -0
  107. package/src/modules/auth/strategies/jwt-refresh.strategy.js +45 -0
  108. package/src/modules/auth/strategies/jwt-refresh.strategy.js.map +1 -0
  109. package/src/modules/auth/strategies/jwt.strategy.d.ts +3 -1
  110. package/src/modules/auth/strategies/jwt.strategy.js.map +1 -1
  111. package/src/routes/aggregate/aggregate-controller.mixin.js +1 -2
  112. package/src/routes/aggregate/aggregate-controller.mixin.js.map +1 -1
  113. package/src/routes/aggregate/aggregate-gateway.mixin.js +1 -2
  114. package/src/routes/aggregate/aggregate-gateway.mixin.js.map +1 -1
  115. package/src/routes/aggregate/aggregate-presenter.mixin.js +1 -2
  116. package/src/routes/aggregate/aggregate-presenter.mixin.js.map +1 -1
  117. package/src/routes/aggregate/aggregate.helper.js +3 -4
  118. package/src/routes/aggregate/aggregate.helper.js.map +1 -1
  119. package/src/routes/aggregate/base-aggregate.service.d.ts +0 -25
  120. package/src/routes/aggregate/base-aggregate.service.js.map +1 -1
  121. package/src/routes/create-many/base-create-many.service.d.ts +0 -25
  122. package/src/routes/create-many/base-create-many.service.js.map +1 -1
  123. package/src/routes/create-many/create-many-body.mixin.js +1 -2
  124. package/src/routes/create-many/create-many-body.mixin.js.map +1 -1
  125. package/src/routes/create-many/create-many-controller.mixin.js +1 -2
  126. package/src/routes/create-many/create-many-controller.mixin.js.map +1 -1
  127. package/src/routes/create-many/create-many-gateway.mixin.js +1 -2
  128. package/src/routes/create-many/create-many-gateway.mixin.js.map +1 -1
  129. package/src/routes/create-many/create-many-presenter.mixin.js +1 -2
  130. package/src/routes/create-many/create-many-presenter.mixin.js.map +1 -1
  131. package/src/routes/create-many/create-many.helper.js +3 -4
  132. package/src/routes/create-many/create-many.helper.js.map +1 -1
  133. package/src/routes/create-one/base-create-one.service.d.ts +0 -25
  134. package/src/routes/create-one/base-create-one.service.js.map +1 -1
  135. package/src/routes/create-one/create-one-controller.mixin.js +1 -2
  136. package/src/routes/create-one/create-one-controller.mixin.js.map +1 -1
  137. package/src/routes/create-one/create-one-gateway.mixin.js +1 -2
  138. package/src/routes/create-one/create-one-gateway.mixin.js.map +1 -1
  139. package/src/routes/create-one/create-one.helper.js +3 -4
  140. package/src/routes/create-one/create-one.helper.js.map +1 -1
  141. package/src/routes/delete-many/base-delete-many.service.d.ts +0 -25
  142. package/src/routes/delete-many/base-delete-many.service.js.map +1 -1
  143. package/src/routes/delete-many/delete-many-controller.mixin.js +1 -2
  144. package/src/routes/delete-many/delete-many-controller.mixin.js.map +1 -1
  145. package/src/routes/delete-many/delete-many-gateway.mixin.js +1 -2
  146. package/src/routes/delete-many/delete-many-gateway.mixin.js.map +1 -1
  147. package/src/routes/delete-many/delete-many.helper.js +3 -4
  148. package/src/routes/delete-many/delete-many.helper.js.map +1 -1
  149. package/src/routes/delete-one/base-delete-one.service.d.ts +0 -25
  150. package/src/routes/delete-one/base-delete-one.service.js.map +1 -1
  151. package/src/routes/delete-one/delete-one-controller.mixin.js +1 -2
  152. package/src/routes/delete-one/delete-one-controller.mixin.js.map +1 -1
  153. package/src/routes/delete-one/delete-one-gateway.mixin.js +1 -2
  154. package/src/routes/delete-one/delete-one-gateway.mixin.js.map +1 -1
  155. package/src/routes/delete-one/delete-one.helper.js +3 -4
  156. package/src/routes/delete-one/delete-one.helper.js.map +1 -1
  157. package/src/routes/duplicate-many/base-duplicate-many.service.d.ts +0 -25
  158. package/src/routes/duplicate-many/base-duplicate-many.service.js +4 -3
  159. package/src/routes/duplicate-many/base-duplicate-many.service.js.map +1 -1
  160. package/src/routes/duplicate-many/duplicate-many-controller.mixin.js +1 -2
  161. package/src/routes/duplicate-many/duplicate-many-controller.mixin.js.map +1 -1
  162. package/src/routes/duplicate-many/duplicate-many-gateway.mixin.js +1 -2
  163. package/src/routes/duplicate-many/duplicate-many-gateway.mixin.js.map +1 -1
  164. package/src/routes/duplicate-many/duplicate-many.helper.js +3 -4
  165. package/src/routes/duplicate-many/duplicate-many.helper.js.map +1 -1
  166. package/src/routes/duplicate-one/base-duplicate-one.service.d.ts +0 -25
  167. package/src/routes/duplicate-one/base-duplicate-one.service.js +3 -2
  168. package/src/routes/duplicate-one/base-duplicate-one.service.js.map +1 -1
  169. package/src/routes/duplicate-one/duplicate-one-controller.mixin.js +1 -2
  170. package/src/routes/duplicate-one/duplicate-one-controller.mixin.js.map +1 -1
  171. package/src/routes/duplicate-one/duplicate-one-gateway.mixin.js +1 -2
  172. package/src/routes/duplicate-one/duplicate-one-gateway.mixin.js.map +1 -1
  173. package/src/routes/duplicate-one/duplicate-one.helper.js +3 -4
  174. package/src/routes/duplicate-one/duplicate-one.helper.js.map +1 -1
  175. package/src/routes/get-many/base-get-many.service.d.ts +0 -25
  176. package/src/routes/get-many/base-get-many.service.js.map +1 -1
  177. package/src/routes/get-many/get-many-controller.mixin.js +1 -2
  178. package/src/routes/get-many/get-many-controller.mixin.js.map +1 -1
  179. package/src/routes/get-many/get-many-gateway.mixin.js +1 -2
  180. package/src/routes/get-many/get-many-gateway.mixin.js.map +1 -1
  181. package/src/routes/get-many/get-many.helper.js +3 -4
  182. package/src/routes/get-many/get-many.helper.js.map +1 -1
  183. package/src/routes/get-one/base-get-one.service.d.ts +0 -25
  184. package/src/routes/get-one/base-get-one.service.js.map +1 -1
  185. package/src/routes/get-one/get-one-controller.mixin.js +1 -2
  186. package/src/routes/get-one/get-one-controller.mixin.js.map +1 -1
  187. package/src/routes/get-one/get-one-gateway.mixin.js +1 -2
  188. package/src/routes/get-one/get-one-gateway.mixin.js.map +1 -1
  189. package/src/routes/get-one/get-one.helper.js +3 -4
  190. package/src/routes/get-one/get-one.helper.js.map +1 -1
  191. package/src/routes/replace-one/base-replace-one.service.d.ts +0 -25
  192. package/src/routes/replace-one/base-replace-one.service.js +3 -2
  193. package/src/routes/replace-one/base-replace-one.service.js.map +1 -1
  194. package/src/routes/replace-one/replace-one-controller.mixin.js +1 -2
  195. package/src/routes/replace-one/replace-one-controller.mixin.js.map +1 -1
  196. package/src/routes/replace-one/replace-one-gateway.mixin.js +1 -2
  197. package/src/routes/replace-one/replace-one-gateway.mixin.js.map +1 -1
  198. package/src/routes/replace-one/replace-one.helper.js +3 -4
  199. package/src/routes/replace-one/replace-one.helper.js.map +1 -1
  200. package/src/routes/update-many/base-update-many.service.d.ts +0 -25
  201. package/src/routes/update-many/base-update-many.service.js.map +1 -1
  202. package/src/routes/update-many/update-many-controller.mixin.js +1 -2
  203. package/src/routes/update-many/update-many-controller.mixin.js.map +1 -1
  204. package/src/routes/update-many/update-many-gateway.mixin.js +1 -2
  205. package/src/routes/update-many/update-many-gateway.mixin.js.map +1 -1
  206. package/src/routes/update-many/update-many.helper.js +3 -4
  207. package/src/routes/update-many/update-many.helper.js.map +1 -1
  208. package/src/routes/update-one/base-update-one.service.d.ts +0 -25
  209. package/src/routes/update-one/base-update-one.service.js.map +1 -1
  210. package/src/routes/update-one/update-one-controller.mixin.js +1 -2
  211. package/src/routes/update-one/update-one-controller.mixin.js.map +1 -1
  212. package/src/routes/update-one/update-one-gateway.mixin.js +1 -2
  213. package/src/routes/update-one/update-one-gateway.mixin.js.map +1 -1
  214. package/src/routes/update-one/update-one.helper.js +3 -4
  215. package/src/routes/update-one/update-one.helper.js.map +1 -1
  216. package/src/services/base/base.service.d.ts +3 -28
  217. package/src/services/base/base.service.js +26 -8
  218. package/src/services/base/base.service.js.map +1 -1
  219. package/src/services/dynamic-api-global-state/dynamic-api-global-state.service.d.ts +0 -25
  220. package/src/services/dynamic-api-global-state/dynamic-api-global-state.service.js +3 -0
  221. package/src/services/dynamic-api-global-state/dynamic-api-global-state.service.js.map +1 -1
  222. package/src/version.json +1 -1
  223. package/test/e2e.setup.d.ts +9 -34
  224. package/test/e2e.setup.js +8 -7
  225. package/test/e2e.setup.js.map +1 -1
  226. package/test/for-feature/base-entity.e2e-spec.js +316 -0
  227. package/test/for-feature/base-entity.e2e-spec.js.map +1 -0
  228. package/test/for-feature/http-broadcast.e2e-spec.js +187 -0
  229. package/test/for-feature/http-broadcast.e2e-spec.js.map +1 -0
  230. package/test/for-feature/soft-deletable-entity.e2e-spec.d.ts +1 -0
  231. package/test/for-feature/soft-deletable-entity.e2e-spec.js +335 -0
  232. package/test/for-feature/soft-deletable-entity.e2e-spec.js.map +1 -0
  233. package/test/for-feature/websockets.e2e-spec.d.ts +1 -0
  234. package/test/for-feature/websockets.e2e-spec.js +324 -0
  235. package/test/for-feature/websockets.e2e-spec.js.map +1 -0
  236. package/test/for-root/auth-api-basic.e2e-spec.d.ts +1 -0
  237. package/test/for-root/auth-api-basic.e2e-spec.js +338 -0
  238. package/test/for-root/auth-api-basic.e2e-spec.js.map +1 -0
  239. package/test/for-root/auth-api-broadcast.e2e-spec.d.ts +1 -0
  240. package/test/for-root/auth-api-broadcast.e2e-spec.js +82 -0
  241. package/test/for-root/auth-api-broadcast.e2e-spec.js.map +1 -0
  242. package/test/for-root/auth-api-login.e2e-spec.d.ts +1 -0
  243. package/test/for-root/auth-api-login.e2e-spec.js +103 -0
  244. package/test/for-root/auth-api-login.e2e-spec.js.map +1 -0
  245. package/test/for-root/auth-api-logout.e2e-spec.d.ts +1 -0
  246. package/test/for-root/auth-api-logout.e2e-spec.js +74 -0
  247. package/test/for-root/auth-api-logout.e2e-spec.js.map +1 -0
  248. package/test/for-root/auth-api-refresh-token-cookie.e2e-spec.d.ts +1 -0
  249. package/test/for-root/auth-api-refresh-token-cookie.e2e-spec.js +110 -0
  250. package/test/for-root/auth-api-refresh-token-cookie.e2e-spec.js.map +1 -0
  251. package/test/for-root/auth-api-refresh-token.e2e-spec.d.ts +1 -0
  252. package/test/for-root/auth-api-refresh-token.e2e-spec.js +153 -0
  253. package/test/for-root/auth-api-refresh-token.e2e-spec.js.map +1 -0
  254. package/test/for-root/auth-api-register.e2e-spec.d.ts +1 -0
  255. package/test/for-root/auth-api-register.e2e-spec.js +116 -0
  256. package/test/for-root/auth-api-register.e2e-spec.js.map +1 -0
  257. package/test/for-root/auth-api-reset-password.e2e-spec.d.ts +1 -0
  258. package/test/for-root/auth-api-reset-password.e2e-spec.js +168 -0
  259. package/test/for-root/auth-api-reset-password.e2e-spec.js.map +1 -0
  260. package/test/for-root/initialization.e2e-spec.d.ts +1 -0
  261. package/test/for-root/initialization.e2e-spec.js +84 -0
  262. package/test/for-root/initialization.e2e-spec.js.map +1 -0
  263. package/test/for-root/websockets-auth-basic.e2e-spec.d.ts +1 -0
  264. package/test/for-root/websockets-auth-basic.e2e-spec.js +313 -0
  265. package/test/for-root/websockets-auth-basic.e2e-spec.js.map +1 -0
  266. package/test/for-root/websockets-auth-broadcast.e2e-spec.d.ts +1 -0
  267. package/test/for-root/websockets-auth-broadcast.e2e-spec.js +86 -0
  268. package/test/for-root/websockets-auth-broadcast.e2e-spec.js.map +1 -0
  269. package/test/for-root/websockets-auth-login.e2e-spec.d.ts +1 -0
  270. package/test/for-root/websockets-auth-login.e2e-spec.js +107 -0
  271. package/test/for-root/websockets-auth-login.e2e-spec.js.map +1 -0
  272. package/test/for-root/websockets-auth-refresh-token.e2e-spec.d.ts +1 -0
  273. package/test/for-root/websockets-auth-refresh-token.e2e-spec.js +104 -0
  274. package/test/for-root/websockets-auth-refresh-token.e2e-spec.js.map +1 -0
  275. package/test/for-root/websockets-auth-register.e2e-spec.d.ts +1 -0
  276. package/test/for-root/websockets-auth-register.e2e-spec.js +131 -0
  277. package/test/for-root/websockets-auth-register.e2e-spec.js.map +1 -0
  278. package/test/for-root/websockets-auth-reset-password.e2e-spec.d.ts +1 -0
  279. package/test/for-root/websockets-auth-reset-password.e2e-spec.js +164 -0
  280. package/test/for-root/websockets-auth-reset-password.e2e-spec.js.map +1 -0
  281. package/test/shared/entities/basic-user.factory.d.ts +12 -0
  282. package/test/shared/entities/basic-user.factory.js +31 -0
  283. package/test/shared/entities/basic-user.factory.js.map +1 -0
  284. package/test/shared/entities/broadcast-user.factory.d.ts +13 -0
  285. package/test/shared/entities/broadcast-user.factory.js +35 -0
  286. package/test/shared/entities/broadcast-user.factory.js.map +1 -0
  287. package/test/shared/entities/index.d.ts +7 -0
  288. package/test/shared/entities/index.js +24 -0
  289. package/test/shared/entities/index.js.map +1 -0
  290. package/test/shared/entities/login-user.factory.d.ts +14 -0
  291. package/test/shared/entities/login-user.factory.js +39 -0
  292. package/test/shared/entities/login-user.factory.js.map +1 -0
  293. package/test/shared/entities/refresh-token-user.factory.d.ts +13 -0
  294. package/test/shared/entities/refresh-token-user.factory.js +35 -0
  295. package/test/shared/entities/refresh-token-user.factory.js.map +1 -0
  296. package/test/shared/entities/register-user.factory.d.ts +14 -0
  297. package/test/shared/entities/register-user.factory.js +39 -0
  298. package/test/shared/entities/register-user.factory.js.map +1 -0
  299. package/test/shared/entities/reset-password-user.factory.d.ts +14 -0
  300. package/test/shared/entities/reset-password-user.factory.js +39 -0
  301. package/test/shared/entities/reset-password-user.factory.js.map +1 -0
  302. package/test/shared/entities/validated-user.factory.d.ts +12 -0
  303. package/test/shared/entities/validated-user.factory.js +40 -0
  304. package/test/shared/entities/validated-user.factory.js.map +1 -0
  305. package/test/shared/fixtures/index.d.ts +2 -0
  306. package/test/shared/fixtures/index.js +19 -0
  307. package/test/shared/fixtures/index.js.map +1 -0
  308. package/test/shared/fixtures/login.fixtures.d.ts +16 -0
  309. package/test/shared/fixtures/login.fixtures.js +20 -0
  310. package/test/shared/fixtures/login.fixtures.js.map +1 -0
  311. package/test/shared/fixtures/register.fixtures.d.ts +10 -0
  312. package/test/shared/fixtures/register.fixtures.js +14 -0
  313. package/test/shared/fixtures/register.fixtures.js.map +1 -0
  314. package/test/shared/index.d.ts +4 -0
  315. package/test/shared/index.js +24 -0
  316. package/test/shared/index.js.map +1 -0
  317. package/test/shared/init-app.d.ts +3 -0
  318. package/test/shared/init-app.js +19 -0
  319. package/test/shared/init-app.js.map +1 -0
  320. package/test/shared/init-module.d.ts +4 -0
  321. package/test/shared/init-module.js +16 -0
  322. package/test/shared/init-module.js.map +1 -0
  323. package/test/utils.d.ts +0 -25
  324. package/tsconfig.tsbuildinfo +1 -1
  325. package/test/dynamic-api-for-feature.e2e-spec.js +0 -1100
  326. package/test/dynamic-api-for-feature.e2e-spec.js.map +0 -1
  327. package/test/dynamic-api-for-root.e2e-spec.js +0 -1573
  328. package/test/dynamic-api-for-root.e2e-spec.js.map +0 -1
  329. /package/test/{dynamic-api-for-feature.e2e-spec.d.ts → for-feature/base-entity.e2e-spec.d.ts} +0 -0
  330. /package/test/{dynamic-api-for-root.e2e-spec.d.ts → for-feature/http-broadcast.e2e-spec.d.ts} +0 -0
@@ -0,0 +1,74 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const mongoose_1 = require("mongoose");
4
+ const src_1 = require("../../src");
5
+ const e2e_setup_1 = require("../e2e.setup");
6
+ require("dotenv/config");
7
+ const shared_1 = require("../shared");
8
+ describe('DynamicApiModule forRoot - POST /auth/logout (e2e)', () => {
9
+ beforeEach(() => {
10
+ src_1.DynamicApiModule.state['resetState']();
11
+ });
12
+ afterEach(async () => {
13
+ await (0, e2e_setup_1.closeTestingApp)(mongoose_1.default.connections);
14
+ });
15
+ describe('Bearer mode (useCookie: false) with refreshTokenField', () => {
16
+ let refreshToken;
17
+ beforeEach(async () => {
18
+ const User = (0, shared_1.createUserWithRefreshTokenEntity)();
19
+ await (0, shared_1.initModule)({
20
+ useAuth: {
21
+ userEntity: User,
22
+ jwt: { secret: 'secret', expiresIn: '15m', refreshTokenExpiresIn: '7d' },
23
+ refreshToken: { refreshTokenField: 'refreshTokenHash' },
24
+ },
25
+ });
26
+ await e2e_setup_1.server.post('/auth/register', { email: 'logout@test.co', password: 'test' });
27
+ const { body } = await e2e_setup_1.server.post('/auth/login', { email: 'logout@test.co', password: 'test' });
28
+ refreshToken = body.refreshToken;
29
+ });
30
+ it('should return 204 on logout', async () => {
31
+ const { status } = await e2e_setup_1.server.post('/auth/logout', {}, {
32
+ headers: { Authorization: `Bearer ${refreshToken}` },
33
+ });
34
+ expect(status).toBe(204);
35
+ });
36
+ it('should invalidate the refresh token after logout', async () => {
37
+ const headers = { Authorization: `Bearer ${refreshToken}` };
38
+ await e2e_setup_1.server.post('/auth/logout', {}, { headers });
39
+ const { status } = await e2e_setup_1.server.post('/auth/refresh-token', {}, { headers });
40
+ expect(status).toBe(401);
41
+ });
42
+ it('should return 401 on logout without refresh token', async () => {
43
+ const { status } = await e2e_setup_1.server.post('/auth/logout', {});
44
+ expect(status).toBe(401);
45
+ });
46
+ });
47
+ describe('Bearer mode without refreshTokenField (warning only)', () => {
48
+ let refreshToken;
49
+ beforeEach(async () => {
50
+ await (0, shared_1.initModule)({
51
+ useAuth: {
52
+ userEntity: (0, shared_1.createBasicUserEntity)(),
53
+ jwt: { secret: 'secret', expiresIn: '15m', refreshTokenExpiresIn: '7d' },
54
+ },
55
+ });
56
+ await e2e_setup_1.server.post('/auth/register', { email: 'logout-nowarn@test.co', password: 'test' });
57
+ const { body } = await e2e_setup_1.server.post('/auth/login', { email: 'logout-nowarn@test.co', password: 'test' });
58
+ refreshToken = body.refreshToken;
59
+ });
60
+ it('should return 204 even without refreshTokenField (logs warning)', async () => {
61
+ const { status } = await e2e_setup_1.server.post('/auth/logout', {}, {
62
+ headers: { Authorization: `Bearer ${refreshToken}` },
63
+ });
64
+ expect(status).toBe(204);
65
+ });
66
+ it('should still allow refresh after logout (no server-side revocation)', async () => {
67
+ const headers = { Authorization: `Bearer ${refreshToken}` };
68
+ await e2e_setup_1.server.post('/auth/logout', {}, { headers });
69
+ const { status } = await e2e_setup_1.server.post('/auth/refresh-token', {}, { headers });
70
+ expect(status).toBe(200);
71
+ });
72
+ });
73
+ });
74
+ //# sourceMappingURL=auth-api-logout.e2e-spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-api-logout.e2e-spec.js","sourceRoot":"","sources":["../../../libs/dynamic-api/test/for-root/auth-api-logout.e2e-spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ import 'dotenv/config';
@@ -0,0 +1,110 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const supertest = require("supertest");
4
+ const mongoose_1 = require("mongoose");
5
+ const src_1 = require("../../src");
6
+ const e2e_setup_1 = require("../e2e.setup");
7
+ require("dotenv/config");
8
+ const shared_1 = require("../shared");
9
+ describe('DynamicApiModule forRoot - Cookie mode (useCookie: true) (e2e)', () => {
10
+ let agent;
11
+ let accessToken;
12
+ beforeEach(() => {
13
+ src_1.DynamicApiModule.state['resetState']();
14
+ });
15
+ afterEach(async () => {
16
+ await (0, e2e_setup_1.closeTestingApp)(mongoose_1.default.connections);
17
+ });
18
+ beforeEach(async () => {
19
+ const User = (0, shared_1.createUserWithRefreshTokenEntity)();
20
+ await (0, shared_1.initModule)({
21
+ useAuth: {
22
+ userEntity: User,
23
+ jwt: {
24
+ secret: 'secret',
25
+ expiresIn: '15m',
26
+ refreshTokenExpiresIn: '7d',
27
+ },
28
+ refreshToken: {
29
+ useCookie: true,
30
+ refreshTokenField: 'refreshTokenHash',
31
+ },
32
+ },
33
+ });
34
+ agent = supertest.agent(global.app.getHttpServer());
35
+ await agent
36
+ .post('/auth/register')
37
+ .send({ email: 'cookie@test.co', password: 'test' })
38
+ .set('Content-Type', 'application/json');
39
+ const loginRes = await agent
40
+ .post('/auth/login')
41
+ .send({ email: 'cookie@test.co', password: 'test' })
42
+ .set('Content-Type', 'application/json');
43
+ accessToken = loginRes.body.accessToken;
44
+ });
45
+ it('should set httpOnly refreshToken cookie on login and not expose it in body', async () => {
46
+ const res = await agent
47
+ .post('/auth/login')
48
+ .send({ email: 'cookie@test.co', password: 'test' })
49
+ .set('Content-Type', 'application/json');
50
+ expect(res.status).toBe(200);
51
+ expect(res.body).toEqual({ accessToken: expect.any(String) });
52
+ expect(res.body.refreshToken).toBeUndefined();
53
+ const setCookieHeader = res.headers['set-cookie'];
54
+ expect(setCookieHeader).toBeDefined();
55
+ const refreshCookie = (Array.isArray(setCookieHeader) ? setCookieHeader : [setCookieHeader])
56
+ .find((c) => c.startsWith('refreshToken='));
57
+ expect(refreshCookie).toBeDefined();
58
+ expect(refreshCookie).toContain('HttpOnly');
59
+ });
60
+ it('should refresh using cookie (no Bearer needed)', async () => {
61
+ const res = await agent
62
+ .post('/auth/refresh-token')
63
+ .set('Content-Type', 'application/json');
64
+ expect(res.status).toBe(200);
65
+ expect(res.body).toEqual({ accessToken: expect.any(String) });
66
+ expect(res.body.refreshToken).toBeUndefined();
67
+ const setCookieHeader = res.headers['set-cookie'];
68
+ const refreshCookie = (Array.isArray(setCookieHeader) ? setCookieHeader : [setCookieHeader])
69
+ .find((c) => c.startsWith('refreshToken='));
70
+ expect(refreshCookie).toBeDefined();
71
+ });
72
+ it('should return 401 on refresh without cookie', async () => {
73
+ const freshAgent = supertest.agent(global.app.getHttpServer());
74
+ const res = await freshAgent
75
+ .post('/auth/refresh-token')
76
+ .set('Content-Type', 'application/json');
77
+ expect(res.status).toBe(401);
78
+ });
79
+ it('should reject Bearer token on refresh-token endpoint when useCookie is true', async () => {
80
+ const freshAgent = supertest.agent(global.app.getHttpServer());
81
+ const { body: loginBody } = await agent
82
+ .post('/auth/login')
83
+ .send({ email: 'cookie@test.co', password: 'test' })
84
+ .set('Content-Type', 'application/json');
85
+ const res = await freshAgent
86
+ .post('/auth/refresh-token')
87
+ .set('Authorization', `Bearer ${loginBody.accessToken}`)
88
+ .set('Content-Type', 'application/json');
89
+ expect(res.status).toBe(401);
90
+ });
91
+ it('should clear cookie and return 204 on logout', async () => {
92
+ const res = await agent
93
+ .post('/auth/logout')
94
+ .set('Content-Type', 'application/json');
95
+ expect(res.status).toBe(204);
96
+ const setCookieHeader = res.headers['set-cookie'];
97
+ const refreshCookie = (Array.isArray(setCookieHeader) ? setCookieHeader : [setCookieHeader])
98
+ .find((c) => c.startsWith('refreshToken='));
99
+ expect(refreshCookie).toBeDefined();
100
+ expect(refreshCookie).toContain('Expires=Thu, 01 Jan 1970');
101
+ });
102
+ it('should reject refresh after logout (cookie cleared + DB hash cleared)', async () => {
103
+ await agent.post('/auth/logout').set('Content-Type', 'application/json');
104
+ const res = await agent
105
+ .post('/auth/refresh-token')
106
+ .set('Content-Type', 'application/json');
107
+ expect(res.status).toBe(401);
108
+ });
109
+ });
110
+ //# sourceMappingURL=auth-api-refresh-token-cookie.e2e-spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-api-refresh-token-cookie.e2e-spec.js","sourceRoot":"","sources":["../../../libs/dynamic-api/test/for-root/auth-api-refresh-token-cookie.e2e-spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ import 'dotenv/config';
@@ -0,0 +1,153 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const jwt_1 = require("@nestjs/jwt");
4
+ const mongoose_1 = require("mongoose");
5
+ const src_1 = require("../../src");
6
+ const e2e_setup_1 = require("../e2e.setup");
7
+ require("dotenv/config");
8
+ const utils_1 = require("../utils");
9
+ const shared_1 = require("../shared");
10
+ describe('DynamicApiModule forRoot - POST /auth/refresh-token (e2e)', () => {
11
+ const uri = process.env.MONGO_DB_URL;
12
+ beforeEach(() => {
13
+ src_1.DynamicApiModule.state['resetState']();
14
+ });
15
+ afterEach(async () => {
16
+ await (0, e2e_setup_1.closeTestingApp)(mongoose_1.default.connections);
17
+ });
18
+ describe('with refreshTokenField configured (full rotation + DB validation)', () => {
19
+ let app;
20
+ let jwtService;
21
+ let accessToken;
22
+ let refreshToken;
23
+ beforeEach(async () => {
24
+ const User = (0, shared_1.createUserWithRefreshTokenEntity)();
25
+ app = await (0, shared_1.initModule)({
26
+ useAuth: {
27
+ userEntity: User,
28
+ jwt: {
29
+ secret: 'test-secret',
30
+ expiresIn: '2s',
31
+ refreshTokenExpiresIn: '20s',
32
+ },
33
+ refreshToken: {
34
+ refreshTokenField: 'refreshTokenHash',
35
+ },
36
+ },
37
+ });
38
+ jwtService = app.get(jwt_1.JwtService);
39
+ await e2e_setup_1.server.post('/auth/register', { email: 'rotate@test.co', password: 'test' });
40
+ const { body } = await e2e_setup_1.server.post('/auth/login', { email: 'rotate@test.co', password: 'test' });
41
+ accessToken = body.accessToken;
42
+ refreshToken = body.refreshToken;
43
+ });
44
+ it('should return { accessToken, refreshToken } with longer expiration', async () => {
45
+ const headers = { Authorization: `Bearer ${refreshToken}` };
46
+ const { body, status } = await e2e_setup_1.server.post('/auth/refresh-token', {}, { headers });
47
+ expect(status).toBe(200);
48
+ expect(body).toEqual({ accessToken: expect.any(String), refreshToken: expect.any(String) });
49
+ const decoded = jwtService.decode(body.refreshToken);
50
+ const accessDecoded = jwtService.decode(accessToken);
51
+ expect(decoded.exp - decoded.iat).toBeGreaterThan(accessDecoded.exp - accessDecoded.iat);
52
+ });
53
+ it('should rotate: new refreshToken is different from old one', async () => {
54
+ const headers = { Authorization: `Bearer ${refreshToken}` };
55
+ const { body } = await e2e_setup_1.server.post('/auth/refresh-token', {}, { headers });
56
+ expect(body.refreshToken).not.toBe(refreshToken);
57
+ });
58
+ it('should reject old refresh token after rotation (DB validation)', async () => {
59
+ const headers = { Authorization: `Bearer ${refreshToken}` };
60
+ await e2e_setup_1.server.post('/auth/refresh-token', {}, { headers });
61
+ const { status } = await e2e_setup_1.server.post('/auth/refresh-token', {}, { headers });
62
+ expect(status).toBe(401);
63
+ });
64
+ it('should reject refresh token if no stored hash (after logout)', async () => {
65
+ const refreshHeaders = { Authorization: `Bearer ${refreshToken}` };
66
+ await e2e_setup_1.server.post('/auth/logout', {}, { headers: refreshHeaders });
67
+ const { status } = await e2e_setup_1.server.post('/auth/refresh-token', {}, { headers: refreshHeaders });
68
+ expect(status).toBe(401);
69
+ });
70
+ it('should still issue a valid new access token after the original access token has expired', async () => {
71
+ const headers = { Authorization: `Bearer ${refreshToken}` };
72
+ await (0, utils_1.wait)(3000);
73
+ const { status: expiredStatus } = await e2e_setup_1.server.get('/auth/account', {
74
+ headers: { Authorization: `Bearer ${accessToken}` },
75
+ });
76
+ expect(expiredStatus).toBe(401);
77
+ const { body, status } = await e2e_setup_1.server.post('/auth/refresh-token', {}, { headers });
78
+ expect(status).toBe(200);
79
+ expect(body.accessToken).toBeDefined();
80
+ }, 10000);
81
+ });
82
+ describe('without refreshTokenField (no DB validation, no rotation enforcement)', () => {
83
+ let app;
84
+ let jwtService;
85
+ let accessToken;
86
+ let refreshToken;
87
+ beforeEach(async () => {
88
+ app = await (0, shared_1.initModule)({
89
+ useAuth: {
90
+ userEntity: (0, shared_1.createBasicUserEntity)(),
91
+ jwt: {
92
+ secret: 'test-secret',
93
+ expiresIn: '2s',
94
+ refreshTokenExpiresIn: '10s',
95
+ },
96
+ },
97
+ });
98
+ jwtService = app.get(jwt_1.JwtService);
99
+ await e2e_setup_1.server.post('/auth/register', { email: 'fallback@test.co', password: 'test' });
100
+ const { body } = await e2e_setup_1.server.post('/auth/login', { email: 'fallback@test.co', password: 'test' });
101
+ accessToken = body.accessToken;
102
+ refreshToken = body.refreshToken;
103
+ });
104
+ it('should return { accessToken, refreshToken } with longer expiration', async () => {
105
+ const headers = { Authorization: `Bearer ${refreshToken}` };
106
+ const { body, status } = await e2e_setup_1.server.post('/auth/refresh-token', {}, { headers });
107
+ expect(status).toBe(200);
108
+ expect(body).toEqual({ accessToken: expect.any(String), refreshToken: expect.any(String) });
109
+ const decoded = jwtService.decode(body.refreshToken);
110
+ const accessDecoded = jwtService.decode(accessToken);
111
+ expect(decoded.exp - decoded.iat).toBeGreaterThan(accessDecoded.exp - accessDecoded.iat);
112
+ });
113
+ it('should allow reuse of old refresh token (no server-side invalidation)', async () => {
114
+ const headers = { Authorization: `Bearer ${refreshToken}` };
115
+ await e2e_setup_1.server.post('/auth/refresh-token', {}, { headers });
116
+ const { status } = await e2e_setup_1.server.post('/auth/refresh-token', {}, { headers });
117
+ expect(status).toBe(200);
118
+ });
119
+ });
120
+ describe('with custom refreshSecret', () => {
121
+ let refreshToken;
122
+ beforeEach(async () => {
123
+ await (0, shared_1.initModule)({
124
+ useAuth: {
125
+ userEntity: (0, shared_1.createBasicUserEntity)(),
126
+ jwt: {
127
+ secret: 'access-secret',
128
+ expiresIn: '15m',
129
+ refreshTokenExpiresIn: '7d',
130
+ refreshSecret: 'refresh-secret',
131
+ },
132
+ },
133
+ });
134
+ await e2e_setup_1.server.post('/auth/register', { email: 'custom@test.co', password: 'test' });
135
+ const { body } = await e2e_setup_1.server.post('/auth/login', { email: 'custom@test.co', password: 'test' });
136
+ refreshToken = body.refreshToken;
137
+ });
138
+ it('should accept refresh token signed with refreshSecret', async () => {
139
+ const headers = { Authorization: `Bearer ${refreshToken}` };
140
+ const { body, status } = await e2e_setup_1.server.post('/auth/refresh-token', {}, { headers });
141
+ expect(status).toBe(200);
142
+ expect(body).toEqual({ accessToken: expect.any(String), refreshToken: expect.any(String) });
143
+ });
144
+ it('should reject access token as refresh token (different secret)', async () => {
145
+ await e2e_setup_1.server.post('/auth/register', { email: 'custom2@test.co', password: 'test' });
146
+ const { body: loginBody } = await e2e_setup_1.server.post('/auth/login', { email: 'custom2@test.co', password: 'test' });
147
+ const headers = { Authorization: `Bearer ${loginBody.accessToken}` };
148
+ const { status } = await e2e_setup_1.server.post('/auth/refresh-token', {}, { headers });
149
+ expect(status).toBe(401);
150
+ });
151
+ });
152
+ });
153
+ //# sourceMappingURL=auth-api-refresh-token.e2e-spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-api-refresh-token.e2e-spec.js","sourceRoot":"","sources":["../../../libs/dynamic-api/test/for-root/auth-api-refresh-token.e2e-spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ import 'dotenv/config';
@@ -0,0 +1,116 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const mongoose_1 = require("mongoose");
4
+ const src_1 = require("../../src");
5
+ const e2e_setup_1 = require("../e2e.setup");
6
+ require("dotenv/config");
7
+ const utils_1 = require("../utils");
8
+ const shared_1 = require("../shared");
9
+ describe('DynamicApiModule forRoot - POST /auth/register with register options (e2e)', () => {
10
+ const User = (0, shared_1.createRegisterUserEntity)();
11
+ const admin = shared_1.REGISTER_ADMIN;
12
+ const user = shared_1.REGISTER_USER;
13
+ beforeEach(() => {
14
+ src_1.DynamicApiModule.state['resetState']();
15
+ });
16
+ afterEach(async () => {
17
+ await (0, e2e_setup_1.closeTestingApp)(mongoose_1.default.connections);
18
+ });
19
+ beforeEach(async () => {
20
+ const bcryptService = new src_1.BcryptService();
21
+ const fixtures = async (_) => {
22
+ const model = await (0, utils_1.getModelFromEntity)(User);
23
+ await model.insertMany([
24
+ { ...admin, password: await bcryptService.hashPassword(admin.password) },
25
+ { ...user, password: await bcryptService.hashPassword(user.password) },
26
+ ]);
27
+ };
28
+ await (0, shared_1.initModule)({
29
+ useAuth: {
30
+ userEntity: User,
31
+ register: {
32
+ protected: true,
33
+ abilityPredicate: (user) => user.isVerified,
34
+ additionalFields: ['role'],
35
+ callback: async (user, { updateOneDocument }) => {
36
+ if (user.role !== 'admin') {
37
+ return;
38
+ }
39
+ await updateOneDocument(User, { _id: user.id }, { $set: { isVerified: true } });
40
+ },
41
+ },
42
+ login: {
43
+ additionalFields: ['role', 'isVerified'],
44
+ },
45
+ },
46
+ }, fixtures);
47
+ });
48
+ describe('protected', () => {
49
+ it('should throw an unauthorized exception if user is not logged in and protected is true', async () => {
50
+ const { body, status } = await e2e_setup_1.server.post('/auth/register', { email: 'unit@test.co', password: 'test' });
51
+ expect(status).toBe(401);
52
+ expect(body).toEqual({
53
+ message: 'Unauthorized',
54
+ statusCode: 401,
55
+ });
56
+ });
57
+ });
58
+ describe('abilityPredicate', () => {
59
+ it('should not create a new user if user is not verified', async () => {
60
+ const { email, password } = user;
61
+ const { body: { accessToken } } = await e2e_setup_1.server.post('/auth/login', { email, password });
62
+ const { body, status } = await e2e_setup_1.server.post('/auth/register', { email: 'unit@test.co', password: 'test' }, {
63
+ headers: { Authorization: `Bearer ${accessToken}` },
64
+ });
65
+ expect(status).toBe(403);
66
+ expect(body).toEqual({
67
+ error: 'Forbidden',
68
+ message: 'Access denied',
69
+ statusCode: 403,
70
+ });
71
+ });
72
+ it('should create a new user and return access token if user is verified', async () => {
73
+ const { email, password } = admin;
74
+ const { body: { accessToken } } = await e2e_setup_1.server.post('/auth/login', { email, password });
75
+ const { body, status } = await e2e_setup_1.server.post('/auth/register', { email: 'unit@test.co', password: 'test' }, {
76
+ headers: { Authorization: `Bearer ${accessToken}` },
77
+ });
78
+ expect(status).toBe(201);
79
+ expect(body).toEqual({ accessToken: expect.any(String), refreshToken: expect.any(String) });
80
+ });
81
+ });
82
+ describe('additionalFields', () => {
83
+ it('should allow to register a new user with additional fields', async () => {
84
+ const { email, password } = admin;
85
+ const { body: { accessToken } } = await e2e_setup_1.server.post('/auth/login', { email, password });
86
+ const { body, status } = await e2e_setup_1.server.post('/auth/register', { email: 'client@test.co', password: 'client', role: 'client' }, {
87
+ headers: { Authorization: `Bearer ${accessToken}` },
88
+ });
89
+ expect(status).toBe(201);
90
+ expect(body).toEqual({ accessToken: expect.any(String), refreshToken: expect.any(String) });
91
+ });
92
+ });
93
+ describe('callback', () => {
94
+ it('should not set isVerified to true if role is not admin', async () => {
95
+ const { email, password } = admin;
96
+ const { body: loginBody } = await e2e_setup_1.server.post('/auth/login', { email, password });
97
+ const { body: { accessToken } } = await e2e_setup_1.server.post('/auth/register', { email: 'client@test.co', password: 'client', role: 'client' }, {
98
+ headers: { Authorization: `Bearer ${loginBody.accessToken}` },
99
+ });
100
+ const { body, status } = await e2e_setup_1.server.get('/auth/account', { headers: { Authorization: `Bearer ${accessToken}` } });
101
+ expect(status).toBe(200);
102
+ expect(body).toHaveProperty('isVerified', false);
103
+ });
104
+ it('should set isVerified to true if role is admin', async () => {
105
+ const { email, password } = admin;
106
+ const { body: loginBody } = await e2e_setup_1.server.post('/auth/login', { email, password });
107
+ const { body: { accessToken } } = await e2e_setup_1.server.post('/auth/register', { email: 'admin2@test.co', password: 'admin2', role: 'admin' }, {
108
+ headers: { Authorization: `Bearer ${loginBody.accessToken}` },
109
+ });
110
+ const { body, status } = await e2e_setup_1.server.get('/auth/account', { headers: { Authorization: `Bearer ${accessToken}` } });
111
+ expect(status).toBe(200);
112
+ expect(body).toHaveProperty('isVerified', true);
113
+ });
114
+ });
115
+ });
116
+ //# sourceMappingURL=auth-api-register.e2e-spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-api-register.e2e-spec.js","sourceRoot":"","sources":["../../../libs/dynamic-api/test/for-root/auth-api-register.e2e-spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ import 'dotenv/config';