@expo/entity 0.44.0 → 0.46.0
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/build/{AuthorizationResultBasedEntityAssociationLoader.d.ts → src/AuthorizationResultBasedEntityAssociationLoader.d.ts} +4 -4
- package/build/{AuthorizationResultBasedEntityAssociationLoader.js → src/AuthorizationResultBasedEntityAssociationLoader.js} +2 -1
- package/build/src/AuthorizationResultBasedEntityAssociationLoader.js.map +1 -0
- package/build/{AuthorizationResultBasedEntityLoader.d.ts → src/AuthorizationResultBasedEntityLoader.d.ts} +8 -8
- package/build/{AuthorizationResultBasedEntityLoader.js → src/AuthorizationResultBasedEntityLoader.js} +10 -5
- package/build/src/AuthorizationResultBasedEntityLoader.js.map +1 -0
- package/build/{AuthorizationResultBasedEntityMutator.d.ts → src/AuthorizationResultBasedEntityMutator.d.ts} +11 -11
- package/build/{AuthorizationResultBasedEntityMutator.js → src/AuthorizationResultBasedEntityMutator.js} +2 -2
- package/build/src/AuthorizationResultBasedEntityMutator.js.map +1 -0
- package/build/{ComposedEntityCacheAdapter.d.ts → src/ComposedEntityCacheAdapter.d.ts} +2 -2
- package/build/{ComposedEntityCacheAdapter.js → src/ComposedEntityCacheAdapter.js} +2 -1
- package/build/src/ComposedEntityCacheAdapter.js.map +1 -0
- package/build/{ComposedSecondaryEntityCache.d.ts → src/ComposedSecondaryEntityCache.d.ts} +1 -1
- package/build/{ComposedSecondaryEntityCache.js → src/ComposedSecondaryEntityCache.js} +2 -1
- package/build/src/ComposedSecondaryEntityCache.js.map +1 -0
- package/build/{EnforcingEntityAssociationLoader.d.ts → src/EnforcingEntityAssociationLoader.d.ts} +5 -5
- package/build/{EnforcingEntityAssociationLoader.js → src/EnforcingEntityAssociationLoader.js} +2 -1
- package/build/src/EnforcingEntityAssociationLoader.js.map +1 -0
- package/build/{EnforcingEntityCreator.d.ts → src/EnforcingEntityCreator.d.ts} +4 -4
- package/build/{EnforcingEntityCreator.js → src/EnforcingEntityCreator.js} +2 -1
- package/build/src/EnforcingEntityCreator.js.map +1 -0
- package/build/{EnforcingEntityDeleter.d.ts → src/EnforcingEntityDeleter.d.ts} +4 -4
- package/build/{EnforcingEntityDeleter.js → src/EnforcingEntityDeleter.js} +2 -1
- package/build/src/EnforcingEntityDeleter.js.map +1 -0
- package/build/{EnforcingEntityLoader.d.ts → src/EnforcingEntityLoader.d.ts} +5 -5
- package/build/{EnforcingEntityLoader.js → src/EnforcingEntityLoader.js} +2 -1
- package/build/src/EnforcingEntityLoader.js.map +1 -0
- package/build/{EnforcingEntityUpdater.d.ts → src/EnforcingEntityUpdater.d.ts} +4 -4
- package/build/{EnforcingEntityUpdater.js → src/EnforcingEntityUpdater.js} +2 -1
- package/build/src/EnforcingEntityUpdater.js.map +1 -0
- package/build/{Entity.d.ts → src/Entity.d.ts} +7 -7
- package/build/{Entity.js → src/Entity.js} +13 -15
- package/build/src/Entity.js.map +1 -0
- package/build/{EntityAssociationLoader.d.ts → src/EntityAssociationLoader.d.ts} +5 -5
- package/build/{EntityAssociationLoader.js → src/EntityAssociationLoader.js} +6 -8
- package/build/src/EntityAssociationLoader.js.map +1 -0
- package/build/{EntityCompanion.d.ts → src/EntityCompanion.d.ts} +10 -10
- package/build/{EntityCompanion.js → src/EntityCompanion.js} +6 -8
- package/build/src/EntityCompanion.js.map +1 -0
- package/build/{EntityCompanionProvider.d.ts → src/EntityCompanionProvider.d.ts} +12 -12
- package/build/{EntityCompanionProvider.js → src/EntityCompanionProvider.js} +6 -5
- package/build/src/EntityCompanionProvider.js.map +1 -0
- package/build/{EntityConfiguration.d.ts → src/EntityConfiguration.d.ts} +2 -2
- package/build/{EntityConfiguration.js → src/EntityConfiguration.js} +2 -2
- package/build/src/EntityConfiguration.js.map +1 -0
- package/build/{EntityCreator.d.ts → src/EntityCreator.d.ts} +5 -5
- package/build/{EntityCreator.js → src/EntityCreator.js} +4 -6
- package/build/{EntityCreator.js.map → src/EntityCreator.js.map} +1 -1
- package/build/{EntityDatabaseAdapter.d.ts → src/EntityDatabaseAdapter.d.ts} +2 -2
- package/build/{EntityDatabaseAdapter.js → src/EntityDatabaseAdapter.js} +2 -2
- package/build/src/EntityDatabaseAdapter.js.map +1 -0
- package/build/{EntityDeleter.d.ts → src/EntityDeleter.d.ts} +5 -5
- package/build/{EntityDeleter.js → src/EntityDeleter.js} +4 -6
- package/build/{EntityDeleter.js.map → src/EntityDeleter.js.map} +1 -1
- package/build/{EntityFieldDefinition.d.ts → src/EntityFieldDefinition.d.ts} +3 -3
- package/build/src/EntityFieldDefinition.js.map +1 -0
- package/build/src/EntityFields.js.map +1 -0
- package/build/{EntityLoader.d.ts → src/EntityLoader.d.ts} +7 -7
- package/build/{EntityLoader.js → src/EntityLoader.js} +4 -6
- package/build/{EntityLoader.js.map → src/EntityLoader.js.map} +1 -1
- package/build/{EntityLoaderFactory.d.ts → src/EntityLoaderFactory.d.ts} +8 -8
- package/build/src/EntityLoaderFactory.js +29 -0
- package/build/src/EntityLoaderFactory.js.map +1 -0
- package/build/{EntityLoaderUtils.d.ts → src/EntityLoaderUtils.d.ts} +7 -7
- package/build/{EntityLoaderUtils.js → src/EntityLoaderUtils.js} +2 -1
- package/build/src/EntityLoaderUtils.js.map +1 -0
- package/build/{EntityMutationInfo.d.ts → src/EntityMutationInfo.d.ts} +2 -2
- package/build/src/EntityMutationInfo.js.map +1 -0
- package/build/{EntityMutationTriggerConfiguration.d.ts → src/EntityMutationTriggerConfiguration.d.ts} +3 -3
- package/build/src/EntityMutationTriggerConfiguration.js.map +1 -0
- package/build/{EntityMutationValidator.d.ts → src/EntityMutationValidator.d.ts} +3 -3
- package/build/{EntityMutationValidator.js → src/EntityMutationValidator.js} +2 -1
- package/build/src/EntityMutationValidator.js.map +1 -0
- package/build/{EntityMutatorFactory.d.ts → src/EntityMutatorFactory.d.ts} +12 -12
- package/build/{EntityMutatorFactory.js → src/EntityMutatorFactory.js} +2 -1
- package/build/src/EntityMutatorFactory.js.map +1 -0
- package/build/{EntityPrivacyPolicy.d.ts → src/EntityPrivacyPolicy.d.ts} +6 -6
- package/build/{EntityPrivacyPolicy.js → src/EntityPrivacyPolicy.js} +8 -11
- package/build/{EntityPrivacyPolicy.js.map → src/EntityPrivacyPolicy.js.map} +1 -1
- package/build/{EntityQueryContext.d.ts → src/EntityQueryContext.d.ts} +1 -1
- package/build/src/EntityQueryContext.js.map +1 -0
- package/build/{EntityQueryContextProvider.d.ts → src/EntityQueryContextProvider.d.ts} +2 -2
- package/build/{EntityQueryContextProvider.js → src/EntityQueryContextProvider.js} +2 -1
- package/build/src/EntityQueryContextProvider.js.map +1 -0
- package/build/{EntitySecondaryCacheLoader.d.ts → src/EntitySecondaryCacheLoader.d.ts} +5 -5
- package/build/{EntitySecondaryCacheLoader.js → src/EntitySecondaryCacheLoader.js} +2 -1
- package/build/src/EntitySecondaryCacheLoader.js.map +1 -0
- package/build/{EntityUpdater.d.ts → src/EntityUpdater.d.ts} +5 -5
- package/build/{EntityUpdater.js → src/EntityUpdater.js} +4 -6
- package/build/{EntityUpdater.js.map → src/EntityUpdater.js.map} +1 -1
- package/build/{GenericEntityCacheAdapter.d.ts → src/GenericEntityCacheAdapter.d.ts} +3 -3
- package/build/{GenericEntityCacheAdapter.js → src/GenericEntityCacheAdapter.js} +2 -1
- package/build/src/GenericEntityCacheAdapter.js.map +1 -0
- package/build/{GenericSecondaryEntityCache.d.ts → src/GenericSecondaryEntityCache.d.ts} +2 -2
- package/build/{GenericSecondaryEntityCache.js → src/GenericSecondaryEntityCache.js} +2 -1
- package/build/src/GenericSecondaryEntityCache.js.map +1 -0
- package/build/{IEntityCacheAdapter.d.ts → src/IEntityCacheAdapter.d.ts} +1 -1
- package/build/src/IEntityCacheAdapter.js.map +1 -0
- package/build/{IEntityCacheAdapterProvider.d.ts → src/IEntityCacheAdapterProvider.d.ts} +3 -3
- package/build/src/IEntityCacheAdapterProvider.js.map +1 -0
- package/build/{IEntityDatabaseAdapterProvider.d.ts → src/IEntityDatabaseAdapterProvider.d.ts} +3 -3
- package/build/src/IEntityDatabaseAdapterProvider.js.map +1 -0
- package/build/{IEntityGenericCacher.d.ts → src/IEntityGenericCacher.d.ts} +1 -1
- package/build/src/IEntityGenericCacher.js.map +1 -0
- package/build/{ReadonlyEntity.d.ts → src/ReadonlyEntity.d.ts} +8 -8
- package/build/{ReadonlyEntity.js → src/ReadonlyEntity.js} +9 -8
- package/build/src/ReadonlyEntity.js.map +1 -0
- package/build/{ViewerContext.d.ts → src/ViewerContext.d.ts} +5 -5
- package/build/{ViewerContext.js → src/ViewerContext.js} +4 -6
- package/build/{ViewerContext.js.map → src/ViewerContext.js.map} +1 -1
- package/build/{ViewerScopedEntityCompanion.d.ts → src/ViewerScopedEntityCompanion.d.ts} +9 -9
- package/build/{ViewerScopedEntityCompanion.js → src/ViewerScopedEntityCompanion.js} +6 -8
- package/build/{ViewerScopedEntityCompanion.js.map → src/ViewerScopedEntityCompanion.js.map} +1 -1
- package/build/{ViewerScopedEntityCompanionProvider.d.ts → src/ViewerScopedEntityCompanionProvider.d.ts} +6 -6
- package/build/{ViewerScopedEntityCompanionProvider.js → src/ViewerScopedEntityCompanionProvider.js} +4 -6
- package/build/src/ViewerScopedEntityCompanionProvider.js.map +1 -0
- package/build/{ViewerScopedEntityLoaderFactory.d.ts → src/ViewerScopedEntityLoaderFactory.d.ts} +6 -6
- package/build/{ViewerScopedEntityLoaderFactory.js → src/ViewerScopedEntityLoaderFactory.js} +2 -1
- package/build/src/ViewerScopedEntityLoaderFactory.js.map +1 -0
- package/build/{ViewerScopedEntityMutatorFactory.d.ts → src/ViewerScopedEntityMutatorFactory.d.ts} +6 -6
- package/build/{ViewerScopedEntityMutatorFactory.js → src/ViewerScopedEntityMutatorFactory.js} +2 -1
- package/build/src/ViewerScopedEntityMutatorFactory.js.map +1 -0
- package/build/src/__tests__/AuthorizationResultBasedEntityAssociationLoader-test.d.ts +1 -0
- package/build/src/__tests__/AuthorizationResultBasedEntityAssociationLoader-test.js +240 -0
- package/build/src/__tests__/AuthorizationResultBasedEntityAssociationLoader-test.js.map +1 -0
- package/build/src/__tests__/AuthorizationResultBasedEntityLoader-constructor-test.d.ts +26 -0
- package/build/src/__tests__/AuthorizationResultBasedEntityLoader-constructor-test.js +109 -0
- package/build/src/__tests__/AuthorizationResultBasedEntityLoader-constructor-test.js.map +1 -0
- package/build/src/__tests__/AuthorizationResultBasedEntityLoader-test.d.ts +1 -0
- package/build/src/__tests__/AuthorizationResultBasedEntityLoader-test.js +590 -0
- package/build/src/__tests__/AuthorizationResultBasedEntityLoader-test.js.map +1 -0
- package/build/src/__tests__/ComposedCacheAdapter-test.d.ts +1 -0
- package/build/src/__tests__/ComposedCacheAdapter-test.js +259 -0
- package/build/src/__tests__/ComposedCacheAdapter-test.js.map +1 -0
- package/build/src/__tests__/ComposedSecondaryEntityCache-test.d.ts +1 -0
- package/build/src/__tests__/ComposedSecondaryEntityCache-test.js +67 -0
- package/build/src/__tests__/ComposedSecondaryEntityCache-test.js.map +1 -0
- package/build/src/__tests__/EnforcingEntityAssociationLoader-test.d.ts +1 -0
- package/build/src/__tests__/EnforcingEntityAssociationLoader-test.js +113 -0
- package/build/src/__tests__/EnforcingEntityAssociationLoader-test.js.map +1 -0
- package/build/src/__tests__/EnforcingEntityLoader-test.d.ts +1 -0
- package/build/src/__tests__/EnforcingEntityLoader-test.js +316 -0
- package/build/src/__tests__/EnforcingEntityLoader-test.js.map +1 -0
- package/build/src/__tests__/Entity-test.d.ts +1 -0
- package/build/src/__tests__/Entity-test.js +92 -0
- package/build/src/__tests__/Entity-test.js.map +1 -0
- package/build/src/__tests__/EntityAssociationLoader-test.d.ts +1 -0
- package/build/src/__tests__/EntityAssociationLoader-test.js +28 -0
- package/build/src/__tests__/EntityAssociationLoader-test.js.map +1 -0
- package/build/src/__tests__/EntityCommonUseCases-test.d.ts +1 -0
- package/build/src/__tests__/EntityCommonUseCases-test.js +111 -0
- package/build/src/__tests__/EntityCommonUseCases-test.js.map +1 -0
- package/build/src/__tests__/EntityCompanion-test.d.ts +1 -0
- package/build/src/__tests__/EntityCompanion-test.js +42 -0
- package/build/src/__tests__/EntityCompanion-test.js.map +1 -0
- package/build/src/__tests__/EntityCompanionProvider-test.d.ts +1 -0
- package/build/src/__tests__/EntityCompanionProvider-test.js +53 -0
- package/build/src/__tests__/EntityCompanionProvider-test.js.map +1 -0
- package/build/src/__tests__/EntityConfiguration-test.d.ts +1 -0
- package/build/src/__tests__/EntityConfiguration-test.js +164 -0
- package/build/src/__tests__/EntityConfiguration-test.js.map +1 -0
- package/build/src/__tests__/EntityDatabaseAdapter-test.d.ts +1 -0
- package/build/src/__tests__/EntityDatabaseAdapter-test.js +189 -0
- package/build/src/__tests__/EntityDatabaseAdapter-test.js.map +1 -0
- package/build/src/__tests__/EntityEdges-test.d.ts +1 -0
- package/build/src/__tests__/EntityEdges-test.js +680 -0
- package/build/src/__tests__/EntityEdges-test.js.map +1 -0
- package/build/src/__tests__/EntityFields-test.d.ts +1 -0
- package/build/src/__tests__/EntityFields-test.js +61 -0
- package/build/src/__tests__/EntityFields-test.js.map +1 -0
- package/build/src/__tests__/EntityLoader-test.d.ts +1 -0
- package/build/src/__tests__/EntityLoader-test.js +34 -0
- package/build/src/__tests__/EntityLoader-test.js.map +1 -0
- package/build/src/__tests__/EntityMutator-MutationCacheConsistency-test.d.ts +1 -0
- package/build/src/__tests__/EntityMutator-MutationCacheConsistency-test.js +71 -0
- package/build/src/__tests__/EntityMutator-MutationCacheConsistency-test.js.map +1 -0
- package/build/src/__tests__/EntityMutator-SingleCompositeFieldCacheConsistency-test.d.ts +1 -0
- package/build/src/__tests__/EntityMutator-SingleCompositeFieldCacheConsistency-test.js +54 -0
- package/build/src/__tests__/EntityMutator-SingleCompositeFieldCacheConsistency-test.js.map +1 -0
- package/build/src/__tests__/EntityMutator-test.d.ts +1 -0
- package/build/src/__tests__/EntityMutator-test.js +721 -0
- package/build/src/__tests__/EntityMutator-test.js.map +1 -0
- package/build/src/__tests__/EntityPrivacyPolicy-test.d.ts +1 -0
- package/build/src/__tests__/EntityPrivacyPolicy-test.js +429 -0
- package/build/src/__tests__/EntityPrivacyPolicy-test.js.map +1 -0
- package/build/src/__tests__/EntityQueryContext-test.d.ts +1 -0
- package/build/src/__tests__/EntityQueryContext-test.js +181 -0
- package/build/src/__tests__/EntityQueryContext-test.js.map +1 -0
- package/build/src/__tests__/EntitySecondaryCacheLoader-test.d.ts +1 -0
- package/build/src/__tests__/EntitySecondaryCacheLoader-test.js +58 -0
- package/build/src/__tests__/EntitySecondaryCacheLoader-test.js.map +1 -0
- package/build/src/__tests__/EntitySelfReferentialEdges-test.d.ts +1 -0
- package/build/src/__tests__/EntitySelfReferentialEdges-test.js +196 -0
- package/build/src/__tests__/EntitySelfReferentialEdges-test.js.map +1 -0
- package/build/src/__tests__/GenericEntityCacheAdapter-test.d.ts +1 -0
- package/build/src/__tests__/GenericEntityCacheAdapter-test.js +95 -0
- package/build/src/__tests__/GenericEntityCacheAdapter-test.js.map +1 -0
- package/build/src/__tests__/ReadonlyEntity-test.d.ts +1 -0
- package/build/src/__tests__/ReadonlyEntity-test.js +209 -0
- package/build/src/__tests__/ReadonlyEntity-test.js.map +1 -0
- package/build/src/__tests__/ViewerContext-test.d.ts +1 -0
- package/build/src/__tests__/ViewerContext-test.js +28 -0
- package/build/src/__tests__/ViewerContext-test.js.map +1 -0
- package/build/src/__tests__/ViewerScopedEntityCompanion-test.d.ts +1 -0
- package/build/src/__tests__/ViewerScopedEntityCompanion-test.js +18 -0
- package/build/src/__tests__/ViewerScopedEntityCompanion-test.js.map +1 -0
- package/build/src/__tests__/ViewerScopedEntityCompanionProvider-test.d.ts +1 -0
- package/build/src/__tests__/ViewerScopedEntityCompanionProvider-test.js +18 -0
- package/build/src/__tests__/ViewerScopedEntityCompanionProvider-test.js.map +1 -0
- package/build/src/__tests__/ViewerScopedEntityLoaderFactory-test.d.ts +1 -0
- package/build/src/__tests__/ViewerScopedEntityLoaderFactory-test.js +21 -0
- package/build/src/__tests__/ViewerScopedEntityLoaderFactory-test.js.map +1 -0
- package/build/src/__tests__/ViewerScopedEntityMutatorFactory-test.d.ts +1 -0
- package/build/src/__tests__/ViewerScopedEntityMutatorFactory-test.js +20 -0
- package/build/src/__tests__/ViewerScopedEntityMutatorFactory-test.js.map +1 -0
- package/build/src/__tests__/cases/TwoEntitySameTableDisjointRows-test.d.ts +1 -0
- package/build/src/__tests__/cases/TwoEntitySameTableDisjointRows-test.js +121 -0
- package/build/src/__tests__/cases/TwoEntitySameTableDisjointRows-test.js.map +1 -0
- package/build/src/__tests__/cases/TwoEntitySameTableOverlappingRows-test.d.ts +1 -0
- package/build/src/__tests__/cases/TwoEntitySameTableOverlappingRows-test.js +119 -0
- package/build/src/__tests__/cases/TwoEntitySameTableOverlappingRows-test.js.map +1 -0
- package/build/src/__tests__/entityUtils-test.d.ts +1 -0
- package/build/src/__tests__/entityUtils-test.js +88 -0
- package/build/src/__tests__/entityUtils-test.js.map +1 -0
- package/build/src/entityUtils.js.map +1 -0
- package/build/{errors → src/errors}/EntityCacheAdapterError.d.ts +2 -2
- package/build/src/errors/EntityCacheAdapterError.js +13 -0
- package/build/src/errors/EntityCacheAdapterError.js.map +1 -0
- package/build/{errors → src/errors}/EntityDatabaseAdapterError.d.ts +2 -2
- package/build/{errors → src/errors}/EntityDatabaseAdapterError.js +4 -37
- package/build/src/errors/EntityDatabaseAdapterError.js.map +1 -0
- package/build/{errors → src/errors}/EntityError.d.ts +1 -1
- package/build/{errors → src/errors}/EntityError.js +2 -2
- package/build/src/errors/EntityError.js.map +1 -0
- package/build/{errors → src/errors}/EntityInvalidFieldValueError.d.ts +5 -5
- package/build/src/errors/EntityInvalidFieldValueError.js +13 -0
- package/build/src/errors/EntityInvalidFieldValueError.js.map +1 -0
- package/build/{errors → src/errors}/EntityNotAuthorizedError.d.ts +4 -4
- package/build/src/errors/EntityNotAuthorizedError.js +16 -0
- package/build/src/errors/EntityNotAuthorizedError.js.map +1 -0
- package/build/src/errors/EntityNotFoundError.d.ts +17 -0
- package/build/src/errors/EntityNotFoundError.js +18 -0
- package/build/src/errors/EntityNotFoundError.js.map +1 -0
- package/build/src/errors/__tests__/EntityDatabaseAdapterError-test.d.ts +1 -0
- package/build/src/errors/__tests__/EntityDatabaseAdapterError-test.js +21 -0
- package/build/src/errors/__tests__/EntityDatabaseAdapterError-test.js.map +1 -0
- package/build/src/index.d.ts +76 -0
- package/build/src/index.js +94 -0
- package/build/src/index.js.map +1 -0
- package/build/{internal → src/internal}/CompositeFieldHolder.d.ts +1 -1
- package/build/src/internal/CompositeFieldHolder.js.map +1 -0
- package/build/src/internal/CompositeFieldValueMap.js.map +1 -0
- package/build/{internal → src/internal}/EntityDataManager.d.ts +5 -5
- package/build/{internal → src/internal}/EntityDataManager.js +2 -1
- package/build/src/internal/EntityDataManager.js.map +1 -0
- package/build/{internal → src/internal}/EntityFieldTransformationUtils.d.ts +1 -1
- package/build/src/internal/EntityFieldTransformationUtils.js.map +1 -0
- package/build/{internal → src/internal}/EntityLoadInterfaces.d.ts +1 -1
- package/build/src/internal/EntityLoadInterfaces.js.map +1 -0
- package/build/{internal → src/internal}/EntityTableDataCoordinator.d.ts +9 -9
- package/build/{internal → src/internal}/EntityTableDataCoordinator.js +5 -7
- package/build/{internal → src/internal}/EntityTableDataCoordinator.js.map +1 -1
- package/build/{internal → src/internal}/ReadThroughEntityCache.d.ts +3 -3
- package/build/{internal → src/internal}/ReadThroughEntityCache.js +2 -2
- package/build/src/internal/ReadThroughEntityCache.js.map +1 -0
- package/build/{internal → src/internal}/SingleFieldHolder.d.ts +1 -1
- package/build/src/internal/SingleFieldHolder.js.map +1 -0
- package/build/src/internal/__tests__/CompositeFieldHolder-test.d.ts +1 -0
- package/build/src/internal/__tests__/CompositeFieldHolder-test.js +25 -0
- package/build/src/internal/__tests__/CompositeFieldHolder-test.js.map +1 -0
- package/build/src/internal/__tests__/CompositeFieldValueMap-test.d.ts +1 -0
- package/build/src/internal/__tests__/CompositeFieldValueMap-test.js +40 -0
- package/build/src/internal/__tests__/CompositeFieldValueMap-test.js.map +1 -0
- package/build/src/internal/__tests__/EntityDataManager-test.d.ts +1 -0
- package/build/src/internal/__tests__/EntityDataManager-test.js +666 -0
- package/build/src/internal/__tests__/EntityDataManager-test.js.map +1 -0
- package/build/src/internal/__tests__/EntityFieldTransformationUtils-test.d.ts +1 -0
- package/build/src/internal/__tests__/EntityFieldTransformationUtils-test.js +135 -0
- package/build/src/internal/__tests__/EntityFieldTransformationUtils-test.js.map +1 -0
- package/build/src/internal/__tests__/ReadThroughEntityCache-test.d.ts +1 -0
- package/build/src/internal/__tests__/ReadThroughEntityCache-test.js +217 -0
- package/build/src/internal/__tests__/ReadThroughEntityCache-test.js.map +1 -0
- package/build/{metrics → src/metrics}/EntityMetricsUtils.d.ts +1 -1
- package/build/src/metrics/EntityMetricsUtils.js.map +1 -0
- package/build/{metrics → src/metrics}/IEntityMetricsAdapter.d.ts +1 -1
- package/build/src/metrics/IEntityMetricsAdapter.js.map +1 -0
- package/build/{metrics → src/metrics}/NoOpEntityMetricsAdapter.d.ts +2 -2
- package/build/{metrics → src/metrics}/NoOpEntityMetricsAdapter.js +2 -1
- package/build/src/metrics/NoOpEntityMetricsAdapter.js.map +1 -0
- package/build/{rules → src/rules}/AlwaysAllowPrivacyPolicyRule.d.ts +4 -4
- package/build/src/rules/AlwaysAllowPrivacyPolicyRule.js +14 -0
- package/build/src/rules/AlwaysAllowPrivacyPolicyRule.js.map +1 -0
- package/build/{rules → src/rules}/AlwaysDenyPrivacyPolicyRule.d.ts +4 -4
- package/build/src/rules/AlwaysDenyPrivacyPolicyRule.js +14 -0
- package/build/src/rules/AlwaysDenyPrivacyPolicyRule.js.map +1 -0
- package/build/{rules → src/rules}/AlwaysSkipPrivacyPolicyRule.d.ts +4 -4
- package/build/src/rules/AlwaysSkipPrivacyPolicyRule.js +14 -0
- package/build/src/rules/AlwaysSkipPrivacyPolicyRule.js.map +1 -0
- package/build/{rules → src/rules}/PrivacyPolicyRule.d.ts +3 -3
- package/build/{rules → src/rules}/PrivacyPolicyRule.js +2 -2
- package/build/src/rules/PrivacyPolicyRule.js.map +1 -0
- package/build/src/rules/__tests__/AlwaysAllowPrivacyPolicyRule-test.d.ts +1 -0
- package/build/src/rules/__tests__/AlwaysAllowPrivacyPolicyRule-test.js +18 -0
- package/build/src/rules/__tests__/AlwaysAllowPrivacyPolicyRule-test.js.map +1 -0
- package/build/src/rules/__tests__/AlwaysDenyPrivacyPolicyRule-test.d.ts +1 -0
- package/build/src/rules/__tests__/AlwaysDenyPrivacyPolicyRule-test.js +18 -0
- package/build/src/rules/__tests__/AlwaysDenyPrivacyPolicyRule-test.js.map +1 -0
- package/build/src/rules/__tests__/AlwaysSkipPrivacyPolicyRule-test.d.ts +1 -0
- package/build/src/rules/__tests__/AlwaysSkipPrivacyPolicyRule-test.js +18 -0
- package/build/src/rules/__tests__/AlwaysSkipPrivacyPolicyRule-test.js.map +1 -0
- package/build/src/utils/EntityCreationUtils.d.ts +14 -0
- package/build/src/utils/EntityCreationUtils.js +54 -0
- package/build/src/utils/EntityCreationUtils.js.map +1 -0
- package/build/{utils → src/utils}/EntityPrivacyUtils.d.ts +4 -4
- package/build/{utils → src/utils}/EntityPrivacyUtils.js +4 -7
- package/build/{utils → src/utils}/EntityPrivacyUtils.js.map +1 -1
- package/build/src/utils/__testfixtures__/PrivacyPolicyRuleTestUtils.d.ts +28 -0
- package/build/src/utils/__testfixtures__/PrivacyPolicyRuleTestUtils.js +53 -0
- package/build/src/utils/__testfixtures__/PrivacyPolicyRuleTestUtils.js.map +1 -0
- package/build/src/utils/__testfixtures__/SimpleTestEntity.d.ts +20 -0
- package/build/src/utils/__testfixtures__/SimpleTestEntity.js +46 -0
- package/build/src/utils/__testfixtures__/SimpleTestEntity.js.map +1 -0
- package/build/src/utils/__testfixtures__/StubCacheAdapter.d.ts +29 -0
- package/build/src/utils/__testfixtures__/StubCacheAdapter.js +103 -0
- package/build/src/utils/__testfixtures__/StubCacheAdapter.js.map +1 -0
- package/build/src/utils/__testfixtures__/StubDatabaseAdapter.d.ts +26 -0
- package/build/src/utils/__testfixtures__/StubDatabaseAdapter.js +173 -0
- package/build/src/utils/__testfixtures__/StubDatabaseAdapter.js.map +1 -0
- package/build/src/utils/__testfixtures__/StubDatabaseAdapterProvider.d.ts +7 -0
- package/build/src/utils/__testfixtures__/StubDatabaseAdapterProvider.js +12 -0
- package/build/src/utils/__testfixtures__/StubDatabaseAdapterProvider.js.map +1 -0
- package/build/src/utils/__testfixtures__/StubQueryContextProvider.d.ts +7 -0
- package/build/src/utils/__testfixtures__/StubQueryContextProvider.js +17 -0
- package/build/src/utils/__testfixtures__/StubQueryContextProvider.js.map +1 -0
- package/build/src/utils/__testfixtures__/TSMockitoExtensions.d.ts +9 -0
- package/build/src/utils/__testfixtures__/TSMockitoExtensions.js +65 -0
- package/build/src/utils/__testfixtures__/TSMockitoExtensions.js.map +1 -0
- package/build/src/utils/__testfixtures__/TestEntity.d.ts +30 -0
- package/build/src/utils/__testfixtures__/TestEntity.js +96 -0
- package/build/src/utils/__testfixtures__/TestEntity.js.map +1 -0
- package/build/src/utils/__testfixtures__/TestEntity2.d.ts +20 -0
- package/build/src/utils/__testfixtures__/TestEntity2.js +49 -0
- package/build/src/utils/__testfixtures__/TestEntity2.js.map +1 -0
- package/build/src/utils/__testfixtures__/TestEntityWithMutationTriggers.d.ts +36 -0
- package/build/src/utils/__testfixtures__/TestEntityWithMutationTriggers.js +80 -0
- package/build/src/utils/__testfixtures__/TestEntityWithMutationTriggers.js.map +1 -0
- package/build/src/utils/__testfixtures__/TestViewerContext.d.ts +3 -0
- package/build/src/utils/__testfixtures__/TestViewerContext.js +8 -0
- package/build/src/utils/__testfixtures__/TestViewerContext.js.map +1 -0
- package/build/src/utils/__testfixtures__/createUnitTestEntityCompanionProvider.d.ts +7 -0
- package/build/src/utils/__testfixtures__/createUnitTestEntityCompanionProvider.js +33 -0
- package/build/src/utils/__testfixtures__/createUnitTestEntityCompanionProvider.js.map +1 -0
- package/build/src/utils/__testfixtures__/describeFieldTestCase.d.ts +2 -0
- package/build/src/utils/__testfixtures__/describeFieldTestCase.js +19 -0
- package/build/src/utils/__testfixtures__/describeFieldTestCase.js.map +1 -0
- package/build/src/utils/__tests__/EntityCreationUtils-test.d.ts +1 -0
- package/build/src/utils/__tests__/EntityCreationUtils-test.js +144 -0
- package/build/src/utils/__tests__/EntityCreationUtils-test.js.map +1 -0
- package/build/src/utils/__tests__/EntityPrivacyUtils-test.d.ts +1 -0
- package/build/src/utils/__tests__/EntityPrivacyUtils-test.js +460 -0
- package/build/src/utils/__tests__/EntityPrivacyUtils-test.js.map +1 -0
- package/build/src/utils/__tests__/canViewerDeleteAsync-edgeDeletionPermissionInferenceBehavior-test.d.ts +1 -0
- package/build/src/utils/__tests__/canViewerDeleteAsync-edgeDeletionPermissionInferenceBehavior-test.js +180 -0
- package/build/src/utils/__tests__/canViewerDeleteAsync-edgeDeletionPermissionInferenceBehavior-test.js.map +1 -0
- package/build/src/utils/__tests__/mergeEntityMutationTriggerConfigurations-test.d.ts +1 -0
- package/build/src/utils/__tests__/mergeEntityMutationTriggerConfigurations-test.js +27 -0
- package/build/src/utils/__tests__/mergeEntityMutationTriggerConfigurations-test.js.map +1 -0
- package/build/src/utils/collections/SerializableKeyMap.js.map +1 -0
- package/build/src/utils/collections/__tests__/SerializableKeyMap-test.d.ts +5 -0
- package/build/src/utils/collections/__tests__/SerializableKeyMap-test.js +99 -0
- package/build/src/utils/collections/__tests__/SerializableKeyMap-test.js.map +1 -0
- package/build/src/utils/collections/__tests__/maps-test.d.ts +1 -0
- package/build/src/utils/collections/__tests__/maps-test.js +121 -0
- package/build/src/utils/collections/__tests__/maps-test.js.map +1 -0
- package/build/src/utils/collections/__tests__/sets-test.d.ts +1 -0
- package/build/src/utils/collections/__tests__/sets-test.js +19 -0
- package/build/src/utils/collections/__tests__/sets-test.js.map +1 -0
- package/build/src/utils/collections/maps.js.map +1 -0
- package/build/src/utils/collections/sets.js.map +1 -0
- package/build/{utils → src/utils}/mergeEntityMutationTriggerConfigurations.d.ts +3 -3
- package/build/src/utils/mergeEntityMutationTriggerConfigurations.js.map +1 -0
- package/build/tsconfig.tsbuildinfo +1 -0
- package/package.json +11 -23
- package/src/AuthorizationResultBasedEntityAssociationLoader.ts +4 -4
- package/src/AuthorizationResultBasedEntityLoader.ts +20 -13
- package/src/AuthorizationResultBasedEntityMutator.ts +15 -14
- package/src/ComposedEntityCacheAdapter.ts +3 -3
- package/src/ComposedSecondaryEntityCache.ts +1 -1
- package/src/EnforcingEntityAssociationLoader.ts +6 -5
- package/src/EnforcingEntityCreator.ts +4 -4
- package/src/EnforcingEntityDeleter.ts +4 -4
- package/src/EnforcingEntityLoader.ts +5 -5
- package/src/EnforcingEntityUpdater.ts +4 -4
- package/src/Entity.ts +10 -10
- package/src/EntityAssociationLoader.ts +5 -5
- package/src/EntityCompanion.ts +10 -10
- package/src/EntityCompanionProvider.ts +13 -13
- package/src/EntityConfiguration.ts +3 -3
- package/src/EntityCreator.ts +5 -5
- package/src/EntityDatabaseAdapter.ts +3 -3
- package/src/EntityDeleter.ts +5 -5
- package/src/EntityFieldDefinition.ts +3 -3
- package/src/EntityLoader.ts +7 -7
- package/src/EntityLoaderFactory.ts +9 -9
- package/src/EntityLoaderUtils.ts +7 -7
- package/src/EntityMutationInfo.ts +2 -2
- package/src/EntityMutationTriggerConfiguration.ts +3 -3
- package/src/EntityMutationValidator.ts +3 -3
- package/src/EntityMutatorFactory.ts +12 -12
- package/src/EntityPrivacyPolicy.ts +7 -6
- package/src/EntityQueryContext.ts +1 -1
- package/src/EntityQueryContextProvider.ts +3 -3
- package/src/EntitySecondaryCacheLoader.ts +5 -5
- package/src/EntityUpdater.ts +5 -5
- package/src/GenericEntityCacheAdapter.ts +3 -3
- package/src/GenericSecondaryEntityCache.ts +2 -2
- package/src/IEntityCacheAdapter.ts +1 -1
- package/src/IEntityCacheAdapterProvider.ts +3 -3
- package/src/IEntityDatabaseAdapterProvider.ts +3 -3
- package/src/IEntityGenericCacher.ts +1 -1
- package/src/ReadonlyEntity.ts +10 -10
- package/src/ViewerContext.ts +6 -6
- package/src/ViewerScopedEntityCompanion.ts +9 -9
- package/src/ViewerScopedEntityCompanionProvider.ts +6 -6
- package/src/ViewerScopedEntityLoaderFactory.ts +6 -6
- package/src/ViewerScopedEntityMutatorFactory.ts +6 -6
- package/src/__tests__/AuthorizationResultBasedEntityAssociationLoader-test.ts +5 -4
- package/src/__tests__/AuthorizationResultBasedEntityLoader-constructor-test.ts +14 -18
- package/src/__tests__/AuthorizationResultBasedEntityLoader-test.ts +18 -16
- package/src/__tests__/ComposedCacheAdapter-test.ts +5 -3
- package/src/__tests__/ComposedSecondaryEntityCache-test.ts +2 -1
- package/src/__tests__/EnforcingEntityAssociationLoader-test.ts +4 -3
- package/src/__tests__/EnforcingEntityLoader-test.ts +4 -3
- package/src/__tests__/Entity-test.ts +8 -6
- package/src/__tests__/EntityAssociationLoader-test.ts +7 -5
- package/src/__tests__/EntityCommonUseCases-test.ts +10 -9
- package/src/__tests__/EntityCompanion-test.ts +13 -11
- package/src/__tests__/EntityCompanionProvider-test.ts +7 -5
- package/src/__tests__/EntityConfiguration-test.ts +3 -1
- package/src/__tests__/EntityDatabaseAdapter-test.ts +9 -7
- package/src/__tests__/EntityEdges-test.ts +10 -8
- package/src/__tests__/EntityFields-test.ts +8 -7
- package/src/__tests__/EntityLoader-test.ts +8 -6
- package/src/__tests__/EntityMutator-MutationCacheConsistency-test.ts +8 -6
- package/src/__tests__/EntityMutator-SingleCompositeFieldCacheConsistency-test.ts +5 -3
- package/src/__tests__/EntityMutator-test.ts +33 -29
- package/src/__tests__/EntityPrivacyPolicy-test.ts +19 -16
- package/src/__tests__/EntityQueryContext-test.ts +7 -6
- package/src/__tests__/EntitySecondaryCacheLoader-test.ts +5 -3
- package/src/__tests__/EntitySelfReferentialEdges-test.ts +7 -5
- package/src/__tests__/GenericEntityCacheAdapter-test.ts +4 -3
- package/src/__tests__/ReadonlyEntity-test.ts +10 -9
- package/src/__tests__/ViewerContext-test.ts +3 -1
- package/src/__tests__/ViewerScopedEntityCompanion-test.ts +10 -8
- package/src/__tests__/ViewerScopedEntityCompanionProvider-test.ts +7 -6
- package/src/__tests__/ViewerScopedEntityLoaderFactory-test.ts +5 -4
- package/src/__tests__/ViewerScopedEntityMutatorFactory-test.ts +8 -6
- package/src/__tests__/cases/TwoEntitySameTableDisjointRows-test.ts +15 -13
- package/src/__tests__/cases/TwoEntitySameTableOverlappingRows-test.ts +7 -5
- package/src/__tests__/entityUtils-test.ts +3 -2
- package/src/errors/EntityCacheAdapterError.ts +2 -2
- package/src/errors/EntityDatabaseAdapterError.ts +2 -2
- package/src/errors/EntityError.ts +1 -1
- package/src/errors/EntityInvalidFieldValueError.ts +5 -5
- package/src/errors/EntityNotAuthorizedError.ts +4 -4
- package/src/errors/EntityNotFoundError.ts +56 -9
- package/src/errors/__tests__/EntityDatabaseAdapterError-test.ts +29 -0
- package/src/index.ts +40 -54
- package/src/internal/CompositeFieldHolder.ts +2 -1
- package/src/internal/EntityDataManager.ts +7 -5
- package/src/internal/EntityFieldTransformationUtils.ts +1 -1
- package/src/internal/EntityLoadInterfaces.ts +1 -1
- package/src/internal/EntityTableDataCoordinator.ts +10 -10
- package/src/internal/ReadThroughEntityCache.ts +3 -3
- package/src/internal/SingleFieldHolder.ts +1 -1
- package/src/internal/__tests__/CompositeFieldHolder-test.ts +2 -0
- package/src/internal/__tests__/CompositeFieldValueMap-test.ts +2 -0
- package/src/internal/__tests__/EntityDataManager-test.ts +34 -31
- package/src/internal/__tests__/EntityFieldTransformationUtils-test.ts +5 -3
- package/src/internal/__tests__/ReadThroughEntityCache-test.ts +5 -4
- package/src/metrics/EntityMetricsUtils.ts +3 -2
- package/src/metrics/IEntityMetricsAdapter.ts +1 -1
- package/src/metrics/NoOpEntityMetricsAdapter.ts +3 -2
- package/src/rules/AlwaysAllowPrivacyPolicyRule.ts +4 -4
- package/src/rules/AlwaysDenyPrivacyPolicyRule.ts +4 -4
- package/src/rules/AlwaysSkipPrivacyPolicyRule.ts +4 -4
- package/src/rules/PrivacyPolicyRule.ts +3 -3
- package/src/rules/__tests__/AlwaysAllowPrivacyPolicyRule-test.ts +3 -3
- package/src/rules/__tests__/AlwaysDenyPrivacyPolicyRule-test.ts +3 -3
- package/src/rules/__tests__/AlwaysSkipPrivacyPolicyRule-test.ts +3 -3
- package/src/utils/EntityCreationUtils.ts +143 -0
- package/src/utils/EntityPrivacyUtils.ts +5 -5
- package/src/utils/__testfixtures__/PrivacyPolicyRuleTestUtils.ts +5 -3
- package/src/utils/__testfixtures__/SimpleTestEntity.ts +6 -6
- package/src/utils/__testfixtures__/StubCacheAdapter.ts +4 -4
- package/src/utils/__testfixtures__/StubDatabaseAdapter.ts +8 -7
- package/src/utils/__testfixtures__/StubDatabaseAdapterProvider.ts +5 -5
- package/src/utils/__testfixtures__/StubQueryContextProvider.ts +2 -2
- package/src/utils/__testfixtures__/TestEntity.ts +7 -7
- package/src/utils/__testfixtures__/TestEntity2.ts +6 -6
- package/src/utils/__testfixtures__/TestEntityWithMutationTriggers.ts +6 -10
- package/src/utils/__testfixtures__/TestViewerContext.ts +2 -2
- package/src/utils/__testfixtures__/createUnitTestEntityCompanionProvider.ts +5 -5
- package/src/utils/__testfixtures__/describeFieldTestCase.ts +3 -1
- package/src/utils/__tests__/EntityCreationUtils-test.ts +356 -0
- package/src/utils/__tests__/EntityPrivacyUtils-test.ts +15 -13
- package/src/utils/__tests__/canViewerDeleteAsync-edgeDeletionPermissionInferenceBehavior-test.ts +10 -8
- package/src/utils/__tests__/mergeEntityMutationTriggerConfigurations-test.ts +2 -0
- package/src/utils/collections/__tests__/SerializableKeyMap-test.ts +2 -0
- package/src/utils/collections/__tests__/maps-test.ts +3 -1
- package/src/utils/collections/__tests__/sets-test.ts +2 -0
- package/src/utils/mergeEntityMutationTriggerConfigurations.ts +3 -3
- package/build/AuthorizationResultBasedEntityAssociationLoader.js.map +0 -1
- package/build/AuthorizationResultBasedEntityLoader.js.map +0 -1
- package/build/AuthorizationResultBasedEntityMutator.js.map +0 -1
- package/build/ComposedEntityCacheAdapter.js.map +0 -1
- package/build/ComposedSecondaryEntityCache.js.map +0 -1
- package/build/EnforcingEntityAssociationLoader.js.map +0 -1
- package/build/EnforcingEntityCreator.js.map +0 -1
- package/build/EnforcingEntityDeleter.js.map +0 -1
- package/build/EnforcingEntityLoader.js.map +0 -1
- package/build/EnforcingEntityUpdater.js.map +0 -1
- package/build/Entity.js.map +0 -1
- package/build/EntityAssociationLoader.js.map +0 -1
- package/build/EntityCompanion.js.map +0 -1
- package/build/EntityCompanionProvider.js.map +0 -1
- package/build/EntityConfiguration.js.map +0 -1
- package/build/EntityDatabaseAdapter.js.map +0 -1
- package/build/EntityFieldDefinition.js.map +0 -1
- package/build/EntityFields.js.map +0 -1
- package/build/EntityLoaderFactory.js +0 -31
- package/build/EntityLoaderFactory.js.map +0 -1
- package/build/EntityLoaderUtils.js.map +0 -1
- package/build/EntityMutationInfo.js.map +0 -1
- package/build/EntityMutationTriggerConfiguration.js.map +0 -1
- package/build/EntityMutationValidator.js.map +0 -1
- package/build/EntityMutatorFactory.js.map +0 -1
- package/build/EntityQueryContext.js.map +0 -1
- package/build/EntityQueryContextProvider.js.map +0 -1
- package/build/EntitySecondaryCacheLoader.js.map +0 -1
- package/build/GenericEntityCacheAdapter.js.map +0 -1
- package/build/GenericSecondaryEntityCache.js.map +0 -1
- package/build/IEntityCacheAdapter.js.map +0 -1
- package/build/IEntityCacheAdapterProvider.js.map +0 -1
- package/build/IEntityDatabaseAdapterProvider.js.map +0 -1
- package/build/IEntityGenericCacher.js.map +0 -1
- package/build/ReadonlyEntity.js.map +0 -1
- package/build/ViewerScopedEntityCompanionProvider.js.map +0 -1
- package/build/ViewerScopedEntityLoaderFactory.js.map +0 -1
- package/build/ViewerScopedEntityMutatorFactory.js.map +0 -1
- package/build/entityUtils.js.map +0 -1
- package/build/errors/EntityCacheAdapterError.js +0 -46
- package/build/errors/EntityCacheAdapterError.js.map +0 -1
- package/build/errors/EntityDatabaseAdapterError.js.map +0 -1
- package/build/errors/EntityError.js.map +0 -1
- package/build/errors/EntityInvalidFieldValueError.js +0 -45
- package/build/errors/EntityInvalidFieldValueError.js.map +0 -1
- package/build/errors/EntityNotAuthorizedError.js +0 -48
- package/build/errors/EntityNotAuthorizedError.js.map +0 -1
- package/build/errors/EntityNotFoundError.d.ts +0 -10
- package/build/errors/EntityNotFoundError.js +0 -45
- package/build/errors/EntityNotFoundError.js.map +0 -1
- package/build/index.d.ts +0 -90
- package/build/index.js +0 -154
- package/build/index.js.map +0 -1
- package/build/internal/CompositeFieldHolder.js.map +0 -1
- package/build/internal/CompositeFieldValueMap.js.map +0 -1
- package/build/internal/EntityDataManager.js.map +0 -1
- package/build/internal/EntityFieldTransformationUtils.js.map +0 -1
- package/build/internal/EntityLoadInterfaces.js.map +0 -1
- package/build/internal/ReadThroughEntityCache.js.map +0 -1
- package/build/internal/SingleFieldHolder.js.map +0 -1
- package/build/metrics/EntityMetricsUtils.js.map +0 -1
- package/build/metrics/IEntityMetricsAdapter.js.map +0 -1
- package/build/metrics/NoOpEntityMetricsAdapter.js.map +0 -1
- package/build/rules/AlwaysAllowPrivacyPolicyRule.js +0 -46
- package/build/rules/AlwaysAllowPrivacyPolicyRule.js.map +0 -1
- package/build/rules/AlwaysDenyPrivacyPolicyRule.js +0 -46
- package/build/rules/AlwaysDenyPrivacyPolicyRule.js.map +0 -1
- package/build/rules/AlwaysSkipPrivacyPolicyRule.js +0 -46
- package/build/rules/AlwaysSkipPrivacyPolicyRule.js.map +0 -1
- package/build/rules/PrivacyPolicyRule.js.map +0 -1
- package/build/tsconfig.build.tsbuildinfo +0 -1
- package/build/utils/collections/SerializableKeyMap.js.map +0 -1
- package/build/utils/collections/maps.js.map +0 -1
- package/build/utils/collections/sets.js.map +0 -1
- package/build/utils/mergeEntityMutationTriggerConfigurations.js.map +0 -1
- /package/build/{EntityFieldDefinition.js → src/EntityFieldDefinition.js} +0 -0
- /package/build/{EntityFields.d.ts → src/EntityFields.d.ts} +0 -0
- /package/build/{EntityFields.js → src/EntityFields.js} +0 -0
- /package/build/{EntityMutationInfo.js → src/EntityMutationInfo.js} +0 -0
- /package/build/{EntityMutationTriggerConfiguration.js → src/EntityMutationTriggerConfiguration.js} +0 -0
- /package/build/{EntityQueryContext.js → src/EntityQueryContext.js} +0 -0
- /package/build/{IEntityCacheAdapter.js → src/IEntityCacheAdapter.js} +0 -0
- /package/build/{IEntityCacheAdapterProvider.js → src/IEntityCacheAdapterProvider.js} +0 -0
- /package/build/{IEntityDatabaseAdapterProvider.js → src/IEntityDatabaseAdapterProvider.js} +0 -0
- /package/build/{IEntityGenericCacher.js → src/IEntityGenericCacher.js} +0 -0
- /package/build/{entityUtils.d.ts → src/entityUtils.d.ts} +0 -0
- /package/build/{entityUtils.js → src/entityUtils.js} +0 -0
- /package/build/{internal → src/internal}/CompositeFieldHolder.js +0 -0
- /package/build/{internal → src/internal}/CompositeFieldValueMap.d.ts +0 -0
- /package/build/{internal → src/internal}/CompositeFieldValueMap.js +0 -0
- /package/build/{internal → src/internal}/EntityFieldTransformationUtils.js +0 -0
- /package/build/{internal → src/internal}/EntityLoadInterfaces.js +0 -0
- /package/build/{internal → src/internal}/SingleFieldHolder.js +0 -0
- /package/build/{metrics → src/metrics}/EntityMetricsUtils.js +0 -0
- /package/build/{metrics → src/metrics}/IEntityMetricsAdapter.js +0 -0
- /package/build/{utils → src/utils}/collections/SerializableKeyMap.d.ts +0 -0
- /package/build/{utils → src/utils}/collections/SerializableKeyMap.js +0 -0
- /package/build/{utils → src/utils}/collections/maps.d.ts +0 -0
- /package/build/{utils → src/utils}/collections/maps.js +0 -0
- /package/build/{utils → src/utils}/collections/sets.d.ts +0 -0
- /package/build/{utils → src/utils}/collections/sets.js +0 -0
- /package/build/{utils → src/utils}/mergeEntityMutationTriggerConfigurations.js +0 -0
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.InMemoryFullCacheStubCacheAdapter = exports.InMemoryFullCacheStubCacheAdapterProvider = exports.DOES_NOT_EXIST = exports.NoCacheStubCacheAdapter = exports.NoCacheStubCacheAdapterProvider = void 0;
|
|
7
|
+
const invariant_1 = __importDefault(require("invariant"));
|
|
8
|
+
const ReadThroughEntityCache_1 = require("../../internal/ReadThroughEntityCache");
|
|
9
|
+
class NoCacheStubCacheAdapterProvider {
|
|
10
|
+
getCacheAdapter(_entityConfiguration) {
|
|
11
|
+
return new NoCacheStubCacheAdapter();
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
exports.NoCacheStubCacheAdapterProvider = NoCacheStubCacheAdapterProvider;
|
|
15
|
+
class NoCacheStubCacheAdapter {
|
|
16
|
+
async loadManyAsync(key, values) {
|
|
17
|
+
return values.reduce((acc, v) => {
|
|
18
|
+
acc.set(v, {
|
|
19
|
+
status: ReadThroughEntityCache_1.CacheStatus.MISS,
|
|
20
|
+
});
|
|
21
|
+
return acc;
|
|
22
|
+
}, key.vendNewLoadValueMap());
|
|
23
|
+
}
|
|
24
|
+
async cacheManyAsync(_key, _objectMap) { }
|
|
25
|
+
async cacheDBMissesAsync(_key, _values) { }
|
|
26
|
+
async invalidateManyAsync(_key, _values) { }
|
|
27
|
+
}
|
|
28
|
+
exports.NoCacheStubCacheAdapter = NoCacheStubCacheAdapter;
|
|
29
|
+
// Sentinel value we store in the in-memory cache to negatively cache a database miss.
|
|
30
|
+
// The sentinel value is distinct from any (positively) cached value.
|
|
31
|
+
exports.DOES_NOT_EXIST = Symbol('inMemoryCacheDoesNotExistValue');
|
|
32
|
+
class InMemoryFullCacheStubCacheAdapterProvider {
|
|
33
|
+
cache = new Map();
|
|
34
|
+
getCacheAdapter(entityConfiguration) {
|
|
35
|
+
return new InMemoryFullCacheStubCacheAdapter(entityConfiguration, this.cache);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
exports.InMemoryFullCacheStubCacheAdapterProvider = InMemoryFullCacheStubCacheAdapterProvider;
|
|
39
|
+
class InMemoryFullCacheStubCacheAdapter {
|
|
40
|
+
entityConfiguration;
|
|
41
|
+
cache;
|
|
42
|
+
constructor(entityConfiguration, cache) {
|
|
43
|
+
this.entityConfiguration = entityConfiguration;
|
|
44
|
+
this.cache = cache;
|
|
45
|
+
}
|
|
46
|
+
async loadManyAsync(key, values) {
|
|
47
|
+
const results = key.vendNewLoadValueMap();
|
|
48
|
+
values.forEach((value) => {
|
|
49
|
+
const cacheKey = this.createCacheKey(key, value);
|
|
50
|
+
if (!this.cache.has(cacheKey)) {
|
|
51
|
+
results.set(value, {
|
|
52
|
+
status: ReadThroughEntityCache_1.CacheStatus.MISS,
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
const objectForFieldValue = this.cache.get(cacheKey);
|
|
57
|
+
(0, invariant_1.default)(objectForFieldValue !== undefined, 'should have set value for key');
|
|
58
|
+
if (objectForFieldValue === exports.DOES_NOT_EXIST) {
|
|
59
|
+
results.set(value, {
|
|
60
|
+
status: ReadThroughEntityCache_1.CacheStatus.NEGATIVE,
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
results.set(value, {
|
|
65
|
+
status: ReadThroughEntityCache_1.CacheStatus.HIT,
|
|
66
|
+
item: objectForFieldValue,
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
return results;
|
|
72
|
+
}
|
|
73
|
+
async cacheManyAsync(key, objectMap) {
|
|
74
|
+
objectMap.forEach((obj, value) => {
|
|
75
|
+
const cacheKey = this.createCacheKey(key, value);
|
|
76
|
+
this.cache.set(cacheKey, obj);
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
async cacheDBMissesAsync(key, values) {
|
|
80
|
+
values.forEach((value) => {
|
|
81
|
+
const cacheKey = this.createCacheKey(key, value);
|
|
82
|
+
this.cache.set(cacheKey, exports.DOES_NOT_EXIST);
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
async invalidateManyAsync(key, values) {
|
|
86
|
+
values.forEach((value) => {
|
|
87
|
+
const cacheKey = this.createCacheKey(key, value);
|
|
88
|
+
this.cache.delete(cacheKey);
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
createCacheKey(key, value) {
|
|
92
|
+
const cacheKeyType = key.getLoadMethodType();
|
|
93
|
+
const parts = key.createCacheKeyPartsForLoadValue(this.entityConfiguration, value);
|
|
94
|
+
return [
|
|
95
|
+
this.entityConfiguration.tableName,
|
|
96
|
+
cacheKeyType,
|
|
97
|
+
`v${this.entityConfiguration.cacheKeyVersion}`,
|
|
98
|
+
...parts,
|
|
99
|
+
].join(':');
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
exports.InMemoryFullCacheStubCacheAdapter = InMemoryFullCacheStubCacheAdapter;
|
|
103
|
+
//# sourceMappingURL=StubCacheAdapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StubCacheAdapter.js","sourceRoot":"","sources":["../../../../src/utils/__testfixtures__/StubCacheAdapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { EntityConfiguration } from '../../EntityConfiguration';
|
|
2
|
+
import { EntityDatabaseAdapter, TableFieldMultiValueEqualityCondition, TableFieldSingleValueEqualityCondition, TableQuerySelectionModifiers } from '../../EntityDatabaseAdapter';
|
|
3
|
+
import { FieldTransformerMap } from '../../internal/EntityFieldTransformationUtils';
|
|
4
|
+
export declare class StubDatabaseAdapter<TFields extends Record<string, any>, TIDField extends keyof TFields> extends EntityDatabaseAdapter<TFields, TIDField> {
|
|
5
|
+
private readonly entityConfiguration2;
|
|
6
|
+
private readonly dataStore;
|
|
7
|
+
constructor(entityConfiguration2: EntityConfiguration<TFields, TIDField>, dataStore: Map<string, Readonly<{
|
|
8
|
+
[key: string]: any;
|
|
9
|
+
}>[]>);
|
|
10
|
+
static convertFieldObjectsToDataStore<TFields extends Record<string, any>, TIDField extends keyof TFields>(entityConfiguration: EntityConfiguration<TFields, TIDField>, dataStore: Map<string, Readonly<TFields>[]>): Map<string, Readonly<{
|
|
11
|
+
[key: string]: any;
|
|
12
|
+
}>[]>;
|
|
13
|
+
getObjectCollectionForTable(tableName: string): {
|
|
14
|
+
[key: string]: any;
|
|
15
|
+
}[];
|
|
16
|
+
protected getFieldTransformerMap(): FieldTransformerMap;
|
|
17
|
+
private static uniqBy;
|
|
18
|
+
protected fetchManyWhereInternalAsync(_queryInterface: any, tableName: string, tableColumns: readonly string[], tableTuples: (readonly any[])[]): Promise<object[]>;
|
|
19
|
+
private static compareByOrderBys;
|
|
20
|
+
protected fetchManyByFieldEqualityConjunctionInternalAsync(_queryInterface: any, tableName: string, tableFieldSingleValueEqualityOperands: TableFieldSingleValueEqualityCondition[], tableFieldMultiValueEqualityOperands: TableFieldMultiValueEqualityCondition[], querySelectionModifiers: TableQuerySelectionModifiers): Promise<object[]>;
|
|
21
|
+
protected fetchManyByRawWhereClauseInternalAsync(_queryInterface: any, _tableName: string, _rawWhereClause: string, _bindings: object | any[], _querySelectionModifiers: TableQuerySelectionModifiers): Promise<object[]>;
|
|
22
|
+
private generateRandomID;
|
|
23
|
+
protected insertInternalAsync(_queryInterface: any, tableName: string, object: object): Promise<object[]>;
|
|
24
|
+
protected updateInternalAsync(_queryInterface: any, tableName: string, tableIdField: string, id: any, object: object): Promise<object[]>;
|
|
25
|
+
protected deleteInternalAsync(_queryInterface: any, tableName: string, tableIdField: string, id: any): Promise<number>;
|
|
26
|
+
}
|
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.StubDatabaseAdapter = void 0;
|
|
7
|
+
const invariant_1 = __importDefault(require("invariant"));
|
|
8
|
+
const uuidv7_1 = require("uuidv7");
|
|
9
|
+
const EntityDatabaseAdapter_1 = require("../../EntityDatabaseAdapter");
|
|
10
|
+
const EntityFields_1 = require("../../EntityFields");
|
|
11
|
+
const EntityFieldTransformationUtils_1 = require("../../internal/EntityFieldTransformationUtils");
|
|
12
|
+
const maps_1 = require("../collections/maps");
|
|
13
|
+
class StubDatabaseAdapter extends EntityDatabaseAdapter_1.EntityDatabaseAdapter {
|
|
14
|
+
entityConfiguration2;
|
|
15
|
+
dataStore;
|
|
16
|
+
constructor(entityConfiguration2, dataStore) {
|
|
17
|
+
super(entityConfiguration2);
|
|
18
|
+
this.entityConfiguration2 = entityConfiguration2;
|
|
19
|
+
this.dataStore = dataStore;
|
|
20
|
+
}
|
|
21
|
+
static convertFieldObjectsToDataStore(entityConfiguration, dataStore) {
|
|
22
|
+
return (0, maps_1.mapMap)(dataStore, (objectsForTable) => objectsForTable.map((objectForTable) => (0, EntityFieldTransformationUtils_1.transformFieldsToDatabaseObject)(entityConfiguration, new Map(), objectForTable)));
|
|
23
|
+
}
|
|
24
|
+
getObjectCollectionForTable(tableName) {
|
|
25
|
+
return (0, maps_1.computeIfAbsent)(this.dataStore, tableName, () => []);
|
|
26
|
+
}
|
|
27
|
+
getFieldTransformerMap() {
|
|
28
|
+
return new Map();
|
|
29
|
+
}
|
|
30
|
+
static uniqBy(a, keyExtractor) {
|
|
31
|
+
const seen = new Set();
|
|
32
|
+
return a.filter((item) => {
|
|
33
|
+
const k = keyExtractor(item);
|
|
34
|
+
if (seen.has(k)) {
|
|
35
|
+
return false;
|
|
36
|
+
}
|
|
37
|
+
seen.add(k);
|
|
38
|
+
return true;
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
async fetchManyWhereInternalAsync(_queryInterface, tableName, tableColumns, tableTuples) {
|
|
42
|
+
const objectCollection = this.getObjectCollectionForTable(tableName);
|
|
43
|
+
const results = StubDatabaseAdapter.uniqBy(tableTuples, (tuple) => tuple.join(':')).reduce((acc, tableTuple) => {
|
|
44
|
+
return acc.concat(objectCollection.filter((obj) => {
|
|
45
|
+
return tableColumns.every((tableColumn, index) => {
|
|
46
|
+
return obj[tableColumn] === tableTuple[index];
|
|
47
|
+
});
|
|
48
|
+
}));
|
|
49
|
+
}, []);
|
|
50
|
+
return [...results];
|
|
51
|
+
}
|
|
52
|
+
static compareByOrderBys(orderBys, objectA, objectB) {
|
|
53
|
+
if (orderBys.length === 0) {
|
|
54
|
+
return 0;
|
|
55
|
+
}
|
|
56
|
+
const currentOrderBy = orderBys[0];
|
|
57
|
+
const aField = objectA[currentOrderBy.columnName];
|
|
58
|
+
const bField = objectB[currentOrderBy.columnName];
|
|
59
|
+
switch (currentOrderBy.order) {
|
|
60
|
+
case EntityDatabaseAdapter_1.OrderByOrdering.DESCENDING: {
|
|
61
|
+
// simulate NULLS FIRST for DESC
|
|
62
|
+
if (aField === null && bField === null) {
|
|
63
|
+
return 0;
|
|
64
|
+
}
|
|
65
|
+
else if (aField === null) {
|
|
66
|
+
return -1;
|
|
67
|
+
}
|
|
68
|
+
else if (bField === null) {
|
|
69
|
+
return 1;
|
|
70
|
+
}
|
|
71
|
+
return aField > bField
|
|
72
|
+
? -1
|
|
73
|
+
: aField < bField
|
|
74
|
+
? 1
|
|
75
|
+
: this.compareByOrderBys(orderBys.slice(1), objectA, objectB);
|
|
76
|
+
}
|
|
77
|
+
case EntityDatabaseAdapter_1.OrderByOrdering.ASCENDING: {
|
|
78
|
+
// simulate NULLS LAST for ASC
|
|
79
|
+
if (aField === null && bField === null) {
|
|
80
|
+
return 0;
|
|
81
|
+
}
|
|
82
|
+
else if (bField === null) {
|
|
83
|
+
return -1;
|
|
84
|
+
}
|
|
85
|
+
else if (aField === null) {
|
|
86
|
+
return 1;
|
|
87
|
+
}
|
|
88
|
+
return bField > aField
|
|
89
|
+
? -1
|
|
90
|
+
: bField < aField
|
|
91
|
+
? 1
|
|
92
|
+
: this.compareByOrderBys(orderBys.slice(1), objectA, objectB);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
async fetchManyByFieldEqualityConjunctionInternalAsync(_queryInterface, tableName, tableFieldSingleValueEqualityOperands, tableFieldMultiValueEqualityOperands, querySelectionModifiers) {
|
|
97
|
+
let filteredObjects = this.getObjectCollectionForTable(tableName);
|
|
98
|
+
for (const { tableField, tableValue } of tableFieldSingleValueEqualityOperands) {
|
|
99
|
+
filteredObjects = filteredObjects.filter((obj) => obj[tableField] === tableValue);
|
|
100
|
+
}
|
|
101
|
+
for (const { tableField, tableValues } of tableFieldMultiValueEqualityOperands) {
|
|
102
|
+
filteredObjects = filteredObjects.filter((obj) => tableValues.includes(obj[tableField]));
|
|
103
|
+
}
|
|
104
|
+
const orderBy = querySelectionModifiers.orderBy;
|
|
105
|
+
if (orderBy !== undefined) {
|
|
106
|
+
filteredObjects = filteredObjects.sort((a, b) => StubDatabaseAdapter.compareByOrderBys(orderBy, a, b));
|
|
107
|
+
}
|
|
108
|
+
const offset = querySelectionModifiers.offset;
|
|
109
|
+
if (offset !== undefined) {
|
|
110
|
+
filteredObjects = filteredObjects.slice(offset);
|
|
111
|
+
}
|
|
112
|
+
const limit = querySelectionModifiers.limit;
|
|
113
|
+
if (limit !== undefined) {
|
|
114
|
+
filteredObjects = filteredObjects.slice(0, 0 + limit);
|
|
115
|
+
}
|
|
116
|
+
return filteredObjects;
|
|
117
|
+
}
|
|
118
|
+
fetchManyByRawWhereClauseInternalAsync(_queryInterface, _tableName, _rawWhereClause, _bindings, _querySelectionModifiers) {
|
|
119
|
+
throw new Error('Raw WHERE clauses not supported for StubDatabaseAdapter');
|
|
120
|
+
}
|
|
121
|
+
generateRandomID() {
|
|
122
|
+
const idSchemaField = this.entityConfiguration2.schema.get(this.entityConfiguration2.idField);
|
|
123
|
+
(0, invariant_1.default)(idSchemaField, `No schema field found for ${String(this.entityConfiguration2.idField)}`);
|
|
124
|
+
if (idSchemaField instanceof EntityFields_1.StringField) {
|
|
125
|
+
return (0, uuidv7_1.uuidv7)();
|
|
126
|
+
}
|
|
127
|
+
else if (idSchemaField instanceof EntityFields_1.IntField) {
|
|
128
|
+
return Math.floor(Math.random() * Number.MAX_SAFE_INTEGER);
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
throw new Error(`Unsupported ID type for StubDatabaseAdapter: ${idSchemaField.constructor.name}`);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
async insertInternalAsync(_queryInterface, tableName, object) {
|
|
135
|
+
const objectCollection = this.getObjectCollectionForTable(tableName);
|
|
136
|
+
const idField = (0, EntityFieldTransformationUtils_1.getDatabaseFieldForEntityField)(this.entityConfiguration2, this.entityConfiguration2.idField);
|
|
137
|
+
const objectToInsert = {
|
|
138
|
+
[idField]: this.generateRandomID(),
|
|
139
|
+
...object,
|
|
140
|
+
};
|
|
141
|
+
objectCollection.push(objectToInsert);
|
|
142
|
+
return [objectToInsert];
|
|
143
|
+
}
|
|
144
|
+
async updateInternalAsync(_queryInterface, tableName, tableIdField, id, object) {
|
|
145
|
+
// SQL does not support empty updates, mirror behavior here for better test simulation
|
|
146
|
+
if (Object.keys(object).length === 0) {
|
|
147
|
+
throw new Error(`Empty update (${tableIdField} = ${id})`);
|
|
148
|
+
}
|
|
149
|
+
const objectCollection = this.getObjectCollectionForTable(tableName);
|
|
150
|
+
const objectIndex = objectCollection.findIndex((obj) => {
|
|
151
|
+
return obj[tableIdField] === id;
|
|
152
|
+
});
|
|
153
|
+
(0, invariant_1.default)(objectIndex >= 0, 'should exist');
|
|
154
|
+
objectCollection[objectIndex] = {
|
|
155
|
+
...objectCollection[objectIndex],
|
|
156
|
+
...object,
|
|
157
|
+
};
|
|
158
|
+
return [objectCollection[objectIndex]];
|
|
159
|
+
}
|
|
160
|
+
async deleteInternalAsync(_queryInterface, tableName, tableIdField, id) {
|
|
161
|
+
const objectCollection = this.getObjectCollectionForTable(tableName);
|
|
162
|
+
const objectIndex = objectCollection.findIndex((obj) => {
|
|
163
|
+
return obj[tableIdField] === id;
|
|
164
|
+
});
|
|
165
|
+
if (objectIndex < 0) {
|
|
166
|
+
return 0;
|
|
167
|
+
}
|
|
168
|
+
objectCollection.splice(objectIndex, 1);
|
|
169
|
+
return 1;
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
exports.StubDatabaseAdapter = StubDatabaseAdapter;
|
|
173
|
+
//# sourceMappingURL=StubDatabaseAdapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StubDatabaseAdapter.js","sourceRoot":"","sources":["../../../../src/utils/__testfixtures__/StubDatabaseAdapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { EntityConfiguration } from '../../EntityConfiguration';
|
|
2
|
+
import { EntityDatabaseAdapter } from '../../EntityDatabaseAdapter';
|
|
3
|
+
import { IEntityDatabaseAdapterProvider } from '../../IEntityDatabaseAdapterProvider';
|
|
4
|
+
export declare class StubDatabaseAdapterProvider implements IEntityDatabaseAdapterProvider {
|
|
5
|
+
private readonly objectCollection;
|
|
6
|
+
getDatabaseAdapter<TFields extends Record<string, any>, TIDField extends keyof TFields>(entityConfiguration: EntityConfiguration<TFields, TIDField>): EntityDatabaseAdapter<TFields, TIDField>;
|
|
7
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.StubDatabaseAdapterProvider = void 0;
|
|
4
|
+
const StubDatabaseAdapter_1 = require("../__testfixtures__/StubDatabaseAdapter");
|
|
5
|
+
class StubDatabaseAdapterProvider {
|
|
6
|
+
objectCollection = new Map();
|
|
7
|
+
getDatabaseAdapter(entityConfiguration) {
|
|
8
|
+
return new StubDatabaseAdapter_1.StubDatabaseAdapter(entityConfiguration, this.objectCollection);
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
exports.StubDatabaseAdapterProvider = StubDatabaseAdapterProvider;
|
|
12
|
+
//# sourceMappingURL=StubDatabaseAdapterProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StubDatabaseAdapterProvider.js","sourceRoot":"","sources":["../../../../src/utils/__testfixtures__/StubDatabaseAdapterProvider.ts"],"names":[],"mappings":";;;AAGA,iFAA8E;AAE9E,MAAa,2BAA2B;IACrB,gBAAgB,GAAG,IAAI,GAAG,EAAE,CAAC;IAE9C,kBAAkB,CAChB,mBAA2D;QAE3D,OAAO,IAAI,yCAAmB,CAAC,mBAAmB,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAC7E,CAAC;CACF;AARD,kEAQC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { TransactionConfig } from '../../EntityQueryContext';
|
|
2
|
+
import { EntityQueryContextProvider } from '../../EntityQueryContextProvider';
|
|
3
|
+
export declare class StubQueryContextProvider extends EntityQueryContextProvider {
|
|
4
|
+
protected getQueryInterface(): any;
|
|
5
|
+
protected createTransactionRunner<T>(_transactionConfig?: TransactionConfig): (transactionScope: (queryInterface: any) => Promise<T>) => Promise<T>;
|
|
6
|
+
protected createNestedTransactionRunner<T>(_outerQueryInterface: any): (transactionScope: (queryInterface: any) => Promise<T>) => Promise<T>;
|
|
7
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.StubQueryContextProvider = void 0;
|
|
4
|
+
const EntityQueryContextProvider_1 = require("../../EntityQueryContextProvider");
|
|
5
|
+
class StubQueryContextProvider extends EntityQueryContextProvider_1.EntityQueryContextProvider {
|
|
6
|
+
getQueryInterface() {
|
|
7
|
+
return {};
|
|
8
|
+
}
|
|
9
|
+
createTransactionRunner(_transactionConfig) {
|
|
10
|
+
return (transactionScope) => Promise.resolve(transactionScope({}));
|
|
11
|
+
}
|
|
12
|
+
createNestedTransactionRunner(_outerQueryInterface) {
|
|
13
|
+
return (transactionScope) => Promise.resolve(transactionScope({}));
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
exports.StubQueryContextProvider = StubQueryContextProvider;
|
|
17
|
+
//# sourceMappingURL=StubQueryContextProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StubQueryContextProvider.js","sourceRoot":"","sources":["../../../../src/utils/__testfixtures__/StubQueryContextProvider.ts"],"names":[],"mappings":";;;AACA,iFAA8E;AAE9E,MAAa,wBAAyB,SAAQ,uDAA0B;IAC5D,iBAAiB;QACzB,OAAO,EAAE,CAAC;IACZ,CAAC;IAES,uBAAuB,CAC/B,kBAAsC;QAEtC,OAAO,CAAC,gBAAgB,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC,CAAC;IACrE,CAAC;IAES,6BAA6B,CACrC,oBAAyB;QAEzB,OAAO,CAAC,gBAAgB,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC,CAAC;IACrE,CAAC;CACF;AAhBD,4DAgBC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Matcher } from 'ts-mockito/lib/matcher/type/Matcher';
|
|
2
|
+
export declare function isEqualWithEntityAware(expected: any, actual: any): boolean;
|
|
3
|
+
export declare class DeepEqualEntityAwareMatcher<T> extends Matcher {
|
|
4
|
+
private readonly expectedValue;
|
|
5
|
+
constructor(expectedValue: T);
|
|
6
|
+
match(value: any): boolean;
|
|
7
|
+
toString(): string;
|
|
8
|
+
}
|
|
9
|
+
export declare function deepEqualEntityAware<T>(expectedValue: T): T;
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.DeepEqualEntityAwareMatcher = void 0;
|
|
7
|
+
exports.isEqualWithEntityAware = isEqualWithEntityAware;
|
|
8
|
+
exports.deepEqualEntityAware = deepEqualEntityAware;
|
|
9
|
+
const isEqualWith_1 = __importDefault(require("lodash/isEqualWith"));
|
|
10
|
+
const Matcher_1 = require("ts-mockito/lib/matcher/type/Matcher");
|
|
11
|
+
const CompositeFieldHolder_1 = require("../../internal/CompositeFieldHolder");
|
|
12
|
+
const SingleFieldHolder_1 = require("../../internal/SingleFieldHolder");
|
|
13
|
+
const SerializableKeyMap_1 = require("../collections/SerializableKeyMap");
|
|
14
|
+
function isEqualWithEntityAware(expected, actual) {
|
|
15
|
+
return (0, isEqualWith_1.default)(expected, actual, (expected, actual) => {
|
|
16
|
+
if (expected instanceof Matcher_1.Matcher) {
|
|
17
|
+
return expected.match(actual);
|
|
18
|
+
}
|
|
19
|
+
if (expected instanceof SingleFieldHolder_1.SingleFieldHolder && actual instanceof SingleFieldHolder_1.SingleFieldHolder) {
|
|
20
|
+
return expected.fieldName === actual.fieldName;
|
|
21
|
+
}
|
|
22
|
+
if (expected instanceof SingleFieldHolder_1.SingleFieldValueHolder && actual instanceof SingleFieldHolder_1.SingleFieldValueHolder) {
|
|
23
|
+
return expected.fieldValue === actual.fieldValue;
|
|
24
|
+
}
|
|
25
|
+
if (expected instanceof CompositeFieldHolder_1.CompositeFieldHolder && actual instanceof CompositeFieldHolder_1.CompositeFieldHolder) {
|
|
26
|
+
return expected.serialize() === actual.serialize();
|
|
27
|
+
}
|
|
28
|
+
if (expected instanceof CompositeFieldHolder_1.CompositeFieldValueHolder &&
|
|
29
|
+
actual instanceof CompositeFieldHolder_1.CompositeFieldValueHolder) {
|
|
30
|
+
return expected.serialize() === actual.serialize();
|
|
31
|
+
}
|
|
32
|
+
if (expected instanceof SerializableKeyMap_1.SerializableKeyMap && actual instanceof SerializableKeyMap_1.SerializableKeyMap) {
|
|
33
|
+
for (const [key, value] of expected.entries()) {
|
|
34
|
+
if (!actual.has(key) || !(0, isEqualWith_1.default)(value, actual.get(key))) {
|
|
35
|
+
return false;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
return true;
|
|
39
|
+
}
|
|
40
|
+
return undefined;
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
class DeepEqualEntityAwareMatcher extends Matcher_1.Matcher {
|
|
44
|
+
expectedValue;
|
|
45
|
+
constructor(expectedValue) {
|
|
46
|
+
super();
|
|
47
|
+
this.expectedValue = expectedValue;
|
|
48
|
+
}
|
|
49
|
+
match(value) {
|
|
50
|
+
return isEqualWithEntityAware(this.expectedValue, value);
|
|
51
|
+
}
|
|
52
|
+
toString() {
|
|
53
|
+
if (this.expectedValue instanceof Array) {
|
|
54
|
+
return `deepEqualEntityAware([${this.expectedValue}])`;
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
return `deepEqualEntityAware(${this.expectedValue})`;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
exports.DeepEqualEntityAwareMatcher = DeepEqualEntityAwareMatcher;
|
|
62
|
+
function deepEqualEntityAware(expectedValue) {
|
|
63
|
+
return new DeepEqualEntityAwareMatcher(expectedValue);
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=TSMockitoExtensions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TSMockitoExtensions.js","sourceRoot":"","sources":["../../../../src/utils/__testfixtures__/TSMockitoExtensions.ts"],"names":[],"mappings":";;;;;;AAUA,wDAoCC;AAoBD,oDAEC;AApED,qEAA6C;AAC7C,iEAA8D;AAE9D,8EAG6C;AAC7C,wEAA6F;AAC7F,0EAAuE;AAEvE,SAAgB,sBAAsB,CAAC,QAAa,EAAE,MAAW;IAC/D,OAAO,IAAA,qBAAW,EAAC,QAAQ,EAAE,MAAM,EAAE,CAAC,QAAa,EAAE,MAAW,EAAuB,EAAE;QACvF,IAAI,QAAQ,YAAY,iBAAO,EAAE,CAAC;YAChC,OAAO,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAChC,CAAC;QAED,IAAI,QAAQ,YAAY,qCAAiB,IAAI,MAAM,YAAY,qCAAiB,EAAE,CAAC;YACjF,OAAO,QAAQ,CAAC,SAAS,KAAK,MAAM,CAAC,SAAS,CAAC;QACjD,CAAC;QAED,IAAI,QAAQ,YAAY,0CAAsB,IAAI,MAAM,YAAY,0CAAsB,EAAE,CAAC;YAC3F,OAAO,QAAQ,CAAC,UAAU,KAAK,MAAM,CAAC,UAAU,CAAC;QACnD,CAAC;QAED,IAAI,QAAQ,YAAY,2CAAoB,IAAI,MAAM,YAAY,2CAAoB,EAAE,CAAC;YACvF,OAAO,QAAQ,CAAC,SAAS,EAAE,KAAK,MAAM,CAAC,SAAS,EAAE,CAAC;QACrD,CAAC;QAED,IACE,QAAQ,YAAY,gDAAyB;YAC7C,MAAM,YAAY,gDAAyB,EAC3C,CAAC;YACD,OAAO,QAAQ,CAAC,SAAS,EAAE,KAAK,MAAM,CAAC,SAAS,EAAE,CAAC;QACrD,CAAC;QAED,IAAI,QAAQ,YAAY,uCAAkB,IAAI,MAAM,YAAY,uCAAkB,EAAE,CAAC;YACnF,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,QAAQ,CAAC,OAAO,EAAE,EAAE,CAAC;gBAC9C,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,IAAA,qBAAW,EAAC,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;oBAC7D,OAAO,KAAK,CAAC;gBACf,CAAC;YACH,CAAC;YACD,OAAO,IAAI,CAAC;QACd,CAAC;QAED,OAAO,SAAS,CAAC;IACnB,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAa,2BAA+B,SAAQ,iBAAO;IAC5B;IAA7B,YAA6B,aAAgB;QAC3C,KAAK,EAAE,CAAC;QADmB,kBAAa,GAAb,aAAa,CAAG;IAE7C,CAAC;IAEe,KAAK,CAAC,KAAU;QAC9B,OAAO,sBAAsB,CAAC,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;IAC3D,CAAC;IAEe,QAAQ;QACtB,IAAI,IAAI,CAAC,aAAa,YAAY,KAAK,EAAE,CAAC;YACxC,OAAO,yBAAyB,IAAI,CAAC,aAAa,IAAI,CAAC;QACzD,CAAC;aAAM,CAAC;YACN,OAAO,wBAAwB,IAAI,CAAC,aAAa,GAAG,CAAC;QACvD,CAAC;IACH,CAAC;CACF;AAhBD,kEAgBC;AAED,SAAgB,oBAAoB,CAAI,aAAgB;IACtD,OAAO,IAAI,2BAA2B,CAAC,aAAa,CAAQ,CAAC;AAC/D,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { Result } from '@expo/results';
|
|
2
|
+
import { Entity } from '../../Entity';
|
|
3
|
+
import { EntityCompanionDefinition } from '../../EntityCompanionProvider';
|
|
4
|
+
import { EntityConfiguration } from '../../EntityConfiguration';
|
|
5
|
+
import { EntityPrivacyPolicy } from '../../EntityPrivacyPolicy';
|
|
6
|
+
import { ViewerContext } from '../../ViewerContext';
|
|
7
|
+
import { AlwaysAllowPrivacyPolicyRule } from '../../rules/AlwaysAllowPrivacyPolicyRule';
|
|
8
|
+
export type TestFields = {
|
|
9
|
+
customIdField: string;
|
|
10
|
+
testIndexedField: string;
|
|
11
|
+
stringField: string;
|
|
12
|
+
intField: number;
|
|
13
|
+
dateField: Date;
|
|
14
|
+
nullableField: string | null;
|
|
15
|
+
};
|
|
16
|
+
export declare const testEntityConfiguration: EntityConfiguration<TestFields, "customIdField">;
|
|
17
|
+
export declare class TestEntityPrivacyPolicy extends EntityPrivacyPolicy<TestFields, 'customIdField', ViewerContext, TestEntity> {
|
|
18
|
+
protected readonly readRules: AlwaysAllowPrivacyPolicyRule<TestFields, "customIdField", ViewerContext, TestEntity, keyof TestFields>[];
|
|
19
|
+
protected readonly createRules: AlwaysAllowPrivacyPolicyRule<TestFields, "customIdField", ViewerContext, TestEntity, keyof TestFields>[];
|
|
20
|
+
protected readonly updateRules: AlwaysAllowPrivacyPolicyRule<TestFields, "customIdField", ViewerContext, TestEntity, keyof TestFields>[];
|
|
21
|
+
protected readonly deleteRules: AlwaysAllowPrivacyPolicyRule<TestFields, "customIdField", ViewerContext, TestEntity, keyof TestFields>[];
|
|
22
|
+
}
|
|
23
|
+
export declare class TestEntity extends Entity<TestFields, 'customIdField', ViewerContext> {
|
|
24
|
+
static defineCompanionDefinition(): EntityCompanionDefinition<TestFields, 'customIdField', ViewerContext, TestEntity, TestEntityPrivacyPolicy>;
|
|
25
|
+
getBlah(): string;
|
|
26
|
+
static helloAsync(viewerContext: ViewerContext, testValue: string): Promise<Result<TestEntity>>;
|
|
27
|
+
static returnErrorAsync(_viewerContext: ViewerContext): Promise<Result<TestEntity>>;
|
|
28
|
+
static throwErrorAsync(_viewerContext: ViewerContext): Promise<Result<TestEntity>>;
|
|
29
|
+
static nonResultAsync(_viewerContext: ViewerContext, testValue: string): Promise<string>;
|
|
30
|
+
}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TestEntity = exports.TestEntityPrivacyPolicy = exports.testEntityConfiguration = void 0;
|
|
4
|
+
const results_1 = require("@expo/results");
|
|
5
|
+
const Entity_1 = require("../../Entity");
|
|
6
|
+
const EntityConfiguration_1 = require("../../EntityConfiguration");
|
|
7
|
+
const EntityFields_1 = require("../../EntityFields");
|
|
8
|
+
const EntityPrivacyPolicy_1 = require("../../EntityPrivacyPolicy");
|
|
9
|
+
const AlwaysAllowPrivacyPolicyRule_1 = require("../../rules/AlwaysAllowPrivacyPolicyRule");
|
|
10
|
+
exports.testEntityConfiguration = new EntityConfiguration_1.EntityConfiguration({
|
|
11
|
+
idField: 'customIdField',
|
|
12
|
+
tableName: 'test_entity_should_not_write_to_db',
|
|
13
|
+
schema: {
|
|
14
|
+
customIdField: new EntityFields_1.UUIDField({
|
|
15
|
+
columnName: 'custom_id',
|
|
16
|
+
cache: true,
|
|
17
|
+
}),
|
|
18
|
+
testIndexedField: new EntityFields_1.StringField({
|
|
19
|
+
columnName: 'test_index',
|
|
20
|
+
cache: true,
|
|
21
|
+
}),
|
|
22
|
+
stringField: new EntityFields_1.StringField({
|
|
23
|
+
columnName: 'string_field',
|
|
24
|
+
}),
|
|
25
|
+
intField: new EntityFields_1.IntField({
|
|
26
|
+
columnName: 'number_field',
|
|
27
|
+
}),
|
|
28
|
+
dateField: new EntityFields_1.DateField({
|
|
29
|
+
columnName: 'date_field',
|
|
30
|
+
}),
|
|
31
|
+
nullableField: new EntityFields_1.StringField({
|
|
32
|
+
columnName: 'nullable_field',
|
|
33
|
+
}),
|
|
34
|
+
},
|
|
35
|
+
databaseAdapterFlavor: 'postgres',
|
|
36
|
+
cacheAdapterFlavor: 'redis',
|
|
37
|
+
compositeFieldDefinitions: [
|
|
38
|
+
{ compositeField: ['stringField', 'intField'], cache: false },
|
|
39
|
+
{ compositeField: ['stringField', 'testIndexedField'], cache: true },
|
|
40
|
+
{ compositeField: ['nullableField', 'testIndexedField'], cache: true },
|
|
41
|
+
],
|
|
42
|
+
});
|
|
43
|
+
class TestEntityPrivacyPolicy extends EntityPrivacyPolicy_1.EntityPrivacyPolicy {
|
|
44
|
+
readRules = [
|
|
45
|
+
new AlwaysAllowPrivacyPolicyRule_1.AlwaysAllowPrivacyPolicyRule(),
|
|
46
|
+
];
|
|
47
|
+
createRules = [
|
|
48
|
+
new AlwaysAllowPrivacyPolicyRule_1.AlwaysAllowPrivacyPolicyRule(),
|
|
49
|
+
];
|
|
50
|
+
updateRules = [
|
|
51
|
+
new AlwaysAllowPrivacyPolicyRule_1.AlwaysAllowPrivacyPolicyRule(),
|
|
52
|
+
];
|
|
53
|
+
deleteRules = [
|
|
54
|
+
new AlwaysAllowPrivacyPolicyRule_1.AlwaysAllowPrivacyPolicyRule(),
|
|
55
|
+
];
|
|
56
|
+
}
|
|
57
|
+
exports.TestEntityPrivacyPolicy = TestEntityPrivacyPolicy;
|
|
58
|
+
class TestEntity extends Entity_1.Entity {
|
|
59
|
+
static defineCompanionDefinition() {
|
|
60
|
+
return {
|
|
61
|
+
entityClass: TestEntity,
|
|
62
|
+
entityConfiguration: exports.testEntityConfiguration,
|
|
63
|
+
privacyPolicyClass: TestEntityPrivacyPolicy,
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
getBlah() {
|
|
67
|
+
return 'Hello World!';
|
|
68
|
+
}
|
|
69
|
+
static async helloAsync(viewerContext, testValue) {
|
|
70
|
+
const fields = {
|
|
71
|
+
customIdField: testValue,
|
|
72
|
+
testIndexedField: 'hello',
|
|
73
|
+
stringField: 'hello',
|
|
74
|
+
intField: 1,
|
|
75
|
+
dateField: new Date(),
|
|
76
|
+
nullableField: null,
|
|
77
|
+
};
|
|
78
|
+
return (0, results_1.result)(new TestEntity({
|
|
79
|
+
viewerContext,
|
|
80
|
+
id: testValue,
|
|
81
|
+
databaseFields: fields,
|
|
82
|
+
selectedFields: fields,
|
|
83
|
+
}));
|
|
84
|
+
}
|
|
85
|
+
static async returnErrorAsync(_viewerContext) {
|
|
86
|
+
return (0, results_1.result)(new Error('return entity'));
|
|
87
|
+
}
|
|
88
|
+
static async throwErrorAsync(_viewerContext) {
|
|
89
|
+
throw new Error('threw entity');
|
|
90
|
+
}
|
|
91
|
+
static async nonResultAsync(_viewerContext, testValue) {
|
|
92
|
+
return testValue;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
exports.TestEntity = TestEntity;
|
|
96
|
+
//# sourceMappingURL=TestEntity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TestEntity.js","sourceRoot":"","sources":["../../../../src/utils/__testfixtures__/TestEntity.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Entity } from '../../Entity';
|
|
2
|
+
import { EntityCompanionDefinition } from '../../EntityCompanionProvider';
|
|
3
|
+
import { EntityConfiguration } from '../../EntityConfiguration';
|
|
4
|
+
import { EntityPrivacyPolicy } from '../../EntityPrivacyPolicy';
|
|
5
|
+
import { ViewerContext } from '../../ViewerContext';
|
|
6
|
+
import { AlwaysAllowPrivacyPolicyRule } from '../../rules/AlwaysAllowPrivacyPolicyRule';
|
|
7
|
+
export type Test2Fields = {
|
|
8
|
+
id: string;
|
|
9
|
+
foreignKey: string;
|
|
10
|
+
};
|
|
11
|
+
export declare const testEntity2Configuration: EntityConfiguration<Test2Fields, "id">;
|
|
12
|
+
export declare class TestEntity2PrivacyPolicy extends EntityPrivacyPolicy<Test2Fields, 'id', ViewerContext, TestEntity2> {
|
|
13
|
+
protected readonly readRules: AlwaysAllowPrivacyPolicyRule<Test2Fields, "id", ViewerContext, TestEntity2, keyof Test2Fields>[];
|
|
14
|
+
protected readonly createRules: AlwaysAllowPrivacyPolicyRule<Test2Fields, "id", ViewerContext, TestEntity2, keyof Test2Fields>[];
|
|
15
|
+
protected readonly updateRules: AlwaysAllowPrivacyPolicyRule<Test2Fields, "id", ViewerContext, TestEntity2, keyof Test2Fields>[];
|
|
16
|
+
protected readonly deleteRules: AlwaysAllowPrivacyPolicyRule<Test2Fields, "id", ViewerContext, TestEntity2, keyof Test2Fields>[];
|
|
17
|
+
}
|
|
18
|
+
export declare class TestEntity2 extends Entity<Test2Fields, 'id', ViewerContext> {
|
|
19
|
+
static defineCompanionDefinition(): EntityCompanionDefinition<Test2Fields, 'id', ViewerContext, TestEntity2, TestEntity2PrivacyPolicy>;
|
|
20
|
+
}
|