@venizia/ignis 0.0.7-2 → 0.0.7-21

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 (559) hide show
  1. package/README.md +2757 -28
  2. package/dist/base/applications/abstract.d.ts.map +1 -1
  3. package/dist/base/applications/abstract.js +0 -8
  4. package/dist/base/applications/abstract.js.map +1 -1
  5. package/dist/base/applications/base.d.ts.map +1 -1
  6. package/dist/base/applications/base.js +0 -17
  7. package/dist/base/applications/base.js.map +1 -1
  8. package/dist/base/applications/types.d.ts.map +1 -1
  9. package/dist/base/applications/types.js.map +1 -1
  10. package/dist/base/components/base.d.ts.map +1 -1
  11. package/dist/base/components/base.js +0 -2
  12. package/dist/base/components/base.js.map +1 -1
  13. package/dist/base/controllers/abstract.d.ts +16 -130
  14. package/dist/base/controllers/abstract.d.ts.map +1 -1
  15. package/dist/base/controllers/abstract.js +62 -112
  16. package/dist/base/controllers/abstract.js.map +1 -1
  17. package/dist/base/controllers/base.d.ts +10 -118
  18. package/dist/base/controllers/base.d.ts.map +1 -1
  19. package/dist/base/controllers/base.js +5 -113
  20. package/dist/base/controllers/base.js.map +1 -1
  21. package/dist/base/controllers/common/constants.d.ts +1 -16
  22. package/dist/base/controllers/common/constants.d.ts.map +1 -1
  23. package/dist/base/controllers/common/constants.js +10 -29
  24. package/dist/base/controllers/common/constants.js.map +1 -1
  25. package/dist/base/controllers/common/types.d.ts +34 -152
  26. package/dist/base/controllers/common/types.d.ts.map +1 -1
  27. package/dist/base/controllers/common/types.js +1 -4
  28. package/dist/base/controllers/common/types.js.map +1 -1
  29. package/dist/base/controllers/factory/controller.d.ts +37 -199
  30. package/dist/base/controllers/factory/controller.d.ts.map +1 -1
  31. package/dist/base/controllers/factory/controller.js +21 -146
  32. package/dist/base/controllers/factory/controller.js.map +1 -1
  33. package/dist/base/controllers/factory/definition.d.ts +15 -9
  34. package/dist/base/controllers/factory/definition.d.ts.map +1 -1
  35. package/dist/base/controllers/factory/definition.js +62 -58
  36. package/dist/base/controllers/factory/definition.js.map +1 -1
  37. package/dist/base/datasources/base.d.ts +2 -31
  38. package/dist/base/datasources/base.d.ts.map +1 -1
  39. package/dist/base/datasources/base.js +2 -39
  40. package/dist/base/datasources/base.js.map +1 -1
  41. package/dist/base/datasources/common/types.d.ts +2 -4
  42. package/dist/base/datasources/common/types.d.ts.map +1 -1
  43. package/dist/base/datasources/common/types.js +1 -8
  44. package/dist/base/datasources/common/types.js.map +1 -1
  45. package/dist/base/metadata/injectors.d.ts +1 -30
  46. package/dist/base/metadata/injectors.d.ts.map +1 -1
  47. package/dist/base/metadata/injectors.js +1 -30
  48. package/dist/base/metadata/injectors.js.map +1 -1
  49. package/dist/base/metadata/persistents.d.ts +3 -63
  50. package/dist/base/metadata/persistents.d.ts.map +1 -1
  51. package/dist/base/metadata/persistents.js +11 -88
  52. package/dist/base/metadata/persistents.js.map +1 -1
  53. package/dist/base/metadata/routes.d.ts +8 -31
  54. package/dist/base/metadata/routes.d.ts.map +1 -1
  55. package/dist/base/metadata/routes.js +1 -27
  56. package/dist/base/metadata/routes.js.map +1 -1
  57. package/dist/base/middlewares/app-error.middleware.d.ts +1 -10
  58. package/dist/base/middlewares/app-error.middleware.d.ts.map +1 -1
  59. package/dist/base/middlewares/app-error.middleware.js +2 -14
  60. package/dist/base/middlewares/app-error.middleware.js.map +1 -1
  61. package/dist/base/middlewares/emoji-favicon.middleware.d.ts +1 -7
  62. package/dist/base/middlewares/emoji-favicon.middleware.d.ts.map +1 -1
  63. package/dist/base/middlewares/emoji-favicon.middleware.js +1 -7
  64. package/dist/base/middlewares/emoji-favicon.middleware.js.map +1 -1
  65. package/dist/base/middlewares/not-found.middleware.d.ts +1 -8
  66. package/dist/base/middlewares/not-found.middleware.d.ts.map +1 -1
  67. package/dist/base/middlewares/not-found.middleware.js +1 -8
  68. package/dist/base/middlewares/not-found.middleware.js.map +1 -1
  69. package/dist/base/middlewares/request-spy.middleware.d.ts +3 -19
  70. package/dist/base/middlewares/request-spy.middleware.d.ts.map +1 -1
  71. package/dist/base/middlewares/request-spy.middleware.js +3 -23
  72. package/dist/base/middlewares/request-spy.middleware.js.map +1 -1
  73. package/dist/base/mixins/component.mixin.d.ts.map +1 -1
  74. package/dist/base/mixins/controller.mixin.d.ts.map +1 -1
  75. package/dist/base/mixins/repository.mixin.d.ts.map +1 -1
  76. package/dist/base/mixins/service.mixin.d.ts.map +1 -1
  77. package/dist/base/models/base.d.ts +4 -21
  78. package/dist/base/models/base.d.ts.map +1 -1
  79. package/dist/base/models/base.js +1 -11
  80. package/dist/base/models/base.js.map +1 -1
  81. package/dist/base/models/common/types.d.ts.map +1 -1
  82. package/dist/base/models/common/types.js +0 -2
  83. package/dist/base/models/common/types.js.map +1 -1
  84. package/dist/base/models/enrichers/id.enricher.d.ts.map +1 -1
  85. package/dist/base/models/enrichers/id.enricher.js.map +1 -1
  86. package/dist/base/models/enrichers/user-audit.enricher.d.ts.map +1 -1
  87. package/dist/base/models/enrichers/user-audit.enricher.js +1 -6
  88. package/dist/base/models/enrichers/user-audit.enricher.js.map +1 -1
  89. package/dist/base/repositories/common/constants.d.ts +5 -59
  90. package/dist/base/repositories/common/constants.d.ts.map +1 -1
  91. package/dist/base/repositories/common/constants.js +3 -51
  92. package/dist/base/repositories/common/constants.js.map +1 -1
  93. package/dist/base/repositories/common/shared.d.ts +1 -13
  94. package/dist/base/repositories/common/shared.d.ts.map +1 -1
  95. package/dist/base/repositories/common/shared.js +2 -19
  96. package/dist/base/repositories/common/shared.js.map +1 -1
  97. package/dist/base/repositories/common/types.d.ts +32 -461
  98. package/dist/base/repositories/common/types.d.ts.map +1 -1
  99. package/dist/base/repositories/common/types.js +13 -159
  100. package/dist/base/repositories/common/types.js.map +1 -1
  101. package/dist/base/repositories/core/abstract.d.ts +10 -204
  102. package/dist/base/repositories/core/abstract.d.ts.map +1 -1
  103. package/dist/base/repositories/core/abstract.js +6 -126
  104. package/dist/base/repositories/core/abstract.js.map +1 -1
  105. package/dist/base/repositories/core/default-crud.d.ts +1 -36
  106. package/dist/base/repositories/core/default-crud.d.ts.map +1 -1
  107. package/dist/base/repositories/core/default-crud.js +1 -36
  108. package/dist/base/repositories/core/default-crud.js.map +1 -1
  109. package/dist/base/repositories/core/index.d.ts +1 -0
  110. package/dist/base/repositories/core/index.d.ts.map +1 -1
  111. package/dist/base/repositories/core/index.js +1 -0
  112. package/dist/base/repositories/core/index.js.map +1 -1
  113. package/dist/base/repositories/core/persistable.d.ts +2 -71
  114. package/dist/base/repositories/core/persistable.d.ts.map +1 -1
  115. package/dist/base/repositories/core/persistable.js +2 -100
  116. package/dist/base/repositories/core/persistable.js.map +1 -1
  117. package/dist/base/repositories/core/readable.d.ts +12 -127
  118. package/dist/base/repositories/core/readable.d.ts.map +1 -1
  119. package/dist/base/repositories/core/readable.js +8 -124
  120. package/dist/base/repositories/core/readable.js.map +1 -1
  121. package/dist/base/repositories/core/soft-deletable.d.ts +140 -0
  122. package/dist/base/repositories/core/soft-deletable.d.ts.map +1 -0
  123. package/dist/base/repositories/core/soft-deletable.js +99 -0
  124. package/dist/base/repositories/core/soft-deletable.js.map +1 -0
  125. package/dist/base/repositories/mixins/default-filter.d.ts +3 -49
  126. package/dist/base/repositories/mixins/default-filter.d.ts.map +1 -1
  127. package/dist/base/repositories/mixins/default-filter.js +3 -57
  128. package/dist/base/repositories/mixins/default-filter.js.map +1 -1
  129. package/dist/base/repositories/mixins/fields-visibility.d.ts +3 -59
  130. package/dist/base/repositories/mixins/fields-visibility.d.ts.map +1 -1
  131. package/dist/base/repositories/mixins/fields-visibility.js +3 -67
  132. package/dist/base/repositories/mixins/fields-visibility.js.map +1 -1
  133. package/dist/base/repositories/operators/filter.d.ts +10 -115
  134. package/dist/base/repositories/operators/filter.d.ts.map +1 -1
  135. package/dist/base/repositories/operators/filter.js +13 -154
  136. package/dist/base/repositories/operators/filter.js.map +1 -1
  137. package/dist/base/repositories/operators/json-utils.d.ts +5 -38
  138. package/dist/base/repositories/operators/json-utils.d.ts.map +1 -1
  139. package/dist/base/repositories/operators/json-utils.js +5 -47
  140. package/dist/base/repositories/operators/json-utils.js.map +1 -1
  141. package/dist/base/repositories/operators/query.d.ts +3 -56
  142. package/dist/base/repositories/operators/query.d.ts.map +1 -1
  143. package/dist/base/repositories/operators/query.js +11 -106
  144. package/dist/base/repositories/operators/query.js.map +1 -1
  145. package/dist/base/repositories/operators/relation.d.ts +1 -33
  146. package/dist/base/repositories/operators/relation.d.ts.map +1 -1
  147. package/dist/base/repositories/operators/relation.js +1 -36
  148. package/dist/base/repositories/operators/relation.js.map +1 -1
  149. package/dist/base/repositories/operators/update.d.ts +7 -72
  150. package/dist/base/repositories/operators/update.d.ts.map +1 -1
  151. package/dist/base/repositories/operators/update.js +6 -91
  152. package/dist/base/repositories/operators/update.js.map +1 -1
  153. package/dist/base/services/types.d.ts.map +1 -1
  154. package/dist/common/bindings.d.ts +2 -17
  155. package/dist/common/bindings.d.ts.map +1 -1
  156. package/dist/common/bindings.js +2 -14
  157. package/dist/common/bindings.js.map +1 -1
  158. package/dist/common/constants.d.ts +1 -3
  159. package/dist/common/constants.d.ts.map +1 -1
  160. package/dist/common/constants.js +1 -4
  161. package/dist/common/constants.js.map +1 -1
  162. package/dist/common/environments.d.ts +1 -4
  163. package/dist/common/environments.d.ts.map +1 -1
  164. package/dist/common/environments.js +1 -4
  165. package/dist/common/environments.js.map +1 -1
  166. package/dist/common/statuses.d.ts +6 -19
  167. package/dist/common/statuses.d.ts.map +1 -1
  168. package/dist/common/statuses.js +6 -27
  169. package/dist/common/statuses.js.map +1 -1
  170. package/dist/components/auth/authenticate/common/codecs.d.ts +11 -0
  171. package/dist/components/auth/authenticate/common/codecs.d.ts.map +1 -0
  172. package/dist/components/auth/authenticate/common/codecs.js +28 -0
  173. package/dist/components/auth/authenticate/common/codecs.js.map +1 -0
  174. package/dist/components/auth/authenticate/common/constants.d.ts +31 -5
  175. package/dist/components/auth/authenticate/common/constants.d.ts.map +1 -1
  176. package/dist/components/auth/authenticate/common/constants.js +41 -9
  177. package/dist/components/auth/authenticate/common/constants.js.map +1 -1
  178. package/dist/components/auth/authenticate/common/index.d.ts +1 -0
  179. package/dist/components/auth/authenticate/common/index.d.ts.map +1 -1
  180. package/dist/components/auth/authenticate/common/index.js +1 -0
  181. package/dist/components/auth/authenticate/common/index.js.map +1 -1
  182. package/dist/components/auth/authenticate/common/keys.d.ts +1 -0
  183. package/dist/components/auth/authenticate/common/keys.d.ts.map +1 -1
  184. package/dist/components/auth/authenticate/common/keys.js +1 -0
  185. package/dist/components/auth/authenticate/common/keys.js.map +1 -1
  186. package/dist/components/auth/authenticate/common/types.d.ts +63 -37
  187. package/dist/components/auth/authenticate/common/types.d.ts.map +1 -1
  188. package/dist/components/auth/authenticate/component.d.ts +5 -18
  189. package/dist/components/auth/authenticate/component.d.ts.map +1 -1
  190. package/dist/components/auth/authenticate/component.js +114 -82
  191. package/dist/components/auth/authenticate/component.js.map +1 -1
  192. package/dist/components/auth/authenticate/controllers/factory.d.ts +12 -12
  193. package/dist/components/auth/authenticate/controllers/factory.d.ts.map +1 -1
  194. package/dist/components/auth/authenticate/controllers/factory.js +23 -22
  195. package/dist/components/auth/authenticate/controllers/factory.js.map +1 -1
  196. package/dist/components/auth/authenticate/controllers/index.d.ts +1 -0
  197. package/dist/components/auth/authenticate/controllers/index.d.ts.map +1 -1
  198. package/dist/components/auth/authenticate/controllers/index.js +1 -0
  199. package/dist/components/auth/authenticate/controllers/index.js.map +1 -1
  200. package/dist/components/auth/authenticate/controllers/jwks/controller.d.ts +9 -0
  201. package/dist/components/auth/authenticate/controllers/jwks/controller.d.ts.map +1 -0
  202. package/dist/components/auth/authenticate/controllers/jwks/controller.js +54 -0
  203. package/dist/components/auth/authenticate/controllers/jwks/controller.js.map +1 -0
  204. package/dist/components/auth/authenticate/controllers/jwks/definitions.d.ts +66 -0
  205. package/dist/components/auth/authenticate/controllers/jwks/definitions.d.ts.map +1 -0
  206. package/dist/components/auth/authenticate/controllers/jwks/definitions.js +32 -0
  207. package/dist/components/auth/authenticate/controllers/jwks/definitions.js.map +1 -0
  208. package/dist/components/auth/authenticate/controllers/jwks/index.d.ts +2 -0
  209. package/dist/components/auth/authenticate/controllers/jwks/index.d.ts.map +1 -0
  210. package/dist/components/auth/authenticate/controllers/jwks/index.js +18 -0
  211. package/dist/components/auth/authenticate/controllers/jwks/index.js.map +1 -0
  212. package/dist/components/auth/authenticate/index.d.ts +2 -0
  213. package/dist/components/auth/authenticate/index.d.ts.map +1 -1
  214. package/dist/components/auth/authenticate/index.js +2 -0
  215. package/dist/components/auth/authenticate/index.js.map +1 -1
  216. package/dist/components/auth/authenticate/middlewares/authenticate.middleware.d.ts +6 -0
  217. package/dist/components/auth/authenticate/middlewares/authenticate.middleware.d.ts.map +1 -0
  218. package/dist/components/auth/authenticate/middlewares/authenticate.middleware.js +12 -0
  219. package/dist/components/auth/authenticate/middlewares/authenticate.middleware.js.map +1 -0
  220. package/dist/components/auth/authenticate/middlewares/index.d.ts +2 -0
  221. package/dist/components/auth/authenticate/middlewares/index.d.ts.map +1 -0
  222. package/dist/components/auth/authenticate/middlewares/index.js +18 -0
  223. package/dist/components/auth/authenticate/middlewares/index.js.map +1 -0
  224. package/dist/components/auth/authenticate/providers/authentication.provider.d.ts +12 -0
  225. package/dist/components/auth/authenticate/providers/authentication.provider.d.ts.map +1 -0
  226. package/dist/components/auth/authenticate/providers/authentication.provider.js +117 -0
  227. package/dist/components/auth/authenticate/providers/authentication.provider.js.map +1 -0
  228. package/dist/components/auth/authenticate/providers/index.d.ts +2 -0
  229. package/dist/components/auth/authenticate/providers/index.d.ts.map +1 -0
  230. package/dist/components/auth/authenticate/providers/index.js +18 -0
  231. package/dist/components/auth/authenticate/providers/index.js.map +1 -0
  232. package/dist/components/auth/authenticate/services/basic/index.d.ts +2 -0
  233. package/dist/components/auth/authenticate/services/basic/index.d.ts.map +1 -0
  234. package/dist/components/auth/authenticate/services/basic/index.js +18 -0
  235. package/dist/components/auth/authenticate/services/basic/index.js.map +1 -0
  236. package/dist/components/auth/authenticate/services/basic/service.d.ts +24 -0
  237. package/dist/components/auth/authenticate/services/basic/service.d.ts.map +1 -0
  238. package/dist/components/auth/authenticate/services/{basic-token.service.js → basic/service.js} +10 -49
  239. package/dist/components/auth/authenticate/services/basic/service.js.map +1 -0
  240. package/dist/components/auth/authenticate/services/bearer/abstract.service.d.ts +52 -0
  241. package/dist/components/auth/authenticate/services/bearer/abstract.service.d.ts.map +1 -0
  242. package/dist/components/auth/authenticate/services/bearer/abstract.service.js +177 -0
  243. package/dist/components/auth/authenticate/services/bearer/abstract.service.js.map +1 -0
  244. package/dist/components/auth/authenticate/services/bearer/index.d.ts +4 -0
  245. package/dist/components/auth/authenticate/services/bearer/index.d.ts.map +1 -0
  246. package/dist/components/auth/authenticate/services/bearer/index.js +20 -0
  247. package/dist/components/auth/authenticate/services/bearer/index.js.map +1 -0
  248. package/dist/components/auth/authenticate/services/bearer/jwks/abstract.service.d.ts +16 -0
  249. package/dist/components/auth/authenticate/services/bearer/jwks/abstract.service.d.ts.map +1 -0
  250. package/dist/components/auth/authenticate/services/bearer/jwks/abstract.service.js +32 -0
  251. package/dist/components/auth/authenticate/services/bearer/jwks/abstract.service.js.map +1 -0
  252. package/dist/components/auth/authenticate/services/bearer/jwks/index.d.ts +4 -0
  253. package/dist/components/auth/authenticate/services/bearer/jwks/index.d.ts.map +1 -0
  254. package/dist/components/auth/authenticate/services/bearer/jwks/index.js +20 -0
  255. package/dist/components/auth/authenticate/services/bearer/jwks/index.js.map +1 -0
  256. package/dist/components/auth/authenticate/services/bearer/jwks/issuer.service.d.ts +46 -0
  257. package/dist/components/auth/authenticate/services/bearer/jwks/issuer.service.d.ts.map +1 -0
  258. package/dist/components/auth/authenticate/services/bearer/jwks/issuer.service.js +168 -0
  259. package/dist/components/auth/authenticate/services/bearer/jwks/issuer.service.js.map +1 -0
  260. package/dist/components/auth/authenticate/services/bearer/jwks/verifier.service.d.ts +18 -0
  261. package/dist/components/auth/authenticate/services/bearer/jwks/verifier.service.d.ts.map +1 -0
  262. package/dist/components/auth/authenticate/services/bearer/jwks/verifier.service.js +73 -0
  263. package/dist/components/auth/authenticate/services/bearer/jwks/verifier.service.js.map +1 -0
  264. package/dist/components/auth/authenticate/services/bearer/jws.service.d.ts +19 -0
  265. package/dist/components/auth/authenticate/services/bearer/jws.service.d.ts.map +1 -0
  266. package/dist/components/auth/authenticate/services/bearer/jws.service.js +76 -0
  267. package/dist/components/auth/authenticate/services/bearer/jws.service.js.map +1 -0
  268. package/dist/components/auth/authenticate/services/index.d.ts +2 -2
  269. package/dist/components/auth/authenticate/services/index.d.ts.map +1 -1
  270. package/dist/components/auth/authenticate/services/index.js +2 -2
  271. package/dist/components/auth/authenticate/services/index.js.map +1 -1
  272. package/dist/components/auth/authenticate/strategies/basic.strategy.d.ts +2 -23
  273. package/dist/components/auth/authenticate/strategies/basic.strategy.d.ts.map +1 -1
  274. package/dist/components/auth/authenticate/strategies/basic.strategy.js +12 -26
  275. package/dist/components/auth/authenticate/strategies/basic.strategy.js.map +1 -1
  276. package/dist/components/auth/authenticate/strategies/index.d.ts +2 -1
  277. package/dist/components/auth/authenticate/strategies/index.d.ts.map +1 -1
  278. package/dist/components/auth/authenticate/strategies/index.js +2 -1
  279. package/dist/components/auth/authenticate/strategies/index.js.map +1 -1
  280. package/dist/components/auth/authenticate/strategies/jwks.strategy.d.ts +21 -0
  281. package/dist/components/auth/authenticate/strategies/jwks.strategy.d.ts.map +1 -0
  282. package/dist/components/auth/authenticate/strategies/jwks.strategy.js +68 -0
  283. package/dist/components/auth/authenticate/strategies/jwks.strategy.js.map +1 -0
  284. package/dist/components/auth/authenticate/strategies/{jwt.strategy.d.ts → jws.strategy.d.ts} +6 -5
  285. package/dist/components/auth/authenticate/strategies/jws.strategy.d.ts.map +1 -0
  286. package/dist/components/auth/authenticate/strategies/{jwt.strategy.js → jws.strategy.js} +21 -13
  287. package/dist/components/auth/authenticate/strategies/jws.strategy.js.map +1 -0
  288. package/dist/components/auth/authenticate/strategies/strategy-registry.d.ts +11 -24
  289. package/dist/components/auth/authenticate/strategies/strategy-registry.d.ts.map +1 -1
  290. package/dist/components/auth/authenticate/strategies/strategy-registry.js +9 -132
  291. package/dist/components/auth/authenticate/strategies/strategy-registry.js.map +1 -1
  292. package/dist/components/auth/authorize/adapters/base-filtered.d.ts +73 -0
  293. package/dist/components/auth/authorize/adapters/base-filtered.d.ts.map +1 -0
  294. package/dist/components/auth/authorize/adapters/base-filtered.js +90 -0
  295. package/dist/components/auth/authorize/adapters/base-filtered.js.map +1 -0
  296. package/dist/components/auth/authorize/adapters/drizzle-casbin.d.ts +40 -0
  297. package/dist/components/auth/authorize/adapters/drizzle-casbin.d.ts.map +1 -0
  298. package/dist/components/auth/authorize/adapters/drizzle-casbin.js +99 -0
  299. package/dist/components/auth/authorize/adapters/drizzle-casbin.js.map +1 -0
  300. package/dist/components/auth/authorize/adapters/index.d.ts +3 -0
  301. package/dist/components/auth/authorize/adapters/index.d.ts.map +1 -0
  302. package/dist/components/auth/authorize/adapters/index.js +19 -0
  303. package/dist/components/auth/authorize/adapters/index.js.map +1 -0
  304. package/dist/components/auth/authorize/common/constants.d.ts +70 -0
  305. package/dist/components/auth/authorize/common/constants.d.ts.map +1 -0
  306. package/dist/components/auth/authorize/common/constants.js +130 -0
  307. package/dist/components/auth/authorize/common/constants.js.map +1 -0
  308. package/dist/components/auth/authorize/common/index.d.ts +4 -0
  309. package/dist/components/auth/authorize/common/index.d.ts.map +1 -0
  310. package/dist/components/auth/authorize/common/index.js +20 -0
  311. package/dist/components/auth/authorize/common/index.js.map +1 -0
  312. package/dist/components/auth/authorize/common/keys.d.ts +6 -0
  313. package/dist/components/auth/authorize/common/keys.d.ts.map +1 -0
  314. package/dist/components/auth/authorize/common/keys.js +12 -0
  315. package/dist/components/auth/authorize/common/keys.js.map +1 -0
  316. package/dist/components/auth/authorize/common/types.d.ts +107 -0
  317. package/dist/components/auth/authorize/common/types.d.ts.map +1 -0
  318. package/dist/components/auth/authorize/{middleware.js → common/types.js} +1 -1
  319. package/dist/components/auth/authorize/common/types.js.map +1 -0
  320. package/dist/components/auth/authorize/component.d.ts +10 -0
  321. package/dist/components/auth/authorize/component.d.ts.map +1 -0
  322. package/dist/components/auth/authorize/component.js +58 -0
  323. package/dist/components/auth/authorize/component.js.map +1 -0
  324. package/dist/components/auth/authorize/enforcers/casbin.enforcer.d.ts +56 -0
  325. package/dist/components/auth/authorize/enforcers/casbin.enforcer.d.ts.map +1 -0
  326. package/dist/components/auth/authorize/enforcers/casbin.enforcer.js +254 -0
  327. package/dist/components/auth/authorize/enforcers/casbin.enforcer.js.map +1 -0
  328. package/dist/components/auth/authorize/enforcers/enforcer-registry.d.ts +33 -0
  329. package/dist/components/auth/authorize/enforcers/enforcer-registry.d.ts.map +1 -0
  330. package/dist/components/auth/authorize/enforcers/enforcer-registry.js +79 -0
  331. package/dist/components/auth/authorize/enforcers/enforcer-registry.js.map +1 -0
  332. package/dist/components/auth/authorize/enforcers/index.d.ts +3 -0
  333. package/dist/components/auth/authorize/enforcers/index.d.ts.map +1 -0
  334. package/dist/components/auth/authorize/enforcers/index.js +19 -0
  335. package/dist/components/auth/authorize/enforcers/index.js.map +1 -0
  336. package/dist/components/auth/authorize/index.d.ts +7 -1
  337. package/dist/components/auth/authorize/index.d.ts.map +1 -1
  338. package/dist/components/auth/authorize/index.js +21 -0
  339. package/dist/components/auth/authorize/index.js.map +1 -1
  340. package/dist/components/auth/authorize/middlewares/authorize.middleware.d.ts +6 -0
  341. package/dist/components/auth/authorize/middlewares/authorize.middleware.d.ts.map +1 -0
  342. package/dist/components/auth/authorize/middlewares/authorize.middleware.js +12 -0
  343. package/dist/components/auth/authorize/middlewares/authorize.middleware.js.map +1 -0
  344. package/dist/components/auth/authorize/middlewares/index.d.ts +2 -0
  345. package/dist/components/auth/authorize/middlewares/index.d.ts.map +1 -0
  346. package/dist/components/auth/authorize/middlewares/index.js +18 -0
  347. package/dist/components/auth/authorize/middlewares/index.js.map +1 -0
  348. package/dist/components/auth/authorize/models/abilities/index.d.ts +3 -0
  349. package/dist/components/auth/authorize/models/abilities/index.d.ts.map +1 -0
  350. package/dist/components/auth/authorize/models/abilities/index.js +19 -0
  351. package/dist/components/auth/authorize/models/abilities/index.js.map +1 -0
  352. package/dist/components/auth/authorize/models/abilities/string-action.model.d.ts +14 -0
  353. package/dist/components/auth/authorize/models/abilities/string-action.model.d.ts.map +1 -0
  354. package/dist/components/auth/authorize/models/abilities/string-action.model.js +23 -0
  355. package/dist/components/auth/authorize/models/abilities/string-action.model.js.map +1 -0
  356. package/dist/components/auth/authorize/models/abilities/string-resource.model.d.ts +13 -0
  357. package/dist/components/auth/authorize/models/abilities/string-resource.model.d.ts.map +1 -0
  358. package/dist/components/auth/authorize/models/abilities/string-resource.model.js +19 -0
  359. package/dist/components/auth/authorize/models/abilities/string-resource.model.js.map +1 -0
  360. package/dist/components/auth/authorize/models/authorization-role.model.d.ts +30 -0
  361. package/dist/components/auth/authorize/models/authorization-role.model.d.ts.map +1 -0
  362. package/dist/components/auth/authorize/models/authorization-role.model.js +30 -0
  363. package/dist/components/auth/authorize/models/authorization-role.model.js.map +1 -0
  364. package/dist/components/auth/authorize/models/index.d.ts +3 -0
  365. package/dist/components/auth/authorize/models/index.d.ts.map +1 -0
  366. package/dist/components/auth/authorize/models/index.js +19 -0
  367. package/dist/components/auth/authorize/models/index.js.map +1 -0
  368. package/dist/components/auth/authorize/providers/authorization.provider.d.ts +10 -0
  369. package/dist/components/auth/authorize/providers/authorization.provider.d.ts.map +1 -0
  370. package/dist/components/auth/authorize/providers/authorization.provider.js +135 -0
  371. package/dist/components/auth/authorize/providers/authorization.provider.js.map +1 -0
  372. package/dist/components/auth/authorize/providers/index.d.ts +2 -0
  373. package/dist/components/auth/authorize/providers/index.d.ts.map +1 -0
  374. package/dist/components/auth/authorize/providers/index.js +18 -0
  375. package/dist/components/auth/authorize/providers/index.js.map +1 -0
  376. package/dist/components/auth/base/abstract-auth-registry.d.ts +27 -0
  377. package/dist/components/auth/base/abstract-auth-registry.d.ts.map +1 -0
  378. package/dist/components/auth/base/abstract-auth-registry.js +62 -0
  379. package/dist/components/auth/base/abstract-auth-registry.js.map +1 -0
  380. package/dist/components/auth/base/index.d.ts +2 -0
  381. package/dist/components/auth/base/index.d.ts.map +1 -0
  382. package/dist/components/auth/base/index.js +18 -0
  383. package/dist/components/auth/base/index.js.map +1 -0
  384. package/dist/components/auth/context-variables.d.ts +14 -0
  385. package/dist/components/auth/context-variables.d.ts.map +1 -0
  386. package/dist/components/auth/context-variables.js +3 -0
  387. package/dist/components/auth/context-variables.js.map +1 -0
  388. package/dist/components/auth/index.d.ts +2 -0
  389. package/dist/components/auth/index.d.ts.map +1 -1
  390. package/dist/components/auth/index.js +2 -0
  391. package/dist/components/auth/index.js.map +1 -1
  392. package/dist/components/auth/models/entities/index.d.ts +1 -2
  393. package/dist/components/auth/models/entities/index.d.ts.map +1 -1
  394. package/dist/components/auth/models/entities/index.js +1 -2
  395. package/dist/components/auth/models/entities/index.js.map +1 -1
  396. package/dist/components/auth/models/entities/permission.model.d.ts +0 -1
  397. package/dist/components/auth/models/entities/permission.model.d.ts.map +1 -1
  398. package/dist/components/auth/models/entities/permission.model.js +0 -2
  399. package/dist/components/auth/models/entities/permission.model.js.map +1 -1
  400. package/dist/components/auth/models/entities/policy-definition.model.d.ts +24 -0
  401. package/dist/components/auth/models/entities/policy-definition.model.d.ts.map +1 -0
  402. package/dist/components/auth/models/entities/policy-definition.model.js +39 -0
  403. package/dist/components/auth/models/entities/policy-definition.model.js.map +1 -0
  404. package/dist/components/auth/models/entities/role.model.d.ts +3 -1
  405. package/dist/components/auth/models/entities/role.model.d.ts.map +1 -1
  406. package/dist/components/auth/models/entities/role.model.js +5 -3
  407. package/dist/components/auth/models/entities/role.model.js.map +1 -1
  408. package/dist/components/auth/models/entities/user.model.d.ts +4 -2
  409. package/dist/components/auth/models/entities/user.model.d.ts.map +1 -1
  410. package/dist/components/auth/models/entities/user.model.js +6 -5
  411. package/dist/components/auth/models/entities/user.model.js.map +1 -1
  412. package/dist/components/auth/models/requests/change-password.schema.js +3 -3
  413. package/dist/components/auth/models/requests/change-password.schema.js.map +1 -1
  414. package/dist/components/auth/models/requests/sign-in.schema.js +5 -5
  415. package/dist/components/auth/models/requests/sign-in.schema.js.map +1 -1
  416. package/dist/components/health-check/controller.d.ts.map +1 -1
  417. package/dist/components/health-check/controller.js +0 -1
  418. package/dist/components/health-check/controller.js.map +1 -1
  419. package/dist/components/index.d.ts +0 -2
  420. package/dist/components/index.d.ts.map +1 -1
  421. package/dist/components/index.js +4 -2
  422. package/dist/components/index.js.map +1 -1
  423. package/dist/components/mail/common/types.d.ts +1 -1
  424. package/dist/components/mail/common/types.d.ts.map +1 -1
  425. package/dist/components/mail/component.d.ts.map +1 -1
  426. package/dist/components/mail/component.js +2 -7
  427. package/dist/components/mail/component.js.map +1 -1
  428. package/dist/components/mail/helpers/executors/bull-mq-executor.helper.d.ts +2 -1
  429. package/dist/components/mail/helpers/executors/bull-mq-executor.helper.d.ts.map +1 -1
  430. package/dist/components/mail/helpers/executors/bull-mq-executor.helper.js +10 -9
  431. package/dist/components/mail/helpers/executors/bull-mq-executor.helper.js.map +1 -1
  432. package/dist/components/mail/helpers/executors/direct-executor.helper.d.ts +1 -1
  433. package/dist/components/mail/helpers/executors/direct-executor.helper.d.ts.map +1 -1
  434. package/dist/components/mail/helpers/executors/direct-executor.helper.js +3 -3
  435. package/dist/components/mail/helpers/executors/direct-executor.helper.js.map +1 -1
  436. package/dist/components/mail/helpers/executors/internal-queue-executor.helper.d.ts +1 -1
  437. package/dist/components/mail/helpers/executors/internal-queue-executor.helper.d.ts.map +1 -1
  438. package/dist/components/mail/helpers/executors/internal-queue-executor.helper.js +4 -4
  439. package/dist/components/mail/helpers/executors/internal-queue-executor.helper.js.map +1 -1
  440. package/dist/components/mail/helpers/transporters/mailgun-transporter.helper.d.ts +1 -1
  441. package/dist/components/mail/helpers/transporters/mailgun-transporter.helper.d.ts.map +1 -1
  442. package/dist/components/mail/helpers/transporters/mailgun-transporter.helper.js +3 -3
  443. package/dist/components/mail/helpers/transporters/mailgun-transporter.helper.js.map +1 -1
  444. package/dist/components/mail/helpers/transporters/nodemail-transporter.helper.d.ts +1 -1
  445. package/dist/components/mail/helpers/transporters/nodemail-transporter.helper.d.ts.map +1 -1
  446. package/dist/components/mail/helpers/transporters/nodemail-transporter.helper.js +3 -3
  447. package/dist/components/mail/helpers/transporters/nodemail-transporter.helper.js.map +1 -1
  448. package/dist/components/mail/providers/mail-queue-executor.provider.d.ts.map +1 -1
  449. package/dist/components/mail/providers/mail-queue-executor.provider.js +8 -8
  450. package/dist/components/mail/providers/mail-queue-executor.provider.js.map +1 -1
  451. package/dist/components/mail/providers/mail-transporter.provider.d.ts.map +1 -1
  452. package/dist/components/mail/providers/mail-transporter.provider.js +6 -6
  453. package/dist/components/mail/providers/mail-transporter.provider.js.map +1 -1
  454. package/dist/components/mail/services/mail.service.d.ts +1 -1
  455. package/dist/components/mail/services/mail.service.d.ts.map +1 -1
  456. package/dist/components/mail/services/mail.service.js +9 -9
  457. package/dist/components/mail/services/mail.service.js.map +1 -1
  458. package/dist/components/mail/services/template.service.d.ts +1 -1
  459. package/dist/components/mail/services/template.service.d.ts.map +1 -1
  460. package/dist/components/mail/services/template.service.js +4 -4
  461. package/dist/components/mail/services/template.service.js.map +1 -1
  462. package/dist/components/mail/utilities/type.utility.d.ts +1 -1
  463. package/dist/components/mail/utilities/type.utility.d.ts.map +1 -1
  464. package/dist/components/socket-io/common/types.d.ts +2 -1
  465. package/dist/components/socket-io/common/types.d.ts.map +1 -1
  466. package/dist/components/socket-io/component.d.ts.map +1 -1
  467. package/dist/components/socket-io/component.js +2 -5
  468. package/dist/components/socket-io/component.js.map +1 -1
  469. package/dist/components/socket-io/handlers/node.handler.d.ts +1 -1
  470. package/dist/components/socket-io/handlers/node.handler.d.ts.map +1 -1
  471. package/dist/components/socket-io/handlers/node.handler.js +2 -1
  472. package/dist/components/socket-io/handlers/node.handler.js.map +1 -1
  473. package/dist/components/static-asset/common/constants.d.ts +1 -0
  474. package/dist/components/static-asset/common/constants.d.ts.map +1 -1
  475. package/dist/components/static-asset/common/constants.js +2 -1
  476. package/dist/components/static-asset/common/constants.js.map +1 -1
  477. package/dist/components/static-asset/common/types.d.ts +44 -1
  478. package/dist/components/static-asset/common/types.d.ts.map +1 -1
  479. package/dist/components/static-asset/controller/base.definition.d.ts +81 -80
  480. package/dist/components/static-asset/controller/base.definition.d.ts.map +1 -1
  481. package/dist/components/static-asset/controller/base.definition.js +1 -2
  482. package/dist/components/static-asset/controller/base.definition.js.map +1 -1
  483. package/dist/components/static-asset/controller/factory.d.ts +8 -12
  484. package/dist/components/static-asset/controller/factory.d.ts.map +1 -1
  485. package/dist/components/static-asset/controller/factory.js +41 -42
  486. package/dist/components/static-asset/controller/factory.js.map +1 -1
  487. package/dist/components/static-asset/models/base.model.d.ts +49 -19
  488. package/dist/components/static-asset/models/base.model.d.ts.map +1 -1
  489. package/dist/components/static-asset/models/base.model.js +3 -7
  490. package/dist/components/static-asset/models/base.model.js.map +1 -1
  491. package/dist/components/swagger/ui-factory.d.ts.map +1 -1
  492. package/dist/components/swagger/ui-factory.js +0 -2
  493. package/dist/components/swagger/ui-factory.js.map +1 -1
  494. package/dist/components/websocket/component.d.ts.map +1 -1
  495. package/dist/components/websocket/component.js +0 -3
  496. package/dist/components/websocket/component.js.map +1 -1
  497. package/dist/helpers/base-helper.d.ts +2 -0
  498. package/dist/helpers/base-helper.d.ts.map +1 -0
  499. package/dist/helpers/base-helper.js +6 -0
  500. package/dist/helpers/base-helper.js.map +1 -0
  501. package/dist/helpers/index.d.ts +2 -1
  502. package/dist/helpers/index.d.ts.map +1 -1
  503. package/dist/helpers/index.js +1 -1
  504. package/dist/helpers/index.js.map +1 -1
  505. package/dist/helpers/inversion/common/keys.d.ts.map +1 -1
  506. package/dist/helpers/inversion/common/keys.js +0 -2
  507. package/dist/helpers/inversion/common/keys.js.map +1 -1
  508. package/dist/helpers/inversion/common/types.d.ts +18 -56
  509. package/dist/helpers/inversion/common/types.d.ts.map +1 -1
  510. package/dist/helpers/inversion/container.d.ts.map +1 -1
  511. package/dist/helpers/inversion/container.js +0 -1
  512. package/dist/helpers/inversion/container.js.map +1 -1
  513. package/dist/helpers/inversion/index.d.ts +1 -1
  514. package/dist/helpers/inversion/index.d.ts.map +1 -1
  515. package/dist/helpers/inversion/index.js +5 -1
  516. package/dist/helpers/inversion/index.js.map +1 -1
  517. package/dist/helpers/inversion/mixins/controller.mixin.d.ts.map +1 -1
  518. package/dist/helpers/inversion/mixins/controller.mixin.js +0 -3
  519. package/dist/helpers/inversion/mixins/controller.mixin.js.map +1 -1
  520. package/dist/helpers/inversion/mixins/datasource.mixin.d.ts.map +1 -1
  521. package/dist/helpers/inversion/mixins/datasource.mixin.js +0 -3
  522. package/dist/helpers/inversion/mixins/datasource.mixin.js.map +1 -1
  523. package/dist/helpers/inversion/mixins/model.mixin.d.ts +29 -1
  524. package/dist/helpers/inversion/mixins/model.mixin.d.ts.map +1 -1
  525. package/dist/helpers/inversion/mixins/model.mixin.js +66 -2
  526. package/dist/helpers/inversion/mixins/model.mixin.js.map +1 -1
  527. package/dist/helpers/inversion/mixins/repository.mixin.d.ts.map +1 -1
  528. package/dist/helpers/inversion/mixins/repository.mixin.js +0 -2
  529. package/dist/helpers/inversion/mixins/repository.mixin.js.map +1 -1
  530. package/dist/helpers/inversion/registry.d.ts +22 -0
  531. package/dist/helpers/inversion/registry.d.ts.map +1 -1
  532. package/dist/utilities/jsx.utility.d.ts +2 -16
  533. package/dist/utilities/jsx.utility.d.ts.map +1 -1
  534. package/dist/utilities/jsx.utility.js +2 -16
  535. package/dist/utilities/jsx.utility.js.map +1 -1
  536. package/dist/utilities/schema.utility.d.ts.map +1 -1
  537. package/dist/utilities/schema.utility.js +0 -2
  538. package/dist/utilities/schema.utility.js.map +1 -1
  539. package/package.json +117 -77
  540. package/dist/components/auth/authenticate/services/basic-token.service.d.ts +0 -60
  541. package/dist/components/auth/authenticate/services/basic-token.service.d.ts.map +0 -1
  542. package/dist/components/auth/authenticate/services/basic-token.service.js.map +0 -1
  543. package/dist/components/auth/authenticate/services/jwt-token.service.d.ts +0 -34
  544. package/dist/components/auth/authenticate/services/jwt-token.service.d.ts.map +0 -1
  545. package/dist/components/auth/authenticate/services/jwt-token.service.js +0 -219
  546. package/dist/components/auth/authenticate/services/jwt-token.service.js.map +0 -1
  547. package/dist/components/auth/authenticate/strategies/jwt.strategy.d.ts.map +0 -1
  548. package/dist/components/auth/authenticate/strategies/jwt.strategy.js.map +0 -1
  549. package/dist/components/auth/authorize/middleware.d.ts +0 -2
  550. package/dist/components/auth/authorize/middleware.d.ts.map +0 -1
  551. package/dist/components/auth/authorize/middleware.js.map +0 -1
  552. package/dist/components/auth/models/entities/permission-mapping.model.d.ts +0 -26
  553. package/dist/components/auth/models/entities/permission-mapping.model.d.ts.map +0 -1
  554. package/dist/components/auth/models/entities/permission-mapping.model.js +0 -33
  555. package/dist/components/auth/models/entities/permission-mapping.model.js.map +0 -1
  556. package/dist/components/auth/models/entities/user-role.model.d.ts +0 -17
  557. package/dist/components/auth/models/entities/user-role.model.d.ts.map +0 -1
  558. package/dist/components/auth/models/entities/user-role.model.js +0 -34
  559. package/dist/components/auth/models/entities/user-role.model.js.map +0 -1
@@ -0,0 +1,177 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AbstractBearerTokenService = void 0;
4
+ const base_1 = require("../../../../../base/services/base");
5
+ const ignis_helpers_1 = require("@venizia/ignis-helpers");
6
+ const common_1 = require("../../common");
7
+ /** Abstract base for Bearer-token services (JWS, JWKS) with optional AES payload encryption. */
8
+ class AbstractBearerTokenService extends base_1.BaseService {
9
+ constructor() {
10
+ super(...arguments);
11
+ this.aes = null;
12
+ this.applicationSecret = null;
13
+ this.fieldCodecs = new Map();
14
+ }
15
+ /** Standard JWT fields that are never encrypted. */
16
+ static { this.JWT_COMMON_FIELDS = new Set([
17
+ 'iss',
18
+ 'sub',
19
+ 'aud',
20
+ 'jti',
21
+ 'nbf',
22
+ 'exp',
23
+ 'iat',
24
+ ]); }
25
+ /** Configures AES payload encryption and field codecs. Both aesAlgorithm and applicationSecret required to activate encryption. */
26
+ configurePayloadEncryption(opts) {
27
+ const { aesAlgorithm = 'aes-256-cbc', applicationSecret, fieldCodecs } = opts;
28
+ if (fieldCodecs) {
29
+ for (const codec of fieldCodecs) {
30
+ this.fieldCodecs.set(codec.key, codec);
31
+ }
32
+ }
33
+ if (!applicationSecret) {
34
+ return;
35
+ }
36
+ this.aes = ignis_helpers_1.AES.withAlgorithm(aesAlgorithm);
37
+ this.applicationSecret = applicationSecret;
38
+ }
39
+ extractCredentials(context) {
40
+ const request = context.req;
41
+ const authHeaderValue = request.header('Authorization');
42
+ if (!authHeaderValue) {
43
+ throw (0, ignis_helpers_1.getError)({
44
+ statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_4.Unauthorized,
45
+ message: 'Unauthorized user! Missing authorization header',
46
+ });
47
+ }
48
+ if (!authHeaderValue.startsWith(common_1.Authentication.TYPE_BEARER)) {
49
+ throw (0, ignis_helpers_1.getError)({
50
+ statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_4.Unauthorized,
51
+ message: 'Unauthorized user! Invalid schema of request token!',
52
+ });
53
+ }
54
+ const parts = authHeaderValue.split(' ');
55
+ if (parts.length !== 2) {
56
+ throw (0, ignis_helpers_1.getError)({
57
+ statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_4.Unauthorized,
58
+ message: `Authorization header value is invalid format. It must follow the pattern: 'Bearer xx.yy.zz' where xx.yy.zz is a valid JWT token.`,
59
+ });
60
+ }
61
+ const [tokenType, tokenValue] = parts;
62
+ return { type: tokenType, token: tokenValue };
63
+ }
64
+ async verify(opts) {
65
+ const { token } = opts;
66
+ if (!token) {
67
+ this.logger.for(this.verify.name).error('Missing token for validating request!');
68
+ throw (0, ignis_helpers_1.getError)({
69
+ statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_4.Unauthorized,
70
+ message: '[verify] Invalid request token!',
71
+ });
72
+ }
73
+ try {
74
+ return await this.doVerify(token);
75
+ }
76
+ catch (error) {
77
+ this.logger.for(this.verify.name).error('Failed to verify token | Error: %s', error);
78
+ throw (0, ignis_helpers_1.getError)({
79
+ statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_4.Unauthorized,
80
+ message: '[verify] Invalid or expired token',
81
+ });
82
+ }
83
+ }
84
+ async generate(opts) {
85
+ const { payload, getTokenExpiresFn = this.getDefaultTokenExpiresFn() } = opts;
86
+ if (!payload) {
87
+ throw (0, ignis_helpers_1.getError)({
88
+ statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_4.Unauthorized,
89
+ message: '[generate] Invalid token payload!',
90
+ });
91
+ }
92
+ const signer = await this.getSigner({ payload, getTokenExpiresFn });
93
+ try {
94
+ const rs = await signer.sign(await this.getSigningKey());
95
+ return rs;
96
+ }
97
+ catch (error) {
98
+ this.logger.for(this.generate.name).error('Failed to generate token | Error: %s', error);
99
+ throw (0, ignis_helpers_1.getError)({
100
+ statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_5.InternalServerError,
101
+ message: '[generate] Failed to generate token',
102
+ });
103
+ }
104
+ }
105
+ serializeField(opts) {
106
+ const { key, value } = opts;
107
+ const codec = this.fieldCodecs.get(key);
108
+ if (codec) {
109
+ return codec.serialize({ value });
110
+ }
111
+ return JSON.stringify(value);
112
+ }
113
+ encryptPayload(payload) {
114
+ if (!this.aes || !this.applicationSecret) {
115
+ return payload;
116
+ }
117
+ const rs = {};
118
+ const keys = Object.keys(payload);
119
+ for (const key of keys) {
120
+ const value = payload[key];
121
+ if (AbstractBearerTokenService.JWT_COMMON_FIELDS.has(key)) {
122
+ rs[key] = value;
123
+ continue;
124
+ }
125
+ // NOTE: Skip undefined or null values because they cannot be encrypted
126
+ if (value === undefined || value === null) {
127
+ continue;
128
+ }
129
+ const encryptedKey = this.aes.encrypt({
130
+ message: key,
131
+ secret: this.applicationSecret,
132
+ });
133
+ const serialized = this.serializeField({ key, value });
134
+ rs[encryptedKey] = this.aes.encrypt({
135
+ message: serialized,
136
+ secret: this.applicationSecret,
137
+ });
138
+ }
139
+ return rs;
140
+ }
141
+ deserializeField(opts) {
142
+ const { key, value } = opts;
143
+ const codec = this.fieldCodecs.get(key);
144
+ if (codec) {
145
+ return codec.deserialize({ raw: value });
146
+ }
147
+ return JSON.parse(value);
148
+ }
149
+ decryptPayload(opts) {
150
+ const { payload, protectedHeader } = opts.result;
151
+ if (!this.aes || !this.applicationSecret) {
152
+ return payload;
153
+ }
154
+ this.logger
155
+ .for(this.decryptPayload.name)
156
+ .debug('JWT Token | payload: %j | header: %j', payload, protectedHeader);
157
+ const rs = {};
158
+ for (const key in payload) {
159
+ if (AbstractBearerTokenService.JWT_COMMON_FIELDS.has(key)) {
160
+ rs[key] = payload[key];
161
+ continue;
162
+ }
163
+ const decryptedKey = this.aes.decrypt({
164
+ message: key,
165
+ secret: this.applicationSecret,
166
+ });
167
+ const decryptedValue = this.aes.decrypt({
168
+ message: payload[key],
169
+ secret: this.applicationSecret,
170
+ });
171
+ rs[decryptedKey] = this.deserializeField({ key: decryptedKey, value: decryptedValue });
172
+ }
173
+ return rs;
174
+ }
175
+ }
176
+ exports.AbstractBearerTokenService = AbstractBearerTokenService;
177
+ //# sourceMappingURL=abstract.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"abstract.service.js","sourceRoot":"","sources":["../../../../../../src/components/auth/authenticate/services/bearer/abstract.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ export * from './abstract.service';
2
+ export * from './jwks';
3
+ export * from './jws.service';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/components/auth/authenticate/services/bearer/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,QAAQ,CAAC;AACvB,cAAc,eAAe,CAAC"}
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./abstract.service"), exports);
18
+ __exportStar(require("./jwks"), exports);
19
+ __exportStar(require("./jws.service"), exports);
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../src/components/auth/authenticate/services/bearer/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,qDAAmC;AACnC,yCAAuB;AACvB,gDAA8B"}
@@ -0,0 +1,16 @@
1
+ import { Env } from 'hono';
2
+ import { AbstractBearerTokenService } from '../abstract.service';
3
+ /**
4
+ * Base class for JWKS token services (Issuer + Verifier).
5
+ *
6
+ * Consolidates the lazy-initialization pattern with retry-on-failure semantics:
7
+ * if `initialize()` rejects, `initPromise` is reset so the next call retries
8
+ * instead of caching the failure permanently.
9
+ */
10
+ export declare abstract class AbstractJWKSTokenService<E extends Env = Env> extends AbstractBearerTokenService<E> {
11
+ protected initialized: boolean;
12
+ protected initPromise: Promise<void> | null;
13
+ protected ensureInitialized(): Promise<void>;
14
+ protected abstract initialize(): Promise<void>;
15
+ }
16
+ //# sourceMappingURL=abstract.service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"abstract.service.d.ts","sourceRoot":"","sources":["../../../../../../../src/components/auth/authenticate/services/bearer/jwks/abstract.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAC3B,OAAO,EAAE,0BAA0B,EAAE,MAAM,qBAAqB,CAAC;AAEjE;;;;;;GAMG;AACH,8BAAsB,wBAAwB,CAC5C,CAAC,SAAS,GAAG,GAAG,GAAG,CACnB,SAAQ,0BAA0B,CAAC,CAAC,CAAC;IACrC,SAAS,CAAC,WAAW,UAAS;IAC9B,SAAS,CAAC,WAAW,EAAE,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAQ;cAEnC,iBAAiB,IAAI,OAAO,CAAC,IAAI,CAAC;IAelD,SAAS,CAAC,QAAQ,CAAC,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;CAC/C"}
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AbstractJWKSTokenService = void 0;
4
+ const abstract_service_1 = require("../abstract.service");
5
+ /**
6
+ * Base class for JWKS token services (Issuer + Verifier).
7
+ *
8
+ * Consolidates the lazy-initialization pattern with retry-on-failure semantics:
9
+ * if `initialize()` rejects, `initPromise` is reset so the next call retries
10
+ * instead of caching the failure permanently.
11
+ */
12
+ class AbstractJWKSTokenService extends abstract_service_1.AbstractBearerTokenService {
13
+ constructor() {
14
+ super(...arguments);
15
+ this.initialized = false;
16
+ this.initPromise = null;
17
+ }
18
+ async ensureInitialized() {
19
+ if (this.initialized) {
20
+ return;
21
+ }
22
+ if (!this.initPromise) {
23
+ this.initPromise = this.initialize().catch(error => {
24
+ this.initPromise = null;
25
+ throw error;
26
+ });
27
+ }
28
+ await this.initPromise;
29
+ }
30
+ }
31
+ exports.AbstractJWKSTokenService = AbstractJWKSTokenService;
32
+ //# sourceMappingURL=abstract.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"abstract.service.js","sourceRoot":"","sources":["../../../../../../../src/components/auth/authenticate/services/bearer/jwks/abstract.service.ts"],"names":[],"mappings":";;;AACA,0DAAiE;AAEjE;;;;;;GAMG;AACH,MAAsB,wBAEpB,SAAQ,6CAA6B;IAFvC;;QAGY,gBAAW,GAAG,KAAK,CAAC;QACpB,gBAAW,GAAyB,IAAI,CAAC;IAkBrD,CAAC;IAhBW,KAAK,CAAC,iBAAiB;QAC/B,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,OAAO;QACT,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;gBACjD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;gBACxB,MAAM,KAAK,CAAC;YACd,CAAC,CAAC,CAAC;QACL,CAAC;QAED,MAAM,IAAI,CAAC,WAAW,CAAC;IACzB,CAAC;CAGF;AAtBD,4DAsBC"}
@@ -0,0 +1,4 @@
1
+ export * from './abstract.service';
2
+ export * from './issuer.service';
3
+ export * from './verifier.service';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../../src/components/auth/authenticate/services/bearer/jwks/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,kBAAkB,CAAC;AACjC,cAAc,oBAAoB,CAAC"}
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./abstract.service"), exports);
18
+ __exportStar(require("./issuer.service"), exports);
19
+ __exportStar(require("./verifier.service"), exports);
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../src/components/auth/authenticate/services/bearer/jwks/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,qDAAmC;AACnC,mDAAiC;AACjC,qDAAmC"}
@@ -0,0 +1,46 @@
1
+ import { TNullable, ValueOrPromise } from '@venizia/ignis-helpers';
2
+ import { Env } from 'hono';
3
+ import { CryptoKey, JWK, SignJWT } from 'jose';
4
+ import { IJWKSIssuerOptions, IJWTTokenPayload, TGetTokenExpiresFn } from '../../../common';
5
+ import { AbstractJWKSTokenService } from './abstract.service';
6
+ export declare class JWKSIssuerTokenService<E extends Env = Env> extends AbstractJWKSTokenService<E> {
7
+ protected options: IJWKSIssuerOptions;
8
+ protected privateKey: TNullable<CryptoKey | Uint8Array>;
9
+ protected publicKey: TNullable<CryptoKey | Uint8Array>;
10
+ protected jwks: {
11
+ keys: JWK[];
12
+ } | null;
13
+ constructor(options: IJWKSIssuerOptions);
14
+ protected initialize(): Promise<void>;
15
+ protected resolveKeyContent(opts: {
16
+ keys: IJWKSIssuerOptions['keys'];
17
+ }): Promise<{
18
+ priv: string;
19
+ pub: string;
20
+ }>;
21
+ protected parseKeyMaterial(opts: {
22
+ raw: {
23
+ priv: string;
24
+ pub: string;
25
+ };
26
+ algorithm: IJWKSIssuerOptions['algorithm'];
27
+ keys: IJWKSIssuerOptions['keys'];
28
+ }): Promise<{
29
+ priv: Uint8Array<ArrayBufferLike> | import("node:crypto").webcrypto.CryptoKey;
30
+ pub: Uint8Array<ArrayBufferLike> | import("node:crypto").webcrypto.CryptoKey;
31
+ }>;
32
+ protected doVerify(token: string): Promise<IJWTTokenPayload>;
33
+ getSigner(opts: {
34
+ payload: IJWTTokenPayload;
35
+ getTokenExpiresFn: TGetTokenExpiresFn;
36
+ }): Promise<SignJWT>;
37
+ protected getSigningKey(): ValueOrPromise<Uint8Array | CryptoKey>;
38
+ protected getDefaultTokenExpiresFn(): TGetTokenExpiresFn;
39
+ getJWKS(): {
40
+ keys: JWK[];
41
+ };
42
+ getJWKSAsync(): Promise<{
43
+ keys: JWK[];
44
+ }>;
45
+ }
46
+ //# sourceMappingURL=issuer.service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"issuer.service.d.ts","sourceRoot":"","sources":["../../../../../../../src/components/auth/authenticate/services/bearer/jwks/issuer.service.ts"],"names":[],"mappings":"AACA,OAAO,EAAkB,SAAS,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACnF,OAAO,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAC3B,OAAO,EACL,SAAS,EAKT,GAAG,EAEH,OAAO,EACR,MAAM,MAAM,CAAC;AAEd,OAAO,EAEL,kBAAkB,EAClB,gBAAgB,EAGhB,kBAAkB,EACnB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,wBAAwB,EAAE,MAAM,oBAAoB,CAAC;AAE9D,qBAAa,sBAAsB,CAAC,CAAC,SAAS,GAAG,GAAG,GAAG,CAAE,SAAQ,wBAAwB,CAAC,CAAC,CAAC;IAOxF,SAAS,CAAC,OAAO,EAAE,kBAAkB;IANvC,SAAS,CAAC,UAAU,EAAE,SAAS,CAAC,SAAS,GAAG,UAAU,CAAC,CAAQ;IAC/D,SAAS,CAAC,SAAS,EAAE,SAAS,CAAC,SAAS,GAAG,UAAU,CAAC,CAAQ;IAC9D,SAAS,CAAC,IAAI,EAAE;QAAE,IAAI,EAAE,GAAG,EAAE,CAAA;KAAE,GAAG,IAAI,CAAQ;gBAIlC,OAAO,EAAE,kBAAkB;cAWd,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;cA4BpC,iBAAiB,CAAC,IAAI,EAAE;QAAE,IAAI,EAAE,kBAAkB,CAAC,MAAM,CAAC,CAAA;KAAE;;;;cA0B5D,gBAAgB,CAAC,IAAI,EAAE;QACrC,GAAG,EAAE;YAAE,IAAI,EAAE,MAAM,CAAC;YAAC,GAAG,EAAE,MAAM,CAAA;SAAE,CAAC;QACnC,SAAS,EAAE,kBAAkB,CAAC,WAAW,CAAC,CAAC;QAC3C,IAAI,EAAE,kBAAkB,CAAC,MAAM,CAAC,CAAC;KAClC;;;;cAoDwB,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAM5D,SAAS,CAAC,IAAI,EAAE;QAC7B,OAAO,EAAE,gBAAgB,CAAC;QAC1B,iBAAiB,EAAE,kBAAkB,CAAC;KACvC;cAekB,aAAa,IAAI,cAAc,CAAC,UAAU,GAAG,SAAS,CAAC;cAQvD,wBAAwB,IAAI,kBAAkB;IAIjE,OAAO,IAAI;QAAE,IAAI,EAAE,GAAG,EAAE,CAAA;KAAE;IAWpB,YAAY,IAAI,OAAO,CAAC;QAAE,IAAI,EAAE,GAAG,EAAE,CAAA;KAAE,CAAC;CAI/C"}
@@ -0,0 +1,168 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ var JWKSIssuerTokenService_1;
15
+ Object.defineProperty(exports, "__esModule", { value: true });
16
+ exports.JWKSIssuerTokenService = void 0;
17
+ const injectors_1 = require("../../../../../../base/metadata/injectors");
18
+ const ignis_helpers_1 = require("@venizia/ignis-helpers");
19
+ const jose_1 = require("jose");
20
+ const promises_1 = require("node:fs/promises");
21
+ const common_1 = require("../../../common");
22
+ const abstract_service_1 = require("./abstract.service");
23
+ let JWKSIssuerTokenService = JWKSIssuerTokenService_1 = class JWKSIssuerTokenService extends abstract_service_1.AbstractJWKSTokenService {
24
+ constructor(options) {
25
+ super({ scope: JWKSIssuerTokenService_1.name });
26
+ this.options = options;
27
+ this.privateKey = null;
28
+ this.publicKey = null;
29
+ this.jwks = null;
30
+ this.configurePayloadEncryption({
31
+ aesAlgorithm: this.options.aesAlgorithm,
32
+ applicationSecret: this.options.applicationSecret,
33
+ fieldCodecs: this.options.fieldCodecs,
34
+ });
35
+ }
36
+ async initialize() {
37
+ const { keys, algorithm } = this.options;
38
+ const raw = await this.resolveKeyContent({ keys });
39
+ const built = await this.parseKeyMaterial({ raw, algorithm, keys });
40
+ this.privateKey = built.priv;
41
+ this.publicKey = built.pub;
42
+ const publicJWK = await (0, jose_1.exportJWK)(this.publicKey);
43
+ publicJWK.kid = this.options.kid;
44
+ publicJWK.alg = algorithm;
45
+ publicJWK.use = 'sig';
46
+ this.jwks = { keys: [publicJWK] };
47
+ this.initialized = true;
48
+ this.logger
49
+ .for(this.initialize.name)
50
+ .info('JWKS issuer initialized | driver: %s | format: %s | kid: %s', keys.driver, keys.format, this.options.kid);
51
+ }
52
+ async resolveKeyContent(opts) {
53
+ const { keys } = opts;
54
+ switch (keys.driver) {
55
+ case common_1.JWKSKeyDrivers.FILE: {
56
+ const [priv, pub] = await Promise.all([
57
+ (0, promises_1.readFile)(keys.private, 'utf-8'),
58
+ (0, promises_1.readFile)(keys.public, 'utf-8'),
59
+ ]);
60
+ return { priv, pub };
61
+ }
62
+ case common_1.JWKSKeyDrivers.TEXT: {
63
+ return {
64
+ priv: keys.private,
65
+ pub: keys.public,
66
+ };
67
+ }
68
+ default: {
69
+ throw (0, ignis_helpers_1.getError)({
70
+ statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_5.InternalServerError,
71
+ message: `[JWKSIssuerTokenService] Unknown key driver: ${keys.driver}`,
72
+ });
73
+ }
74
+ }
75
+ }
76
+ async parseKeyMaterial(opts) {
77
+ const { raw, algorithm, keys } = opts;
78
+ if (!raw.priv) {
79
+ throw (0, ignis_helpers_1.getError)({
80
+ statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_5.InternalServerError,
81
+ message: '[JWKSIssuerTokenService] Invalid raw.priv key!',
82
+ });
83
+ }
84
+ if (!raw.pub) {
85
+ throw (0, ignis_helpers_1.getError)({
86
+ statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_5.InternalServerError,
87
+ message: '[JWKSIssuerTokenService] Invalid raw.pub key!',
88
+ });
89
+ }
90
+ switch (keys.format) {
91
+ case common_1.JWKSKeyFormats.PEM: {
92
+ const priv = await (0, jose_1.importPKCS8)(raw.priv, algorithm);
93
+ const pub = await (0, jose_1.importSPKI)(raw.pub, algorithm);
94
+ return { priv, pub };
95
+ }
96
+ case common_1.JWKSKeyFormats.JWK: {
97
+ try {
98
+ const parsed = {
99
+ priv: JSON.parse(raw.priv),
100
+ pub: JSON.parse(raw.pub),
101
+ };
102
+ const priv = await (0, jose_1.importJWK)(parsed.priv, algorithm);
103
+ const pub = await (0, jose_1.importJWK)(parsed.pub, algorithm);
104
+ return { priv, pub };
105
+ }
106
+ catch (error) {
107
+ this.logger
108
+ .for(this.parseKeyMaterial.name)
109
+ .error('Invalid JWK key material | Error: %s', error);
110
+ throw (0, ignis_helpers_1.getError)({
111
+ statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_5.InternalServerError,
112
+ message: '[JWKSIssuerTokenService] Invalid JWK key material',
113
+ });
114
+ }
115
+ }
116
+ default: {
117
+ throw (0, ignis_helpers_1.getError)({
118
+ statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_5.InternalServerError,
119
+ message: `[JWKSIssuerTokenService] Unknown key format: ${keys.format}`,
120
+ });
121
+ }
122
+ }
123
+ }
124
+ async doVerify(token) {
125
+ await this.ensureInitialized();
126
+ const result = await (0, jose_1.jwtVerify)(token, this.publicKey);
127
+ return this.decryptPayload({ result });
128
+ }
129
+ async getSigner(opts) {
130
+ await this.ensureInitialized();
131
+ const now = Math.floor(Date.now() / 1000);
132
+ const expiresIn = await opts.getTokenExpiresFn();
133
+ const encryptedPayload = this.encryptPayload(opts.payload);
134
+ return new jose_1.SignJWT({ ...encryptedPayload })
135
+ .setProtectedHeader({ alg: this.options.algorithm, kid: this.options.kid })
136
+ .setIssuedAt()
137
+ .setExpirationTime(now + expiresIn)
138
+ .setNotBefore(now);
139
+ }
140
+ getSigningKey() {
141
+ if (!this.privateKey) {
142
+ throw (0, ignis_helpers_1.getError)({ message: '[getSigningKey] Invalid privateKey!' });
143
+ }
144
+ return this.privateKey;
145
+ }
146
+ getDefaultTokenExpiresFn() {
147
+ return this.options.getTokenExpiresFn;
148
+ }
149
+ getJWKS() {
150
+ if (!this.jwks) {
151
+ throw (0, ignis_helpers_1.getError)({
152
+ statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_5.InternalServerError,
153
+ message: '[JWKSIssuerTokenService] JWKS not initialized yet. Call getJWKSAsync() instead.',
154
+ });
155
+ }
156
+ return this.jwks;
157
+ }
158
+ async getJWKSAsync() {
159
+ await this.ensureInitialized();
160
+ return this.jwks;
161
+ }
162
+ };
163
+ exports.JWKSIssuerTokenService = JWKSIssuerTokenService;
164
+ exports.JWKSIssuerTokenService = JWKSIssuerTokenService = JWKSIssuerTokenService_1 = __decorate([
165
+ __param(0, (0, injectors_1.inject)({ key: common_1.AuthenticateBindingKeys.JWKS_OPTIONS })),
166
+ __metadata("design:paramtypes", [Object])
167
+ ], JWKSIssuerTokenService);
168
+ //# sourceMappingURL=issuer.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"issuer.service.js","sourceRoot":"","sources":["../../../../../../../src/components/auth/authenticate/services/bearer/jwks/issuer.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import { Env } from 'hono';
2
+ import { createRemoteJWKSet, SignJWT } from 'jose';
3
+ import { IJWKSVerifierOptions, IJWTTokenPayload, TGetTokenExpiresFn } from '../../../common';
4
+ import { AbstractJWKSTokenService } from './abstract.service';
5
+ export declare class JWKSVerifierTokenService<E extends Env = Env> extends AbstractJWKSTokenService<E> {
6
+ protected options: IJWKSVerifierOptions;
7
+ protected jwksVerifier: ReturnType<typeof createRemoteJWKSet> | null;
8
+ constructor(options: IJWKSVerifierOptions);
9
+ protected initialize(): Promise<void>;
10
+ protected doVerify(token: string): Promise<IJWTTokenPayload>;
11
+ getSigner(_opts: {
12
+ payload: IJWTTokenPayload;
13
+ getTokenExpiresFn: TGetTokenExpiresFn;
14
+ }): Promise<SignJWT>;
15
+ protected getSigningKey(): never;
16
+ protected getDefaultTokenExpiresFn(): never;
17
+ }
18
+ //# sourceMappingURL=verifier.service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"verifier.service.d.ts","sourceRoot":"","sources":["../../../../../../../src/components/auth/authenticate/services/bearer/jwks/verifier.service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAC3B,OAAO,EAAE,kBAAkB,EAAa,OAAO,EAAE,MAAM,MAAM,CAAC;AAC9D,OAAO,EAEL,oBAAoB,EACpB,gBAAgB,EAChB,kBAAkB,EACnB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,wBAAwB,EAAE,MAAM,oBAAoB,CAAC;AAE9D,qBAAa,wBAAwB,CAAC,CAAC,SAAS,GAAG,GAAG,GAAG,CAAE,SAAQ,wBAAwB,CAAC,CAAC,CAAC;IAK1F,SAAS,CAAC,OAAO,EAAE,oBAAoB;IAJzC,SAAS,CAAC,YAAY,EAAE,UAAU,CAAC,OAAO,kBAAkB,CAAC,GAAG,IAAI,CAAQ;gBAIhE,OAAO,EAAE,oBAAoB;cAUhB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;cAc3B,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAM5D,SAAS,CAAC,KAAK,EAAE;QAC9B,OAAO,EAAE,gBAAgB,CAAC;QAC1B,iBAAiB,EAAE,kBAAkB,CAAC;KACvC,GAAG,OAAO,CAAC,OAAO,CAAC;cAOD,aAAa,IAAI,KAAK;cAOtB,wBAAwB,IAAI,KAAK;CAMrD"}
@@ -0,0 +1,73 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ var JWKSVerifierTokenService_1;
15
+ Object.defineProperty(exports, "__esModule", { value: true });
16
+ exports.JWKSVerifierTokenService = void 0;
17
+ const injectors_1 = require("../../../../../../base/metadata/injectors");
18
+ const ignis_helpers_1 = require("@venizia/ignis-helpers");
19
+ const jose_1 = require("jose");
20
+ const common_1 = require("../../../common");
21
+ const abstract_service_1 = require("./abstract.service");
22
+ let JWKSVerifierTokenService = JWKSVerifierTokenService_1 = class JWKSVerifierTokenService extends abstract_service_1.AbstractJWKSTokenService {
23
+ constructor(options) {
24
+ super({ scope: JWKSVerifierTokenService_1.name });
25
+ this.options = options;
26
+ this.jwksVerifier = null;
27
+ this.configurePayloadEncryption({
28
+ aesAlgorithm: this.options.aesAlgorithm,
29
+ applicationSecret: this.options.applicationSecret,
30
+ fieldCodecs: this.options.fieldCodecs,
31
+ });
32
+ }
33
+ async initialize() {
34
+ const jwksUrl = new URL(this.options.jwksUrl);
35
+ this.jwksVerifier = (0, jose_1.createRemoteJWKSet)(jwksUrl, {
36
+ cacheMaxAge: this.options.cacheTtlMs ?? 43_200_000,
37
+ cooldownDuration: this.options.cooldownMs ?? 30_000,
38
+ });
39
+ this.initialized = true;
40
+ this.logger
41
+ .for(this.initialize.name)
42
+ .info('JWKS verifier initialized | url: %s', this.options.jwksUrl);
43
+ }
44
+ async doVerify(token) {
45
+ await this.ensureInitialized();
46
+ const result = await (0, jose_1.jwtVerify)(token, this.jwksVerifier);
47
+ return this.decryptPayload({ result });
48
+ }
49
+ async getSigner(_opts) {
50
+ throw (0, ignis_helpers_1.getError)({
51
+ statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_5.InternalServerError,
52
+ message: '[JWKSVerifierTokenService] Verifier mode cannot sign tokens',
53
+ });
54
+ }
55
+ getSigningKey() {
56
+ throw (0, ignis_helpers_1.getError)({
57
+ statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_5.InternalServerError,
58
+ message: '[JWKSVerifierTokenService] Verifier mode cannot sign tokens',
59
+ });
60
+ }
61
+ getDefaultTokenExpiresFn() {
62
+ throw (0, ignis_helpers_1.getError)({
63
+ statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_5.InternalServerError,
64
+ message: '[JWKSVerifierTokenService] Verifier mode has no token expiry',
65
+ });
66
+ }
67
+ };
68
+ exports.JWKSVerifierTokenService = JWKSVerifierTokenService;
69
+ exports.JWKSVerifierTokenService = JWKSVerifierTokenService = JWKSVerifierTokenService_1 = __decorate([
70
+ __param(0, (0, injectors_1.inject)({ key: common_1.AuthenticateBindingKeys.JWKS_OPTIONS })),
71
+ __metadata("design:paramtypes", [Object])
72
+ ], JWKSVerifierTokenService);
73
+ //# sourceMappingURL=verifier.service.js.map