@x12i/catalox 3.5.1 → 3.7.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/README.md +155 -10
- package/dist/src/adapters/api/api-adapter.d.ts.map +1 -1
- package/dist/src/adapters/api/api-adapter.js +1 -0
- package/dist/src/adapters/api/api-adapter.js.map +1 -1
- package/dist/src/adapters/mongo/mongo-adapter.d.ts.map +1 -1
- package/dist/src/adapters/mongo/mongo-adapter.js +1 -0
- package/dist/src/adapters/mongo/mongo-adapter.js.map +1 -1
- package/dist/src/catalox/catalog-discovery.d.ts.map +1 -1
- package/dist/src/catalox/catalog-discovery.js +8 -6
- package/dist/src/catalox/catalog-discovery.js.map +1 -1
- package/dist/src/catalox/catalog-lifecycle.d.ts.map +1 -1
- package/dist/src/catalox/catalog-lifecycle.js +26 -19
- package/dist/src/catalox/catalog-lifecycle.js.map +1 -1
- package/dist/src/catalox/catalox-bound.d.ts +48 -1
- package/dist/src/catalox/catalox-bound.d.ts.map +1 -1
- package/dist/src/catalox/catalox-bound.js +24 -0
- package/dist/src/catalox/catalox-bound.js.map +1 -1
- package/dist/src/catalox/catalox.d.ts +94 -2
- package/dist/src/catalox/catalox.d.ts.map +1 -1
- package/dist/src/catalox/catalox.js +596 -75
- package/dist/src/catalox/catalox.js.map +1 -1
- package/dist/src/catalox/create-catalox.d.ts +4 -0
- package/dist/src/catalox/create-catalox.d.ts.map +1 -1
- package/dist/src/catalox/create-catalox.js +15 -0
- package/dist/src/catalox/create-catalox.js.map +1 -1
- package/dist/src/catalox/native-catalog-merge.d.ts.map +1 -1
- package/dist/src/catalox/native-catalog-merge.js +12 -11
- package/dist/src/catalox/native-catalog-merge.js.map +1 -1
- package/dist/src/contracts/agents.d.ts +19 -0
- package/dist/src/contracts/agents.d.ts.map +1 -0
- package/dist/src/contracts/agents.js +2 -0
- package/dist/src/contracts/agents.js.map +1 -0
- package/dist/src/contracts/catalog-types.d.ts +19 -0
- package/dist/src/contracts/catalog-types.d.ts.map +1 -0
- package/dist/src/contracts/catalog-types.js +2 -0
- package/dist/src/contracts/catalog-types.js.map +1 -0
- package/dist/src/contracts/catalogs.d.ts +26 -6
- package/dist/src/contracts/catalogs.d.ts.map +1 -1
- package/dist/src/contracts/catalogs.js.map +1 -1
- package/dist/src/contracts/descriptors.d.ts +11 -0
- package/dist/src/contracts/descriptors.d.ts.map +1 -1
- package/dist/src/contracts/design-objects.d.ts +38 -0
- package/dist/src/contracts/design-objects.d.ts.map +1 -0
- package/dist/src/contracts/design-objects.js +2 -0
- package/dist/src/contracts/design-objects.js.map +1 -0
- package/dist/src/contracts/discovery.d.ts +7 -8
- package/dist/src/contracts/discovery.d.ts.map +1 -1
- package/dist/src/contracts/domains.d.ts +19 -0
- package/dist/src/contracts/domains.d.ts.map +1 -0
- package/dist/src/contracts/domains.js +2 -0
- package/dist/src/contracts/domains.js.map +1 -0
- package/dist/src/contracts/ids.d.ts +2 -0
- package/dist/src/contracts/ids.d.ts.map +1 -1
- package/dist/src/contracts/index.d.ts +11 -5
- package/dist/src/contracts/index.d.ts.map +1 -1
- package/dist/src/contracts/index.js +1 -0
- package/dist/src/contracts/index.js.map +1 -1
- package/dist/src/contracts/inputs.d.ts +19 -0
- package/dist/src/contracts/inputs.d.ts.map +1 -1
- package/dist/src/contracts/items.d.ts +9 -7
- package/dist/src/contracts/items.d.ts.map +1 -1
- package/dist/src/contracts/presentation-binding.d.ts +116 -0
- package/dist/src/contracts/presentation-binding.d.ts.map +1 -0
- package/dist/src/contracts/presentation-binding.js +215 -0
- package/dist/src/contracts/presentation-binding.js.map +1 -0
- package/dist/src/contracts/presentation.d.ts +76 -0
- package/dist/src/contracts/presentation.d.ts.map +1 -1
- package/dist/src/contracts/references.d.ts +40 -0
- package/dist/src/contracts/references.d.ts.map +1 -1
- package/dist/src/contracts/render-map.d.ts +12 -0
- package/dist/src/contracts/render-map.d.ts.map +1 -1
- package/dist/src/firebase/agent-store.d.ts +18 -0
- package/dist/src/firebase/agent-store.d.ts.map +1 -0
- package/dist/src/firebase/agent-store.js +47 -0
- package/dist/src/firebase/agent-store.js.map +1 -0
- package/dist/src/firebase/catalog-type-store.d.ts +22 -0
- package/dist/src/firebase/catalog-type-store.d.ts.map +1 -0
- package/dist/src/firebase/catalog-type-store.js +51 -0
- package/dist/src/firebase/catalog-type-store.js.map +1 -0
- package/dist/src/firebase/definition-store.d.ts +4 -18
- package/dist/src/firebase/definition-store.d.ts.map +1 -1
- package/dist/src/firebase/definition-store.js.map +1 -1
- package/dist/src/firebase/design-object-store.d.ts +15 -0
- package/dist/src/firebase/design-object-store.d.ts.map +1 -0
- package/dist/src/firebase/design-object-store.js +51 -0
- package/dist/src/firebase/design-object-store.js.map +1 -0
- package/dist/src/firebase/domain-store.d.ts +18 -0
- package/dist/src/firebase/domain-store.d.ts.map +1 -0
- package/dist/src/firebase/domain-store.js +47 -0
- package/dist/src/firebase/domain-store.js.map +1 -0
- package/dist/src/firebase/index.d.ts +2 -0
- package/dist/src/firebase/index.d.ts.map +1 -1
- package/dist/src/firebase/index.js +2 -0
- package/dist/src/firebase/index.js.map +1 -1
- package/dist/src/firebase/presentation-profile-store.d.ts +18 -0
- package/dist/src/firebase/presentation-profile-store.d.ts.map +1 -0
- package/dist/src/firebase/presentation-profile-store.js +44 -0
- package/dist/src/firebase/presentation-profile-store.js.map +1 -0
- package/dist/src/firebase/reference-store.d.ts +1 -0
- package/dist/src/firebase/reference-store.d.ts.map +1 -1
- package/dist/src/firebase/reference-store.js +7 -0
- package/dist/src/firebase/reference-store.js.map +1 -1
- package/dist/src/migrations/backfill-catalog-model.d.ts +29 -0
- package/dist/src/migrations/backfill-catalog-model.d.ts.map +1 -0
- package/dist/src/migrations/backfill-catalog-model.js +124 -0
- package/dist/src/migrations/backfill-catalog-model.js.map +1 -0
- package/dist/src/migrations/migrate-native-catalog-layout.js +4 -4
- package/dist/src/migrations/migrate-native-catalog-layout.js.map +1 -1
- package/dist/src/validation/index.d.ts +2 -2
- package/dist/src/validation/index.d.ts.map +1 -1
- package/dist/src/validation/index.js +2 -2
- package/dist/src/validation/index.js.map +1 -1
- package/dist/src/validation/ui-spec-schema.d.ts +5 -0
- package/dist/src/validation/ui-spec-schema.d.ts.map +1 -1
- package/dist/src/validation/ui-spec-schema.js +139 -0
- package/dist/src/validation/ui-spec-schema.js.map +1 -1
- package/dist/src/validation/ui-spec-validate.d.ts +3 -0
- package/dist/src/validation/ui-spec-validate.d.ts.map +1 -1
- package/dist/src/validation/ui-spec-validate.js +13 -1
- package/dist/src/validation/ui-spec-validate.js.map +1 -1
- package/package.json +2 -2
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { AppId, StoreId } from "../contracts/ids.js";
|
|
2
|
+
import type { AgentRegistryRecord, AgentRegistryScope } from "../contracts/agents.js";
|
|
3
|
+
import { FirestoreStore } from "./firestore-store.js";
|
|
4
|
+
export declare class AgentStore {
|
|
5
|
+
private readonly store;
|
|
6
|
+
constructor(store: FirestoreStore);
|
|
7
|
+
private docRef;
|
|
8
|
+
get(scope: AgentRegistryScope): Promise<AgentRegistryRecord | null>;
|
|
9
|
+
upsert(scope: AgentRegistryScope, input: {
|
|
10
|
+
agents: string[];
|
|
11
|
+
metadata?: Record<string, unknown>;
|
|
12
|
+
}): Promise<void>;
|
|
13
|
+
resolveForContext(input: {
|
|
14
|
+
storeId?: StoreId;
|
|
15
|
+
appId?: AppId;
|
|
16
|
+
}): Promise<AgentRegistryRecord | null>;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=agent-store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-store.d.ts","sourceRoot":"","sources":["../../../src/firebase/agent-store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,KAAK,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AACtF,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAQtD,qBAAa,UAAU;IACT,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,cAAc;IAElD,OAAO,CAAC,MAAM;IAIR,GAAG,CAAC,KAAK,EAAE,kBAAkB,GAAG,OAAO,CAAC,mBAAmB,GAAG,IAAI,CAAC;IAKnE,MAAM,CAAC,KAAK,EAAE,kBAAkB,EAAE,KAAK,EAAE;QAAE,MAAM,EAAE,MAAM,EAAE,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAajH,iBAAiB,CAAC,KAAK,EAAE;QAAE,OAAO,CAAC,EAAE,OAAO,CAAC;QAAC,KAAK,CAAC,EAAE,KAAK,CAAA;KAAE,GAAG,OAAO,CAAC,mBAAmB,GAAG,IAAI,CAAC;CAW1G"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { FirestoreStore } from "./firestore-store.js";
|
|
2
|
+
function scopeDocId(scope) {
|
|
3
|
+
if (scope.kind === "global")
|
|
4
|
+
return "global";
|
|
5
|
+
if (scope.kind === "app")
|
|
6
|
+
return `app:${String(scope.appId)}`;
|
|
7
|
+
return `store:${String(scope.storeId)}`;
|
|
8
|
+
}
|
|
9
|
+
export class AgentStore {
|
|
10
|
+
store;
|
|
11
|
+
constructor(store) {
|
|
12
|
+
this.store = store;
|
|
13
|
+
}
|
|
14
|
+
docRef(scope) {
|
|
15
|
+
return this.store.collection("agentRegistry").doc(scopeDocId(scope));
|
|
16
|
+
}
|
|
17
|
+
async get(scope) {
|
|
18
|
+
const snap = await this.docRef(scope).get();
|
|
19
|
+
return snap.exists ? snap.data() : null;
|
|
20
|
+
}
|
|
21
|
+
async upsert(scope, input) {
|
|
22
|
+
const now = new Date().toISOString();
|
|
23
|
+
const existing = await this.get(scope);
|
|
24
|
+
const record = {
|
|
25
|
+
scope,
|
|
26
|
+
agents: input.agents,
|
|
27
|
+
...(input.metadata != null ? { metadata: input.metadata } : {}),
|
|
28
|
+
createdAt: existing?.createdAt ?? now,
|
|
29
|
+
updatedAt: now,
|
|
30
|
+
};
|
|
31
|
+
await this.docRef(scope).set(record, { merge: true });
|
|
32
|
+
}
|
|
33
|
+
async resolveForContext(input) {
|
|
34
|
+
if (input.storeId) {
|
|
35
|
+
const got = await this.get({ kind: "store", storeId: input.storeId });
|
|
36
|
+
if (got)
|
|
37
|
+
return got;
|
|
38
|
+
}
|
|
39
|
+
if (input.appId) {
|
|
40
|
+
const got = await this.get({ kind: "app", appId: input.appId });
|
|
41
|
+
if (got)
|
|
42
|
+
return got;
|
|
43
|
+
}
|
|
44
|
+
return this.get({ kind: "global" });
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=agent-store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-store.js","sourceRoot":"","sources":["../../../src/firebase/agent-store.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,SAAS,UAAU,CAAC,KAAyB;IAC3C,IAAI,KAAK,CAAC,IAAI,KAAK,QAAQ;QAAE,OAAO,QAAQ,CAAC;IAC7C,IAAI,KAAK,CAAC,IAAI,KAAK,KAAK;QAAE,OAAO,OAAO,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC;IAC9D,OAAO,SAAS,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;AAC1C,CAAC;AAED,MAAM,OAAO,UAAU;IACQ;IAA7B,YAA6B,KAAqB;QAArB,UAAK,GAAL,KAAK,CAAgB;IAAG,CAAC;IAE9C,MAAM,CAAC,KAAyB;QACtC,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;IACvE,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,KAAyB;QACjC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,CAAC;QAC5C,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAE,IAAI,CAAC,IAAI,EAA0B,CAAC,CAAC,CAAC,IAAI,CAAC;IACnE,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,KAAyB,EAAE,KAA+D;QACrG,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QACrC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACvC,MAAM,MAAM,GAAwB;YAClC,KAAK;YACL,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,GAAG,CAAC,KAAK,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YAC/D,SAAS,EAAE,QAAQ,EAAE,SAAS,IAAI,GAAG;YACrC,SAAS,EAAE,GAAG;SACf,CAAC;QACF,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IACxD,CAAC;IAED,KAAK,CAAC,iBAAiB,CAAC,KAA2C;QACjE,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;YAClB,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;YACtE,IAAI,GAAG;gBAAE,OAAO,GAAG,CAAC;QACtB,CAAC;QACD,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;YAChB,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;YAChE,IAAI,GAAG;gBAAE,OAAO,GAAG,CAAC;QACtB,CAAC;QACD,OAAO,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC;IACtC,CAAC;CACF"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { AppId, StoreId } from "../contracts/ids.js";
|
|
2
|
+
import type { CatalogTypeRegistryRecord, CatalogTypeScope } from "../contracts/catalog-types.js";
|
|
3
|
+
import { FirestoreStore } from "./firestore-store.js";
|
|
4
|
+
export declare class CatalogTypeStore {
|
|
5
|
+
private readonly store;
|
|
6
|
+
constructor(store: FirestoreStore);
|
|
7
|
+
private docRef;
|
|
8
|
+
get(scope: CatalogTypeScope): Promise<CatalogTypeRegistryRecord | null>;
|
|
9
|
+
upsert(scope: CatalogTypeScope, input: {
|
|
10
|
+
types: string[];
|
|
11
|
+
metadata?: Record<string, unknown>;
|
|
12
|
+
}): Promise<void>;
|
|
13
|
+
/**
|
|
14
|
+
* Best applicable list for a context: store → app → global.
|
|
15
|
+
* Returns null when no registry entry exists for any applicable scope.
|
|
16
|
+
*/
|
|
17
|
+
resolveForContext(input: {
|
|
18
|
+
storeId?: StoreId;
|
|
19
|
+
appId?: AppId;
|
|
20
|
+
}): Promise<CatalogTypeRegistryRecord | null>;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=catalog-type-store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"catalog-type-store.d.ts","sourceRoot":"","sources":["../../../src/firebase/catalog-type-store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,KAAK,EAAE,yBAAyB,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AACjG,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAQtD,qBAAa,gBAAgB;IACf,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,cAAc;IAElD,OAAO,CAAC,MAAM;IAIR,GAAG,CAAC,KAAK,EAAE,gBAAgB,GAAG,OAAO,CAAC,yBAAyB,GAAG,IAAI,CAAC;IAKvE,MAAM,CAAC,KAAK,EAAE,gBAAgB,EAAE,KAAK,EAAE;QAAE,KAAK,EAAE,MAAM,EAAE,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAapH;;;OAGG;IACG,iBAAiB,CAAC,KAAK,EAAE;QAAE,OAAO,CAAC,EAAE,OAAO,CAAC;QAAC,KAAK,CAAC,EAAE,KAAK,CAAA;KAAE,GAAG,OAAO,CAAC,yBAAyB,GAAG,IAAI,CAAC;CAWhH"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { FirestoreStore } from "./firestore-store.js";
|
|
2
|
+
function scopeDocId(scope) {
|
|
3
|
+
if (scope.kind === "global")
|
|
4
|
+
return "global";
|
|
5
|
+
if (scope.kind === "app")
|
|
6
|
+
return `app:${String(scope.appId)}`;
|
|
7
|
+
return `store:${String(scope.storeId)}`;
|
|
8
|
+
}
|
|
9
|
+
export class CatalogTypeStore {
|
|
10
|
+
store;
|
|
11
|
+
constructor(store) {
|
|
12
|
+
this.store = store;
|
|
13
|
+
}
|
|
14
|
+
docRef(scope) {
|
|
15
|
+
return this.store.collection("catalogTypeRegistry").doc(scopeDocId(scope));
|
|
16
|
+
}
|
|
17
|
+
async get(scope) {
|
|
18
|
+
const snap = await this.docRef(scope).get();
|
|
19
|
+
return snap.exists ? snap.data() : null;
|
|
20
|
+
}
|
|
21
|
+
async upsert(scope, input) {
|
|
22
|
+
const now = new Date().toISOString();
|
|
23
|
+
const existing = await this.get(scope);
|
|
24
|
+
const record = {
|
|
25
|
+
scope,
|
|
26
|
+
types: input.types,
|
|
27
|
+
...(input.metadata != null ? { metadata: input.metadata } : {}),
|
|
28
|
+
createdAt: existing?.createdAt ?? now,
|
|
29
|
+
updatedAt: now,
|
|
30
|
+
};
|
|
31
|
+
await this.docRef(scope).set(record, { merge: true });
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Best applicable list for a context: store → app → global.
|
|
35
|
+
* Returns null when no registry entry exists for any applicable scope.
|
|
36
|
+
*/
|
|
37
|
+
async resolveForContext(input) {
|
|
38
|
+
if (input.storeId) {
|
|
39
|
+
const got = await this.get({ kind: "store", storeId: input.storeId });
|
|
40
|
+
if (got)
|
|
41
|
+
return got;
|
|
42
|
+
}
|
|
43
|
+
if (input.appId) {
|
|
44
|
+
const got = await this.get({ kind: "app", appId: input.appId });
|
|
45
|
+
if (got)
|
|
46
|
+
return got;
|
|
47
|
+
}
|
|
48
|
+
return this.get({ kind: "global" });
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=catalog-type-store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"catalog-type-store.js","sourceRoot":"","sources":["../../../src/firebase/catalog-type-store.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,SAAS,UAAU,CAAC,KAAuB;IACzC,IAAI,KAAK,CAAC,IAAI,KAAK,QAAQ;QAAE,OAAO,QAAQ,CAAC;IAC7C,IAAI,KAAK,CAAC,IAAI,KAAK,KAAK;QAAE,OAAO,OAAO,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC;IAC9D,OAAO,SAAS,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;AAC1C,CAAC;AAED,MAAM,OAAO,gBAAgB;IACE;IAA7B,YAA6B,KAAqB;QAArB,UAAK,GAAL,KAAK,CAAgB;IAAG,CAAC;IAE9C,MAAM,CAAC,KAAuB;QACpC,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,qBAAqB,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;IAC7E,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,KAAuB;QAC/B,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,CAAC;QAC5C,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAE,IAAI,CAAC,IAAI,EAAgC,CAAC,CAAC,CAAC,IAAI,CAAC;IACzE,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,KAAuB,EAAE,KAA8D;QAClG,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QACrC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACvC,MAAM,MAAM,GAA8B;YACxC,KAAK;YACL,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,GAAG,CAAC,KAAK,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YAC/D,SAAS,EAAE,QAAQ,EAAE,SAAS,IAAI,GAAG;YACrC,SAAS,EAAE,GAAG;SACf,CAAC;QACF,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IACxD,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,iBAAiB,CAAC,KAA2C;QACjE,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;YAClB,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;YACtE,IAAI,GAAG;gBAAE,OAAO,GAAG,CAAC;QACtB,CAAC;QACD,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;YAChB,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;YAChE,IAAI,GAAG;gBAAE,OAAO,GAAG,CAAC;QACtB,CAAC;QACD,OAAO,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC;IACtC,CAAC;CACF"}
|
|
@@ -1,23 +1,10 @@
|
|
|
1
1
|
import type { CatalogId } from "../contracts/ids.js";
|
|
2
|
+
import type { CatalogItemsConfig, CatalogSourceMode } from "../contracts/catalogs.js";
|
|
2
3
|
import { FirestoreStore } from "./firestore-store.js";
|
|
3
|
-
export type
|
|
4
|
+
export type CatalogDefinitionRecord = {
|
|
4
5
|
catalogId: CatalogId;
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
provider: "firestore";
|
|
8
|
-
collectionPath: string;
|
|
9
|
-
};
|
|
10
|
-
itemSchema?: Record<string, unknown>;
|
|
11
|
-
metadata?: Record<string, unknown>;
|
|
12
|
-
createdAt: string;
|
|
13
|
-
updatedAt: string;
|
|
14
|
-
};
|
|
15
|
-
export type MappedCatalogDefinitionRecord = {
|
|
16
|
-
catalogId: CatalogId;
|
|
17
|
-
type: "mapped";
|
|
18
|
-
adapterType: "mongo" | "api";
|
|
19
|
-
adapterId: string;
|
|
20
|
-
mappingId: string;
|
|
6
|
+
sourceMode: CatalogSourceMode;
|
|
7
|
+
catalogItems: CatalogItemsConfig;
|
|
21
8
|
sync?: {
|
|
22
9
|
mode: "read-through" | "snapshot";
|
|
23
10
|
lastSyncedAt?: string;
|
|
@@ -28,7 +15,6 @@ export type MappedCatalogDefinitionRecord = {
|
|
|
28
15
|
createdAt: string;
|
|
29
16
|
updatedAt: string;
|
|
30
17
|
};
|
|
31
|
-
export type CatalogDefinitionRecord = NativeCatalogDefinitionRecord | MappedCatalogDefinitionRecord;
|
|
32
18
|
export declare class DefinitionStore {
|
|
33
19
|
private readonly store;
|
|
34
20
|
constructor(store: FirestoreStore);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"definition-store.d.ts","sourceRoot":"","sources":["../../../src/firebase/definition-store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,
|
|
1
|
+
{"version":3,"file":"definition-store.d.ts","sourceRoot":"","sources":["../../../src/firebase/definition-store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,KAAK,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AACtF,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,MAAM,MAAM,uBAAuB,GAAG;IACpC,SAAS,EAAE,SAAS,CAAC;IACrB,UAAU,EAAE,iBAAiB,CAAC;IAC9B,YAAY,EAAE,kBAAkB,CAAC;IACjC,IAAI,CAAC,EAAE;QACL,IAAI,EAAE,cAAc,GAAG,UAAU,CAAC;QAClC,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,UAAU,CAAC,EAAE,MAAM,GAAG,SAAS,GAAG,SAAS,GAAG,OAAO,GAAG,OAAO,CAAC;QAChE,aAAa,CAAC,EAAE,MAAM,CAAC;KACxB,CAAC;IACF,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACnC,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,qBAAa,eAAe;IACd,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,cAAc;IAElD,OAAO,CAAC,MAAM;IAIR,GAAG,CAAC,SAAS,EAAE,SAAS,GAAG,OAAO,CAAC,uBAAuB,GAAG,IAAI,CAAC;IAKlE,MAAM,CAAC,MAAM,EAAE,uBAAuB,GAAG,OAAO,CAAC,IAAI,CAAC;CAG7D"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"definition-store.js","sourceRoot":"","sources":["../../../src/firebase/definition-store.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"definition-store.js","sourceRoot":"","sources":["../../../src/firebase/definition-store.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAiBtD,MAAM,OAAO,eAAe;IACG;IAA7B,YAA6B,KAAqB;QAArB,UAAK,GAAL,KAAK,CAAgB;IAAG,CAAC;IAE9C,MAAM,CAAC,SAAoB;QACjC,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IACpE,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,SAAoB;QAC5B,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,CAAC;QAChD,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAE,IAAI,CAAC,IAAI,EAA8B,CAAC,CAAC,CAAC,IAAI,CAAC;IACvE,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,MAA+B;QAC1C,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IACnE,CAAC;CACF"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { CatalogDesignObjectRecord, CatalogDesignScope } from "../contracts/design-objects.js";
|
|
2
|
+
import { FirestoreStore } from "./firestore-store.js";
|
|
3
|
+
export declare class DesignObjectStore {
|
|
4
|
+
private readonly store;
|
|
5
|
+
constructor(store: FirestoreStore);
|
|
6
|
+
private docRef;
|
|
7
|
+
get(designId: string): Promise<CatalogDesignObjectRecord | null>;
|
|
8
|
+
upsert(record: CatalogDesignObjectRecord): Promise<void>;
|
|
9
|
+
/**
|
|
10
|
+
* Best-effort list: queries by one primary axis then filters the rest in-memory.
|
|
11
|
+
* This avoids requiring a large number of composite indexes.
|
|
12
|
+
*/
|
|
13
|
+
listByScope(scope: CatalogDesignScope): Promise<CatalogDesignObjectRecord[]>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=design-object-store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"design-object-store.d.ts","sourceRoot":"","sources":["../../../src/firebase/design-object-store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,yBAAyB,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AACpG,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,qBAAa,iBAAiB;IAChB,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,cAAc;IAElD,OAAO,CAAC,MAAM;IAIR,GAAG,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,yBAAyB,GAAG,IAAI,CAAC;IAKhE,MAAM,CAAC,MAAM,EAAE,yBAAyB,GAAG,OAAO,CAAC,IAAI,CAAC;IAI9D;;;OAGG;IACG,WAAW,CAAC,KAAK,EAAE,kBAAkB,GAAG,OAAO,CAAC,yBAAyB,EAAE,CAAC;CA6BnF"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { FirestoreStore } from "./firestore-store.js";
|
|
2
|
+
export class DesignObjectStore {
|
|
3
|
+
store;
|
|
4
|
+
constructor(store) {
|
|
5
|
+
this.store = store;
|
|
6
|
+
}
|
|
7
|
+
docRef(designId) {
|
|
8
|
+
return this.store.collection("catalogDesignObjects").doc(String(designId));
|
|
9
|
+
}
|
|
10
|
+
async get(designId) {
|
|
11
|
+
const snap = await this.docRef(designId).get();
|
|
12
|
+
return snap.exists ? snap.data() : null;
|
|
13
|
+
}
|
|
14
|
+
async upsert(record) {
|
|
15
|
+
await this.docRef(record.designId).set(record, { merge: true });
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Best-effort list: queries by one primary axis then filters the rest in-memory.
|
|
19
|
+
* This avoids requiring a large number of composite indexes.
|
|
20
|
+
*/
|
|
21
|
+
async listByScope(scope) {
|
|
22
|
+
const col = this.store.collection("catalogDesignObjects");
|
|
23
|
+
const primary = scope.storeId != null
|
|
24
|
+
? { field: "scope.storeId", value: String(scope.storeId) }
|
|
25
|
+
: scope.appId != null
|
|
26
|
+
? { field: "scope.appId", value: String(scope.appId) }
|
|
27
|
+
: scope.accountId != null
|
|
28
|
+
? { field: "scope.accountId", value: String(scope.accountId) }
|
|
29
|
+
: scope.agentId != null
|
|
30
|
+
? { field: "scope.agentId", value: String(scope.agentId) }
|
|
31
|
+
: null;
|
|
32
|
+
if (!primary)
|
|
33
|
+
return [];
|
|
34
|
+
const snap = await col.where(primary.field, "==", primary.value).get();
|
|
35
|
+
const all = snap.docs.map((d) => d.data());
|
|
36
|
+
const matches = (r) => {
|
|
37
|
+
const s = r?.scope ?? {};
|
|
38
|
+
if (scope.storeId != null && String(s.storeId ?? "") !== String(scope.storeId))
|
|
39
|
+
return false;
|
|
40
|
+
if (scope.appId != null && String(s.appId ?? "") !== String(scope.appId))
|
|
41
|
+
return false;
|
|
42
|
+
if (scope.accountId != null && String(s.accountId ?? "") !== String(scope.accountId))
|
|
43
|
+
return false;
|
|
44
|
+
if (scope.agentId != null && String(s.agentId ?? "") !== String(scope.agentId))
|
|
45
|
+
return false;
|
|
46
|
+
return true;
|
|
47
|
+
};
|
|
48
|
+
return all.filter(matches);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=design-object-store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"design-object-store.js","sourceRoot":"","sources":["../../../src/firebase/design-object-store.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,MAAM,OAAO,iBAAiB;IACC;IAA7B,YAA6B,KAAqB;QAArB,UAAK,GAAL,KAAK,CAAgB;IAAG,CAAC;IAE9C,MAAM,CAAC,QAAgB;QAC7B,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,sBAAsB,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC;IAC7E,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,QAAgB;QACxB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC;QAC/C,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAE,IAAI,CAAC,IAAI,EAAgC,CAAC,CAAC,CAAC,IAAI,CAAC;IACzE,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,MAAiC;QAC5C,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IAClE,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,WAAW,CAAC,KAAyB;QACzC,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,sBAAsB,CAAC,CAAC;QAC1D,MAAM,OAAO,GACX,KAAK,CAAC,OAAO,IAAI,IAAI;YACnB,CAAC,CAAC,EAAE,KAAK,EAAE,eAAe,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE;YAC1D,CAAC,CAAC,KAAK,CAAC,KAAK,IAAI,IAAI;gBACnB,CAAC,CAAC,EAAE,KAAK,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;gBACtD,CAAC,CAAC,KAAK,CAAC,SAAS,IAAI,IAAI;oBACvB,CAAC,CAAC,EAAE,KAAK,EAAE,iBAAiB,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE;oBAC9D,CAAC,CAAC,KAAK,CAAC,OAAO,IAAI,IAAI;wBACrB,CAAC,CAAC,EAAE,KAAK,EAAE,eAAe,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE;wBAC1D,CAAC,CAAC,IAAI,CAAC;QAEjB,IAAI,CAAC,OAAO;YAAE,OAAO,EAAE,CAAC;QAExB,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,EAAE,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,CAAC;QACvE,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAA+B,CAAC,CAAC;QAExE,MAAM,OAAO,GAAG,CAAC,CAA4B,EAAE,EAAE;YAC/C,MAAM,CAAC,GAAS,CAAS,EAAE,KAAK,IAAI,EAAE,CAAC;YACvC,IAAI,KAAK,CAAC,OAAO,IAAI,IAAI,IAAI,MAAM,CAAC,CAAC,CAAC,OAAO,IAAI,EAAE,CAAC,KAAK,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC;gBAAE,OAAO,KAAK,CAAC;YAC7F,IAAI,KAAK,CAAC,KAAK,IAAI,IAAI,IAAI,MAAM,CAAC,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC,KAAK,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC;gBAAE,OAAO,KAAK,CAAC;YACvF,IAAI,KAAK,CAAC,SAAS,IAAI,IAAI,IAAI,MAAM,CAAC,CAAC,CAAC,SAAS,IAAI,EAAE,CAAC,KAAK,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC;gBAAE,OAAO,KAAK,CAAC;YACnG,IAAI,KAAK,CAAC,OAAO,IAAI,IAAI,IAAI,MAAM,CAAC,CAAC,CAAC,OAAO,IAAI,EAAE,CAAC,KAAK,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC;gBAAE,OAAO,KAAK,CAAC;YAC7F,OAAO,IAAI,CAAC;QACd,CAAC,CAAC;QAEF,OAAO,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAC7B,CAAC;CACF"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { AppId, StoreId } from "../contracts/ids.js";
|
|
2
|
+
import type { DomainRegistryRecord, DomainRegistryScope } from "../contracts/domains.js";
|
|
3
|
+
import { FirestoreStore } from "./firestore-store.js";
|
|
4
|
+
export declare class DomainStore {
|
|
5
|
+
private readonly store;
|
|
6
|
+
constructor(store: FirestoreStore);
|
|
7
|
+
private docRef;
|
|
8
|
+
get(scope: DomainRegistryScope): Promise<DomainRegistryRecord | null>;
|
|
9
|
+
upsert(scope: DomainRegistryScope, input: {
|
|
10
|
+
domains: string[];
|
|
11
|
+
metadata?: Record<string, unknown>;
|
|
12
|
+
}): Promise<void>;
|
|
13
|
+
resolveForContext(input: {
|
|
14
|
+
storeId?: StoreId;
|
|
15
|
+
appId?: AppId;
|
|
16
|
+
}): Promise<DomainRegistryRecord | null>;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=domain-store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"domain-store.d.ts","sourceRoot":"","sources":["../../../src/firebase/domain-store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,KAAK,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AACzF,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAQtD,qBAAa,WAAW;IACV,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,cAAc;IAElD,OAAO,CAAC,MAAM;IAIR,GAAG,CAAC,KAAK,EAAE,mBAAmB,GAAG,OAAO,CAAC,oBAAoB,GAAG,IAAI,CAAC;IAKrE,MAAM,CAAC,KAAK,EAAE,mBAAmB,EAAE,KAAK,EAAE;QAAE,OAAO,EAAE,MAAM,EAAE,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAanH,iBAAiB,CAAC,KAAK,EAAE;QAAE,OAAO,CAAC,EAAE,OAAO,CAAC;QAAC,KAAK,CAAC,EAAE,KAAK,CAAA;KAAE,GAAG,OAAO,CAAC,oBAAoB,GAAG,IAAI,CAAC;CAW3G"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { FirestoreStore } from "./firestore-store.js";
|
|
2
|
+
function scopeDocId(scope) {
|
|
3
|
+
if (scope.kind === "global")
|
|
4
|
+
return "global";
|
|
5
|
+
if (scope.kind === "app")
|
|
6
|
+
return `app:${String(scope.appId)}`;
|
|
7
|
+
return `store:${String(scope.storeId)}`;
|
|
8
|
+
}
|
|
9
|
+
export class DomainStore {
|
|
10
|
+
store;
|
|
11
|
+
constructor(store) {
|
|
12
|
+
this.store = store;
|
|
13
|
+
}
|
|
14
|
+
docRef(scope) {
|
|
15
|
+
return this.store.collection("domainRegistry").doc(scopeDocId(scope));
|
|
16
|
+
}
|
|
17
|
+
async get(scope) {
|
|
18
|
+
const snap = await this.docRef(scope).get();
|
|
19
|
+
return snap.exists ? snap.data() : null;
|
|
20
|
+
}
|
|
21
|
+
async upsert(scope, input) {
|
|
22
|
+
const now = new Date().toISOString();
|
|
23
|
+
const existing = await this.get(scope);
|
|
24
|
+
const record = {
|
|
25
|
+
scope,
|
|
26
|
+
domains: input.domains,
|
|
27
|
+
...(input.metadata != null ? { metadata: input.metadata } : {}),
|
|
28
|
+
createdAt: existing?.createdAt ?? now,
|
|
29
|
+
updatedAt: now,
|
|
30
|
+
};
|
|
31
|
+
await this.docRef(scope).set(record, { merge: true });
|
|
32
|
+
}
|
|
33
|
+
async resolveForContext(input) {
|
|
34
|
+
if (input.storeId) {
|
|
35
|
+
const got = await this.get({ kind: "store", storeId: input.storeId });
|
|
36
|
+
if (got)
|
|
37
|
+
return got;
|
|
38
|
+
}
|
|
39
|
+
if (input.appId) {
|
|
40
|
+
const got = await this.get({ kind: "app", appId: input.appId });
|
|
41
|
+
if (got)
|
|
42
|
+
return got;
|
|
43
|
+
}
|
|
44
|
+
return this.get({ kind: "global" });
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=domain-store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"domain-store.js","sourceRoot":"","sources":["../../../src/firebase/domain-store.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,SAAS,UAAU,CAAC,KAA0B;IAC5C,IAAI,KAAK,CAAC,IAAI,KAAK,QAAQ;QAAE,OAAO,QAAQ,CAAC;IAC7C,IAAI,KAAK,CAAC,IAAI,KAAK,KAAK;QAAE,OAAO,OAAO,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC;IAC9D,OAAO,SAAS,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;AAC1C,CAAC;AAED,MAAM,OAAO,WAAW;IACO;IAA7B,YAA6B,KAAqB;QAArB,UAAK,GAAL,KAAK,CAAgB;IAAG,CAAC;IAE9C,MAAM,CAAC,KAA0B;QACvC,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;IACxE,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,KAA0B;QAClC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,CAAC;QAC5C,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAE,IAAI,CAAC,IAAI,EAA2B,CAAC,CAAC,CAAC,IAAI,CAAC;IACpE,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,KAA0B,EAAE,KAAgE;QACvG,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QACrC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACvC,MAAM,MAAM,GAAyB;YACnC,KAAK;YACL,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,GAAG,CAAC,KAAK,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YAC/D,SAAS,EAAE,QAAQ,EAAE,SAAS,IAAI,GAAG;YACrC,SAAS,EAAE,GAAG;SACf,CAAC;QACF,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IACxD,CAAC;IAED,KAAK,CAAC,iBAAiB,CAAC,KAA2C;QACjE,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;YAClB,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;YACtE,IAAI,GAAG;gBAAE,OAAO,GAAG,CAAC;QACtB,CAAC;QACD,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;YAChB,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;YAChE,IAAI,GAAG;gBAAE,OAAO,GAAG,CAAC;QACtB,CAAC;QACD,OAAO,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC;IACtC,CAAC;CACF"}
|
|
@@ -9,6 +9,8 @@ export * from "./mapping-store.js";
|
|
|
9
9
|
export * from "./adapter-store.js";
|
|
10
10
|
export * from "./descriptor-store.js";
|
|
11
11
|
export * from "./renderer-snippet-store.js";
|
|
12
|
+
export * from "./presentation-profile-store.js";
|
|
13
|
+
export * from "./design-object-store.js";
|
|
12
14
|
export * from "./reference-store.js";
|
|
13
15
|
export * from "./native-item-store.js";
|
|
14
16
|
export * from "./snapshot-store.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/firebase/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,yBAAyB,CAAC;AACxC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,sBAAsB,CAAC;AACrC,cAAc,wBAAwB,CAAC;AACvC,cAAc,qBAAqB,CAAC;AACpC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,iCAAiC,CAAC;AAChD,cAAc,gBAAgB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/firebase/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,yBAAyB,CAAC;AACxC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,iCAAiC,CAAC;AAChD,cAAc,0BAA0B,CAAC;AACzC,cAAc,sBAAsB,CAAC;AACrC,cAAc,wBAAwB,CAAC;AACvC,cAAc,qBAAqB,CAAC;AACpC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,iCAAiC,CAAC;AAChD,cAAc,gBAAgB,CAAC"}
|
|
@@ -9,6 +9,8 @@ export * from "./mapping-store.js";
|
|
|
9
9
|
export * from "./adapter-store.js";
|
|
10
10
|
export * from "./descriptor-store.js";
|
|
11
11
|
export * from "./renderer-snippet-store.js";
|
|
12
|
+
export * from "./presentation-profile-store.js";
|
|
13
|
+
export * from "./design-object-store.js";
|
|
12
14
|
export * from "./reference-store.js";
|
|
13
15
|
export * from "./native-item-store.js";
|
|
14
16
|
export * from "./snapshot-store.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/firebase/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,yBAAyB,CAAC;AACxC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,sBAAsB,CAAC;AACrC,cAAc,wBAAwB,CAAC;AACvC,cAAc,qBAAqB,CAAC;AACpC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,iCAAiC,CAAC;AAChD,cAAc,gBAAgB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/firebase/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,yBAAyB,CAAC;AACxC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,iCAAiC,CAAC;AAChD,cAAc,0BAA0B,CAAC;AACzC,cAAc,sBAAsB,CAAC;AACrC,cAAc,wBAAwB,CAAC;AACvC,cAAc,qBAAqB,CAAC;AACpC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,iCAAiC,CAAC;AAChD,cAAc,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { CatalogPresentationProfileRecord } from "../contracts/presentation-binding.js";
|
|
2
|
+
import { FirestoreStore } from "./firestore-store.js";
|
|
3
|
+
export declare class PresentationProfileStore {
|
|
4
|
+
private readonly store;
|
|
5
|
+
constructor(store: FirestoreStore);
|
|
6
|
+
private docRef;
|
|
7
|
+
get(profileId: string): Promise<CatalogPresentationProfileRecord | null>;
|
|
8
|
+
upsert(record: CatalogPresentationProfileRecord): Promise<void>;
|
|
9
|
+
/**
|
|
10
|
+
* Best-effort listing of applicable profiles for a catalog.
|
|
11
|
+
* Returns catalog-scoped profiles first, then catalogType-scoped profiles.
|
|
12
|
+
*/
|
|
13
|
+
listForCatalog(input: {
|
|
14
|
+
catalogId?: string;
|
|
15
|
+
catalogType?: string;
|
|
16
|
+
}): Promise<CatalogPresentationProfileRecord[]>;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=presentation-profile-store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"presentation-profile-store.d.ts","sourceRoot":"","sources":["../../../src/firebase/presentation-profile-store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gCAAgC,EAAE,MAAM,sCAAsC,CAAC;AAC7F,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,qBAAa,wBAAwB;IACvB,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,cAAc;IAElD,OAAO,CAAC,MAAM;IAIR,GAAG,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,gCAAgC,GAAG,IAAI,CAAC;IAKxE,MAAM,CAAC,MAAM,EAAE,gCAAgC,GAAG,OAAO,CAAC,IAAI,CAAC;IAIrE;;;OAGG;IACG,cAAc,CAAC,KAAK,EAAE;QAAE,SAAS,CAAC,EAAE,MAAM,CAAC;QAAC,WAAW,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,gCAAgC,EAAE,CAAC;CAsBvH"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { FirestoreStore } from "./firestore-store.js";
|
|
2
|
+
export class PresentationProfileStore {
|
|
3
|
+
store;
|
|
4
|
+
constructor(store) {
|
|
5
|
+
this.store = store;
|
|
6
|
+
}
|
|
7
|
+
docRef(profileId) {
|
|
8
|
+
return this.store.collection("catalogPresentationProfiles").doc(String(profileId));
|
|
9
|
+
}
|
|
10
|
+
async get(profileId) {
|
|
11
|
+
const snap = await this.docRef(profileId).get();
|
|
12
|
+
return snap.exists ? snap.data() : null;
|
|
13
|
+
}
|
|
14
|
+
async upsert(record) {
|
|
15
|
+
await this.docRef(record.profileId).set(record, { merge: true });
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Best-effort listing of applicable profiles for a catalog.
|
|
19
|
+
* Returns catalog-scoped profiles first, then catalogType-scoped profiles.
|
|
20
|
+
*/
|
|
21
|
+
async listForCatalog(input) {
|
|
22
|
+
const col = this.store.collection("catalogPresentationProfiles");
|
|
23
|
+
const out = [];
|
|
24
|
+
if (input.catalogId) {
|
|
25
|
+
const snap = await col.where("scope.catalogId", "==", String(input.catalogId)).get();
|
|
26
|
+
out.push(...snap.docs.map((d) => d.data()));
|
|
27
|
+
}
|
|
28
|
+
if (input.catalogType) {
|
|
29
|
+
const snap = await col.where("scope.catalogType", "==", String(input.catalogType)).get();
|
|
30
|
+
out.push(...snap.docs.map((d) => d.data()));
|
|
31
|
+
}
|
|
32
|
+
const seen = new Set();
|
|
33
|
+
return out.filter((r) => {
|
|
34
|
+
const id = String(r?.profileId ?? "");
|
|
35
|
+
if (!id)
|
|
36
|
+
return false;
|
|
37
|
+
if (seen.has(id))
|
|
38
|
+
return false;
|
|
39
|
+
seen.add(id);
|
|
40
|
+
return true;
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=presentation-profile-store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"presentation-profile-store.js","sourceRoot":"","sources":["../../../src/firebase/presentation-profile-store.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,MAAM,OAAO,wBAAwB;IACN;IAA7B,YAA6B,KAAqB;QAArB,UAAK,GAAL,KAAK,CAAgB;IAAG,CAAC;IAE9C,MAAM,CAAC,SAAiB;QAC9B,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,6BAA6B,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;IACrF,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,SAAiB;QACzB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,CAAC;QAChD,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAE,IAAI,CAAC,IAAI,EAAuC,CAAC,CAAC,CAAC,IAAI,CAAC;IAChF,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,MAAwC;QACnD,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IACnE,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,cAAc,CAAC,KAAmD;QACtE,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,6BAA6B,CAAC,CAAC;QACjE,MAAM,GAAG,GAAuC,EAAE,CAAC;QAEnD,IAAI,KAAK,CAAC,SAAS,EAAE,CAAC;YACpB,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,KAAK,CAAC,iBAAiB,EAAE,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;YACrF,GAAG,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAsC,CAAC,CAAC,CAAC;QAClF,CAAC;QACD,IAAI,KAAK,CAAC,WAAW,EAAE,CAAC;YACtB,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,KAAK,CAAC,mBAAmB,EAAE,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;YACzF,GAAG,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAsC,CAAC,CAAC,CAAC;QAClF,CAAC;QAED,MAAM,IAAI,GAAG,IAAI,GAAG,EAAU,CAAC;QAC/B,OAAO,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE;YACtB,MAAM,EAAE,GAAG,MAAM,CAAC,CAAC,EAAE,SAAS,IAAI,EAAE,CAAC,CAAC;YACtC,IAAI,CAAC,EAAE;gBAAE,OAAO,KAAK,CAAC;YACtB,IAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;gBAAE,OAAO,KAAK,CAAC;YAC/B,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YACb,OAAO,IAAI,CAAC;QACd,CAAC,CAAC,CAAC;IACL,CAAC;CACF"}
|
|
@@ -15,6 +15,7 @@ export declare class ReferenceStore {
|
|
|
15
15
|
listReferencingCatalog(catalogId: CatalogId): Promise<CatalogReferenceRecord[]>;
|
|
16
16
|
delete(referenceId: string): Promise<void>;
|
|
17
17
|
listByItem(catalogId: CatalogId, itemId: ItemId): Promise<CatalogReferenceRecord[]>;
|
|
18
|
+
listToItem(catalogId: CatalogId, itemId: ItemId): Promise<CatalogReferenceRecord[]>;
|
|
18
19
|
upsert(record: CatalogReferenceRecord): Promise<void>;
|
|
19
20
|
}
|
|
20
21
|
//# sourceMappingURL=reference-store.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"reference-store.d.ts","sourceRoot":"","sources":["../../../src/firebase/reference-store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AACvE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,MAAM,MAAM,sBAAsB,GAAG,oBAAoB,GAAG;IAC1D,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,qBAAa,cAAc;IACb,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,cAAc;IAElD,OAAO,CAAC,aAAa;IAIf,aAAa,CAAC,SAAS,EAAE,SAAS,GAAG,OAAO,CAAC,sBAAsB,EAAE,CAAC;IAOtE,eAAe,CAAC,SAAS,EAAE,SAAS,GAAG,OAAO,CAAC,sBAAsB,EAAE,CAAC;IAOxE,sBAAsB,CAAC,SAAS,EAAE,SAAS,GAAG,OAAO,CAAC,sBAAsB,EAAE,CAAC;IAO/E,MAAM,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI1C,UAAU,CACd,SAAS,EAAE,SAAS,EACpB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,sBAAsB,EAAE,CAAC;IAQ9B,MAAM,CAAC,MAAM,EAAE,sBAAsB,GAAG,OAAO,CAAC,IAAI,CAAC;CAG5D"}
|
|
1
|
+
{"version":3,"file":"reference-store.d.ts","sourceRoot":"","sources":["../../../src/firebase/reference-store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AACvE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,MAAM,MAAM,sBAAsB,GAAG,oBAAoB,GAAG;IAC1D,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,qBAAa,cAAc;IACb,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,cAAc;IAElD,OAAO,CAAC,aAAa;IAIf,aAAa,CAAC,SAAS,EAAE,SAAS,GAAG,OAAO,CAAC,sBAAsB,EAAE,CAAC;IAOtE,eAAe,CAAC,SAAS,EAAE,SAAS,GAAG,OAAO,CAAC,sBAAsB,EAAE,CAAC;IAOxE,sBAAsB,CAAC,SAAS,EAAE,SAAS,GAAG,OAAO,CAAC,sBAAsB,EAAE,CAAC;IAO/E,MAAM,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI1C,UAAU,CACd,SAAS,EAAE,SAAS,EACpB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,sBAAsB,EAAE,CAAC;IAQ9B,UAAU,CACd,SAAS,EAAE,SAAS,EACpB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,sBAAsB,EAAE,CAAC;IAQ9B,MAAM,CAAC,MAAM,EAAE,sBAAsB,GAAG,OAAO,CAAC,IAAI,CAAC;CAG5D"}
|
|
@@ -36,6 +36,13 @@ export class ReferenceStore {
|
|
|
36
36
|
.get();
|
|
37
37
|
return snap.docs.map((d) => d.data());
|
|
38
38
|
}
|
|
39
|
+
async listToItem(catalogId, itemId) {
|
|
40
|
+
const snap = await this.collectionRef()
|
|
41
|
+
.where("toCatalogId", "==", catalogId)
|
|
42
|
+
.where("toItemId", "==", itemId)
|
|
43
|
+
.get();
|
|
44
|
+
return snap.docs.map((d) => d.data());
|
|
45
|
+
}
|
|
39
46
|
async upsert(record) {
|
|
40
47
|
await this.collectionRef().doc(record.referenceId).set(record, { merge: true });
|
|
41
48
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"reference-store.js","sourceRoot":"","sources":["../../../src/firebase/reference-store.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAQtD,MAAM,OAAO,cAAc;IACI;IAA7B,YAA6B,KAAqB;QAArB,UAAK,GAAL,KAAK,CAAgB;IAAG,CAAC;IAE9C,aAAa;QACnB,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC;IACpD,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,SAAoB;QACtC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,aAAa,EAAE;aACpC,KAAK,CAAC,eAAe,EAAE,IAAI,EAAE,SAAS,CAAC;aACvC,GAAG,EAAE,CAAC;QACT,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAA4B,CAAC,CAAC;IAClE,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,SAAoB;QACxC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,aAAa,EAAE;aACpC,KAAK,CAAC,aAAa,EAAE,IAAI,EAAE,SAAS,CAAC;aACrC,GAAG,EAAE,CAAC;QACT,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAA4B,CAAC,CAAC;IAClE,CAAC;IAED,KAAK,CAAC,sBAAsB,CAAC,SAAoB;QAC/C,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QACvG,MAAM,IAAI,GAAG,IAAI,GAAG,EAAkC,CAAC;QACvD,KAAK,MAAM,CAAC,IAAI,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,CAAC;YAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;QAC7D,OAAO,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IAC5B,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,WAAmB;QAC9B,MAAM,IAAI,CAAC,aAAa,EAAE,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC,MAAM,EAAE,CAAC;IACvD,CAAC;IAED,KAAK,CAAC,UAAU,CACd,SAAoB,EACpB,MAAc;QAEd,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,aAAa,EAAE;aACpC,KAAK,CAAC,eAAe,EAAE,IAAI,EAAE,SAAS,CAAC;aACvC,KAAK,CAAC,YAAY,EAAE,IAAI,EAAE,MAAM,CAAC;aACjC,GAAG,EAAE,CAAC;QACT,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAA4B,CAAC,CAAC;IAClE,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,MAA8B;QACzC,MAAM,IAAI,CAAC,aAAa,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IAClF,CAAC;CACF"}
|
|
1
|
+
{"version":3,"file":"reference-store.js","sourceRoot":"","sources":["../../../src/firebase/reference-store.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { type Firestore } from "firebase-admin/firestore";
|
|
2
|
+
import type { CatalogId } from "../contracts/ids.js";
|
|
3
|
+
export type BackfillCatalogModelInput = {
|
|
4
|
+
catalogIds?: CatalogId[];
|
|
5
|
+
dryRun?: boolean;
|
|
6
|
+
};
|
|
7
|
+
export type BackfillCatalogModelResult = {
|
|
8
|
+
ok: boolean;
|
|
9
|
+
dryRun: boolean;
|
|
10
|
+
catalogsScanned: number;
|
|
11
|
+
catalogsPatched: number;
|
|
12
|
+
nativeItemsPatched: number;
|
|
13
|
+
definitionRecordsPatched: number;
|
|
14
|
+
issues?: Array<{
|
|
15
|
+
code: string;
|
|
16
|
+
message: string;
|
|
17
|
+
catalogId?: string;
|
|
18
|
+
}>;
|
|
19
|
+
};
|
|
20
|
+
/**
|
|
21
|
+
* One-time backfill to the newer catalog model.
|
|
22
|
+
*
|
|
23
|
+
* - Ensures `catalogs/*` has `catalogType`, `catalogItems`, and `metadata` envelope.
|
|
24
|
+
* - Migrates legacy top-level `status`, `createdAt`, `updatedAt` into `metadata.*`.
|
|
25
|
+
* - Ensures native item records under `catalogData-{catalogId}-items/*` have `metadata.createdAt` and `metadata.lastUpdate`.
|
|
26
|
+
* - Converts legacy `catalogDefinitions/*` native `storage` into `catalogItems.providerType: internal` (best-effort).
|
|
27
|
+
*/
|
|
28
|
+
export declare function backfillCatalogModel(fs: Firestore, input: BackfillCatalogModelInput): Promise<BackfillCatalogModelResult>;
|
|
29
|
+
//# sourceMappingURL=backfill-catalog-model.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backfill-catalog-model.d.ts","sourceRoot":"","sources":["../../../src/migrations/backfill-catalog-model.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,KAAK,SAAS,EAAE,MAAM,0BAA0B,CAAC;AAEtE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAGrD,MAAM,MAAM,yBAAyB,GAAG;IACtC,UAAU,CAAC,EAAE,SAAS,EAAE,CAAC;IACzB,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB,CAAC;AAEF,MAAM,MAAM,0BAA0B,GAAG;IACvC,EAAE,EAAE,OAAO,CAAC;IACZ,MAAM,EAAE,OAAO,CAAC;IAChB,eAAe,EAAE,MAAM,CAAC;IACxB,eAAe,EAAE,MAAM,CAAC;IACxB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,wBAAwB,EAAE,MAAM,CAAC;IACjC,MAAM,CAAC,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,SAAS,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CACvE,CAAC;AAEF;;;;;;;GAOG;AACH,wBAAsB,oBAAoB,CAAC,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,yBAAyB,GAAG,OAAO,CAAC,0BAA0B,CAAC,CA6G/H"}
|