@x12i/memorix-descriptors 1.3.1 → 1.4.1
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/README.md +181 -20
- package/dist/admin/control-plane.d.ts +14 -0
- package/dist/admin/control-plane.d.ts.map +1 -0
- package/dist/admin/control-plane.js +22 -0
- package/dist/admin/control-plane.js.map +1 -0
- package/dist/admin/create-admin.d.ts +3 -2
- package/dist/admin/create-admin.d.ts.map +1 -1
- package/dist/admin/create-admin.js +2 -1
- package/dist/admin/create-admin.js.map +1 -1
- package/dist/admin/execute-mutation.d.ts +9 -0
- package/dist/admin/execute-mutation.d.ts.map +1 -0
- package/dist/admin/execute-mutation.js +85 -0
- package/dist/admin/execute-mutation.js.map +1 -0
- package/dist/index.d.ts +3 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -1
- package/dist/index.js.map +1 -1
- package/dist/reconcile/apply.d.ts +4 -0
- package/dist/reconcile/apply.d.ts.map +1 -0
- package/dist/reconcile/apply.js +123 -0
- package/dist/reconcile/apply.js.map +1 -0
- package/dist/reconcile/index.d.ts +10 -24
- package/dist/reconcile/index.d.ts.map +1 -1
- package/dist/reconcile/index.js +54 -63
- package/dist/reconcile/index.js.map +1 -1
- package/dist/reconcile/suggestions.d.ts +4 -0
- package/dist/reconcile/suggestions.d.ts.map +1 -0
- package/dist/reconcile/suggestions.js +90 -0
- package/dist/reconcile/suggestions.js.map +1 -0
- package/dist/reconcile/types.d.ts +45 -0
- package/dist/reconcile/types.d.ts.map +1 -0
- package/dist/reconcile/types.js +2 -0
- package/dist/reconcile/types.js.map +1 -0
- package/dist/tests/execute-mutation.test.d.ts +2 -0
- package/dist/tests/execute-mutation.test.d.ts.map +1 -0
- package/dist/tests/execute-mutation.test.js +57 -0
- package/dist/tests/execute-mutation.test.js.map +1 -0
- package/dist/tests/live/catalox.live.test.js +3 -2
- package/dist/tests/live/catalox.live.test.js.map +1 -1
- package/dist/tests/reconcile-unified.test.d.ts +2 -0
- package/dist/tests/reconcile-unified.test.d.ts.map +1 -0
- package/dist/tests/reconcile-unified.test.js +214 -0
- package/dist/tests/reconcile-unified.test.js.map +1 -0
- package/package.json +1 -1
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,4BAA4B,EAC5B,mCAAmC,EACnC,KAAK,mCAAmC,EACxC,KAAK,0CAA0C,EAC/C,KAAK,sBAAsB,GAC5B,MAAM,yBAAyB,CAAC;AAEjC,OAAO,EACL,cAAc,EACd,mCAAmC,EACnC,8BAA8B,EAC9B,kCAAkC,EAClC,kCAAkC,EAClC,gCAAgC,EAChC,gCAAgC,EAChC,gCAAgC,EAChC,0BAA0B,EAC1B,wBAAwB,EACxB,uBAAuB,EACvB,mBAAmB,GACpB,MAAM,kBAAkB,CAAC;AAE1B,YAAY,EACV,kBAAkB,EAClB,gBAAgB,EAChB,yBAAyB,EACzB,yBAAyB,EACzB,wBAAwB,EACxB,kBAAkB,EAClB,sBAAsB,EACtB,uBAAuB,EACvB,cAAc,EACd,wBAAwB,EACxB,cAAc,EACd,sBAAsB,EACtB,gBAAgB,EAChB,sBAAsB,EACtB,kBAAkB,EAClB,sBAAsB,EACtB,aAAa,EACb,WAAW,EACX,aAAa,EACb,wBAAwB,EACxB,6BAA6B,EAC7B,oBAAoB,EACpB,qBAAqB,GACtB,MAAM,kBAAkB,CAAC;AAE1B,OAAO,EACL,0BAA0B,EAC1B,0BAA0B,GAC3B,MAAM,yBAAyB,CAAC;AACjC,OAAO,EACL,oBAAoB,EACpB,wBAAwB,EACxB,KAAK,eAAe,EACpB,KAAK,mBAAmB,EACxB,KAAK,mBAAmB,GACzB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EACL,6BAA6B,EAC7B,uBAAuB,EACvB,uBAAuB,EACvB,WAAW,EACX,mBAAmB,EACnB,qBAAqB,EACrB,+BAA+B,EAC/B,mCAAmC,EACnC,6BAA6B,EAC7B,6BAA6B,EAC7B,0BAA0B,EAC1B,yBAAyB,GAC1B,MAAM,uCAAuC,CAAC;AAE/C,OAAO,EACL,2BAA2B,EAC3B,2BAA2B,EAC3B,0BAA0B,EAC1B,qCAAqC,EACrC,0BAA0B,EAC1B,KAAK,sBAAsB,GAC5B,MAAM,kBAAkB,CAAC;AAE1B,OAAO,EACL,6BAA6B,EAC7B,KAAK,0BAA0B,EAC/B,KAAK,mBAAmB,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
package/dist/index.js
CHANGED
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
export { createMemorixDescriptorAdmin, createMemorixDescriptorAdminFromEnv, } from "./admin/create-admin.js";
|
|
2
|
+
export { createMemorixControlPlaneFromEnv, } from "./admin/control-plane.js";
|
|
3
|
+
export { executeDescriptorMutation, } from "./admin/execute-mutation.js";
|
|
2
4
|
export { MEMORIX_APP_ID, MEMORIX_COMPLETION_MAPPINGS_CATALOG, MEMORIX_DESCRIPTOR_CATALOG_IDS, MEMORIX_ENTITY_DESCRIPTORS_CATALOG, MEMORIX_INVENTORY_POLICIES_CATALOG, MEMORIX_INVENTORY_POLICY_ITEM_ID, MEMORIX_ITEM_DESCRIPTORS_CATALOG, MEMORIX_LIST_DESCRIPTORS_CATALOG, MEMORIX_SYSTEM_CATALOG_IDS, allowedIdFieldsForTarget, defaultIdFieldForTarget, resolveMemorixAppId, } from "./catalog/ids.js";
|
|
3
5
|
export { validateMemorixDescriptors, validateDescriptorSnapshot, } from "./integrity/validate.js";
|
|
4
6
|
export { buildDescriptorGraph, descriptorGraphToMermaid, } from "./integrity/graph.js";
|
|
5
7
|
export { assertListFieldsHumanReadable, defaultItemDescriptorId, defaultListDescriptorId, isKebabCase, parseDescriptorData, singularizeEntityName, validateMemorixEntityDescriptor, validateMemorixEntityListDescriptor, validateMemorixItemDescriptor, validateMemorixListDescriptor, validatePropertyDescriptor, DescriptorValidationError, } from "./validation/descriptor-validation.js";
|
|
6
8
|
export { applyDescriptorSeedManifest, buildDescriptorSeedManifest, exportDescriptorSeedInputs, exportDescriptorSeedInputsFromCatalox, importDescriptorSeedInputs, } from "./seeds/index.js";
|
|
7
|
-
export { reconcileDescriptorsWithMongo, } from "./reconcile/index.js";
|
|
9
|
+
export { reconcileDescriptorsWithMongo, applyReconcileDraft, buildReconcileDraftForSuggestion, buildReconcileSuggestionsFromUnifiedInventory, } from "./reconcile/index.js";
|
|
8
10
|
export { buildAddContentTypeDraftFromCollection, buildDescriptorDraftFromOrphanCollection, buildFixCollectionBindingDraft, buildIgnoreCollectionDraft, } from "./reconcile/drafts.js";
|
|
9
11
|
export { parseMemorixCollectionName, } from "./collections/parse.js";
|
|
10
12
|
export { validateMemorixSliceDescriptorShape, validateSliceDescriptorAgainstSnapshot, buildSlicePreview, isMemorixSliceDescriptor, } from "./validation/slice-validation.js";
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,4BAA4B,EAC5B,mCAAmC,GAIpC,MAAM,yBAAyB,CAAC;AAEjC,OAAO,EACL,cAAc,EACd,mCAAmC,EACnC,8BAA8B,EAC9B,kCAAkC,EAClC,kCAAkC,EAClC,gCAAgC,EAChC,gCAAgC,EAChC,gCAAgC,EAChC,0BAA0B,EAC1B,wBAAwB,EACxB,uBAAuB,EACvB,mBAAmB,GACpB,MAAM,kBAAkB,CAAC;AA4B1B,OAAO,EACL,0BAA0B,EAC1B,0BAA0B,GAC3B,MAAM,yBAAyB,CAAC;AACjC,OAAO,EACL,oBAAoB,EACpB,wBAAwB,GAIzB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EACL,6BAA6B,EAC7B,uBAAuB,EACvB,uBAAuB,EACvB,WAAW,EACX,mBAAmB,EACnB,qBAAqB,EACrB,+BAA+B,EAC/B,mCAAmC,EACnC,6BAA6B,EAC7B,6BAA6B,EAC7B,0BAA0B,EAC1B,yBAAyB,GAC1B,MAAM,uCAAuC,CAAC;AAE/C,OAAO,EACL,2BAA2B,EAC3B,2BAA2B,EAC3B,0BAA0B,EAC1B,qCAAqC,EACrC,0BAA0B,GAE3B,MAAM,kBAAkB,CAAC;AAE1B,OAAO,EACL,6BAA6B,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,4BAA4B,EAC5B,mCAAmC,GAIpC,MAAM,yBAAyB,CAAC;AAEjC,OAAO,EACL,gCAAgC,GAGjC,MAAM,0BAA0B,CAAC;AAElC,OAAO,EACL,yBAAyB,GAE1B,MAAM,6BAA6B,CAAC;AAErC,OAAO,EACL,cAAc,EACd,mCAAmC,EACnC,8BAA8B,EAC9B,kCAAkC,EAClC,kCAAkC,EAClC,gCAAgC,EAChC,gCAAgC,EAChC,gCAAgC,EAChC,0BAA0B,EAC1B,wBAAwB,EACxB,uBAAuB,EACvB,mBAAmB,GACpB,MAAM,kBAAkB,CAAC;AA4B1B,OAAO,EACL,0BAA0B,EAC1B,0BAA0B,GAC3B,MAAM,yBAAyB,CAAC;AACjC,OAAO,EACL,oBAAoB,EACpB,wBAAwB,GAIzB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EACL,6BAA6B,EAC7B,uBAAuB,EACvB,uBAAuB,EACvB,WAAW,EACX,mBAAmB,EACnB,qBAAqB,EACrB,+BAA+B,EAC/B,mCAAmC,EACnC,6BAA6B,EAC7B,6BAA6B,EAC7B,0BAA0B,EAC1B,yBAAyB,GAC1B,MAAM,uCAAuC,CAAC;AAE/C,OAAO,EACL,2BAA2B,EAC3B,2BAA2B,EAC3B,0BAA0B,EAC1B,qCAAqC,EACrC,0BAA0B,GAE3B,MAAM,kBAAkB,CAAC;AAE1B,OAAO,EACL,6BAA6B,EAC7B,mBAAmB,EACnB,gCAAgC,EAChC,6CAA6C,GAK9C,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EACL,sCAAsC,EACtC,wCAAwC,EACxC,8BAA8B,EAC9B,0BAA0B,GAK3B,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EACL,0BAA0B,GAE3B,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EACL,mCAAmC,EACnC,sCAAsC,EACtC,iBAAiB,EACjB,wBAAwB,GACzB,MAAM,kCAAkC,CAAC;AAE1C,OAAO,EACL,wBAAwB,EACxB,8BAA8B,EAC9B,8BAA8B,EAC9B,oBAAoB,EACpB,mBAAmB,GACpB,MAAM,6CAA6C,CAAC;AAErD,OAAO,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;AAE7D,OAAO,EAAE,+BAA+B,EAAE,MAAM,8BAA8B,CAAC;AAC/E,OAAO,EAAE,sBAAsB,EAAsC,MAAM,8BAA8B,CAAC;AAC1G,OAAO,EAAE,0BAA0B,EAAE,MAAM,gBAAgB,CAAC;AAC5D,OAAO,EAAE,oBAAoB,EAAE,gCAAgC,EAAE,MAAM,sBAAsB,CAAC;AAC9F,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,8BAA8B,EAAE,MAAM,+BAA+B,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { DescriptorMutationOptions, DescriptorMutationResult, ReconcileDescriptorDraft } from "../types/index.js";
|
|
2
|
+
import type { EntityMutationContext } from "../mutations/entity.js";
|
|
3
|
+
export declare function applyReconcileDraft(ctx: EntityMutationContext, draft: ReconcileDescriptorDraft, options?: DescriptorMutationOptions): Promise<DescriptorMutationResult>;
|
|
4
|
+
//# sourceMappingURL=apply.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apply.d.ts","sourceRoot":"","sources":["../../src/reconcile/apply.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAoB,yBAAyB,EAAE,wBAAwB,EAAyC,wBAAwB,EAAiC,MAAM,mBAAmB,CAAC;AAE/M,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAkDpE,wBAAsB,mBAAmB,CACvC,GAAG,EAAE,qBAAqB,EAC1B,KAAK,EAAE,wBAAwB,EAC/B,OAAO,GAAE,yBAA8B,GACtC,OAAO,CAAC,wBAAwB,CAAC,CA+GnC"}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { addContentType, updateContentType } from "../mutations/content-type.js";
|
|
2
|
+
import { registerEntityDescriptor } from "../mutations/entity.js";
|
|
3
|
+
import { ignoreCollection } from "../mutations/inventory-policy.js";
|
|
4
|
+
import { mutationFailure } from "../mutations/common.js";
|
|
5
|
+
function asRecord(value) {
|
|
6
|
+
if (!value || typeof value !== "object" || Array.isArray(value)) {
|
|
7
|
+
return {};
|
|
8
|
+
}
|
|
9
|
+
return value;
|
|
10
|
+
}
|
|
11
|
+
function registerInputFromDraft(draft) {
|
|
12
|
+
const entityName = String(draft.entityName ?? "").trim();
|
|
13
|
+
const target = draft.target;
|
|
14
|
+
if (!entityName || !target)
|
|
15
|
+
return null;
|
|
16
|
+
const collectionPrefix = String(draft.collectionPrefix ?? entityName).trim();
|
|
17
|
+
const contentTypes = asRecord(draft.contentTypes);
|
|
18
|
+
const canonicalRaw = draft.canonicalContentType;
|
|
19
|
+
const canonicalKey = typeof canonicalRaw === "string"
|
|
20
|
+
? canonicalRaw
|
|
21
|
+
: String(asRecord(canonicalRaw).key ?? "").trim();
|
|
22
|
+
if (!canonicalKey)
|
|
23
|
+
return null;
|
|
24
|
+
const canonicalDef = asRecord(contentTypes[canonicalKey]);
|
|
25
|
+
const postfix = String(canonicalDef.postfix ?? canonicalKey).trim();
|
|
26
|
+
const collection = typeof canonicalDef.collection === "string"
|
|
27
|
+
? canonicalDef.collection
|
|
28
|
+
: `${collectionPrefix}-${postfix}`;
|
|
29
|
+
return {
|
|
30
|
+
entityName,
|
|
31
|
+
target,
|
|
32
|
+
collectionPrefix,
|
|
33
|
+
canonicalContentType: {
|
|
34
|
+
key: canonicalKey,
|
|
35
|
+
postfix,
|
|
36
|
+
collection,
|
|
37
|
+
dataRoot: typeof canonicalDef.dataRoot === "string" ? canonicalDef.dataRoot : undefined,
|
|
38
|
+
},
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
export async function applyReconcileDraft(ctx, draft, options = {}) {
|
|
42
|
+
if (draft.suggestedAction === "manualReview") {
|
|
43
|
+
return mutationFailure([
|
|
44
|
+
{
|
|
45
|
+
code: "MANUAL_REVIEW_REQUIRED",
|
|
46
|
+
message: draft.warnings.join("; ") ||
|
|
47
|
+
"Reconcile draft requires manual review before apply",
|
|
48
|
+
},
|
|
49
|
+
], options);
|
|
50
|
+
}
|
|
51
|
+
const payload = draft.draft;
|
|
52
|
+
switch (draft.suggestedAction) {
|
|
53
|
+
case "registerEntityDescriptor": {
|
|
54
|
+
const input = registerInputFromDraft(payload);
|
|
55
|
+
if (!input) {
|
|
56
|
+
return mutationFailure([
|
|
57
|
+
{
|
|
58
|
+
code: "INVALID_DRAFT",
|
|
59
|
+
message: "registerEntityDescriptor draft is missing entityName, target, or canonicalContentType",
|
|
60
|
+
},
|
|
61
|
+
], options);
|
|
62
|
+
}
|
|
63
|
+
return registerEntityDescriptor(ctx, input, options);
|
|
64
|
+
}
|
|
65
|
+
case "addContentType": {
|
|
66
|
+
const entityName = String(payload.entityName ?? "").trim();
|
|
67
|
+
const contentType = payload.contentType;
|
|
68
|
+
if (!entityName || !contentType?.key) {
|
|
69
|
+
return mutationFailure([
|
|
70
|
+
{
|
|
71
|
+
code: "INVALID_DRAFT",
|
|
72
|
+
message: "addContentType draft requires entityName and contentType.key",
|
|
73
|
+
},
|
|
74
|
+
], options);
|
|
75
|
+
}
|
|
76
|
+
return addContentType(ctx, entityName, contentType, options);
|
|
77
|
+
}
|
|
78
|
+
case "updateContentType": {
|
|
79
|
+
const entityName = String(payload.entityName ?? "").trim();
|
|
80
|
+
const contentTypeKey = String(payload.contentTypeKey ?? "").trim();
|
|
81
|
+
const patch = asRecord(payload.patch);
|
|
82
|
+
if (!entityName || !contentTypeKey) {
|
|
83
|
+
return mutationFailure([
|
|
84
|
+
{
|
|
85
|
+
code: "INVALID_DRAFT",
|
|
86
|
+
message: "updateContentType draft requires entityName and contentTypeKey",
|
|
87
|
+
},
|
|
88
|
+
], options);
|
|
89
|
+
}
|
|
90
|
+
return updateContentType(ctx, entityName, contentTypeKey, patch, options);
|
|
91
|
+
}
|
|
92
|
+
case "ignoreCollection": {
|
|
93
|
+
const target = payload.target;
|
|
94
|
+
const collectionName = String(payload.collectionName ?? "").trim();
|
|
95
|
+
const reason = payload.reason;
|
|
96
|
+
if (!target || !collectionName || !reason) {
|
|
97
|
+
return mutationFailure([
|
|
98
|
+
{
|
|
99
|
+
code: "INVALID_DRAFT",
|
|
100
|
+
message: "ignoreCollection draft requires target, collectionName, and reason",
|
|
101
|
+
},
|
|
102
|
+
], options);
|
|
103
|
+
}
|
|
104
|
+
return ignoreCollection(ctx, {
|
|
105
|
+
target,
|
|
106
|
+
collectionName,
|
|
107
|
+
reason,
|
|
108
|
+
databaseName: typeof payload.databaseName === "string"
|
|
109
|
+
? payload.databaseName
|
|
110
|
+
: undefined,
|
|
111
|
+
note: typeof payload.note === "string" ? payload.note : undefined,
|
|
112
|
+
}, options);
|
|
113
|
+
}
|
|
114
|
+
default:
|
|
115
|
+
return mutationFailure([
|
|
116
|
+
{
|
|
117
|
+
code: "UNSUPPORTED_DRAFT_ACTION",
|
|
118
|
+
message: `Unsupported reconcile draft action "${draft.suggestedAction}"`,
|
|
119
|
+
},
|
|
120
|
+
], options);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
//# sourceMappingURL=apply.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apply.js","sourceRoot":"","sources":["../../src/reconcile/apply.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,28 +1,8 @@
|
|
|
1
|
-
import { type
|
|
1
|
+
import { type BuildMemorixUnifiedInventoryOptions, type MemorixInventoryIssue, type MemorixRetrievalClient, type MemorixUnifiedInventory } from "@x12i/memorix-retrieval";
|
|
2
2
|
import type { CataloxBoundClient } from "../catalox/client.js";
|
|
3
3
|
import type { EntityMutationContext } from "../mutations/entity.js";
|
|
4
|
-
import type {
|
|
5
|
-
export type ReconcileSuggestion
|
|
6
|
-
kind: "create-descriptor-for-orphan";
|
|
7
|
-
collection: string;
|
|
8
|
-
target: MemorixTarget;
|
|
9
|
-
} | {
|
|
10
|
-
kind: "ensure-collection";
|
|
11
|
-
entityName: string;
|
|
12
|
-
contentType: string;
|
|
13
|
-
} | {
|
|
14
|
-
kind: "empty-declared-collection";
|
|
15
|
-
entityName: string;
|
|
16
|
-
contentType: string;
|
|
17
|
-
};
|
|
18
|
-
export type ReconcileDescriptorsResult = {
|
|
19
|
-
inventory: MemorixCollectionInventoryResult;
|
|
20
|
-
suggestions: ReconcileSuggestion[];
|
|
21
|
-
applied: Array<{
|
|
22
|
-
kind: string;
|
|
23
|
-
detail: string;
|
|
24
|
-
}>;
|
|
25
|
-
};
|
|
4
|
+
import type { ReconcileDescriptorsResult, ReconcileSuggestion } from "./types.js";
|
|
5
|
+
export type { ReconcileDescriptorsResult, ReconcileSuggestion } from "./types.js";
|
|
26
6
|
export type ReconcileDescriptorsOptions = {
|
|
27
7
|
catalox: CataloxBoundClient;
|
|
28
8
|
appId: string;
|
|
@@ -31,7 +11,13 @@ export type ReconcileDescriptorsOptions = {
|
|
|
31
11
|
allowCreateCollection?: boolean;
|
|
32
12
|
skipMongo?: boolean;
|
|
33
13
|
xronox?: EntityMutationContext["xronox"];
|
|
14
|
+
inventory?: MemorixUnifiedInventory;
|
|
15
|
+
useUnifiedInventory?: boolean;
|
|
16
|
+
inventoryOptions?: BuildMemorixUnifiedInventoryOptions;
|
|
34
17
|
};
|
|
35
18
|
export declare function reconcileDescriptorsWithMongo(options: ReconcileDescriptorsOptions): Promise<ReconcileDescriptorsResult>;
|
|
36
|
-
export
|
|
19
|
+
export declare function buildReconcileDraftForSuggestion(suggestion: ReconcileSuggestion, snapshot?: Awaited<ReturnType<EntityMutationContext["loadSnapshot"]>>, env?: NodeJS.ProcessEnv): import("../types/index.js").ReconcileDescriptorDraft | null;
|
|
20
|
+
export { applyReconcileDraft } from "./apply.js";
|
|
21
|
+
export { buildReconcileSuggestionsFromUnifiedInventory } from "./suggestions.js";
|
|
22
|
+
export type { MemorixRetrievalClient, MemorixUnifiedInventory, MemorixInventoryIssue };
|
|
37
23
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/reconcile/index.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/reconcile/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAIL,KAAK,mCAAmC,EACxC,KAAK,qBAAqB,EAC1B,KAAK,sBAAsB,EAC3B,KAAK,uBAAuB,EAC7B,MAAM,yBAAyB,CAAC;AACjC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAG/D,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAYpE,OAAO,KAAK,EAAE,0BAA0B,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAElF,YAAY,EAAE,0BAA0B,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAElF,MAAM,MAAM,2BAA2B,GAAG;IACxC,OAAO,EAAE,kBAAkB,CAAC;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,CAAC,EAAE,MAAM,CAAC,UAAU,CAAC;IAC/B,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,MAAM,CAAC,EAAE,qBAAqB,CAAC,QAAQ,CAAC,CAAC;IACzC,SAAS,CAAC,EAAE,uBAAuB,CAAC;IACpC,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,gBAAgB,CAAC,EAAE,mCAAmC,CAAC;CACxD,CAAC;AAEF,wBAAsB,6BAA6B,CACjD,OAAO,EAAE,2BAA2B,GACnC,OAAO,CAAC,0BAA0B,CAAC,CAyFrC;AAED,wBAAgB,gCAAgC,CAC9C,UAAU,EAAE,mBAAmB,EAC/B,QAAQ,CAAC,EAAE,OAAO,CAAC,UAAU,CAAC,qBAAqB,CAAC,cAAc,CAAC,CAAC,CAAC,EACrE,GAAG,GAAE,MAAM,CAAC,UAAwB,+DAoCrC;AAED,OAAO,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AACjD,OAAO,EAAE,6CAA6C,EAAE,MAAM,kBAAkB,CAAC;AACjF,YAAY,EAAE,sBAAsB,EAAE,uBAAuB,EAAE,qBAAqB,EAAE,CAAC"}
|
package/dist/reconcile/index.js
CHANGED
|
@@ -1,32 +1,39 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { buildMemorixUnifiedInventory, createCataloxAdapterFromBound, createMemorixRetrieval, } from "@x12i/memorix-retrieval";
|
|
2
2
|
import { createMongoCollectionIfMissing } from "../collections/mongo-create.js";
|
|
3
|
-
import { resolveDatabaseForTarget } from "../collections/resolve.js";
|
|
4
|
-
import { registerEntityDescriptor } from "../mutations/entity.js";
|
|
3
|
+
import { resolveCollectionForEntity, resolveDatabaseForTarget } from "../collections/resolve.js";
|
|
5
4
|
import { loadDescriptorSnapshot } from "../store/snapshot.js";
|
|
6
5
|
import { validateMemorixEntityDescriptor } from "../validation/descriptor-validation.js";
|
|
7
|
-
import {
|
|
6
|
+
import { applyReconcileDraft } from "./apply.js";
|
|
7
|
+
import { buildAddContentTypeDraftFromCollection, buildDescriptorDraftFromOrphanCollection, buildFixCollectionBindingDraft, buildIgnoreCollectionDraft, } from "./drafts.js";
|
|
8
|
+
import { buildReconcileSuggestionsFromUnifiedInventory } from "./suggestions.js";
|
|
8
9
|
export async function reconcileDescriptorsWithMongo(options) {
|
|
9
10
|
const env = options.processEnv ?? process.env;
|
|
11
|
+
const useUnifiedInventory = options.useUnifiedInventory ?? true;
|
|
12
|
+
if (!useUnifiedInventory && !options.inventory) {
|
|
13
|
+
throw new Error("reconcileDescriptorsWithMongo requires inventory when useUnifiedInventory is false");
|
|
14
|
+
}
|
|
10
15
|
const cataloxAdapter = createCataloxAdapterFromBound(options.catalox);
|
|
11
16
|
const client = createMemorixRetrieval({
|
|
12
17
|
appId: options.appId,
|
|
13
18
|
catalox: cataloxAdapter,
|
|
14
19
|
processEnv: env,
|
|
20
|
+
xronox: options.xronox,
|
|
15
21
|
});
|
|
16
|
-
const
|
|
17
|
-
|
|
18
|
-
const
|
|
22
|
+
const inventory = options.inventory ??
|
|
23
|
+
(await buildMemorixUnifiedInventory(client, options.inventoryOptions ?? {}));
|
|
24
|
+
const issues = inventory.issues;
|
|
25
|
+
const suggestions = buildReconcileSuggestionsFromUnifiedInventory(inventory);
|
|
19
26
|
const applied = [];
|
|
20
27
|
if (options.skipMongo) {
|
|
21
|
-
return { inventory, suggestions, applied };
|
|
28
|
+
return { inventory, issues, suggestions, applied };
|
|
22
29
|
}
|
|
30
|
+
const snapshot = await loadDescriptorSnapshot(options.catalox);
|
|
23
31
|
const ctx = {
|
|
24
32
|
catalox: options.catalox,
|
|
25
33
|
xronox: options.xronox,
|
|
26
34
|
env,
|
|
27
35
|
loadSnapshot: async () => loadDescriptorSnapshot(options.catalox),
|
|
28
36
|
};
|
|
29
|
-
const prefixes = Object.values(snapshot.entityDescriptors).map((raw) => String(raw.collectionPrefix ?? raw.id));
|
|
30
37
|
for (const suggestion of suggestions) {
|
|
31
38
|
if (suggestion.kind === "ensure-collection" && options.allowCreateCollection) {
|
|
32
39
|
const entityRaw = snapshot.entityDescriptors[suggestion.entityName];
|
|
@@ -51,22 +58,15 @@ export async function reconcileDescriptorsWithMongo(options) {
|
|
|
51
58
|
continue;
|
|
52
59
|
}
|
|
53
60
|
if (suggestion.kind === "create-descriptor-for-orphan" && options.autoRegisterOrphans) {
|
|
54
|
-
const
|
|
55
|
-
const entityName = parsed.entityName;
|
|
56
|
-
if (!entityName || snapshot.entityDescriptors[entityName]) {
|
|
57
|
-
continue;
|
|
58
|
-
}
|
|
59
|
-
const postfix = parsed.contentType ?? "snapshots";
|
|
60
|
-
const result = await registerEntityDescriptor(ctx, {
|
|
61
|
-
entityName,
|
|
61
|
+
const draft = buildDescriptorDraftFromOrphanCollection({
|
|
62
62
|
target: suggestion.target,
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
63
|
+
collectionName: suggestion.collection,
|
|
64
|
+
});
|
|
65
|
+
if (draft.suggestedAction !== "registerEntityDescriptor")
|
|
66
|
+
continue;
|
|
67
|
+
if (snapshot.entityDescriptors[String(draft.draft.entityName)])
|
|
68
|
+
continue;
|
|
69
|
+
const result = await applyReconcileDraft(ctx, draft, {
|
|
70
70
|
dryRun: false,
|
|
71
71
|
skipMongo: true,
|
|
72
72
|
allowCreateCollection: false,
|
|
@@ -74,50 +74,41 @@ export async function reconcileDescriptorsWithMongo(options) {
|
|
|
74
74
|
});
|
|
75
75
|
applied.push({
|
|
76
76
|
kind: "create-descriptor-for-orphan",
|
|
77
|
-
detail: `${suggestion.collection} → ${entityName} (${result.ok ? "ok" : "failed"})`,
|
|
77
|
+
detail: `${suggestion.collection} → ${String(draft.draft.entityName)} (${result.ok ? "ok" : "failed"})`,
|
|
78
78
|
});
|
|
79
79
|
}
|
|
80
80
|
}
|
|
81
|
-
return { inventory, suggestions, applied };
|
|
81
|
+
return { inventory, issues, suggestions, applied };
|
|
82
82
|
}
|
|
83
|
-
function
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
for (const [contentTypeKey] of Object.entries(entity.contentTypes)) {
|
|
90
|
-
const collection = resolveCollectionForEntity(entity, contentTypeKey, env);
|
|
91
|
-
declared.add(`${target}:${collection}`);
|
|
92
|
-
const match = inventory.entries.find((entry) => entry.collection === collection && entry.target === target);
|
|
93
|
-
if (!match) {
|
|
94
|
-
suggestions.push({
|
|
95
|
-
kind: "ensure-collection",
|
|
96
|
-
entityName,
|
|
97
|
-
contentType: contentTypeKey,
|
|
98
|
-
});
|
|
99
|
-
}
|
|
100
|
-
else if (match.documentCount === 0) {
|
|
101
|
-
suggestions.push({
|
|
102
|
-
kind: "empty-declared-collection",
|
|
103
|
-
entityName,
|
|
104
|
-
contentType: contentTypeKey,
|
|
105
|
-
});
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
for (const entry of inventory.entries) {
|
|
110
|
-
if (entry.matchStatus !== "orphan")
|
|
111
|
-
continue;
|
|
112
|
-
const key = `${entry.target}:${entry.collection}`;
|
|
113
|
-
if (!declared.has(key)) {
|
|
114
|
-
suggestions.push({
|
|
115
|
-
kind: "create-descriptor-for-orphan",
|
|
116
|
-
collection: entry.collection,
|
|
117
|
-
target: entry.target,
|
|
83
|
+
export function buildReconcileDraftForSuggestion(suggestion, snapshot, env = process.env) {
|
|
84
|
+
switch (suggestion.kind) {
|
|
85
|
+
case "create-descriptor-for-orphan":
|
|
86
|
+
return buildDescriptorDraftFromOrphanCollection({
|
|
87
|
+
target: suggestion.target,
|
|
88
|
+
collectionName: suggestion.collection,
|
|
118
89
|
});
|
|
119
|
-
|
|
90
|
+
case "add-content-type-for-orphan":
|
|
91
|
+
return buildAddContentTypeDraftFromCollection({
|
|
92
|
+
entityName: suggestion.parsedObject ?? "",
|
|
93
|
+
collectionName: suggestion.collection,
|
|
94
|
+
target: suggestion.target,
|
|
95
|
+
}, snapshot);
|
|
96
|
+
case "fix-collection-binding":
|
|
97
|
+
return buildFixCollectionBindingDraft({
|
|
98
|
+
entityName: suggestion.entityName,
|
|
99
|
+
contentTypeKey: suggestion.contentType,
|
|
100
|
+
collectionName: suggestion.actualCollection,
|
|
101
|
+
}, snapshot, env);
|
|
102
|
+
case "ignore-collection":
|
|
103
|
+
return buildIgnoreCollectionDraft({
|
|
104
|
+
target: suggestion.target,
|
|
105
|
+
collectionName: suggestion.collectionName,
|
|
106
|
+
reason: "not-memorix",
|
|
107
|
+
});
|
|
108
|
+
default:
|
|
109
|
+
return null;
|
|
120
110
|
}
|
|
121
|
-
return suggestions;
|
|
122
111
|
}
|
|
112
|
+
export { applyReconcileDraft } from "./apply.js";
|
|
113
|
+
export { buildReconcileSuggestionsFromUnifiedInventory } from "./suggestions.js";
|
|
123
114
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/reconcile/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/reconcile/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { MemorixUnifiedInventory } from "@x12i/memorix-retrieval";
|
|
2
|
+
import type { ReconcileSuggestion } from "./types.js";
|
|
3
|
+
export declare function buildReconcileSuggestionsFromUnifiedInventory(inventory: MemorixUnifiedInventory): ReconcileSuggestion[];
|
|
4
|
+
//# sourceMappingURL=suggestions.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"suggestions.d.ts","sourceRoot":"","sources":["../../src/reconcile/suggestions.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAyB,uBAAuB,EAAE,MAAM,yBAAyB,CAAC;AAC9F,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAStD,wBAAgB,6CAA6C,CAC3D,SAAS,EAAE,uBAAuB,GACjC,mBAAmB,EAAE,CA8FvB"}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
function rowForIssue(inventory, issue) {
|
|
2
|
+
return inventory.rows.find((row) => row.issueIds?.includes(issue.issueId));
|
|
3
|
+
}
|
|
4
|
+
export function buildReconcileSuggestionsFromUnifiedInventory(inventory) {
|
|
5
|
+
const suggestions = [];
|
|
6
|
+
const seen = new Set();
|
|
7
|
+
const push = (suggestion) => {
|
|
8
|
+
const key = JSON.stringify(suggestion);
|
|
9
|
+
if (seen.has(key))
|
|
10
|
+
return;
|
|
11
|
+
seen.add(key);
|
|
12
|
+
suggestions.push(suggestion);
|
|
13
|
+
};
|
|
14
|
+
for (const issue of inventory.issues) {
|
|
15
|
+
switch (issue.kind) {
|
|
16
|
+
case "missing-collection":
|
|
17
|
+
if (issue.objectName && issue.contentType) {
|
|
18
|
+
push({
|
|
19
|
+
kind: "ensure-collection",
|
|
20
|
+
entityName: issue.objectName,
|
|
21
|
+
contentType: issue.contentType,
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
break;
|
|
25
|
+
case "empty-declared-collection":
|
|
26
|
+
if (issue.objectName && issue.contentType) {
|
|
27
|
+
push({
|
|
28
|
+
kind: "empty-declared-collection",
|
|
29
|
+
entityName: issue.objectName,
|
|
30
|
+
contentType: issue.contentType,
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
break;
|
|
34
|
+
case "orphan-collection":
|
|
35
|
+
case "object-missing":
|
|
36
|
+
if (issue.collectionName && issue.target) {
|
|
37
|
+
push({
|
|
38
|
+
kind: "create-descriptor-for-orphan",
|
|
39
|
+
collection: issue.collectionName,
|
|
40
|
+
target: issue.target,
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
break;
|
|
44
|
+
case "content-type-missing":
|
|
45
|
+
if (issue.collectionName && issue.target) {
|
|
46
|
+
push({
|
|
47
|
+
kind: "add-content-type-for-orphan",
|
|
48
|
+
target: issue.target,
|
|
49
|
+
collection: issue.collectionName,
|
|
50
|
+
parsedObject: issue.objectName,
|
|
51
|
+
parsedContentType: issue.contentType,
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
break;
|
|
55
|
+
case "collection-mismatch": {
|
|
56
|
+
const row = rowForIssue(inventory, issue);
|
|
57
|
+
if (issue.objectName && issue.contentType && issue.collectionName) {
|
|
58
|
+
push({
|
|
59
|
+
kind: "fix-collection-binding",
|
|
60
|
+
entityName: issue.objectName,
|
|
61
|
+
contentType: issue.contentType,
|
|
62
|
+
expectedCollection: row?.expectedCollectionName ?? issue.collectionName,
|
|
63
|
+
actualCollection: issue.collectionName,
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
break;
|
|
67
|
+
}
|
|
68
|
+
case "unparseable-collection":
|
|
69
|
+
if (issue.collectionName && issue.target) {
|
|
70
|
+
push({
|
|
71
|
+
kind: "unparseable-collection",
|
|
72
|
+
target: issue.target,
|
|
73
|
+
collectionName: issue.collectionName,
|
|
74
|
+
});
|
|
75
|
+
if (issue.suggestedActions.includes("ignore")) {
|
|
76
|
+
push({
|
|
77
|
+
kind: "ignore-collection",
|
|
78
|
+
target: issue.target,
|
|
79
|
+
collectionName: issue.collectionName,
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
break;
|
|
84
|
+
default:
|
|
85
|
+
break;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
return suggestions;
|
|
89
|
+
}
|
|
90
|
+
//# sourceMappingURL=suggestions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"suggestions.js","sourceRoot":"","sources":["../../src/reconcile/suggestions.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import type { MemorixInventoryIssue, MemorixUnifiedInventory } from "@x12i/memorix-retrieval";
|
|
2
|
+
import type { MemorixTarget } from "../types/index.js";
|
|
3
|
+
export type ReconcileSuggestion = {
|
|
4
|
+
kind: "create-descriptor-for-orphan";
|
|
5
|
+
collection: string;
|
|
6
|
+
target: MemorixTarget;
|
|
7
|
+
} | {
|
|
8
|
+
kind: "ensure-collection";
|
|
9
|
+
entityName: string;
|
|
10
|
+
contentType: string;
|
|
11
|
+
} | {
|
|
12
|
+
kind: "empty-declared-collection";
|
|
13
|
+
entityName: string;
|
|
14
|
+
contentType: string;
|
|
15
|
+
} | {
|
|
16
|
+
kind: "add-content-type-for-orphan";
|
|
17
|
+
target: MemorixTarget;
|
|
18
|
+
collection: string;
|
|
19
|
+
parsedObject?: string;
|
|
20
|
+
parsedContentType?: string;
|
|
21
|
+
} | {
|
|
22
|
+
kind: "fix-collection-binding";
|
|
23
|
+
entityName: string;
|
|
24
|
+
contentType: string;
|
|
25
|
+
expectedCollection: string;
|
|
26
|
+
actualCollection: string;
|
|
27
|
+
} | {
|
|
28
|
+
kind: "ignore-collection";
|
|
29
|
+
target: MemorixTarget;
|
|
30
|
+
collectionName: string;
|
|
31
|
+
} | {
|
|
32
|
+
kind: "unparseable-collection";
|
|
33
|
+
target: MemorixTarget;
|
|
34
|
+
collectionName: string;
|
|
35
|
+
};
|
|
36
|
+
export type ReconcileDescriptorsResult = {
|
|
37
|
+
inventory: MemorixUnifiedInventory;
|
|
38
|
+
issues: MemorixInventoryIssue[];
|
|
39
|
+
suggestions: ReconcileSuggestion[];
|
|
40
|
+
applied: Array<{
|
|
41
|
+
kind: string;
|
|
42
|
+
detail: string;
|
|
43
|
+
}>;
|
|
44
|
+
};
|
|
45
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/reconcile/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,qBAAqB,EACrB,uBAAuB,EACxB,MAAM,yBAAyB,CAAC;AACjC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAEvD,MAAM,MAAM,mBAAmB,GAC3B;IAAE,IAAI,EAAE,8BAA8B,CAAC;IAAC,UAAU,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,aAAa,CAAA;CAAE,GACnF;IAAE,IAAI,EAAE,mBAAmB,CAAC;IAAC,UAAU,EAAE,MAAM,CAAC;IAAC,WAAW,EAAE,MAAM,CAAA;CAAE,GACtE;IAAE,IAAI,EAAE,2BAA2B,CAAC;IAAC,UAAU,EAAE,MAAM,CAAC;IAAC,WAAW,EAAE,MAAM,CAAA;CAAE,GAC9E;IACE,IAAI,EAAE,6BAA6B,CAAC;IACpC,MAAM,EAAE,aAAa,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B,GACD;IACE,IAAI,EAAE,wBAAwB,CAAC;IAC/B,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;IACpB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,gBAAgB,EAAE,MAAM,CAAC;CAC1B,GACD;IAAE,IAAI,EAAE,mBAAmB,CAAC;IAAC,MAAM,EAAE,aAAa,CAAC;IAAC,cAAc,EAAE,MAAM,CAAA;CAAE,GAC5E;IAAE,IAAI,EAAE,wBAAwB,CAAC;IAAC,MAAM,EAAE,aAAa,CAAC;IAAC,cAAc,EAAE,MAAM,CAAA;CAAE,CAAC;AAEtF,MAAM,MAAM,0BAA0B,GAAG;IACvC,SAAS,EAAE,uBAAuB,CAAC;IACnC,MAAM,EAAE,qBAAqB,EAAE,CAAC;IAChC,WAAW,EAAE,mBAAmB,EAAE,CAAC;IACnC,OAAO,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CAClD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/reconcile/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"execute-mutation.test.d.ts","sourceRoot":"","sources":["../../src/tests/execute-mutation.test.ts"],"names":[],"mappings":""}
|