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,338 @@
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 - Authentication API Basic (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('useAuth when only userEntity is provided', () => {
19
+ const UserEntity = (0, shared_1.createBasicUserEntity)();
20
+ let app;
21
+ beforeEach(async () => {
22
+ app = await (0, shared_1.initModule)({ useAuth: { userEntity: UserEntity } });
23
+ });
24
+ it('should initialize dynamic api module state and authentication API with default options', async () => {
25
+ expect(app).toBeDefined();
26
+ expect(src_1.DynamicApiModule.state.get()).toStrictEqual({
27
+ uri,
28
+ initialized: true,
29
+ isGlobalCacheEnabled: true,
30
+ connectionName: 'dynamic-api-connection',
31
+ cacheExcludedPaths: [],
32
+ credentials: {
33
+ loginField: 'email',
34
+ passwordField: 'password',
35
+ },
36
+ isAuthEnabled: true,
37
+ jwtExpirationTime: '15m',
38
+ jwtRefreshTokenExpiresIn: '7d',
39
+ jwtRefreshSecret: undefined,
40
+ jwtRefreshUseCookie: false,
41
+ jwtSecret: 'dynamic-api-jwt-secret',
42
+ routesConfig: {
43
+ defaults: [
44
+ 'GetMany',
45
+ 'GetOne',
46
+ 'CreateMany',
47
+ 'CreateOne',
48
+ 'UpdateMany',
49
+ 'UpdateOne',
50
+ 'ReplaceOne',
51
+ 'DuplicateMany',
52
+ 'DuplicateOne',
53
+ 'DeleteMany',
54
+ 'DeleteOne',
55
+ ],
56
+ excluded: [],
57
+ },
58
+ gatewayOptions: undefined,
59
+ });
60
+ });
61
+ describe('POST /auth/register', () => {
62
+ it('should throw a bad request exception if email is missing', async () => {
63
+ const { body, status } = await e2e_setup_1.server.post('/auth/register', { username: 'unit-test', password: 'test-2' });
64
+ expect(status).toBe(400);
65
+ expect(body).toEqual({
66
+ error: 'Bad Request',
67
+ message: ['email property is required'],
68
+ statusCode: 400,
69
+ });
70
+ });
71
+ it('should throw a bad request exception if password is missing', async () => {
72
+ const { body, status } = await e2e_setup_1.server.post('/auth/register', { email: 'unit@test.co', pass: 'test-2' });
73
+ expect(status).toBe(400);
74
+ expect(body).toEqual({
75
+ error: 'Bad Request',
76
+ message: ['password property is required'],
77
+ statusCode: 400,
78
+ });
79
+ });
80
+ it('should create a new user and return access token and refresh token', async () => {
81
+ const { body, status } = await e2e_setup_1.server.post('/auth/register', { email: 'unit@test.co', password: 'test' });
82
+ expect(status).toBe(201);
83
+ expect(body).toEqual({ accessToken: expect.any(String), refreshToken: expect.any(String) });
84
+ });
85
+ });
86
+ describe('POST /auth/login', () => {
87
+ it('should throw an unauthorized exception if email is missing', async () => {
88
+ const { body, status } = await e2e_setup_1.server.post('/auth/login', { pass: 'test-2' });
89
+ expect(status).toBe(401);
90
+ expect(body).toEqual({
91
+ message: 'Unauthorized',
92
+ statusCode: 401,
93
+ });
94
+ });
95
+ it('should throw an unauthorized exception if password is missing', async () => {
96
+ const { body, status } = await e2e_setup_1.server.post('/auth/login', { email: 'unit@test.co' });
97
+ expect(status).toBe(401);
98
+ expect(body).toEqual({
99
+ message: 'Unauthorized',
100
+ statusCode: 401,
101
+ });
102
+ });
103
+ it('should return access token and refresh token', async () => {
104
+ await e2e_setup_1.server.post('/auth/register', { email: 'unit@test.co', password: 'test' });
105
+ const { body, status } = await e2e_setup_1.server.post('/auth/login', { email: 'unit@test.co', password: 'test' });
106
+ expect(status).toBe(200);
107
+ expect(body).toEqual({ accessToken: expect.any(String), refreshToken: expect.any(String) });
108
+ });
109
+ });
110
+ describe('GET /auth/account', () => {
111
+ it('should throw an unauthorized exception if access token is missing', async () => {
112
+ const { body, status } = await e2e_setup_1.server.get('/auth/account');
113
+ expect(status).toBe(401);
114
+ expect(body).toEqual({
115
+ message: 'Unauthorized',
116
+ statusCode: 401,
117
+ });
118
+ });
119
+ it('should return user account', async () => {
120
+ await e2e_setup_1.server.post('/auth/register', { email: 'unit@test.co', password: 'test' });
121
+ const { body: { accessToken } } = await e2e_setup_1.server.post('/auth/login', { email: 'unit@test.co', password: 'test' });
122
+ const headers = { Authorization: `Bearer ${accessToken}` };
123
+ const { body: account, status: accountStatus } = await e2e_setup_1.server.get('/auth/account', { headers });
124
+ expect(accountStatus).toBe(200);
125
+ expect(account).toEqual({ id: expect.any(String), email: 'unit@test.co' });
126
+ });
127
+ });
128
+ describe('POST /auth/refresh-token', () => {
129
+ it('should throw an unauthorized exception if refresh token is missing', async () => {
130
+ const { body, status } = await e2e_setup_1.server.post('/auth/refresh-token', {});
131
+ expect(status).toBe(401);
132
+ expect(body).toEqual({ message: 'Unauthorized', statusCode: 401 });
133
+ });
134
+ it('should return a new access token and refresh token using the refresh token as Bearer', async () => {
135
+ await e2e_setup_1.server.post('/auth/register', { email: 'unit@test.co', password: 'test' });
136
+ const { body: { refreshToken } } = await e2e_setup_1.server.post('/auth/login', { email: 'unit@test.co', password: 'test' });
137
+ const headers = { Authorization: `Bearer ${refreshToken}` };
138
+ const { body, status } = await e2e_setup_1.server.post('/auth/refresh-token', {}, { headers });
139
+ expect(status).toBe(200);
140
+ expect(body).toEqual({ accessToken: expect.any(String), refreshToken: expect.any(String) });
141
+ });
142
+ it('should reject the old refresh token after rotation', async () => {
143
+ await e2e_setup_1.server.post('/auth/register', { email: 'unit@test.co', password: 'test' });
144
+ const { body: loginBody } = await e2e_setup_1.server.post('/auth/login', { email: 'unit@test.co', password: 'test' });
145
+ const oldRefreshToken = loginBody.refreshToken;
146
+ const headers = { Authorization: `Bearer ${oldRefreshToken}` };
147
+ await e2e_setup_1.server.post('/auth/refresh-token', {}, { headers });
148
+ const { status } = await e2e_setup_1.server.post('/auth/refresh-token', {}, { headers });
149
+ expect(status).toBe(200);
150
+ });
151
+ });
152
+ describe('POST /auth/logout', () => {
153
+ it('should logout and return 204', async () => {
154
+ await e2e_setup_1.server.post('/auth/register', { email: 'unit@test.co', password: 'test' });
155
+ const { body: loginBody } = await e2e_setup_1.server.post('/auth/login', { email: 'unit@test.co', password: 'test' });
156
+ const headers = { Authorization: `Bearer ${loginBody.refreshToken}` };
157
+ const { status } = await e2e_setup_1.server.post('/auth/logout', {}, { headers });
158
+ expect(status).toBe(204);
159
+ });
160
+ });
161
+ it('should throw a Service Unavailable exception when requesting reset password endpoint if reset password options are not configured', async () => {
162
+ const { body, status } = await e2e_setup_1.server.post('/auth/reset-password', { email: 'toto@test.co' });
163
+ expect(status).toBe(503);
164
+ expect(body).toEqual({
165
+ error: 'Service Unavailable',
166
+ message: 'This feature is not available',
167
+ statusCode: 503,
168
+ });
169
+ });
170
+ it('should throw a Service Unavailable exception when requesting change password endpoint if reset password options are not configured', async () => {
171
+ const { body, status } = await e2e_setup_1.server.patch('/auth/change-password', { newPassword: 'test' });
172
+ expect(status).toBe(503);
173
+ expect(body).toEqual({
174
+ error: 'Service Unavailable',
175
+ message: 'This feature is not available',
176
+ statusCode: 503,
177
+ });
178
+ });
179
+ });
180
+ describe('useAuth with jwt options', () => {
181
+ let jwtService;
182
+ let token;
183
+ let app;
184
+ const UserEntity = (0, shared_1.createBasicUserEntity)();
185
+ beforeEach(async () => {
186
+ app = await (0, shared_1.initModule)({
187
+ useAuth: {
188
+ userEntity: UserEntity,
189
+ jwt: {
190
+ secret: 'test-secret',
191
+ expiresIn: '4s',
192
+ },
193
+ },
194
+ });
195
+ jwtService = app.get(jwt_1.JwtService);
196
+ const { body: { accessToken } } = await e2e_setup_1.server.post('/auth/register', { email: 'unit@test.co', password: 'test' });
197
+ token = accessToken;
198
+ });
199
+ it('should initialize dynamic api module state and authentication API with jwt options', async () => {
200
+ expect(app).toBeDefined();
201
+ expect(src_1.DynamicApiModule.state.get()).toStrictEqual({
202
+ uri,
203
+ initialized: true,
204
+ isGlobalCacheEnabled: true,
205
+ connectionName: 'dynamic-api-connection',
206
+ cacheExcludedPaths: [],
207
+ credentials: {
208
+ loginField: 'email',
209
+ passwordField: 'password',
210
+ },
211
+ isAuthEnabled: true,
212
+ jwtExpirationTime: '4s',
213
+ jwtRefreshTokenExpiresIn: '7d',
214
+ jwtRefreshSecret: undefined,
215
+ jwtRefreshUseCookie: false,
216
+ jwtSecret: 'test-secret',
217
+ routesConfig: {
218
+ defaults: [
219
+ 'GetMany',
220
+ 'GetOne',
221
+ 'CreateMany',
222
+ 'CreateOne',
223
+ 'UpdateMany',
224
+ 'UpdateOne',
225
+ 'ReplaceOne',
226
+ 'DuplicateMany',
227
+ 'DuplicateOne',
228
+ 'DeleteMany',
229
+ 'DeleteOne',
230
+ ],
231
+ excluded: [],
232
+ },
233
+ gatewayOptions: undefined,
234
+ });
235
+ });
236
+ it('should throw an unauthorized exception if access token is expired', async () => {
237
+ await (0, utils_1.wait)(5000);
238
+ const headers = { Authorization: `Bearer ${token}` };
239
+ const { body, status } = await e2e_setup_1.server.get('/auth/account', { headers });
240
+ expect(status).toBe(401);
241
+ expect(body).toEqual({
242
+ message: 'Unauthorized',
243
+ statusCode: 401,
244
+ });
245
+ }, 6000);
246
+ it('should throw an unauthorized exception if secret is invalid', async () => {
247
+ const invalidToken = jwtService.sign({ email: 'u', password: 'p' }, { secret: 'invalid-secret' });
248
+ const headers = { Authorization: `Bearer ${invalidToken}` };
249
+ const { body, status } = await e2e_setup_1.server.get('/auth/account', { headers });
250
+ expect(status).toBe(401);
251
+ expect(body).toEqual({
252
+ message: 'Unauthorized',
253
+ statusCode: 401,
254
+ });
255
+ });
256
+ });
257
+ describe('useAuth with validation options', () => {
258
+ let app;
259
+ const UserEntity = (0, shared_1.createValidatedUserEntity)();
260
+ beforeEach(async () => {
261
+ app = await (0, shared_1.initModule)({
262
+ useAuth: {
263
+ userEntity: UserEntity,
264
+ validationPipeOptions: {
265
+ whitelist: true,
266
+ forbidNonWhitelisted: true,
267
+ transform: true,
268
+ },
269
+ },
270
+ });
271
+ });
272
+ describe('POST /auth/register', () => {
273
+ it('should throw a bad request exception if payload contains non whitelisted property', async () => {
274
+ const { body, status } = await e2e_setup_1.server.post('/auth/register', { email: 'unit@test.co', password: 'Test-2', role: 'ADMIN' });
275
+ expect(status).toBe(400);
276
+ expect(body).toEqual({
277
+ error: 'Bad Request',
278
+ message: ['property role should not exist'],
279
+ statusCode: 400,
280
+ });
281
+ });
282
+ it('should throw a bad request exception if validation fails', async () => {
283
+ const { body, status } = await e2e_setup_1.server.post('/auth/register', { email: 'unit.test.co', password: 'test-2' });
284
+ expect(status).toBe(400);
285
+ expect(body).toEqual({
286
+ error: 'Bad Request',
287
+ message: [
288
+ 'email must be an email',
289
+ 'password is not strong enough',
290
+ ],
291
+ statusCode: 400,
292
+ });
293
+ });
294
+ it('should create a new user and return access token if the validation was successful', async () => {
295
+ const { body, status } = await e2e_setup_1.server.post('/auth/register', { email: 'unit@test.co', password: 'Test-2' });
296
+ expect(status).toBe(201);
297
+ expect(body).toEqual({ accessToken: expect.any(String), refreshToken: expect.any(String) });
298
+ });
299
+ });
300
+ describe('POST /auth/login', () => {
301
+ beforeEach(async () => {
302
+ await e2e_setup_1.server.post('/auth/register', { email: 'unit@test.co', password: 'Test-2' });
303
+ });
304
+ it('should throw an unauthorized exception if payload contains non whitelisted property', async () => {
305
+ const { body, status } = await e2e_setup_1.server.post('/auth/login', { email: 'unit@test.co', password: 'Test-2', role: 'ADMIN' });
306
+ expect(status).toBe(400);
307
+ expect(body).toEqual({
308
+ error: 'Bad Request',
309
+ message: ['property role should not exist'],
310
+ statusCode: 400,
311
+ });
312
+ });
313
+ it('should throw an unauthorized exception if email is missing', async () => {
314
+ const { body, status } = await e2e_setup_1.server.post('/auth/login', { password: 'Test-2' });
315
+ expect(status).toBe(401);
316
+ expect(body).toEqual({
317
+ message: 'Unauthorized',
318
+ statusCode: 401,
319
+ });
320
+ });
321
+ it('should throw an unauthorized exception if password is missing', async () => {
322
+ const { body, status } = await e2e_setup_1.server.post('/auth/login', { email: 'unit@test.co' });
323
+ expect(status).toBe(401);
324
+ expect(body).toEqual({
325
+ message: 'Unauthorized',
326
+ statusCode: 401,
327
+ });
328
+ });
329
+ it('should return access token if the validation was successful', async () => {
330
+ await e2e_setup_1.server.post('/auth/register', { email: 'unit@test.co', password: 'test' });
331
+ const { body, status } = await e2e_setup_1.server.post('/auth/login', { email: 'unit@test.co', password: 'Test-2' });
332
+ expect(status).toBe(200);
333
+ expect(body).toEqual({ accessToken: expect.any(String), refreshToken: expect.any(String) });
334
+ });
335
+ });
336
+ });
337
+ });
338
+ //# sourceMappingURL=auth-api-basic.e2e-spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-api-basic.e2e-spec.js","sourceRoot":"","sources":["../../../libs/dynamic-api/test/for-root/auth-api-basic.e2e-spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ import 'dotenv/config';
@@ -0,0 +1,82 @@
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 - useAuth with broadcast options (e2e)', () => {
9
+ const UserEntity = (0, shared_1.createBroadcastUserEntity)();
10
+ beforeEach(() => {
11
+ src_1.DynamicApiModule.state['resetState']();
12
+ });
13
+ afterEach(async () => {
14
+ await (0, e2e_setup_1.closeTestingApp)(mongoose_1.default.connections);
15
+ });
16
+ beforeEach(async () => {
17
+ await (0, shared_1.initModule)({
18
+ useAuth: {
19
+ userEntity: UserEntity,
20
+ login: {
21
+ loginField: 'email',
22
+ passwordField: 'password',
23
+ broadcast: { enabled: true },
24
+ },
25
+ register: {
26
+ broadcast: { enabled: true, fields: ['id', 'email'] },
27
+ },
28
+ getAccount: {
29
+ broadcast: { enabled: true, fields: ['id', 'email'] },
30
+ },
31
+ updateAccount: {
32
+ broadcast: { enabled: true, fields: ['id', 'email'] },
33
+ },
34
+ },
35
+ }, undefined, async (app) => {
36
+ app.useWebSocketAdapter(new e2e_setup_1.TestSocketAdapter(app));
37
+ });
38
+ jest.clearAllMocks();
39
+ });
40
+ it('[login] should broadcast user data via HTTP after login', async () => {
41
+ await e2e_setup_1.server.post('/auth/register', { email: 'broadcast@test.co', password: 'pass' });
42
+ const { broadcastData } = await e2e_setup_1.server.httpWithBroadcast('post', '/auth/login', { email: 'broadcast@test.co', password: 'pass' }, { broadcastEvent: 'auth-login-broadcast' });
43
+ expect(e2e_setup_1.handleSocketBroadcast).toHaveBeenCalledTimes(1);
44
+ expect(broadcastData).toEqual(expect.arrayContaining([
45
+ expect.objectContaining({ email: 'broadcast@test.co' }),
46
+ ]));
47
+ });
48
+ it('[register] should broadcast user data via HTTP after register', async () => {
49
+ const { broadcastData } = await e2e_setup_1.server.httpWithBroadcast('post', '/auth/register', { email: 'broadcast2@test.co', password: 'pass2' }, { broadcastEvent: 'auth-register-broadcast' });
50
+ expect(e2e_setup_1.handleSocketBroadcast).toHaveBeenCalledTimes(1);
51
+ expect(broadcastData).toEqual(expect.arrayContaining([
52
+ expect.objectContaining({ email: 'broadcast2@test.co' }),
53
+ ]));
54
+ });
55
+ it('[getAccount] should broadcast account via HTTP after GET /auth/account', async () => {
56
+ await e2e_setup_1.server.post('/auth/register', { email: 'broadcast3@test.co', password: 'pass3' });
57
+ const { body: { accessToken } } = await e2e_setup_1.server.post('/auth/login', { email: 'broadcast3@test.co', password: 'pass3' });
58
+ jest.clearAllMocks();
59
+ const { broadcastData } = await e2e_setup_1.server.httpWithBroadcast('get', '/auth/account', undefined, {
60
+ authToken: accessToken,
61
+ broadcastEvent: 'auth-get-account-broadcast',
62
+ });
63
+ expect(e2e_setup_1.handleSocketBroadcast).toHaveBeenCalledTimes(1);
64
+ expect(broadcastData).toEqual(expect.arrayContaining([
65
+ expect.objectContaining({ email: 'broadcast3@test.co' }),
66
+ ]));
67
+ });
68
+ it('[updateAccount] should broadcast updated account via HTTP after PATCH /auth/account', async () => {
69
+ await e2e_setup_1.server.post('/auth/register', { email: 'broadcast4@test.co', password: 'pass4' });
70
+ const { body: { accessToken } } = await e2e_setup_1.server.post('/auth/login', { email: 'broadcast4@test.co', password: 'pass4' });
71
+ jest.clearAllMocks();
72
+ const { broadcastData } = await e2e_setup_1.server.httpWithBroadcast('patch', '/auth/account', { name: 'Broadcast User' }, {
73
+ authToken: accessToken,
74
+ broadcastEvent: 'auth-update-account-broadcast',
75
+ });
76
+ expect(e2e_setup_1.handleSocketBroadcast).toHaveBeenCalledTimes(1);
77
+ expect(broadcastData).toEqual(expect.arrayContaining([
78
+ expect.objectContaining({ email: 'broadcast4@test.co' }),
79
+ ]));
80
+ });
81
+ });
82
+ //# sourceMappingURL=auth-api-broadcast.e2e-spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-api-broadcast.e2e-spec.js","sourceRoot":"","sources":["../../../libs/dynamic-api/test/for-root/auth-api-broadcast.e2e-spec.ts"],"names":[],"mappings":";;AACA,uCAAgC;AAChC,mCAA6C;AAC7C,4CAAiG;AACjG,yBAAuB;AACvB,sCAAkE;AAElE,QAAQ,CAAC,iEAAiE,EAAE,GAAG,EAAE;IAC/E,MAAM,UAAU,GAAG,IAAA,kCAAyB,GAAE,CAAC;IAE/C,UAAU,CAAC,GAAG,EAAE;QACd,sBAAgB,CAAC,KAAK,CAAC,YAAY,CAAC,EAAE,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,KAAK,IAAI,EAAE;QACnB,MAAM,IAAA,2BAAe,EAAC,kBAAQ,CAAC,WAAW,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAGH,UAAU,CAAC,KAAK,IAAI,EAAE;QACpB,MAAM,IAAA,mBAAU,EAAC;YACf,OAAO,EAAE;gBACP,UAAU,EAAE,UAAU;gBACtB,KAAK,EAAE;oBACL,UAAU,EAAE,OAAO;oBACnB,aAAa,EAAE,UAAU;oBACzB,SAAS,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE;iBAC7B;gBACD,QAAQ,EAAE;oBACR,SAAS,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,IAAI,EAAE,OAAO,CAAC,EAAE;iBACtD;gBACD,UAAU,EAAE;oBACV,SAAS,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,IAAI,EAAE,OAAO,CAAC,EAAE;iBACtD;gBACD,aAAa,EAAE;oBACb,SAAS,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,IAAI,EAAE,OAAO,CAAC,EAAE;iBACtD;aACF;SACF,EACD,SAAS,EACT,KAAK,EAAE,GAAqB,EAAE,EAAE;YAC9B,GAAG,CAAC,mBAAmB,CAAC,IAAI,6BAAiB,CAAC,GAAG,CAAC,CAAC,CAAC;QACtD,CAAC,CACA,CAAC;QACF,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yDAAyD,EAAE,KAAK,IAAI,EAAE;QACvE,MAAM,kBAAM,CAAC,IAAI,CAAC,gBAAgB,EAAE,EAAE,KAAK,EAAE,mBAAmB,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,CAAC;QAEtF,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,kBAAM,CAAC,iBAAiB,CACtD,MAAM,EACN,aAAa,EACb,EAAE,KAAK,EAAE,mBAAmB,EAAE,QAAQ,EAAE,MAAM,EAAE,EAChD,EAAE,cAAc,EAAE,sBAAsB,EAAE,CAC3C,CAAC;QAEF,MAAM,CAAC,iCAAqB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACvD,MAAM,CAAC,aAAa,CAAC,CAAC,OAAO,CAC3B,MAAM,CAAC,eAAe,CAAC;YACrB,MAAM,CAAC,gBAAgB,CAAC,EAAE,KAAK,EAAE,mBAAmB,EAAE,CAAC;SACxD,CAAC,CACH,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+DAA+D,EAAE,KAAK,IAAI,EAAE;QAC7E,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,kBAAM,CAAC,iBAAiB,CACtD,MAAM,EACN,gBAAgB,EAChB,EAAE,KAAK,EAAE,oBAAoB,EAAE,QAAQ,EAAE,OAAO,EAAE,EAClD,EAAE,cAAc,EAAE,yBAAyB,EAAE,CAC9C,CAAC;QAEF,MAAM,CAAC,iCAAqB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACvD,MAAM,CAAC,aAAa,CAAC,CAAC,OAAO,CAC3B,MAAM,CAAC,eAAe,CAAC;YACrB,MAAM,CAAC,gBAAgB,CAAC,EAAE,KAAK,EAAE,oBAAoB,EAAE,CAAC;SACzD,CAAC,CACH,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wEAAwE,EAAE,KAAK,IAAI,EAAE;QACtF,MAAM,kBAAM,CAAC,IAAI,CAAC,gBAAgB,EAAE,EAAE,KAAK,EAAE,oBAAoB,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC;QACxF,MAAM,EAAE,IAAI,EAAE,EAAE,WAAW,EAAE,EAAE,GAAG,MAAM,kBAAM,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE,KAAK,EAAE,oBAAoB,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC;QAEvH,IAAI,CAAC,aAAa,EAAE,CAAC;QAErB,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,kBAAM,CAAC,iBAAiB,CACtD,KAAK,EACL,eAAe,EACf,SAAS,EACT;YACE,SAAS,EAAE,WAAW;YACtB,cAAc,EAAE,4BAA4B;SAC7C,CACF,CAAC;QAEF,MAAM,CAAC,iCAAqB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACvD,MAAM,CAAC,aAAa,CAAC,CAAC,OAAO,CAC3B,MAAM,CAAC,eAAe,CAAC;YACrB,MAAM,CAAC,gBAAgB,CAAC,EAAE,KAAK,EAAE,oBAAoB,EAAE,CAAC;SACzD,CAAC,CACH,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qFAAqF,EAAE,KAAK,IAAI,EAAE;QACnG,MAAM,kBAAM,CAAC,IAAI,CAAC,gBAAgB,EAAE,EAAE,KAAK,EAAE,oBAAoB,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC;QACxF,MAAM,EAAE,IAAI,EAAE,EAAE,WAAW,EAAE,EAAE,GAAG,MAAM,kBAAM,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE,KAAK,EAAE,oBAAoB,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC;QAEvH,IAAI,CAAC,aAAa,EAAE,CAAC;QAErB,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,kBAAM,CAAC,iBAAiB,CACtD,OAAO,EACP,eAAe,EACf,EAAE,IAAI,EAAE,gBAAgB,EAAE,EAC1B;YACE,SAAS,EAAE,WAAW;YACtB,cAAc,EAAE,+BAA+B;SAChD,CACF,CAAC;QAEF,MAAM,CAAC,iCAAqB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACvD,MAAM,CAAC,aAAa,CAAC,CAAC,OAAO,CAC3B,MAAM,CAAC,eAAe,CAAC;YACrB,MAAM,CAAC,gBAAgB,CAAC,EAAE,KAAK,EAAE,oBAAoB,EAAE,CAAC;SACzD,CAAC,CACH,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1 @@
1
+ import 'dotenv/config';
@@ -0,0 +1,103 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const common_1 = require("@nestjs/common");
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/login with login options (e2e)', () => {
11
+ const User = (0, shared_1.createLoginUserEntity)();
12
+ const admin = shared_1.LOGIN_ADMIN;
13
+ const user = shared_1.LOGIN_USER;
14
+ const client = shared_1.LOGIN_CLIENT;
15
+ beforeEach(() => {
16
+ src_1.DynamicApiModule.state['resetState']();
17
+ });
18
+ afterEach(async () => {
19
+ await (0, e2e_setup_1.closeTestingApp)(mongoose_1.default.connections);
20
+ });
21
+ beforeEach(async () => {
22
+ const bcryptService = new src_1.BcryptService();
23
+ const fixtures = async (_) => {
24
+ const model = await (0, utils_1.getModelFromEntity)(User);
25
+ await model.insertMany([
26
+ { ...admin, pass: await bcryptService.hashPassword(admin.pass) },
27
+ { ...user, pass: await bcryptService.hashPassword(user.pass) },
28
+ { ...client, pass: await bcryptService.hashPassword(client.pass) },
29
+ ]);
30
+ };
31
+ await (0, shared_1.initModule)({
32
+ useAuth: {
33
+ userEntity: User,
34
+ login: {
35
+ loginField: 'username',
36
+ passwordField: 'pass',
37
+ additionalFields: ['role', 'isVerified'],
38
+ abilityPredicate: (user) => user.role === 'admin' || user.role === 'user',
39
+ callback: async (user) => {
40
+ if (user.isVerified) {
41
+ return;
42
+ }
43
+ throw new common_1.UnauthorizedException(`Hello ${user.username}, you must verify your account first!`);
44
+ },
45
+ },
46
+ },
47
+ }, fixtures);
48
+ });
49
+ describe('loginField', () => {
50
+ it('should throw an unauthorized exception if loginField is missing', async () => {
51
+ const { body, status } = await e2e_setup_1.server.post('/auth/login', { pass: 'test' });
52
+ expect(status).toBe(401);
53
+ expect(body).toEqual({
54
+ message: 'Unauthorized',
55
+ statusCode: 401,
56
+ });
57
+ });
58
+ });
59
+ describe('passwordField', () => {
60
+ it('should throw an unauthorized exception if passwordField is missing', async () => {
61
+ const { body, status } = await e2e_setup_1.server.post('/auth/login', { username: 'unit' });
62
+ expect(status).toBe(401);
63
+ expect(body).toEqual({
64
+ message: 'Unauthorized',
65
+ statusCode: 401,
66
+ });
67
+ });
68
+ });
69
+ describe('abilityPredicate', () => {
70
+ it('should throw an forbidden exception if user role is not admin or user', async () => {
71
+ const { username, pass } = client;
72
+ const { body, status } = await e2e_setup_1.server.post('/auth/login', { username, pass });
73
+ expect(status).toBe(403);
74
+ expect(body).toEqual({
75
+ error: 'Forbidden',
76
+ message: 'Access denied',
77
+ statusCode: 403,
78
+ });
79
+ });
80
+ });
81
+ describe('callback', () => {
82
+ it('should throw an unauthorized exception if user is not verified', async () => {
83
+ const { username, pass } = user;
84
+ const { body, status } = await e2e_setup_1.server.post('/auth/login', { username, pass });
85
+ expect(status).toBe(401);
86
+ expect(body).toEqual({
87
+ error: 'Unauthorized',
88
+ message: `Hello ${username}, you must verify your account first!`,
89
+ statusCode: 401,
90
+ });
91
+ });
92
+ });
93
+ describe('additionalFields', () => {
94
+ it('should return additional fields', async () => {
95
+ const { username, pass } = admin;
96
+ const { body: { accessToken } } = await e2e_setup_1.server.post('/auth/login', { username, pass });
97
+ const { body, status } = await e2e_setup_1.server.get('/auth/account', { headers: { Authorization: `Bearer ${accessToken}` } });
98
+ expect(status).toBe(200);
99
+ expect(body).toEqual({ id: expect.any(String), username: 'admin', role: 'admin', isVerified: true });
100
+ });
101
+ });
102
+ });
103
+ //# sourceMappingURL=auth-api-login.e2e-spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-api-login.e2e-spec.js","sourceRoot":"","sources":["../../../libs/dynamic-api/test/for-root/auth-api-login.e2e-spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ import 'dotenv/config';