@webiny/api-core 0.0.0-unstable.61c048f412

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 (1214) hide show
  1. package/ApiCoreFeature.d.ts +2 -0
  2. package/ApiCoreFeature.js +27 -0
  3. package/ApiCoreFeature.js.map +1 -0
  4. package/LICENSE +21 -0
  5. package/README.md +11 -0
  6. package/createApiCore.d.ts +7 -0
  7. package/createApiCore.js +17 -0
  8. package/createApiCore.js.map +1 -0
  9. package/domain/identity/SystemIdentityValue.d.ts +7 -0
  10. package/domain/identity/SystemIdentityValue.js +11 -0
  11. package/domain/identity/SystemIdentityValue.js.map +1 -0
  12. package/domain/security/ApiToken.d.ts +7 -0
  13. package/domain/security/ApiToken.js +14 -0
  14. package/domain/security/ApiToken.js.map +1 -0
  15. package/domain/tenancy/RootTenantValue.d.ts +4 -0
  16. package/domain/tenancy/RootTenantValue.js +11 -0
  17. package/domain/tenancy/RootTenantValue.js.map +1 -0
  18. package/domain/tenancy/errors.d.ts +0 -0
  19. package/domain/tenancy/errors.js +3 -0
  20. package/domain/tenancy/errors.js.map +1 -0
  21. package/exports/api/buildParams.d.ts +1 -0
  22. package/exports/api/buildParams.js +3 -0
  23. package/exports/api/buildParams.js.map +1 -0
  24. package/exports/api/eventPublisher.d.ts +1 -0
  25. package/exports/api/eventPublisher.js +3 -0
  26. package/exports/api/eventPublisher.js.map +1 -0
  27. package/exports/api/graphql.d.ts +1 -0
  28. package/exports/api/graphql.js +3 -0
  29. package/exports/api/graphql.js.map +1 -0
  30. package/exports/api/keyValueStore.d.ts +1 -0
  31. package/exports/api/keyValueStore.js +3 -0
  32. package/exports/api/keyValueStore.js.map +1 -0
  33. package/exports/api/logger.d.ts +1 -0
  34. package/exports/api/logger.js +3 -0
  35. package/exports/api/logger.js.map +1 -0
  36. package/exports/api/security/apiKey.d.ts +7 -0
  37. package/exports/api/security/apiKey.js +9 -0
  38. package/exports/api/security/apiKey.js.map +1 -0
  39. package/exports/api/security/authentication.d.ts +1 -0
  40. package/exports/api/security/authentication.js +3 -0
  41. package/exports/api/security/authentication.js.map +1 -0
  42. package/exports/api/security/role.d.ts +5 -0
  43. package/exports/api/security/role.js +7 -0
  44. package/exports/api/security/role.js.map +1 -0
  45. package/exports/api/security/user.d.ts +6 -0
  46. package/exports/api/security/user.js +8 -0
  47. package/exports/api/security/user.js.map +1 -0
  48. package/exports/api/security.d.ts +6 -0
  49. package/exports/api/security.js +8 -0
  50. package/exports/api/security.js.map +1 -0
  51. package/exports/api/system.d.ts +1 -0
  52. package/exports/api/system.js +3 -0
  53. package/exports/api/system.js.map +1 -0
  54. package/exports/api/tasks.d.ts +2 -0
  55. package/exports/api/tasks.js +4 -0
  56. package/exports/api/tasks.js.map +1 -0
  57. package/exports/api/tenancy.d.ts +6 -0
  58. package/exports/api/tenancy.js +8 -0
  59. package/exports/api/tenancy.js.map +1 -0
  60. package/extensions/BuildParam.d.ts +11 -0
  61. package/extensions/BuildParam.js +119 -0
  62. package/extensions/BuildParam.js.map +1 -0
  63. package/extensions/GenericExtension.d.ts +10 -0
  64. package/extensions/GenericExtension.js +7 -0
  65. package/extensions/GenericExtension.js.map +1 -0
  66. package/extensions/eventHandlers/AfterAuthentication.d.ts +10 -0
  67. package/extensions/eventHandlers/AfterAuthentication.js +9 -0
  68. package/extensions/eventHandlers/AfterAuthentication.js.map +1 -0
  69. package/extensions/eventHandlers/ApiKeyAfterCreate.d.ts +10 -0
  70. package/extensions/eventHandlers/ApiKeyAfterCreate.js +9 -0
  71. package/extensions/eventHandlers/ApiKeyAfterCreate.js.map +1 -0
  72. package/extensions/eventHandlers/ApiKeyAfterDelete.d.ts +10 -0
  73. package/extensions/eventHandlers/ApiKeyAfterDelete.js +9 -0
  74. package/extensions/eventHandlers/ApiKeyAfterDelete.js.map +1 -0
  75. package/extensions/eventHandlers/ApiKeyAfterUpdate.d.ts +10 -0
  76. package/extensions/eventHandlers/ApiKeyAfterUpdate.js +9 -0
  77. package/extensions/eventHandlers/ApiKeyAfterUpdate.js.map +1 -0
  78. package/extensions/eventHandlers/ApiKeyBeforeCreate.d.ts +10 -0
  79. package/extensions/eventHandlers/ApiKeyBeforeCreate.js +9 -0
  80. package/extensions/eventHandlers/ApiKeyBeforeCreate.js.map +1 -0
  81. package/extensions/eventHandlers/ApiKeyBeforeDelete.d.ts +10 -0
  82. package/extensions/eventHandlers/ApiKeyBeforeDelete.js +9 -0
  83. package/extensions/eventHandlers/ApiKeyBeforeDelete.js.map +1 -0
  84. package/extensions/eventHandlers/ApiKeyBeforeUpdate.d.ts +10 -0
  85. package/extensions/eventHandlers/ApiKeyBeforeUpdate.js +9 -0
  86. package/extensions/eventHandlers/ApiKeyBeforeUpdate.js.map +1 -0
  87. package/extensions/eventHandlers/BeforeAuthentication.d.ts +10 -0
  88. package/extensions/eventHandlers/BeforeAuthentication.js +9 -0
  89. package/extensions/eventHandlers/BeforeAuthentication.js.map +1 -0
  90. package/extensions/eventHandlers/RoleAfterCreate.d.ts +10 -0
  91. package/extensions/eventHandlers/RoleAfterCreate.js +9 -0
  92. package/extensions/eventHandlers/RoleAfterCreate.js.map +1 -0
  93. package/extensions/eventHandlers/RoleAfterDelete.d.ts +10 -0
  94. package/extensions/eventHandlers/RoleAfterDelete.js +9 -0
  95. package/extensions/eventHandlers/RoleAfterDelete.js.map +1 -0
  96. package/extensions/eventHandlers/RoleAfterUpdate.d.ts +10 -0
  97. package/extensions/eventHandlers/RoleAfterUpdate.js +9 -0
  98. package/extensions/eventHandlers/RoleAfterUpdate.js.map +1 -0
  99. package/extensions/eventHandlers/RoleBeforeCreate.d.ts +10 -0
  100. package/extensions/eventHandlers/RoleBeforeCreate.js +9 -0
  101. package/extensions/eventHandlers/RoleBeforeCreate.js.map +1 -0
  102. package/extensions/eventHandlers/RoleBeforeDelete.d.ts +10 -0
  103. package/extensions/eventHandlers/RoleBeforeDelete.js +9 -0
  104. package/extensions/eventHandlers/RoleBeforeDelete.js.map +1 -0
  105. package/extensions/eventHandlers/RoleBeforeUpdate.d.ts +10 -0
  106. package/extensions/eventHandlers/RoleBeforeUpdate.js +9 -0
  107. package/extensions/eventHandlers/RoleBeforeUpdate.js.map +1 -0
  108. package/extensions/eventHandlers/SystemInstalled.d.ts +10 -0
  109. package/extensions/eventHandlers/SystemInstalled.js +9 -0
  110. package/extensions/eventHandlers/SystemInstalled.js.map +1 -0
  111. package/extensions/eventHandlers/TeamAfterCreate.d.ts +10 -0
  112. package/extensions/eventHandlers/TeamAfterCreate.js +9 -0
  113. package/extensions/eventHandlers/TeamAfterCreate.js.map +1 -0
  114. package/extensions/eventHandlers/TeamAfterDelete.d.ts +10 -0
  115. package/extensions/eventHandlers/TeamAfterDelete.js +9 -0
  116. package/extensions/eventHandlers/TeamAfterDelete.js.map +1 -0
  117. package/extensions/eventHandlers/TeamAfterUpdate.d.ts +10 -0
  118. package/extensions/eventHandlers/TeamAfterUpdate.js +9 -0
  119. package/extensions/eventHandlers/TeamAfterUpdate.js.map +1 -0
  120. package/extensions/eventHandlers/TeamBeforeCreate.d.ts +10 -0
  121. package/extensions/eventHandlers/TeamBeforeCreate.js +9 -0
  122. package/extensions/eventHandlers/TeamBeforeCreate.js.map +1 -0
  123. package/extensions/eventHandlers/TeamBeforeDelete.d.ts +10 -0
  124. package/extensions/eventHandlers/TeamBeforeDelete.js +9 -0
  125. package/extensions/eventHandlers/TeamBeforeDelete.js.map +1 -0
  126. package/extensions/eventHandlers/TeamBeforeUpdate.d.ts +10 -0
  127. package/extensions/eventHandlers/TeamBeforeUpdate.js +9 -0
  128. package/extensions/eventHandlers/TeamBeforeUpdate.js.map +1 -0
  129. package/extensions/eventHandlers/TenantAfterCreate.d.ts +10 -0
  130. package/extensions/eventHandlers/TenantAfterCreate.js +9 -0
  131. package/extensions/eventHandlers/TenantAfterCreate.js.map +1 -0
  132. package/extensions/eventHandlers/TenantAfterDelete.d.ts +10 -0
  133. package/extensions/eventHandlers/TenantAfterDelete.js +9 -0
  134. package/extensions/eventHandlers/TenantAfterDelete.js.map +1 -0
  135. package/extensions/eventHandlers/TenantAfterUpdate.d.ts +10 -0
  136. package/extensions/eventHandlers/TenantAfterUpdate.js +9 -0
  137. package/extensions/eventHandlers/TenantAfterUpdate.js.map +1 -0
  138. package/extensions/eventHandlers/TenantBeforeCreate.d.ts +10 -0
  139. package/extensions/eventHandlers/TenantBeforeCreate.js +9 -0
  140. package/extensions/eventHandlers/TenantBeforeCreate.js.map +1 -0
  141. package/extensions/eventHandlers/TenantBeforeDelete.d.ts +10 -0
  142. package/extensions/eventHandlers/TenantBeforeDelete.js +9 -0
  143. package/extensions/eventHandlers/TenantBeforeDelete.js.map +1 -0
  144. package/extensions/eventHandlers/TenantBeforeUpdate.d.ts +10 -0
  145. package/extensions/eventHandlers/TenantBeforeUpdate.js +9 -0
  146. package/extensions/eventHandlers/TenantBeforeUpdate.js.map +1 -0
  147. package/extensions/eventHandlers/TenantInstalled.d.ts +10 -0
  148. package/extensions/eventHandlers/TenantInstalled.js +9 -0
  149. package/extensions/eventHandlers/TenantInstalled.js.map +1 -0
  150. package/extensions/eventHandlers/UserAfterCreate.d.ts +10 -0
  151. package/extensions/eventHandlers/UserAfterCreate.js +9 -0
  152. package/extensions/eventHandlers/UserAfterCreate.js.map +1 -0
  153. package/extensions/eventHandlers/UserAfterDelete.d.ts +10 -0
  154. package/extensions/eventHandlers/UserAfterDelete.js +9 -0
  155. package/extensions/eventHandlers/UserAfterDelete.js.map +1 -0
  156. package/extensions/eventHandlers/UserAfterUpdate.d.ts +10 -0
  157. package/extensions/eventHandlers/UserAfterUpdate.js +9 -0
  158. package/extensions/eventHandlers/UserAfterUpdate.js.map +1 -0
  159. package/extensions/eventHandlers/UserBeforeCreate.d.ts +10 -0
  160. package/extensions/eventHandlers/UserBeforeCreate.js +9 -0
  161. package/extensions/eventHandlers/UserBeforeCreate.js.map +1 -0
  162. package/extensions/eventHandlers/UserBeforeDelete.d.ts +10 -0
  163. package/extensions/eventHandlers/UserBeforeDelete.js +9 -0
  164. package/extensions/eventHandlers/UserBeforeDelete.js.map +1 -0
  165. package/extensions/eventHandlers/UserBeforeUpdate.d.ts +10 -0
  166. package/extensions/eventHandlers/UserBeforeUpdate.js +9 -0
  167. package/extensions/eventHandlers/UserBeforeUpdate.js.map +1 -0
  168. package/extensions/eventHandlers/index.d.ts +34 -0
  169. package/extensions/eventHandlers/index.js +49 -0
  170. package/extensions/eventHandlers/index.js.map +1 -0
  171. package/extensions/index.d.ts +58 -0
  172. package/extensions/index.js +49 -0
  173. package/extensions/index.js.map +1 -0
  174. package/features/buildParams/BuildParams.d.ts +9 -0
  175. package/features/buildParams/BuildParams.js +18 -0
  176. package/features/buildParams/BuildParams.js.map +1 -0
  177. package/features/buildParams/abstractions.d.ts +15 -0
  178. package/features/buildParams/abstractions.js +5 -0
  179. package/features/buildParams/abstractions.js.map +1 -0
  180. package/features/buildParams/feature.d.ts +1 -0
  181. package/features/buildParams/feature.js +10 -0
  182. package/features/buildParams/feature.js.map +1 -0
  183. package/features/buildParams/index.d.ts +1 -0
  184. package/features/buildParams/index.js +3 -0
  185. package/features/buildParams/index.js.map +1 -0
  186. package/features/eventPublisher/EventPublisher.d.ts +7 -0
  187. package/features/eventPublisher/EventPublisher.js +19 -0
  188. package/features/eventPublisher/EventPublisher.js.map +1 -0
  189. package/features/eventPublisher/__tests__/EventPublisher.test.d.ts +92 -0
  190. package/features/eventPublisher/__tests__/EventPublisher.test.js +463 -0
  191. package/features/eventPublisher/__tests__/EventPublisher.test.js.map +1 -0
  192. package/features/eventPublisher/abstractions.d.ts +18 -0
  193. package/features/eventPublisher/abstractions.js +14 -0
  194. package/features/eventPublisher/abstractions.js.map +1 -0
  195. package/features/eventPublisher/feature.d.ts +1 -0
  196. package/features/eventPublisher/feature.js +11 -0
  197. package/features/eventPublisher/feature.js.map +1 -0
  198. package/features/eventPublisher/index.d.ts +1 -0
  199. package/features/eventPublisher/index.js +3 -0
  200. package/features/eventPublisher/index.js.map +1 -0
  201. package/features/keyValueStore/GlobalKeyValueStore.d.ts +12 -0
  202. package/features/keyValueStore/GlobalKeyValueStore.js +30 -0
  203. package/features/keyValueStore/GlobalKeyValueStore.js.map +1 -0
  204. package/features/keyValueStore/KeyValueStore.d.ts +16 -0
  205. package/features/keyValueStore/KeyValueStore.js +33 -0
  206. package/features/keyValueStore/KeyValueStore.js.map +1 -0
  207. package/features/keyValueStore/KeyValueStoreRepository.d.ts +17 -0
  208. package/features/keyValueStore/KeyValueStoreRepository.js +50 -0
  209. package/features/keyValueStore/KeyValueStoreRepository.js.map +1 -0
  210. package/features/keyValueStore/abstractions.d.ts +58 -0
  211. package/features/keyValueStore/abstractions.js +19 -0
  212. package/features/keyValueStore/abstractions.js.map +1 -0
  213. package/features/keyValueStore/errors.d.ts +11 -0
  214. package/features/keyValueStore/errors.js +22 -0
  215. package/features/keyValueStore/errors.js.map +1 -0
  216. package/features/keyValueStore/feature.d.ts +1 -0
  217. package/features/keyValueStore/feature.js +17 -0
  218. package/features/keyValueStore/feature.js.map +1 -0
  219. package/features/keyValueStore/index.d.ts +2 -0
  220. package/features/keyValueStore/index.js +4 -0
  221. package/features/keyValueStore/index.js.map +1 -0
  222. package/features/logger/LoggerService.d.ts +14 -0
  223. package/features/logger/LoggerService.js +52 -0
  224. package/features/logger/LoggerService.js.map +1 -0
  225. package/features/logger/abstractions.d.ts +13 -0
  226. package/features/logger/abstractions.js +4 -0
  227. package/features/logger/abstractions.js.map +1 -0
  228. package/features/logger/feature.d.ts +1 -0
  229. package/features/logger/feature.js +10 -0
  230. package/features/logger/feature.js.map +1 -0
  231. package/features/logger/index.d.ts +1 -0
  232. package/features/logger/index.js +3 -0
  233. package/features/logger/index.js.map +1 -0
  234. package/features/security/IdentityContext/AnonymousIdentity.d.ts +9 -0
  235. package/features/security/IdentityContext/AnonymousIdentity.js +20 -0
  236. package/features/security/IdentityContext/AnonymousIdentity.js.map +1 -0
  237. package/features/security/IdentityContext/AuthenticatedIdentity.d.ts +7 -0
  238. package/features/security/IdentityContext/AuthenticatedIdentity.js +12 -0
  239. package/features/security/IdentityContext/AuthenticatedIdentity.js.map +1 -0
  240. package/features/security/IdentityContext/Identity.d.ts +79 -0
  241. package/features/security/IdentityContext/Identity.js +76 -0
  242. package/features/security/IdentityContext/Identity.js.map +1 -0
  243. package/features/security/IdentityContext/IdentityContext.d.ts +23 -0
  244. package/features/security/IdentityContext/IdentityContext.js +125 -0
  245. package/features/security/IdentityContext/IdentityContext.js.map +1 -0
  246. package/features/security/IdentityContext/abstractions.d.ts +17 -0
  247. package/features/security/IdentityContext/abstractions.js +4 -0
  248. package/features/security/IdentityContext/abstractions.js.map +1 -0
  249. package/features/security/IdentityContext/feature.d.ts +1 -0
  250. package/features/security/IdentityContext/feature.js +10 -0
  251. package/features/security/IdentityContext/feature.js.map +1 -0
  252. package/features/security/IdentityContext/index.d.ts +6 -0
  253. package/features/security/IdentityContext/index.js +8 -0
  254. package/features/security/IdentityContext/index.js.map +1 -0
  255. package/features/security/SecurityFeature.d.ts +9 -0
  256. package/features/security/SecurityFeature.js +33 -0
  257. package/features/security/SecurityFeature.js.map +1 -0
  258. package/features/security/apiKeys/CreateApiKey/CreateApiKeyUseCase.d.ts +17 -0
  259. package/features/security/apiKeys/CreateApiKey/CreateApiKeyUseCase.js +63 -0
  260. package/features/security/apiKeys/CreateApiKey/CreateApiKeyUseCase.js.map +1 -0
  261. package/features/security/apiKeys/CreateApiKey/abstractions.d.ts +26 -0
  262. package/features/security/apiKeys/CreateApiKey/abstractions.js +4 -0
  263. package/features/security/apiKeys/CreateApiKey/abstractions.js.map +1 -0
  264. package/features/security/apiKeys/CreateApiKey/events.d.ts +21 -0
  265. package/features/security/apiKeys/CreateApiKey/events.js +18 -0
  266. package/features/security/apiKeys/CreateApiKey/events.js.map +1 -0
  267. package/features/security/apiKeys/CreateApiKey/feature.d.ts +1 -0
  268. package/features/security/apiKeys/CreateApiKey/feature.js +10 -0
  269. package/features/security/apiKeys/CreateApiKey/feature.js.map +1 -0
  270. package/features/security/apiKeys/CreateApiKey/index.d.ts +2 -0
  271. package/features/security/apiKeys/CreateApiKey/index.js +4 -0
  272. package/features/security/apiKeys/CreateApiKey/index.js.map +1 -0
  273. package/features/security/apiKeys/DeleteApiKey/DeleteApiKeyUseCase.d.ts +16 -0
  274. package/features/security/apiKeys/DeleteApiKey/DeleteApiKeyUseCase.js +42 -0
  275. package/features/security/apiKeys/DeleteApiKey/DeleteApiKeyUseCase.js.map +1 -0
  276. package/features/security/apiKeys/DeleteApiKey/abstractions.d.ts +23 -0
  277. package/features/security/apiKeys/DeleteApiKey/abstractions.js +4 -0
  278. package/features/security/apiKeys/DeleteApiKey/abstractions.js.map +1 -0
  279. package/features/security/apiKeys/DeleteApiKey/events.d.ts +21 -0
  280. package/features/security/apiKeys/DeleteApiKey/events.js +18 -0
  281. package/features/security/apiKeys/DeleteApiKey/events.js.map +1 -0
  282. package/features/security/apiKeys/DeleteApiKey/feature.d.ts +1 -0
  283. package/features/security/apiKeys/DeleteApiKey/feature.js +10 -0
  284. package/features/security/apiKeys/DeleteApiKey/feature.js.map +1 -0
  285. package/features/security/apiKeys/DeleteApiKey/index.d.ts +2 -0
  286. package/features/security/apiKeys/DeleteApiKey/index.js +4 -0
  287. package/features/security/apiKeys/DeleteApiKey/index.js.map +1 -0
  288. package/features/security/apiKeys/GetApiKey/GetApiKeyUseCase.d.ts +15 -0
  289. package/features/security/apiKeys/GetApiKey/GetApiKeyUseCase.js +24 -0
  290. package/features/security/apiKeys/GetApiKey/GetApiKeyUseCase.js.map +1 -0
  291. package/features/security/apiKeys/GetApiKey/abstractions.d.ts +17 -0
  292. package/features/security/apiKeys/GetApiKey/abstractions.js +4 -0
  293. package/features/security/apiKeys/GetApiKey/abstractions.js.map +1 -0
  294. package/features/security/apiKeys/GetApiKey/feature.d.ts +1 -0
  295. package/features/security/apiKeys/GetApiKey/feature.js +10 -0
  296. package/features/security/apiKeys/GetApiKey/feature.js.map +1 -0
  297. package/features/security/apiKeys/GetApiKey/index.d.ts +1 -0
  298. package/features/security/apiKeys/GetApiKey/index.js +3 -0
  299. package/features/security/apiKeys/GetApiKey/index.js.map +1 -0
  300. package/features/security/apiKeys/GetApiKeyBySlug/GetApiKeyBySlugUseCase.d.ts +13 -0
  301. package/features/security/apiKeys/GetApiKeyBySlug/GetApiKeyBySlugUseCase.js +16 -0
  302. package/features/security/apiKeys/GetApiKeyBySlug/GetApiKeyBySlugUseCase.js.map +1 -0
  303. package/features/security/apiKeys/GetApiKeyBySlug/abstractions.d.ts +15 -0
  304. package/features/security/apiKeys/GetApiKeyBySlug/abstractions.js +4 -0
  305. package/features/security/apiKeys/GetApiKeyBySlug/abstractions.js.map +1 -0
  306. package/features/security/apiKeys/GetApiKeyBySlug/feature.d.ts +1 -0
  307. package/features/security/apiKeys/GetApiKeyBySlug/feature.js +10 -0
  308. package/features/security/apiKeys/GetApiKeyBySlug/feature.js.map +1 -0
  309. package/features/security/apiKeys/GetApiKeyBySlug/index.d.ts +1 -0
  310. package/features/security/apiKeys/GetApiKeyBySlug/index.js +3 -0
  311. package/features/security/apiKeys/GetApiKeyBySlug/index.js.map +1 -0
  312. package/features/security/apiKeys/GetApiKeyByToken/GetApiKeyByTokenUseCase.d.ts +13 -0
  313. package/features/security/apiKeys/GetApiKeyByToken/GetApiKeyByTokenUseCase.js +16 -0
  314. package/features/security/apiKeys/GetApiKeyByToken/GetApiKeyByTokenUseCase.js.map +1 -0
  315. package/features/security/apiKeys/GetApiKeyByToken/abstractions.d.ts +15 -0
  316. package/features/security/apiKeys/GetApiKeyByToken/abstractions.js +4 -0
  317. package/features/security/apiKeys/GetApiKeyByToken/abstractions.js.map +1 -0
  318. package/features/security/apiKeys/GetApiKeyByToken/feature.d.ts +1 -0
  319. package/features/security/apiKeys/GetApiKeyByToken/feature.js +10 -0
  320. package/features/security/apiKeys/GetApiKeyByToken/feature.js.map +1 -0
  321. package/features/security/apiKeys/GetApiKeyByToken/index.d.ts +1 -0
  322. package/features/security/apiKeys/GetApiKeyByToken/index.js +3 -0
  323. package/features/security/apiKeys/GetApiKeyByToken/index.js.map +1 -0
  324. package/features/security/apiKeys/ListApiKeys/ListApiKeysUseCase.d.ts +15 -0
  325. package/features/security/apiKeys/ListApiKeys/ListApiKeysUseCase.js +29 -0
  326. package/features/security/apiKeys/ListApiKeys/ListApiKeysUseCase.js.map +1 -0
  327. package/features/security/apiKeys/ListApiKeys/abstractions.d.ts +19 -0
  328. package/features/security/apiKeys/ListApiKeys/abstractions.js +4 -0
  329. package/features/security/apiKeys/ListApiKeys/abstractions.js.map +1 -0
  330. package/features/security/apiKeys/ListApiKeys/feature.d.ts +1 -0
  331. package/features/security/apiKeys/ListApiKeys/feature.js +10 -0
  332. package/features/security/apiKeys/ListApiKeys/feature.js.map +1 -0
  333. package/features/security/apiKeys/ListApiKeys/index.d.ts +1 -0
  334. package/features/security/apiKeys/ListApiKeys/index.js +3 -0
  335. package/features/security/apiKeys/ListApiKeys/index.js.map +1 -0
  336. package/features/security/apiKeys/UpdateApiKey/UpdateApiKeyUseCase.d.ts +17 -0
  337. package/features/security/apiKeys/UpdateApiKey/UpdateApiKeyUseCase.js +55 -0
  338. package/features/security/apiKeys/UpdateApiKey/UpdateApiKeyUseCase.js.map +1 -0
  339. package/features/security/apiKeys/UpdateApiKey/abstractions.d.ts +28 -0
  340. package/features/security/apiKeys/UpdateApiKey/abstractions.js +4 -0
  341. package/features/security/apiKeys/UpdateApiKey/abstractions.js.map +1 -0
  342. package/features/security/apiKeys/UpdateApiKey/events.d.ts +21 -0
  343. package/features/security/apiKeys/UpdateApiKey/events.js +18 -0
  344. package/features/security/apiKeys/UpdateApiKey/events.js.map +1 -0
  345. package/features/security/apiKeys/UpdateApiKey/feature.d.ts +1 -0
  346. package/features/security/apiKeys/UpdateApiKey/feature.js +10 -0
  347. package/features/security/apiKeys/UpdateApiKey/feature.js.map +1 -0
  348. package/features/security/apiKeys/UpdateApiKey/index.d.ts +2 -0
  349. package/features/security/apiKeys/UpdateApiKey/index.js +4 -0
  350. package/features/security/apiKeys/UpdateApiKey/index.js.map +1 -0
  351. package/features/security/apiKeys/feature.d.ts +1 -0
  352. package/features/security/apiKeys/feature.js +29 -0
  353. package/features/security/apiKeys/feature.js.map +1 -0
  354. package/features/security/apiKeys/shared/ApiKeyProvider.d.ts +15 -0
  355. package/features/security/apiKeys/shared/ApiKeyProvider.js +51 -0
  356. package/features/security/apiKeys/shared/ApiKeyProvider.js.map +1 -0
  357. package/features/security/apiKeys/shared/ApiKeysRepository.d.ts +21 -0
  358. package/features/security/apiKeys/shared/ApiKeysRepository.js +153 -0
  359. package/features/security/apiKeys/shared/ApiKeysRepository.js.map +1 -0
  360. package/features/security/apiKeys/shared/abstractions.d.ts +42 -0
  361. package/features/security/apiKeys/shared/abstractions.js +6 -0
  362. package/features/security/apiKeys/shared/abstractions.js.map +1 -0
  363. package/features/security/apiKeys/shared/errors.d.ts +24 -0
  364. package/features/security/apiKeys/shared/errors.js +39 -0
  365. package/features/security/apiKeys/shared/errors.js.map +1 -0
  366. package/features/security/apiKeys/shared/generateToken.d.ts +7 -0
  367. package/features/security/apiKeys/shared/generateToken.js +19 -0
  368. package/features/security/apiKeys/shared/generateToken.js.map +1 -0
  369. package/features/security/apiKeys/shared/schemas.d.ts +91 -0
  370. package/features/security/apiKeys/shared/schemas.js +29 -0
  371. package/features/security/apiKeys/shared/schemas.js.map +1 -0
  372. package/features/security/apiKeys/shared/types.d.ts +25 -0
  373. package/features/security/apiKeys/shared/types.js +3 -0
  374. package/features/security/apiKeys/shared/types.js.map +1 -0
  375. package/features/security/authentication/AuthenticationContext/AuthenticationContext.d.ts +15 -0
  376. package/features/security/authentication/AuthenticationContext/AuthenticationContext.js +51 -0
  377. package/features/security/authentication/AuthenticationContext/AuthenticationContext.js.map +1 -0
  378. package/features/security/authentication/AuthenticationContext/SetIdTokenCookie.d.ts +11 -0
  379. package/features/security/authentication/AuthenticationContext/SetIdTokenCookie.js +52 -0
  380. package/features/security/authentication/AuthenticationContext/SetIdTokenCookie.js.map +1 -0
  381. package/features/security/authentication/AuthenticationContext/abstractions.d.ts +9 -0
  382. package/features/security/authentication/AuthenticationContext/abstractions.js +4 -0
  383. package/features/security/authentication/AuthenticationContext/abstractions.js.map +1 -0
  384. package/features/security/authentication/AuthenticationContext/errors.d.ts +64 -0
  385. package/features/security/authentication/AuthenticationContext/errors.js +130 -0
  386. package/features/security/authentication/AuthenticationContext/errors.js.map +1 -0
  387. package/features/security/authentication/AuthenticationContext/events.d.ts +28 -0
  388. package/features/security/authentication/AuthenticationContext/events.js +18 -0
  389. package/features/security/authentication/AuthenticationContext/events.js.map +1 -0
  390. package/features/security/authentication/AuthenticationContext/feature.d.ts +1 -0
  391. package/features/security/authentication/AuthenticationContext/feature.js +10 -0
  392. package/features/security/authentication/AuthenticationContext/feature.js.map +1 -0
  393. package/features/security/authentication/AuthenticationContext/index.d.ts +5 -0
  394. package/features/security/authentication/AuthenticationContext/index.js +6 -0
  395. package/features/security/authentication/AuthenticationContext/index.js.map +1 -0
  396. package/features/security/authentication/Authenticator/abstractions.d.ts +8 -0
  397. package/features/security/authentication/Authenticator/abstractions.js +4 -0
  398. package/features/security/authentication/Authenticator/abstractions.js.map +1 -0
  399. package/features/security/authentication/Authenticator/index.d.ts +1 -0
  400. package/features/security/authentication/Authenticator/index.js +3 -0
  401. package/features/security/authentication/Authenticator/index.js.map +1 -0
  402. package/features/security/authorization/AuthorizationContext/AuthorizationContext.d.ts +16 -0
  403. package/features/security/authorization/AuthorizationContext/AuthorizationContext.js +55 -0
  404. package/features/security/authorization/AuthorizationContext/AuthorizationContext.js.map +1 -0
  405. package/features/security/authorization/AuthorizationContext/abstractions.d.ts +21 -0
  406. package/features/security/authorization/AuthorizationContext/abstractions.js +5 -0
  407. package/features/security/authorization/AuthorizationContext/abstractions.js.map +1 -0
  408. package/features/security/authorization/AuthorizationContext/feature.d.ts +1 -0
  409. package/features/security/authorization/AuthorizationContext/feature.js +15 -0
  410. package/features/security/authorization/AuthorizationContext/feature.js.map +1 -0
  411. package/features/security/authorization/AuthorizationContext/index.d.ts +4 -0
  412. package/features/security/authorization/AuthorizationContext/index.js +5 -0
  413. package/features/security/authorization/AuthorizationContext/index.js.map +1 -0
  414. package/features/security/authorization/Authorizer/abstractions.d.ts +9 -0
  415. package/features/security/authorization/Authorizer/abstractions.js +4 -0
  416. package/features/security/authorization/Authorizer/abstractions.js.map +1 -0
  417. package/features/security/authorization/Authorizer/index.d.ts +1 -0
  418. package/features/security/authorization/Authorizer/index.js +3 -0
  419. package/features/security/authorization/Authorizer/index.js.map +1 -0
  420. package/features/security/authorization/GroupsTeamsAuthorizer/GetPermissionsFromIdentity.d.ts +23 -0
  421. package/features/security/authorization/GroupsTeamsAuthorizer/GetPermissionsFromIdentity.js +80 -0
  422. package/features/security/authorization/GroupsTeamsAuthorizer/GetPermissionsFromIdentity.js.map +1 -0
  423. package/features/security/authorization/GroupsTeamsAuthorizer/RolesTeamsAuthorizer.d.ts +17 -0
  424. package/features/security/authorization/GroupsTeamsAuthorizer/RolesTeamsAuthorizer.js +51 -0
  425. package/features/security/authorization/GroupsTeamsAuthorizer/RolesTeamsAuthorizer.js.map +1 -0
  426. package/features/security/authorization/GroupsTeamsAuthorizer/abstractions.d.ts +13 -0
  427. package/features/security/authorization/GroupsTeamsAuthorizer/abstractions.js +4 -0
  428. package/features/security/authorization/GroupsTeamsAuthorizer/abstractions.js.map +1 -0
  429. package/features/security/authorization/GroupsTeamsAuthorizer/feature.d.ts +1 -0
  430. package/features/security/authorization/GroupsTeamsAuthorizer/feature.js +12 -0
  431. package/features/security/authorization/GroupsTeamsAuthorizer/feature.js.map +1 -0
  432. package/features/security/login/abstractions.d.ts +15 -0
  433. package/features/security/login/abstractions.js +11 -0
  434. package/features/security/login/abstractions.js.map +1 -0
  435. package/features/security/login/index.d.ts +1 -0
  436. package/features/security/login/index.js +3 -0
  437. package/features/security/login/index.js.map +1 -0
  438. package/features/security/roles/CreateRole/CreateRoleUseCase.d.ts +17 -0
  439. package/features/security/roles/CreateRole/CreateRoleUseCase.js +76 -0
  440. package/features/security/roles/CreateRole/CreateRoleUseCase.js.map +1 -0
  441. package/features/security/roles/CreateRole/abstractions.d.ts +27 -0
  442. package/features/security/roles/CreateRole/abstractions.js +4 -0
  443. package/features/security/roles/CreateRole/abstractions.js.map +1 -0
  444. package/features/security/roles/CreateRole/events.d.ts +21 -0
  445. package/features/security/roles/CreateRole/events.js +18 -0
  446. package/features/security/roles/CreateRole/events.js.map +1 -0
  447. package/features/security/roles/CreateRole/feature.d.ts +1 -0
  448. package/features/security/roles/CreateRole/feature.js +10 -0
  449. package/features/security/roles/CreateRole/feature.js.map +1 -0
  450. package/features/security/roles/CreateRole/index.d.ts +2 -0
  451. package/features/security/roles/CreateRole/index.js +4 -0
  452. package/features/security/roles/CreateRole/index.js.map +1 -0
  453. package/features/security/roles/CreateRole/schema.d.ts +27 -0
  454. package/features/security/roles/CreateRole/schema.js +11 -0
  455. package/features/security/roles/CreateRole/schema.js.map +1 -0
  456. package/features/security/roles/DeleteRole/DeleteRoleUseCase.d.ts +14 -0
  457. package/features/security/roles/DeleteRole/DeleteRoleUseCase.js +51 -0
  458. package/features/security/roles/DeleteRole/DeleteRoleUseCase.js.map +1 -0
  459. package/features/security/roles/DeleteRole/abstractions.d.ts +24 -0
  460. package/features/security/roles/DeleteRole/abstractions.js +4 -0
  461. package/features/security/roles/DeleteRole/abstractions.js.map +1 -0
  462. package/features/security/roles/DeleteRole/events.d.ts +21 -0
  463. package/features/security/roles/DeleteRole/events.js +18 -0
  464. package/features/security/roles/DeleteRole/events.js.map +1 -0
  465. package/features/security/roles/DeleteRole/feature.d.ts +1 -0
  466. package/features/security/roles/DeleteRole/feature.js +10 -0
  467. package/features/security/roles/DeleteRole/feature.js.map +1 -0
  468. package/features/security/roles/DeleteRole/index.d.ts +2 -0
  469. package/features/security/roles/DeleteRole/index.js +4 -0
  470. package/features/security/roles/DeleteRole/index.js.map +1 -0
  471. package/features/security/roles/GetRole/GetRoleUseCase.d.ts +12 -0
  472. package/features/security/roles/GetRole/GetRoleUseCase.js +26 -0
  473. package/features/security/roles/GetRole/GetRoleUseCase.js.map +1 -0
  474. package/features/security/roles/GetRole/abstractions.d.ts +17 -0
  475. package/features/security/roles/GetRole/abstractions.js +4 -0
  476. package/features/security/roles/GetRole/abstractions.js.map +1 -0
  477. package/features/security/roles/GetRole/feature.d.ts +1 -0
  478. package/features/security/roles/GetRole/feature.js +10 -0
  479. package/features/security/roles/GetRole/feature.js.map +1 -0
  480. package/features/security/roles/GetRole/index.d.ts +1 -0
  481. package/features/security/roles/GetRole/index.js +3 -0
  482. package/features/security/roles/GetRole/index.js.map +1 -0
  483. package/features/security/roles/Installer/RolesInstaller.d.ts +18 -0
  484. package/features/security/roles/Installer/RolesInstaller.js +47 -0
  485. package/features/security/roles/Installer/RolesInstaller.js.map +1 -0
  486. package/features/security/roles/ListRoles/ListRolesUseCase.d.ts +13 -0
  487. package/features/security/roles/ListRoles/ListRolesUseCase.js +26 -0
  488. package/features/security/roles/ListRoles/ListRolesUseCase.js.map +1 -0
  489. package/features/security/roles/ListRoles/abstractions.d.ts +17 -0
  490. package/features/security/roles/ListRoles/abstractions.js +4 -0
  491. package/features/security/roles/ListRoles/abstractions.js.map +1 -0
  492. package/features/security/roles/ListRoles/feature.d.ts +1 -0
  493. package/features/security/roles/ListRoles/feature.js +10 -0
  494. package/features/security/roles/ListRoles/feature.js.map +1 -0
  495. package/features/security/roles/ListRoles/index.d.ts +1 -0
  496. package/features/security/roles/ListRoles/index.js +3 -0
  497. package/features/security/roles/ListRoles/index.js.map +1 -0
  498. package/features/security/roles/UpdateRole/UpdateRoleUseCase.d.ts +17 -0
  499. package/features/security/roles/UpdateRole/UpdateRoleUseCase.js +62 -0
  500. package/features/security/roles/UpdateRole/UpdateRoleUseCase.js.map +1 -0
  501. package/features/security/roles/UpdateRole/abstractions.d.ts +29 -0
  502. package/features/security/roles/UpdateRole/abstractions.js +4 -0
  503. package/features/security/roles/UpdateRole/abstractions.js.map +1 -0
  504. package/features/security/roles/UpdateRole/events.d.ts +21 -0
  505. package/features/security/roles/UpdateRole/events.js +18 -0
  506. package/features/security/roles/UpdateRole/events.js.map +1 -0
  507. package/features/security/roles/UpdateRole/feature.d.ts +1 -0
  508. package/features/security/roles/UpdateRole/feature.js +10 -0
  509. package/features/security/roles/UpdateRole/feature.js.map +1 -0
  510. package/features/security/roles/UpdateRole/index.d.ts +2 -0
  511. package/features/security/roles/UpdateRole/index.js +4 -0
  512. package/features/security/roles/UpdateRole/index.js.map +1 -0
  513. package/features/security/roles/UpdateRole/schema.d.ts +24 -0
  514. package/features/security/roles/UpdateRole/schema.js +10 -0
  515. package/features/security/roles/UpdateRole/schema.js.map +1 -0
  516. package/features/security/roles/feature.d.ts +1 -0
  517. package/features/security/roles/feature.js +29 -0
  518. package/features/security/roles/feature.js.map +1 -0
  519. package/features/security/roles/shared/RolesRepository.d.ts +18 -0
  520. package/features/security/roles/shared/RolesRepository.js +130 -0
  521. package/features/security/roles/shared/RolesRepository.js.map +1 -0
  522. package/features/security/roles/shared/abstractions.d.ts +20 -0
  523. package/features/security/roles/shared/abstractions.js +4 -0
  524. package/features/security/roles/shared/abstractions.js.map +1 -0
  525. package/features/security/roles/shared/decorators/ListCache.d.ts +24 -0
  526. package/features/security/roles/shared/decorators/ListCache.js +26 -0
  527. package/features/security/roles/shared/decorators/ListCache.js.map +1 -0
  528. package/features/security/roles/shared/decorators/RolesRepositoryCachingDecorator.d.ts +17 -0
  529. package/features/security/roles/shared/decorators/RolesRepositoryCachingDecorator.js +76 -0
  530. package/features/security/roles/shared/decorators/RolesRepositoryCachingDecorator.js.map +1 -0
  531. package/features/security/roles/shared/errors.d.ts +39 -0
  532. package/features/security/roles/shared/errors.js +66 -0
  533. package/features/security/roles/shared/errors.js.map +1 -0
  534. package/features/security/roles/shared/types.d.ts +29 -0
  535. package/features/security/roles/shared/types.js +3 -0
  536. package/features/security/roles/shared/types.js.map +1 -0
  537. package/features/security/shared/abstractions.d.ts +31 -0
  538. package/features/security/shared/abstractions.js +22 -0
  539. package/features/security/shared/abstractions.js.map +1 -0
  540. package/features/security/shared/abstractions.ts.bak +52 -0
  541. package/features/security/shared/errors.d.ts +10 -0
  542. package/features/security/shared/errors.js +12 -0
  543. package/features/security/shared/errors.js.map +1 -0
  544. package/features/security/shared/index.d.ts +2 -0
  545. package/features/security/shared/index.js +4 -0
  546. package/features/security/shared/index.js.map +1 -0
  547. package/features/security/teams/CreateTeam/CreateTeamUseCase.d.ts +16 -0
  548. package/features/security/teams/CreateTeam/CreateTeamUseCase.js +76 -0
  549. package/features/security/teams/CreateTeam/CreateTeamUseCase.js.map +1 -0
  550. package/features/security/teams/CreateTeam/abstractions.d.ts +27 -0
  551. package/features/security/teams/CreateTeam/abstractions.js +4 -0
  552. package/features/security/teams/CreateTeam/abstractions.js.map +1 -0
  553. package/features/security/teams/CreateTeam/events.d.ts +21 -0
  554. package/features/security/teams/CreateTeam/events.js +18 -0
  555. package/features/security/teams/CreateTeam/events.js.map +1 -0
  556. package/features/security/teams/CreateTeam/feature.d.ts +1 -0
  557. package/features/security/teams/CreateTeam/feature.js +10 -0
  558. package/features/security/teams/CreateTeam/feature.js.map +1 -0
  559. package/features/security/teams/CreateTeam/index.d.ts +2 -0
  560. package/features/security/teams/CreateTeam/index.js +4 -0
  561. package/features/security/teams/CreateTeam/index.js.map +1 -0
  562. package/features/security/teams/CreateTeam/schema.d.ts +17 -0
  563. package/features/security/teams/CreateTeam/schema.js +9 -0
  564. package/features/security/teams/CreateTeam/schema.js.map +1 -0
  565. package/features/security/teams/DeleteTeam/DeleteTeamUseCase.d.ts +13 -0
  566. package/features/security/teams/DeleteTeam/DeleteTeamUseCase.js +56 -0
  567. package/features/security/teams/DeleteTeam/DeleteTeamUseCase.js.map +1 -0
  568. package/features/security/teams/DeleteTeam/abstractions.d.ts +25 -0
  569. package/features/security/teams/DeleteTeam/abstractions.js +4 -0
  570. package/features/security/teams/DeleteTeam/abstractions.js.map +1 -0
  571. package/features/security/teams/DeleteTeam/events.d.ts +21 -0
  572. package/features/security/teams/DeleteTeam/events.js +18 -0
  573. package/features/security/teams/DeleteTeam/events.js.map +1 -0
  574. package/features/security/teams/DeleteTeam/feature.d.ts +1 -0
  575. package/features/security/teams/DeleteTeam/feature.js +10 -0
  576. package/features/security/teams/DeleteTeam/feature.js.map +1 -0
  577. package/features/security/teams/DeleteTeam/index.d.ts +3 -0
  578. package/features/security/teams/DeleteTeam/index.js +5 -0
  579. package/features/security/teams/DeleteTeam/index.js.map +1 -0
  580. package/features/security/teams/GetTeam/GetTeamUseCase.d.ts +15 -0
  581. package/features/security/teams/GetTeam/GetTeamUseCase.js +28 -0
  582. package/features/security/teams/GetTeam/GetTeamUseCase.js.map +1 -0
  583. package/features/security/teams/GetTeam/abstractions.d.ts +17 -0
  584. package/features/security/teams/GetTeam/abstractions.js +4 -0
  585. package/features/security/teams/GetTeam/abstractions.js.map +1 -0
  586. package/features/security/teams/GetTeam/feature.d.ts +1 -0
  587. package/features/security/teams/GetTeam/feature.js +10 -0
  588. package/features/security/teams/GetTeam/feature.js.map +1 -0
  589. package/features/security/teams/GetTeam/index.d.ts +1 -0
  590. package/features/security/teams/GetTeam/index.js +3 -0
  591. package/features/security/teams/GetTeam/index.js.map +1 -0
  592. package/features/security/teams/ListTeams/ListTeamsUseCase.d.ts +12 -0
  593. package/features/security/teams/ListTeams/ListTeamsUseCase.js +30 -0
  594. package/features/security/teams/ListTeams/ListTeamsUseCase.js.map +1 -0
  595. package/features/security/teams/ListTeams/abstractions.d.ts +17 -0
  596. package/features/security/teams/ListTeams/abstractions.js +4 -0
  597. package/features/security/teams/ListTeams/abstractions.js.map +1 -0
  598. package/features/security/teams/ListTeams/feature.d.ts +1 -0
  599. package/features/security/teams/ListTeams/feature.js +10 -0
  600. package/features/security/teams/ListTeams/feature.js.map +1 -0
  601. package/features/security/teams/ListTeams/index.d.ts +1 -0
  602. package/features/security/teams/ListTeams/index.js +3 -0
  603. package/features/security/teams/ListTeams/index.js.map +1 -0
  604. package/features/security/teams/UpdateTeam/UpdateTeamUseCase.d.ts +14 -0
  605. package/features/security/teams/UpdateTeam/UpdateTeamUseCase.js +69 -0
  606. package/features/security/teams/UpdateTeam/UpdateTeamUseCase.js.map +1 -0
  607. package/features/security/teams/UpdateTeam/abstractions.d.ts +30 -0
  608. package/features/security/teams/UpdateTeam/abstractions.js +4 -0
  609. package/features/security/teams/UpdateTeam/abstractions.js.map +1 -0
  610. package/features/security/teams/UpdateTeam/events.d.ts +21 -0
  611. package/features/security/teams/UpdateTeam/events.js +18 -0
  612. package/features/security/teams/UpdateTeam/events.js.map +1 -0
  613. package/features/security/teams/UpdateTeam/feature.d.ts +1 -0
  614. package/features/security/teams/UpdateTeam/feature.js +10 -0
  615. package/features/security/teams/UpdateTeam/feature.js.map +1 -0
  616. package/features/security/teams/UpdateTeam/index.d.ts +3 -0
  617. package/features/security/teams/UpdateTeam/index.js +5 -0
  618. package/features/security/teams/UpdateTeam/index.js.map +1 -0
  619. package/features/security/teams/UpdateTeam/schema.d.ts +14 -0
  620. package/features/security/teams/UpdateTeam/schema.js +8 -0
  621. package/features/security/teams/UpdateTeam/schema.js.map +1 -0
  622. package/features/security/teams/feature.d.ts +1 -0
  623. package/features/security/teams/feature.js +23 -0
  624. package/features/security/teams/feature.js.map +1 -0
  625. package/features/security/teams/shared/TeamsRepository.d.ts +18 -0
  626. package/features/security/teams/shared/TeamsRepository.js +133 -0
  627. package/features/security/teams/shared/TeamsRepository.js.map +1 -0
  628. package/features/security/teams/shared/abstractions.d.ts +20 -0
  629. package/features/security/teams/shared/abstractions.js +4 -0
  630. package/features/security/teams/shared/abstractions.js.map +1 -0
  631. package/features/security/teams/shared/errors.d.ts +47 -0
  632. package/features/security/teams/shared/errors.js +82 -0
  633. package/features/security/teams/shared/errors.js.map +1 -0
  634. package/features/security/teams/shared/types.d.ts +28 -0
  635. package/features/security/teams/shared/types.js +3 -0
  636. package/features/security/teams/shared/types.js.map +1 -0
  637. package/features/security/utils/AppPermissions.d.ts +27 -0
  638. package/features/security/utils/AppPermissions.js +99 -0
  639. package/features/security/utils/AppPermissions.js.map +1 -0
  640. package/features/security/utils/IdentityValue.d.ts +18 -0
  641. package/features/security/utils/IdentityValue.js +27 -0
  642. package/features/security/utils/IdentityValue.js.map +1 -0
  643. package/features/security/utils/filterOutCustomWbyAppsPermissions.d.ts +2 -0
  644. package/features/security/utils/filterOutCustomWbyAppsPermissions.js +29 -0
  645. package/features/security/utils/filterOutCustomWbyAppsPermissions.js.map +1 -0
  646. package/features/security/utils/getPermissionsFromRoles.d.ts +8 -0
  647. package/features/security/utils/getPermissionsFromRoles.js +12 -0
  648. package/features/security/utils/getPermissionsFromRoles.js.map +1 -0
  649. package/features/security/utils/isJwt.d.ts +1 -0
  650. package/features/security/utils/isJwt.js +3 -0
  651. package/features/security/utils/isJwt.js.map +1 -0
  652. package/features/security/utils/verifyJwtUsingJwk.d.ts +10 -0
  653. package/features/security/utils/verifyJwtUsingJwk.js +11 -0
  654. package/features/security/utils/verifyJwtUsingJwk.js.map +1 -0
  655. package/features/system/InstallSystem/InstallSystemUseCase.d.ts +24 -0
  656. package/features/system/InstallSystem/InstallSystemUseCase.js +61 -0
  657. package/features/system/InstallSystem/InstallSystemUseCase.js.map +1 -0
  658. package/features/system/InstallSystem/abstractions.d.ts +34 -0
  659. package/features/system/InstallSystem/abstractions.js +21 -0
  660. package/features/system/InstallSystem/abstractions.js.map +1 -0
  661. package/features/system/InstallSystem/errors.d.ts +16 -0
  662. package/features/system/InstallSystem/errors.js +21 -0
  663. package/features/system/InstallSystem/errors.js.map +1 -0
  664. package/features/system/InstallSystem/events.d.ts +5 -0
  665. package/features/system/InstallSystem/events.js +10 -0
  666. package/features/system/InstallSystem/events.js.map +1 -0
  667. package/features/system/InstallSystem/feature.d.ts +1 -0
  668. package/features/system/InstallSystem/feature.js +12 -0
  669. package/features/system/InstallSystem/feature.js.map +1 -0
  670. package/features/system/InstallSystem/index.d.ts +6 -0
  671. package/features/system/InstallSystem/index.js +7 -0
  672. package/features/system/InstallSystem/index.js.map +1 -0
  673. package/features/system/SystemFeature.d.ts +1 -0
  674. package/features/system/SystemFeature.js +10 -0
  675. package/features/system/SystemFeature.js.map +1 -0
  676. package/features/task/TaskController/abstractions.d.ts +13 -0
  677. package/features/task/TaskController/abstractions.js +12 -0
  678. package/features/task/TaskController/abstractions.js.map +1 -0
  679. package/features/task/TaskController/index.d.ts +1 -0
  680. package/features/task/TaskController/index.js +3 -0
  681. package/features/task/TaskController/index.js.map +1 -0
  682. package/features/task/TaskDefinition/abstractions.d.ts +131 -0
  683. package/features/task/TaskDefinition/abstractions.js +43 -0
  684. package/features/task/TaskDefinition/abstractions.js.map +1 -0
  685. package/features/task/TaskDefinition/index.d.ts +1 -0
  686. package/features/task/TaskDefinition/index.js +3 -0
  687. package/features/task/TaskDefinition/index.js.map +1 -0
  688. package/features/task/TaskService/abstractions.d.ts +74 -0
  689. package/features/task/TaskService/abstractions.js +16 -0
  690. package/features/task/TaskService/abstractions.js.map +1 -0
  691. package/features/task/TaskService/index.d.ts +1 -0
  692. package/features/task/TaskService/index.js +3 -0
  693. package/features/task/TaskService/index.js.map +1 -0
  694. package/features/tenancy/CreateTenant/CreateTenantGateway.d.ts +10 -0
  695. package/features/tenancy/CreateTenant/CreateTenantGateway.js +18 -0
  696. package/features/tenancy/CreateTenant/CreateTenantGateway.js.map +1 -0
  697. package/features/tenancy/CreateTenant/CreateTenantRepository.d.ts +12 -0
  698. package/features/tenancy/CreateTenant/CreateTenantRepository.js +22 -0
  699. package/features/tenancy/CreateTenant/CreateTenantRepository.js.map +1 -0
  700. package/features/tenancy/CreateTenant/CreateTenantUseCase.d.ts +14 -0
  701. package/features/tenancy/CreateTenant/CreateTenantUseCase.js +51 -0
  702. package/features/tenancy/CreateTenant/CreateTenantUseCase.js.map +1 -0
  703. package/features/tenancy/CreateTenant/abstractions.d.ts +55 -0
  704. package/features/tenancy/CreateTenant/abstractions.js +30 -0
  705. package/features/tenancy/CreateTenant/abstractions.js.map +1 -0
  706. package/features/tenancy/CreateTenant/decorators/CreateTenantWithWcpIncrement.d.ts +11 -0
  707. package/features/tenancy/CreateTenant/decorators/CreateTenantWithWcpIncrement.js +24 -0
  708. package/features/tenancy/CreateTenant/decorators/CreateTenantWithWcpIncrement.js.map +1 -0
  709. package/features/tenancy/CreateTenant/errors.d.ts +5 -0
  710. package/features/tenancy/CreateTenant/errors.js +12 -0
  711. package/features/tenancy/CreateTenant/errors.js.map +1 -0
  712. package/features/tenancy/CreateTenant/events.d.ts +18 -0
  713. package/features/tenancy/CreateTenant/events.js +16 -0
  714. package/features/tenancy/CreateTenant/events.js.map +1 -0
  715. package/features/tenancy/CreateTenant/feature.d.ts +1 -0
  716. package/features/tenancy/CreateTenant/feature.js +16 -0
  717. package/features/tenancy/CreateTenant/feature.js.map +1 -0
  718. package/features/tenancy/CreateTenant/index.d.ts +3 -0
  719. package/features/tenancy/CreateTenant/index.js +5 -0
  720. package/features/tenancy/CreateTenant/index.js.map +1 -0
  721. package/features/tenancy/DeleteTenant/DeleteTenantGateway.d.ts +8 -0
  722. package/features/tenancy/DeleteTenant/DeleteTenantGateway.js +18 -0
  723. package/features/tenancy/DeleteTenant/DeleteTenantGateway.js.map +1 -0
  724. package/features/tenancy/DeleteTenant/DeleteTenantRepository.d.ts +11 -0
  725. package/features/tenancy/DeleteTenant/DeleteTenantRepository.js +25 -0
  726. package/features/tenancy/DeleteTenant/DeleteTenantRepository.js.map +1 -0
  727. package/features/tenancy/DeleteTenant/DeleteTenantUseCase.d.ts +12 -0
  728. package/features/tenancy/DeleteTenant/DeleteTenantUseCase.js +35 -0
  729. package/features/tenancy/DeleteTenant/DeleteTenantUseCase.js.map +1 -0
  730. package/features/tenancy/DeleteTenant/abstractions.d.ts +33 -0
  731. package/features/tenancy/DeleteTenant/abstractions.js +8 -0
  732. package/features/tenancy/DeleteTenant/abstractions.js.map +1 -0
  733. package/features/tenancy/DeleteTenant/decorators/DeleteTenantWithWcpDecrement.d.ts +10 -0
  734. package/features/tenancy/DeleteTenant/decorators/DeleteTenantWithWcpDecrement.js +21 -0
  735. package/features/tenancy/DeleteTenant/decorators/DeleteTenantWithWcpDecrement.js.map +1 -0
  736. package/features/tenancy/DeleteTenant/events.d.ts +16 -0
  737. package/features/tenancy/DeleteTenant/events.js +16 -0
  738. package/features/tenancy/DeleteTenant/events.js.map +1 -0
  739. package/features/tenancy/DeleteTenant/feature.d.ts +1 -0
  740. package/features/tenancy/DeleteTenant/feature.js +16 -0
  741. package/features/tenancy/DeleteTenant/feature.js.map +1 -0
  742. package/features/tenancy/DeleteTenant/index.d.ts +3 -0
  743. package/features/tenancy/DeleteTenant/index.js +5 -0
  744. package/features/tenancy/DeleteTenant/index.js.map +1 -0
  745. package/features/tenancy/GetRootTenant/GetRootTenantUseCase.d.ts +8 -0
  746. package/features/tenancy/GetRootTenant/GetRootTenantUseCase.js +18 -0
  747. package/features/tenancy/GetRootTenant/GetRootTenantUseCase.js.map +1 -0
  748. package/features/tenancy/GetRootTenant/abstractions.d.ts +8 -0
  749. package/features/tenancy/GetRootTenant/abstractions.js +7 -0
  750. package/features/tenancy/GetRootTenant/abstractions.js.map +1 -0
  751. package/features/tenancy/GetRootTenant/feature.d.ts +1 -0
  752. package/features/tenancy/GetRootTenant/feature.js +10 -0
  753. package/features/tenancy/GetRootTenant/feature.js.map +1 -0
  754. package/features/tenancy/GetRootTenant/index.d.ts +1 -0
  755. package/features/tenancy/GetRootTenant/index.js +3 -0
  756. package/features/tenancy/GetRootTenant/index.js.map +1 -0
  757. package/features/tenancy/GetTenantById/GetTenantByIdGateway.d.ts +10 -0
  758. package/features/tenancy/GetTenantById/GetTenantByIdGateway.js +19 -0
  759. package/features/tenancy/GetTenantById/GetTenantByIdGateway.js.map +1 -0
  760. package/features/tenancy/GetTenantById/GetTenantByIdRepository.d.ts +12 -0
  761. package/features/tenancy/GetTenantById/GetTenantByIdRepository.js +28 -0
  762. package/features/tenancy/GetTenantById/GetTenantByIdRepository.js.map +1 -0
  763. package/features/tenancy/GetTenantById/GetTenantByIdUseCase.d.ts +9 -0
  764. package/features/tenancy/GetTenantById/GetTenantByIdUseCase.js +25 -0
  765. package/features/tenancy/GetTenantById/GetTenantByIdUseCase.js.map +1 -0
  766. package/features/tenancy/GetTenantById/abstractions.d.ts +31 -0
  767. package/features/tenancy/GetTenantById/abstractions.js +15 -0
  768. package/features/tenancy/GetTenantById/abstractions.js.map +1 -0
  769. package/features/tenancy/GetTenantById/feature.d.ts +1 -0
  770. package/features/tenancy/GetTenantById/feature.js +19 -0
  771. package/features/tenancy/GetTenantById/feature.js.map +1 -0
  772. package/features/tenancy/GetTenantById/index.d.ts +1 -0
  773. package/features/tenancy/GetTenantById/index.js +3 -0
  774. package/features/tenancy/GetTenantById/index.js.map +1 -0
  775. package/features/tenancy/InstallTenant/DependencyResolver.d.ts +6 -0
  776. package/features/tenancy/InstallTenant/DependencyResolver.js +73 -0
  777. package/features/tenancy/InstallTenant/DependencyResolver.js.map +1 -0
  778. package/features/tenancy/InstallTenant/InstallTenantUseCase.d.ts +20 -0
  779. package/features/tenancy/InstallTenant/InstallTenantUseCase.js +133 -0
  780. package/features/tenancy/InstallTenant/InstallTenantUseCase.js.map +1 -0
  781. package/features/tenancy/InstallTenant/abstractions.d.ts +66 -0
  782. package/features/tenancy/InstallTenant/abstractions.js +27 -0
  783. package/features/tenancy/InstallTenant/abstractions.js.map +1 -0
  784. package/features/tenancy/InstallTenant/errors.d.ts +19 -0
  785. package/features/tenancy/InstallTenant/errors.js +21 -0
  786. package/features/tenancy/InstallTenant/errors.js.map +1 -0
  787. package/features/tenancy/InstallTenant/events.d.ts +10 -0
  788. package/features/tenancy/InstallTenant/events.js +10 -0
  789. package/features/tenancy/InstallTenant/events.js.map +1 -0
  790. package/features/tenancy/InstallTenant/feature.d.ts +1 -0
  791. package/features/tenancy/InstallTenant/feature.js +10 -0
  792. package/features/tenancy/InstallTenant/feature.js.map +1 -0
  793. package/features/tenancy/InstallTenant/index.d.ts +5 -0
  794. package/features/tenancy/InstallTenant/index.js +7 -0
  795. package/features/tenancy/InstallTenant/index.js.map +1 -0
  796. package/features/tenancy/ListTenants/ListTenantsGateway.d.ts +10 -0
  797. package/features/tenancy/ListTenants/ListTenantsGateway.js +18 -0
  798. package/features/tenancy/ListTenants/ListTenantsGateway.js.map +1 -0
  799. package/features/tenancy/ListTenants/ListTenantsRepository.d.ts +10 -0
  800. package/features/tenancy/ListTenants/ListTenantsRepository.js +18 -0
  801. package/features/tenancy/ListTenants/ListTenantsRepository.js.map +1 -0
  802. package/features/tenancy/ListTenants/ListTenantsUseCase.d.ts +11 -0
  803. package/features/tenancy/ListTenants/ListTenantsUseCase.js +19 -0
  804. package/features/tenancy/ListTenants/ListTenantsUseCase.js.map +1 -0
  805. package/features/tenancy/ListTenants/abstractions.d.ts +23 -0
  806. package/features/tenancy/ListTenants/abstractions.js +15 -0
  807. package/features/tenancy/ListTenants/abstractions.js.map +1 -0
  808. package/features/tenancy/ListTenants/feature.d.ts +1 -0
  809. package/features/tenancy/ListTenants/feature.js +14 -0
  810. package/features/tenancy/ListTenants/feature.js.map +1 -0
  811. package/features/tenancy/ListTenants/index.d.ts +2 -0
  812. package/features/tenancy/ListTenants/index.js +4 -0
  813. package/features/tenancy/ListTenants/index.js.map +1 -0
  814. package/features/tenancy/TenancyFeature.d.ts +2 -0
  815. package/features/tenancy/TenancyFeature.js +40 -0
  816. package/features/tenancy/TenancyFeature.js.map +1 -0
  817. package/features/tenancy/TenantContext/TenantContext.d.ts +15 -0
  818. package/features/tenancy/TenantContext/TenantContext.js +61 -0
  819. package/features/tenancy/TenantContext/TenantContext.js.map +1 -0
  820. package/features/tenancy/TenantContext/abstractions.d.ts +12 -0
  821. package/features/tenancy/TenantContext/abstractions.js +4 -0
  822. package/features/tenancy/TenantContext/abstractions.js.map +1 -0
  823. package/features/tenancy/TenantContext/errors.d.ts +5 -0
  824. package/features/tenancy/TenantContext/errors.js +11 -0
  825. package/features/tenancy/TenantContext/errors.js.map +1 -0
  826. package/features/tenancy/TenantContext/feature.d.ts +1 -0
  827. package/features/tenancy/TenantContext/feature.js +10 -0
  828. package/features/tenancy/TenantContext/feature.js.map +1 -0
  829. package/features/tenancy/TenantContext/index.d.ts +1 -0
  830. package/features/tenancy/TenantContext/index.js +3 -0
  831. package/features/tenancy/TenantContext/index.js.map +1 -0
  832. package/features/tenancy/UpdateTenant/UpdateTenantGateway.d.ts +10 -0
  833. package/features/tenancy/UpdateTenant/UpdateTenantGateway.js +18 -0
  834. package/features/tenancy/UpdateTenant/UpdateTenantGateway.js.map +1 -0
  835. package/features/tenancy/UpdateTenant/UpdateTenantRepository.d.ts +12 -0
  836. package/features/tenancy/UpdateTenant/UpdateTenantRepository.js +23 -0
  837. package/features/tenancy/UpdateTenant/UpdateTenantRepository.js.map +1 -0
  838. package/features/tenancy/UpdateTenant/UpdateTenantUseCase.d.ts +17 -0
  839. package/features/tenancy/UpdateTenant/UpdateTenantUseCase.js +44 -0
  840. package/features/tenancy/UpdateTenant/UpdateTenantUseCase.js.map +1 -0
  841. package/features/tenancy/UpdateTenant/abstractions.d.ts +41 -0
  842. package/features/tenancy/UpdateTenant/abstractions.js +8 -0
  843. package/features/tenancy/UpdateTenant/abstractions.js.map +1 -0
  844. package/features/tenancy/UpdateTenant/events.d.ts +19 -0
  845. package/features/tenancy/UpdateTenant/events.js +16 -0
  846. package/features/tenancy/UpdateTenant/events.js.map +1 -0
  847. package/features/tenancy/UpdateTenant/feature.d.ts +1 -0
  848. package/features/tenancy/UpdateTenant/feature.js +14 -0
  849. package/features/tenancy/UpdateTenant/feature.js.map +1 -0
  850. package/features/tenancy/UpdateTenant/index.d.ts +3 -0
  851. package/features/tenancy/UpdateTenant/index.js +5 -0
  852. package/features/tenancy/UpdateTenant/index.js.map +1 -0
  853. package/features/tenancy/shared/TenantCache.d.ts +13 -0
  854. package/features/tenancy/shared/TenantCache.js +20 -0
  855. package/features/tenancy/shared/TenantCache.js.map +1 -0
  856. package/features/tenancy/shared/abstractions.d.ts +11 -0
  857. package/features/tenancy/shared/abstractions.js +4 -0
  858. package/features/tenancy/shared/abstractions.js.map +1 -0
  859. package/features/tenancy/shared/storageOperations.d.ts +9 -0
  860. package/features/tenancy/shared/storageOperations.js +8 -0
  861. package/features/tenancy/shared/storageOperations.js.map +1 -0
  862. package/features/users/AdminUsersFeature.d.ts +1 -0
  863. package/features/users/AdminUsersFeature.js +33 -0
  864. package/features/users/AdminUsersFeature.js.map +1 -0
  865. package/features/users/CreateUser/CreateUserUseCase.d.ts +19 -0
  866. package/features/users/CreateUser/CreateUserUseCase.js +114 -0
  867. package/features/users/CreateUser/CreateUserUseCase.js.map +1 -0
  868. package/features/users/CreateUser/abstractions.d.ts +29 -0
  869. package/features/users/CreateUser/abstractions.js +16 -0
  870. package/features/users/CreateUser/abstractions.js.map +1 -0
  871. package/features/users/CreateUser/decorators/CreateUserWithWcpIncrement.d.ts +11 -0
  872. package/features/users/CreateUser/decorators/CreateUserWithWcpIncrement.js +24 -0
  873. package/features/users/CreateUser/decorators/CreateUserWithWcpIncrement.js.map +1 -0
  874. package/features/users/CreateUser/events.d.ts +21 -0
  875. package/features/users/CreateUser/events.js +20 -0
  876. package/features/users/CreateUser/events.js.map +1 -0
  877. package/features/users/CreateUser/feature.d.ts +1 -0
  878. package/features/users/CreateUser/feature.js +12 -0
  879. package/features/users/CreateUser/feature.js.map +1 -0
  880. package/features/users/CreateUser/index.d.ts +2 -0
  881. package/features/users/CreateUser/index.js +4 -0
  882. package/features/users/CreateUser/index.js.map +1 -0
  883. package/features/users/CreateUser/schema.d.ts +47 -0
  884. package/features/users/CreateUser/schema.js +22 -0
  885. package/features/users/CreateUser/schema.js.map +1 -0
  886. package/features/users/DeleteUser/DeleteUserUseCase.d.ts +14 -0
  887. package/features/users/DeleteUser/DeleteUserUseCase.js +62 -0
  888. package/features/users/DeleteUser/DeleteUserUseCase.js.map +1 -0
  889. package/features/users/DeleteUser/abstractions.d.ts +24 -0
  890. package/features/users/DeleteUser/abstractions.js +16 -0
  891. package/features/users/DeleteUser/abstractions.js.map +1 -0
  892. package/features/users/DeleteUser/decorators/DeleteUserWithWcpDecrement.d.ts +10 -0
  893. package/features/users/DeleteUser/decorators/DeleteUserWithWcpDecrement.js +25 -0
  894. package/features/users/DeleteUser/decorators/DeleteUserWithWcpDecrement.js.map +1 -0
  895. package/features/users/DeleteUser/errors.d.ts +5 -0
  896. package/features/users/DeleteUser/errors.js +11 -0
  897. package/features/users/DeleteUser/errors.js.map +1 -0
  898. package/features/users/DeleteUser/events.d.ts +21 -0
  899. package/features/users/DeleteUser/events.js +20 -0
  900. package/features/users/DeleteUser/events.js.map +1 -0
  901. package/features/users/DeleteUser/feature.d.ts +1 -0
  902. package/features/users/DeleteUser/feature.js +12 -0
  903. package/features/users/DeleteUser/feature.js.map +1 -0
  904. package/features/users/DeleteUser/index.d.ts +2 -0
  905. package/features/users/DeleteUser/index.js +4 -0
  906. package/features/users/DeleteUser/index.js.map +1 -0
  907. package/features/users/ExternalIdpUserSync/ExternalIdpUserSyncHandler.d.ts +19 -0
  908. package/features/users/ExternalIdpUserSync/ExternalIdpUserSyncHandler.js +89 -0
  909. package/features/users/ExternalIdpUserSync/ExternalIdpUserSyncHandler.js.map +1 -0
  910. package/features/users/ExternalIdpUserSync/feature.d.ts +1 -0
  911. package/features/users/ExternalIdpUserSync/feature.js +10 -0
  912. package/features/users/ExternalIdpUserSync/feature.js.map +1 -0
  913. package/features/users/ExternalIdpUserSync/index.d.ts +1 -0
  914. package/features/users/ExternalIdpUserSync/index.js +3 -0
  915. package/features/users/ExternalIdpUserSync/index.js.map +1 -0
  916. package/features/users/GetIdentityProfile/GetIdentityProfileUseCase.d.ts +13 -0
  917. package/features/users/GetIdentityProfile/GetIdentityProfileUseCase.js +49 -0
  918. package/features/users/GetIdentityProfile/GetIdentityProfileUseCase.js.map +1 -0
  919. package/features/users/GetIdentityProfile/abstractions.d.ts +18 -0
  920. package/features/users/GetIdentityProfile/abstractions.js +14 -0
  921. package/features/users/GetIdentityProfile/abstractions.js.map +1 -0
  922. package/features/users/GetIdentityProfile/feature.d.ts +1 -0
  923. package/features/users/GetIdentityProfile/feature.js +10 -0
  924. package/features/users/GetIdentityProfile/feature.js.map +1 -0
  925. package/features/users/GetIdentityProfile/index.d.ts +1 -0
  926. package/features/users/GetIdentityProfile/index.js +3 -0
  927. package/features/users/GetIdentityProfile/index.js.map +1 -0
  928. package/features/users/GetIdentityProfile/types.d.ts +11 -0
  929. package/features/users/GetIdentityProfile/types.js +3 -0
  930. package/features/users/GetIdentityProfile/types.js.map +1 -0
  931. package/features/users/GetUser/GetUserUseCase.d.ts +14 -0
  932. package/features/users/GetUser/GetUserUseCase.js +33 -0
  933. package/features/users/GetUser/GetUserUseCase.js.map +1 -0
  934. package/features/users/GetUser/abstractions.d.ts +18 -0
  935. package/features/users/GetUser/abstractions.js +14 -0
  936. package/features/users/GetUser/abstractions.js.map +1 -0
  937. package/features/users/GetUser/feature.d.ts +1 -0
  938. package/features/users/GetUser/feature.js +10 -0
  939. package/features/users/GetUser/feature.js.map +1 -0
  940. package/features/users/GetUser/index.d.ts +1 -0
  941. package/features/users/GetUser/index.js +3 -0
  942. package/features/users/GetUser/index.js.map +1 -0
  943. package/features/users/ListUserTeams/ListUserTeamsUseCase.d.ts +15 -0
  944. package/features/users/ListUserTeams/ListUserTeamsUseCase.js +50 -0
  945. package/features/users/ListUserTeams/ListUserTeamsUseCase.js.map +1 -0
  946. package/features/users/ListUserTeams/abstractions.d.ts +15 -0
  947. package/features/users/ListUserTeams/abstractions.js +14 -0
  948. package/features/users/ListUserTeams/abstractions.js.map +1 -0
  949. package/features/users/ListUserTeams/feature.d.ts +1 -0
  950. package/features/users/ListUserTeams/feature.js +10 -0
  951. package/features/users/ListUserTeams/feature.js.map +1 -0
  952. package/features/users/ListUserTeams/index.d.ts +1 -0
  953. package/features/users/ListUserTeams/index.js +3 -0
  954. package/features/users/ListUserTeams/index.js.map +1 -0
  955. package/features/users/ListUsers/ListUsersUseCase.d.ts +14 -0
  956. package/features/users/ListUsers/ListUsersUseCase.js +33 -0
  957. package/features/users/ListUsers/ListUsersUseCase.js.map +1 -0
  958. package/features/users/ListUsers/abstractions.d.ts +18 -0
  959. package/features/users/ListUsers/abstractions.js +14 -0
  960. package/features/users/ListUsers/abstractions.js.map +1 -0
  961. package/features/users/ListUsers/feature.d.ts +1 -0
  962. package/features/users/ListUsers/feature.js +10 -0
  963. package/features/users/ListUsers/feature.js.map +1 -0
  964. package/features/users/ListUsers/index.d.ts +1 -0
  965. package/features/users/ListUsers/index.js +3 -0
  966. package/features/users/ListUsers/index.js.map +1 -0
  967. package/features/users/UpdateUser/UpdateUserUseCase.d.ts +16 -0
  968. package/features/users/UpdateUser/UpdateUserUseCase.js +86 -0
  969. package/features/users/UpdateUser/UpdateUserUseCase.js.map +1 -0
  970. package/features/users/UpdateUser/abstractions.d.ts +30 -0
  971. package/features/users/UpdateUser/abstractions.js +16 -0
  972. package/features/users/UpdateUser/abstractions.js.map +1 -0
  973. package/features/users/UpdateUser/events.d.ts +21 -0
  974. package/features/users/UpdateUser/events.js +20 -0
  975. package/features/users/UpdateUser/events.js.map +1 -0
  976. package/features/users/UpdateUser/feature.d.ts +1 -0
  977. package/features/users/UpdateUser/feature.js +10 -0
  978. package/features/users/UpdateUser/feature.js.map +1 -0
  979. package/features/users/UpdateUser/index.d.ts +2 -0
  980. package/features/users/UpdateUser/index.js +4 -0
  981. package/features/users/UpdateUser/index.js.map +1 -0
  982. package/features/users/UpdateUser/schema.d.ts +38 -0
  983. package/features/users/UpdateUser/schema.js +14 -0
  984. package/features/users/UpdateUser/schema.js.map +1 -0
  985. package/features/users/shared/AdminUsersRepository.d.ts +23 -0
  986. package/features/users/shared/AdminUsersRepository.js +129 -0
  987. package/features/users/shared/AdminUsersRepository.js.map +1 -0
  988. package/features/users/shared/abstractions.d.ts +24 -0
  989. package/features/users/shared/abstractions.js +12 -0
  990. package/features/users/shared/abstractions.js.map +1 -0
  991. package/features/users/shared/errors.d.ts +27 -0
  992. package/features/users/shared/errors.js +54 -0
  993. package/features/users/shared/errors.js.map +1 -0
  994. package/features/users/shared/loaders.d.ts +17 -0
  995. package/features/users/shared/loaders.js +73 -0
  996. package/features/users/shared/loaders.js.map +1 -0
  997. package/features/users/shared/storageAbstractions.d.ts +5 -0
  998. package/features/users/shared/storageAbstractions.js +5 -0
  999. package/features/users/shared/storageAbstractions.js.map +1 -0
  1000. package/features/users/shared/types.d.ts +49 -0
  1001. package/features/users/shared/types.js +3 -0
  1002. package/features/users/shared/types.js.map +1 -0
  1003. package/features/wcp/WcpContext/WcpContext.d.ts +32 -0
  1004. package/features/wcp/WcpContext/WcpContext.js +133 -0
  1005. package/features/wcp/WcpContext/WcpContext.js.map +1 -0
  1006. package/features/wcp/WcpContext/abstractions.d.ts +19 -0
  1007. package/features/wcp/WcpContext/abstractions.js +9 -0
  1008. package/features/wcp/WcpContext/abstractions.js.map +1 -0
  1009. package/features/wcp/WcpContext/feature.d.ts +2 -0
  1010. package/features/wcp/WcpContext/feature.js +11 -0
  1011. package/features/wcp/WcpContext/feature.js.map +1 -0
  1012. package/features/wcp/WcpContext/index.d.ts +4 -0
  1013. package/features/wcp/WcpContext/index.js +4 -0
  1014. package/features/wcp/WcpContext/index.js.map +1 -0
  1015. package/features/wcp/WcpContext/types.d.ts +17 -0
  1016. package/features/wcp/WcpContext/types.js +3 -0
  1017. package/features/wcp/WcpContext/types.js.map +1 -0
  1018. package/features/wcp/WcpContext/utils.d.ts +13 -0
  1019. package/features/wcp/WcpContext/utils.js +58 -0
  1020. package/features/wcp/WcpContext/utils.js.map +1 -0
  1021. package/features/wcp/WcpFeature.d.ts +2 -0
  1022. package/features/wcp/WcpFeature.js +10 -0
  1023. package/features/wcp/WcpFeature.js.map +1 -0
  1024. package/graphql/security/NotAuthorizedResponse.d.ts +10 -0
  1025. package/graphql/security/NotAuthorizedResponse.js +17 -0
  1026. package/graphql/security/NotAuthorizedResponse.js.map +1 -0
  1027. package/graphql/security/ProfileMapper.d.ts +16 -0
  1028. package/graphql/security/ProfileMapper.js +14 -0
  1029. package/graphql/security/ProfileMapper.js.map +1 -0
  1030. package/graphql/security/apiKey.gql.d.ts +4 -0
  1031. package/graphql/security/apiKey.gql.js +99 -0
  1032. package/graphql/security/apiKey.gql.js.map +1 -0
  1033. package/graphql/security/base.gql.d.ts +4 -0
  1034. package/graphql/security/base.gql.js +48 -0
  1035. package/graphql/security/base.gql.js.map +1 -0
  1036. package/graphql/security/identity.gql.d.ts +4 -0
  1037. package/graphql/security/identity.gql.js +163 -0
  1038. package/graphql/security/identity.gql.js.map +1 -0
  1039. package/graphql/security/index.d.ts +1 -0
  1040. package/graphql/security/index.js +10 -0
  1041. package/graphql/security/index.js.map +1 -0
  1042. package/graphql/security/role.gql.d.ts +4 -0
  1043. package/graphql/security/role.gql.js +114 -0
  1044. package/graphql/security/role.gql.js.map +1 -0
  1045. package/graphql/security/team.gql.d.ts +4 -0
  1046. package/graphql/security/team.gql.js +127 -0
  1047. package/graphql/security/team.gql.js.map +1 -0
  1048. package/graphql/system/createSystemGraphQL.d.ts +2 -0
  1049. package/graphql/system/createSystemGraphQL.js +57 -0
  1050. package/graphql/system/createSystemGraphQL.js.map +1 -0
  1051. package/graphql/users/user.gql.d.ts +3 -0
  1052. package/graphql/users/user.gql.js +185 -0
  1053. package/graphql/users/user.gql.js.map +1 -0
  1054. package/graphql/wcp/graphql.d.ts +2 -0
  1055. package/graphql/wcp/graphql.js +88 -0
  1056. package/graphql/wcp/graphql.js.map +1 -0
  1057. package/idp/JwksCache.d.ts +7 -0
  1058. package/idp/JwksCache.js +32 -0
  1059. package/idp/JwksCache.js.map +1 -0
  1060. package/idp/JwtAuthenticator.d.ts +12 -0
  1061. package/idp/JwtAuthenticator.js +58 -0
  1062. package/idp/JwtAuthenticator.js.map +1 -0
  1063. package/idp/OidcJwtIdentityProvider.d.ts +15 -0
  1064. package/idp/OidcJwtIdentityProvider.js +90 -0
  1065. package/idp/OidcJwtIdentityProvider.js.map +1 -0
  1066. package/idp/abstractions.d.ts +62 -0
  1067. package/idp/abstractions.js +13 -0
  1068. package/idp/abstractions.js.map +1 -0
  1069. package/idp/feature.d.ts +1 -0
  1070. package/idp/feature.js +15 -0
  1071. package/idp/feature.js.map +1 -0
  1072. package/idp/index.d.ts +2 -0
  1073. package/idp/index.js +3 -0
  1074. package/idp/index.js.map +1 -0
  1075. package/idp/types.d.ts +3 -0
  1076. package/idp/types.js +3 -0
  1077. package/idp/types.js.map +1 -0
  1078. package/index.d.ts +1 -0
  1079. package/index.js +3 -0
  1080. package/index.js.map +1 -0
  1081. package/legacy/security/LegacyContext.d.ts +36 -0
  1082. package/legacy/security/LegacyContext.js +205 -0
  1083. package/legacy/security/LegacyContext.js.map +1 -0
  1084. package/legacy/security/createSecurityContext.d.ts +3 -0
  1085. package/legacy/security/createSecurityContext.js +25 -0
  1086. package/legacy/security/createSecurityContext.js.map +1 -0
  1087. package/legacy/security/plugins/SecurityRolePlugin.d.ts +16 -0
  1088. package/legacy/security/plugins/SecurityRolePlugin.js +33 -0
  1089. package/legacy/security/plugins/SecurityRolePlugin.js.map +1 -0
  1090. package/legacy/security/plugins/SecurityTeamPlugin.d.ts +16 -0
  1091. package/legacy/security/plugins/SecurityTeamPlugin.js +33 -0
  1092. package/legacy/security/plugins/SecurityTeamPlugin.js.map +1 -0
  1093. package/legacy/security/plugins/apiKeyAuthentication.d.ts +7 -0
  1094. package/legacy/security/plugins/apiKeyAuthentication.js +29 -0
  1095. package/legacy/security/plugins/apiKeyAuthentication.js.map +1 -0
  1096. package/legacy/security/plugins/apiKeyAuthorization.d.ts +6 -0
  1097. package/legacy/security/plugins/apiKeyAuthorization.js +22 -0
  1098. package/legacy/security/plugins/apiKeyAuthorization.js.map +1 -0
  1099. package/legacy/security/plugins/authenticateUsingCookie.d.ts +5 -0
  1100. package/legacy/security/plugins/authenticateUsingCookie.js +27 -0
  1101. package/legacy/security/plugins/authenticateUsingCookie.js.map +1 -0
  1102. package/legacy/security/plugins/authenticateUsingHttpHeader.d.ts +5 -0
  1103. package/legacy/security/plugins/authenticateUsingHttpHeader.js +23 -0
  1104. package/legacy/security/plugins/authenticateUsingHttpHeader.js.map +1 -0
  1105. package/legacy/security/plugins/secureHeaders.d.ts +1 -0
  1106. package/legacy/security/plugins/secureHeaders.js +23 -0
  1107. package/legacy/security/plugins/secureHeaders.js.map +1 -0
  1108. package/legacy/tenancy/LegacyContext.d.ts +15 -0
  1109. package/legacy/tenancy/LegacyContext.js +64 -0
  1110. package/legacy/tenancy/LegacyContext.js.map +1 -0
  1111. package/legacy/tenancy/createTenancyContext.d.ts +3 -0
  1112. package/legacy/tenancy/createTenancyContext.js +51 -0
  1113. package/legacy/tenancy/createTenancyContext.js.map +1 -0
  1114. package/legacy/users/LegacyContext.d.ts +13 -0
  1115. package/legacy/users/LegacyContext.js +70 -0
  1116. package/legacy/users/LegacyContext.js.map +1 -0
  1117. package/legacy/users/createAdminUsersContext.d.ts +3 -0
  1118. package/legacy/users/createAdminUsersContext.js +12 -0
  1119. package/legacy/users/createAdminUsersContext.js.map +1 -0
  1120. package/legacy/wcp/LegacyWcpContext.d.ts +28 -0
  1121. package/legacy/wcp/LegacyWcpContext.js +68 -0
  1122. package/legacy/wcp/LegacyWcpContext.js.map +1 -0
  1123. package/legacy/wcp/context.d.ts +7 -0
  1124. package/legacy/wcp/context.js +50 -0
  1125. package/legacy/wcp/context.js.map +1 -0
  1126. package/models/base/BaseModel.d.ts +20 -0
  1127. package/models/base/BaseModel.js +64 -0
  1128. package/models/base/BaseModel.js.map +1 -0
  1129. package/models/base/ModelBuilder.d.ts +18 -0
  1130. package/models/base/ModelBuilder.js +68 -0
  1131. package/models/base/ModelBuilder.js.map +1 -0
  1132. package/models/base/ModelFactory.d.ts +0 -0
  1133. package/models/base/ModelFactory.js +3 -0
  1134. package/models/base/ModelFactory.js.map +1 -0
  1135. package/models/base/__tests__/ModelBuilder.test.d.ts +1 -0
  1136. package/models/base/__tests__/ModelBuilder.test.js +468 -0
  1137. package/models/base/__tests__/ModelBuilder.test.js.map +1 -0
  1138. package/models/base/abstractions.d.ts +19 -0
  1139. package/models/base/abstractions.js +3 -0
  1140. package/models/base/abstractions.js.map +1 -0
  1141. package/models/cms/FieldBuilder.d.ts +36 -0
  1142. package/models/cms/FieldBuilder.js +132 -0
  1143. package/models/cms/FieldBuilder.js.map +1 -0
  1144. package/models/cms/FieldBuilderRegistry.d.ts +11 -0
  1145. package/models/cms/FieldBuilderRegistry.js +18 -0
  1146. package/models/cms/FieldBuilderRegistry.js.map +1 -0
  1147. package/models/cms/FieldDefinitionsBuilder.d.ts +24 -0
  1148. package/models/cms/FieldDefinitionsBuilder.js +63 -0
  1149. package/models/cms/FieldDefinitionsBuilder.js.map +1 -0
  1150. package/models/cms/PrivateCmsModelBuilder.d.ts +21 -0
  1151. package/models/cms/PrivateCmsModelBuilder.js +103 -0
  1152. package/models/cms/PrivateCmsModelBuilder.js.map +1 -0
  1153. package/models/cms/PrivatePage/Page.fields.d.ts +8 -0
  1154. package/models/cms/PrivatePage/Page.fields.js +9 -0
  1155. package/models/cms/PrivatePage/Page.fields.js.map +1 -0
  1156. package/models/cms/PrivatePage/PageModelBuilder.d.ts +9 -0
  1157. package/models/cms/PrivatePage/PageModelBuilder.js +23 -0
  1158. package/models/cms/PrivatePage/PageModelBuilder.js.map +1 -0
  1159. package/models/cms/PrivatePage/PageModelFactory.d.ts +12 -0
  1160. package/models/cms/PrivatePage/PageModelFactory.js +32 -0
  1161. package/models/cms/PrivatePage/PageModelFactory.js.map +1 -0
  1162. package/models/cms/PrivatePage/__tests__/PageModelFactory.test.d.ts +1 -0
  1163. package/models/cms/PrivatePage/__tests__/PageModelFactory.test.js +251 -0
  1164. package/models/cms/PrivatePage/__tests__/PageModelFactory.test.js.map +1 -0
  1165. package/models/cms/PrivatePage/__tests__/PagePublishingDecorator.d.ts +21 -0
  1166. package/models/cms/PrivatePage/__tests__/PagePublishingDecorator.js +43 -0
  1167. package/models/cms/PrivatePage/__tests__/PagePublishingDecorator.js.map +1 -0
  1168. package/models/cms/PrivatePage/__tests__/PageSeoDecorator.d.ts +21 -0
  1169. package/models/cms/PrivatePage/__tests__/PageSeoDecorator.js +33 -0
  1170. package/models/cms/PrivatePage/__tests__/PageSeoDecorator.js.map +1 -0
  1171. package/models/cms/PrivatePage/abstractions.d.ts +19 -0
  1172. package/models/cms/PrivatePage/abstractions.js +12 -0
  1173. package/models/cms/PrivatePage/abstractions.js.map +1 -0
  1174. package/models/cms/__tests__/PrivateCmsModelBuilder.test.d.ts +1 -0
  1175. package/models/cms/__tests__/PrivateCmsModelBuilder.test.js +195 -0
  1176. package/models/cms/__tests__/PrivateCmsModelBuilder.test.js.map +1 -0
  1177. package/models/cms/abstractions.d.ts +38 -0
  1178. package/models/cms/abstractions.js +23 -0
  1179. package/models/cms/abstractions.js.map +1 -0
  1180. package/models/cms/fieldsBuilder.md +386 -0
  1181. package/models/cms/types.d.ts +45 -0
  1182. package/models/cms/types.js +3 -0
  1183. package/models/cms/types.js.map +1 -0
  1184. package/models/simple/Page/PageModelBuilder.d.ts +10 -0
  1185. package/models/simple/Page/PageModelBuilder.js +20 -0
  1186. package/models/simple/Page/PageModelBuilder.js.map +1 -0
  1187. package/models/simple/Page/PageModelFactory.d.ts +9 -0
  1188. package/models/simple/Page/PageModelFactory.js +22 -0
  1189. package/models/simple/Page/PageModelFactory.js.map +1 -0
  1190. package/models/simple/Page/__tests__/PageModelBuilderDecorator.d.ts +20 -0
  1191. package/models/simple/Page/__tests__/PageModelBuilderDecorator.js +26 -0
  1192. package/models/simple/Page/__tests__/PageModelBuilderDecorator.js.map +1 -0
  1193. package/models/simple/Page/__tests__/PageModelBuilderDecorator2.d.ts +15 -0
  1194. package/models/simple/Page/__tests__/PageModelBuilderDecorator2.js +22 -0
  1195. package/models/simple/Page/__tests__/PageModelBuilderDecorator2.js.map +1 -0
  1196. package/models/simple/Page/__tests__/PageModelFactory.test.d.ts +1 -0
  1197. package/models/simple/Page/__tests__/PageModelFactory.test.js +38 -0
  1198. package/models/simple/Page/__tests__/PageModelFactory.test.js.map +1 -0
  1199. package/models/simple/Page/abstractions.d.ts +35 -0
  1200. package/models/simple/Page/abstractions.js +12 -0
  1201. package/models/simple/Page/abstractions.js.map +1 -0
  1202. package/package.json +98 -0
  1203. package/types/core.d.ts +13 -0
  1204. package/types/core.js +3 -0
  1205. package/types/core.js.map +1 -0
  1206. package/types/security.d.ts +203 -0
  1207. package/types/security.js +3 -0
  1208. package/types/security.js.map +1 -0
  1209. package/types/tenancy.d.ts +49 -0
  1210. package/types/tenancy.js +3 -0
  1211. package/types/tenancy.js.map +1 -0
  1212. package/types/users.d.ts +85 -0
  1213. package/types/users.js +3 -0
  1214. package/types/users.js.map +1 -0
@@ -0,0 +1,185 @@
1
+ import { ErrorResponse, ListErrorResponse, ListResponse, NotFoundResponse, Response } from "@webiny/handler-graphql/responses.js";
2
+ import { GraphQLSchemaPlugin } from "@webiny/handler-graphql/plugins/GraphQLSchemaPlugin.js";
3
+ import { GetUserUseCase } from "../../features/users/GetUser/index.js";
4
+ import NotAuthorizedResponse from "../security/NotAuthorizedResponse.js";
5
+ import { ListUsersUseCase } from "../../features/users/ListUsers/index.js";
6
+ const emptyResolver = () => ({});
7
+ export const createUsersGraphQL = () => {
8
+ return [new GraphQLSchemaPlugin({
9
+ typeDefs: /* GraphQL */`
10
+ type AdminUsersQuery {
11
+ _empty: String
12
+ }
13
+
14
+ type AdminUsersMutation {
15
+ _empty: String
16
+ }
17
+
18
+ extend type Query {
19
+ adminUsers: AdminUsersQuery
20
+ }
21
+
22
+ extend type Mutation {
23
+ adminUsers: AdminUsersMutation
24
+ }
25
+
26
+ type AdminUsersCreatedBy {
27
+ id: ID
28
+ displayName: String
29
+ }
30
+
31
+ type AdminUsersError {
32
+ code: String
33
+ message: String
34
+ data: JSON
35
+ stack: String
36
+ }
37
+
38
+ type AdminUsersBooleanResponse {
39
+ data: Boolean
40
+ error: AdminUsersError
41
+ }
42
+ `,
43
+ resolvers: {
44
+ Query: {
45
+ adminUsers: emptyResolver
46
+ },
47
+ Mutation: {
48
+ adminUsers: emptyResolver
49
+ }
50
+ }
51
+ }), new GraphQLSchemaPlugin({
52
+ typeDefs: /* GraphQL */`
53
+ type AdminUser {
54
+ id: ID!
55
+ displayName: String!
56
+ email: String!
57
+
58
+ roles: [SecurityRole]
59
+ firstName: String
60
+ lastName: String
61
+ avatar: JSON
62
+ external: Boolean
63
+ createdOn: DateTime
64
+ }
65
+
66
+ type AdminUsersResponse {
67
+ data: AdminUser
68
+ error: AdminUsersError
69
+ }
70
+
71
+ type AdminUsersListResponse {
72
+ data: [AdminUser]
73
+ error: AdminUsersError
74
+ }
75
+
76
+ input AdminUsersGetUserWhereInput {
77
+ id: ID
78
+ email: String
79
+ }
80
+
81
+ extend type AdminUsersQuery {
82
+ getUser(where: AdminUsersGetUserWhereInput): AdminUsersResponse
83
+ getCurrentUser: AdminUsersResponse
84
+ listUsers: AdminUsersListResponse
85
+ }
86
+ `,
87
+ resolvers: {
88
+ AdminUser: {
89
+ roles(user, _, context) {
90
+ if (!user.roles) {
91
+ return null;
92
+ }
93
+ return context.security.listRoles({
94
+ where: {
95
+ id_in: user.roles
96
+ }
97
+ });
98
+ }
99
+ },
100
+ AdminUsersQuery: {
101
+ getUser: async (_, {
102
+ where
103
+ }, context) => {
104
+ const getUser = context.container.resolve(GetUserUseCase);
105
+ const userResult = await getUser.execute({
106
+ id: where.id,
107
+ email: where.email
108
+ });
109
+ if (userResult.isFail()) {
110
+ const error = userResult.error;
111
+ if (error.code === "AdminUser/NotFound") {
112
+ return new NotFoundResponse(`User "${JSON.stringify(where)}" was not found!`);
113
+ }
114
+ return new ErrorResponse({
115
+ message: error.message,
116
+ code: error.code,
117
+ data: error.data
118
+ });
119
+ }
120
+ return new Response(userResult.value);
121
+ },
122
+ getCurrentUser: async (_, __, context) => {
123
+ const identity = context.security.getIdentity();
124
+ if (!identity.isAdmin()) {
125
+ throw new NotAuthorizedResponse();
126
+ }
127
+
128
+ // Current user might not have permissions to execute `getUser` (this method can load any user in the system),
129
+ // but loading your own user record should be allowed. For that reason, let's temporarily disable authorization.
130
+
131
+ const getUser = context.container.resolve(GetUserUseCase);
132
+ const userResponse = await context.security.withoutAuthorization(async () => {
133
+ // Get user record using the identity ID.
134
+ return await getUser.execute({
135
+ id: identity.id
136
+ });
137
+ });
138
+ if (userResponse.isFail()) {
139
+ const error = userResponse.error;
140
+ if (error.code === "AdminUser/NotFound") {
141
+ return new NotFoundResponse(`User with ID ${identity.id} was not found!`);
142
+ }
143
+ return new ErrorResponse({
144
+ message: error.message,
145
+ code: error.code,
146
+ data: error.data
147
+ });
148
+ }
149
+ return new Response(userResponse.value);
150
+ },
151
+ listUsers: async (_, __, context) => {
152
+ const listUsers = context.container.resolve(ListUsersUseCase);
153
+ const users = await listUsers.execute();
154
+ if (users.isFail()) {
155
+ return new ListErrorResponse(users.error);
156
+ }
157
+ return new ListResponse(users.value);
158
+ }
159
+ }
160
+ }
161
+ }), new GraphQLSchemaPlugin({
162
+ typeDefs: /* GraphQL */`
163
+ extend type AdminUser {
164
+ teams: [SecurityTeam]
165
+ }
166
+ `,
167
+ resolvers: {
168
+ AdminUser: {
169
+ teams(user, _, context) {
170
+ const hasTeams = Array.isArray(user.teams) && user.teams.length > 0;
171
+ if (!hasTeams) {
172
+ return [];
173
+ }
174
+ return context.security.listTeams({
175
+ where: {
176
+ id_in: user.teams
177
+ }
178
+ });
179
+ }
180
+ }
181
+ }
182
+ })].filter(Boolean);
183
+ };
184
+
185
+ //# sourceMappingURL=user.gql.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["ErrorResponse","ListErrorResponse","ListResponse","NotFoundResponse","Response","GraphQLSchemaPlugin","GetUserUseCase","NotAuthorizedResponse","ListUsersUseCase","emptyResolver","createUsersGraphQL","typeDefs","resolvers","Query","adminUsers","Mutation","AdminUser","roles","user","_","context","security","listRoles","where","id_in","AdminUsersQuery","getUser","container","resolve","userResult","execute","id","email","isFail","error","code","JSON","stringify","message","data","value","getCurrentUser","__","identity","getIdentity","isAdmin","userResponse","withoutAuthorization","listUsers","users","teams","hasTeams","Array","isArray","length","listTeams","filter","Boolean"],"sources":["user.gql.ts"],"sourcesContent":["import {\n ErrorResponse,\n ListErrorResponse,\n ListResponse,\n NotFoundResponse,\n Response\n} from \"@webiny/handler-graphql/responses.js\";\nimport { GraphQLSchemaPlugin } from \"@webiny/handler-graphql/plugins/GraphQLSchemaPlugin.js\";\nimport type { ApiCoreContext } from \"~/types/core.js\";\nimport { AdminUser } from \"~/types/users.js\";\nimport { GetUserUseCase } from \"~/features/users/GetUser/index.js\";\nimport NotAuthorizedResponse from \"~/graphql/security/NotAuthorizedResponse.js\";\nimport { ListUsersUseCase } from \"~/features/users/ListUsers/index.js\";\n\nconst emptyResolver = () => ({});\n\nexport const createUsersGraphQL = () => {\n return [\n new GraphQLSchemaPlugin<ApiCoreContext>({\n typeDefs: /* GraphQL */ `\n type AdminUsersQuery {\n _empty: String\n }\n\n type AdminUsersMutation {\n _empty: String\n }\n\n extend type Query {\n adminUsers: AdminUsersQuery\n }\n\n extend type Mutation {\n adminUsers: AdminUsersMutation\n }\n\n type AdminUsersCreatedBy {\n id: ID\n displayName: String\n }\n\n type AdminUsersError {\n code: String\n message: String\n data: JSON\n stack: String\n }\n\n type AdminUsersBooleanResponse {\n data: Boolean\n error: AdminUsersError\n }\n `,\n resolvers: {\n Query: {\n adminUsers: emptyResolver\n },\n Mutation: {\n adminUsers: emptyResolver\n }\n }\n }),\n new GraphQLSchemaPlugin<ApiCoreContext>({\n typeDefs: /* GraphQL */ `\n type AdminUser {\n id: ID!\n displayName: String!\n email: String!\n\n roles: [SecurityRole]\n firstName: String\n lastName: String\n avatar: JSON\n external: Boolean\n createdOn: DateTime\n }\n\n type AdminUsersResponse {\n data: AdminUser\n error: AdminUsersError\n }\n\n type AdminUsersListResponse {\n data: [AdminUser]\n error: AdminUsersError\n }\n\n input AdminUsersGetUserWhereInput {\n id: ID\n email: String\n }\n\n extend type AdminUsersQuery {\n getUser(where: AdminUsersGetUserWhereInput): AdminUsersResponse\n getCurrentUser: AdminUsersResponse\n listUsers: AdminUsersListResponse\n }\n `,\n resolvers: {\n AdminUser: {\n roles(user: AdminUser, _, context) {\n if (!user.roles) {\n return null;\n }\n\n return context.security.listRoles({ where: { id_in: user.roles } });\n }\n },\n AdminUsersQuery: {\n getUser: async (_, { where }: any, context) => {\n const getUser = context.container.resolve(GetUserUseCase);\n\n const userResult = await getUser.execute({\n id: where.id,\n email: where.email\n });\n\n if (userResult.isFail()) {\n const error = userResult.error;\n if (error.code === \"AdminUser/NotFound\") {\n return new NotFoundResponse(\n `User \"${JSON.stringify(where)}\" was not found!`\n );\n }\n\n return new ErrorResponse({\n message: error.message,\n code: error.code,\n data: error.data\n });\n }\n\n return new Response(userResult.value);\n },\n getCurrentUser: async (_, __, context) => {\n const identity = context.security.getIdentity();\n\n if (!identity.isAdmin()) {\n throw new NotAuthorizedResponse();\n }\n\n // Current user might not have permissions to execute `getUser` (this method can load any user in the system),\n // but loading your own user record should be allowed. For that reason, let's temporarily disable authorization.\n\n const getUser = context.container.resolve(GetUserUseCase);\n\n const userResponse = await context.security.withoutAuthorization(\n async () => {\n // Get user record using the identity ID.\n return await getUser.execute({ id: identity.id });\n }\n );\n\n if (userResponse.isFail()) {\n const error = userResponse.error;\n if (error.code === \"AdminUser/NotFound\") {\n return new NotFoundResponse(\n `User with ID ${identity.id} was not found!`\n );\n }\n\n return new ErrorResponse({\n message: error.message,\n code: error.code,\n data: error.data\n });\n }\n\n return new Response(userResponse.value);\n },\n listUsers: async (_, __, context) => {\n const listUsers = context.container.resolve(ListUsersUseCase);\n const users = await listUsers.execute();\n\n if (users.isFail()) {\n return new ListErrorResponse(users.error);\n }\n\n return new ListResponse(users.value);\n }\n }\n }\n }),\n new GraphQLSchemaPlugin<ApiCoreContext>({\n typeDefs: /* GraphQL */ `\n extend type AdminUser {\n teams: [SecurityTeam]\n }\n `,\n resolvers: {\n AdminUser: {\n teams(user: AdminUser, _, context) {\n const hasTeams = Array.isArray(user.teams) && user.teams.length > 0;\n if (!hasTeams) {\n return [];\n }\n\n return context.security.listTeams({ where: { id_in: user.teams } });\n }\n }\n }\n })\n ].filter(Boolean);\n};\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import { GraphQLSchemaPlugin } from "@webiny/handler-graphql/plugins/index.js";
2
+ export declare const createWcpGraphQL: () => GraphQLSchemaPlugin<import("@webiny/api/types").Context>;
@@ -0,0 +1,88 @@
1
+ import { GraphQLSchemaPlugin } from "@webiny/handler-graphql/plugins/index.js";
2
+ import { ErrorResponse, Response } from "@webiny/handler-graphql/responses.js";
3
+ import { WcpContext } from "../../features/wcp/WcpContext/index.js";
4
+ const emptyResolver = () => ({});
5
+ export const createWcpGraphQL = () => {
6
+ return new GraphQLSchemaPlugin({
7
+ typeDefs: /* GraphQL */`
8
+ type WcpProjectPackageFeaturesFeature {
9
+ enabled: Boolean
10
+ options: JSON
11
+ }
12
+
13
+ type WcpProjectPackageFeatures {
14
+ seats: WcpProjectPackageFeaturesFeature
15
+ multiTenancy: WcpProjectPackageFeaturesFeature
16
+ advancedPublishingWorkflow: WcpProjectPackageFeaturesFeature
17
+ advancedAccessControlLayer: WcpProjectPackageFeaturesFeature
18
+ auditLogs: WcpProjectPackageFeaturesFeature
19
+ recordLocking: WcpProjectPackageFeaturesFeature
20
+ fileManager: WcpProjectPackageFeaturesFeature
21
+ }
22
+
23
+ type WcpProjectPackage {
24
+ features: WcpProjectPackageFeatures
25
+ }
26
+
27
+ type WcpProject {
28
+ orgId: ID
29
+ projectId: ID
30
+ package: WcpProjectPackage
31
+ }
32
+
33
+ type WcpError {
34
+ code: String
35
+ message: String
36
+ data: JSON
37
+ stack: String
38
+ }
39
+
40
+ type WcpProjectResponse {
41
+ data: WcpProject
42
+ error: WcpError
43
+ }
44
+
45
+ type WcpQuery {
46
+ getProject: WcpProjectResponse
47
+ }
48
+
49
+ type WcpMutation {
50
+ updateProject: WcpProjectResponse
51
+ }
52
+
53
+ extend type Query {
54
+ wcp: WcpQuery
55
+ }
56
+
57
+ extend type Mutation {
58
+ wcp: WcpMutation
59
+ }
60
+ `,
61
+ resolvers: {
62
+ Query: {
63
+ wcp: emptyResolver
64
+ },
65
+ WcpQuery: {
66
+ getProject: async (_, __, context) => {
67
+ try {
68
+ const wcpContext = context.container.resolve(WcpContext);
69
+ const project = wcpContext.getProject();
70
+ if (!project) {
71
+ throw Error(`Could not get project!`);
72
+ }
73
+ return new Response(project);
74
+ } catch (e) {
75
+ return new ErrorResponse({
76
+ code: "COULD_NOT_GET_PROJECT",
77
+ message: e.message,
78
+ data: null,
79
+ stack: e.stack
80
+ });
81
+ }
82
+ }
83
+ }
84
+ }
85
+ });
86
+ };
87
+
88
+ //# sourceMappingURL=graphql.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["GraphQLSchemaPlugin","ErrorResponse","Response","WcpContext","emptyResolver","createWcpGraphQL","typeDefs","resolvers","Query","wcp","WcpQuery","getProject","_","__","context","wcpContext","container","resolve","project","Error","e","code","message","data","stack"],"sources":["graphql.ts"],"sourcesContent":["import { GraphQLSchemaPlugin } from \"@webiny/handler-graphql/plugins/index.js\";\nimport { ErrorResponse, Response } from \"@webiny/handler-graphql/responses.js\";\nimport { WcpContext } from \"~/features/wcp/WcpContext/index.js\";\n\nconst emptyResolver = () => ({});\n\nexport const createWcpGraphQL = () => {\n return new GraphQLSchemaPlugin({\n typeDefs: /* GraphQL */ `\n type WcpProjectPackageFeaturesFeature {\n enabled: Boolean\n options: JSON\n }\n\n type WcpProjectPackageFeatures {\n seats: WcpProjectPackageFeaturesFeature\n multiTenancy: WcpProjectPackageFeaturesFeature\n advancedPublishingWorkflow: WcpProjectPackageFeaturesFeature\n advancedAccessControlLayer: WcpProjectPackageFeaturesFeature\n auditLogs: WcpProjectPackageFeaturesFeature\n recordLocking: WcpProjectPackageFeaturesFeature\n fileManager: WcpProjectPackageFeaturesFeature\n }\n\n type WcpProjectPackage {\n features: WcpProjectPackageFeatures\n }\n\n type WcpProject {\n orgId: ID\n projectId: ID\n package: WcpProjectPackage\n }\n\n type WcpError {\n code: String\n message: String\n data: JSON\n stack: String\n }\n\n type WcpProjectResponse {\n data: WcpProject\n error: WcpError\n }\n\n type WcpQuery {\n getProject: WcpProjectResponse\n }\n\n type WcpMutation {\n updateProject: WcpProjectResponse\n }\n\n extend type Query {\n wcp: WcpQuery\n }\n\n extend type Mutation {\n wcp: WcpMutation\n }\n `,\n resolvers: {\n Query: {\n wcp: emptyResolver\n },\n WcpQuery: {\n getProject: async (_, __, context) => {\n try {\n const wcpContext = context.container.resolve(WcpContext);\n const project = wcpContext.getProject();\n\n if (!project) {\n throw Error(`Could not get project!`);\n }\n\n return new Response(project);\n } catch (e) {\n return new ErrorResponse({\n code: \"COULD_NOT_GET_PROJECT\",\n message: e.message,\n data: null,\n stack: e.stack\n });\n }\n }\n }\n }\n });\n};\n"],"mappings":"AAAA,SAASA,mBAAmB,QAAQ,0CAA0C;AAC9E,SAASC,aAAa,EAAEC,QAAQ,QAAQ,sCAAsC;AAC9E,SAASC,UAAU;AAEnB,MAAMC,aAAa,GAAGA,CAAA,MAAO,CAAC,CAAC,CAAC;AAEhC,OAAO,MAAMC,gBAAgB,GAAGA,CAAA,KAAM;EAClC,OAAO,IAAIL,mBAAmB,CAAC;IAC3BM,QAAQ,EAAE,aAAc;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;IACDC,SAAS,EAAE;MACPC,KAAK,EAAE;QACHC,GAAG,EAAEL;MACT,CAAC;MACDM,QAAQ,EAAE;QACNC,UAAU,EAAE,MAAAA,CAAOC,CAAC,EAAEC,EAAE,EAAEC,OAAO,KAAK;UAClC,IAAI;YACA,MAAMC,UAAU,GAAGD,OAAO,CAACE,SAAS,CAACC,OAAO,CAACd,UAAU,CAAC;YACxD,MAAMe,OAAO,GAAGH,UAAU,CAACJ,UAAU,CAAC,CAAC;YAEvC,IAAI,CAACO,OAAO,EAAE;cACV,MAAMC,KAAK,CAAC,wBAAwB,CAAC;YACzC;YAEA,OAAO,IAAIjB,QAAQ,CAACgB,OAAO,CAAC;UAChC,CAAC,CAAC,OAAOE,CAAC,EAAE;YACR,OAAO,IAAInB,aAAa,CAAC;cACrBoB,IAAI,EAAE,uBAAuB;cAC7BC,OAAO,EAAEF,CAAC,CAACE,OAAO;cAClBC,IAAI,EAAE,IAAI;cACVC,KAAK,EAAEJ,CAAC,CAACI;YACb,CAAC,CAAC;UACN;QACJ;MACJ;IACJ;EACJ,CAAC,CAAC;AACN,CAAC","ignoreList":[]}
@@ -0,0 +1,7 @@
1
+ import type { Jwk } from "../features/security/utils/verifyJwtUsingJwk.js";
2
+ import { JwkCache } from "./abstractions.js";
3
+ export declare class JwksCache implements JwkCache.Interface {
4
+ private cache;
5
+ getKeys(issuer: string): Promise<Jwk[]>;
6
+ clearCache(): void;
7
+ }
@@ -0,0 +1,32 @@
1
+ export class JwksCache {
2
+ cache = new Map();
3
+ async getKeys(issuer) {
4
+ // Check cache first
5
+ const cached = this.cache.get(issuer);
6
+ if (cached) {
7
+ return cached.jwks;
8
+ }
9
+
10
+ // Fetch OIDC configuration
11
+ const openidUrl = new URL(issuer);
12
+ const pathname = openidUrl.pathname + "/.well-known/openid-configuration";
13
+ openidUrl.pathname = pathname.replace(/\/+/g, "/");
14
+ const oidcConfig = await fetch(openidUrl.toString()).then(res => res.json());
15
+
16
+ // Fetch JWKs from jwks_uri
17
+ const jwksResponse = await fetch(oidcConfig.jwks_uri).then(res => res.json());
18
+ const jwks = jwksResponse.keys;
19
+
20
+ // Cache both config and JWKs
21
+ this.cache.set(issuer, {
22
+ oidcConfig,
23
+ jwks
24
+ });
25
+ return jwks;
26
+ }
27
+ clearCache() {
28
+ this.cache.clear();
29
+ }
30
+ }
31
+
32
+ //# sourceMappingURL=JwksCache.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["JwksCache","cache","Map","getKeys","issuer","cached","get","jwks","openidUrl","URL","pathname","replace","oidcConfig","fetch","toString","then","res","json","jwksResponse","jwks_uri","keys","set","clearCache","clear"],"sources":["JwksCache.ts"],"sourcesContent":["import type { Jwk } from \"~/features/security/utils/verifyJwtUsingJwk.js\";\nimport { JwkCache } from \"./abstractions.js\";\n\ninterface OidcConfiguration {\n jwks_uri: string;\n [key: string]: any;\n}\n\ninterface CacheEntry {\n oidcConfig: OidcConfiguration;\n jwks: Jwk[];\n}\n\nexport class JwksCache implements JwkCache.Interface {\n private cache = new Map<string, CacheEntry>();\n\n async getKeys(issuer: string): Promise<Jwk[]> {\n // Check cache first\n const cached = this.cache.get(issuer);\n if (cached) {\n return cached.jwks;\n }\n\n // Fetch OIDC configuration\n const openidUrl = new URL(issuer);\n const pathname = openidUrl.pathname + \"/.well-known/openid-configuration\";\n openidUrl.pathname = pathname.replace(/\\/+/g, \"/\");\n\n const oidcConfig = await fetch(openidUrl.toString()).then(\n res => res.json() as Promise<OidcConfiguration>\n );\n\n // Fetch JWKs from jwks_uri\n const jwksResponse = await fetch(oidcConfig.jwks_uri).then(res => res.json());\n const jwks = jwksResponse.keys as Jwk[];\n\n // Cache both config and JWKs\n this.cache.set(issuer, {\n oidcConfig,\n jwks\n });\n\n return jwks;\n }\n\n clearCache(): void {\n this.cache.clear();\n }\n}\n"],"mappings":"AAaA,OAAO,MAAMA,SAAS,CAA+B;EACzCC,KAAK,GAAG,IAAIC,GAAG,CAAqB,CAAC;EAE7C,MAAMC,OAAOA,CAACC,MAAc,EAAkB;IAC1C;IACA,MAAMC,MAAM,GAAG,IAAI,CAACJ,KAAK,CAACK,GAAG,CAACF,MAAM,CAAC;IACrC,IAAIC,MAAM,EAAE;MACR,OAAOA,MAAM,CAACE,IAAI;IACtB;;IAEA;IACA,MAAMC,SAAS,GAAG,IAAIC,GAAG,CAACL,MAAM,CAAC;IACjC,MAAMM,QAAQ,GAAGF,SAAS,CAACE,QAAQ,GAAG,mCAAmC;IACzEF,SAAS,CAACE,QAAQ,GAAGA,QAAQ,CAACC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC;IAElD,MAAMC,UAAU,GAAG,MAAMC,KAAK,CAACL,SAAS,CAACM,QAAQ,CAAC,CAAC,CAAC,CAACC,IAAI,CACrDC,GAAG,IAAIA,GAAG,CAACC,IAAI,CAAC,CACpB,CAAC;;IAED;IACA,MAAMC,YAAY,GAAG,MAAML,KAAK,CAACD,UAAU,CAACO,QAAQ,CAAC,CAACJ,IAAI,CAACC,GAAG,IAAIA,GAAG,CAACC,IAAI,CAAC,CAAC,CAAC;IAC7E,MAAMV,IAAI,GAAGW,YAAY,CAACE,IAAa;;IAEvC;IACA,IAAI,CAACnB,KAAK,CAACoB,GAAG,CAACjB,MAAM,EAAE;MACnBQ,UAAU;MACVL;IACJ,CAAC,CAAC;IAEF,OAAOA,IAAI;EACf;EAEAe,UAAUA,CAAA,EAAS;IACf,IAAI,CAACrB,KAAK,CAACsB,KAAK,CAAC,CAAC;EACtB;AACJ","ignoreList":[]}
@@ -0,0 +1,12 @@
1
+ import { Authenticator } from "../features/security/authentication/Authenticator/abstractions.js";
2
+ import { JwtIdentityProvider } from "./abstractions.js";
3
+ import type { IdentityData } from "../features/security/IdentityContext/Identity.js";
4
+ declare class JwtAuthenticatorImpl implements Authenticator.Interface {
5
+ private providers;
6
+ constructor(providers: JwtIdentityProvider.Interface[]);
7
+ authenticate(token: string): Promise<IdentityData | null>;
8
+ }
9
+ export declare const JwtAuthenticator: typeof JwtAuthenticatorImpl & {
10
+ __abstraction: import("@webiny/di").Abstraction<import("~/features/security/authentication/Authenticator/abstractions.js").IAuthenticator>;
11
+ };
12
+ export {};
@@ -0,0 +1,58 @@
1
+ import jwt from "jsonwebtoken";
2
+ import { Authenticator } from "../features/security/authentication/Authenticator/abstractions.js";
3
+ import { JwtIdentityProvider } from "./abstractions.js";
4
+ import { isJwt } from "../features/security/utils/isJwt.js";
5
+ class JwtAuthenticatorImpl {
6
+ constructor(providers) {
7
+ this.providers = providers;
8
+ }
9
+ async authenticate(token) {
10
+ if (!isJwt(token)) {
11
+ return null;
12
+ }
13
+
14
+ // Decode JWT to get payload
15
+ const decoded = jwt.decode(token, {
16
+ complete: true
17
+ });
18
+ if (!decoded || typeof decoded === "string") {
19
+ return null;
20
+ }
21
+ if (typeof decoded.payload === "string") {
22
+ return null;
23
+ }
24
+
25
+ // TODO: validate expiration claim and exit early if expired
26
+
27
+ for (const provider of this.providers) {
28
+ // Check if provider is applicable
29
+ if (provider.isApplicable(decoded.payload)) {
30
+ // Use provider to get identity
31
+ const identity = await provider.getIdentity(token, decoded);
32
+ if (identity) {
33
+ // We treat all IDP identities as external by default.
34
+ const isExternal = identity.profile?.external ?? true;
35
+ return {
36
+ ...identity,
37
+ type: identity.type ?? "admin",
38
+ profile: {
39
+ ...(identity.profile ?? {}),
40
+ external: isExternal
41
+ }
42
+ };
43
+ }
44
+ }
45
+ }
46
+
47
+ // No applicable provider found
48
+ return null;
49
+ }
50
+ }
51
+ export const JwtAuthenticator = Authenticator.createImplementation({
52
+ implementation: JwtAuthenticatorImpl,
53
+ dependencies: [[JwtIdentityProvider, {
54
+ multiple: true
55
+ }]]
56
+ });
57
+
58
+ //# sourceMappingURL=JwtAuthenticator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["jwt","Authenticator","JwtIdentityProvider","isJwt","JwtAuthenticatorImpl","constructor","providers","authenticate","token","decoded","decode","complete","payload","provider","isApplicable","identity","getIdentity","isExternal","profile","external","type","JwtAuthenticator","createImplementation","implementation","dependencies","multiple"],"sources":["JwtAuthenticator.ts"],"sourcesContent":["import jwt from \"jsonwebtoken\";\nimport { Authenticator } from \"~/features/security/authentication/Authenticator/abstractions.js\";\nimport { IdentityProvider, JwtIdentityProvider } from \"./abstractions.js\";\nimport { isJwt } from \"~/features/security/utils/isJwt.js\";\nimport type { IdentityData } from \"~/features/security/IdentityContext/Identity.js\";\n\nclass JwtAuthenticatorImpl implements Authenticator.Interface {\n constructor(private providers: JwtIdentityProvider.Interface[]) {}\n\n async authenticate(token: string): Promise<IdentityData | null> {\n if (!isJwt(token)) {\n return null;\n }\n\n // Decode JWT to get payload\n const decoded = jwt.decode(token, { complete: true });\n if (!decoded || typeof decoded === \"string\") {\n return null;\n }\n\n if (typeof decoded.payload === \"string\") {\n return null;\n }\n\n // TODO: validate expiration claim and exit early if expired\n\n for (const provider of this.providers) {\n // Check if provider is applicable\n if (provider.isApplicable(decoded.payload as IdentityProvider.JwtPayload)) {\n // Use provider to get identity\n const identity = await provider.getIdentity(\n token,\n decoded as JwtIdentityProvider.Jwt\n );\n\n if (identity) {\n // We treat all IDP identities as external by default.\n const isExternal = identity.profile?.external ?? true;\n return {\n ...identity,\n type: identity.type ?? \"admin\",\n profile: {\n ...(identity.profile ?? {}),\n external: isExternal\n }\n };\n }\n }\n }\n\n // No applicable provider found\n return null;\n }\n}\n\nexport const JwtAuthenticator = Authenticator.createImplementation({\n implementation: JwtAuthenticatorImpl,\n dependencies: [[JwtIdentityProvider, { multiple: true }]]\n});\n"],"mappings":"AAAA,OAAOA,GAAG,MAAM,cAAc;AAC9B,SAASC,aAAa;AACtB,SAA2BC,mBAAmB;AAC9C,SAASC,KAAK;AAGd,MAAMC,oBAAoB,CAAoC;EAC1DC,WAAWA,CAASC,SAA0C,EAAE;IAAA,KAA5CA,SAA0C,GAA1CA,SAA0C;EAAG;EAEjE,MAAMC,YAAYA,CAACC,KAAa,EAAgC;IAC5D,IAAI,CAACL,KAAK,CAACK,KAAK,CAAC,EAAE;MACf,OAAO,IAAI;IACf;;IAEA;IACA,MAAMC,OAAO,GAAGT,GAAG,CAACU,MAAM,CAACF,KAAK,EAAE;MAAEG,QAAQ,EAAE;IAAK,CAAC,CAAC;IACrD,IAAI,CAACF,OAAO,IAAI,OAAOA,OAAO,KAAK,QAAQ,EAAE;MACzC,OAAO,IAAI;IACf;IAEA,IAAI,OAAOA,OAAO,CAACG,OAAO,KAAK,QAAQ,EAAE;MACrC,OAAO,IAAI;IACf;;IAEA;;IAEA,KAAK,MAAMC,QAAQ,IAAI,IAAI,CAACP,SAAS,EAAE;MACnC;MACA,IAAIO,QAAQ,CAACC,YAAY,CAACL,OAAO,CAACG,OAAsC,CAAC,EAAE;QACvE;QACA,MAAMG,QAAQ,GAAG,MAAMF,QAAQ,CAACG,WAAW,CACvCR,KAAK,EACLC,OACJ,CAAC;QAED,IAAIM,QAAQ,EAAE;UACV;UACA,MAAME,UAAU,GAAGF,QAAQ,CAACG,OAAO,EAAEC,QAAQ,IAAI,IAAI;UACrD,OAAO;YACH,GAAGJ,QAAQ;YACXK,IAAI,EAAEL,QAAQ,CAACK,IAAI,IAAI,OAAO;YAC9BF,OAAO,EAAE;cACL,IAAIH,QAAQ,CAACG,OAAO,IAAI,CAAC,CAAC,CAAC;cAC3BC,QAAQ,EAAEF;YACd;UACJ,CAAC;QACL;MACJ;IACJ;;IAEA;IACA,OAAO,IAAI;EACf;AACJ;AAEA,OAAO,MAAMI,gBAAgB,GAAGpB,aAAa,CAACqB,oBAAoB,CAAC;EAC/DC,cAAc,EAAEnB,oBAAoB;EACpCoB,YAAY,EAAE,CAAC,CAACtB,mBAAmB,EAAE;IAAEuB,QAAQ,EAAE;EAAK,CAAC,CAAC;AAC5D,CAAC,CAAC","ignoreList":[]}
@@ -0,0 +1,15 @@
1
+ import type { IdentityData } from "../features/security/IdentityContext/Identity.js";
2
+ import { JwkCache, JwtIdentityProvider, OidcIdentityProvider } from "./abstractions.js";
3
+ declare class OidcJwtIdentityProviderImpl implements JwtIdentityProvider.Interface {
4
+ private oidcIdentityProviders;
5
+ private jwksCache;
6
+ constructor(oidcIdentityProviders: OidcIdentityProvider.Interface[], jwksCache: JwkCache.Interface);
7
+ isApplicable(token: JwtIdentityProvider.JwtPayload): boolean;
8
+ getIdentity(token: string, jwt: JwtIdentityProvider.Jwt): Promise<IdentityData | null>;
9
+ private getApplicableProvider;
10
+ private verifyToken;
11
+ }
12
+ export declare const OidcJwtIdentityProvider: typeof OidcJwtIdentityProviderImpl & {
13
+ __abstraction: import("@webiny/di").Abstraction<import("./abstractions.js").IJwtIdentityProvider>;
14
+ };
15
+ export {};
@@ -0,0 +1,90 @@
1
+ import { verifyJwtUsingJwk } from "../features/security/utils/verifyJwtUsingJwk.js";
2
+ import { JwkCache, JwtIdentityProvider, OidcIdentityProvider } from "./abstractions.js";
3
+ class OidcJwtIdentityProviderImpl {
4
+ constructor(oidcIdentityProviders, jwksCache) {
5
+ this.oidcIdentityProviders = oidcIdentityProviders;
6
+ this.jwksCache = jwksCache;
7
+ }
8
+ isApplicable(token) {
9
+ return this.oidcIdentityProviders.some(provider => provider.isApplicable(token));
10
+ }
11
+ async getIdentity(token, jwt) {
12
+ const {
13
+ header,
14
+ payload
15
+ } = jwt;
16
+ const provider = this.getApplicableProvider(payload);
17
+ if (!provider) {
18
+ return null;
19
+ }
20
+ const verifiedPayload = await this.verifyToken(provider, token, header);
21
+ if (!verifiedPayload) {
22
+ return null;
23
+ }
24
+
25
+ // Call config.getIdentity to get IdentityData
26
+ const providerIdentity = await provider.getIdentity(verifiedPayload);
27
+ const identity = {
28
+ ...providerIdentity,
29
+ type: providerIdentity.type ?? "admin"
30
+ };
31
+
32
+ // Handle default values
33
+ const context = identity.context ?? {
34
+ canAccessTenant: true,
35
+ defaultTenantId: "root"
36
+ };
37
+ if (context.canAccessTenant === undefined) {
38
+ context.canAccessTenant = true;
39
+ }
40
+ if (context.defaultTenantId === undefined) {
41
+ context.defaultTenantId = "root";
42
+ }
43
+ identity.context = context;
44
+ return identity;
45
+ }
46
+ getApplicableProvider(payload) {
47
+ return this.oidcIdentityProviders.find(provider => provider.isApplicable(payload));
48
+ }
49
+ async verifyToken(provider, token, header) {
50
+ // If the implementation specifies a custom verification function, use it.
51
+ let verifiedPayload;
52
+ if (typeof provider.verifyToken === "function") {
53
+ // Use custom verification
54
+ const result = await provider.verifyToken(token);
55
+ if (result) {
56
+ return result;
57
+ }
58
+ return null;
59
+ }
60
+
61
+ // Otherwise, continue with OIDC best practices, using JWKs.
62
+
63
+ // Fetch JWKs from cache
64
+ const jwks = await this.jwksCache.getKeys(provider.issuer);
65
+
66
+ // Find matching JWK using header.kid
67
+ const jwk = jwks.find(key => key.kid === header.kid);
68
+ if (!jwk) {
69
+ return null;
70
+ }
71
+ if (!verifiedPayload) {
72
+ // Default JWK verification
73
+ verifiedPayload = await verifyJwtUsingJwk(token, jwk);
74
+ }
75
+
76
+ // Call verifyTokenClaims if provided
77
+ if (provider.verifyTokenClaims) {
78
+ await provider.verifyTokenClaims(verifiedPayload);
79
+ }
80
+ return verifiedPayload;
81
+ }
82
+ }
83
+ export const OidcJwtIdentityProvider = JwtIdentityProvider.createImplementation({
84
+ implementation: OidcJwtIdentityProviderImpl,
85
+ dependencies: [[OidcIdentityProvider, {
86
+ multiple: true
87
+ }], JwkCache]
88
+ });
89
+
90
+ //# sourceMappingURL=OidcJwtIdentityProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["verifyJwtUsingJwk","JwkCache","JwtIdentityProvider","OidcIdentityProvider","OidcJwtIdentityProviderImpl","constructor","oidcIdentityProviders","jwksCache","isApplicable","token","some","provider","getIdentity","jwt","header","payload","getApplicableProvider","verifiedPayload","verifyToken","providerIdentity","identity","type","context","canAccessTenant","defaultTenantId","undefined","find","result","jwks","getKeys","issuer","jwk","key","kid","verifyTokenClaims","OidcJwtIdentityProvider","createImplementation","implementation","dependencies","multiple"],"sources":["OidcJwtIdentityProvider.ts"],"sourcesContent":["import { verifyJwtUsingJwk } from \"~/features/security/utils/verifyJwtUsingJwk.js\";\nimport type { IdentityData } from \"~/features/security/IdentityContext/Identity.js\";\nimport { JwkCache, JwtIdentityProvider, OidcIdentityProvider } from \"./abstractions.js\";\n\nclass OidcJwtIdentityProviderImpl implements JwtIdentityProvider.Interface {\n constructor(\n private oidcIdentityProviders: OidcIdentityProvider.Interface[],\n private jwksCache: JwkCache.Interface\n ) {}\n\n isApplicable(token: JwtIdentityProvider.JwtPayload): boolean {\n return this.oidcIdentityProviders.some(provider => provider.isApplicable(token));\n }\n\n async getIdentity(token: string, jwt: JwtIdentityProvider.Jwt): Promise<IdentityData | null> {\n const { header, payload } = jwt;\n\n const provider = this.getApplicableProvider(payload);\n\n if (!provider) {\n return null;\n }\n\n const verifiedPayload = await this.verifyToken(provider, token, header);\n\n if (!verifiedPayload) {\n return null;\n }\n\n // Call config.getIdentity to get IdentityData\n const providerIdentity = await provider.getIdentity(verifiedPayload);\n\n const identity: IdentityData = {\n ...providerIdentity,\n type: providerIdentity.type ?? \"admin\"\n };\n\n // Handle default values\n const context = identity.context ?? { canAccessTenant: true, defaultTenantId: \"root\" };\n if (context.canAccessTenant === undefined) {\n context.canAccessTenant = true;\n }\n if (context.defaultTenantId === undefined) {\n context.defaultTenantId = \"root\";\n }\n\n identity.context = context;\n\n return identity;\n }\n\n private getApplicableProvider(\n payload: JwtIdentityProvider.JwtPayload\n ): OidcIdentityProvider.Interface | undefined {\n return this.oidcIdentityProviders.find(provider => provider.isApplicable(payload));\n }\n\n private async verifyToken(\n provider: OidcIdentityProvider.Interface,\n token: string,\n header: JwtIdentityProvider.JwtHeader\n ) {\n // If the implementation specifies a custom verification function, use it.\n let verifiedPayload: JwtIdentityProvider.JwtPayload | undefined;\n if (typeof provider.verifyToken === \"function\") {\n // Use custom verification\n const result = await provider.verifyToken(token);\n if (result) {\n return result;\n }\n return null;\n }\n\n // Otherwise, continue with OIDC best practices, using JWKs.\n\n // Fetch JWKs from cache\n const jwks = await this.jwksCache.getKeys(provider.issuer);\n\n // Find matching JWK using header.kid\n const jwk = jwks.find(key => key.kid === header.kid);\n if (!jwk) {\n return null;\n }\n\n if (!verifiedPayload) {\n // Default JWK verification\n verifiedPayload = await verifyJwtUsingJwk(token, jwk);\n }\n\n // Call verifyTokenClaims if provided\n if (provider.verifyTokenClaims) {\n await provider.verifyTokenClaims(verifiedPayload);\n }\n\n return verifiedPayload;\n }\n}\n\nexport const OidcJwtIdentityProvider = JwtIdentityProvider.createImplementation({\n implementation: OidcJwtIdentityProviderImpl,\n dependencies: [[OidcIdentityProvider, { multiple: true }], JwkCache]\n});\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,62 @@
1
+ import type { JwtPayload as IJwtPayload, JwtHeader as IJwtHeader } from "jsonwebtoken";
2
+ import type { IdentityData as IIdentityData } from "../features/security/IdentityContext/Identity.js";
3
+ import type { Jwk as IJwk } from "../features/security/utils/verifyJwtUsingJwk.js";
4
+ export type IJwt = {
5
+ header: IJwtHeader;
6
+ payload: IJwtPayload;
7
+ };
8
+ export type OptionalExternal<T> = Omit<T, "external"> & {
9
+ external?: boolean;
10
+ };
11
+ export type IProviderIdentityData = Omit<IIdentityData, "type" | "profile"> & {
12
+ /**
13
+ * Defaults to `admin` it omitted.
14
+ */
15
+ type?: string;
16
+ profile?: OptionalExternal<NonNullable<IIdentityData["profile"]>>;
17
+ };
18
+ export interface IIdentityProvider {
19
+ isApplicable(token: string): boolean;
20
+ getIdentity(token: string): Promise<IProviderIdentityData | null>;
21
+ }
22
+ export declare const IdentityProvider: import("@webiny/di").Abstraction<IIdentityProvider>;
23
+ export declare namespace IdentityProvider {
24
+ type Interface = IIdentityProvider;
25
+ type IdentityData = IProviderIdentityData;
26
+ type JwtPayload = IJwtPayload;
27
+ }
28
+ export interface IJwtIdentityProvider {
29
+ isApplicable(token: IJwtPayload): boolean;
30
+ getIdentity(token: string, jwt: IJwt): Promise<IProviderIdentityData | null>;
31
+ }
32
+ export declare const JwtIdentityProvider: import("@webiny/di").Abstraction<IJwtIdentityProvider>;
33
+ export declare namespace JwtIdentityProvider {
34
+ type Interface = IJwtIdentityProvider;
35
+ type Jwt = IJwt;
36
+ type JwtPayload = IJwtPayload;
37
+ type JwtHeader = IJwtHeader;
38
+ type IdentityData = IProviderIdentityData;
39
+ }
40
+ export interface IOidcIdentityProvider {
41
+ issuer: string;
42
+ clientId: string;
43
+ isApplicable(token: IJwtPayload): boolean;
44
+ getIdentity(jwt: IJwtPayload): Promise<IProviderIdentityData>;
45
+ verifyToken?(token: string): Promise<IJwtPayload | undefined>;
46
+ verifyTokenClaims?(token: IJwtPayload): Promise<void>;
47
+ }
48
+ export declare const OidcIdentityProvider: import("@webiny/di").Abstraction<IOidcIdentityProvider>;
49
+ export declare namespace OidcIdentityProvider {
50
+ type Interface = IOidcIdentityProvider;
51
+ type JwtPayload = IJwtPayload;
52
+ type IdentityData = IProviderIdentityData;
53
+ }
54
+ interface IJwkCache {
55
+ getKeys(issuer: string): Promise<IJwk[]>;
56
+ }
57
+ export declare const JwkCache: import("@webiny/di").Abstraction<IJwkCache>;
58
+ export declare namespace JwkCache {
59
+ type Interface = IJwkCache;
60
+ type Jwk = IJwk;
61
+ }
62
+ export {};
@@ -0,0 +1,13 @@
1
+ import { createAbstraction } from "@webiny/feature/api";
2
+
3
+ // Generic Idp Provider
4
+
5
+ export const IdentityProvider = createAbstraction("IdentityProvider");
6
+ export const JwtIdentityProvider = createAbstraction("JwtIdentityProvider");
7
+
8
+ // OIDC Provider
9
+
10
+ export const OidcIdentityProvider = createAbstraction("OidcIdentityProvider");
11
+ export const JwkCache = createAbstraction("JwkCache");
12
+
13
+ //# sourceMappingURL=abstractions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["createAbstraction","IdentityProvider","JwtIdentityProvider","OidcIdentityProvider","JwkCache"],"sources":["abstractions.ts"],"sourcesContent":["import type { JwtPayload as IJwtPayload, JwtHeader as IJwtHeader } from \"jsonwebtoken\";\nimport { createAbstraction } from \"@webiny/feature/api\";\nimport type { IdentityData as IIdentityData } from \"~/features/security/IdentityContext/Identity.js\";\nimport type { Jwk as IJwk } from \"~/features/security/utils/verifyJwtUsingJwk.js\";\n\nexport type IJwt = {\n header: IJwtHeader;\n payload: IJwtPayload;\n};\n\nexport type OptionalExternal<T> = Omit<T, \"external\"> & { external?: boolean };\n\nexport type IProviderIdentityData = Omit<IIdentityData, \"type\" | \"profile\"> & {\n /**\n * Defaults to `admin` it omitted.\n */\n type?: string;\n profile?: OptionalExternal<NonNullable<IIdentityData[\"profile\"]>>;\n};\n\n// Generic Idp Provider\nexport interface IIdentityProvider {\n isApplicable(token: string): boolean;\n getIdentity(token: string): Promise<IProviderIdentityData | null>;\n}\n\nexport const IdentityProvider = createAbstraction<IIdentityProvider>(\"IdentityProvider\");\n\nexport namespace IdentityProvider {\n export type Interface = IIdentityProvider;\n export type IdentityData = IProviderIdentityData;\n export type JwtPayload = IJwtPayload;\n}\n\nexport interface IJwtIdentityProvider {\n isApplicable(token: IJwtPayload): boolean;\n getIdentity(token: string, jwt: IJwt): Promise<IProviderIdentityData | null>;\n}\n\nexport const JwtIdentityProvider = createAbstraction<IJwtIdentityProvider>(\"JwtIdentityProvider\");\n\nexport namespace JwtIdentityProvider {\n export type Interface = IJwtIdentityProvider;\n export type Jwt = IJwt;\n export type JwtPayload = IJwtPayload;\n export type JwtHeader = IJwtHeader;\n export type IdentityData = IProviderIdentityData;\n}\n\n// OIDC Provider\nexport interface IOidcIdentityProvider {\n issuer: string;\n clientId: string;\n isApplicable(token: IJwtPayload): boolean;\n getIdentity(jwt: IJwtPayload): Promise<IProviderIdentityData>;\n verifyToken?(token: string): Promise<IJwtPayload | undefined>;\n verifyTokenClaims?(token: IJwtPayload): Promise<void>;\n}\n\nexport const OidcIdentityProvider =\n createAbstraction<IOidcIdentityProvider>(\"OidcIdentityProvider\");\n\nexport namespace OidcIdentityProvider {\n export type Interface = IOidcIdentityProvider;\n export type JwtPayload = IJwtPayload;\n export type IdentityData = IProviderIdentityData;\n}\n\ninterface IJwkCache {\n getKeys(issuer: string): Promise<IJwk[]>;\n}\n\nexport const JwkCache = createAbstraction<IJwkCache>(\"JwkCache\");\nexport namespace JwkCache {\n export type Interface = IJwkCache;\n export type Jwk = IJwk;\n}\n"],"mappings":"AACA,SAASA,iBAAiB,QAAQ,qBAAqB;;AAmBvD;;AAMA,OAAO,MAAMC,gBAAgB,GAAGD,iBAAiB,CAAoB,kBAAkB,CAAC;AAaxF,OAAO,MAAME,mBAAmB,GAAGF,iBAAiB,CAAuB,qBAAqB,CAAC;;AAUjG;;AAUA,OAAO,MAAMG,oBAAoB,GAC7BH,iBAAiB,CAAwB,sBAAsB,CAAC;AAYpE,OAAO,MAAMI,QAAQ,GAAGJ,iBAAiB,CAAY,UAAU,CAAC","ignoreList":[]}