@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 @@
|
|
|
1
|
+
{"version":3,"names":["Result","WebinyError","BaseModel","__schema","Error","constructor","data","validateData","populate","Object","assign","validate","toData","ok","error","fail","validateOrThrow","clone","Constructor","_def","typeName","result","shape","key","structuredClone","updateWith","partial","updated","safeParse","success","message","code","errors"],"sources":["BaseModel.ts"],"sourcesContent":["import { Result } from \"@webiny/feature/api\";\nimport { WebinyError } from \"@webiny/error\";\nimport z from \"zod\";\n\ntype DataProperties<T> = Omit<T, \"__schema\">;\n\nexport type IModelData<T> = {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\n [K in keyof DataProperties<T> as T[K] extends Function ? never : K]: T[K];\n};\n\nexport type IModelInput<T> = IModelData<T>;\n\nexport abstract class BaseModel<TModel extends z.ZodObject<any> = any> {\n get __schema(): TModel {\n throw new Error(\"Schema getter is not implemented!\");\n }\n\n constructor(data: IModelData<TModel>) {\n this.validateData(data);\n this.populate(data);\n }\n\n populate(data: IModelData<TModel>): void {\n Object.assign(this, data);\n }\n\n validate(): Result<true, WebinyError> {\n try {\n this.validateData(this.toData());\n return Result.ok(true);\n } catch (error) {\n return Result.fail(error);\n }\n }\n\n validateOrThrow(): void {\n this.validateData(this.toData());\n }\n\n clone(): this {\n const Constructor = this.constructor as new (data: IModelData<TModel>) => this;\n return new Constructor(this.toData());\n }\n\n toData(): IModelData<TModel> {\n if (this.__schema && this.__schema._def?.typeName === \"ZodObject\") {\n const result = {} as IModelData<TModel>;\n const shape = this.__schema.shape;\n for (const key in shape) {\n // always use structuredClone for safety.\n // @ts-expect-error allow index.\n result[key] = structuredClone(this[key]);\n }\n return result;\n }\n\n return { ...(this as any) } as IModelData<TModel>;\n }\n\n updateWith(partial: Partial<IModelData<this>>): void {\n const updated = { ...this.toData(), ...partial };\n this.validateData(updated);\n this.populate(updated);\n }\n\n protected validateData(data: IModelData<TModel>): void {\n const result = this.__schema.safeParse(data);\n if (!result.success) {\n throw new WebinyError({\n message: \"Validation error\",\n code: \"DOMAIN_MODEL_VALIDATION_ERROR\",\n data: result.error.errors\n });\n }\n }\n}\n"],"mappings":"AAAA,SAASA,MAAM,QAAQ,qBAAqB;AAC5C,SAASC,WAAW,QAAQ,eAAe;AAY3C,OAAO,MAAeC,SAAS,CAAwC;EACnE,IAAIC,QAAQA,CAAA,EAAW;IACnB,MAAM,IAAIC,KAAK,CAAC,mCAAmC,CAAC;EACxD;EAEAC,WAAWA,CAACC,IAAwB,EAAE;IAClC,IAAI,CAACC,YAAY,CAACD,IAAI,CAAC;IACvB,IAAI,CAACE,QAAQ,CAACF,IAAI,CAAC;EACvB;EAEAE,QAAQA,CAACF,IAAwB,EAAQ;IACrCG,MAAM,CAACC,MAAM,CAAC,IAAI,EAAEJ,IAAI,CAAC;EAC7B;EAEAK,QAAQA,CAAA,EAA8B;IAClC,IAAI;MACA,IAAI,CAACJ,YAAY,CAAC,IAAI,CAACK,MAAM,CAAC,CAAC,CAAC;MAChC,OAAOZ,MAAM,CAACa,EAAE,CAAC,IAAI,CAAC;IAC1B,CAAC,CAAC,OAAOC,KAAK,EAAE;MACZ,OAAOd,MAAM,CAACe,IAAI,CAACD,KAAK,CAAC;IAC7B;EACJ;EAEAE,eAAeA,CAAA,EAAS;IACpB,IAAI,CAACT,YAAY,CAAC,IAAI,CAACK,MAAM,CAAC,CAAC,CAAC;EACpC;EAEAK,KAAKA,CAAA,EAAS;IACV,MAAMC,WAAW,GAAG,IAAI,CAACb,WAAqD;IAC9E,OAAO,IAAIa,WAAW,CAAC,IAAI,CAACN,MAAM,CAAC,CAAC,CAAC;EACzC;EAEAA,MAAMA,CAAA,EAAuB;IACzB,IAAI,IAAI,CAACT,QAAQ,IAAI,IAAI,CAACA,QAAQ,CAACgB,IAAI,EAAEC,QAAQ,KAAK,WAAW,EAAE;MAC/D,MAAMC,MAAM,GAAG,CAAC,CAAuB;MACvC,MAAMC,KAAK,GAAG,IAAI,CAACnB,QAAQ,CAACmB,KAAK;MACjC,KAAK,MAAMC,GAAG,IAAID,KAAK,EAAE;QACrB;QACA;QACAD,MAAM,CAACE,GAAG,CAAC,GAAGC,eAAe,CAAC,IAAI,CAACD,GAAG,CAAC,CAAC;MAC5C;MACA,OAAOF,MAAM;IACjB;IAEA,OAAO;MAAE,GAAI;IAAa,CAAC;EAC/B;EAEAI,UAAUA,CAACC,OAAkC,EAAQ;IACjD,MAAMC,OAAO,GAAG;MAAE,GAAG,IAAI,CAACf,MAAM,CAAC,CAAC;MAAE,GAAGc;IAAQ,CAAC;IAChD,IAAI,CAACnB,YAAY,CAACoB,OAAO,CAAC;IAC1B,IAAI,CAACnB,QAAQ,CAACmB,OAAO,CAAC;EAC1B;EAEUpB,YAAYA,CAACD,IAAwB,EAAQ;IACnD,MAAMe,MAAM,GAAG,IAAI,CAAClB,QAAQ,CAACyB,SAAS,CAACtB,IAAI,CAAC;IAC5C,IAAI,CAACe,MAAM,CAACQ,OAAO,EAAE;MACjB,MAAM,IAAI5B,WAAW,CAAC;QAClB6B,OAAO,EAAE,kBAAkB;QAC3BC,IAAI,EAAE,+BAA+B;QACrCzB,IAAI,EAAEe,MAAM,CAACP,KAAK,CAACkB;MACvB,CAAC,CAAC;IACN;EACJ;AACJ","ignoreList":[]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
import { BaseModel, type IModelData as ExtractModelData } from "./BaseModel.js";
|
|
3
|
+
export type ModelClass<TModel extends BaseModel<any>> = {
|
|
4
|
+
__schema: TModel["__schema"];
|
|
5
|
+
new (data: ExtractModelData<TModel>): TModel;
|
|
6
|
+
create(data: ExtractModelData<TModel>): TModel;
|
|
7
|
+
};
|
|
8
|
+
export declare const createModelSchema: <TReturn extends z.ZodRawShape>(factory: (zod: typeof z) => TReturn) => z.ZodObject<TReturn, "strip", z.ZodTypeAny, z.objectUtil.addQuestionMarks<z.baseObjectOutputType<TReturn>, any> extends infer T ? { [k in keyof T]: T[k]; } : never, z.baseObjectInputType<TReturn> extends infer T_1 ? { [k_1 in keyof T_1]: T_1[k_1]; } : never>;
|
|
9
|
+
export declare class ModelBuilder<TModel extends BaseModel<any>> {
|
|
10
|
+
private name;
|
|
11
|
+
private schema;
|
|
12
|
+
private methods;
|
|
13
|
+
constructor(name: string, schema: TModel["__schema"]);
|
|
14
|
+
extendSchema<TExt extends z.ZodRawShape>(extensionFn: (zod: typeof z) => TExt): this;
|
|
15
|
+
withMethods<TExtMethods extends object>(methods: TExtMethods & ThisType<TModel & TExtMethods>): ModelBuilder<TModel & TExtMethods>;
|
|
16
|
+
getSchema(): TModel["__schema"];
|
|
17
|
+
build(): ModelClass<TModel>;
|
|
18
|
+
}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
import { BaseModel } from "./BaseModel.js";
|
|
3
|
+
export const createModelSchema = factory => {
|
|
4
|
+
return z.object({
|
|
5
|
+
...factory(z)
|
|
6
|
+
});
|
|
7
|
+
};
|
|
8
|
+
export class ModelBuilder {
|
|
9
|
+
methods = {};
|
|
10
|
+
constructor(name, schema) {
|
|
11
|
+
this.name = name;
|
|
12
|
+
this.schema = schema;
|
|
13
|
+
this.methods = {};
|
|
14
|
+
}
|
|
15
|
+
extendSchema(extensionFn) {
|
|
16
|
+
const shape = extensionFn(z);
|
|
17
|
+
const baseExtensions = this.schema.shape.extensions;
|
|
18
|
+
let baseExtensionsObject;
|
|
19
|
+
if (baseExtensions instanceof z.ZodObject) {
|
|
20
|
+
baseExtensionsObject = baseExtensions;
|
|
21
|
+
} else if (baseExtensions) {
|
|
22
|
+
let inner = baseExtensions;
|
|
23
|
+
while (inner && "_def" in inner && ["ZodOptional", "ZodNullable", "ZodDefault"].includes(inner._def.typeName)) {
|
|
24
|
+
inner = inner._def.innerType;
|
|
25
|
+
}
|
|
26
|
+
baseExtensionsObject = inner instanceof z.ZodObject ? inner : z.object({});
|
|
27
|
+
} else {
|
|
28
|
+
baseExtensionsObject = z.object({});
|
|
29
|
+
}
|
|
30
|
+
const newExtensions = baseExtensionsObject.extend(shape);
|
|
31
|
+
this.schema = this.schema.extend({
|
|
32
|
+
extensions: newExtensions
|
|
33
|
+
});
|
|
34
|
+
return this;
|
|
35
|
+
}
|
|
36
|
+
withMethods(methods) {
|
|
37
|
+
Object.assign(this.methods, methods);
|
|
38
|
+
return this;
|
|
39
|
+
}
|
|
40
|
+
getSchema() {
|
|
41
|
+
return this.schema;
|
|
42
|
+
}
|
|
43
|
+
build() {
|
|
44
|
+
const schema = this.schema;
|
|
45
|
+
const methods = this.methods;
|
|
46
|
+
const name = this.name;
|
|
47
|
+
class Model extends BaseModel {
|
|
48
|
+
get __schema() {
|
|
49
|
+
return schema;
|
|
50
|
+
}
|
|
51
|
+
static __schema = schema;
|
|
52
|
+
static create(data) {
|
|
53
|
+
return new this(data);
|
|
54
|
+
}
|
|
55
|
+
clone() {
|
|
56
|
+
const Constructor = this.constructor;
|
|
57
|
+
return new Constructor(this.toData());
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
Object.assign(Model.prototype, methods);
|
|
61
|
+
Object.defineProperty(Model.prototype, Symbol.toStringTag, {
|
|
62
|
+
value: name
|
|
63
|
+
});
|
|
64
|
+
return Model;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
//# sourceMappingURL=ModelBuilder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["z","BaseModel","createModelSchema","factory","object","ModelBuilder","methods","constructor","name","schema","extendSchema","extensionFn","shape","baseExtensions","extensions","baseExtensionsObject","ZodObject","inner","includes","_def","typeName","innerType","newExtensions","extend","withMethods","Object","assign","getSchema","build","Model","__schema","create","data","clone","Constructor","toData","prototype","defineProperty","Symbol","toStringTag","value"],"sources":["ModelBuilder.ts"],"sourcesContent":["import { z } from \"zod\";\nimport { BaseModel, type IModelData as ExtractModelData } from \"./BaseModel.js\";\n\nexport type ModelClass<TModel extends BaseModel<any>> = {\n __schema: TModel[\"__schema\"];\n new (data: ExtractModelData<TModel>): TModel;\n create(data: ExtractModelData<TModel>): TModel;\n};\n\nexport const createModelSchema = <TReturn extends z.ZodRawShape>(\n factory: (zod: typeof z) => TReturn\n) => {\n return z.object({ ...factory(z) });\n};\n\nexport class ModelBuilder<TModel extends BaseModel<any>> {\n private methods: Partial<Record<keyof TModel, any>> = {};\n\n constructor(\n private name: string,\n private schema: TModel[\"__schema\"]\n ) {\n this.methods = {};\n }\n\n extendSchema<TExt extends z.ZodRawShape>(extensionFn: (zod: typeof z) => TExt): this {\n const shape = extensionFn(z);\n const baseExtensions = (this.schema.shape as any).extensions;\n\n let baseExtensionsObject: z.ZodObject<any>;\n if (baseExtensions instanceof z.ZodObject) {\n baseExtensionsObject = baseExtensions;\n } else if (baseExtensions) {\n let inner = baseExtensions as any;\n while (\n inner &&\n \"_def\" in inner &&\n [\"ZodOptional\", \"ZodNullable\", \"ZodDefault\"].includes(inner._def.typeName)\n ) {\n inner = inner._def.innerType;\n }\n baseExtensionsObject = inner instanceof z.ZodObject ? inner : z.object({});\n } else {\n baseExtensionsObject = z.object({});\n }\n\n const newExtensions = baseExtensionsObject.extend(shape);\n this.schema = this.schema.extend({\n extensions: newExtensions\n }) as TModel[\"__schema\"];\n\n return this;\n }\n\n withMethods<TExtMethods extends object>(\n methods: TExtMethods & ThisType<TModel & TExtMethods>\n ): ModelBuilder<TModel & TExtMethods> {\n Object.assign(this.methods, methods);\n return this as unknown as ModelBuilder<TModel & TExtMethods>;\n }\n\n getSchema() {\n return this.schema;\n }\n\n build(): ModelClass<TModel> {\n const schema = this.schema;\n const methods = this.methods;\n const name = this.name;\n\n type ModelData = ExtractModelData<TModel>;\n\n class Model extends BaseModel<TModel[\"__schema\"]> {\n public override get __schema() {\n return schema;\n }\n\n static __schema = schema;\n\n static create(data: ModelData) {\n return new this(data) as unknown as TModel;\n }\n\n override clone(): this {\n const Constructor = this.constructor as new (data: ModelData) => this;\n return new Constructor(this.toData());\n }\n }\n\n Object.assign(Model.prototype, methods);\n\n Object.defineProperty(Model.prototype, Symbol.toStringTag, {\n value: name\n });\n\n return Model as unknown as ModelClass<TModel>;\n }\n}\n"],"mappings":"AAAA,SAASA,CAAC,QAAQ,KAAK;AACvB,SAASC,SAAS;AAQlB,OAAO,MAAMC,iBAAiB,GAC1BC,OAAmC,IAClC;EACD,OAAOH,CAAC,CAACI,MAAM,CAAC;IAAE,GAAGD,OAAO,CAACH,CAAC;EAAE,CAAC,CAAC;AACtC,CAAC;AAED,OAAO,MAAMK,YAAY,CAAgC;EAC7CC,OAAO,GAAuC,CAAC,CAAC;EAExDC,WAAWA,CACCC,IAAY,EACZC,MAA0B,EACpC;IAAA,KAFUD,IAAY,GAAZA,IAAY;IAAA,KACZC,MAA0B,GAA1BA,MAA0B;IAElC,IAAI,CAACH,OAAO,GAAG,CAAC,CAAC;EACrB;EAEAI,YAAYA,CAA6BC,WAAoC,EAAQ;IACjF,MAAMC,KAAK,GAAGD,WAAW,CAACX,CAAC,CAAC;IAC5B,MAAMa,cAAc,GAAI,IAAI,CAACJ,MAAM,CAACG,KAAK,CAASE,UAAU;IAE5D,IAAIC,oBAAsC;IAC1C,IAAIF,cAAc,YAAYb,CAAC,CAACgB,SAAS,EAAE;MACvCD,oBAAoB,GAAGF,cAAc;IACzC,CAAC,MAAM,IAAIA,cAAc,EAAE;MACvB,IAAII,KAAK,GAAGJ,cAAqB;MACjC,OACII,KAAK,IACL,MAAM,IAAIA,KAAK,IACf,CAAC,aAAa,EAAE,aAAa,EAAE,YAAY,CAAC,CAACC,QAAQ,CAACD,KAAK,CAACE,IAAI,CAACC,QAAQ,CAAC,EAC5E;QACEH,KAAK,GAAGA,KAAK,CAACE,IAAI,CAACE,SAAS;MAChC;MACAN,oBAAoB,GAAGE,KAAK,YAAYjB,CAAC,CAACgB,SAAS,GAAGC,KAAK,GAAGjB,CAAC,CAACI,MAAM,CAAC,CAAC,CAAC,CAAC;IAC9E,CAAC,MAAM;MACHW,oBAAoB,GAAGf,CAAC,CAACI,MAAM,CAAC,CAAC,CAAC,CAAC;IACvC;IAEA,MAAMkB,aAAa,GAAGP,oBAAoB,CAACQ,MAAM,CAACX,KAAK,CAAC;IACxD,IAAI,CAACH,MAAM,GAAG,IAAI,CAACA,MAAM,CAACc,MAAM,CAAC;MAC7BT,UAAU,EAAEQ;IAChB,CAAC,CAAuB;IAExB,OAAO,IAAI;EACf;EAEAE,WAAWA,CACPlB,OAAqD,EACnB;IAClCmB,MAAM,CAACC,MAAM,CAAC,IAAI,CAACpB,OAAO,EAAEA,OAAO,CAAC;IACpC,OAAO,IAAI;EACf;EAEAqB,SAASA,CAAA,EAAG;IACR,OAAO,IAAI,CAAClB,MAAM;EACtB;EAEAmB,KAAKA,CAAA,EAAuB;IACxB,MAAMnB,MAAM,GAAG,IAAI,CAACA,MAAM;IAC1B,MAAMH,OAAO,GAAG,IAAI,CAACA,OAAO;IAC5B,MAAME,IAAI,GAAG,IAAI,CAACA,IAAI;IAItB,MAAMqB,KAAK,SAAS5B,SAAS,CAAqB;MAC9C,IAAoB6B,QAAQA,CAAA,EAAG;QAC3B,OAAOrB,MAAM;MACjB;MAEA,OAAOqB,QAAQ,GAAGrB,MAAM;MAExB,OAAOsB,MAAMA,CAACC,IAAe,EAAE;QAC3B,OAAO,IAAI,IAAI,CAACA,IAAI,CAAC;MACzB;MAESC,KAAKA,CAAA,EAAS;QACnB,MAAMC,WAAW,GAAG,IAAI,CAAC3B,WAA4C;QACrE,OAAO,IAAI2B,WAAW,CAAC,IAAI,CAACC,MAAM,CAAC,CAAC,CAAC;MACzC;IACJ;IAEAV,MAAM,CAACC,MAAM,CAACG,KAAK,CAACO,SAAS,EAAE9B,OAAO,CAAC;IAEvCmB,MAAM,CAACY,cAAc,CAACR,KAAK,CAACO,SAAS,EAAEE,MAAM,CAACC,WAAW,EAAE;MACvDC,KAAK,EAAEhC;IACX,CAAC,CAAC;IAEF,OAAOqB,KAAK;EAChB;AACJ","ignoreList":[]}
|
|
File without changes
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sources":["ModelFactory.ts"],"sourcesContent":[""],"mappings":"","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,468 @@
|
|
|
1
|
+
import { describe, it, expect } from "vitest";
|
|
2
|
+
import { createModelSchema, ModelBuilder } from "../ModelBuilder.js";
|
|
3
|
+
describe("ModelBuilder", () => {
|
|
4
|
+
describe("Basic functionality", () => {
|
|
5
|
+
it("should create a model class from schema", () => {
|
|
6
|
+
const schema = createModelSchema(z => ({
|
|
7
|
+
id: z.string(),
|
|
8
|
+
name: z.string()
|
|
9
|
+
}));
|
|
10
|
+
const builder = new ModelBuilder("Model", schema);
|
|
11
|
+
const Model = builder.build();
|
|
12
|
+
const instance = new Model({
|
|
13
|
+
id: "1",
|
|
14
|
+
name: "Test"
|
|
15
|
+
});
|
|
16
|
+
expect(instance.id).toBe("1");
|
|
17
|
+
expect(instance.name).toBe("Test");
|
|
18
|
+
});
|
|
19
|
+
it("should expose schema as static property", () => {
|
|
20
|
+
const schema = createModelSchema(z => ({
|
|
21
|
+
id: z.string(),
|
|
22
|
+
name: z.string()
|
|
23
|
+
}));
|
|
24
|
+
const builder = new ModelBuilder("Model", schema);
|
|
25
|
+
const Model = builder.build();
|
|
26
|
+
expect(Model.__schema).toBeDefined();
|
|
27
|
+
});
|
|
28
|
+
it("should validate data on construction", () => {
|
|
29
|
+
const schema = createModelSchema(z => ({
|
|
30
|
+
id: z.string(),
|
|
31
|
+
age: z.number()
|
|
32
|
+
}));
|
|
33
|
+
const builder = new ModelBuilder("Model", schema);
|
|
34
|
+
const Model = builder.build();
|
|
35
|
+
expect(() => {
|
|
36
|
+
new Model({
|
|
37
|
+
id: "1",
|
|
38
|
+
age: "not a number"
|
|
39
|
+
});
|
|
40
|
+
}).toThrow("Validation error");
|
|
41
|
+
});
|
|
42
|
+
it("should throw on missing required fields", () => {
|
|
43
|
+
const schema = createModelSchema(z => ({
|
|
44
|
+
id: z.string(),
|
|
45
|
+
required: z.string()
|
|
46
|
+
}));
|
|
47
|
+
const builder = new ModelBuilder("Model", schema);
|
|
48
|
+
const Model = builder.build();
|
|
49
|
+
expect(() => {
|
|
50
|
+
new Model({
|
|
51
|
+
id: "1"
|
|
52
|
+
});
|
|
53
|
+
}).toThrow("Validation error");
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
describe("withMethods", () => {
|
|
57
|
+
it("should add methods to model", () => {
|
|
58
|
+
const schema = createModelSchema(z => ({
|
|
59
|
+
id: z.string(),
|
|
60
|
+
active: z.boolean()
|
|
61
|
+
}));
|
|
62
|
+
const builder = new ModelBuilder("Model", schema).withMethods({
|
|
63
|
+
isActive() {
|
|
64
|
+
return this.active;
|
|
65
|
+
},
|
|
66
|
+
activate() {
|
|
67
|
+
this.active = true;
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
const Model = builder.build();
|
|
71
|
+
const instance = new Model({
|
|
72
|
+
id: "1",
|
|
73
|
+
active: false
|
|
74
|
+
});
|
|
75
|
+
expect(instance.isActive()).toBe(false);
|
|
76
|
+
instance.activate();
|
|
77
|
+
expect(instance.isActive()).toBe(true);
|
|
78
|
+
});
|
|
79
|
+
it("should chain multiple withMethods calls", () => {
|
|
80
|
+
const schema = createModelSchema(z => ({
|
|
81
|
+
count: z.number()
|
|
82
|
+
}));
|
|
83
|
+
const builder = new ModelBuilder("Model", schema).withMethods({
|
|
84
|
+
increment() {
|
|
85
|
+
this.count++;
|
|
86
|
+
}
|
|
87
|
+
}).withMethods({
|
|
88
|
+
decrement() {
|
|
89
|
+
this.count--;
|
|
90
|
+
}
|
|
91
|
+
});
|
|
92
|
+
const Model = builder.build();
|
|
93
|
+
const instance = new Model({
|
|
94
|
+
count: 5
|
|
95
|
+
});
|
|
96
|
+
instance.increment();
|
|
97
|
+
expect(instance.count).toBe(6);
|
|
98
|
+
instance.decrement();
|
|
99
|
+
expect(instance.count).toBe(5);
|
|
100
|
+
});
|
|
101
|
+
it("should have access to all properties in methods", () => {
|
|
102
|
+
const schema = createModelSchema(z => ({
|
|
103
|
+
firstName: z.string(),
|
|
104
|
+
lastName: z.string()
|
|
105
|
+
}));
|
|
106
|
+
const builder = new ModelBuilder("Model", schema).withMethods({
|
|
107
|
+
getFullName() {
|
|
108
|
+
return `${this.firstName} ${this.lastName}`;
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
const Model = builder.build();
|
|
112
|
+
const instance = new Model({
|
|
113
|
+
firstName: "John",
|
|
114
|
+
lastName: "Doe"
|
|
115
|
+
});
|
|
116
|
+
expect(instance.getFullName()).toBe("John Doe");
|
|
117
|
+
});
|
|
118
|
+
});
|
|
119
|
+
describe("extendSchema", () => {
|
|
120
|
+
it("should extend schema with new fields in extensions", () => {
|
|
121
|
+
const baseSchema = createModelSchema(z => ({
|
|
122
|
+
id: z.string()
|
|
123
|
+
}));
|
|
124
|
+
const builder = new ModelBuilder("Model", baseSchema).extendSchema(z => ({
|
|
125
|
+
name: z.string(),
|
|
126
|
+
age: z.number()
|
|
127
|
+
}));
|
|
128
|
+
const Model = builder.build();
|
|
129
|
+
const instance = new Model({
|
|
130
|
+
id: "1",
|
|
131
|
+
// @ts-expect-error In a real environment, you'll never have everything in one file, so interface will be augmented.
|
|
132
|
+
extensions: {
|
|
133
|
+
name: "Test",
|
|
134
|
+
age: 25
|
|
135
|
+
}
|
|
136
|
+
});
|
|
137
|
+
expect(instance.id).toBe("1");
|
|
138
|
+
// @ts-expect-error
|
|
139
|
+
expect(instance.extensions.name).toBe("Test");
|
|
140
|
+
// @ts-expect-error
|
|
141
|
+
expect(instance.extensions.age).toBe(25);
|
|
142
|
+
});
|
|
143
|
+
it("should validate extended fields", () => {
|
|
144
|
+
const baseSchema = createModelSchema(z => ({
|
|
145
|
+
id: z.string()
|
|
146
|
+
}));
|
|
147
|
+
const builder = new ModelBuilder("Model", baseSchema).extendSchema(z => ({
|
|
148
|
+
email: z.string().email()
|
|
149
|
+
}));
|
|
150
|
+
const Model = builder.build();
|
|
151
|
+
expect(() => {
|
|
152
|
+
// @ts-expect-error
|
|
153
|
+
new Model({
|
|
154
|
+
id: "1",
|
|
155
|
+
extensions: {
|
|
156
|
+
email: "invalid-email"
|
|
157
|
+
}
|
|
158
|
+
});
|
|
159
|
+
}).toThrow("Validation error");
|
|
160
|
+
const valid = new Model({
|
|
161
|
+
id: "1",
|
|
162
|
+
// @ts-expect-error
|
|
163
|
+
extensions: {
|
|
164
|
+
email: "test@example.com"
|
|
165
|
+
}
|
|
166
|
+
});
|
|
167
|
+
// @ts-expect-error
|
|
168
|
+
expect(valid.extensions.email).toBe("test@example.com");
|
|
169
|
+
});
|
|
170
|
+
it("should chain extendSchema calls", () => {
|
|
171
|
+
const baseSchema = createModelSchema(z => ({
|
|
172
|
+
id: z.string()
|
|
173
|
+
}));
|
|
174
|
+
const builder = new ModelBuilder("Model", baseSchema).extendSchema(z => ({
|
|
175
|
+
name: z.string()
|
|
176
|
+
})).extendSchema(z => ({
|
|
177
|
+
age: z.number()
|
|
178
|
+
}));
|
|
179
|
+
const Model = builder.build();
|
|
180
|
+
const instance = new Model({
|
|
181
|
+
id: "1",
|
|
182
|
+
// @ts-expect-error In a real environment, you'll never have everything in one file, so interface will be augmented.
|
|
183
|
+
extensions: {
|
|
184
|
+
name: "Test",
|
|
185
|
+
age: 30
|
|
186
|
+
}
|
|
187
|
+
});
|
|
188
|
+
expect(instance.id).toBe("1");
|
|
189
|
+
// @ts-expect-error
|
|
190
|
+
expect(instance.extensions.name).toBe("Test");
|
|
191
|
+
// @ts-expect-error
|
|
192
|
+
expect(instance.extensions.age).toBe(30);
|
|
193
|
+
});
|
|
194
|
+
it("should preserve methods when extending schema", () => {
|
|
195
|
+
const baseSchema = createModelSchema(z => ({
|
|
196
|
+
count: z.number()
|
|
197
|
+
}));
|
|
198
|
+
const builder = new ModelBuilder("Model", baseSchema).withMethods({
|
|
199
|
+
increment() {
|
|
200
|
+
this.count++;
|
|
201
|
+
}
|
|
202
|
+
}).extendSchema(z => ({
|
|
203
|
+
name: z.string()
|
|
204
|
+
}));
|
|
205
|
+
const Model = builder.build();
|
|
206
|
+
const instance = new Model({
|
|
207
|
+
count: 5,
|
|
208
|
+
// @ts-expect-error
|
|
209
|
+
extensions: {
|
|
210
|
+
name: "Counter"
|
|
211
|
+
}
|
|
212
|
+
});
|
|
213
|
+
instance.increment();
|
|
214
|
+
expect(instance.count).toBe(6);
|
|
215
|
+
// @ts-expect-error
|
|
216
|
+
expect(instance.extensions.name).toBe("Counter");
|
|
217
|
+
});
|
|
218
|
+
});
|
|
219
|
+
describe("clone", () => {
|
|
220
|
+
it("should create a copy of the instance", () => {
|
|
221
|
+
const schema = createModelSchema(z => ({
|
|
222
|
+
id: z.string(),
|
|
223
|
+
name: z.string()
|
|
224
|
+
}));
|
|
225
|
+
const builder = new ModelBuilder("Model", schema);
|
|
226
|
+
const Model = builder.build();
|
|
227
|
+
const original = new Model({
|
|
228
|
+
id: "1",
|
|
229
|
+
name: "Original"
|
|
230
|
+
});
|
|
231
|
+
const cloned = original.clone();
|
|
232
|
+
expect(cloned).not.toBe(original);
|
|
233
|
+
expect(cloned.id).toBe(original.id);
|
|
234
|
+
expect(cloned.name).toBe(original.name);
|
|
235
|
+
});
|
|
236
|
+
it("should clone with methods intact", () => {
|
|
237
|
+
const schema = createModelSchema(z => ({
|
|
238
|
+
count: z.number()
|
|
239
|
+
}));
|
|
240
|
+
const builder = new ModelBuilder("Model", schema).withMethods({
|
|
241
|
+
increment() {
|
|
242
|
+
this.count++;
|
|
243
|
+
}
|
|
244
|
+
});
|
|
245
|
+
const Model = builder.build();
|
|
246
|
+
const original = new Model({
|
|
247
|
+
count: 5
|
|
248
|
+
});
|
|
249
|
+
const cloned = original.clone();
|
|
250
|
+
cloned.increment();
|
|
251
|
+
expect(original.count).toBe(5);
|
|
252
|
+
expect(cloned.count).toBe(6);
|
|
253
|
+
});
|
|
254
|
+
it("should preserve extended properties in clone", () => {
|
|
255
|
+
const schema = createModelSchema(z => ({
|
|
256
|
+
id: z.string()
|
|
257
|
+
}));
|
|
258
|
+
const builder = new ModelBuilder("Model", schema).extendSchema(z => ({
|
|
259
|
+
metadata: z.object({
|
|
260
|
+
key: z.string()
|
|
261
|
+
}).optional()
|
|
262
|
+
}));
|
|
263
|
+
const Model = builder.build();
|
|
264
|
+
const original = new Model({
|
|
265
|
+
id: "1",
|
|
266
|
+
// @ts-expect-error
|
|
267
|
+
extensions: {
|
|
268
|
+
metadata: {
|
|
269
|
+
key: "value"
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
});
|
|
273
|
+
const cloned = original.clone();
|
|
274
|
+
|
|
275
|
+
// @ts-expect-error
|
|
276
|
+
expect(cloned.extensions.metadata).toEqual({
|
|
277
|
+
key: "value"
|
|
278
|
+
});
|
|
279
|
+
});
|
|
280
|
+
});
|
|
281
|
+
describe("updateWith", () => {
|
|
282
|
+
it("should update properties", () => {
|
|
283
|
+
const schema = createModelSchema(z => ({
|
|
284
|
+
id: z.string(),
|
|
285
|
+
name: z.string(),
|
|
286
|
+
age: z.number()
|
|
287
|
+
}));
|
|
288
|
+
const builder = new ModelBuilder("Model", schema);
|
|
289
|
+
const Model = builder.build();
|
|
290
|
+
const instance = Model.create({
|
|
291
|
+
id: "1",
|
|
292
|
+
name: "John",
|
|
293
|
+
age: 25
|
|
294
|
+
});
|
|
295
|
+
instance.updateWith({
|
|
296
|
+
name: "Jane",
|
|
297
|
+
age: 30
|
|
298
|
+
});
|
|
299
|
+
expect(instance.id).toBe("1");
|
|
300
|
+
expect(instance.name).toBe("Jane");
|
|
301
|
+
expect(instance.age).toBe(30);
|
|
302
|
+
});
|
|
303
|
+
it("should validate updated data", () => {
|
|
304
|
+
const schema = createModelSchema(z => ({
|
|
305
|
+
id: z.string(),
|
|
306
|
+
email: z.string().email()
|
|
307
|
+
}));
|
|
308
|
+
const builder = new ModelBuilder("Model", schema);
|
|
309
|
+
const Model = builder.build();
|
|
310
|
+
const instance = new Model({
|
|
311
|
+
id: "1",
|
|
312
|
+
email: "valid@example.com"
|
|
313
|
+
});
|
|
314
|
+
expect(() => {
|
|
315
|
+
instance.updateWith({
|
|
316
|
+
email: "invalid-email"
|
|
317
|
+
});
|
|
318
|
+
}).toThrow("Validation error");
|
|
319
|
+
expect(instance.email).toBe("valid@example.com");
|
|
320
|
+
});
|
|
321
|
+
it("should allow partial updates", () => {
|
|
322
|
+
const schema = createModelSchema(z => ({
|
|
323
|
+
id: z.string(),
|
|
324
|
+
name: z.string(),
|
|
325
|
+
age: z.number()
|
|
326
|
+
}));
|
|
327
|
+
const builder = new ModelBuilder("Model", schema);
|
|
328
|
+
const Model = builder.build();
|
|
329
|
+
const instance = new Model({
|
|
330
|
+
id: "1",
|
|
331
|
+
name: "John",
|
|
332
|
+
age: 25
|
|
333
|
+
});
|
|
334
|
+
instance.updateWith({
|
|
335
|
+
age: 26
|
|
336
|
+
});
|
|
337
|
+
expect(instance.id).toBe("1");
|
|
338
|
+
expect(instance.name).toBe("John");
|
|
339
|
+
expect(instance.age).toBe(26);
|
|
340
|
+
});
|
|
341
|
+
});
|
|
342
|
+
describe("Complex composition", () => {
|
|
343
|
+
it("should handle full extension chain", () => {
|
|
344
|
+
const baseSchema = createModelSchema(z => ({
|
|
345
|
+
id: z.string(),
|
|
346
|
+
title: z.string()
|
|
347
|
+
}));
|
|
348
|
+
const builder = new ModelBuilder("Model", baseSchema).withMethods({
|
|
349
|
+
getTitle() {
|
|
350
|
+
return this.title;
|
|
351
|
+
}
|
|
352
|
+
}).extendSchema(z => ({
|
|
353
|
+
publishedAt: z.date().nullable()
|
|
354
|
+
})).withMethods({
|
|
355
|
+
publish() {
|
|
356
|
+
// @ts-expect-error
|
|
357
|
+
this.extensions.publishedAt = new Date();
|
|
358
|
+
},
|
|
359
|
+
isPublished() {
|
|
360
|
+
// @ts-expect-error
|
|
361
|
+
return this.extensions.publishedAt !== null;
|
|
362
|
+
}
|
|
363
|
+
}).extendSchema(z => ({
|
|
364
|
+
metadata: z.object({
|
|
365
|
+
seo: z.string().optional()
|
|
366
|
+
}).optional()
|
|
367
|
+
})).withMethods({
|
|
368
|
+
hasSeo() {
|
|
369
|
+
// @ts-expect-error
|
|
370
|
+
return !!this.extensions.metadata?.seo;
|
|
371
|
+
}
|
|
372
|
+
});
|
|
373
|
+
const Model = builder.build();
|
|
374
|
+
const instance = new Model({
|
|
375
|
+
id: "1",
|
|
376
|
+
title: "Test Post",
|
|
377
|
+
// @ts-expect-error In a real environment, you'll never have everything in one file, so interface will be augmented.
|
|
378
|
+
extensions: {
|
|
379
|
+
publishedAt: null,
|
|
380
|
+
metadata: {
|
|
381
|
+
seo: "SEO Title"
|
|
382
|
+
}
|
|
383
|
+
}
|
|
384
|
+
});
|
|
385
|
+
instance.title = "Test Post";
|
|
386
|
+
expect(instance.getTitle()).toBe("Test Post");
|
|
387
|
+
expect(instance.isPublished()).toBe(false);
|
|
388
|
+
expect(instance.hasSeo()).toBe(true);
|
|
389
|
+
instance.publish();
|
|
390
|
+
expect(instance.isPublished()).toBe(true);
|
|
391
|
+
});
|
|
392
|
+
it("should support nested object schemas", () => {
|
|
393
|
+
const schema = createModelSchema(z => ({
|
|
394
|
+
id: z.string(),
|
|
395
|
+
author: z.object({
|
|
396
|
+
name: z.string(),
|
|
397
|
+
email: z.string()
|
|
398
|
+
})
|
|
399
|
+
}));
|
|
400
|
+
const builder = new ModelBuilder("Model", schema).withMethods({
|
|
401
|
+
getAuthorName() {
|
|
402
|
+
return this.author.name;
|
|
403
|
+
}
|
|
404
|
+
});
|
|
405
|
+
const Model = builder.build();
|
|
406
|
+
const instance = new Model({
|
|
407
|
+
id: "1",
|
|
408
|
+
author: {
|
|
409
|
+
name: "John",
|
|
410
|
+
email: "john@example.com"
|
|
411
|
+
}
|
|
412
|
+
});
|
|
413
|
+
expect(instance.getAuthorName()).toBe("John");
|
|
414
|
+
});
|
|
415
|
+
it("should support array fields in schema", () => {
|
|
416
|
+
const schema = createModelSchema(z => ({
|
|
417
|
+
id: z.string(),
|
|
418
|
+
tags: z.array(z.string())
|
|
419
|
+
}));
|
|
420
|
+
const builder = new ModelBuilder("Model", schema).withMethods({
|
|
421
|
+
hasTag(tag) {
|
|
422
|
+
return this.tags.includes(tag);
|
|
423
|
+
},
|
|
424
|
+
addTag(tag) {
|
|
425
|
+
if (!this.tags.includes(tag)) {
|
|
426
|
+
this.tags.push(tag);
|
|
427
|
+
}
|
|
428
|
+
}
|
|
429
|
+
});
|
|
430
|
+
const Model = builder.build();
|
|
431
|
+
const instance = new Model({
|
|
432
|
+
id: "1",
|
|
433
|
+
tags: ["typescript", "testing"]
|
|
434
|
+
});
|
|
435
|
+
expect(instance.hasTag("typescript")).toBe(true);
|
|
436
|
+
expect(instance.hasTag("javascript")).toBe(false);
|
|
437
|
+
instance.addTag("javascript");
|
|
438
|
+
expect(instance.hasTag("javascript")).toBe(true);
|
|
439
|
+
});
|
|
440
|
+
});
|
|
441
|
+
describe("getSchema", () => {
|
|
442
|
+
it("should return the current schema", () => {
|
|
443
|
+
const baseSchema = createModelSchema(z => ({
|
|
444
|
+
id: z.string()
|
|
445
|
+
}));
|
|
446
|
+
const builder = new ModelBuilder("Model", baseSchema);
|
|
447
|
+
expect(builder.getSchema()).toBeDefined();
|
|
448
|
+
});
|
|
449
|
+
it("should return extended schema after extendSchema", () => {
|
|
450
|
+
const baseSchema = createModelSchema(z => ({
|
|
451
|
+
id: z.string()
|
|
452
|
+
}));
|
|
453
|
+
const extendedBuilder = new ModelBuilder("Model", baseSchema).extendSchema(z => ({
|
|
454
|
+
name: z.string()
|
|
455
|
+
}));
|
|
456
|
+
const schema = extendedBuilder.getSchema();
|
|
457
|
+
const result = schema.safeParse({
|
|
458
|
+
id: "1",
|
|
459
|
+
extensions: {
|
|
460
|
+
name: "Test"
|
|
461
|
+
}
|
|
462
|
+
});
|
|
463
|
+
expect(result.success).toBe(true);
|
|
464
|
+
});
|
|
465
|
+
});
|
|
466
|
+
});
|
|
467
|
+
|
|
468
|
+
//# sourceMappingURL=ModelBuilder.test.js.map
|