@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,20 @@
|
|
|
1
|
+
import DataLoader from "dataloader";
|
|
2
|
+
export class TenantCache {
|
|
3
|
+
constructor(batchLoadFn) {
|
|
4
|
+
this.loader = new DataLoader(batchLoadFn);
|
|
5
|
+
}
|
|
6
|
+
async get(id) {
|
|
7
|
+
return await this.loader.load(id);
|
|
8
|
+
}
|
|
9
|
+
async getMany(ids) {
|
|
10
|
+
return await this.loader.loadMany(ids);
|
|
11
|
+
}
|
|
12
|
+
clear(id) {
|
|
13
|
+
this.loader.clear(id);
|
|
14
|
+
}
|
|
15
|
+
prime(id, tenant) {
|
|
16
|
+
this.loader.prime(id, tenant);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
//# sourceMappingURL=TenantCache.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["DataLoader","TenantCache","constructor","batchLoadFn","loader","get","id","load","getMany","ids","loadMany","clear","prime","tenant"],"sources":["TenantCache.ts"],"sourcesContent":["import DataLoader from \"dataloader\";\nimport type { TenantCache as CacheAbstraction } from \"./abstractions.js\";\nimport type { Tenant } from \"~/types/tenancy.js\";\n\nexport interface TenantCacheBatchLoader {\n (ids: readonly string[]): Promise<Tenant[]>;\n}\n\nexport class TenantCache implements CacheAbstraction.Interface {\n private loader: DataLoader<string, Tenant>;\n\n constructor(batchLoadFn: TenantCacheBatchLoader) {\n this.loader = new DataLoader<string, Tenant>(batchLoadFn);\n }\n\n async get(id: string): Promise<Tenant> {\n return (await this.loader.load(id)) as Tenant;\n }\n\n async getMany(ids: readonly string[]): Promise<Tenant[]> {\n return (await this.loader.loadMany(ids)) as Tenant[];\n }\n\n clear(id: string): void {\n this.loader.clear(id);\n }\n\n prime(id: string, tenant: Tenant | undefined): void {\n this.loader.prime(id, tenant as Tenant);\n }\n}\n"],"mappings":"AAAA,OAAOA,UAAU,MAAM,YAAY;AAQnC,OAAO,MAAMC,WAAW,CAAuC;EAG3DC,WAAWA,CAACC,WAAmC,EAAE;IAC7C,IAAI,CAACC,MAAM,GAAG,IAAIJ,UAAU,CAAiBG,WAAW,CAAC;EAC7D;EAEA,MAAME,GAAGA,CAACC,EAAU,EAAmB;IACnC,OAAQ,MAAM,IAAI,CAACF,MAAM,CAACG,IAAI,CAACD,EAAE,CAAC;EACtC;EAEA,MAAME,OAAOA,CAACC,GAAsB,EAAqB;IACrD,OAAQ,MAAM,IAAI,CAACL,MAAM,CAACM,QAAQ,CAACD,GAAG,CAAC;EAC3C;EAEAE,KAAKA,CAACL,EAAU,EAAQ;IACpB,IAAI,CAACF,MAAM,CAACO,KAAK,CAACL,EAAE,CAAC;EACzB;EAEAM,KAAKA,CAACN,EAAU,EAAEO,MAA0B,EAAQ;IAChD,IAAI,CAACT,MAAM,CAACQ,KAAK,CAACN,EAAE,EAAEO,MAAgB,CAAC;EAC3C;AACJ","ignoreList":[]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Tenant } from "../../../types/tenancy.js";
|
|
2
|
+
export interface ITenantCache {
|
|
3
|
+
get(id: string): Promise<Tenant>;
|
|
4
|
+
getMany(ids: readonly string[]): Promise<Tenant[]>;
|
|
5
|
+
clear(id: string): void;
|
|
6
|
+
prime(id: string, tenant: Tenant | undefined): void;
|
|
7
|
+
}
|
|
8
|
+
export declare const TenantCache: import("@webiny/di").Abstraction<ITenantCache>;
|
|
9
|
+
export declare namespace TenantCache {
|
|
10
|
+
type Interface = ITenantCache;
|
|
11
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createAbstraction","TenantCache"],"sources":["abstractions.ts"],"sourcesContent":["import { createAbstraction } from \"@webiny/feature/api\";\nimport type { Tenant } from \"~/types/tenancy.js\";\n\nexport interface ITenantCache {\n get(id: string): Promise<Tenant>;\n getMany(ids: readonly string[]): Promise<Tenant[]>;\n clear(id: string): void;\n prime(id: string, tenant: Tenant | undefined): void;\n}\n\nexport const TenantCache = createAbstraction<ITenantCache>(\"TenantCache\");\n\nexport namespace TenantCache {\n export type Interface = ITenantCache;\n}\n"],"mappings":"AAAA,SAASA,iBAAiB,QAAQ,qBAAqB;AAUvD,OAAO,MAAMC,WAAW,GAAGD,iBAAiB,CAAe,aAAa,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { TenancyStorageOperations as ITenancyStorageOperations } from "../../../types/tenancy.js";
|
|
2
|
+
/**
|
|
3
|
+
* Abstraction for Tenancy Storage Operations
|
|
4
|
+
* This allows the legacy storage operations to be injected through DI
|
|
5
|
+
*/
|
|
6
|
+
export declare const TenancyStorageOperations: import("@webiny/di").Abstraction<ITenancyStorageOperations>;
|
|
7
|
+
export declare namespace TenancyStorageOperations {
|
|
8
|
+
type Interface = ITenancyStorageOperations;
|
|
9
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { createAbstraction } from "@webiny/feature/api";
|
|
2
|
+
/**
|
|
3
|
+
* Abstraction for Tenancy Storage Operations
|
|
4
|
+
* This allows the legacy storage operations to be injected through DI
|
|
5
|
+
*/
|
|
6
|
+
export const TenancyStorageOperations = createAbstraction("TenancyStorageOperations");
|
|
7
|
+
|
|
8
|
+
//# sourceMappingURL=storageOperations.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createAbstraction","TenancyStorageOperations"],"sources":["storageOperations.ts"],"sourcesContent":["import { createAbstraction } from \"@webiny/feature/api\";\nimport type { TenancyStorageOperations as ITenancyStorageOperations } from \"~/types/tenancy.js\";\n\n/**\n * Abstraction for Tenancy Storage Operations\n * This allows the legacy storage operations to be injected through DI\n */\nexport const TenancyStorageOperations = createAbstraction<ITenancyStorageOperations>(\n \"TenancyStorageOperations\"\n);\n\nexport namespace TenancyStorageOperations {\n export type Interface = ITenancyStorageOperations;\n}\n"],"mappings":"AAAA,SAASA,iBAAiB,QAAQ,qBAAqB;AAGvD;AACA;AACA;AACA;AACA,OAAO,MAAMC,wBAAwB,GAAGD,iBAAiB,CACrD,0BACJ,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const AdminUsersFeature: import("@webiny/feature/api/createFeature.js").FeatureDefinition<import("../../types/users.js").AdminUsersStorageOperations>;
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { createFeature } from "@webiny/feature/api";
|
|
2
|
+
import { AdminUsersRepository } from "./shared/AdminUsersRepository.js";
|
|
3
|
+
import { GetUserFeature } from "./GetUser/feature.js";
|
|
4
|
+
import { GetIdentityProfileFeature } from "./GetIdentityProfile/feature.js";
|
|
5
|
+
import { ListUsersFeature } from "./ListUsers/feature.js";
|
|
6
|
+
import { CreateUserFeature } from "./CreateUser/feature.js";
|
|
7
|
+
import { UpdateUserFeature } from "./UpdateUser/feature.js";
|
|
8
|
+
import { DeleteUserFeature } from "./DeleteUser/feature.js";
|
|
9
|
+
import { ListUserTeamsFeature } from "./ListUserTeams/feature.js";
|
|
10
|
+
import { AdminUsersStorageOperations } from "./shared/storageAbstractions.js";
|
|
11
|
+
import { ExternalIdpUserSyncFeature } from "./ExternalIdpUserSync/index.js";
|
|
12
|
+
export const AdminUsersFeature = createFeature({
|
|
13
|
+
name: "AdminUsers",
|
|
14
|
+
register(container, storageOperations) {
|
|
15
|
+
// Register repository in singleton scope
|
|
16
|
+
container.register(AdminUsersRepository).inSingletonScope();
|
|
17
|
+
|
|
18
|
+
// Register all use cases
|
|
19
|
+
GetUserFeature.register(container);
|
|
20
|
+
GetIdentityProfileFeature.register(container);
|
|
21
|
+
ListUsersFeature.register(container);
|
|
22
|
+
ListUserTeamsFeature.register(container);
|
|
23
|
+
CreateUserFeature.register(container);
|
|
24
|
+
UpdateUserFeature.register(container);
|
|
25
|
+
DeleteUserFeature.register(container);
|
|
26
|
+
ExternalIdpUserSyncFeature.register(container);
|
|
27
|
+
|
|
28
|
+
// Legacy storage ops
|
|
29
|
+
container.registerInstance(AdminUsersStorageOperations, storageOperations);
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
//# sourceMappingURL=AdminUsersFeature.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createFeature","AdminUsersRepository","GetUserFeature","GetIdentityProfileFeature","ListUsersFeature","CreateUserFeature","UpdateUserFeature","DeleteUserFeature","ListUserTeamsFeature","AdminUsersStorageOperations","ExternalIdpUserSyncFeature","AdminUsersFeature","name","register","container","storageOperations","inSingletonScope","registerInstance"],"sources":["AdminUsersFeature.ts"],"sourcesContent":["import { createFeature } from \"@webiny/feature/api\";\nimport { AdminUsersRepository } from \"./shared/AdminUsersRepository.js\";\nimport { GetUserFeature } from \"./GetUser/feature.js\";\nimport { GetIdentityProfileFeature } from \"./GetIdentityProfile/feature.js\";\nimport { ListUsersFeature } from \"./ListUsers/feature.js\";\nimport { CreateUserFeature } from \"./CreateUser/feature.js\";\nimport { UpdateUserFeature } from \"./UpdateUser/feature.js\";\nimport { DeleteUserFeature } from \"./DeleteUser/feature.js\";\nimport { ListUserTeamsFeature } from \"./ListUserTeams/feature.js\";\nimport { AdminUsersStorageOperations } from \"./shared/storageAbstractions.js\";\nimport { ExternalIdpUserSyncFeature } from \"./ExternalIdpUserSync/index.js\";\n\nexport const AdminUsersFeature = createFeature({\n name: \"AdminUsers\",\n register(container, storageOperations: AdminUsersStorageOperations.Interface) {\n // Register repository in singleton scope\n container.register(AdminUsersRepository).inSingletonScope();\n\n // Register all use cases\n GetUserFeature.register(container);\n GetIdentityProfileFeature.register(container);\n ListUsersFeature.register(container);\n ListUserTeamsFeature.register(container);\n CreateUserFeature.register(container);\n UpdateUserFeature.register(container);\n DeleteUserFeature.register(container);\n ExternalIdpUserSyncFeature.register(container);\n\n // Legacy storage ops\n container.registerInstance(AdminUsersStorageOperations, storageOperations);\n }\n});\n"],"mappings":"AAAA,SAASA,aAAa,QAAQ,qBAAqB;AACnD,SAASC,oBAAoB;AAC7B,SAASC,cAAc;AACvB,SAASC,yBAAyB;AAClC,SAASC,gBAAgB;AACzB,SAASC,iBAAiB;AAC1B,SAASC,iBAAiB;AAC1B,SAASC,iBAAiB;AAC1B,SAASC,oBAAoB;AAC7B,SAASC,2BAA2B;AACpC,SAASC,0BAA0B;AAEnC,OAAO,MAAMC,iBAAiB,GAAGX,aAAa,CAAC;EAC3CY,IAAI,EAAE,YAAY;EAClBC,QAAQA,CAACC,SAAS,EAAEC,iBAAwD,EAAE;IAC1E;IACAD,SAAS,CAACD,QAAQ,CAACZ,oBAAoB,CAAC,CAACe,gBAAgB,CAAC,CAAC;;IAE3D;IACAd,cAAc,CAACW,QAAQ,CAACC,SAAS,CAAC;IAClCX,yBAAyB,CAACU,QAAQ,CAACC,SAAS,CAAC;IAC7CV,gBAAgB,CAACS,QAAQ,CAACC,SAAS,CAAC;IACpCN,oBAAoB,CAACK,QAAQ,CAACC,SAAS,CAAC;IACxCT,iBAAiB,CAACQ,QAAQ,CAACC,SAAS,CAAC;IACrCR,iBAAiB,CAACO,QAAQ,CAACC,SAAS,CAAC;IACrCP,iBAAiB,CAACM,QAAQ,CAACC,SAAS,CAAC;IACrCJ,0BAA0B,CAACG,QAAQ,CAACC,SAAS,CAAC;;IAE9C;IACAA,SAAS,CAACG,gBAAgB,CAACR,2BAA2B,EAAEM,iBAAiB,CAAC;EAC9E;AACJ,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Result } from "@webiny/feature/api";
|
|
2
|
+
import { TenantContext } from "../../../features/tenancy/TenantContext/index.js";
|
|
3
|
+
import { IdentityContext } from "../../../features/security/IdentityContext/index.js";
|
|
4
|
+
import { EventPublisher } from "../../../features/eventPublisher/index.js";
|
|
5
|
+
import { CreateUserUseCase as UseCaseAbstraction } from "./abstractions.js";
|
|
6
|
+
import { AdminUsersRepository } from "../../../features/users/shared/abstractions.js";
|
|
7
|
+
import type { AdminUser } from "../../../features/users/shared/types.js";
|
|
8
|
+
import type { CreateUserInput } from "../../../features/users/shared/types.js";
|
|
9
|
+
declare class CreateUserUseCaseImpl implements UseCaseAbstraction.Interface {
|
|
10
|
+
private tenantContext;
|
|
11
|
+
private identityContext;
|
|
12
|
+
private eventPublisher;
|
|
13
|
+
private repository;
|
|
14
|
+
constructor(tenantContext: TenantContext.Interface, identityContext: IdentityContext.Interface, eventPublisher: EventPublisher.Interface, repository: AdminUsersRepository.Interface);
|
|
15
|
+
execute(input: CreateUserInput): Promise<Result<AdminUser, UseCaseAbstraction.Error>>;
|
|
16
|
+
private getDisplayName;
|
|
17
|
+
}
|
|
18
|
+
export declare const CreateUserUseCase: import("@webiny/di").Implementation<typeof CreateUserUseCaseImpl>;
|
|
19
|
+
export {};
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
import { mdbid } from "@webiny/utils";
|
|
2
|
+
import { createImplementation } from "@webiny/feature/api";
|
|
3
|
+
import { Result } from "@webiny/feature/api";
|
|
4
|
+
import { TenantContext } from "../../tenancy/TenantContext/index.js";
|
|
5
|
+
import { IdentityContext } from "../../security/IdentityContext/index.js";
|
|
6
|
+
import { EventPublisher } from "../../eventPublisher/index.js";
|
|
7
|
+
import { CreateUserUseCase as UseCaseAbstraction } from "./abstractions.js";
|
|
8
|
+
import { AdminUsersRepository } from "../shared/abstractions.js";
|
|
9
|
+
import { createUserValidation } from "./schema.js";
|
|
10
|
+
import { NotAuthorizedError, EmailTakenError, UserValidationError } from "../shared/errors.js";
|
|
11
|
+
import { UserBeforeCreateEvent, UserAfterCreateEvent } from "./events.js";
|
|
12
|
+
class CreateUserUseCaseImpl {
|
|
13
|
+
constructor(tenantContext, identityContext, eventPublisher, repository) {
|
|
14
|
+
this.tenantContext = tenantContext;
|
|
15
|
+
this.identityContext = identityContext;
|
|
16
|
+
this.eventPublisher = eventPublisher;
|
|
17
|
+
this.repository = repository;
|
|
18
|
+
}
|
|
19
|
+
async execute(input) {
|
|
20
|
+
// 1. Check permission
|
|
21
|
+
const permission = await this.identityContext.getPermission("adminUsers.user");
|
|
22
|
+
if (!permission) {
|
|
23
|
+
return Result.fail(new NotAuthorizedError());
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
// 2. Validate input
|
|
27
|
+
const validation = createUserValidation.safeParse(input);
|
|
28
|
+
if (!validation.success) {
|
|
29
|
+
return Result.fail(new UserValidationError(validation.error.errors[0].message));
|
|
30
|
+
}
|
|
31
|
+
const data = validation.data;
|
|
32
|
+
|
|
33
|
+
// 3. Check email uniqueness
|
|
34
|
+
const existingUserResult = await this.repository.get({
|
|
35
|
+
email: data.email
|
|
36
|
+
});
|
|
37
|
+
if (existingUserResult.isOk()) {
|
|
38
|
+
// This means the email is taken!
|
|
39
|
+
return Result.fail(new EmailTakenError(data.email));
|
|
40
|
+
}
|
|
41
|
+
if (existingUserResult.error.code !== "AdminUser/NotFound") {
|
|
42
|
+
return Result.fail(existingUserResult.error);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
// 4. Generate ID if not provided
|
|
46
|
+
const id = data.id || mdbid();
|
|
47
|
+
|
|
48
|
+
// 5. Generate display name
|
|
49
|
+
const displayName = this.getDisplayName(data);
|
|
50
|
+
|
|
51
|
+
// 6. Get tenant and identity
|
|
52
|
+
const tenant = this.tenantContext.getTenant().id;
|
|
53
|
+
const identity = this.identityContext.getIdentity();
|
|
54
|
+
let createdBy = null;
|
|
55
|
+
if (identity) {
|
|
56
|
+
createdBy = {
|
|
57
|
+
id: identity.id,
|
|
58
|
+
displayName: identity.displayName,
|
|
59
|
+
type: identity.type
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
// 7. Create user entity
|
|
64
|
+
const user = {
|
|
65
|
+
...data,
|
|
66
|
+
id,
|
|
67
|
+
email: data.email,
|
|
68
|
+
displayName,
|
|
69
|
+
createdOn: new Date().toISOString(),
|
|
70
|
+
createdBy,
|
|
71
|
+
tenant
|
|
72
|
+
};
|
|
73
|
+
|
|
74
|
+
// 8. Publish before event
|
|
75
|
+
await this.eventPublisher.publish(new UserBeforeCreateEvent({
|
|
76
|
+
user,
|
|
77
|
+
input: data
|
|
78
|
+
}));
|
|
79
|
+
|
|
80
|
+
// 10. Create user via repository
|
|
81
|
+
const result = await this.repository.create(user);
|
|
82
|
+
if (result.isFail()) {
|
|
83
|
+
return Result.fail(result.error);
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
// 11. Publish after event
|
|
87
|
+
await this.eventPublisher.publish(new UserAfterCreateEvent({
|
|
88
|
+
user: result.value,
|
|
89
|
+
input: data
|
|
90
|
+
}));
|
|
91
|
+
return Result.ok(result.value);
|
|
92
|
+
}
|
|
93
|
+
getDisplayName(data) {
|
|
94
|
+
// If display name is not set, try to get it from the first name and last name.
|
|
95
|
+
// If first name and last name are not set, use the e-mail address.
|
|
96
|
+
if (data.displayName) {
|
|
97
|
+
return data.displayName;
|
|
98
|
+
}
|
|
99
|
+
if (data.firstName || data.lastName) {
|
|
100
|
+
return `${data.firstName || ""} ${data.lastName || ""}`.trim();
|
|
101
|
+
}
|
|
102
|
+
if (data.email) {
|
|
103
|
+
return data.email;
|
|
104
|
+
}
|
|
105
|
+
return "Missing display name";
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
export const CreateUserUseCase = createImplementation({
|
|
109
|
+
abstraction: UseCaseAbstraction,
|
|
110
|
+
implementation: CreateUserUseCaseImpl,
|
|
111
|
+
dependencies: [TenantContext, IdentityContext, EventPublisher, AdminUsersRepository]
|
|
112
|
+
});
|
|
113
|
+
|
|
114
|
+
//# sourceMappingURL=CreateUserUseCase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["mdbid","createImplementation","Result","TenantContext","IdentityContext","EventPublisher","CreateUserUseCase","UseCaseAbstraction","AdminUsersRepository","createUserValidation","NotAuthorizedError","EmailTakenError","UserValidationError","UserBeforeCreateEvent","UserAfterCreateEvent","CreateUserUseCaseImpl","constructor","tenantContext","identityContext","eventPublisher","repository","execute","input","permission","getPermission","fail","validation","safeParse","success","error","errors","message","data","existingUserResult","get","email","isOk","code","id","displayName","getDisplayName","tenant","getTenant","identity","getIdentity","createdBy","type","user","createdOn","Date","toISOString","publish","result","create","isFail","value","ok","firstName","lastName","trim","abstraction","implementation","dependencies"],"sources":["CreateUserUseCase.ts"],"sourcesContent":["import { mdbid } from \"@webiny/utils\";\nimport { createImplementation } from \"@webiny/feature/api\";\nimport { Result } from \"@webiny/feature/api\";\nimport { TenantContext } from \"~/features/tenancy/TenantContext/index.js\";\nimport { IdentityContext } from \"~/features/security/IdentityContext/index.js\";\nimport { EventPublisher } from \"~/features/eventPublisher/index.js\";\nimport { CreateUserUseCase as UseCaseAbstraction } from \"./abstractions.js\";\nimport { AdminUsersRepository } from \"~/features/users/shared/abstractions.js\";\nimport { createUserValidation } from \"./schema.js\";\nimport {\n NotAuthorizedError,\n EmailTakenError,\n UserValidationError\n} from \"~/features/users/shared/errors.js\";\nimport { UserBeforeCreateEvent, UserAfterCreateEvent } from \"./events.js\";\nimport type { AdminUser } from \"~/features/users/shared/types.js\";\nimport type { CreateUserInput } from \"~/features/users/shared/types.js\";\nimport type { CreatedBy } from \"~/types/users.js\";\n\nclass CreateUserUseCaseImpl implements UseCaseAbstraction.Interface {\n constructor(\n private tenantContext: TenantContext.Interface,\n private identityContext: IdentityContext.Interface,\n private eventPublisher: EventPublisher.Interface,\n private repository: AdminUsersRepository.Interface\n ) {}\n\n async execute(input: CreateUserInput): Promise<Result<AdminUser, UseCaseAbstraction.Error>> {\n // 1. Check permission\n const permission = await this.identityContext.getPermission(\"adminUsers.user\");\n if (!permission) {\n return Result.fail(new NotAuthorizedError());\n }\n\n // 2. Validate input\n const validation = createUserValidation.safeParse(input);\n if (!validation.success) {\n return Result.fail(new UserValidationError(validation.error.errors[0].message));\n }\n\n const data = validation.data;\n\n // 3. Check email uniqueness\n const existingUserResult = await this.repository.get({ email: data.email });\n if (existingUserResult.isOk()) {\n // This means the email is taken!\n return Result.fail(new EmailTakenError(data.email));\n }\n\n if (existingUserResult.error.code !== \"AdminUser/NotFound\") {\n return Result.fail(existingUserResult.error);\n }\n\n // 4. Generate ID if not provided\n const id = data.id || mdbid();\n\n // 5. Generate display name\n const displayName = this.getDisplayName(data);\n\n // 6. Get tenant and identity\n const tenant = this.tenantContext.getTenant().id;\n const identity = this.identityContext.getIdentity();\n\n let createdBy: CreatedBy | null = null;\n if (identity) {\n createdBy = {\n id: identity.id,\n displayName: identity.displayName,\n type: identity.type\n };\n }\n\n // 7. Create user entity\n const user: AdminUser = {\n ...data,\n id,\n email: data.email,\n displayName,\n createdOn: new Date().toISOString(),\n createdBy,\n tenant\n };\n\n // 8. Publish before event\n await this.eventPublisher.publish(new UserBeforeCreateEvent({ user, input: data }));\n\n // 10. Create user via repository\n const result = await this.repository.create(user);\n if (result.isFail()) {\n return Result.fail(result.error);\n }\n\n // 11. Publish after event\n await this.eventPublisher.publish(\n new UserAfterCreateEvent({ user: result.value, input: data })\n );\n\n return Result.ok(result.value);\n }\n\n private getDisplayName(data: CreateUserInput): string {\n // If display name is not set, try to get it from the first name and last name.\n // If first name and last name are not set, use the e-mail address.\n if (data.displayName) {\n return data.displayName;\n }\n\n if (data.firstName || data.lastName) {\n return `${data.firstName || \"\"} ${data.lastName || \"\"}`.trim();\n }\n\n if (data.email) {\n return data.email;\n }\n\n return \"Missing display name\";\n }\n}\n\nexport const CreateUserUseCase = createImplementation({\n abstraction: UseCaseAbstraction,\n implementation: CreateUserUseCaseImpl,\n dependencies: [TenantContext, IdentityContext, EventPublisher, AdminUsersRepository]\n});\n"],"mappings":"AAAA,SAASA,KAAK,QAAQ,eAAe;AACrC,SAASC,oBAAoB,QAAQ,qBAAqB;AAC1D,SAASC,MAAM,QAAQ,qBAAqB;AAC5C,SAASC,aAAa;AACtB,SAASC,eAAe;AACxB,SAASC,cAAc;AACvB,SAASC,iBAAiB,IAAIC,kBAAkB;AAChD,SAASC,oBAAoB;AAC7B,SAASC,oBAAoB;AAC7B,SACIC,kBAAkB,EAClBC,eAAe,EACfC,mBAAmB;AAEvB,SAASC,qBAAqB,EAAEC,oBAAoB;AAKpD,MAAMC,qBAAqB,CAAyC;EAChEC,WAAWA,CACCC,aAAsC,EACtCC,eAA0C,EAC1CC,cAAwC,EACxCC,UAA0C,EACpD;IAAA,KAJUH,aAAsC,GAAtCA,aAAsC;IAAA,KACtCC,eAA0C,GAA1CA,eAA0C;IAAA,KAC1CC,cAAwC,GAAxCA,cAAwC;IAAA,KACxCC,UAA0C,GAA1CA,UAA0C;EACnD;EAEH,MAAMC,OAAOA,CAACC,KAAsB,EAAwD;IACxF;IACA,MAAMC,UAAU,GAAG,MAAM,IAAI,CAACL,eAAe,CAACM,aAAa,CAAC,iBAAiB,CAAC;IAC9E,IAAI,CAACD,UAAU,EAAE;MACb,OAAOrB,MAAM,CAACuB,IAAI,CAAC,IAAIf,kBAAkB,CAAC,CAAC,CAAC;IAChD;;IAEA;IACA,MAAMgB,UAAU,GAAGjB,oBAAoB,CAACkB,SAAS,CAACL,KAAK,CAAC;IACxD,IAAI,CAACI,UAAU,CAACE,OAAO,EAAE;MACrB,OAAO1B,MAAM,CAACuB,IAAI,CAAC,IAAIb,mBAAmB,CAACc,UAAU,CAACG,KAAK,CAACC,MAAM,CAAC,CAAC,CAAC,CAACC,OAAO,CAAC,CAAC;IACnF;IAEA,MAAMC,IAAI,GAAGN,UAAU,CAACM,IAAI;;IAE5B;IACA,MAAMC,kBAAkB,GAAG,MAAM,IAAI,CAACb,UAAU,CAACc,GAAG,CAAC;MAAEC,KAAK,EAAEH,IAAI,CAACG;IAAM,CAAC,CAAC;IAC3E,IAAIF,kBAAkB,CAACG,IAAI,CAAC,CAAC,EAAE;MAC3B;MACA,OAAOlC,MAAM,CAACuB,IAAI,CAAC,IAAId,eAAe,CAACqB,IAAI,CAACG,KAAK,CAAC,CAAC;IACvD;IAEA,IAAIF,kBAAkB,CAACJ,KAAK,CAACQ,IAAI,KAAK,oBAAoB,EAAE;MACxD,OAAOnC,MAAM,CAACuB,IAAI,CAACQ,kBAAkB,CAACJ,KAAK,CAAC;IAChD;;IAEA;IACA,MAAMS,EAAE,GAAGN,IAAI,CAACM,EAAE,IAAItC,KAAK,CAAC,CAAC;;IAE7B;IACA,MAAMuC,WAAW,GAAG,IAAI,CAACC,cAAc,CAACR,IAAI,CAAC;;IAE7C;IACA,MAAMS,MAAM,GAAG,IAAI,CAACxB,aAAa,CAACyB,SAAS,CAAC,CAAC,CAACJ,EAAE;IAChD,MAAMK,QAAQ,GAAG,IAAI,CAACzB,eAAe,CAAC0B,WAAW,CAAC,CAAC;IAEnD,IAAIC,SAA2B,GAAG,IAAI;IACtC,IAAIF,QAAQ,EAAE;MACVE,SAAS,GAAG;QACRP,EAAE,EAAEK,QAAQ,CAACL,EAAE;QACfC,WAAW,EAAEI,QAAQ,CAACJ,WAAW;QACjCO,IAAI,EAAEH,QAAQ,CAACG;MACnB,CAAC;IACL;;IAEA;IACA,MAAMC,IAAe,GAAG;MACpB,GAAGf,IAAI;MACPM,EAAE;MACFH,KAAK,EAAEH,IAAI,CAACG,KAAK;MACjBI,WAAW;MACXS,SAAS,EAAE,IAAIC,IAAI,CAAC,CAAC,CAACC,WAAW,CAAC,CAAC;MACnCL,SAAS;MACTJ;IACJ,CAAC;;IAED;IACA,MAAM,IAAI,CAACtB,cAAc,CAACgC,OAAO,CAAC,IAAItC,qBAAqB,CAAC;MAAEkC,IAAI;MAAEzB,KAAK,EAAEU;IAAK,CAAC,CAAC,CAAC;;IAEnF;IACA,MAAMoB,MAAM,GAAG,MAAM,IAAI,CAAChC,UAAU,CAACiC,MAAM,CAACN,IAAI,CAAC;IACjD,IAAIK,MAAM,CAACE,MAAM,CAAC,CAAC,EAAE;MACjB,OAAOpD,MAAM,CAACuB,IAAI,CAAC2B,MAAM,CAACvB,KAAK,CAAC;IACpC;;IAEA;IACA,MAAM,IAAI,CAACV,cAAc,CAACgC,OAAO,CAC7B,IAAIrC,oBAAoB,CAAC;MAAEiC,IAAI,EAAEK,MAAM,CAACG,KAAK;MAAEjC,KAAK,EAAEU;IAAK,CAAC,CAChE,CAAC;IAED,OAAO9B,MAAM,CAACsD,EAAE,CAACJ,MAAM,CAACG,KAAK,CAAC;EAClC;EAEQf,cAAcA,CAACR,IAAqB,EAAU;IAClD;IACA;IACA,IAAIA,IAAI,CAACO,WAAW,EAAE;MAClB,OAAOP,IAAI,CAACO,WAAW;IAC3B;IAEA,IAAIP,IAAI,CAACyB,SAAS,IAAIzB,IAAI,CAAC0B,QAAQ,EAAE;MACjC,OAAO,GAAG1B,IAAI,CAACyB,SAAS,IAAI,EAAE,IAAIzB,IAAI,CAAC0B,QAAQ,IAAI,EAAE,EAAE,CAACC,IAAI,CAAC,CAAC;IAClE;IAEA,IAAI3B,IAAI,CAACG,KAAK,EAAE;MACZ,OAAOH,IAAI,CAACG,KAAK;IACrB;IAEA,OAAO,sBAAsB;EACjC;AACJ;AAEA,OAAO,MAAM7B,iBAAiB,GAAGL,oBAAoB,CAAC;EAClD2D,WAAW,EAAErD,kBAAkB;EAC/BsD,cAAc,EAAE9C,qBAAqB;EACrC+C,YAAY,EAAE,CAAC3D,aAAa,EAAEC,eAAe,EAAEC,cAAc,EAAEG,oBAAoB;AACvF,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Result } from "@webiny/feature/api";
|
|
2
|
+
import type { AdminUser } from "../../../features/users/shared/types.js";
|
|
3
|
+
import type { CreateUserInput } from "../../../features/users/shared/types.js";
|
|
4
|
+
import { AdminUsersRepository } from "../../../features/users/shared/abstractions.js";
|
|
5
|
+
import { NotAuthorizedError, EmailTakenError, UserValidationError } from "../../../features/users/shared/errors.js";
|
|
6
|
+
export interface ICreateUserErrors {
|
|
7
|
+
notAuthorized: NotAuthorizedError;
|
|
8
|
+
userExists: EmailTakenError;
|
|
9
|
+
validation: UserValidationError;
|
|
10
|
+
}
|
|
11
|
+
type CreateUserError = ICreateUserErrors[keyof ICreateUserErrors] | AdminUsersRepository.Error;
|
|
12
|
+
export interface ICreateUser {
|
|
13
|
+
execute(input: CreateUserInput): Promise<Result<AdminUser, CreateUserError>>;
|
|
14
|
+
}
|
|
15
|
+
export declare const CreateUserUseCase: import("@webiny/di").Abstraction<ICreateUser>;
|
|
16
|
+
export declare namespace CreateUserUseCase {
|
|
17
|
+
type Interface = ICreateUser;
|
|
18
|
+
type Input = CreateUserInput;
|
|
19
|
+
type Error = CreateUserError;
|
|
20
|
+
}
|
|
21
|
+
export interface UserBeforeCreatePayload {
|
|
22
|
+
user: AdminUser;
|
|
23
|
+
input: CreateUserInput;
|
|
24
|
+
}
|
|
25
|
+
export interface UserAfterCreatePayload {
|
|
26
|
+
user: AdminUser;
|
|
27
|
+
input: CreateUserInput;
|
|
28
|
+
}
|
|
29
|
+
export {};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { createAbstraction } from "@webiny/feature/api";
|
|
2
|
+
|
|
3
|
+
// Use case specific errors
|
|
4
|
+
|
|
5
|
+
// Combined error type (use case errors + repository errors)
|
|
6
|
+
|
|
7
|
+
// Use case interface
|
|
8
|
+
|
|
9
|
+
// Abstraction constant
|
|
10
|
+
export const CreateUserUseCase = createAbstraction("CreateUserUseCase");
|
|
11
|
+
|
|
12
|
+
// Namespace exports
|
|
13
|
+
|
|
14
|
+
// Event payload types
|
|
15
|
+
|
|
16
|
+
//# sourceMappingURL=abstractions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createAbstraction","CreateUserUseCase"],"sources":["abstractions.ts"],"sourcesContent":["import { createAbstraction } from \"@webiny/feature/api\";\nimport { Result } from \"@webiny/feature/api\";\nimport type { AdminUser } from \"~/features/users/shared/types.js\";\nimport type { CreateUserInput } from \"~/features/users/shared/types.js\";\nimport { AdminUsersRepository } from \"~/features/users/shared/abstractions.js\";\nimport {\n NotAuthorizedError,\n EmailTakenError,\n UserValidationError\n} from \"~/features/users/shared/errors.js\";\n\n// Use case specific errors\nexport interface ICreateUserErrors {\n notAuthorized: NotAuthorizedError;\n userExists: EmailTakenError;\n validation: UserValidationError;\n}\n\n// Combined error type (use case errors + repository errors)\ntype CreateUserError = ICreateUserErrors[keyof ICreateUserErrors] | AdminUsersRepository.Error;\n\n// Use case interface\nexport interface ICreateUser {\n execute(input: CreateUserInput): Promise<Result<AdminUser, CreateUserError>>;\n}\n\n// Abstraction constant\nexport const CreateUserUseCase = createAbstraction<ICreateUser>(\"CreateUserUseCase\");\n\n// Namespace exports\nexport namespace CreateUserUseCase {\n export type Interface = ICreateUser;\n export type Input = CreateUserInput;\n export type Error = CreateUserError;\n}\n\n// Event payload types\nexport interface UserBeforeCreatePayload {\n user: AdminUser;\n input: CreateUserInput;\n}\n\nexport interface UserAfterCreatePayload {\n user: AdminUser;\n input: CreateUserInput;\n}\n"],"mappings":"AAAA,SAASA,iBAAiB,QAAQ,qBAAqB;;AAWvD;;AAOA;;AAGA;;AAKA;AACA,OAAO,MAAMC,iBAAiB,GAAGD,iBAAiB,CAAc,mBAAmB,CAAC;;AAEpF;;AAOA","ignoreList":[]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { CreateUserUseCase } from "../abstractions.js";
|
|
2
|
+
import type { CreateUserInput } from "../../../../features/users/shared/types.js";
|
|
3
|
+
import { WcpContext } from "../../../../features/wcp/WcpContext/index.js";
|
|
4
|
+
declare class CreateUserWithWcpIncrementImpl implements CreateUserUseCase.Interface {
|
|
5
|
+
private wcp;
|
|
6
|
+
private decoratee;
|
|
7
|
+
constructor(wcp: WcpContext.Interface, decoratee: CreateUserUseCase.Interface);
|
|
8
|
+
execute(input: CreateUserInput): Promise<import("@webiny/feature/api").Result<import("~/features/users/shared/types.js").AdminUser, import("../../shared/errors.js").UserStorageError | import("../../shared/errors.js").UserNotFoundError | import("../../shared/errors.js").EmailTakenError | import("../../shared/errors.js").UserValidationError | import("../../shared/errors.js").NotAuthorizedError>>;
|
|
9
|
+
}
|
|
10
|
+
export declare const CreateUserWithWcpIncrement: typeof CreateUserWithWcpIncrementImpl;
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { createDecorator } from "@webiny/feature/api";
|
|
2
|
+
import { CreateUserUseCase } from "../abstractions.js";
|
|
3
|
+
import { WcpContext } from "../../../wcp/WcpContext/index.js";
|
|
4
|
+
class CreateUserWithWcpIncrementImpl {
|
|
5
|
+
constructor(wcp, decoratee) {
|
|
6
|
+
this.wcp = wcp;
|
|
7
|
+
this.decoratee = decoratee;
|
|
8
|
+
}
|
|
9
|
+
async execute(input) {
|
|
10
|
+
await this.wcp.incrementSeats();
|
|
11
|
+
const result = await this.decoratee.execute(input);
|
|
12
|
+
if (result.isFail()) {
|
|
13
|
+
await this.wcp.decrementSeats();
|
|
14
|
+
}
|
|
15
|
+
return result;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
export const CreateUserWithWcpIncrement = createDecorator({
|
|
19
|
+
abstraction: CreateUserUseCase,
|
|
20
|
+
decorator: CreateUserWithWcpIncrementImpl,
|
|
21
|
+
dependencies: [WcpContext]
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
//# sourceMappingURL=CreateUserWithWcpIncrement.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createDecorator","CreateUserUseCase","WcpContext","CreateUserWithWcpIncrementImpl","constructor","wcp","decoratee","execute","input","incrementSeats","result","isFail","decrementSeats","CreateUserWithWcpIncrement","abstraction","decorator","dependencies"],"sources":["CreateUserWithWcpIncrement.ts"],"sourcesContent":["import { createDecorator } from \"@webiny/feature/api\";\nimport { CreateUserUseCase } from \"../abstractions.js\";\nimport type { CreateUserInput } from \"~/features/users/shared/types.js\";\nimport { WcpContext } from \"~/features/wcp/WcpContext/index.js\";\n\nclass CreateUserWithWcpIncrementImpl implements CreateUserUseCase.Interface {\n constructor(\n private wcp: WcpContext.Interface,\n private decoratee: CreateUserUseCase.Interface\n ) {}\n\n async execute(input: CreateUserInput) {\n await this.wcp.incrementSeats();\n\n const result = await this.decoratee.execute(input);\n\n if (result.isFail()) {\n await this.wcp.decrementSeats();\n }\n\n return result;\n }\n}\n\nexport const CreateUserWithWcpIncrement = createDecorator({\n abstraction: CreateUserUseCase,\n decorator: CreateUserWithWcpIncrementImpl,\n dependencies: [WcpContext]\n});\n"],"mappings":"AAAA,SAASA,eAAe,QAAQ,qBAAqB;AACrD,SAASC,iBAAiB;AAE1B,SAASC,UAAU;AAEnB,MAAMC,8BAA8B,CAAwC;EACxEC,WAAWA,CACCC,GAAyB,EACzBC,SAAsC,EAChD;IAAA,KAFUD,GAAyB,GAAzBA,GAAyB;IAAA,KACzBC,SAAsC,GAAtCA,SAAsC;EAC/C;EAEH,MAAMC,OAAOA,CAACC,KAAsB,EAAE;IAClC,MAAM,IAAI,CAACH,GAAG,CAACI,cAAc,CAAC,CAAC;IAE/B,MAAMC,MAAM,GAAG,MAAM,IAAI,CAACJ,SAAS,CAACC,OAAO,CAACC,KAAK,CAAC;IAElD,IAAIE,MAAM,CAACC,MAAM,CAAC,CAAC,EAAE;MACjB,MAAM,IAAI,CAACN,GAAG,CAACO,cAAc,CAAC,CAAC;IACnC;IAEA,OAAOF,MAAM;EACjB;AACJ;AAEA,OAAO,MAAMG,0BAA0B,GAAGb,eAAe,CAAC;EACtDc,WAAW,EAAEb,iBAAiB;EAC9Bc,SAAS,EAAEZ,8BAA8B;EACzCa,YAAY,EAAE,CAACd,UAAU;AAC7B,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { DomainEvent } from "../../../features/eventPublisher/index.js";
|
|
2
|
+
import type { IEventHandler } from "../../../features/eventPublisher/index.js";
|
|
3
|
+
import type { UserBeforeCreatePayload, UserAfterCreatePayload } from "./abstractions.js";
|
|
4
|
+
export declare class UserBeforeCreateEvent extends DomainEvent<UserBeforeCreatePayload> {
|
|
5
|
+
eventType: "user.beforeCreate";
|
|
6
|
+
getHandlerAbstraction(): import("@webiny/di").Abstraction<IEventHandler<UserBeforeCreateEvent>>;
|
|
7
|
+
}
|
|
8
|
+
export declare const UserBeforeCreateHandler: import("@webiny/di").Abstraction<IEventHandler<UserBeforeCreateEvent>>;
|
|
9
|
+
export declare namespace UserBeforeCreateHandler {
|
|
10
|
+
type Interface = IEventHandler<UserBeforeCreateEvent>;
|
|
11
|
+
type Event = UserBeforeCreateEvent;
|
|
12
|
+
}
|
|
13
|
+
export declare class UserAfterCreateEvent extends DomainEvent<UserAfterCreatePayload> {
|
|
14
|
+
eventType: "user.afterCreate";
|
|
15
|
+
getHandlerAbstraction(): import("@webiny/di").Abstraction<IEventHandler<UserAfterCreateEvent>>;
|
|
16
|
+
}
|
|
17
|
+
export declare const UserAfterCreateHandler: import("@webiny/di").Abstraction<IEventHandler<UserAfterCreateEvent>>;
|
|
18
|
+
export declare namespace UserAfterCreateHandler {
|
|
19
|
+
type Interface = IEventHandler<UserAfterCreateEvent>;
|
|
20
|
+
type Event = UserAfterCreateEvent;
|
|
21
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { createAbstraction } from "@webiny/feature/api";
|
|
2
|
+
import { DomainEvent } from "../../eventPublisher/index.js";
|
|
3
|
+
// Before Create Event
|
|
4
|
+
export class UserBeforeCreateEvent extends DomainEvent {
|
|
5
|
+
eventType = "user.beforeCreate";
|
|
6
|
+
getHandlerAbstraction() {
|
|
7
|
+
return UserBeforeCreateHandler;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
export const UserBeforeCreateHandler = createAbstraction("UserBeforeCreateHandler");
|
|
11
|
+
// After Create Event
|
|
12
|
+
export class UserAfterCreateEvent extends DomainEvent {
|
|
13
|
+
eventType = "user.afterCreate";
|
|
14
|
+
getHandlerAbstraction() {
|
|
15
|
+
return UserAfterCreateHandler;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
export const UserAfterCreateHandler = createAbstraction("UserAfterCreateHandler");
|
|
19
|
+
|
|
20
|
+
//# sourceMappingURL=events.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createAbstraction","DomainEvent","UserBeforeCreateEvent","eventType","getHandlerAbstraction","UserBeforeCreateHandler","UserAfterCreateEvent","UserAfterCreateHandler"],"sources":["events.ts"],"sourcesContent":["import { createAbstraction } from \"@webiny/feature/api\";\nimport { DomainEvent } from \"~/features/eventPublisher/index.js\";\nimport type { IEventHandler } from \"~/features/eventPublisher/index.js\";\nimport type { UserBeforeCreatePayload, UserAfterCreatePayload } from \"./abstractions.js\";\n\n// Before Create Event\nexport class UserBeforeCreateEvent extends DomainEvent<UserBeforeCreatePayload> {\n eventType = \"user.beforeCreate\" as const;\n\n getHandlerAbstraction() {\n return UserBeforeCreateHandler;\n }\n}\n\nexport const UserBeforeCreateHandler =\n createAbstraction<IEventHandler<UserBeforeCreateEvent>>(\"UserBeforeCreateHandler\");\n\nexport namespace UserBeforeCreateHandler {\n export type Interface = IEventHandler<UserBeforeCreateEvent>;\n export type Event = UserBeforeCreateEvent;\n}\n\n// After Create Event\nexport class UserAfterCreateEvent extends DomainEvent<UserAfterCreatePayload> {\n eventType = \"user.afterCreate\" as const;\n\n getHandlerAbstraction() {\n return UserAfterCreateHandler;\n }\n}\n\nexport const UserAfterCreateHandler =\n createAbstraction<IEventHandler<UserAfterCreateEvent>>(\"UserAfterCreateHandler\");\n\nexport namespace UserAfterCreateHandler {\n export type Interface = IEventHandler<UserAfterCreateEvent>;\n export type Event = UserAfterCreateEvent;\n}\n"],"mappings":"AAAA,SAASA,iBAAiB,QAAQ,qBAAqB;AACvD,SAASC,WAAW;AAIpB;AACA,OAAO,MAAMC,qBAAqB,SAASD,WAAW,CAA0B;EAC5EE,SAAS,GAAG,mBAAmB;EAE/BC,qBAAqBA,CAAA,EAAG;IACpB,OAAOC,uBAAuB;EAClC;AACJ;AAEA,OAAO,MAAMA,uBAAuB,GAChCL,iBAAiB,CAAuC,yBAAyB,CAAC;AAOtF;AACA,OAAO,MAAMM,oBAAoB,SAASL,WAAW,CAAyB;EAC1EE,SAAS,GAAG,kBAAkB;EAE9BC,qBAAqBA,CAAA,EAAG;IACpB,OAAOG,sBAAsB;EACjC;AACJ;AAEA,OAAO,MAAMA,sBAAsB,GAC/BP,iBAAiB,CAAsC,wBAAwB,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const CreateUserFeature: import("@webiny/feature/api/createFeature.js").FeatureDefinition<unknown>;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { createFeature } from "@webiny/feature/api";
|
|
2
|
+
import { CreateUserUseCase } from "./CreateUserUseCase.js";
|
|
3
|
+
import { CreateUserWithWcpIncrement } from "./decorators/CreateUserWithWcpIncrement.js";
|
|
4
|
+
export const CreateUserFeature = createFeature({
|
|
5
|
+
name: "CreateUser",
|
|
6
|
+
register(container) {
|
|
7
|
+
container.register(CreateUserUseCase);
|
|
8
|
+
container.registerDecorator(CreateUserWithWcpIncrement);
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
//# sourceMappingURL=feature.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createFeature","CreateUserUseCase","CreateUserWithWcpIncrement","CreateUserFeature","name","register","container","registerDecorator"],"sources":["feature.ts"],"sourcesContent":["import { createFeature } from \"@webiny/feature/api\";\nimport { CreateUserUseCase } from \"./CreateUserUseCase.js\";\nimport { CreateUserWithWcpIncrement } from \"./decorators/CreateUserWithWcpIncrement.js\";\n\nexport const CreateUserFeature = createFeature({\n name: \"CreateUser\",\n register(container) {\n container.register(CreateUserUseCase);\n container.registerDecorator(CreateUserWithWcpIncrement);\n }\n});\n"],"mappings":"AAAA,SAASA,aAAa,QAAQ,qBAAqB;AACnD,SAASC,iBAAiB;AAC1B,SAASC,0BAA0B;AAEnC,OAAO,MAAMC,iBAAiB,GAAGH,aAAa,CAAC;EAC3CI,IAAI,EAAE,YAAY;EAClBC,QAAQA,CAACC,SAAS,EAAE;IAChBA,SAAS,CAACD,QAAQ,CAACJ,iBAAiB,CAAC;IACrCK,SAAS,CAACC,iBAAiB,CAACL,0BAA0B,CAAC;EAC3D;AACJ,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./abstractions.js\";\nexport * from \"./events.js\";\n"],"mappings":"AAAA;AACA","ignoreList":[]}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
export declare const createUserValidation: z.ZodObject<{
|
|
3
|
+
id: z.ZodOptional<z.ZodString>;
|
|
4
|
+
displayName: z.ZodOptional<z.ZodString>;
|
|
5
|
+
email: z.ZodString;
|
|
6
|
+
firstName: z.ZodOptional<z.ZodString>;
|
|
7
|
+
lastName: z.ZodOptional<z.ZodString>;
|
|
8
|
+
avatar: z.ZodNullable<z.ZodOptional<z.ZodObject<{
|
|
9
|
+
id: z.ZodString;
|
|
10
|
+
src: z.ZodString;
|
|
11
|
+
}, "strip", z.ZodTypeAny, {
|
|
12
|
+
id: string;
|
|
13
|
+
src: string;
|
|
14
|
+
}, {
|
|
15
|
+
id: string;
|
|
16
|
+
src: string;
|
|
17
|
+
}>>>;
|
|
18
|
+
roles: z.ZodDefault<z.ZodOptional<z.ZodArray<z.ZodString, "many">>>;
|
|
19
|
+
teams: z.ZodDefault<z.ZodOptional<z.ZodArray<z.ZodString, "many">>>;
|
|
20
|
+
external: z.ZodDefault<z.ZodOptional<z.ZodBoolean>>;
|
|
21
|
+
}, "strip", z.ZodTypeAny, {
|
|
22
|
+
email: string;
|
|
23
|
+
external: boolean;
|
|
24
|
+
roles: string[];
|
|
25
|
+
teams: string[];
|
|
26
|
+
firstName?: string | undefined;
|
|
27
|
+
lastName?: string | undefined;
|
|
28
|
+
id?: string | undefined;
|
|
29
|
+
displayName?: string | undefined;
|
|
30
|
+
avatar?: {
|
|
31
|
+
id: string;
|
|
32
|
+
src: string;
|
|
33
|
+
} | null | undefined;
|
|
34
|
+
}, {
|
|
35
|
+
email: string;
|
|
36
|
+
firstName?: string | undefined;
|
|
37
|
+
lastName?: string | undefined;
|
|
38
|
+
external?: boolean | undefined;
|
|
39
|
+
id?: string | undefined;
|
|
40
|
+
displayName?: string | undefined;
|
|
41
|
+
roles?: string[] | undefined;
|
|
42
|
+
teams?: string[] | undefined;
|
|
43
|
+
avatar?: {
|
|
44
|
+
id: string;
|
|
45
|
+
src: string;
|
|
46
|
+
} | null | undefined;
|
|
47
|
+
}>;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
export const createUserValidation = z.object({
|
|
3
|
+
id: z.string().min(1).optional(),
|
|
4
|
+
displayName: z.string().min(1).optional(),
|
|
5
|
+
// We did not use an e-mail validator here, just because external
|
|
6
|
+
// IdPs (Okta, Auth0) do not require e-mail to be present. When creating
|
|
7
|
+
// admin users, they're actually passing the user's ID as the e-mail.
|
|
8
|
+
// For example: packages/api-security-okta/src/createAdminUsersHooks.ts:13
|
|
9
|
+
// In the future, we might want to rename this field to `idpId` or similar.
|
|
10
|
+
email: z.string(),
|
|
11
|
+
firstName: z.string().optional(),
|
|
12
|
+
lastName: z.string().optional(),
|
|
13
|
+
avatar: z.object({
|
|
14
|
+
id: z.string().min(1),
|
|
15
|
+
src: z.string().url()
|
|
16
|
+
}).optional().nullable(),
|
|
17
|
+
roles: z.array(z.string()).optional().default([]),
|
|
18
|
+
teams: z.array(z.string()).optional().default([]),
|
|
19
|
+
external: z.boolean().optional().default(false)
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
//# sourceMappingURL=schema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["z","createUserValidation","object","id","string","min","optional","displayName","email","firstName","lastName","avatar","src","url","nullable","roles","array","default","teams","external","boolean"],"sources":["schema.ts"],"sourcesContent":["import { z } from \"zod\";\n\nexport const createUserValidation = z.object({\n id: z.string().min(1).optional(),\n displayName: z.string().min(1).optional(),\n // We did not use an e-mail validator here, just because external\n // IdPs (Okta, Auth0) do not require e-mail to be present. When creating\n // admin users, they're actually passing the user's ID as the e-mail.\n // For example: packages/api-security-okta/src/createAdminUsersHooks.ts:13\n // In the future, we might want to rename this field to `idpId` or similar.\n email: z.string(),\n firstName: z.string().optional(),\n lastName: z.string().optional(),\n avatar: z\n .object({\n id: z.string().min(1),\n src: z.string().url()\n })\n .optional()\n .nullable(),\n roles: z.array(z.string()).optional().default([]),\n teams: z.array(z.string()).optional().default([]),\n external: z.boolean().optional().default(false)\n});\n"],"mappings":"AAAA,SAASA,CAAC,QAAQ,KAAK;AAEvB,OAAO,MAAMC,oBAAoB,GAAGD,CAAC,CAACE,MAAM,CAAC;EACzCC,EAAE,EAAEH,CAAC,CAACI,MAAM,CAAC,CAAC,CAACC,GAAG,CAAC,CAAC,CAAC,CAACC,QAAQ,CAAC,CAAC;EAChCC,WAAW,EAAEP,CAAC,CAACI,MAAM,CAAC,CAAC,CAACC,GAAG,CAAC,CAAC,CAAC,CAACC,QAAQ,CAAC,CAAC;EACzC;EACA;EACA;EACA;EACA;EACAE,KAAK,EAAER,CAAC,CAACI,MAAM,CAAC,CAAC;EACjBK,SAAS,EAAET,CAAC,CAACI,MAAM,CAAC,CAAC,CAACE,QAAQ,CAAC,CAAC;EAChCI,QAAQ,EAAEV,CAAC,CAACI,MAAM,CAAC,CAAC,CAACE,QAAQ,CAAC,CAAC;EAC/BK,MAAM,EAAEX,CAAC,CACJE,MAAM,CAAC;IACJC,EAAE,EAAEH,CAAC,CAACI,MAAM,CAAC,CAAC,CAACC,GAAG,CAAC,CAAC,CAAC;IACrBO,GAAG,EAAEZ,CAAC,CAACI,MAAM,CAAC,CAAC,CAACS,GAAG,CAAC;EACxB,CAAC,CAAC,CACDP,QAAQ,CAAC,CAAC,CACVQ,QAAQ,CAAC,CAAC;EACfC,KAAK,EAAEf,CAAC,CAACgB,KAAK,CAAChB,CAAC,CAACI,MAAM,CAAC,CAAC,CAAC,CAACE,QAAQ,CAAC,CAAC,CAACW,OAAO,CAAC,EAAE,CAAC;EACjDC,KAAK,EAAElB,CAAC,CAACgB,KAAK,CAAChB,CAAC,CAACI,MAAM,CAAC,CAAC,CAAC,CAACE,QAAQ,CAAC,CAAC,CAACW,OAAO,CAAC,EAAE,CAAC;EACjDE,QAAQ,EAAEnB,CAAC,CAACoB,OAAO,CAAC,CAAC,CAACd,QAAQ,CAAC,CAAC,CAACW,OAAO,CAAC,KAAK;AAClD,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Result } from "@webiny/feature/api";
|
|
2
|
+
import { IdentityContext } from "../../../features/security/IdentityContext/index.js";
|
|
3
|
+
import { EventPublisher } from "../../../features/eventPublisher/index.js";
|
|
4
|
+
import { DeleteUserUseCase as UseCaseAbstraction } from "./abstractions.js";
|
|
5
|
+
import { AdminUsersRepository } from "../../../features/users/shared/abstractions.js";
|
|
6
|
+
declare class DeleteUserUseCaseImpl implements UseCaseAbstraction.Interface {
|
|
7
|
+
private identityContext;
|
|
8
|
+
private eventPublisher;
|
|
9
|
+
private repository;
|
|
10
|
+
constructor(identityContext: IdentityContext.Interface, eventPublisher: EventPublisher.Interface, repository: AdminUsersRepository.Interface);
|
|
11
|
+
execute(id: string): Promise<Result<void, UseCaseAbstraction.Error>>;
|
|
12
|
+
}
|
|
13
|
+
export declare const DeleteUserUseCase: import("@webiny/di").Implementation<typeof DeleteUserUseCaseImpl>;
|
|
14
|
+
export {};
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { createImplementation } from "@webiny/feature/api";
|
|
2
|
+
import { Result } from "@webiny/feature/api";
|
|
3
|
+
import { IdentityContext } from "../../security/IdentityContext/index.js";
|
|
4
|
+
import { EventPublisher } from "../../eventPublisher/index.js";
|
|
5
|
+
import { DeleteUserUseCase as UseCaseAbstraction } from "./abstractions.js";
|
|
6
|
+
import { AdminUsersRepository } from "../shared/abstractions.js";
|
|
7
|
+
import { NotAuthorizedError } from "../shared/errors.js";
|
|
8
|
+
import { UserBeforeDeleteEvent, UserAfterDeleteEvent } from "./events.js";
|
|
9
|
+
import { CannotDeleteOwnAccountError } from "./errors.js";
|
|
10
|
+
class DeleteUserUseCaseImpl {
|
|
11
|
+
constructor(identityContext, eventPublisher, repository) {
|
|
12
|
+
this.identityContext = identityContext;
|
|
13
|
+
this.eventPublisher = eventPublisher;
|
|
14
|
+
this.repository = repository;
|
|
15
|
+
}
|
|
16
|
+
async execute(id) {
|
|
17
|
+
// 1. Check permission
|
|
18
|
+
const permission = await this.identityContext.getPermission("adminUsers.user");
|
|
19
|
+
if (!permission) {
|
|
20
|
+
return Result.fail(new NotAuthorizedError());
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
// 2. Get existing user
|
|
24
|
+
const getUserResult = await this.repository.get({
|
|
25
|
+
id
|
|
26
|
+
});
|
|
27
|
+
if (getUserResult.isFail()) {
|
|
28
|
+
return Result.fail(getUserResult.error);
|
|
29
|
+
}
|
|
30
|
+
const user = getUserResult.value;
|
|
31
|
+
|
|
32
|
+
// 3. Check if trying to delete own account
|
|
33
|
+
const identity = this.identityContext.getIdentity();
|
|
34
|
+
if (user.id === identity.id) {
|
|
35
|
+
return Result.fail(new CannotDeleteOwnAccountError());
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
// 4. Publish before event
|
|
39
|
+
await this.eventPublisher.publish(new UserBeforeDeleteEvent({
|
|
40
|
+
user
|
|
41
|
+
}));
|
|
42
|
+
|
|
43
|
+
// 5. Delete user via repository
|
|
44
|
+
const result = await this.repository.delete(user);
|
|
45
|
+
if (result.isFail()) {
|
|
46
|
+
return Result.fail(result.error);
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
// 6. Publish after event
|
|
50
|
+
await this.eventPublisher.publish(new UserAfterDeleteEvent({
|
|
51
|
+
user
|
|
52
|
+
}));
|
|
53
|
+
return Result.ok();
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
export const DeleteUserUseCase = createImplementation({
|
|
57
|
+
abstraction: UseCaseAbstraction,
|
|
58
|
+
implementation: DeleteUserUseCaseImpl,
|
|
59
|
+
dependencies: [IdentityContext, EventPublisher, AdminUsersRepository]
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
//# sourceMappingURL=DeleteUserUseCase.js.map
|