@expo/entity 0.22.0 → 0.25.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/ComposedEntityCacheAdapter.d.ts +19 -0
- package/build/ComposedEntityCacheAdapter.js +66 -0
- package/build/ComposedEntityCacheAdapter.js.map +1 -0
- package/build/ComposedSecondaryEntityCache.d.ts +15 -0
- package/build/ComposedSecondaryEntityCache.js +37 -0
- package/build/ComposedSecondaryEntityCache.js.map +1 -0
- package/build/Entity.js +6 -6
- package/build/Entity.js.map +1 -1
- package/build/EntityAssociationLoader.js +4 -4
- package/build/EntityAssociationLoader.js.map +1 -1
- package/build/EntityCacheAdapter.d.ts +2 -9
- package/build/EntityCacheAdapter.js.map +1 -1
- package/build/EntityFieldDefinition.d.ts +8 -0
- package/build/EntityFieldDefinition.js +5 -0
- package/build/EntityFieldDefinition.js.map +1 -1
- package/build/EntityFields.d.ts +38 -0
- package/build/EntityFields.js +38 -0
- package/build/EntityFields.js.map +1 -1
- package/build/EntityLoader.d.ts +3 -2
- package/build/EntityLoader.js +5 -4
- package/build/EntityLoader.js.map +1 -1
- package/build/EntityLoaderFactory.d.ts +2 -2
- package/build/EntityLoaderFactory.js +2 -2
- package/build/EntityLoaderFactory.js.map +1 -1
- package/build/EntityMutationInfo.d.ts +12 -3
- package/build/EntityMutator.d.ts +5 -4
- package/build/EntityMutator.js +31 -24
- package/build/EntityMutator.js.map +1 -1
- package/build/EntityMutatorFactory.d.ts +4 -4
- package/build/EntityMutatorFactory.js +6 -6
- package/build/EntityMutatorFactory.js.map +1 -1
- package/build/EntityPrivacyPolicy.d.ts +15 -4
- package/build/EntityPrivacyPolicy.js +14 -14
- package/build/EntityPrivacyPolicy.js.map +1 -1
- package/build/GenericSecondaryEntityCache.d.ts +19 -0
- package/build/GenericSecondaryEntityCache.js +74 -0
- package/build/GenericSecondaryEntityCache.js.map +1 -0
- package/build/IEntityGenericCacher.d.ts +11 -0
- package/build/IEntityGenericCacher.js +3 -0
- package/build/IEntityGenericCacher.js.map +1 -0
- package/build/ReadonlyEntity.js +1 -1
- package/build/ReadonlyEntity.js.map +1 -1
- package/build/ViewerScopedEntityLoaderFactory.d.ts +2 -2
- package/build/ViewerScopedEntityLoaderFactory.js +2 -2
- package/build/ViewerScopedEntityLoaderFactory.js.map +1 -1
- package/build/ViewerScopedEntityMutatorFactory.d.ts +4 -4
- package/build/ViewerScopedEntityMutatorFactory.js +6 -6
- package/build/ViewerScopedEntityMutatorFactory.js.map +1 -1
- package/build/__tests__/ComposedCacheAdapter-test.d.ts +1 -0
- package/build/__tests__/ComposedCacheAdapter-test.js +198 -0
- package/build/__tests__/ComposedCacheAdapter-test.js.map +1 -0
- package/build/__tests__/ComposedSecondaryEntityCache-test.d.ts +1 -0
- package/build/__tests__/ComposedSecondaryEntityCache-test.js +65 -0
- package/build/__tests__/ComposedSecondaryEntityCache-test.js.map +1 -0
- package/build/__tests__/EntityCommonUseCases-test.js +1 -1
- package/build/__tests__/EntityCommonUseCases-test.js.map +1 -1
- package/build/__tests__/EntityEdges-test.js +260 -37
- package/build/__tests__/EntityEdges-test.js.map +1 -1
- package/build/__tests__/EntityLoader-constructor-test.js +2 -1
- package/build/__tests__/EntityLoader-constructor-test.js.map +1 -1
- package/build/__tests__/EntityLoader-test.js +19 -11
- package/build/__tests__/EntityLoader-test.js.map +1 -1
- package/build/__tests__/EntityMutator-test.js +96 -43
- package/build/__tests__/EntityMutator-test.js.map +1 -1
- package/build/__tests__/EntityPrivacyPolicy-test.js +23 -12
- package/build/__tests__/EntityPrivacyPolicy-test.js.map +1 -1
- package/build/__tests__/EntitySecondaryCacheLoader-test.js +1 -1
- package/build/__tests__/EntitySecondaryCacheLoader-test.js.map +1 -1
- package/build/__tests__/ViewerScopedEntityLoaderFactory-test.js +3 -2
- package/build/__tests__/ViewerScopedEntityLoaderFactory-test.js.map +1 -1
- package/build/__tests__/ViewerScopedEntityMutatorFactory-test.js +3 -2
- package/build/__tests__/ViewerScopedEntityMutatorFactory-test.js.map +1 -1
- package/build/index.d.ts +2 -0
- package/build/index.js +3 -1
- package/build/index.js.map +1 -1
- package/build/internal/ReadThroughEntityCache.d.ts +2 -3
- package/build/internal/ReadThroughEntityCache.js +2 -6
- package/build/internal/ReadThroughEntityCache.js.map +1 -1
- package/build/internal/__tests__/ReadThroughEntityCache-test.js +0 -32
- package/build/internal/__tests__/ReadThroughEntityCache-test.js.map +1 -1
- package/build/rules/AlwaysAllowPrivacyPolicyRule.d.ts +2 -1
- package/build/rules/AlwaysAllowPrivacyPolicyRule.js +1 -1
- package/build/rules/AlwaysAllowPrivacyPolicyRule.js.map +1 -1
- package/build/rules/AlwaysDenyPrivacyPolicyRule.d.ts +2 -1
- package/build/rules/AlwaysDenyPrivacyPolicyRule.js +1 -1
- package/build/rules/AlwaysDenyPrivacyPolicyRule.js.map +1 -1
- package/build/rules/AlwaysSkipPrivacyPolicyRule.d.ts +2 -1
- package/build/rules/AlwaysSkipPrivacyPolicyRule.js +1 -1
- package/build/rules/AlwaysSkipPrivacyPolicyRule.js.map +1 -1
- package/build/rules/PrivacyPolicyRule.d.ts +2 -1
- package/build/rules/PrivacyPolicyRule.js.map +1 -1
- package/build/rules/__tests__/AlwaysAllowPrivacyPolicyRule-test.js +1 -0
- package/build/rules/__tests__/AlwaysAllowPrivacyPolicyRule-test.js.map +1 -1
- package/build/rules/__tests__/AlwaysDenyPrivacyPolicyRule-test.js +1 -0
- package/build/rules/__tests__/AlwaysDenyPrivacyPolicyRule-test.js.map +1 -1
- package/build/rules/__tests__/AlwaysSkipPrivacyPolicyRule-test.js +1 -0
- package/build/rules/__tests__/AlwaysSkipPrivacyPolicyRule-test.js.map +1 -1
- package/build/utils/testing/PrivacyPolicyRuleTestUtils.d.ts +2 -0
- package/build/utils/testing/PrivacyPolicyRuleTestUtils.js +6 -6
- package/build/utils/testing/PrivacyPolicyRuleTestUtils.js.map +1 -1
- package/build/utils/testing/StubCacheAdapter.d.ts +6 -9
- package/build/utils/testing/StubCacheAdapter.js +0 -6
- package/build/utils/testing/StubCacheAdapter.js.map +1 -1
- package/package.json +1 -1
- package/src/ComposedEntityCacheAdapter.ts +86 -0
- package/src/ComposedSecondaryEntityCache.ts +63 -0
- package/src/Entity.ts +6 -4
- package/src/EntityAssociationLoader.ts +4 -4
- package/src/EntityCacheAdapter.ts +2 -10
- package/src/EntityFieldDefinition.ts +8 -0
- package/src/EntityFields.ts +45 -0
- package/src/EntityLoader.ts +5 -1
- package/src/EntityLoaderFactory.ts +4 -2
- package/src/EntityMutationInfo.ts +13 -3
- package/src/EntityMutator.ts +44 -21
- package/src/EntityMutatorFactory.ts +10 -4
- package/src/EntityPrivacyPolicy.ts +31 -1
- package/src/GenericSecondaryEntityCache.ts +98 -0
- package/src/IEntityGenericCacher.ts +15 -0
- package/src/ReadonlyEntity.ts +1 -1
- package/src/ViewerScopedEntityLoaderFactory.ts +8 -3
- package/src/ViewerScopedEntityMutatorFactory.ts +22 -7
- package/src/__tests__/ComposedCacheAdapter-test.ts +280 -0
- package/src/__tests__/ComposedSecondaryEntityCache-test.ts +101 -0
- package/src/__tests__/EntityCommonUseCases-test.ts +2 -1
- package/src/__tests__/EntityEdges-test.ts +286 -45
- package/src/__tests__/EntityLoader-constructor-test.ts +3 -1
- package/src/__tests__/EntityLoader-test.ts +26 -1
- package/src/__tests__/EntityMutator-test.ts +99 -37
- package/src/__tests__/EntityPrivacyPolicy-test.ts +66 -7
- package/src/__tests__/EntitySecondaryCacheLoader-test.ts +1 -0
- package/src/__tests__/ViewerScopedEntityLoaderFactory-test.ts +4 -2
- package/src/__tests__/ViewerScopedEntityMutatorFactory-test.ts +6 -2
- package/src/index.ts +2 -0
- package/src/internal/ReadThroughEntityCache.ts +6 -28
- package/src/internal/__tests__/ReadThroughEntityCache-test.ts +0 -44
- package/src/rules/AlwaysAllowPrivacyPolicyRule.ts +2 -0
- package/src/rules/AlwaysDenyPrivacyPolicyRule.ts +2 -0
- package/src/rules/AlwaysSkipPrivacyPolicyRule.ts +2 -0
- package/src/rules/PrivacyPolicyRule.ts +2 -0
- package/src/rules/__tests__/AlwaysAllowPrivacyPolicyRule-test.ts +2 -0
- package/src/rules/__tests__/AlwaysDenyPrivacyPolicyRule-test.ts +2 -0
- package/src/rules/__tests__/AlwaysSkipPrivacyPolicyRule-test.ts +2 -0
- package/src/utils/testing/PrivacyPolicyRuleTestUtils.ts +14 -6
- package/src/utils/testing/StubCacheAdapter.ts +11 -17
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import EntityCacheAdapter from './EntityCacheAdapter';
|
|
2
|
+
import EntityConfiguration from './EntityConfiguration';
|
|
3
|
+
import { CacheLoadResult } from './internal/ReadThroughEntityCache';
|
|
4
|
+
export default class ComposedEntityCacheAdapter<TFields> extends EntityCacheAdapter<TFields> {
|
|
5
|
+
private readonly cacheAdapters;
|
|
6
|
+
/**
|
|
7
|
+
* A {@link EntityCacheAdapter} that composes other {@link EntityCacheAdapter} instances.
|
|
8
|
+
*
|
|
9
|
+
* @param entityConfiguration - configuration for entity being loaded
|
|
10
|
+
* @param cacheAdapters - list of cache adapters to compose in order of precedence.
|
|
11
|
+
* Earlier cache adapters are read from first and written to (including invalidations) last.
|
|
12
|
+
* Typically, caches closer to the application should be ordered before caches closer to the database.
|
|
13
|
+
*/
|
|
14
|
+
constructor(entityConfiguration: EntityConfiguration<TFields>, cacheAdapters: EntityCacheAdapter<TFields>[]);
|
|
15
|
+
loadManyAsync<N extends keyof TFields>(fieldName: N, fieldValues: readonly NonNullable<TFields[N]>[]): Promise<ReadonlyMap<NonNullable<TFields[N]>, CacheLoadResult<TFields>>>;
|
|
16
|
+
cacheManyAsync<N extends keyof TFields>(fieldName: N, objectMap: ReadonlyMap<NonNullable<TFields[N]>, Readonly<TFields>>): Promise<void>;
|
|
17
|
+
cacheDBMissesAsync<N extends keyof TFields>(fieldName: N, fieldValues: readonly NonNullable<TFields[N]>[]): Promise<void>;
|
|
18
|
+
invalidateManyAsync<N extends keyof TFields>(fieldName: N, fieldValues: readonly NonNullable<TFields[N]>[]): Promise<void>;
|
|
19
|
+
}
|
|
@@ -0,0 +1,66 @@
|
|
|
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
|
+
const nullthrows_1 = __importDefault(require("nullthrows"));
|
|
7
|
+
const EntityCacheAdapter_1 = __importDefault(require("./EntityCacheAdapter"));
|
|
8
|
+
const ReadThroughEntityCache_1 = require("./internal/ReadThroughEntityCache");
|
|
9
|
+
class ComposedEntityCacheAdapter extends EntityCacheAdapter_1.default {
|
|
10
|
+
/**
|
|
11
|
+
* A {@link EntityCacheAdapter} that composes other {@link EntityCacheAdapter} instances.
|
|
12
|
+
*
|
|
13
|
+
* @param entityConfiguration - configuration for entity being loaded
|
|
14
|
+
* @param cacheAdapters - list of cache adapters to compose in order of precedence.
|
|
15
|
+
* Earlier cache adapters are read from first and written to (including invalidations) last.
|
|
16
|
+
* Typically, caches closer to the application should be ordered before caches closer to the database.
|
|
17
|
+
*/
|
|
18
|
+
constructor(entityConfiguration, cacheAdapters) {
|
|
19
|
+
super(entityConfiguration);
|
|
20
|
+
this.cacheAdapters = cacheAdapters;
|
|
21
|
+
}
|
|
22
|
+
async loadManyAsync(fieldName, fieldValues) {
|
|
23
|
+
const retMap = new Map();
|
|
24
|
+
let unfulfilledFieldValues = fieldValues;
|
|
25
|
+
for (const cacheAdapter of this.cacheAdapters) {
|
|
26
|
+
const cacheResultsFromAdapter = await cacheAdapter.loadManyAsync(fieldName, unfulfilledFieldValues);
|
|
27
|
+
const newUnfulfilledFieldValues = [];
|
|
28
|
+
for (const [fieldValue, cacheResult] of cacheResultsFromAdapter) {
|
|
29
|
+
if (cacheResult.status === ReadThroughEntityCache_1.CacheStatus.MISS) {
|
|
30
|
+
newUnfulfilledFieldValues.push(fieldValue);
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
retMap.set(fieldValue, cacheResult);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
unfulfilledFieldValues = newUnfulfilledFieldValues;
|
|
37
|
+
}
|
|
38
|
+
for (const fieldValue of unfulfilledFieldValues) {
|
|
39
|
+
retMap.set(fieldValue, { status: ReadThroughEntityCache_1.CacheStatus.MISS });
|
|
40
|
+
}
|
|
41
|
+
return retMap;
|
|
42
|
+
}
|
|
43
|
+
async cacheManyAsync(fieldName, objectMap) {
|
|
44
|
+
// write to lower layers first
|
|
45
|
+
for (let i = this.cacheAdapters.length - 1; i >= 0; i--) {
|
|
46
|
+
const cacheAdapter = (0, nullthrows_1.default)(this.cacheAdapters[i]);
|
|
47
|
+
await cacheAdapter.cacheManyAsync(fieldName, objectMap);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
async cacheDBMissesAsync(fieldName, fieldValues) {
|
|
51
|
+
// write to lower layers first
|
|
52
|
+
for (let i = this.cacheAdapters.length - 1; i >= 0; i--) {
|
|
53
|
+
const cacheAdapter = (0, nullthrows_1.default)(this.cacheAdapters[i]);
|
|
54
|
+
await cacheAdapter.cacheDBMissesAsync(fieldName, fieldValues);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
async invalidateManyAsync(fieldName, fieldValues) {
|
|
58
|
+
// delete from lower layers first
|
|
59
|
+
for (let i = this.cacheAdapters.length - 1; i >= 0; i--) {
|
|
60
|
+
const cacheAdapter = (0, nullthrows_1.default)(this.cacheAdapters[i]);
|
|
61
|
+
await cacheAdapter.invalidateManyAsync(fieldName, fieldValues);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
exports.default = ComposedEntityCacheAdapter;
|
|
66
|
+
//# sourceMappingURL=ComposedEntityCacheAdapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ComposedEntityCacheAdapter.js","sourceRoot":"","sources":["../src/ComposedEntityCacheAdapter.ts"],"names":[],"mappings":";;;;;AAAA,4DAAoC;AAEpC,8EAAsD;AAEtD,8EAAiF;AAEjF,MAAqB,0BAAoC,SAAQ,4BAA2B;IAC1F;;;;;;;OAOG;IACH,YACE,mBAAiD,EAChC,aAA4C;QAE7D,KAAK,CAAC,mBAAmB,CAAC,CAAC;QAFV,kBAAa,GAAb,aAAa,CAA+B;IAG/D,CAAC;IAEM,KAAK,CAAC,aAAa,CACxB,SAAY,EACZ,WAA+C;QAE/C,MAAM,MAAM,GAAG,IAAI,GAAG,EAAqD,CAAC;QAE5E,IAAI,sBAAsB,GAAG,WAAW,CAAC;QACzC,KAAK,MAAM,YAAY,IAAI,IAAI,CAAC,aAAa,EAAE;YAC7C,MAAM,uBAAuB,GAAG,MAAM,YAAY,CAAC,aAAa,CAC9D,SAAS,EACT,sBAAsB,CACvB,CAAC;YAEF,MAAM,yBAAyB,GAAG,EAAE,CAAC;YACrC,KAAK,MAAM,CAAC,UAAU,EAAE,WAAW,CAAC,IAAI,uBAAuB,EAAE;gBAC/D,IAAI,WAAW,CAAC,MAAM,KAAK,oCAAW,CAAC,IAAI,EAAE;oBAC3C,yBAAyB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;iBAC5C;qBAAM;oBACL,MAAM,CAAC,GAAG,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;iBACrC;aACF;YACD,sBAAsB,GAAG,yBAAyB,CAAC;SACpD;QAED,KAAK,MAAM,UAAU,IAAI,sBAAsB,EAAE;YAC/C,MAAM,CAAC,GAAG,CAAC,UAAU,EAAE,EAAE,MAAM,EAAE,oCAAW,CAAC,IAAI,EAAE,CAAC,CAAC;SACtD;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAEM,KAAK,CAAC,cAAc,CACzB,SAAY,EACZ,SAAkE;QAElE,8BAA8B;QAC9B,KAAK,IAAI,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;YACvD,MAAM,YAAY,GAAG,IAAA,oBAAU,EAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;YACvD,MAAM,YAAY,CAAC,cAAc,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;SACzD;IACH,CAAC;IAEM,KAAK,CAAC,kBAAkB,CAC7B,SAAY,EACZ,WAA+C;QAE/C,8BAA8B;QAC9B,KAAK,IAAI,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;YACvD,MAAM,YAAY,GAAG,IAAA,oBAAU,EAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;YACvD,MAAM,YAAY,CAAC,kBAAkB,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;SAC/D;IACH,CAAC;IAEM,KAAK,CAAC,mBAAmB,CAC9B,SAAY,EACZ,WAA+C;QAE/C,iCAAiC;QACjC,KAAK,IAAI,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;YACvD,MAAM,YAAY,GAAG,IAAA,oBAAU,EAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;YACvD,MAAM,YAAY,CAAC,mBAAmB,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;SAChE;IACH,CAAC;CACF;AA/ED,6CA+EC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { ISecondaryEntityCache } from './EntitySecondaryCacheLoader';
|
|
2
|
+
export default class ComposedSecondaryEntityCache<TLoadParams, TFields> implements ISecondaryEntityCache<TFields, TLoadParams> {
|
|
3
|
+
private readonly secondaryEntityCaches;
|
|
4
|
+
/**
|
|
5
|
+
* A {@link ISecondaryEntityCache} that composes other {@link ISecondaryEntityCache} instances.
|
|
6
|
+
*
|
|
7
|
+
* @param secondaryEntityCaches - list of caches to compose in order of precedence.
|
|
8
|
+
* Earlier caches are read from first and written to (including invalidations) last.
|
|
9
|
+
* Typically, caches closer to the application should be ordered before caches closer to the database.
|
|
10
|
+
*/
|
|
11
|
+
constructor(secondaryEntityCaches: ISecondaryEntityCache<TFields, TLoadParams>[]);
|
|
12
|
+
loadManyThroughAsync(loadParamsArray: readonly Readonly<TLoadParams>[], fetcher: (fetcherLoadParamsArray: readonly Readonly<TLoadParams>[]) => Promise<ReadonlyMap<Readonly<TLoadParams>, Readonly<TFields> | null>>): Promise<ReadonlyMap<Readonly<TLoadParams>, Readonly<TFields> | null>>;
|
|
13
|
+
private static loadManyThroughRecursivelyAsync;
|
|
14
|
+
invalidateManyAsync(loadParamsArray: readonly Readonly<TLoadParams>[]): Promise<void>;
|
|
15
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
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
|
+
const nullthrows_1 = __importDefault(require("nullthrows"));
|
|
7
|
+
class ComposedSecondaryEntityCache {
|
|
8
|
+
/**
|
|
9
|
+
* A {@link ISecondaryEntityCache} that composes other {@link ISecondaryEntityCache} instances.
|
|
10
|
+
*
|
|
11
|
+
* @param secondaryEntityCaches - list of caches to compose in order of precedence.
|
|
12
|
+
* Earlier caches are read from first and written to (including invalidations) last.
|
|
13
|
+
* Typically, caches closer to the application should be ordered before caches closer to the database.
|
|
14
|
+
*/
|
|
15
|
+
constructor(secondaryEntityCaches) {
|
|
16
|
+
this.secondaryEntityCaches = secondaryEntityCaches;
|
|
17
|
+
}
|
|
18
|
+
async loadManyThroughAsync(loadParamsArray, fetcher) {
|
|
19
|
+
return await ComposedSecondaryEntityCache.loadManyThroughRecursivelyAsync(this.secondaryEntityCaches, loadParamsArray, fetcher);
|
|
20
|
+
}
|
|
21
|
+
static async loadManyThroughRecursivelyAsync(secondaryEntityCaches, loadParamsArray, fetcher) {
|
|
22
|
+
if (secondaryEntityCaches.length === 0) {
|
|
23
|
+
return await fetcher(loadParamsArray);
|
|
24
|
+
}
|
|
25
|
+
const [firstCache, ...restCaches] = secondaryEntityCaches;
|
|
26
|
+
return await (0, nullthrows_1.default)(firstCache).loadManyThroughAsync(loadParamsArray, (fetcherLoadParamsArray) => ComposedSecondaryEntityCache.loadManyThroughRecursivelyAsync(restCaches, fetcherLoadParamsArray, fetcher));
|
|
27
|
+
}
|
|
28
|
+
async invalidateManyAsync(loadParamsArray) {
|
|
29
|
+
// invalidate lower layers first
|
|
30
|
+
for (let i = this.secondaryEntityCaches.length - 1; i >= 0; i--) {
|
|
31
|
+
const secondaryEntityCache = (0, nullthrows_1.default)(this.secondaryEntityCaches[i]);
|
|
32
|
+
await secondaryEntityCache.invalidateManyAsync(loadParamsArray);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
exports.default = ComposedSecondaryEntityCache;
|
|
37
|
+
//# sourceMappingURL=ComposedSecondaryEntityCache.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ComposedSecondaryEntityCache.js","sourceRoot":"","sources":["../src/ComposedSecondaryEntityCache.ts"],"names":[],"mappings":";;;;;AAAA,4DAAoC;AAIpC,MAAqB,4BAA4B;IAG/C;;;;;;OAMG;IACH,YACmB,qBAAoE;QAApE,0BAAqB,GAArB,qBAAqB,CAA+C;IACpF,CAAC;IAEJ,KAAK,CAAC,oBAAoB,CACxB,eAAiD,EACjD,OAE0E;QAE1E,OAAO,MAAM,4BAA4B,CAAC,+BAA+B,CACvE,IAAI,CAAC,qBAAqB,EAC1B,eAAe,EACf,OAAO,CACR,CAAC;IACJ,CAAC;IAEO,MAAM,CAAC,KAAK,CAAC,+BAA+B,CAClD,qBAAoE,EACpE,eAAiD,EACjD,OAE0E;QAE1E,IAAI,qBAAqB,CAAC,MAAM,KAAK,CAAC,EAAE;YACtC,OAAO,MAAM,OAAO,CAAC,eAAe,CAAC,CAAC;SACvC;QAED,MAAM,CAAC,UAAU,EAAE,GAAG,UAAU,CAAC,GAAG,qBAAqB,CAAC;QAE1D,OAAO,MAAM,IAAA,oBAAU,EAAC,UAAU,CAAC,CAAC,oBAAoB,CACtD,eAAe,EACf,CAAC,sBAAsB,EAAE,EAAE,CACzB,4BAA4B,CAAC,+BAA+B,CAC1D,UAAU,EACV,sBAAsB,EACtB,OAAO,CACR,CACJ,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,mBAAmB,CAAC,eAAiD;QACzE,gCAAgC;QAChC,KAAK,IAAI,CAAC,GAAG,IAAI,CAAC,qBAAqB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;YAC/D,MAAM,oBAAoB,GAAG,IAAA,oBAAU,EAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,CAAC;YACvE,MAAM,oBAAoB,CAAC,mBAAmB,CAAC,eAAe,CAAC,CAAC;SACjE;IACH,CAAC;CACF;AA1DD,+CA0DC"}
|
package/build/Entity.js
CHANGED
|
@@ -37,7 +37,7 @@ class Entity extends ReadonlyEntity_1.default {
|
|
|
37
37
|
return viewerContext
|
|
38
38
|
.getViewerScopedEntityCompanionForClass(this)
|
|
39
39
|
.getMutatorFactory()
|
|
40
|
-
.forCreate(queryContext);
|
|
40
|
+
.forCreate(queryContext, { cascadingDeleteCause: null });
|
|
41
41
|
}
|
|
42
42
|
/**
|
|
43
43
|
* Vend mutator for updating an existing entity in given query context.
|
|
@@ -54,7 +54,7 @@ class Entity extends ReadonlyEntity_1.default {
|
|
|
54
54
|
.getViewerContext()
|
|
55
55
|
.getViewerScopedEntityCompanionForClass(this)
|
|
56
56
|
.getMutatorFactory()
|
|
57
|
-
.forUpdate(existingEntity, queryContext);
|
|
57
|
+
.forUpdate(existingEntity, queryContext, { cascadingDeleteCause: null });
|
|
58
58
|
}
|
|
59
59
|
/**
|
|
60
60
|
* Delete an existing entity in given query context.
|
|
@@ -70,7 +70,7 @@ class Entity extends ReadonlyEntity_1.default {
|
|
|
70
70
|
.getViewerContext()
|
|
71
71
|
.getViewerScopedEntityCompanionForClass(this)
|
|
72
72
|
.getMutatorFactory()
|
|
73
|
-
.forDelete(existingEntity, queryContext)
|
|
73
|
+
.forDelete(existingEntity, queryContext, { cascadingDeleteCause: null })
|
|
74
74
|
.deleteAsync();
|
|
75
75
|
}
|
|
76
76
|
/**
|
|
@@ -87,7 +87,7 @@ class Entity extends ReadonlyEntity_1.default {
|
|
|
87
87
|
.getViewerContext()
|
|
88
88
|
.getViewerScopedEntityCompanionForClass(this)
|
|
89
89
|
.getMutatorFactory()
|
|
90
|
-
.forDelete(existingEntity, queryContext)
|
|
90
|
+
.forDelete(existingEntity, queryContext, { cascadingDeleteCause: null })
|
|
91
91
|
.enforceDeleteAsync();
|
|
92
92
|
}
|
|
93
93
|
/**
|
|
@@ -115,7 +115,7 @@ class Entity extends ReadonlyEntity_1.default {
|
|
|
115
115
|
.getViewerContext()
|
|
116
116
|
.getViewerScopedEntityCompanionForClass(this);
|
|
117
117
|
const privacyPolicy = new (this.getCompanionDefinition().privacyPolicyClass)();
|
|
118
|
-
const evaluationResult = await (0, results_1.asyncResult)(privacyPolicy.authorizeUpdateAsync(existingEntity.getViewerContext(), queryContext, existingEntity, companion.getMetricsAdapter()));
|
|
118
|
+
const evaluationResult = await (0, results_1.asyncResult)(privacyPolicy.authorizeUpdateAsync(existingEntity.getViewerContext(), queryContext, { cascadingDeleteCause: null }, existingEntity, companion.getMetricsAdapter()));
|
|
119
119
|
return evaluationResult.ok;
|
|
120
120
|
}
|
|
121
121
|
/**
|
|
@@ -136,7 +136,7 @@ class Entity extends ReadonlyEntity_1.default {
|
|
|
136
136
|
.getViewerContext()
|
|
137
137
|
.getViewerScopedEntityCompanionForClass(this);
|
|
138
138
|
const privacyPolicy = new (this.getCompanionDefinition().privacyPolicyClass)();
|
|
139
|
-
const evaluationResult = await (0, results_1.asyncResult)(privacyPolicy.authorizeDeleteAsync(existingEntity.getViewerContext(), queryContext, existingEntity, companion.getMetricsAdapter()));
|
|
139
|
+
const evaluationResult = await (0, results_1.asyncResult)(privacyPolicy.authorizeDeleteAsync(existingEntity.getViewerContext(), queryContext, { cascadingDeleteCause: null }, existingEntity, companion.getMetricsAdapter()));
|
|
140
140
|
return evaluationResult.ok;
|
|
141
141
|
}
|
|
142
142
|
}
|
package/build/Entity.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Entity.js","sourceRoot":"","sources":["../src/Entity.ts"],"names":[],"mappings":";;;;;AAAA,2CAAoD;AAMpD,sEAA8C;AAG9C;;;;;;;;;;;;;;;;;GAiBG;AACH,MAA8B,MAK5B,SAAQ,wBAA6D;IACrE;;;;;OAKG;IACH,MAAM,CAAC,OAAO,CAuBZ,aAA+B,EAC/B,eAAmC,aAAa;SAC7C,sCAAsC,CAAC,IAAI,CAAC;SAC5C,uBAAuB,EAAE;SACzB,eAAe,EAAE;QAEpB,OAAO,aAAa;aACjB,sCAAsC,CAAC,IAAI,CAAC;aAC5C,iBAAiB,EAAE;aACnB,SAAS,CAAC,YAAY,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"Entity.js","sourceRoot":"","sources":["../src/Entity.ts"],"names":[],"mappings":"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"}
|
|
@@ -25,7 +25,7 @@ class EntityAssociationLoader {
|
|
|
25
25
|
.getViewerContext()
|
|
26
26
|
.getViewerScopedEntityCompanionForClass(associatedEntityClass)
|
|
27
27
|
.getLoaderFactory()
|
|
28
|
-
.forLoad(queryContext);
|
|
28
|
+
.forLoad(queryContext, { cascadingDeleteCause: null });
|
|
29
29
|
return (await loader.loadByIDAsync(associatedEntityID));
|
|
30
30
|
}
|
|
31
31
|
/**
|
|
@@ -47,7 +47,7 @@ class EntityAssociationLoader {
|
|
|
47
47
|
.getViewerContext()
|
|
48
48
|
.getViewerScopedEntityCompanionForClass(associatedEntityClass)
|
|
49
49
|
.getLoaderFactory()
|
|
50
|
-
.forLoad(queryContext);
|
|
50
|
+
.forLoad(queryContext, { cascadingDeleteCause: null });
|
|
51
51
|
return await loader.loadManyByFieldEqualingAsync(associatedEntityFieldContainingThisID, thisID);
|
|
52
52
|
}
|
|
53
53
|
/**
|
|
@@ -71,7 +71,7 @@ class EntityAssociationLoader {
|
|
|
71
71
|
.getViewerContext()
|
|
72
72
|
.getViewerScopedEntityCompanionForClass(associatedEntityClass)
|
|
73
73
|
.getLoaderFactory()
|
|
74
|
-
.forLoad(queryContext);
|
|
74
|
+
.forLoad(queryContext, { cascadingDeleteCause: null });
|
|
75
75
|
return await loader.loadByFieldEqualingAsync(associatedEntityLookupByField, associatedFieldValue);
|
|
76
76
|
}
|
|
77
77
|
/**
|
|
@@ -95,7 +95,7 @@ class EntityAssociationLoader {
|
|
|
95
95
|
.getViewerContext()
|
|
96
96
|
.getViewerScopedEntityCompanionForClass(associatedEntityClass)
|
|
97
97
|
.getLoaderFactory()
|
|
98
|
-
.forLoad(queryContext);
|
|
98
|
+
.forLoad(queryContext, { cascadingDeleteCause: null });
|
|
99
99
|
return await loader.loadManyByFieldEqualingAsync(associatedEntityLookupByField, associatedFieldValue);
|
|
100
100
|
}
|
|
101
101
|
async loadAssociatedEntityThroughAsync(loadDirectives, queryContext) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EntityAssociationLoader.js","sourceRoot":"","sources":["../src/EntityAssociationLoader.ts"],"names":[],"mappings":";;AAAA,2CAA+C;AAQ/C,MAAqB,uBAAuB;IAO1C,YAA6B,MAAe;QAAf,WAAM,GAAN,MAAM,CAAS;IAAG,CAAC;IAEhD;;;;;;OAMG;IACH,KAAK,CAAC,yBAAyB,CAmB7B,gCAAmD,EACnD,qBAOC,EACD,eAAmC,IAAI,CAAC,MAAM;SAC3C,gBAAgB,EAAE;SAClB,sCAAsC,CAAC,qBAAqB,CAAC;SAC7D,uBAAuB,EAAE;SACzB,eAAe,EAAE;QAIpB,MAAM,kBAAkB,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,gCAAgC,CAAC,CAAC;QAClF,IAAI,CAAC,kBAAkB,EAAE;YACvB,OAAO,IAAA,gBAAM,EAAC,IAAI,CAEjB,CAAC;SACH;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM;aACvB,gBAAgB,EAAE;aAClB,sCAAsC,CAAC,qBAAqB,CAAC;aAC7D,gBAAgB,EAAE;aAClB,OAAO,CAAC,YAAY,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"EntityAssociationLoader.js","sourceRoot":"","sources":["../src/EntityAssociationLoader.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import EntityConfiguration from './EntityConfiguration';
|
|
2
|
-
import { FieldTransformerMap } from './internal/EntityFieldTransformationUtils';
|
|
3
2
|
import { CacheLoadResult } from './internal/ReadThroughEntityCache';
|
|
4
3
|
/**
|
|
5
4
|
* A cache adapter is an interface by which objects can be
|
|
@@ -8,25 +7,19 @@ import { CacheLoadResult } from './internal/ReadThroughEntityCache';
|
|
|
8
7
|
export default abstract class EntityCacheAdapter<TFields> {
|
|
9
8
|
protected readonly entityConfiguration: EntityConfiguration<TFields>;
|
|
10
9
|
constructor(entityConfiguration: EntityConfiguration<TFields>);
|
|
11
|
-
/**
|
|
12
|
-
* Transformer definitions for field types. Used to modify values as they are read from or written to
|
|
13
|
-
* the cache. Override in concrete subclasses to change transformation behavior.
|
|
14
|
-
* If a field type is not present in the map, then fields of that type will not be transformed.
|
|
15
|
-
*/
|
|
16
|
-
abstract getFieldTransformerMap(): FieldTransformerMap;
|
|
17
10
|
/**
|
|
18
11
|
* Load many objects from cache.
|
|
19
12
|
* @param fieldName - object field being queried
|
|
20
13
|
* @param fieldValues - fieldName field values being queried
|
|
21
14
|
* @returns map from all field values to a CacheLoadResult for each input value
|
|
22
15
|
*/
|
|
23
|
-
abstract loadManyAsync<N extends keyof TFields>(fieldName: N, fieldValues: readonly NonNullable<TFields[N]>[]): Promise<ReadonlyMap<NonNullable<TFields[N]>, CacheLoadResult
|
|
16
|
+
abstract loadManyAsync<N extends keyof TFields>(fieldName: N, fieldValues: readonly NonNullable<TFields[N]>[]): Promise<ReadonlyMap<NonNullable<TFields[N]>, CacheLoadResult<TFields>>>;
|
|
24
17
|
/**
|
|
25
18
|
* Cache many objects fetched from the DB.
|
|
26
19
|
* @param fieldName - object field being queried
|
|
27
20
|
* @param objectMap - map from field value to object to cache
|
|
28
21
|
*/
|
|
29
|
-
abstract cacheManyAsync<N extends keyof TFields>(fieldName: N, objectMap: ReadonlyMap<NonNullable<TFields[N]>,
|
|
22
|
+
abstract cacheManyAsync<N extends keyof TFields>(fieldName: N, objectMap: ReadonlyMap<NonNullable<TFields[N]>, Readonly<TFields>>): Promise<void>;
|
|
30
23
|
/**
|
|
31
24
|
* Negatively cache objects that could not be found in the cache or DB.
|
|
32
25
|
* @param fieldName - object field being queried
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EntityCacheAdapter.js","sourceRoot":"","sources":["../src/EntityCacheAdapter.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"EntityCacheAdapter.js","sourceRoot":"","sources":["../src/EntityCacheAdapter.ts"],"names":[],"mappings":";;AAGA;;;GAGG;AACH,MAA8B,kBAAkB;IAC9C,YAA+B,mBAAiD;QAAjD,wBAAmB,GAAnB,mBAAmB,CAA8B;IAAG,CAAC;CA2CrF;AA5CD,qCA4CC"}
|
|
@@ -24,6 +24,9 @@ export declare enum EntityEdgeDeletionBehavior {
|
|
|
24
24
|
*/
|
|
25
25
|
SET_NULL = 2
|
|
26
26
|
}
|
|
27
|
+
/**
|
|
28
|
+
* Defines an association between entities. An association is primarily used to define cascading deletion behavior.
|
|
29
|
+
*/
|
|
27
30
|
export interface EntityAssociationDefinition<TViewerContext extends ViewerContext, TAssociatedFields, TAssociatedID extends NonNullable<TAssociatedFields[TAssociatedSelectedFields]>, TAssociatedEntity extends ReadonlyEntity<TAssociatedFields, TAssociatedID, TViewerContext, TAssociatedSelectedFields>, TAssociatedPrivacyPolicy extends EntityPrivacyPolicy<TAssociatedFields, TAssociatedID, TViewerContext, TAssociatedEntity, TAssociatedSelectedFields>, TAssociatedSelectedFields extends keyof TAssociatedFields = keyof TAssociatedFields> {
|
|
28
31
|
/**
|
|
29
32
|
* Class of entity on the other end of this edge.
|
|
@@ -51,6 +54,10 @@ export interface EntityAssociationDefinition<TViewerContext extends ViewerContex
|
|
|
51
54
|
*/
|
|
52
55
|
edgeDeletionBehavior?: EntityEdgeDeletionBehavior;
|
|
53
56
|
}
|
|
57
|
+
/**
|
|
58
|
+
* Definition for a field referencing a column in the underlying database. Specifies things like
|
|
59
|
+
* cache behavior and associations, and handles input validation.
|
|
60
|
+
*/
|
|
54
61
|
export declare abstract class EntityFieldDefinition<T> {
|
|
55
62
|
readonly columnName: string;
|
|
56
63
|
readonly cache: boolean;
|
|
@@ -61,6 +68,7 @@ export declare abstract class EntityFieldDefinition<T> {
|
|
|
61
68
|
* @param cache - Whether or not to cache loaded instances of the entity by this field. The column name is
|
|
62
69
|
* used to derive a cache key for the cache entry. If true, this column must be able uniquely
|
|
63
70
|
* identify the entity.
|
|
71
|
+
* @param association - Defines the association behavior for an entity that this column references.
|
|
64
72
|
*/
|
|
65
73
|
constructor({ columnName, cache, association, }: {
|
|
66
74
|
columnName: string;
|
|
@@ -24,6 +24,10 @@ var EntityEdgeDeletionBehavior;
|
|
|
24
24
|
*/
|
|
25
25
|
EntityEdgeDeletionBehavior[EntityEdgeDeletionBehavior["SET_NULL"] = 2] = "SET_NULL";
|
|
26
26
|
})(EntityEdgeDeletionBehavior = exports.EntityEdgeDeletionBehavior || (exports.EntityEdgeDeletionBehavior = {}));
|
|
27
|
+
/**
|
|
28
|
+
* Definition for a field referencing a column in the underlying database. Specifies things like
|
|
29
|
+
* cache behavior and associations, and handles input validation.
|
|
30
|
+
*/
|
|
27
31
|
class EntityFieldDefinition {
|
|
28
32
|
/**
|
|
29
33
|
*
|
|
@@ -31,6 +35,7 @@ class EntityFieldDefinition {
|
|
|
31
35
|
* @param cache - Whether or not to cache loaded instances of the entity by this field. The column name is
|
|
32
36
|
* used to derive a cache key for the cache entry. If true, this column must be able uniquely
|
|
33
37
|
* identify the entity.
|
|
38
|
+
* @param association - Defines the association behavior for an entity that this column references.
|
|
34
39
|
*/
|
|
35
40
|
constructor({ columnName, cache = false, association, }) {
|
|
36
41
|
this.columnName = columnName;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EntityFieldDefinition.js","sourceRoot":"","sources":["../src/EntityFieldDefinition.ts"],"names":[],"mappings":";;;AAKA,IAAY,0BAuBX;AAvBD,WAAY,0BAA0B;IACpC;;;;;;OAMG;IACH,iIAA+B,CAAA;IAE/B;;;;OAIG;IACH,+FAAc,CAAA;IAEd;;;;OAIG;IACH,mFAAQ,CAAA;AACV,CAAC,EAvBW,0BAA0B,GAA1B,kCAA0B,KAA1B,kCAA0B,QAuBrC;
|
|
1
|
+
{"version":3,"file":"EntityFieldDefinition.js","sourceRoot":"","sources":["../src/EntityFieldDefinition.ts"],"names":[],"mappings":";;;AAKA,IAAY,0BAuBX;AAvBD,WAAY,0BAA0B;IACpC;;;;;;OAMG;IACH,iIAA+B,CAAA;IAE/B;;;;OAIG;IACH,+FAAc,CAAA;IAEd;;;;OAIG;IACH,mFAAQ,CAAA;AACV,CAAC,EAvBW,0BAA0B,GAA1B,kCAA0B,KAA1B,kCAA0B,QAuBrC;AA4DD;;;GAGG;AACH,MAAsB,qBAAqB;IAIzC;;;;;;;OAOG;IACH,YAAY,EACV,UAAU,EACV,KAAK,GAAG,KAAK,EACb,WAAW,GAKZ;QACC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;IACjC,CAAC;IAED;;;;OAIG;IACI,kBAAkB,CAAC,KAA2B;QACnD,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE;YACzC,OAAO,IAAI,CAAC;SACb;QAED,OAAO,IAAI,CAAC,0BAA0B,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC;CAEF;AAvCD,sDAuCC"}
|
package/build/EntityFields.d.ts
CHANGED
|
@@ -1,34 +1,72 @@
|
|
|
1
1
|
import { EntityFieldDefinition } from './EntityFieldDefinition';
|
|
2
|
+
/**
|
|
3
|
+
* {@link EntityFieldDefinition} for a column with a JS string type.
|
|
4
|
+
*/
|
|
2
5
|
export declare class StringField extends EntityFieldDefinition<string> {
|
|
3
6
|
protected validateInputValueInternal(value: string): boolean;
|
|
4
7
|
}
|
|
8
|
+
/**
|
|
9
|
+
* {@link EntityFieldDefinition} for a column with a JS string type.
|
|
10
|
+
* Enforces that the string is a valid UUID.
|
|
11
|
+
*/
|
|
5
12
|
export declare class UUIDField extends StringField {
|
|
6
13
|
protected validateInputValueInternal(value: string): boolean;
|
|
7
14
|
}
|
|
15
|
+
/**
|
|
16
|
+
* {@link EntityFieldDefinition} for a column with a JS Date type.
|
|
17
|
+
*/
|
|
8
18
|
export declare class DateField extends EntityFieldDefinition<Date> {
|
|
9
19
|
protected validateInputValueInternal(value: Date): boolean;
|
|
10
20
|
}
|
|
21
|
+
/**
|
|
22
|
+
* {@link EntityFieldDefinition} for a column with a JS boolean type.
|
|
23
|
+
*/
|
|
11
24
|
export declare class BooleanField extends EntityFieldDefinition<boolean> {
|
|
12
25
|
protected validateInputValueInternal(value: boolean): boolean;
|
|
13
26
|
}
|
|
27
|
+
/**
|
|
28
|
+
* {@link EntityFieldDefinition} for a column with a JS number type.
|
|
29
|
+
* Enforces that the number is an integer.
|
|
30
|
+
*/
|
|
14
31
|
export declare class IntField extends EntityFieldDefinition<number> {
|
|
15
32
|
protected validateInputValueInternal(value: number): boolean;
|
|
16
33
|
}
|
|
34
|
+
/**
|
|
35
|
+
* {@link EntityFieldDefinition} for a column with a JS number type.
|
|
36
|
+
* Enforces that the number is a float (which includes integers in JS).
|
|
37
|
+
*/
|
|
17
38
|
export declare class FloatField extends EntityFieldDefinition<number> {
|
|
18
39
|
protected validateInputValueInternal(value: number): boolean;
|
|
19
40
|
}
|
|
41
|
+
/**
|
|
42
|
+
* {@link EntityFieldDefinition} for a column with a JS string array type.
|
|
43
|
+
* Enforces that every member of the string array is a string.
|
|
44
|
+
*/
|
|
20
45
|
export declare class StringArrayField extends EntityFieldDefinition<string[]> {
|
|
21
46
|
protected validateInputValueInternal(value: string[]): boolean;
|
|
22
47
|
}
|
|
48
|
+
/**
|
|
49
|
+
* {@link EntityFieldDefinition} for a column with a JS JSON object type.
|
|
50
|
+
*/
|
|
23
51
|
export declare class JSONObjectField extends EntityFieldDefinition<object> {
|
|
24
52
|
protected validateInputValueInternal(value: object): boolean;
|
|
25
53
|
}
|
|
54
|
+
/**
|
|
55
|
+
* {@link EntityFieldDefinition} for a enum column with a JS string or number type.
|
|
56
|
+
*/
|
|
26
57
|
export declare class EnumField extends EntityFieldDefinition<string | number> {
|
|
27
58
|
protected validateInputValueInternal(value: string | number): boolean;
|
|
28
59
|
}
|
|
60
|
+
/**
|
|
61
|
+
* {@link EntityFieldDefinition} for a column with a JS JSON array type.
|
|
62
|
+
*/
|
|
29
63
|
export declare class JSONArrayField extends EntityFieldDefinition<any[]> {
|
|
30
64
|
protected validateInputValueInternal(value: any[]): boolean;
|
|
31
65
|
}
|
|
66
|
+
/**
|
|
67
|
+
* {@link EntityFieldDefinition} for a column that may be a JS JSON array type.
|
|
68
|
+
* Does not do any validation.
|
|
69
|
+
*/
|
|
32
70
|
export declare class MaybeJSONArrayField extends EntityFieldDefinition<any | any[]> {
|
|
33
71
|
protected validateInputValueInternal(_value: any): boolean;
|
|
34
72
|
}
|
package/build/EntityFields.js
CHANGED
|
@@ -3,66 +3,104 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.MaybeJSONArrayField = exports.JSONArrayField = exports.EnumField = exports.JSONObjectField = exports.StringArrayField = exports.FloatField = exports.IntField = exports.BooleanField = exports.DateField = exports.UUIDField = exports.StringField = void 0;
|
|
4
4
|
const uuid_1 = require("uuid");
|
|
5
5
|
const EntityFieldDefinition_1 = require("./EntityFieldDefinition");
|
|
6
|
+
/**
|
|
7
|
+
* {@link EntityFieldDefinition} for a column with a JS string type.
|
|
8
|
+
*/
|
|
6
9
|
class StringField extends EntityFieldDefinition_1.EntityFieldDefinition {
|
|
7
10
|
validateInputValueInternal(value) {
|
|
8
11
|
return typeof value === 'string';
|
|
9
12
|
}
|
|
10
13
|
}
|
|
11
14
|
exports.StringField = StringField;
|
|
15
|
+
/**
|
|
16
|
+
* {@link EntityFieldDefinition} for a column with a JS string type.
|
|
17
|
+
* Enforces that the string is a valid UUID.
|
|
18
|
+
*/
|
|
12
19
|
class UUIDField extends StringField {
|
|
13
20
|
validateInputValueInternal(value) {
|
|
14
21
|
return (0, uuid_1.validate)(value);
|
|
15
22
|
}
|
|
16
23
|
}
|
|
17
24
|
exports.UUIDField = UUIDField;
|
|
25
|
+
/**
|
|
26
|
+
* {@link EntityFieldDefinition} for a column with a JS Date type.
|
|
27
|
+
*/
|
|
18
28
|
class DateField extends EntityFieldDefinition_1.EntityFieldDefinition {
|
|
19
29
|
validateInputValueInternal(value) {
|
|
20
30
|
return value instanceof Date;
|
|
21
31
|
}
|
|
22
32
|
}
|
|
23
33
|
exports.DateField = DateField;
|
|
34
|
+
/**
|
|
35
|
+
* {@link EntityFieldDefinition} for a column with a JS boolean type.
|
|
36
|
+
*/
|
|
24
37
|
class BooleanField extends EntityFieldDefinition_1.EntityFieldDefinition {
|
|
25
38
|
validateInputValueInternal(value) {
|
|
26
39
|
return typeof value === 'boolean';
|
|
27
40
|
}
|
|
28
41
|
}
|
|
29
42
|
exports.BooleanField = BooleanField;
|
|
43
|
+
/**
|
|
44
|
+
* {@link EntityFieldDefinition} for a column with a JS number type.
|
|
45
|
+
* Enforces that the number is an integer.
|
|
46
|
+
*/
|
|
30
47
|
class IntField extends EntityFieldDefinition_1.EntityFieldDefinition {
|
|
31
48
|
validateInputValueInternal(value) {
|
|
32
49
|
return typeof value === 'number' && Number.isInteger(value);
|
|
33
50
|
}
|
|
34
51
|
}
|
|
35
52
|
exports.IntField = IntField;
|
|
53
|
+
/**
|
|
54
|
+
* {@link EntityFieldDefinition} for a column with a JS number type.
|
|
55
|
+
* Enforces that the number is a float (which includes integers in JS).
|
|
56
|
+
*/
|
|
36
57
|
class FloatField extends EntityFieldDefinition_1.EntityFieldDefinition {
|
|
37
58
|
validateInputValueInternal(value) {
|
|
38
59
|
return typeof value === 'number';
|
|
39
60
|
}
|
|
40
61
|
}
|
|
41
62
|
exports.FloatField = FloatField;
|
|
63
|
+
/**
|
|
64
|
+
* {@link EntityFieldDefinition} for a column with a JS string array type.
|
|
65
|
+
* Enforces that every member of the string array is a string.
|
|
66
|
+
*/
|
|
42
67
|
class StringArrayField extends EntityFieldDefinition_1.EntityFieldDefinition {
|
|
43
68
|
validateInputValueInternal(value) {
|
|
44
69
|
return Array.isArray(value) && value.every((subValue) => typeof subValue === 'string');
|
|
45
70
|
}
|
|
46
71
|
}
|
|
47
72
|
exports.StringArrayField = StringArrayField;
|
|
73
|
+
/**
|
|
74
|
+
* {@link EntityFieldDefinition} for a column with a JS JSON object type.
|
|
75
|
+
*/
|
|
48
76
|
class JSONObjectField extends EntityFieldDefinition_1.EntityFieldDefinition {
|
|
49
77
|
validateInputValueInternal(value) {
|
|
50
78
|
return typeof value === 'object' && !Array.isArray(value);
|
|
51
79
|
}
|
|
52
80
|
}
|
|
53
81
|
exports.JSONObjectField = JSONObjectField;
|
|
82
|
+
/**
|
|
83
|
+
* {@link EntityFieldDefinition} for a enum column with a JS string or number type.
|
|
84
|
+
*/
|
|
54
85
|
class EnumField extends EntityFieldDefinition_1.EntityFieldDefinition {
|
|
55
86
|
validateInputValueInternal(value) {
|
|
56
87
|
return typeof value === 'number' || typeof value === 'string';
|
|
57
88
|
}
|
|
58
89
|
}
|
|
59
90
|
exports.EnumField = EnumField;
|
|
91
|
+
/**
|
|
92
|
+
* {@link EntityFieldDefinition} for a column with a JS JSON array type.
|
|
93
|
+
*/
|
|
60
94
|
class JSONArrayField extends EntityFieldDefinition_1.EntityFieldDefinition {
|
|
61
95
|
validateInputValueInternal(value) {
|
|
62
96
|
return Array.isArray(value);
|
|
63
97
|
}
|
|
64
98
|
}
|
|
65
99
|
exports.JSONArrayField = JSONArrayField;
|
|
100
|
+
/**
|
|
101
|
+
* {@link EntityFieldDefinition} for a column that may be a JS JSON array type.
|
|
102
|
+
* Does not do any validation.
|
|
103
|
+
*/
|
|
66
104
|
class MaybeJSONArrayField extends EntityFieldDefinition_1.EntityFieldDefinition {
|
|
67
105
|
validateInputValueInternal(_value) {
|
|
68
106
|
return true;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EntityFields.js","sourceRoot":"","sources":["../src/EntityFields.ts"],"names":[],"mappings":";;;AAAA,+BAAgD;AAEhD,mEAAgE;AAEhE,MAAa,WAAY,SAAQ,6CAA6B;IAClD,0BAA0B,CAAC,KAAa;QAChD,OAAO,OAAO,KAAK,KAAK,QAAQ,CAAC;IACnC,CAAC;CACF;AAJD,kCAIC;
|
|
1
|
+
{"version":3,"file":"EntityFields.js","sourceRoot":"","sources":["../src/EntityFields.ts"],"names":[],"mappings":";;;AAAA,+BAAgD;AAEhD,mEAAgE;AAEhE;;GAEG;AACH,MAAa,WAAY,SAAQ,6CAA6B;IAClD,0BAA0B,CAAC,KAAa;QAChD,OAAO,OAAO,KAAK,KAAK,QAAQ,CAAC;IACnC,CAAC;CACF;AAJD,kCAIC;AAED;;;GAGG;AACH,MAAa,SAAU,SAAQ,WAAW;IACrB,0BAA0B,CAAC,KAAa;QACzD,OAAO,IAAA,eAAY,EAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;CACF;AAJD,8BAIC;AAED;;GAEG;AACH,MAAa,SAAU,SAAQ,6CAA2B;IAC9C,0BAA0B,CAAC,KAAW;QAC9C,OAAO,KAAK,YAAY,IAAI,CAAC;IAC/B,CAAC;CACF;AAJD,8BAIC;AAED;;GAEG;AACH,MAAa,YAAa,SAAQ,6CAA8B;IACpD,0BAA0B,CAAC,KAAc;QACjD,OAAO,OAAO,KAAK,KAAK,SAAS,CAAC;IACpC,CAAC;CACF;AAJD,oCAIC;AAED;;;GAGG;AACH,MAAa,QAAS,SAAQ,6CAA6B;IAC/C,0BAA0B,CAAC,KAAa;QAChD,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAI,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC9D,CAAC;CACF;AAJD,4BAIC;AAED;;;GAGG;AACH,MAAa,UAAW,SAAQ,6CAA6B;IACjD,0BAA0B,CAAC,KAAa;QAChD,OAAO,OAAO,KAAK,KAAK,QAAQ,CAAC;IACnC,CAAC;CACF;AAJD,gCAIC;AAED;;;GAGG;AACH,MAAa,gBAAiB,SAAQ,6CAA+B;IACzD,0BAA0B,CAAC,KAAe;QAClD,OAAO,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,OAAO,QAAQ,KAAK,QAAQ,CAAC,CAAC;IACzF,CAAC;CACF;AAJD,4CAIC;AAED;;GAEG;AACH,MAAa,eAAgB,SAAQ,6CAA6B;IACtD,0BAA0B,CAAC,KAAa;QAChD,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IAC5D,CAAC;CACF;AAJD,0CAIC;AAED;;GAEG;AACH,MAAa,SAAU,SAAQ,6CAAsC;IACzD,0BAA0B,CAAC,KAAsB;QACzD,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAI,OAAO,KAAK,KAAK,QAAQ,CAAC;IAChE,CAAC;CACF;AAJD,8BAIC;AAED;;GAEG;AACH,MAAa,cAAe,SAAQ,6CAA4B;IACpD,0BAA0B,CAAC,KAAY;QAC/C,OAAO,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;CACF;AAJD,wCAIC;AAED;;;GAGG;AACH,MAAa,mBAAoB,SAAQ,6CAAkC;IAC/D,0BAA0B,CAAC,MAAW;QAC9C,OAAO,IAAI,CAAC;IACd,CAAC;CACF;AAJD,kDAIC"}
|
package/build/EntityLoader.d.ts
CHANGED
|
@@ -3,7 +3,7 @@ import EnforcingEntityLoader from './EnforcingEntityLoader';
|
|
|
3
3
|
import { IEntityClass } from './Entity';
|
|
4
4
|
import EntityConfiguration from './EntityConfiguration';
|
|
5
5
|
import { FieldEqualityCondition, QuerySelectionModifiers } from './EntityDatabaseAdapter';
|
|
6
|
-
import EntityPrivacyPolicy from './EntityPrivacyPolicy';
|
|
6
|
+
import EntityPrivacyPolicy, { EntityPrivacyPolicyEvaluationContext } from './EntityPrivacyPolicy';
|
|
7
7
|
import { EntityQueryContext } from './EntityQueryContext';
|
|
8
8
|
import ReadonlyEntity from './ReadonlyEntity';
|
|
9
9
|
import ViewerContext from './ViewerContext';
|
|
@@ -16,12 +16,13 @@ import IEntityMetricsAdapter from './metrics/IEntityMetricsAdapter';
|
|
|
16
16
|
export default class EntityLoader<TFields, TID extends NonNullable<TFields[TSelectedFields]>, TViewerContext extends ViewerContext, TEntity extends ReadonlyEntity<TFields, TID, TViewerContext, TSelectedFields>, TPrivacyPolicy extends EntityPrivacyPolicy<TFields, TID, TViewerContext, TEntity, TSelectedFields>, TSelectedFields extends keyof TFields> {
|
|
17
17
|
private readonly viewerContext;
|
|
18
18
|
private readonly queryContext;
|
|
19
|
+
private readonly privacyPolicyEvaluationContext;
|
|
19
20
|
private readonly entityConfiguration;
|
|
20
21
|
private readonly entityClass;
|
|
21
22
|
private readonly privacyPolicy;
|
|
22
23
|
private readonly dataManager;
|
|
23
24
|
protected readonly metricsAdapter: IEntityMetricsAdapter;
|
|
24
|
-
constructor(viewerContext: TViewerContext, queryContext: EntityQueryContext, entityConfiguration: EntityConfiguration<TFields>, entityClass: IEntityClass<TFields, TID, TViewerContext, TEntity, TPrivacyPolicy, TSelectedFields>, privacyPolicy: TPrivacyPolicy, dataManager: EntityDataManager<TFields>, metricsAdapter: IEntityMetricsAdapter);
|
|
25
|
+
constructor(viewerContext: TViewerContext, queryContext: EntityQueryContext, privacyPolicyEvaluationContext: EntityPrivacyPolicyEvaluationContext, entityConfiguration: EntityConfiguration<TFields>, entityClass: IEntityClass<TFields, TID, TViewerContext, TEntity, TPrivacyPolicy, TSelectedFields>, privacyPolicy: TPrivacyPolicy, dataManager: EntityDataManager<TFields>, metricsAdapter: IEntityMetricsAdapter);
|
|
25
26
|
/**
|
|
26
27
|
* Enforcing view on this entity loader. All loads through this view are
|
|
27
28
|
* guaranteed to be the values of successful results (or null for some loader methods),
|
package/build/EntityLoader.js
CHANGED
|
@@ -15,9 +15,10 @@ const maps_1 = require("./utils/collections/maps");
|
|
|
15
15
|
* cached, and authorized against the entity's {@link EntityPrivacyPolicy}.
|
|
16
16
|
*/
|
|
17
17
|
class EntityLoader {
|
|
18
|
-
constructor(viewerContext, queryContext, entityConfiguration, entityClass, privacyPolicy, dataManager, metricsAdapter) {
|
|
18
|
+
constructor(viewerContext, queryContext, privacyPolicyEvaluationContext, entityConfiguration, entityClass, privacyPolicy, dataManager, metricsAdapter) {
|
|
19
19
|
this.viewerContext = viewerContext;
|
|
20
20
|
this.queryContext = queryContext;
|
|
21
|
+
this.privacyPolicyEvaluationContext = privacyPolicyEvaluationContext;
|
|
21
22
|
this.entityConfiguration = entityConfiguration;
|
|
22
23
|
this.entityClass = entityClass;
|
|
23
24
|
this.privacyPolicy = privacyPolicy;
|
|
@@ -130,7 +131,7 @@ class EntityLoader {
|
|
|
130
131
|
if (!uncheckedEntityResult.ok) {
|
|
131
132
|
return uncheckedEntityResult;
|
|
132
133
|
}
|
|
133
|
-
return await (0, results_1.asyncResult)(this.privacyPolicy.authorizeReadAsync(this.viewerContext, this.queryContext, uncheckedEntityResult.value, this.metricsAdapter));
|
|
134
|
+
return await (0, results_1.asyncResult)(this.privacyPolicy.authorizeReadAsync(this.viewerContext, this.queryContext, this.privacyPolicyEvaluationContext, uncheckedEntityResult.value, this.metricsAdapter));
|
|
134
135
|
}));
|
|
135
136
|
}
|
|
136
137
|
/**
|
|
@@ -165,7 +166,7 @@ class EntityLoader {
|
|
|
165
166
|
if (!uncheckedEntityResult.ok) {
|
|
166
167
|
return uncheckedEntityResult;
|
|
167
168
|
}
|
|
168
|
-
return await (0, results_1.asyncResult)(this.privacyPolicy.authorizeReadAsync(this.viewerContext, this.queryContext, uncheckedEntityResult.value, this.metricsAdapter));
|
|
169
|
+
return await (0, results_1.asyncResult)(this.privacyPolicy.authorizeReadAsync(this.viewerContext, this.queryContext, this.privacyPolicyEvaluationContext, uncheckedEntityResult.value, this.metricsAdapter));
|
|
169
170
|
}));
|
|
170
171
|
}
|
|
171
172
|
/**
|
|
@@ -209,7 +210,7 @@ class EntityLoader {
|
|
|
209
210
|
if (!uncheckedEntityResult.ok) {
|
|
210
211
|
return uncheckedEntityResult;
|
|
211
212
|
}
|
|
212
|
-
return await (0, results_1.asyncResult)(this.privacyPolicy.authorizeReadAsync(this.viewerContext, this.queryContext, uncheckedEntityResult.value, this.metricsAdapter));
|
|
213
|
+
return await (0, results_1.asyncResult)(this.privacyPolicy.authorizeReadAsync(this.viewerContext, this.queryContext, this.privacyPolicyEvaluationContext, uncheckedEntityResult.value, this.metricsAdapter));
|
|
213
214
|
}));
|
|
214
215
|
});
|
|
215
216
|
}
|