@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.
- package/ApiCoreFeature.d.ts +2 -0
- package/ApiCoreFeature.js +27 -0
- package/ApiCoreFeature.js.map +1 -0
- package/LICENSE +21 -0
- package/README.md +11 -0
- package/createApiCore.d.ts +7 -0
- package/createApiCore.js +17 -0
- package/createApiCore.js.map +1 -0
- package/domain/identity/SystemIdentityValue.d.ts +7 -0
- package/domain/identity/SystemIdentityValue.js +11 -0
- package/domain/identity/SystemIdentityValue.js.map +1 -0
- package/domain/security/ApiToken.d.ts +7 -0
- package/domain/security/ApiToken.js +14 -0
- package/domain/security/ApiToken.js.map +1 -0
- package/domain/tenancy/RootTenantValue.d.ts +4 -0
- package/domain/tenancy/RootTenantValue.js +11 -0
- package/domain/tenancy/RootTenantValue.js.map +1 -0
- package/domain/tenancy/errors.d.ts +0 -0
- package/domain/tenancy/errors.js +3 -0
- package/domain/tenancy/errors.js.map +1 -0
- package/exports/api/buildParams.d.ts +1 -0
- package/exports/api/buildParams.js +3 -0
- package/exports/api/buildParams.js.map +1 -0
- package/exports/api/eventPublisher.d.ts +1 -0
- package/exports/api/eventPublisher.js +3 -0
- package/exports/api/eventPublisher.js.map +1 -0
- package/exports/api/graphql.d.ts +1 -0
- package/exports/api/graphql.js +3 -0
- package/exports/api/graphql.js.map +1 -0
- package/exports/api/keyValueStore.d.ts +1 -0
- package/exports/api/keyValueStore.js +3 -0
- package/exports/api/keyValueStore.js.map +1 -0
- package/exports/api/logger.d.ts +1 -0
- package/exports/api/logger.js +3 -0
- package/exports/api/logger.js.map +1 -0
- package/exports/api/security/apiKey.d.ts +7 -0
- package/exports/api/security/apiKey.js +9 -0
- package/exports/api/security/apiKey.js.map +1 -0
- package/exports/api/security/authentication.d.ts +1 -0
- package/exports/api/security/authentication.js +3 -0
- package/exports/api/security/authentication.js.map +1 -0
- package/exports/api/security/role.d.ts +5 -0
- package/exports/api/security/role.js +7 -0
- package/exports/api/security/role.js.map +1 -0
- package/exports/api/security/user.d.ts +6 -0
- package/exports/api/security/user.js +8 -0
- package/exports/api/security/user.js.map +1 -0
- package/exports/api/security.d.ts +6 -0
- package/exports/api/security.js +8 -0
- package/exports/api/security.js.map +1 -0
- package/exports/api/system.d.ts +1 -0
- package/exports/api/system.js +3 -0
- package/exports/api/system.js.map +1 -0
- package/exports/api/tasks.d.ts +2 -0
- package/exports/api/tasks.js +4 -0
- package/exports/api/tasks.js.map +1 -0
- package/exports/api/tenancy.d.ts +6 -0
- package/exports/api/tenancy.js +8 -0
- package/exports/api/tenancy.js.map +1 -0
- package/extensions/BuildParam.d.ts +11 -0
- package/extensions/BuildParam.js +119 -0
- package/extensions/BuildParam.js.map +1 -0
- package/extensions/GenericExtension.d.ts +10 -0
- package/extensions/GenericExtension.js +7 -0
- package/extensions/GenericExtension.js.map +1 -0
- package/extensions/eventHandlers/AfterAuthentication.d.ts +10 -0
- package/extensions/eventHandlers/AfterAuthentication.js +9 -0
- package/extensions/eventHandlers/AfterAuthentication.js.map +1 -0
- package/extensions/eventHandlers/ApiKeyAfterCreate.d.ts +10 -0
- package/extensions/eventHandlers/ApiKeyAfterCreate.js +9 -0
- package/extensions/eventHandlers/ApiKeyAfterCreate.js.map +1 -0
- package/extensions/eventHandlers/ApiKeyAfterDelete.d.ts +10 -0
- package/extensions/eventHandlers/ApiKeyAfterDelete.js +9 -0
- package/extensions/eventHandlers/ApiKeyAfterDelete.js.map +1 -0
- package/extensions/eventHandlers/ApiKeyAfterUpdate.d.ts +10 -0
- package/extensions/eventHandlers/ApiKeyAfterUpdate.js +9 -0
- package/extensions/eventHandlers/ApiKeyAfterUpdate.js.map +1 -0
- package/extensions/eventHandlers/ApiKeyBeforeCreate.d.ts +10 -0
- package/extensions/eventHandlers/ApiKeyBeforeCreate.js +9 -0
- package/extensions/eventHandlers/ApiKeyBeforeCreate.js.map +1 -0
- package/extensions/eventHandlers/ApiKeyBeforeDelete.d.ts +10 -0
- package/extensions/eventHandlers/ApiKeyBeforeDelete.js +9 -0
- package/extensions/eventHandlers/ApiKeyBeforeDelete.js.map +1 -0
- package/extensions/eventHandlers/ApiKeyBeforeUpdate.d.ts +10 -0
- package/extensions/eventHandlers/ApiKeyBeforeUpdate.js +9 -0
- package/extensions/eventHandlers/ApiKeyBeforeUpdate.js.map +1 -0
- package/extensions/eventHandlers/BeforeAuthentication.d.ts +10 -0
- package/extensions/eventHandlers/BeforeAuthentication.js +9 -0
- package/extensions/eventHandlers/BeforeAuthentication.js.map +1 -0
- package/extensions/eventHandlers/RoleAfterCreate.d.ts +10 -0
- package/extensions/eventHandlers/RoleAfterCreate.js +9 -0
- package/extensions/eventHandlers/RoleAfterCreate.js.map +1 -0
- package/extensions/eventHandlers/RoleAfterDelete.d.ts +10 -0
- package/extensions/eventHandlers/RoleAfterDelete.js +9 -0
- package/extensions/eventHandlers/RoleAfterDelete.js.map +1 -0
- package/extensions/eventHandlers/RoleAfterUpdate.d.ts +10 -0
- package/extensions/eventHandlers/RoleAfterUpdate.js +9 -0
- package/extensions/eventHandlers/RoleAfterUpdate.js.map +1 -0
- package/extensions/eventHandlers/RoleBeforeCreate.d.ts +10 -0
- package/extensions/eventHandlers/RoleBeforeCreate.js +9 -0
- package/extensions/eventHandlers/RoleBeforeCreate.js.map +1 -0
- package/extensions/eventHandlers/RoleBeforeDelete.d.ts +10 -0
- package/extensions/eventHandlers/RoleBeforeDelete.js +9 -0
- package/extensions/eventHandlers/RoleBeforeDelete.js.map +1 -0
- package/extensions/eventHandlers/RoleBeforeUpdate.d.ts +10 -0
- package/extensions/eventHandlers/RoleBeforeUpdate.js +9 -0
- package/extensions/eventHandlers/RoleBeforeUpdate.js.map +1 -0
- package/extensions/eventHandlers/SystemInstalled.d.ts +10 -0
- package/extensions/eventHandlers/SystemInstalled.js +9 -0
- package/extensions/eventHandlers/SystemInstalled.js.map +1 -0
- package/extensions/eventHandlers/TeamAfterCreate.d.ts +10 -0
- package/extensions/eventHandlers/TeamAfterCreate.js +9 -0
- package/extensions/eventHandlers/TeamAfterCreate.js.map +1 -0
- package/extensions/eventHandlers/TeamAfterDelete.d.ts +10 -0
- package/extensions/eventHandlers/TeamAfterDelete.js +9 -0
- package/extensions/eventHandlers/TeamAfterDelete.js.map +1 -0
- package/extensions/eventHandlers/TeamAfterUpdate.d.ts +10 -0
- package/extensions/eventHandlers/TeamAfterUpdate.js +9 -0
- package/extensions/eventHandlers/TeamAfterUpdate.js.map +1 -0
- package/extensions/eventHandlers/TeamBeforeCreate.d.ts +10 -0
- package/extensions/eventHandlers/TeamBeforeCreate.js +9 -0
- package/extensions/eventHandlers/TeamBeforeCreate.js.map +1 -0
- package/extensions/eventHandlers/TeamBeforeDelete.d.ts +10 -0
- package/extensions/eventHandlers/TeamBeforeDelete.js +9 -0
- package/extensions/eventHandlers/TeamBeforeDelete.js.map +1 -0
- package/extensions/eventHandlers/TeamBeforeUpdate.d.ts +10 -0
- package/extensions/eventHandlers/TeamBeforeUpdate.js +9 -0
- package/extensions/eventHandlers/TeamBeforeUpdate.js.map +1 -0
- package/extensions/eventHandlers/TenantAfterCreate.d.ts +10 -0
- package/extensions/eventHandlers/TenantAfterCreate.js +9 -0
- package/extensions/eventHandlers/TenantAfterCreate.js.map +1 -0
- package/extensions/eventHandlers/TenantAfterDelete.d.ts +10 -0
- package/extensions/eventHandlers/TenantAfterDelete.js +9 -0
- package/extensions/eventHandlers/TenantAfterDelete.js.map +1 -0
- package/extensions/eventHandlers/TenantAfterUpdate.d.ts +10 -0
- package/extensions/eventHandlers/TenantAfterUpdate.js +9 -0
- package/extensions/eventHandlers/TenantAfterUpdate.js.map +1 -0
- package/extensions/eventHandlers/TenantBeforeCreate.d.ts +10 -0
- package/extensions/eventHandlers/TenantBeforeCreate.js +9 -0
- package/extensions/eventHandlers/TenantBeforeCreate.js.map +1 -0
- package/extensions/eventHandlers/TenantBeforeDelete.d.ts +10 -0
- package/extensions/eventHandlers/TenantBeforeDelete.js +9 -0
- package/extensions/eventHandlers/TenantBeforeDelete.js.map +1 -0
- package/extensions/eventHandlers/TenantBeforeUpdate.d.ts +10 -0
- package/extensions/eventHandlers/TenantBeforeUpdate.js +9 -0
- package/extensions/eventHandlers/TenantBeforeUpdate.js.map +1 -0
- package/extensions/eventHandlers/TenantInstalled.d.ts +10 -0
- package/extensions/eventHandlers/TenantInstalled.js +9 -0
- package/extensions/eventHandlers/TenantInstalled.js.map +1 -0
- package/extensions/eventHandlers/UserAfterCreate.d.ts +10 -0
- package/extensions/eventHandlers/UserAfterCreate.js +9 -0
- package/extensions/eventHandlers/UserAfterCreate.js.map +1 -0
- package/extensions/eventHandlers/UserAfterDelete.d.ts +10 -0
- package/extensions/eventHandlers/UserAfterDelete.js +9 -0
- package/extensions/eventHandlers/UserAfterDelete.js.map +1 -0
- package/extensions/eventHandlers/UserAfterUpdate.d.ts +10 -0
- package/extensions/eventHandlers/UserAfterUpdate.js +9 -0
- package/extensions/eventHandlers/UserAfterUpdate.js.map +1 -0
- package/extensions/eventHandlers/UserBeforeCreate.d.ts +10 -0
- package/extensions/eventHandlers/UserBeforeCreate.js +9 -0
- package/extensions/eventHandlers/UserBeforeCreate.js.map +1 -0
- package/extensions/eventHandlers/UserBeforeDelete.d.ts +10 -0
- package/extensions/eventHandlers/UserBeforeDelete.js +9 -0
- package/extensions/eventHandlers/UserBeforeDelete.js.map +1 -0
- package/extensions/eventHandlers/UserBeforeUpdate.d.ts +10 -0
- package/extensions/eventHandlers/UserBeforeUpdate.js +9 -0
- package/extensions/eventHandlers/UserBeforeUpdate.js.map +1 -0
- package/extensions/eventHandlers/index.d.ts +34 -0
- package/extensions/eventHandlers/index.js +49 -0
- package/extensions/eventHandlers/index.js.map +1 -0
- package/extensions/index.d.ts +58 -0
- package/extensions/index.js +49 -0
- package/extensions/index.js.map +1 -0
- package/features/buildParams/BuildParams.d.ts +9 -0
- package/features/buildParams/BuildParams.js +18 -0
- package/features/buildParams/BuildParams.js.map +1 -0
- package/features/buildParams/abstractions.d.ts +15 -0
- package/features/buildParams/abstractions.js +5 -0
- package/features/buildParams/abstractions.js.map +1 -0
- package/features/buildParams/feature.d.ts +1 -0
- package/features/buildParams/feature.js +10 -0
- package/features/buildParams/feature.js.map +1 -0
- package/features/buildParams/index.d.ts +1 -0
- package/features/buildParams/index.js +3 -0
- package/features/buildParams/index.js.map +1 -0
- package/features/eventPublisher/EventPublisher.d.ts +7 -0
- package/features/eventPublisher/EventPublisher.js +19 -0
- package/features/eventPublisher/EventPublisher.js.map +1 -0
- package/features/eventPublisher/__tests__/EventPublisher.test.d.ts +92 -0
- package/features/eventPublisher/__tests__/EventPublisher.test.js +463 -0
- package/features/eventPublisher/__tests__/EventPublisher.test.js.map +1 -0
- package/features/eventPublisher/abstractions.d.ts +18 -0
- package/features/eventPublisher/abstractions.js +14 -0
- package/features/eventPublisher/abstractions.js.map +1 -0
- package/features/eventPublisher/feature.d.ts +1 -0
- package/features/eventPublisher/feature.js +11 -0
- package/features/eventPublisher/feature.js.map +1 -0
- package/features/eventPublisher/index.d.ts +1 -0
- package/features/eventPublisher/index.js +3 -0
- package/features/eventPublisher/index.js.map +1 -0
- package/features/keyValueStore/GlobalKeyValueStore.d.ts +12 -0
- package/features/keyValueStore/GlobalKeyValueStore.js +30 -0
- package/features/keyValueStore/GlobalKeyValueStore.js.map +1 -0
- package/features/keyValueStore/KeyValueStore.d.ts +16 -0
- package/features/keyValueStore/KeyValueStore.js +33 -0
- package/features/keyValueStore/KeyValueStore.js.map +1 -0
- package/features/keyValueStore/KeyValueStoreRepository.d.ts +17 -0
- package/features/keyValueStore/KeyValueStoreRepository.js +50 -0
- package/features/keyValueStore/KeyValueStoreRepository.js.map +1 -0
- package/features/keyValueStore/abstractions.d.ts +58 -0
- package/features/keyValueStore/abstractions.js +19 -0
- package/features/keyValueStore/abstractions.js.map +1 -0
- package/features/keyValueStore/errors.d.ts +11 -0
- package/features/keyValueStore/errors.js +22 -0
- package/features/keyValueStore/errors.js.map +1 -0
- package/features/keyValueStore/feature.d.ts +1 -0
- package/features/keyValueStore/feature.js +17 -0
- package/features/keyValueStore/feature.js.map +1 -0
- package/features/keyValueStore/index.d.ts +2 -0
- package/features/keyValueStore/index.js +4 -0
- package/features/keyValueStore/index.js.map +1 -0
- package/features/logger/LoggerService.d.ts +14 -0
- package/features/logger/LoggerService.js +52 -0
- package/features/logger/LoggerService.js.map +1 -0
- package/features/logger/abstractions.d.ts +13 -0
- package/features/logger/abstractions.js +4 -0
- package/features/logger/abstractions.js.map +1 -0
- package/features/logger/feature.d.ts +1 -0
- package/features/logger/feature.js +10 -0
- package/features/logger/feature.js.map +1 -0
- package/features/logger/index.d.ts +1 -0
- package/features/logger/index.js +3 -0
- package/features/logger/index.js.map +1 -0
- package/features/security/IdentityContext/AnonymousIdentity.d.ts +9 -0
- package/features/security/IdentityContext/AnonymousIdentity.js +20 -0
- package/features/security/IdentityContext/AnonymousIdentity.js.map +1 -0
- package/features/security/IdentityContext/AuthenticatedIdentity.d.ts +7 -0
- package/features/security/IdentityContext/AuthenticatedIdentity.js +12 -0
- package/features/security/IdentityContext/AuthenticatedIdentity.js.map +1 -0
- package/features/security/IdentityContext/Identity.d.ts +79 -0
- package/features/security/IdentityContext/Identity.js +76 -0
- package/features/security/IdentityContext/Identity.js.map +1 -0
- package/features/security/IdentityContext/IdentityContext.d.ts +23 -0
- package/features/security/IdentityContext/IdentityContext.js +125 -0
- package/features/security/IdentityContext/IdentityContext.js.map +1 -0
- package/features/security/IdentityContext/abstractions.d.ts +17 -0
- package/features/security/IdentityContext/abstractions.js +4 -0
- package/features/security/IdentityContext/abstractions.js.map +1 -0
- package/features/security/IdentityContext/feature.d.ts +1 -0
- package/features/security/IdentityContext/feature.js +10 -0
- package/features/security/IdentityContext/feature.js.map +1 -0
- package/features/security/IdentityContext/index.d.ts +6 -0
- package/features/security/IdentityContext/index.js +8 -0
- package/features/security/IdentityContext/index.js.map +1 -0
- package/features/security/SecurityFeature.d.ts +9 -0
- package/features/security/SecurityFeature.js +33 -0
- package/features/security/SecurityFeature.js.map +1 -0
- package/features/security/apiKeys/CreateApiKey/CreateApiKeyUseCase.d.ts +17 -0
- package/features/security/apiKeys/CreateApiKey/CreateApiKeyUseCase.js +63 -0
- package/features/security/apiKeys/CreateApiKey/CreateApiKeyUseCase.js.map +1 -0
- package/features/security/apiKeys/CreateApiKey/abstractions.d.ts +26 -0
- package/features/security/apiKeys/CreateApiKey/abstractions.js +4 -0
- package/features/security/apiKeys/CreateApiKey/abstractions.js.map +1 -0
- package/features/security/apiKeys/CreateApiKey/events.d.ts +21 -0
- package/features/security/apiKeys/CreateApiKey/events.js +18 -0
- package/features/security/apiKeys/CreateApiKey/events.js.map +1 -0
- package/features/security/apiKeys/CreateApiKey/feature.d.ts +1 -0
- package/features/security/apiKeys/CreateApiKey/feature.js +10 -0
- package/features/security/apiKeys/CreateApiKey/feature.js.map +1 -0
- package/features/security/apiKeys/CreateApiKey/index.d.ts +2 -0
- package/features/security/apiKeys/CreateApiKey/index.js +4 -0
- package/features/security/apiKeys/CreateApiKey/index.js.map +1 -0
- package/features/security/apiKeys/DeleteApiKey/DeleteApiKeyUseCase.d.ts +16 -0
- package/features/security/apiKeys/DeleteApiKey/DeleteApiKeyUseCase.js +42 -0
- package/features/security/apiKeys/DeleteApiKey/DeleteApiKeyUseCase.js.map +1 -0
- package/features/security/apiKeys/DeleteApiKey/abstractions.d.ts +23 -0
- package/features/security/apiKeys/DeleteApiKey/abstractions.js +4 -0
- package/features/security/apiKeys/DeleteApiKey/abstractions.js.map +1 -0
- package/features/security/apiKeys/DeleteApiKey/events.d.ts +21 -0
- package/features/security/apiKeys/DeleteApiKey/events.js +18 -0
- package/features/security/apiKeys/DeleteApiKey/events.js.map +1 -0
- package/features/security/apiKeys/DeleteApiKey/feature.d.ts +1 -0
- package/features/security/apiKeys/DeleteApiKey/feature.js +10 -0
- package/features/security/apiKeys/DeleteApiKey/feature.js.map +1 -0
- package/features/security/apiKeys/DeleteApiKey/index.d.ts +2 -0
- package/features/security/apiKeys/DeleteApiKey/index.js +4 -0
- package/features/security/apiKeys/DeleteApiKey/index.js.map +1 -0
- package/features/security/apiKeys/GetApiKey/GetApiKeyUseCase.d.ts +15 -0
- package/features/security/apiKeys/GetApiKey/GetApiKeyUseCase.js +24 -0
- package/features/security/apiKeys/GetApiKey/GetApiKeyUseCase.js.map +1 -0
- package/features/security/apiKeys/GetApiKey/abstractions.d.ts +17 -0
- package/features/security/apiKeys/GetApiKey/abstractions.js +4 -0
- package/features/security/apiKeys/GetApiKey/abstractions.js.map +1 -0
- package/features/security/apiKeys/GetApiKey/feature.d.ts +1 -0
- package/features/security/apiKeys/GetApiKey/feature.js +10 -0
- package/features/security/apiKeys/GetApiKey/feature.js.map +1 -0
- package/features/security/apiKeys/GetApiKey/index.d.ts +1 -0
- package/features/security/apiKeys/GetApiKey/index.js +3 -0
- package/features/security/apiKeys/GetApiKey/index.js.map +1 -0
- package/features/security/apiKeys/GetApiKeyBySlug/GetApiKeyBySlugUseCase.d.ts +13 -0
- package/features/security/apiKeys/GetApiKeyBySlug/GetApiKeyBySlugUseCase.js +16 -0
- package/features/security/apiKeys/GetApiKeyBySlug/GetApiKeyBySlugUseCase.js.map +1 -0
- package/features/security/apiKeys/GetApiKeyBySlug/abstractions.d.ts +15 -0
- package/features/security/apiKeys/GetApiKeyBySlug/abstractions.js +4 -0
- package/features/security/apiKeys/GetApiKeyBySlug/abstractions.js.map +1 -0
- package/features/security/apiKeys/GetApiKeyBySlug/feature.d.ts +1 -0
- package/features/security/apiKeys/GetApiKeyBySlug/feature.js +10 -0
- package/features/security/apiKeys/GetApiKeyBySlug/feature.js.map +1 -0
- package/features/security/apiKeys/GetApiKeyBySlug/index.d.ts +1 -0
- package/features/security/apiKeys/GetApiKeyBySlug/index.js +3 -0
- package/features/security/apiKeys/GetApiKeyBySlug/index.js.map +1 -0
- package/features/security/apiKeys/GetApiKeyByToken/GetApiKeyByTokenUseCase.d.ts +13 -0
- package/features/security/apiKeys/GetApiKeyByToken/GetApiKeyByTokenUseCase.js +16 -0
- package/features/security/apiKeys/GetApiKeyByToken/GetApiKeyByTokenUseCase.js.map +1 -0
- package/features/security/apiKeys/GetApiKeyByToken/abstractions.d.ts +15 -0
- package/features/security/apiKeys/GetApiKeyByToken/abstractions.js +4 -0
- package/features/security/apiKeys/GetApiKeyByToken/abstractions.js.map +1 -0
- package/features/security/apiKeys/GetApiKeyByToken/feature.d.ts +1 -0
- package/features/security/apiKeys/GetApiKeyByToken/feature.js +10 -0
- package/features/security/apiKeys/GetApiKeyByToken/feature.js.map +1 -0
- package/features/security/apiKeys/GetApiKeyByToken/index.d.ts +1 -0
- package/features/security/apiKeys/GetApiKeyByToken/index.js +3 -0
- package/features/security/apiKeys/GetApiKeyByToken/index.js.map +1 -0
- package/features/security/apiKeys/ListApiKeys/ListApiKeysUseCase.d.ts +15 -0
- package/features/security/apiKeys/ListApiKeys/ListApiKeysUseCase.js +29 -0
- package/features/security/apiKeys/ListApiKeys/ListApiKeysUseCase.js.map +1 -0
- package/features/security/apiKeys/ListApiKeys/abstractions.d.ts +19 -0
- package/features/security/apiKeys/ListApiKeys/abstractions.js +4 -0
- package/features/security/apiKeys/ListApiKeys/abstractions.js.map +1 -0
- package/features/security/apiKeys/ListApiKeys/feature.d.ts +1 -0
- package/features/security/apiKeys/ListApiKeys/feature.js +10 -0
- package/features/security/apiKeys/ListApiKeys/feature.js.map +1 -0
- package/features/security/apiKeys/ListApiKeys/index.d.ts +1 -0
- package/features/security/apiKeys/ListApiKeys/index.js +3 -0
- package/features/security/apiKeys/ListApiKeys/index.js.map +1 -0
- package/features/security/apiKeys/UpdateApiKey/UpdateApiKeyUseCase.d.ts +17 -0
- package/features/security/apiKeys/UpdateApiKey/UpdateApiKeyUseCase.js +55 -0
- package/features/security/apiKeys/UpdateApiKey/UpdateApiKeyUseCase.js.map +1 -0
- package/features/security/apiKeys/UpdateApiKey/abstractions.d.ts +28 -0
- package/features/security/apiKeys/UpdateApiKey/abstractions.js +4 -0
- package/features/security/apiKeys/UpdateApiKey/abstractions.js.map +1 -0
- package/features/security/apiKeys/UpdateApiKey/events.d.ts +21 -0
- package/features/security/apiKeys/UpdateApiKey/events.js +18 -0
- package/features/security/apiKeys/UpdateApiKey/events.js.map +1 -0
- package/features/security/apiKeys/UpdateApiKey/feature.d.ts +1 -0
- package/features/security/apiKeys/UpdateApiKey/feature.js +10 -0
- package/features/security/apiKeys/UpdateApiKey/feature.js.map +1 -0
- package/features/security/apiKeys/UpdateApiKey/index.d.ts +2 -0
- package/features/security/apiKeys/UpdateApiKey/index.js +4 -0
- package/features/security/apiKeys/UpdateApiKey/index.js.map +1 -0
- package/features/security/apiKeys/feature.d.ts +1 -0
- package/features/security/apiKeys/feature.js +29 -0
- package/features/security/apiKeys/feature.js.map +1 -0
- package/features/security/apiKeys/shared/ApiKeyProvider.d.ts +15 -0
- package/features/security/apiKeys/shared/ApiKeyProvider.js +51 -0
- package/features/security/apiKeys/shared/ApiKeyProvider.js.map +1 -0
- package/features/security/apiKeys/shared/ApiKeysRepository.d.ts +21 -0
- package/features/security/apiKeys/shared/ApiKeysRepository.js +153 -0
- package/features/security/apiKeys/shared/ApiKeysRepository.js.map +1 -0
- package/features/security/apiKeys/shared/abstractions.d.ts +42 -0
- package/features/security/apiKeys/shared/abstractions.js +6 -0
- package/features/security/apiKeys/shared/abstractions.js.map +1 -0
- package/features/security/apiKeys/shared/errors.d.ts +24 -0
- package/features/security/apiKeys/shared/errors.js +39 -0
- package/features/security/apiKeys/shared/errors.js.map +1 -0
- package/features/security/apiKeys/shared/generateToken.d.ts +7 -0
- package/features/security/apiKeys/shared/generateToken.js +19 -0
- package/features/security/apiKeys/shared/generateToken.js.map +1 -0
- package/features/security/apiKeys/shared/schemas.d.ts +91 -0
- package/features/security/apiKeys/shared/schemas.js +29 -0
- package/features/security/apiKeys/shared/schemas.js.map +1 -0
- package/features/security/apiKeys/shared/types.d.ts +25 -0
- package/features/security/apiKeys/shared/types.js +3 -0
- package/features/security/apiKeys/shared/types.js.map +1 -0
- package/features/security/authentication/AuthenticationContext/AuthenticationContext.d.ts +15 -0
- package/features/security/authentication/AuthenticationContext/AuthenticationContext.js +51 -0
- package/features/security/authentication/AuthenticationContext/AuthenticationContext.js.map +1 -0
- package/features/security/authentication/AuthenticationContext/SetIdTokenCookie.d.ts +11 -0
- package/features/security/authentication/AuthenticationContext/SetIdTokenCookie.js +52 -0
- package/features/security/authentication/AuthenticationContext/SetIdTokenCookie.js.map +1 -0
- package/features/security/authentication/AuthenticationContext/abstractions.d.ts +9 -0
- package/features/security/authentication/AuthenticationContext/abstractions.js +4 -0
- package/features/security/authentication/AuthenticationContext/abstractions.js.map +1 -0
- package/features/security/authentication/AuthenticationContext/errors.d.ts +64 -0
- package/features/security/authentication/AuthenticationContext/errors.js +130 -0
- package/features/security/authentication/AuthenticationContext/errors.js.map +1 -0
- package/features/security/authentication/AuthenticationContext/events.d.ts +28 -0
- package/features/security/authentication/AuthenticationContext/events.js +18 -0
- package/features/security/authentication/AuthenticationContext/events.js.map +1 -0
- package/features/security/authentication/AuthenticationContext/feature.d.ts +1 -0
- package/features/security/authentication/AuthenticationContext/feature.js +10 -0
- package/features/security/authentication/AuthenticationContext/feature.js.map +1 -0
- package/features/security/authentication/AuthenticationContext/index.d.ts +5 -0
- package/features/security/authentication/AuthenticationContext/index.js +6 -0
- package/features/security/authentication/AuthenticationContext/index.js.map +1 -0
- package/features/security/authentication/Authenticator/abstractions.d.ts +8 -0
- package/features/security/authentication/Authenticator/abstractions.js +4 -0
- package/features/security/authentication/Authenticator/abstractions.js.map +1 -0
- package/features/security/authentication/Authenticator/index.d.ts +1 -0
- package/features/security/authentication/Authenticator/index.js +3 -0
- package/features/security/authentication/Authenticator/index.js.map +1 -0
- package/features/security/authorization/AuthorizationContext/AuthorizationContext.d.ts +16 -0
- package/features/security/authorization/AuthorizationContext/AuthorizationContext.js +55 -0
- package/features/security/authorization/AuthorizationContext/AuthorizationContext.js.map +1 -0
- package/features/security/authorization/AuthorizationContext/abstractions.d.ts +21 -0
- package/features/security/authorization/AuthorizationContext/abstractions.js +5 -0
- package/features/security/authorization/AuthorizationContext/abstractions.js.map +1 -0
- package/features/security/authorization/AuthorizationContext/feature.d.ts +1 -0
- package/features/security/authorization/AuthorizationContext/feature.js +15 -0
- package/features/security/authorization/AuthorizationContext/feature.js.map +1 -0
- package/features/security/authorization/AuthorizationContext/index.d.ts +4 -0
- package/features/security/authorization/AuthorizationContext/index.js +5 -0
- package/features/security/authorization/AuthorizationContext/index.js.map +1 -0
- package/features/security/authorization/Authorizer/abstractions.d.ts +9 -0
- package/features/security/authorization/Authorizer/abstractions.js +4 -0
- package/features/security/authorization/Authorizer/abstractions.js.map +1 -0
- package/features/security/authorization/Authorizer/index.d.ts +1 -0
- package/features/security/authorization/Authorizer/index.js +3 -0
- package/features/security/authorization/Authorizer/index.js.map +1 -0
- package/features/security/authorization/GroupsTeamsAuthorizer/GetPermissionsFromIdentity.d.ts +23 -0
- package/features/security/authorization/GroupsTeamsAuthorizer/GetPermissionsFromIdentity.js +80 -0
- package/features/security/authorization/GroupsTeamsAuthorizer/GetPermissionsFromIdentity.js.map +1 -0
- package/features/security/authorization/GroupsTeamsAuthorizer/RolesTeamsAuthorizer.d.ts +17 -0
- package/features/security/authorization/GroupsTeamsAuthorizer/RolesTeamsAuthorizer.js +51 -0
- package/features/security/authorization/GroupsTeamsAuthorizer/RolesTeamsAuthorizer.js.map +1 -0
- package/features/security/authorization/GroupsTeamsAuthorizer/abstractions.d.ts +13 -0
- package/features/security/authorization/GroupsTeamsAuthorizer/abstractions.js +4 -0
- package/features/security/authorization/GroupsTeamsAuthorizer/abstractions.js.map +1 -0
- package/features/security/authorization/GroupsTeamsAuthorizer/feature.d.ts +1 -0
- package/features/security/authorization/GroupsTeamsAuthorizer/feature.js +12 -0
- package/features/security/authorization/GroupsTeamsAuthorizer/feature.js.map +1 -0
- package/features/security/login/abstractions.d.ts +15 -0
- package/features/security/login/abstractions.js +11 -0
- package/features/security/login/abstractions.js.map +1 -0
- package/features/security/login/index.d.ts +1 -0
- package/features/security/login/index.js +3 -0
- package/features/security/login/index.js.map +1 -0
- package/features/security/roles/CreateRole/CreateRoleUseCase.d.ts +17 -0
- package/features/security/roles/CreateRole/CreateRoleUseCase.js +76 -0
- package/features/security/roles/CreateRole/CreateRoleUseCase.js.map +1 -0
- package/features/security/roles/CreateRole/abstractions.d.ts +27 -0
- package/features/security/roles/CreateRole/abstractions.js +4 -0
- package/features/security/roles/CreateRole/abstractions.js.map +1 -0
- package/features/security/roles/CreateRole/events.d.ts +21 -0
- package/features/security/roles/CreateRole/events.js +18 -0
- package/features/security/roles/CreateRole/events.js.map +1 -0
- package/features/security/roles/CreateRole/feature.d.ts +1 -0
- package/features/security/roles/CreateRole/feature.js +10 -0
- package/features/security/roles/CreateRole/feature.js.map +1 -0
- package/features/security/roles/CreateRole/index.d.ts +2 -0
- package/features/security/roles/CreateRole/index.js +4 -0
- package/features/security/roles/CreateRole/index.js.map +1 -0
- package/features/security/roles/CreateRole/schema.d.ts +27 -0
- package/features/security/roles/CreateRole/schema.js +11 -0
- package/features/security/roles/CreateRole/schema.js.map +1 -0
- package/features/security/roles/DeleteRole/DeleteRoleUseCase.d.ts +14 -0
- package/features/security/roles/DeleteRole/DeleteRoleUseCase.js +51 -0
- package/features/security/roles/DeleteRole/DeleteRoleUseCase.js.map +1 -0
- package/features/security/roles/DeleteRole/abstractions.d.ts +24 -0
- package/features/security/roles/DeleteRole/abstractions.js +4 -0
- package/features/security/roles/DeleteRole/abstractions.js.map +1 -0
- package/features/security/roles/DeleteRole/events.d.ts +21 -0
- package/features/security/roles/DeleteRole/events.js +18 -0
- package/features/security/roles/DeleteRole/events.js.map +1 -0
- package/features/security/roles/DeleteRole/feature.d.ts +1 -0
- package/features/security/roles/DeleteRole/feature.js +10 -0
- package/features/security/roles/DeleteRole/feature.js.map +1 -0
- package/features/security/roles/DeleteRole/index.d.ts +2 -0
- package/features/security/roles/DeleteRole/index.js +4 -0
- package/features/security/roles/DeleteRole/index.js.map +1 -0
- package/features/security/roles/GetRole/GetRoleUseCase.d.ts +12 -0
- package/features/security/roles/GetRole/GetRoleUseCase.js +26 -0
- package/features/security/roles/GetRole/GetRoleUseCase.js.map +1 -0
- package/features/security/roles/GetRole/abstractions.d.ts +17 -0
- package/features/security/roles/GetRole/abstractions.js +4 -0
- package/features/security/roles/GetRole/abstractions.js.map +1 -0
- package/features/security/roles/GetRole/feature.d.ts +1 -0
- package/features/security/roles/GetRole/feature.js +10 -0
- package/features/security/roles/GetRole/feature.js.map +1 -0
- package/features/security/roles/GetRole/index.d.ts +1 -0
- package/features/security/roles/GetRole/index.js +3 -0
- package/features/security/roles/GetRole/index.js.map +1 -0
- package/features/security/roles/Installer/RolesInstaller.d.ts +18 -0
- package/features/security/roles/Installer/RolesInstaller.js +47 -0
- package/features/security/roles/Installer/RolesInstaller.js.map +1 -0
- package/features/security/roles/ListRoles/ListRolesUseCase.d.ts +13 -0
- package/features/security/roles/ListRoles/ListRolesUseCase.js +26 -0
- package/features/security/roles/ListRoles/ListRolesUseCase.js.map +1 -0
- package/features/security/roles/ListRoles/abstractions.d.ts +17 -0
- package/features/security/roles/ListRoles/abstractions.js +4 -0
- package/features/security/roles/ListRoles/abstractions.js.map +1 -0
- package/features/security/roles/ListRoles/feature.d.ts +1 -0
- package/features/security/roles/ListRoles/feature.js +10 -0
- package/features/security/roles/ListRoles/feature.js.map +1 -0
- package/features/security/roles/ListRoles/index.d.ts +1 -0
- package/features/security/roles/ListRoles/index.js +3 -0
- package/features/security/roles/ListRoles/index.js.map +1 -0
- package/features/security/roles/UpdateRole/UpdateRoleUseCase.d.ts +17 -0
- package/features/security/roles/UpdateRole/UpdateRoleUseCase.js +62 -0
- package/features/security/roles/UpdateRole/UpdateRoleUseCase.js.map +1 -0
- package/features/security/roles/UpdateRole/abstractions.d.ts +29 -0
- package/features/security/roles/UpdateRole/abstractions.js +4 -0
- package/features/security/roles/UpdateRole/abstractions.js.map +1 -0
- package/features/security/roles/UpdateRole/events.d.ts +21 -0
- package/features/security/roles/UpdateRole/events.js +18 -0
- package/features/security/roles/UpdateRole/events.js.map +1 -0
- package/features/security/roles/UpdateRole/feature.d.ts +1 -0
- package/features/security/roles/UpdateRole/feature.js +10 -0
- package/features/security/roles/UpdateRole/feature.js.map +1 -0
- package/features/security/roles/UpdateRole/index.d.ts +2 -0
- package/features/security/roles/UpdateRole/index.js +4 -0
- package/features/security/roles/UpdateRole/index.js.map +1 -0
- package/features/security/roles/UpdateRole/schema.d.ts +24 -0
- package/features/security/roles/UpdateRole/schema.js +10 -0
- package/features/security/roles/UpdateRole/schema.js.map +1 -0
- package/features/security/roles/feature.d.ts +1 -0
- package/features/security/roles/feature.js +29 -0
- package/features/security/roles/feature.js.map +1 -0
- package/features/security/roles/shared/RolesRepository.d.ts +18 -0
- package/features/security/roles/shared/RolesRepository.js +130 -0
- package/features/security/roles/shared/RolesRepository.js.map +1 -0
- package/features/security/roles/shared/abstractions.d.ts +20 -0
- package/features/security/roles/shared/abstractions.js +4 -0
- package/features/security/roles/shared/abstractions.js.map +1 -0
- package/features/security/roles/shared/decorators/ListCache.d.ts +24 -0
- package/features/security/roles/shared/decorators/ListCache.js +26 -0
- package/features/security/roles/shared/decorators/ListCache.js.map +1 -0
- package/features/security/roles/shared/decorators/RolesRepositoryCachingDecorator.d.ts +17 -0
- package/features/security/roles/shared/decorators/RolesRepositoryCachingDecorator.js +76 -0
- package/features/security/roles/shared/decorators/RolesRepositoryCachingDecorator.js.map +1 -0
- package/features/security/roles/shared/errors.d.ts +39 -0
- package/features/security/roles/shared/errors.js +66 -0
- package/features/security/roles/shared/errors.js.map +1 -0
- package/features/security/roles/shared/types.d.ts +29 -0
- package/features/security/roles/shared/types.js +3 -0
- package/features/security/roles/shared/types.js.map +1 -0
- package/features/security/shared/abstractions.d.ts +31 -0
- package/features/security/shared/abstractions.js +22 -0
- package/features/security/shared/abstractions.js.map +1 -0
- package/features/security/shared/abstractions.ts.bak +52 -0
- package/features/security/shared/errors.d.ts +10 -0
- package/features/security/shared/errors.js +12 -0
- package/features/security/shared/errors.js.map +1 -0
- package/features/security/shared/index.d.ts +2 -0
- package/features/security/shared/index.js +4 -0
- package/features/security/shared/index.js.map +1 -0
- package/features/security/teams/CreateTeam/CreateTeamUseCase.d.ts +16 -0
- package/features/security/teams/CreateTeam/CreateTeamUseCase.js +76 -0
- package/features/security/teams/CreateTeam/CreateTeamUseCase.js.map +1 -0
- package/features/security/teams/CreateTeam/abstractions.d.ts +27 -0
- package/features/security/teams/CreateTeam/abstractions.js +4 -0
- package/features/security/teams/CreateTeam/abstractions.js.map +1 -0
- package/features/security/teams/CreateTeam/events.d.ts +21 -0
- package/features/security/teams/CreateTeam/events.js +18 -0
- package/features/security/teams/CreateTeam/events.js.map +1 -0
- package/features/security/teams/CreateTeam/feature.d.ts +1 -0
- package/features/security/teams/CreateTeam/feature.js +10 -0
- package/features/security/teams/CreateTeam/feature.js.map +1 -0
- package/features/security/teams/CreateTeam/index.d.ts +2 -0
- package/features/security/teams/CreateTeam/index.js +4 -0
- package/features/security/teams/CreateTeam/index.js.map +1 -0
- package/features/security/teams/CreateTeam/schema.d.ts +17 -0
- package/features/security/teams/CreateTeam/schema.js +9 -0
- package/features/security/teams/CreateTeam/schema.js.map +1 -0
- package/features/security/teams/DeleteTeam/DeleteTeamUseCase.d.ts +13 -0
- package/features/security/teams/DeleteTeam/DeleteTeamUseCase.js +56 -0
- package/features/security/teams/DeleteTeam/DeleteTeamUseCase.js.map +1 -0
- package/features/security/teams/DeleteTeam/abstractions.d.ts +25 -0
- package/features/security/teams/DeleteTeam/abstractions.js +4 -0
- package/features/security/teams/DeleteTeam/abstractions.js.map +1 -0
- package/features/security/teams/DeleteTeam/events.d.ts +21 -0
- package/features/security/teams/DeleteTeam/events.js +18 -0
- package/features/security/teams/DeleteTeam/events.js.map +1 -0
- package/features/security/teams/DeleteTeam/feature.d.ts +1 -0
- package/features/security/teams/DeleteTeam/feature.js +10 -0
- package/features/security/teams/DeleteTeam/feature.js.map +1 -0
- package/features/security/teams/DeleteTeam/index.d.ts +3 -0
- package/features/security/teams/DeleteTeam/index.js +5 -0
- package/features/security/teams/DeleteTeam/index.js.map +1 -0
- package/features/security/teams/GetTeam/GetTeamUseCase.d.ts +15 -0
- package/features/security/teams/GetTeam/GetTeamUseCase.js +28 -0
- package/features/security/teams/GetTeam/GetTeamUseCase.js.map +1 -0
- package/features/security/teams/GetTeam/abstractions.d.ts +17 -0
- package/features/security/teams/GetTeam/abstractions.js +4 -0
- package/features/security/teams/GetTeam/abstractions.js.map +1 -0
- package/features/security/teams/GetTeam/feature.d.ts +1 -0
- package/features/security/teams/GetTeam/feature.js +10 -0
- package/features/security/teams/GetTeam/feature.js.map +1 -0
- package/features/security/teams/GetTeam/index.d.ts +1 -0
- package/features/security/teams/GetTeam/index.js +3 -0
- package/features/security/teams/GetTeam/index.js.map +1 -0
- package/features/security/teams/ListTeams/ListTeamsUseCase.d.ts +12 -0
- package/features/security/teams/ListTeams/ListTeamsUseCase.js +30 -0
- package/features/security/teams/ListTeams/ListTeamsUseCase.js.map +1 -0
- package/features/security/teams/ListTeams/abstractions.d.ts +17 -0
- package/features/security/teams/ListTeams/abstractions.js +4 -0
- package/features/security/teams/ListTeams/abstractions.js.map +1 -0
- package/features/security/teams/ListTeams/feature.d.ts +1 -0
- package/features/security/teams/ListTeams/feature.js +10 -0
- package/features/security/teams/ListTeams/feature.js.map +1 -0
- package/features/security/teams/ListTeams/index.d.ts +1 -0
- package/features/security/teams/ListTeams/index.js +3 -0
- package/features/security/teams/ListTeams/index.js.map +1 -0
- package/features/security/teams/UpdateTeam/UpdateTeamUseCase.d.ts +14 -0
- package/features/security/teams/UpdateTeam/UpdateTeamUseCase.js +69 -0
- package/features/security/teams/UpdateTeam/UpdateTeamUseCase.js.map +1 -0
- package/features/security/teams/UpdateTeam/abstractions.d.ts +30 -0
- package/features/security/teams/UpdateTeam/abstractions.js +4 -0
- package/features/security/teams/UpdateTeam/abstractions.js.map +1 -0
- package/features/security/teams/UpdateTeam/events.d.ts +21 -0
- package/features/security/teams/UpdateTeam/events.js +18 -0
- package/features/security/teams/UpdateTeam/events.js.map +1 -0
- package/features/security/teams/UpdateTeam/feature.d.ts +1 -0
- package/features/security/teams/UpdateTeam/feature.js +10 -0
- package/features/security/teams/UpdateTeam/feature.js.map +1 -0
- package/features/security/teams/UpdateTeam/index.d.ts +3 -0
- package/features/security/teams/UpdateTeam/index.js +5 -0
- package/features/security/teams/UpdateTeam/index.js.map +1 -0
- package/features/security/teams/UpdateTeam/schema.d.ts +14 -0
- package/features/security/teams/UpdateTeam/schema.js +8 -0
- package/features/security/teams/UpdateTeam/schema.js.map +1 -0
- package/features/security/teams/feature.d.ts +1 -0
- package/features/security/teams/feature.js +23 -0
- package/features/security/teams/feature.js.map +1 -0
- package/features/security/teams/shared/TeamsRepository.d.ts +18 -0
- package/features/security/teams/shared/TeamsRepository.js +133 -0
- package/features/security/teams/shared/TeamsRepository.js.map +1 -0
- package/features/security/teams/shared/abstractions.d.ts +20 -0
- package/features/security/teams/shared/abstractions.js +4 -0
- package/features/security/teams/shared/abstractions.js.map +1 -0
- package/features/security/teams/shared/errors.d.ts +47 -0
- package/features/security/teams/shared/errors.js +82 -0
- package/features/security/teams/shared/errors.js.map +1 -0
- package/features/security/teams/shared/types.d.ts +28 -0
- package/features/security/teams/shared/types.js +3 -0
- package/features/security/teams/shared/types.js.map +1 -0
- package/features/security/utils/AppPermissions.d.ts +27 -0
- package/features/security/utils/AppPermissions.js +99 -0
- package/features/security/utils/AppPermissions.js.map +1 -0
- package/features/security/utils/IdentityValue.d.ts +18 -0
- package/features/security/utils/IdentityValue.js +27 -0
- package/features/security/utils/IdentityValue.js.map +1 -0
- package/features/security/utils/filterOutCustomWbyAppsPermissions.d.ts +2 -0
- package/features/security/utils/filterOutCustomWbyAppsPermissions.js +29 -0
- package/features/security/utils/filterOutCustomWbyAppsPermissions.js.map +1 -0
- package/features/security/utils/getPermissionsFromRoles.d.ts +8 -0
- package/features/security/utils/getPermissionsFromRoles.js +12 -0
- package/features/security/utils/getPermissionsFromRoles.js.map +1 -0
- package/features/security/utils/isJwt.d.ts +1 -0
- package/features/security/utils/isJwt.js +3 -0
- package/features/security/utils/isJwt.js.map +1 -0
- package/features/security/utils/verifyJwtUsingJwk.d.ts +10 -0
- package/features/security/utils/verifyJwtUsingJwk.js +11 -0
- package/features/security/utils/verifyJwtUsingJwk.js.map +1 -0
- package/features/system/InstallSystem/InstallSystemUseCase.d.ts +24 -0
- package/features/system/InstallSystem/InstallSystemUseCase.js +61 -0
- package/features/system/InstallSystem/InstallSystemUseCase.js.map +1 -0
- package/features/system/InstallSystem/abstractions.d.ts +34 -0
- package/features/system/InstallSystem/abstractions.js +21 -0
- package/features/system/InstallSystem/abstractions.js.map +1 -0
- package/features/system/InstallSystem/errors.d.ts +16 -0
- package/features/system/InstallSystem/errors.js +21 -0
- package/features/system/InstallSystem/errors.js.map +1 -0
- package/features/system/InstallSystem/events.d.ts +5 -0
- package/features/system/InstallSystem/events.js +10 -0
- package/features/system/InstallSystem/events.js.map +1 -0
- package/features/system/InstallSystem/feature.d.ts +1 -0
- package/features/system/InstallSystem/feature.js +12 -0
- package/features/system/InstallSystem/feature.js.map +1 -0
- package/features/system/InstallSystem/index.d.ts +6 -0
- package/features/system/InstallSystem/index.js +7 -0
- package/features/system/InstallSystem/index.js.map +1 -0
- package/features/system/SystemFeature.d.ts +1 -0
- package/features/system/SystemFeature.js +10 -0
- package/features/system/SystemFeature.js.map +1 -0
- package/features/task/TaskController/abstractions.d.ts +13 -0
- package/features/task/TaskController/abstractions.js +12 -0
- package/features/task/TaskController/abstractions.js.map +1 -0
- package/features/task/TaskController/index.d.ts +1 -0
- package/features/task/TaskController/index.js +3 -0
- package/features/task/TaskController/index.js.map +1 -0
- package/features/task/TaskDefinition/abstractions.d.ts +131 -0
- package/features/task/TaskDefinition/abstractions.js +43 -0
- package/features/task/TaskDefinition/abstractions.js.map +1 -0
- package/features/task/TaskDefinition/index.d.ts +1 -0
- package/features/task/TaskDefinition/index.js +3 -0
- package/features/task/TaskDefinition/index.js.map +1 -0
- package/features/task/TaskService/abstractions.d.ts +74 -0
- package/features/task/TaskService/abstractions.js +16 -0
- package/features/task/TaskService/abstractions.js.map +1 -0
- package/features/task/TaskService/index.d.ts +1 -0
- package/features/task/TaskService/index.js +3 -0
- package/features/task/TaskService/index.js.map +1 -0
- package/features/tenancy/CreateTenant/CreateTenantGateway.d.ts +10 -0
- package/features/tenancy/CreateTenant/CreateTenantGateway.js +18 -0
- package/features/tenancy/CreateTenant/CreateTenantGateway.js.map +1 -0
- package/features/tenancy/CreateTenant/CreateTenantRepository.d.ts +12 -0
- package/features/tenancy/CreateTenant/CreateTenantRepository.js +22 -0
- package/features/tenancy/CreateTenant/CreateTenantRepository.js.map +1 -0
- package/features/tenancy/CreateTenant/CreateTenantUseCase.d.ts +14 -0
- package/features/tenancy/CreateTenant/CreateTenantUseCase.js +51 -0
- package/features/tenancy/CreateTenant/CreateTenantUseCase.js.map +1 -0
- package/features/tenancy/CreateTenant/abstractions.d.ts +55 -0
- package/features/tenancy/CreateTenant/abstractions.js +30 -0
- package/features/tenancy/CreateTenant/abstractions.js.map +1 -0
- package/features/tenancy/CreateTenant/decorators/CreateTenantWithWcpIncrement.d.ts +11 -0
- package/features/tenancy/CreateTenant/decorators/CreateTenantWithWcpIncrement.js +24 -0
- package/features/tenancy/CreateTenant/decorators/CreateTenantWithWcpIncrement.js.map +1 -0
- package/features/tenancy/CreateTenant/errors.d.ts +5 -0
- package/features/tenancy/CreateTenant/errors.js +12 -0
- package/features/tenancy/CreateTenant/errors.js.map +1 -0
- package/features/tenancy/CreateTenant/events.d.ts +18 -0
- package/features/tenancy/CreateTenant/events.js +16 -0
- package/features/tenancy/CreateTenant/events.js.map +1 -0
- package/features/tenancy/CreateTenant/feature.d.ts +1 -0
- package/features/tenancy/CreateTenant/feature.js +16 -0
- package/features/tenancy/CreateTenant/feature.js.map +1 -0
- package/features/tenancy/CreateTenant/index.d.ts +3 -0
- package/features/tenancy/CreateTenant/index.js +5 -0
- package/features/tenancy/CreateTenant/index.js.map +1 -0
- package/features/tenancy/DeleteTenant/DeleteTenantGateway.d.ts +8 -0
- package/features/tenancy/DeleteTenant/DeleteTenantGateway.js +18 -0
- package/features/tenancy/DeleteTenant/DeleteTenantGateway.js.map +1 -0
- package/features/tenancy/DeleteTenant/DeleteTenantRepository.d.ts +11 -0
- package/features/tenancy/DeleteTenant/DeleteTenantRepository.js +25 -0
- package/features/tenancy/DeleteTenant/DeleteTenantRepository.js.map +1 -0
- package/features/tenancy/DeleteTenant/DeleteTenantUseCase.d.ts +12 -0
- package/features/tenancy/DeleteTenant/DeleteTenantUseCase.js +35 -0
- package/features/tenancy/DeleteTenant/DeleteTenantUseCase.js.map +1 -0
- package/features/tenancy/DeleteTenant/abstractions.d.ts +33 -0
- package/features/tenancy/DeleteTenant/abstractions.js +8 -0
- package/features/tenancy/DeleteTenant/abstractions.js.map +1 -0
- package/features/tenancy/DeleteTenant/decorators/DeleteTenantWithWcpDecrement.d.ts +10 -0
- package/features/tenancy/DeleteTenant/decorators/DeleteTenantWithWcpDecrement.js +21 -0
- package/features/tenancy/DeleteTenant/decorators/DeleteTenantWithWcpDecrement.js.map +1 -0
- package/features/tenancy/DeleteTenant/events.d.ts +16 -0
- package/features/tenancy/DeleteTenant/events.js +16 -0
- package/features/tenancy/DeleteTenant/events.js.map +1 -0
- package/features/tenancy/DeleteTenant/feature.d.ts +1 -0
- package/features/tenancy/DeleteTenant/feature.js +16 -0
- package/features/tenancy/DeleteTenant/feature.js.map +1 -0
- package/features/tenancy/DeleteTenant/index.d.ts +3 -0
- package/features/tenancy/DeleteTenant/index.js +5 -0
- package/features/tenancy/DeleteTenant/index.js.map +1 -0
- package/features/tenancy/GetRootTenant/GetRootTenantUseCase.d.ts +8 -0
- package/features/tenancy/GetRootTenant/GetRootTenantUseCase.js +18 -0
- package/features/tenancy/GetRootTenant/GetRootTenantUseCase.js.map +1 -0
- package/features/tenancy/GetRootTenant/abstractions.d.ts +8 -0
- package/features/tenancy/GetRootTenant/abstractions.js +7 -0
- package/features/tenancy/GetRootTenant/abstractions.js.map +1 -0
- package/features/tenancy/GetRootTenant/feature.d.ts +1 -0
- package/features/tenancy/GetRootTenant/feature.js +10 -0
- package/features/tenancy/GetRootTenant/feature.js.map +1 -0
- package/features/tenancy/GetRootTenant/index.d.ts +1 -0
- package/features/tenancy/GetRootTenant/index.js +3 -0
- package/features/tenancy/GetRootTenant/index.js.map +1 -0
- package/features/tenancy/GetTenantById/GetTenantByIdGateway.d.ts +10 -0
- package/features/tenancy/GetTenantById/GetTenantByIdGateway.js +19 -0
- package/features/tenancy/GetTenantById/GetTenantByIdGateway.js.map +1 -0
- package/features/tenancy/GetTenantById/GetTenantByIdRepository.d.ts +12 -0
- package/features/tenancy/GetTenantById/GetTenantByIdRepository.js +28 -0
- package/features/tenancy/GetTenantById/GetTenantByIdRepository.js.map +1 -0
- package/features/tenancy/GetTenantById/GetTenantByIdUseCase.d.ts +9 -0
- package/features/tenancy/GetTenantById/GetTenantByIdUseCase.js +25 -0
- package/features/tenancy/GetTenantById/GetTenantByIdUseCase.js.map +1 -0
- package/features/tenancy/GetTenantById/abstractions.d.ts +31 -0
- package/features/tenancy/GetTenantById/abstractions.js +15 -0
- package/features/tenancy/GetTenantById/abstractions.js.map +1 -0
- package/features/tenancy/GetTenantById/feature.d.ts +1 -0
- package/features/tenancy/GetTenantById/feature.js +19 -0
- package/features/tenancy/GetTenantById/feature.js.map +1 -0
- package/features/tenancy/GetTenantById/index.d.ts +1 -0
- package/features/tenancy/GetTenantById/index.js +3 -0
- package/features/tenancy/GetTenantById/index.js.map +1 -0
- package/features/tenancy/InstallTenant/DependencyResolver.d.ts +6 -0
- package/features/tenancy/InstallTenant/DependencyResolver.js +73 -0
- package/features/tenancy/InstallTenant/DependencyResolver.js.map +1 -0
- package/features/tenancy/InstallTenant/InstallTenantUseCase.d.ts +20 -0
- package/features/tenancy/InstallTenant/InstallTenantUseCase.js +133 -0
- package/features/tenancy/InstallTenant/InstallTenantUseCase.js.map +1 -0
- package/features/tenancy/InstallTenant/abstractions.d.ts +66 -0
- package/features/tenancy/InstallTenant/abstractions.js +27 -0
- package/features/tenancy/InstallTenant/abstractions.js.map +1 -0
- package/features/tenancy/InstallTenant/errors.d.ts +19 -0
- package/features/tenancy/InstallTenant/errors.js +21 -0
- package/features/tenancy/InstallTenant/errors.js.map +1 -0
- package/features/tenancy/InstallTenant/events.d.ts +10 -0
- package/features/tenancy/InstallTenant/events.js +10 -0
- package/features/tenancy/InstallTenant/events.js.map +1 -0
- package/features/tenancy/InstallTenant/feature.d.ts +1 -0
- package/features/tenancy/InstallTenant/feature.js +10 -0
- package/features/tenancy/InstallTenant/feature.js.map +1 -0
- package/features/tenancy/InstallTenant/index.d.ts +5 -0
- package/features/tenancy/InstallTenant/index.js +7 -0
- package/features/tenancy/InstallTenant/index.js.map +1 -0
- package/features/tenancy/ListTenants/ListTenantsGateway.d.ts +10 -0
- package/features/tenancy/ListTenants/ListTenantsGateway.js +18 -0
- package/features/tenancy/ListTenants/ListTenantsGateway.js.map +1 -0
- package/features/tenancy/ListTenants/ListTenantsRepository.d.ts +10 -0
- package/features/tenancy/ListTenants/ListTenantsRepository.js +18 -0
- package/features/tenancy/ListTenants/ListTenantsRepository.js.map +1 -0
- package/features/tenancy/ListTenants/ListTenantsUseCase.d.ts +11 -0
- package/features/tenancy/ListTenants/ListTenantsUseCase.js +19 -0
- package/features/tenancy/ListTenants/ListTenantsUseCase.js.map +1 -0
- package/features/tenancy/ListTenants/abstractions.d.ts +23 -0
- package/features/tenancy/ListTenants/abstractions.js +15 -0
- package/features/tenancy/ListTenants/abstractions.js.map +1 -0
- package/features/tenancy/ListTenants/feature.d.ts +1 -0
- package/features/tenancy/ListTenants/feature.js +14 -0
- package/features/tenancy/ListTenants/feature.js.map +1 -0
- package/features/tenancy/ListTenants/index.d.ts +2 -0
- package/features/tenancy/ListTenants/index.js +4 -0
- package/features/tenancy/ListTenants/index.js.map +1 -0
- package/features/tenancy/TenancyFeature.d.ts +2 -0
- package/features/tenancy/TenancyFeature.js +40 -0
- package/features/tenancy/TenancyFeature.js.map +1 -0
- package/features/tenancy/TenantContext/TenantContext.d.ts +15 -0
- package/features/tenancy/TenantContext/TenantContext.js +61 -0
- package/features/tenancy/TenantContext/TenantContext.js.map +1 -0
- package/features/tenancy/TenantContext/abstractions.d.ts +12 -0
- package/features/tenancy/TenantContext/abstractions.js +4 -0
- package/features/tenancy/TenantContext/abstractions.js.map +1 -0
- package/features/tenancy/TenantContext/errors.d.ts +5 -0
- package/features/tenancy/TenantContext/errors.js +11 -0
- package/features/tenancy/TenantContext/errors.js.map +1 -0
- package/features/tenancy/TenantContext/feature.d.ts +1 -0
- package/features/tenancy/TenantContext/feature.js +10 -0
- package/features/tenancy/TenantContext/feature.js.map +1 -0
- package/features/tenancy/TenantContext/index.d.ts +1 -0
- package/features/tenancy/TenantContext/index.js +3 -0
- package/features/tenancy/TenantContext/index.js.map +1 -0
- package/features/tenancy/UpdateTenant/UpdateTenantGateway.d.ts +10 -0
- package/features/tenancy/UpdateTenant/UpdateTenantGateway.js +18 -0
- package/features/tenancy/UpdateTenant/UpdateTenantGateway.js.map +1 -0
- package/features/tenancy/UpdateTenant/UpdateTenantRepository.d.ts +12 -0
- package/features/tenancy/UpdateTenant/UpdateTenantRepository.js +23 -0
- package/features/tenancy/UpdateTenant/UpdateTenantRepository.js.map +1 -0
- package/features/tenancy/UpdateTenant/UpdateTenantUseCase.d.ts +17 -0
- package/features/tenancy/UpdateTenant/UpdateTenantUseCase.js +44 -0
- package/features/tenancy/UpdateTenant/UpdateTenantUseCase.js.map +1 -0
- package/features/tenancy/UpdateTenant/abstractions.d.ts +41 -0
- package/features/tenancy/UpdateTenant/abstractions.js +8 -0
- package/features/tenancy/UpdateTenant/abstractions.js.map +1 -0
- package/features/tenancy/UpdateTenant/events.d.ts +19 -0
- package/features/tenancy/UpdateTenant/events.js +16 -0
- package/features/tenancy/UpdateTenant/events.js.map +1 -0
- package/features/tenancy/UpdateTenant/feature.d.ts +1 -0
- package/features/tenancy/UpdateTenant/feature.js +14 -0
- package/features/tenancy/UpdateTenant/feature.js.map +1 -0
- package/features/tenancy/UpdateTenant/index.d.ts +3 -0
- package/features/tenancy/UpdateTenant/index.js +5 -0
- package/features/tenancy/UpdateTenant/index.js.map +1 -0
- package/features/tenancy/shared/TenantCache.d.ts +13 -0
- package/features/tenancy/shared/TenantCache.js +20 -0
- package/features/tenancy/shared/TenantCache.js.map +1 -0
- package/features/tenancy/shared/abstractions.d.ts +11 -0
- package/features/tenancy/shared/abstractions.js +4 -0
- package/features/tenancy/shared/abstractions.js.map +1 -0
- package/features/tenancy/shared/storageOperations.d.ts +9 -0
- package/features/tenancy/shared/storageOperations.js +8 -0
- package/features/tenancy/shared/storageOperations.js.map +1 -0
- package/features/users/AdminUsersFeature.d.ts +1 -0
- package/features/users/AdminUsersFeature.js +33 -0
- package/features/users/AdminUsersFeature.js.map +1 -0
- package/features/users/CreateUser/CreateUserUseCase.d.ts +19 -0
- package/features/users/CreateUser/CreateUserUseCase.js +114 -0
- package/features/users/CreateUser/CreateUserUseCase.js.map +1 -0
- package/features/users/CreateUser/abstractions.d.ts +29 -0
- package/features/users/CreateUser/abstractions.js +16 -0
- package/features/users/CreateUser/abstractions.js.map +1 -0
- package/features/users/CreateUser/decorators/CreateUserWithWcpIncrement.d.ts +11 -0
- package/features/users/CreateUser/decorators/CreateUserWithWcpIncrement.js +24 -0
- package/features/users/CreateUser/decorators/CreateUserWithWcpIncrement.js.map +1 -0
- package/features/users/CreateUser/events.d.ts +21 -0
- package/features/users/CreateUser/events.js +20 -0
- package/features/users/CreateUser/events.js.map +1 -0
- package/features/users/CreateUser/feature.d.ts +1 -0
- package/features/users/CreateUser/feature.js +12 -0
- package/features/users/CreateUser/feature.js.map +1 -0
- package/features/users/CreateUser/index.d.ts +2 -0
- package/features/users/CreateUser/index.js +4 -0
- package/features/users/CreateUser/index.js.map +1 -0
- package/features/users/CreateUser/schema.d.ts +47 -0
- package/features/users/CreateUser/schema.js +22 -0
- package/features/users/CreateUser/schema.js.map +1 -0
- package/features/users/DeleteUser/DeleteUserUseCase.d.ts +14 -0
- package/features/users/DeleteUser/DeleteUserUseCase.js +62 -0
- package/features/users/DeleteUser/DeleteUserUseCase.js.map +1 -0
- package/features/users/DeleteUser/abstractions.d.ts +24 -0
- package/features/users/DeleteUser/abstractions.js +16 -0
- package/features/users/DeleteUser/abstractions.js.map +1 -0
- package/features/users/DeleteUser/decorators/DeleteUserWithWcpDecrement.d.ts +10 -0
- package/features/users/DeleteUser/decorators/DeleteUserWithWcpDecrement.js +25 -0
- package/features/users/DeleteUser/decorators/DeleteUserWithWcpDecrement.js.map +1 -0
- package/features/users/DeleteUser/errors.d.ts +5 -0
- package/features/users/DeleteUser/errors.js +11 -0
- package/features/users/DeleteUser/errors.js.map +1 -0
- package/features/users/DeleteUser/events.d.ts +21 -0
- package/features/users/DeleteUser/events.js +20 -0
- package/features/users/DeleteUser/events.js.map +1 -0
- package/features/users/DeleteUser/feature.d.ts +1 -0
- package/features/users/DeleteUser/feature.js +12 -0
- package/features/users/DeleteUser/feature.js.map +1 -0
- package/features/users/DeleteUser/index.d.ts +2 -0
- package/features/users/DeleteUser/index.js +4 -0
- package/features/users/DeleteUser/index.js.map +1 -0
- package/features/users/ExternalIdpUserSync/ExternalIdpUserSyncHandler.d.ts +19 -0
- package/features/users/ExternalIdpUserSync/ExternalIdpUserSyncHandler.js +89 -0
- package/features/users/ExternalIdpUserSync/ExternalIdpUserSyncHandler.js.map +1 -0
- package/features/users/ExternalIdpUserSync/feature.d.ts +1 -0
- package/features/users/ExternalIdpUserSync/feature.js +10 -0
- package/features/users/ExternalIdpUserSync/feature.js.map +1 -0
- package/features/users/ExternalIdpUserSync/index.d.ts +1 -0
- package/features/users/ExternalIdpUserSync/index.js +3 -0
- package/features/users/ExternalIdpUserSync/index.js.map +1 -0
- package/features/users/GetIdentityProfile/GetIdentityProfileUseCase.d.ts +13 -0
- package/features/users/GetIdentityProfile/GetIdentityProfileUseCase.js +49 -0
- package/features/users/GetIdentityProfile/GetIdentityProfileUseCase.js.map +1 -0
- package/features/users/GetIdentityProfile/abstractions.d.ts +18 -0
- package/features/users/GetIdentityProfile/abstractions.js +14 -0
- package/features/users/GetIdentityProfile/abstractions.js.map +1 -0
- package/features/users/GetIdentityProfile/feature.d.ts +1 -0
- package/features/users/GetIdentityProfile/feature.js +10 -0
- package/features/users/GetIdentityProfile/feature.js.map +1 -0
- package/features/users/GetIdentityProfile/index.d.ts +1 -0
- package/features/users/GetIdentityProfile/index.js +3 -0
- package/features/users/GetIdentityProfile/index.js.map +1 -0
- package/features/users/GetIdentityProfile/types.d.ts +11 -0
- package/features/users/GetIdentityProfile/types.js +3 -0
- package/features/users/GetIdentityProfile/types.js.map +1 -0
- package/features/users/GetUser/GetUserUseCase.d.ts +14 -0
- package/features/users/GetUser/GetUserUseCase.js +33 -0
- package/features/users/GetUser/GetUserUseCase.js.map +1 -0
- package/features/users/GetUser/abstractions.d.ts +18 -0
- package/features/users/GetUser/abstractions.js +14 -0
- package/features/users/GetUser/abstractions.js.map +1 -0
- package/features/users/GetUser/feature.d.ts +1 -0
- package/features/users/GetUser/feature.js +10 -0
- package/features/users/GetUser/feature.js.map +1 -0
- package/features/users/GetUser/index.d.ts +1 -0
- package/features/users/GetUser/index.js +3 -0
- package/features/users/GetUser/index.js.map +1 -0
- package/features/users/ListUserTeams/ListUserTeamsUseCase.d.ts +15 -0
- package/features/users/ListUserTeams/ListUserTeamsUseCase.js +50 -0
- package/features/users/ListUserTeams/ListUserTeamsUseCase.js.map +1 -0
- package/features/users/ListUserTeams/abstractions.d.ts +15 -0
- package/features/users/ListUserTeams/abstractions.js +14 -0
- package/features/users/ListUserTeams/abstractions.js.map +1 -0
- package/features/users/ListUserTeams/feature.d.ts +1 -0
- package/features/users/ListUserTeams/feature.js +10 -0
- package/features/users/ListUserTeams/feature.js.map +1 -0
- package/features/users/ListUserTeams/index.d.ts +1 -0
- package/features/users/ListUserTeams/index.js +3 -0
- package/features/users/ListUserTeams/index.js.map +1 -0
- package/features/users/ListUsers/ListUsersUseCase.d.ts +14 -0
- package/features/users/ListUsers/ListUsersUseCase.js +33 -0
- package/features/users/ListUsers/ListUsersUseCase.js.map +1 -0
- package/features/users/ListUsers/abstractions.d.ts +18 -0
- package/features/users/ListUsers/abstractions.js +14 -0
- package/features/users/ListUsers/abstractions.js.map +1 -0
- package/features/users/ListUsers/feature.d.ts +1 -0
- package/features/users/ListUsers/feature.js +10 -0
- package/features/users/ListUsers/feature.js.map +1 -0
- package/features/users/ListUsers/index.d.ts +1 -0
- package/features/users/ListUsers/index.js +3 -0
- package/features/users/ListUsers/index.js.map +1 -0
- package/features/users/UpdateUser/UpdateUserUseCase.d.ts +16 -0
- package/features/users/UpdateUser/UpdateUserUseCase.js +86 -0
- package/features/users/UpdateUser/UpdateUserUseCase.js.map +1 -0
- package/features/users/UpdateUser/abstractions.d.ts +30 -0
- package/features/users/UpdateUser/abstractions.js +16 -0
- package/features/users/UpdateUser/abstractions.js.map +1 -0
- package/features/users/UpdateUser/events.d.ts +21 -0
- package/features/users/UpdateUser/events.js +20 -0
- package/features/users/UpdateUser/events.js.map +1 -0
- package/features/users/UpdateUser/feature.d.ts +1 -0
- package/features/users/UpdateUser/feature.js +10 -0
- package/features/users/UpdateUser/feature.js.map +1 -0
- package/features/users/UpdateUser/index.d.ts +2 -0
- package/features/users/UpdateUser/index.js +4 -0
- package/features/users/UpdateUser/index.js.map +1 -0
- package/features/users/UpdateUser/schema.d.ts +38 -0
- package/features/users/UpdateUser/schema.js +14 -0
- package/features/users/UpdateUser/schema.js.map +1 -0
- package/features/users/shared/AdminUsersRepository.d.ts +23 -0
- package/features/users/shared/AdminUsersRepository.js +129 -0
- package/features/users/shared/AdminUsersRepository.js.map +1 -0
- package/features/users/shared/abstractions.d.ts +24 -0
- package/features/users/shared/abstractions.js +12 -0
- package/features/users/shared/abstractions.js.map +1 -0
- package/features/users/shared/errors.d.ts +27 -0
- package/features/users/shared/errors.js +54 -0
- package/features/users/shared/errors.js.map +1 -0
- package/features/users/shared/loaders.d.ts +17 -0
- package/features/users/shared/loaders.js +73 -0
- package/features/users/shared/loaders.js.map +1 -0
- package/features/users/shared/storageAbstractions.d.ts +5 -0
- package/features/users/shared/storageAbstractions.js +5 -0
- package/features/users/shared/storageAbstractions.js.map +1 -0
- package/features/users/shared/types.d.ts +49 -0
- package/features/users/shared/types.js +3 -0
- package/features/users/shared/types.js.map +1 -0
- package/features/wcp/WcpContext/WcpContext.d.ts +32 -0
- package/features/wcp/WcpContext/WcpContext.js +133 -0
- package/features/wcp/WcpContext/WcpContext.js.map +1 -0
- package/features/wcp/WcpContext/abstractions.d.ts +19 -0
- package/features/wcp/WcpContext/abstractions.js +9 -0
- package/features/wcp/WcpContext/abstractions.js.map +1 -0
- package/features/wcp/WcpContext/feature.d.ts +2 -0
- package/features/wcp/WcpContext/feature.js +11 -0
- package/features/wcp/WcpContext/feature.js.map +1 -0
- package/features/wcp/WcpContext/index.d.ts +4 -0
- package/features/wcp/WcpContext/index.js +4 -0
- package/features/wcp/WcpContext/index.js.map +1 -0
- package/features/wcp/WcpContext/types.d.ts +17 -0
- package/features/wcp/WcpContext/types.js +3 -0
- package/features/wcp/WcpContext/types.js.map +1 -0
- package/features/wcp/WcpContext/utils.d.ts +13 -0
- package/features/wcp/WcpContext/utils.js +58 -0
- package/features/wcp/WcpContext/utils.js.map +1 -0
- package/features/wcp/WcpFeature.d.ts +2 -0
- package/features/wcp/WcpFeature.js +10 -0
- package/features/wcp/WcpFeature.js.map +1 -0
- package/graphql/security/NotAuthorizedResponse.d.ts +10 -0
- package/graphql/security/NotAuthorizedResponse.js +17 -0
- package/graphql/security/NotAuthorizedResponse.js.map +1 -0
- package/graphql/security/ProfileMapper.d.ts +16 -0
- package/graphql/security/ProfileMapper.js +14 -0
- package/graphql/security/ProfileMapper.js.map +1 -0
- package/graphql/security/apiKey.gql.d.ts +4 -0
- package/graphql/security/apiKey.gql.js +99 -0
- package/graphql/security/apiKey.gql.js.map +1 -0
- package/graphql/security/base.gql.d.ts +4 -0
- package/graphql/security/base.gql.js +48 -0
- package/graphql/security/base.gql.js.map +1 -0
- package/graphql/security/identity.gql.d.ts +4 -0
- package/graphql/security/identity.gql.js +163 -0
- package/graphql/security/identity.gql.js.map +1 -0
- package/graphql/security/index.d.ts +1 -0
- package/graphql/security/index.js +10 -0
- package/graphql/security/index.js.map +1 -0
- package/graphql/security/role.gql.d.ts +4 -0
- package/graphql/security/role.gql.js +114 -0
- package/graphql/security/role.gql.js.map +1 -0
- package/graphql/security/team.gql.d.ts +4 -0
- package/graphql/security/team.gql.js +127 -0
- package/graphql/security/team.gql.js.map +1 -0
- package/graphql/system/createSystemGraphQL.d.ts +2 -0
- package/graphql/system/createSystemGraphQL.js +57 -0
- package/graphql/system/createSystemGraphQL.js.map +1 -0
- package/graphql/users/user.gql.d.ts +3 -0
- package/graphql/users/user.gql.js +185 -0
- package/graphql/users/user.gql.js.map +1 -0
- package/graphql/wcp/graphql.d.ts +2 -0
- package/graphql/wcp/graphql.js +88 -0
- package/graphql/wcp/graphql.js.map +1 -0
- package/idp/JwksCache.d.ts +7 -0
- package/idp/JwksCache.js +32 -0
- package/idp/JwksCache.js.map +1 -0
- package/idp/JwtAuthenticator.d.ts +12 -0
- package/idp/JwtAuthenticator.js +58 -0
- package/idp/JwtAuthenticator.js.map +1 -0
- package/idp/OidcJwtIdentityProvider.d.ts +15 -0
- package/idp/OidcJwtIdentityProvider.js +90 -0
- package/idp/OidcJwtIdentityProvider.js.map +1 -0
- package/idp/abstractions.d.ts +62 -0
- package/idp/abstractions.js +13 -0
- package/idp/abstractions.js.map +1 -0
- package/idp/feature.d.ts +1 -0
- package/idp/feature.js +15 -0
- package/idp/feature.js.map +1 -0
- package/idp/index.d.ts +2 -0
- package/idp/index.js +3 -0
- package/idp/index.js.map +1 -0
- package/idp/types.d.ts +3 -0
- package/idp/types.js +3 -0
- package/idp/types.js.map +1 -0
- package/index.d.ts +1 -0
- package/index.js +3 -0
- package/index.js.map +1 -0
- package/legacy/security/LegacyContext.d.ts +36 -0
- package/legacy/security/LegacyContext.js +205 -0
- package/legacy/security/LegacyContext.js.map +1 -0
- package/legacy/security/createSecurityContext.d.ts +3 -0
- package/legacy/security/createSecurityContext.js +25 -0
- package/legacy/security/createSecurityContext.js.map +1 -0
- package/legacy/security/plugins/SecurityRolePlugin.d.ts +16 -0
- package/legacy/security/plugins/SecurityRolePlugin.js +33 -0
- package/legacy/security/plugins/SecurityRolePlugin.js.map +1 -0
- package/legacy/security/plugins/SecurityTeamPlugin.d.ts +16 -0
- package/legacy/security/plugins/SecurityTeamPlugin.js +33 -0
- package/legacy/security/plugins/SecurityTeamPlugin.js.map +1 -0
- package/legacy/security/plugins/apiKeyAuthentication.d.ts +7 -0
- package/legacy/security/plugins/apiKeyAuthentication.js +29 -0
- package/legacy/security/plugins/apiKeyAuthentication.js.map +1 -0
- package/legacy/security/plugins/apiKeyAuthorization.d.ts +6 -0
- package/legacy/security/plugins/apiKeyAuthorization.js +22 -0
- package/legacy/security/plugins/apiKeyAuthorization.js.map +1 -0
- package/legacy/security/plugins/authenticateUsingCookie.d.ts +5 -0
- package/legacy/security/plugins/authenticateUsingCookie.js +27 -0
- package/legacy/security/plugins/authenticateUsingCookie.js.map +1 -0
- package/legacy/security/plugins/authenticateUsingHttpHeader.d.ts +5 -0
- package/legacy/security/plugins/authenticateUsingHttpHeader.js +23 -0
- package/legacy/security/plugins/authenticateUsingHttpHeader.js.map +1 -0
- package/legacy/security/plugins/secureHeaders.d.ts +1 -0
- package/legacy/security/plugins/secureHeaders.js +23 -0
- package/legacy/security/plugins/secureHeaders.js.map +1 -0
- package/legacy/tenancy/LegacyContext.d.ts +15 -0
- package/legacy/tenancy/LegacyContext.js +64 -0
- package/legacy/tenancy/LegacyContext.js.map +1 -0
- package/legacy/tenancy/createTenancyContext.d.ts +3 -0
- package/legacy/tenancy/createTenancyContext.js +51 -0
- package/legacy/tenancy/createTenancyContext.js.map +1 -0
- package/legacy/users/LegacyContext.d.ts +13 -0
- package/legacy/users/LegacyContext.js +70 -0
- package/legacy/users/LegacyContext.js.map +1 -0
- package/legacy/users/createAdminUsersContext.d.ts +3 -0
- package/legacy/users/createAdminUsersContext.js +12 -0
- package/legacy/users/createAdminUsersContext.js.map +1 -0
- package/legacy/wcp/LegacyWcpContext.d.ts +28 -0
- package/legacy/wcp/LegacyWcpContext.js +68 -0
- package/legacy/wcp/LegacyWcpContext.js.map +1 -0
- package/legacy/wcp/context.d.ts +7 -0
- package/legacy/wcp/context.js +50 -0
- package/legacy/wcp/context.js.map +1 -0
- package/models/base/BaseModel.d.ts +20 -0
- package/models/base/BaseModel.js +64 -0
- package/models/base/BaseModel.js.map +1 -0
- package/models/base/ModelBuilder.d.ts +18 -0
- package/models/base/ModelBuilder.js +68 -0
- package/models/base/ModelBuilder.js.map +1 -0
- package/models/base/ModelFactory.d.ts +0 -0
- package/models/base/ModelFactory.js +3 -0
- package/models/base/ModelFactory.js.map +1 -0
- package/models/base/__tests__/ModelBuilder.test.d.ts +1 -0
- package/models/base/__tests__/ModelBuilder.test.js +468 -0
- package/models/base/__tests__/ModelBuilder.test.js.map +1 -0
- package/models/base/abstractions.d.ts +19 -0
- package/models/base/abstractions.js +3 -0
- package/models/base/abstractions.js.map +1 -0
- package/models/cms/FieldBuilder.d.ts +36 -0
- package/models/cms/FieldBuilder.js +132 -0
- package/models/cms/FieldBuilder.js.map +1 -0
- package/models/cms/FieldBuilderRegistry.d.ts +11 -0
- package/models/cms/FieldBuilderRegistry.js +18 -0
- package/models/cms/FieldBuilderRegistry.js.map +1 -0
- package/models/cms/FieldDefinitionsBuilder.d.ts +24 -0
- package/models/cms/FieldDefinitionsBuilder.js +63 -0
- package/models/cms/FieldDefinitionsBuilder.js.map +1 -0
- package/models/cms/PrivateCmsModelBuilder.d.ts +21 -0
- package/models/cms/PrivateCmsModelBuilder.js +103 -0
- package/models/cms/PrivateCmsModelBuilder.js.map +1 -0
- package/models/cms/PrivatePage/Page.fields.d.ts +8 -0
- package/models/cms/PrivatePage/Page.fields.js +9 -0
- package/models/cms/PrivatePage/Page.fields.js.map +1 -0
- package/models/cms/PrivatePage/PageModelBuilder.d.ts +9 -0
- package/models/cms/PrivatePage/PageModelBuilder.js +23 -0
- package/models/cms/PrivatePage/PageModelBuilder.js.map +1 -0
- package/models/cms/PrivatePage/PageModelFactory.d.ts +12 -0
- package/models/cms/PrivatePage/PageModelFactory.js +32 -0
- package/models/cms/PrivatePage/PageModelFactory.js.map +1 -0
- package/models/cms/PrivatePage/__tests__/PageModelFactory.test.d.ts +1 -0
- package/models/cms/PrivatePage/__tests__/PageModelFactory.test.js +251 -0
- package/models/cms/PrivatePage/__tests__/PageModelFactory.test.js.map +1 -0
- package/models/cms/PrivatePage/__tests__/PagePublishingDecorator.d.ts +21 -0
- package/models/cms/PrivatePage/__tests__/PagePublishingDecorator.js +43 -0
- package/models/cms/PrivatePage/__tests__/PagePublishingDecorator.js.map +1 -0
- package/models/cms/PrivatePage/__tests__/PageSeoDecorator.d.ts +21 -0
- package/models/cms/PrivatePage/__tests__/PageSeoDecorator.js +33 -0
- package/models/cms/PrivatePage/__tests__/PageSeoDecorator.js.map +1 -0
- package/models/cms/PrivatePage/abstractions.d.ts +19 -0
- package/models/cms/PrivatePage/abstractions.js +12 -0
- package/models/cms/PrivatePage/abstractions.js.map +1 -0
- package/models/cms/__tests__/PrivateCmsModelBuilder.test.d.ts +1 -0
- package/models/cms/__tests__/PrivateCmsModelBuilder.test.js +195 -0
- package/models/cms/__tests__/PrivateCmsModelBuilder.test.js.map +1 -0
- package/models/cms/abstractions.d.ts +38 -0
- package/models/cms/abstractions.js +23 -0
- package/models/cms/abstractions.js.map +1 -0
- package/models/cms/fieldsBuilder.md +386 -0
- package/models/cms/types.d.ts +45 -0
- package/models/cms/types.js +3 -0
- package/models/cms/types.js.map +1 -0
- package/models/simple/Page/PageModelBuilder.d.ts +10 -0
- package/models/simple/Page/PageModelBuilder.js +20 -0
- package/models/simple/Page/PageModelBuilder.js.map +1 -0
- package/models/simple/Page/PageModelFactory.d.ts +9 -0
- package/models/simple/Page/PageModelFactory.js +22 -0
- package/models/simple/Page/PageModelFactory.js.map +1 -0
- package/models/simple/Page/__tests__/PageModelBuilderDecorator.d.ts +20 -0
- package/models/simple/Page/__tests__/PageModelBuilderDecorator.js +26 -0
- package/models/simple/Page/__tests__/PageModelBuilderDecorator.js.map +1 -0
- package/models/simple/Page/__tests__/PageModelBuilderDecorator2.d.ts +15 -0
- package/models/simple/Page/__tests__/PageModelBuilderDecorator2.js +22 -0
- package/models/simple/Page/__tests__/PageModelBuilderDecorator2.js.map +1 -0
- package/models/simple/Page/__tests__/PageModelFactory.test.d.ts +1 -0
- package/models/simple/Page/__tests__/PageModelFactory.test.js +38 -0
- package/models/simple/Page/__tests__/PageModelFactory.test.js.map +1 -0
- package/models/simple/Page/abstractions.d.ts +35 -0
- package/models/simple/Page/abstractions.js +12 -0
- package/models/simple/Page/abstractions.js.map +1 -0
- package/package.json +98 -0
- package/types/core.d.ts +13 -0
- package/types/core.js +3 -0
- package/types/core.js.map +1 -0
- package/types/security.d.ts +203 -0
- package/types/security.js +3 -0
- package/types/security.js.map +1 -0
- package/types/tenancy.d.ts +49 -0
- package/types/tenancy.js +3 -0
- package/types/tenancy.js.map +1 -0
- package/types/users.d.ts +85 -0
- package/types/users.js +3 -0
- 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,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
|
+
}
|
package/idp/JwksCache.js
ADDED
|
@@ -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":[]}
|