@xyo-network/archivist 2.75.0 → 2.75.2

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.
Files changed (42) hide show
  1. package/dist/browser/AbstractArchivingModule.d.cts +14 -0
  2. package/dist/browser/AbstractArchivingModule.d.cts.map +1 -0
  3. package/dist/browser/AbstractArchivingModule.js +2 -4
  4. package/dist/browser/AbstractArchivingModule.js.map +1 -1
  5. package/dist/browser/CookieArchivist.d.cts +32 -0
  6. package/dist/browser/CookieArchivist.d.cts.map +1 -0
  7. package/dist/browser/CookieArchivist.js +3 -5
  8. package/dist/browser/CookieArchivist.js.map +1 -1
  9. package/dist/browser/StorageArchivist.d.cts +39 -0
  10. package/dist/browser/StorageArchivist.d.cts.map +1 -0
  11. package/dist/browser/StorageArchivist.js +3 -5
  12. package/dist/browser/StorageArchivist.js.map +1 -1
  13. package/dist/browser/index.d.cts +8 -0
  14. package/dist/browser/index.d.cts.map +1 -0
  15. package/dist/browser/index.js +3 -295
  16. package/dist/browser/index.js.map +1 -1
  17. package/dist/docs.json +125930 -0
  18. package/dist/node/AbstractArchivingModule.d.cts +14 -0
  19. package/dist/node/AbstractArchivingModule.d.cts.map +1 -0
  20. package/dist/node/AbstractArchivingModule.js +8 -6
  21. package/dist/node/AbstractArchivingModule.js.map +1 -1
  22. package/dist/node/AbstractArchivingModule.mjs +8 -6
  23. package/dist/node/AbstractArchivingModule.mjs.map +1 -1
  24. package/dist/node/CookieArchivist.d.cts +32 -0
  25. package/dist/node/CookieArchivist.d.cts.map +1 -0
  26. package/dist/node/CookieArchivist.js +27 -15
  27. package/dist/node/CookieArchivist.js.map +1 -1
  28. package/dist/node/CookieArchivist.mjs +27 -15
  29. package/dist/node/CookieArchivist.mjs.map +1 -1
  30. package/dist/node/StorageArchivist.d.cts +39 -0
  31. package/dist/node/StorageArchivist.d.cts.map +1 -0
  32. package/dist/node/StorageArchivist.js +36 -20
  33. package/dist/node/StorageArchivist.js.map +1 -1
  34. package/dist/node/StorageArchivist.mjs +36 -20
  35. package/dist/node/StorageArchivist.mjs.map +1 -1
  36. package/dist/node/index.d.cts +8 -0
  37. package/dist/node/index.d.cts.map +1 -0
  38. package/dist/node/index.js +334 -6
  39. package/dist/node/index.js.map +1 -1
  40. package/dist/node/index.mjs +314 -3
  41. package/dist/node/index.mjs.map +1 -1
  42. package/package.json +20 -20
@@ -0,0 +1,14 @@
1
+ import { AccountInstance } from '@xyo-network/account-model';
2
+ import { ArchivistInstance } from '@xyo-network/archivist-model';
3
+ import { AbstractModuleInstance, AnyConfigSchema, Module, ModuleConfig, ModuleEventData, ModuleParams, ModuleQueryResult } from '@xyo-network/module';
4
+ import { ModuleError, Payload, Query } from '@xyo-network/payload-model';
5
+ export type ArchivingModuleConfig<T extends ModuleConfig = ModuleConfig> = ModuleConfig<{
6
+ archivists?: string[];
7
+ schema: string;
8
+ } & T>;
9
+ export declare abstract class AbstractArchivingModule<TParams extends ModuleParams<AnyConfigSchema<ArchivingModuleConfig>> = ModuleParams<AnyConfigSchema<ArchivingModuleConfig>>, TEventData extends ModuleEventData = ModuleEventData> extends AbstractModuleInstance<TParams, TEventData> implements Module<TParams, TEventData> {
10
+ protected bindQueryResult<T extends Query>(query: T, payloads: Payload[], additionalWitnesses?: AccountInstance[], errorPayloads?: ModuleError[]): Promise<ModuleQueryResult>;
11
+ protected resolveArchivists(): Promise<ArchivistInstance[]>;
12
+ protected storeToArchivists(payloads: Payload[]): Promise<Payload[]>;
13
+ }
14
+ //# sourceMappingURL=AbstractArchivingModule.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AbstractArchivingModule.d.ts","sourceRoot":"","sources":["../../src/AbstractArchivingModule.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AAC5D,OAAO,EAAE,iBAAiB,EAAuB,MAAM,8BAA8B,CAAA;AACrF,OAAO,EAAE,sBAAsB,EAAE,eAAe,EAAE,MAAM,EAAE,YAAY,EAAE,eAAe,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AACrJ,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,4BAA4B,CAAA;AAExE,MAAM,MAAM,qBAAqB,CAAC,CAAC,SAAS,YAAY,GAAG,YAAY,IAAI,YAAY,CACrF;IACE,UAAU,CAAC,EAAE,MAAM,EAAE,CAAA;IACrB,MAAM,EAAE,MAAM,CAAA;CACf,GAAG,CAAC,CACN,CAAA;AAED,8BAAsB,uBAAuB,CACzC,OAAO,SAAS,YAAY,CAAC,eAAe,CAAC,qBAAqB,CAAC,CAAC,GAAG,YAAY,CAAC,eAAe,CAAC,qBAAqB,CAAC,CAAC,EAC3H,UAAU,SAAS,eAAe,GAAG,eAAe,CAEtD,SAAQ,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAClD,YAAW,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC;cAEb,eAAe,CAAC,CAAC,SAAS,KAAK,EACtD,KAAK,EAAE,CAAC,EACR,QAAQ,EAAE,OAAO,EAAE,EACnB,mBAAmB,GAAE,eAAe,EAAO,EAC3C,aAAa,GAAE,WAAW,EAAO,GAChC,OAAO,CAAC,iBAAiB,CAAC;cAMb,iBAAiB,IAAI,OAAO,CAAC,iBAAiB,EAAE,CAAC;cAQjD,iBAAiB,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;CAU3E"}
@@ -17,6 +17,8 @@ var __copyProps = (to, from, except, desc) => {
17
17
  return to;
18
18
  };
19
19
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
20
+
21
+ // src/AbstractArchivingModule.ts
20
22
  var AbstractArchivingModule_exports = {};
21
23
  __export(AbstractArchivingModule_exports, {
22
24
  AbstractArchivingModule: () => AbstractArchivingModule
@@ -25,10 +27,7 @@ module.exports = __toCommonJS(AbstractArchivingModule_exports);
25
27
  var import_lodash = require("@xylabs/lodash");
26
28
  var import_archivist_model = require("@xyo-network/archivist-model");
27
29
  var import_module = require("@xyo-network/module");
28
- class AbstractArchivingModule extends import_module.AbstractModuleInstance {
29
- static {
30
- __name(this, "AbstractArchivingModule");
31
- }
30
+ var _AbstractArchivingModule = class _AbstractArchivingModule extends import_module.AbstractModuleInstance {
32
31
  async bindQueryResult(query, payloads, additionalWitnesses = [], errorPayloads = []) {
33
32
  const result = await super.bindQueryResult(query, payloads, additionalWitnesses, errorPayloads);
34
33
  await this.storeToArchivists(result.flat());
@@ -42,10 +41,13 @@ class AbstractArchivingModule extends import_module.AbstractModuleInstance {
42
41
  async storeToArchivists(payloads) {
43
42
  const archivists = await this.resolveArchivists();
44
43
  return (await Promise.all(archivists.map((archivist) => {
45
- return archivist.insert?.(payloads);
44
+ var _a;
45
+ return (_a = archivist.insert) == null ? void 0 : _a.call(archivist, payloads);
46
46
  }))).map(([bw]) => bw);
47
47
  }
48
- }
48
+ };
49
+ __name(_AbstractArchivingModule, "AbstractArchivingModule");
50
+ var AbstractArchivingModule = _AbstractArchivingModule;
49
51
  // Annotate the CommonJS export names for ESM import in node:
50
52
  0 && (module.exports = {
51
53
  AbstractArchivingModule
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/AbstractArchivingModule.ts"],"sourcesContent":["import { compact } from '@xylabs/lodash'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { ArchivistInstance, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { AbstractModuleInstance, AnyConfigSchema, Module, ModuleConfig, ModuleEventData, ModuleParams, ModuleQueryResult } from '@xyo-network/module'\nimport { ModuleError, Payload, Query } from '@xyo-network/payload-model'\n\nexport type ArchivingModuleConfig<T extends ModuleConfig = ModuleConfig> = ModuleConfig<\n {\n archivists?: string[]\n schema: string\n } & T\n>\n// @creatableModule()\nexport abstract class AbstractArchivingModule<\n TParams extends ModuleParams<AnyConfigSchema<ArchivingModuleConfig>> = ModuleParams<AnyConfigSchema<ArchivingModuleConfig>>,\n TEventData extends ModuleEventData = ModuleEventData,\n >\n extends AbstractModuleInstance<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n protected override async bindQueryResult<T extends Query>(\n query: T,\n payloads: Payload[],\n additionalWitnesses: AccountInstance[] = [],\n errorPayloads: ModuleError[] = [],\n ): Promise<ModuleQueryResult> {\n const result = await super.bindQueryResult(query, payloads, additionalWitnesses, errorPayloads)\n await this.storeToArchivists(result.flat())\n return result\n }\n\n protected async resolveArchivists(): Promise<ArchivistInstance[]> {\n return compact(\n (await Promise.all((await this.resolve({ address: this.config.archivists ?? [] })) ?? [])).map((module) =>\n asArchivistInstance(module, () => `Module failed to cast to Archivist [${module.config.name}]`),\n ),\n )\n }\n\n protected async storeToArchivists(payloads: Payload[]): Promise<Payload[]> {\n const archivists = await this.resolveArchivists()\n return (\n await Promise.all(\n archivists.map((archivist) => {\n return archivist.insert?.(payloads)\n }),\n )\n ).map(([bw]) => bw)\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;AAAA;;;;;AAAA,oBAAwB;AAExB,6BAAuD;AACvD,oBAAgI;AAUzH,MAAeA,gCAIZC,qCAAAA;EAjBV,OAiBUA;;;EAGR,MAAyBC,gBACvBC,OACAC,UACAC,sBAAyC,CAAA,GACzCC,gBAA+B,CAAA,GACH;AAC5B,UAAMC,SAAS,MAAM,MAAML,gBAAgBC,OAAOC,UAAUC,qBAAqBC,aAAAA;AACjF,UAAM,KAAKE,kBAAkBD,OAAOE,KAAI,CAAA;AACxC,WAAOF;EACT;EAEA,MAAgBG,oBAAkD;AAChE,eAAOC,wBACJ,MAAMC,QAAQC,IAAK,MAAM,KAAKC,QAAQ;MAAEC,SAAS,KAAKC,OAAOC,cAAc,CAAA;IAAG,CAAA,KAAO,CAAA,CAAE,GAAGC,IAAI,CAACC,gBAC9FC,4CAAoBD,SAAQ,MAAM,uCAAuCA,QAAOH,OAAOK,IAAI,GAAG,CAAA,CAAA;EAGpG;EAEA,MAAgBb,kBAAkBJ,UAAyC;AACzE,UAAMa,aAAa,MAAM,KAAKP,kBAAiB;AAC/C,YACE,MAAME,QAAQC,IACZI,WAAWC,IAAI,CAACI,cAAAA;AACd,aAAOA,UAAUC,SAASnB,QAAAA;IAC5B,CAAA,CAAA,GAEFc,IAAI,CAAC,CAACM,EAAAA,MAAQA,EAAAA;EAClB;AACF;","names":["AbstractArchivingModule","AbstractModuleInstance","bindQueryResult","query","payloads","additionalWitnesses","errorPayloads","result","storeToArchivists","flat","resolveArchivists","compact","Promise","all","resolve","address","config","archivists","map","module","asArchivistInstance","name","archivist","insert","bw"]}
1
+ {"version":3,"sources":["../../src/AbstractArchivingModule.ts"],"sourcesContent":["import { compact } from '@xylabs/lodash'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { ArchivistInstance, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { AbstractModuleInstance, AnyConfigSchema, Module, ModuleConfig, ModuleEventData, ModuleParams, ModuleQueryResult } from '@xyo-network/module'\nimport { ModuleError, Payload, Query } from '@xyo-network/payload-model'\n\nexport type ArchivingModuleConfig<T extends ModuleConfig = ModuleConfig> = ModuleConfig<\n {\n archivists?: string[]\n schema: string\n } & T\n>\n// @creatableModule()\nexport abstract class AbstractArchivingModule<\n TParams extends ModuleParams<AnyConfigSchema<ArchivingModuleConfig>> = ModuleParams<AnyConfigSchema<ArchivingModuleConfig>>,\n TEventData extends ModuleEventData = ModuleEventData,\n >\n extends AbstractModuleInstance<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n protected override async bindQueryResult<T extends Query>(\n query: T,\n payloads: Payload[],\n additionalWitnesses: AccountInstance[] = [],\n errorPayloads: ModuleError[] = [],\n ): Promise<ModuleQueryResult> {\n const result = await super.bindQueryResult(query, payloads, additionalWitnesses, errorPayloads)\n await this.storeToArchivists(result.flat())\n return result\n }\n\n protected async resolveArchivists(): Promise<ArchivistInstance[]> {\n return compact(\n (await Promise.all((await this.resolve({ address: this.config.archivists ?? [] })) ?? [])).map((module) =>\n asArchivistInstance(module, () => `Module failed to cast to Archivist [${module.config.name}]`),\n ),\n )\n }\n\n protected async storeToArchivists(payloads: Payload[]): Promise<Payload[]> {\n const archivists = await this.resolveArchivists()\n return (\n await Promise.all(\n archivists.map((archivist) => {\n return archivist.insert?.(payloads)\n }),\n )\n ).map(([bw]) => bw)\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;;;;oBAAwB;AAExB,6BAAuD;AACvD,oBAAgI;AAUzH,IAAeA,2BAAf,MAAeA,iCAIZC,qCAAAA;EAGR,MAAyBC,gBACvBC,OACAC,UACAC,sBAAyC,CAAA,GACzCC,gBAA+B,CAAA,GACH;AAC5B,UAAMC,SAAS,MAAM,MAAML,gBAAgBC,OAAOC,UAAUC,qBAAqBC,aAAAA;AACjF,UAAM,KAAKE,kBAAkBD,OAAOE,KAAI,CAAA;AACxC,WAAOF;EACT;EAEA,MAAgBG,oBAAkD;AAChE,eAAOC,wBACJ,MAAMC,QAAQC,IAAK,MAAM,KAAKC,QAAQ;MAAEC,SAAS,KAAKC,OAAOC,cAAc,CAAA;IAAG,CAAA,KAAO,CAAA,CAAE,GAAGC,IAAI,CAACC,gBAC9FC,4CAAoBD,SAAQ,MAAM,uCAAuCA,QAAOH,OAAOK,IAAI,GAAG,CAAA,CAAA;EAGpG;EAEA,MAAgBb,kBAAkBJ,UAAyC;AACzE,UAAMa,aAAa,MAAM,KAAKP,kBAAiB;AAC/C,YACE,MAAME,QAAQC,IACZI,WAAWC,IAAI,CAACI,cAAAA;AA3CxB;AA4CU,cAAOA,eAAUC,WAAVD,mCAAmBlB;IAC5B,CAAA,CAAA,GAEFc,IAAI,CAAC,CAACM,EAAAA,MAAQA,EAAAA;EAClB;AACF;AAhCUvB;AAJH,IAAeD,0BAAf;","names":["AbstractArchivingModule","AbstractModuleInstance","bindQueryResult","query","payloads","additionalWitnesses","errorPayloads","result","storeToArchivists","flat","resolveArchivists","compact","Promise","all","resolve","address","config","archivists","map","module","asArchivistInstance","name","archivist","insert","bw"]}
@@ -1,12 +1,11 @@
1
1
  var __defProp = Object.defineProperty;
2
2
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+
4
+ // src/AbstractArchivingModule.ts
3
5
  import { compact } from "@xylabs/lodash";
4
6
  import { asArchivistInstance } from "@xyo-network/archivist-model";
5
7
  import { AbstractModuleInstance } from "@xyo-network/module";
6
- class AbstractArchivingModule extends AbstractModuleInstance {
7
- static {
8
- __name(this, "AbstractArchivingModule");
9
- }
8
+ var _AbstractArchivingModule = class _AbstractArchivingModule extends AbstractModuleInstance {
10
9
  async bindQueryResult(query, payloads, additionalWitnesses = [], errorPayloads = []) {
11
10
  const result = await super.bindQueryResult(query, payloads, additionalWitnesses, errorPayloads);
12
11
  await this.storeToArchivists(result.flat());
@@ -20,10 +19,13 @@ class AbstractArchivingModule extends AbstractModuleInstance {
20
19
  async storeToArchivists(payloads) {
21
20
  const archivists = await this.resolveArchivists();
22
21
  return (await Promise.all(archivists.map((archivist) => {
23
- return archivist.insert?.(payloads);
22
+ var _a;
23
+ return (_a = archivist.insert) == null ? void 0 : _a.call(archivist, payloads);
24
24
  }))).map(([bw]) => bw);
25
25
  }
26
- }
26
+ };
27
+ __name(_AbstractArchivingModule, "AbstractArchivingModule");
28
+ var AbstractArchivingModule = _AbstractArchivingModule;
27
29
  export {
28
30
  AbstractArchivingModule
29
31
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/AbstractArchivingModule.ts"],"sourcesContent":["import { compact } from '@xylabs/lodash'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { ArchivistInstance, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { AbstractModuleInstance, AnyConfigSchema, Module, ModuleConfig, ModuleEventData, ModuleParams, ModuleQueryResult } from '@xyo-network/module'\nimport { ModuleError, Payload, Query } from '@xyo-network/payload-model'\n\nexport type ArchivingModuleConfig<T extends ModuleConfig = ModuleConfig> = ModuleConfig<\n {\n archivists?: string[]\n schema: string\n } & T\n>\n// @creatableModule()\nexport abstract class AbstractArchivingModule<\n TParams extends ModuleParams<AnyConfigSchema<ArchivingModuleConfig>> = ModuleParams<AnyConfigSchema<ArchivingModuleConfig>>,\n TEventData extends ModuleEventData = ModuleEventData,\n >\n extends AbstractModuleInstance<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n protected override async bindQueryResult<T extends Query>(\n query: T,\n payloads: Payload[],\n additionalWitnesses: AccountInstance[] = [],\n errorPayloads: ModuleError[] = [],\n ): Promise<ModuleQueryResult> {\n const result = await super.bindQueryResult(query, payloads, additionalWitnesses, errorPayloads)\n await this.storeToArchivists(result.flat())\n return result\n }\n\n protected async resolveArchivists(): Promise<ArchivistInstance[]> {\n return compact(\n (await Promise.all((await this.resolve({ address: this.config.archivists ?? [] })) ?? [])).map((module) =>\n asArchivistInstance(module, () => `Module failed to cast to Archivist [${module.config.name}]`),\n ),\n )\n }\n\n protected async storeToArchivists(payloads: Payload[]): Promise<Payload[]> {\n const archivists = await this.resolveArchivists()\n return (\n await Promise.all(\n archivists.map((archivist) => {\n return archivist.insert?.(payloads)\n }),\n )\n ).map(([bw]) => bw)\n }\n}\n"],"mappings":";;AAAA,SAASA,eAAe;AAExB,SAA4BC,2BAA2B;AACvD,SAASC,8BAAuH;AAUzH,MAAeC,gCAIZD,uBAAAA;EAjBV,OAiBUA;;;EAGR,MAAyBE,gBACvBC,OACAC,UACAC,sBAAyC,CAAA,GACzCC,gBAA+B,CAAA,GACH;AAC5B,UAAMC,SAAS,MAAM,MAAML,gBAAgBC,OAAOC,UAAUC,qBAAqBC,aAAAA;AACjF,UAAM,KAAKE,kBAAkBD,OAAOE,KAAI,CAAA;AACxC,WAAOF;EACT;EAEA,MAAgBG,oBAAkD;AAChE,WAAOZ,SACJ,MAAMa,QAAQC,IAAK,MAAM,KAAKC,QAAQ;MAAEC,SAAS,KAAKC,OAAOC,cAAc,CAAA;IAAG,CAAA,KAAO,CAAA,CAAE,GAAGC,IAAI,CAACC,WAC9FnB,oBAAoBmB,QAAQ,MAAM,uCAAuCA,OAAOH,OAAOI,IAAI,GAAG,CAAA,CAAA;EAGpG;EAEA,MAAgBX,kBAAkBJ,UAAyC;AACzE,UAAMY,aAAa,MAAM,KAAKN,kBAAiB;AAC/C,YACE,MAAMC,QAAQC,IACZI,WAAWC,IAAI,CAACG,cAAAA;AACd,aAAOA,UAAUC,SAASjB,QAAAA;IAC5B,CAAA,CAAA,GAEFa,IAAI,CAAC,CAACK,EAAAA,MAAQA,EAAAA;EAClB;AACF;","names":["compact","asArchivistInstance","AbstractModuleInstance","AbstractArchivingModule","bindQueryResult","query","payloads","additionalWitnesses","errorPayloads","result","storeToArchivists","flat","resolveArchivists","Promise","all","resolve","address","config","archivists","map","module","name","archivist","insert","bw"]}
1
+ {"version":3,"sources":["../../src/AbstractArchivingModule.ts"],"sourcesContent":["import { compact } from '@xylabs/lodash'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { ArchivistInstance, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { AbstractModuleInstance, AnyConfigSchema, Module, ModuleConfig, ModuleEventData, ModuleParams, ModuleQueryResult } from '@xyo-network/module'\nimport { ModuleError, Payload, Query } from '@xyo-network/payload-model'\n\nexport type ArchivingModuleConfig<T extends ModuleConfig = ModuleConfig> = ModuleConfig<\n {\n archivists?: string[]\n schema: string\n } & T\n>\n// @creatableModule()\nexport abstract class AbstractArchivingModule<\n TParams extends ModuleParams<AnyConfigSchema<ArchivingModuleConfig>> = ModuleParams<AnyConfigSchema<ArchivingModuleConfig>>,\n TEventData extends ModuleEventData = ModuleEventData,\n >\n extends AbstractModuleInstance<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n protected override async bindQueryResult<T extends Query>(\n query: T,\n payloads: Payload[],\n additionalWitnesses: AccountInstance[] = [],\n errorPayloads: ModuleError[] = [],\n ): Promise<ModuleQueryResult> {\n const result = await super.bindQueryResult(query, payloads, additionalWitnesses, errorPayloads)\n await this.storeToArchivists(result.flat())\n return result\n }\n\n protected async resolveArchivists(): Promise<ArchivistInstance[]> {\n return compact(\n (await Promise.all((await this.resolve({ address: this.config.archivists ?? [] })) ?? [])).map((module) =>\n asArchivistInstance(module, () => `Module failed to cast to Archivist [${module.config.name}]`),\n ),\n )\n }\n\n protected async storeToArchivists(payloads: Payload[]): Promise<Payload[]> {\n const archivists = await this.resolveArchivists()\n return (\n await Promise.all(\n archivists.map((archivist) => {\n return archivist.insert?.(payloads)\n }),\n )\n ).map(([bw]) => bw)\n }\n}\n"],"mappings":";;;;AAAA,SAASA,eAAe;AAExB,SAA4BC,2BAA2B;AACvD,SAASC,8BAAuH;AAUzH,IAAeC,2BAAf,MAAeA,iCAIZC,uBAAAA;EAGR,MAAyBC,gBACvBC,OACAC,UACAC,sBAAyC,CAAA,GACzCC,gBAA+B,CAAA,GACH;AAC5B,UAAMC,SAAS,MAAM,MAAML,gBAAgBC,OAAOC,UAAUC,qBAAqBC,aAAAA;AACjF,UAAM,KAAKE,kBAAkBD,OAAOE,KAAI,CAAA;AACxC,WAAOF;EACT;EAEA,MAAgBG,oBAAkD;AAChE,WAAOC,SACJ,MAAMC,QAAQC,IAAK,MAAM,KAAKC,QAAQ;MAAEC,SAAS,KAAKC,OAAOC,cAAc,CAAA;IAAG,CAAA,KAAO,CAAA,CAAE,GAAGC,IAAI,CAACC,WAC9FC,oBAAoBD,QAAQ,MAAM,uCAAuCA,OAAOH,OAAOK,IAAI,GAAG,CAAA,CAAA;EAGpG;EAEA,MAAgBb,kBAAkBJ,UAAyC;AACzE,UAAMa,aAAa,MAAM,KAAKP,kBAAiB;AAC/C,YACE,MAAME,QAAQC,IACZI,WAAWC,IAAI,CAACI,cAAAA;AA3CxB;AA4CU,cAAOA,eAAUC,WAAVD,mCAAmBlB;IAC5B,CAAA,CAAA,GAEFc,IAAI,CAAC,CAACM,EAAAA,MAAQA,EAAAA;EAClB;AACF;AAhCUvB;AAJH,IAAeD,0BAAf;","names":["compact","asArchivistInstance","AbstractModuleInstance","AbstractArchivingModule","AbstractModuleInstance","bindQueryResult","query","payloads","additionalWitnesses","errorPayloads","result","storeToArchivists","flat","resolveArchivists","compact","Promise","all","resolve","address","config","archivists","map","module","asArchivistInstance","name","archivist","insert","bw"]}
@@ -0,0 +1,32 @@
1
+ import { AbstractArchivist } from '@xyo-network/archivist-abstract';
2
+ import { ArchivistConfig, ArchivistModuleEventData, ArchivistParams } from '@xyo-network/archivist-model';
3
+ import { BoundWitness } from '@xyo-network/boundwitness-model';
4
+ import { AnyConfigSchema } from '@xyo-network/module';
5
+ import { Payload } from '@xyo-network/payload-model';
6
+ import { Promisable, PromisableArray } from '@xyo-network/promise';
7
+ export type CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config';
8
+ export declare const CookieArchivistConfigSchema: CookieArchivistConfigSchema;
9
+ export type CookieArchivistConfig = ArchivistConfig<{
10
+ domain?: string;
11
+ maxEntries?: number;
12
+ maxEntrySize?: number;
13
+ namespace?: string;
14
+ schema: CookieArchivistConfigSchema;
15
+ }>;
16
+ export type CookieArchivistParams = ArchivistParams<AnyConfigSchema<CookieArchivistConfig>>;
17
+ export declare class CookieArchivist<TParams extends CookieArchivistParams, TEventData extends ArchivistModuleEventData = ArchivistModuleEventData> extends AbstractArchivist<TParams, TEventData> {
18
+ static configSchemas: "network.xyo.archivist.cookie.config"[];
19
+ get domain(): string | undefined;
20
+ get maxEntries(): number;
21
+ get maxEntrySize(): number;
22
+ get namespace(): string;
23
+ get queries(): string[];
24
+ protected allHandler(): PromisableArray<Payload>;
25
+ protected clearHandler(): void | Promise<void>;
26
+ protected commitHandler(): Promise<BoundWitness[]>;
27
+ protected deleteHandler(hashes: string[]): Promise<string[]>;
28
+ protected getHandler(hashes: string[]): Promisable<Payload[]>;
29
+ protected insertHandler(payloads: Payload[]): Promise<Payload[]>;
30
+ private keyFromHash;
31
+ }
32
+ //# sourceMappingURL=CookieArchivist.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,EAIL,eAAe,EAIf,wBAAwB,EACxB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAE9D,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAGlE,MAAM,MAAM,2BAA2B,GAAG,qCAAqC,CAAA;AAC/E,eAAO,MAAM,2BAA2B,EAAE,2BAAmE,CAAA;AAE7G,MAAM,MAAM,qBAAqB,GAAG,eAAe,CAAC;IAClD,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,2BAA2B,CAAA;CACpC,CAAC,CAAA;AAEF,MAAM,MAAM,qBAAqB,GAAG,eAAe,CAAC,eAAe,CAAC,qBAAqB,CAAC,CAAC,CAAA;AAE3F,qBAAa,eAAe,CAC1B,OAAO,SAAS,qBAAqB,EACrC,UAAU,SAAS,wBAAwB,GAAG,wBAAwB,CACtE,SAAQ,iBAAiB,CAAC,OAAO,EAAE,UAAU,CAAC;IAC9C,OAAgB,aAAa,0CAAgC;IAE7D,IAAI,MAAM,uBAET;IAED,IAAI,UAAU,WAGb;IAED,IAAI,YAAY,WAGf;IAED,IAAI,SAAS,WAEZ;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAS/B;cAEkB,UAAU,IAAI,eAAe,CAAC,OAAO,CAAC;cAWtC,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAa9B,aAAa,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;cAuBxC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;cAexD,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;cAS7C,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAmB/E,OAAO,CAAC,WAAW;CAGpB"}
@@ -5,6 +5,7 @@ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
5
  var __getOwnPropNames = Object.getOwnPropertyNames;
6
6
  var __getProtoOf = Object.getPrototypeOf;
7
7
  var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
9
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
9
10
  var __export = (target, all) => {
10
11
  for (var name in all)
@@ -27,6 +28,12 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
27
28
  mod
28
29
  ));
29
30
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
31
+ var __publicField = (obj, key, value) => {
32
+ __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
33
+ return value;
34
+ };
35
+
36
+ // src/CookieArchivist.ts
30
37
  var CookieArchivist_exports = {};
31
38
  __export(CookieArchivist_exports, {
32
39
  CookieArchivist: () => CookieArchivist,
@@ -41,25 +48,23 @@ var import_archivist_model = require("@xyo-network/archivist-model");
41
48
  var import_core = require("@xyo-network/core");
42
49
  var import_payload_wrapper = require("@xyo-network/payload-wrapper");
43
50
  var import_js_cookie = __toESM(require("js-cookie"));
44
- const CookieArchivistConfigSchema = "network.xyo.archivist.cookie.config";
45
- class CookieArchivist extends import_archivist_abstract.AbstractArchivist {
46
- static {
47
- __name(this, "CookieArchivist");
48
- }
49
- static configSchemas = [
50
- CookieArchivistConfigSchema
51
- ];
51
+ var CookieArchivistConfigSchema = "network.xyo.archivist.cookie.config";
52
+ var _CookieArchivist = class _CookieArchivist extends import_archivist_abstract.AbstractArchivist {
52
53
  get domain() {
53
- return this.config?.domain;
54
+ var _a;
55
+ return (_a = this.config) == null ? void 0 : _a.domain;
54
56
  }
55
57
  get maxEntries() {
56
- return this.config?.maxEntries ?? 60;
58
+ var _a;
59
+ return ((_a = this.config) == null ? void 0 : _a.maxEntries) ?? 60;
57
60
  }
58
61
  get maxEntrySize() {
59
- return this.config?.maxEntrySize ?? 4e3;
62
+ var _a;
63
+ return ((_a = this.config) == null ? void 0 : _a.maxEntrySize) ?? 4e3;
60
64
  }
61
65
  get namespace() {
62
- return this.config?.namespace ?? "xyoarch";
66
+ var _a;
67
+ return ((_a = this.config) == null ? void 0 : _a.namespace) ?? "xyoarch";
63
68
  }
64
69
  get queries() {
65
70
  return [
@@ -92,15 +97,17 @@ class CookieArchivist extends import_archivist_abstract.AbstractArchivist {
92
97
  }
93
98
  }
94
99
  async commitHandler() {
100
+ var _a;
95
101
  try {
96
102
  const payloads = await this.all();
97
103
  (0, import_assert.assertEx)(payloads.length > 0, "Nothing to commit");
98
- const settled = await Promise.allSettled((0, import_lodash.compact)(Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {
104
+ const settled = await Promise.allSettled((0, import_lodash.compact)((_a = Object.values((await this.parents()).commit ?? [])) == null ? void 0 : _a.map(async (parent) => {
105
+ var _a2;
99
106
  const queryPayload = {
100
107
  schema: import_archivist_model.ArchivistInsertQuerySchema
101
108
  };
102
109
  const query = await this.bindQuery(queryPayload, payloads);
103
- return (await parent?.query(query[0], query[1]))?.[0];
110
+ return (_a2 = await (parent == null ? void 0 : parent.query(query[0], query[1]))) == null ? void 0 : _a2[0];
104
111
  })));
105
112
  await this.clear();
106
113
  return (0, import_lodash.compact)(settled.filter(import_promise.fulfilled).map((result) => result.value));
@@ -148,7 +155,12 @@ class CookieArchivist extends import_archivist_abstract.AbstractArchivist {
148
155
  keyFromHash(hash) {
149
156
  return `${this.namespace}-${hash}`;
150
157
  }
151
- }
158
+ };
159
+ __name(_CookieArchivist, "CookieArchivist");
160
+ __publicField(_CookieArchivist, "configSchemas", [
161
+ CookieArchivistConfigSchema
162
+ ]);
163
+ var CookieArchivist = _CookieArchivist;
152
164
  // Annotate the CommonJS export names for ESM import in node:
153
165
  0 && (module.exports = {
154
166
  CookieArchivist,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/CookieArchivist.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { compact } from '@xylabs/lodash'\nimport { fulfilled } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuery,\n ArchivistInsertQuerySchema,\n ArchivistModuleEventData,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { AnyConfigSchema } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\nimport { Promisable, PromisableArray } from '@xyo-network/promise'\nimport Cookies from 'js-cookie'\n\nexport type CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\nexport const CookieArchivistConfigSchema: CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\n\nexport type CookieArchivistConfig = ArchivistConfig<{\n domain?: string\n maxEntries?: number\n maxEntrySize?: number\n namespace?: string\n schema: CookieArchivistConfigSchema\n}>\n\nexport type CookieArchivistParams = ArchivistParams<AnyConfigSchema<CookieArchivistConfig>>\n\nexport class CookieArchivist<\n TParams extends CookieArchivistParams,\n TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,\n> extends AbstractArchivist<TParams, TEventData> {\n static override configSchemas = [CookieArchivistConfigSchema]\n\n get domain() {\n return this.config?.domain\n }\n\n get maxEntries() {\n //all browsers support at least 60 cookies\n return this.config?.maxEntries ?? 60\n }\n\n get maxEntrySize() {\n //all browsers support at least 4000 length per cookie\n return this.config?.maxEntrySize ?? 4000\n }\n\n get namespace() {\n return this.config?.namespace ?? 'xyoarch'\n }\n\n override get queries(): string[] {\n return [\n ArchivistAllQuerySchema,\n ArchivistDeleteQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistInsertQuerySchema,\n ArchivistCommitQuerySchema,\n ...super.queries,\n ]\n }\n\n protected override allHandler(): PromisableArray<Payload> {\n try {\n return Object.entries(Cookies.get())\n .filter(([key]) => key.startsWith(`${this.namespace}-`))\n .map(([, value]) => JSON.parse(value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override clearHandler(): void | Promise<void> {\n try {\n Object.entries(Cookies.get()).map(([key]) => {\n if (key.startsWith(`${this.namespace}-`)) {\n Cookies.remove(key)\n }\n })\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async commitHandler(): Promise<BoundWitness[]> {\n try {\n const payloads = await this.all()\n assertEx(payloads.length > 0, 'Nothing to commit')\n const settled = await Promise.allSettled(\n compact(\n Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {\n const queryPayload: ArchivistInsertQuery = {\n schema: ArchivistInsertQuerySchema,\n }\n const query = await this.bindQuery(queryPayload, payloads)\n return (await parent?.query(query[0], query[1]))?.[0]\n }),\n ),\n )\n await this.clear()\n return compact(settled.filter(fulfilled).map((result) => result.value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async deleteHandler(hashes: string[]): Promise<string[]> {\n const payloadPairs: [string, Payload][] = await Promise.all(\n (await this.get(hashes)).map<Promise<[string, Payload]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]),\n )\n const deletedPairs: [string, Payload][] = compact(\n await Promise.all(\n payloadPairs.map<[string, Payload] | undefined>(([hash, payload]) => {\n Cookies.remove(hash)\n return [hash, payload]\n }),\n ),\n )\n return deletedPairs.map(([hash]) => hash)\n }\n\n protected override getHandler(hashes: string[]): Promisable<Payload[]> {\n return compact(\n hashes.map((hash) => {\n const cookieString = Cookies.get(this.keyFromHash(hash))\n return cookieString ? JSON.parse(cookieString) : undefined\n }),\n )\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {\n try {\n const resultPayloads: Payload[] = await Promise.all(\n payloads.map(async (payload) => {\n const wrapper = PayloadWrapper.wrap(payload)\n const key = this.keyFromHash(await wrapper.hashAsync())\n const value = JSON.stringify(wrapper.payload())\n assertEx(value.length < this.maxEntrySize, `Payload too large [${wrapper.hashAsync()}, ${value.length}]`)\n Cookies.set(key, JSON.stringify(wrapper.payload()))\n return wrapper.payload()\n }),\n )\n return resultPayloads\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n private keyFromHash(hash: string) {\n return `${this.namespace}-${hash}`\n }\n}\n"],"mappings":"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","names":["CookieArchivistConfigSchema","CookieArchivist","AbstractArchivist","configSchemas","domain","config","maxEntries","maxEntrySize","namespace","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","allHandler","Object","entries","Cookies","get","filter","key","startsWith","map","value","JSON","parse","ex","console","error","stringify","clearHandler","remove","commitHandler","payloads","all","assertEx","length","settled","Promise","allSettled","compact","values","parents","commit","parent","queryPayload","schema","query","bindQuery","clear","fulfilled","result","deleteHandler","hashes","payloadPairs","payload","PayloadHasher","hashAsync","deletedPairs","hash","getHandler","cookieString","keyFromHash","undefined","insertHandler","resultPayloads","wrapper","PayloadWrapper","wrap","set"]}
1
+ {"version":3,"sources":["../../src/CookieArchivist.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { compact } from '@xylabs/lodash'\nimport { fulfilled } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuery,\n ArchivistInsertQuerySchema,\n ArchivistModuleEventData,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { AnyConfigSchema } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\nimport { Promisable, PromisableArray } from '@xyo-network/promise'\nimport Cookies from 'js-cookie'\n\nexport type CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\nexport const CookieArchivistConfigSchema: CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\n\nexport type CookieArchivistConfig = ArchivistConfig<{\n domain?: string\n maxEntries?: number\n maxEntrySize?: number\n namespace?: string\n schema: CookieArchivistConfigSchema\n}>\n\nexport type CookieArchivistParams = ArchivistParams<AnyConfigSchema<CookieArchivistConfig>>\n\nexport class CookieArchivist<\n TParams extends CookieArchivistParams,\n TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,\n> extends AbstractArchivist<TParams, TEventData> {\n static override configSchemas = [CookieArchivistConfigSchema]\n\n get domain() {\n return this.config?.domain\n }\n\n get maxEntries() {\n //all browsers support at least 60 cookies\n return this.config?.maxEntries ?? 60\n }\n\n get maxEntrySize() {\n //all browsers support at least 4000 length per cookie\n return this.config?.maxEntrySize ?? 4000\n }\n\n get namespace() {\n return this.config?.namespace ?? 'xyoarch'\n }\n\n override get queries(): string[] {\n return [\n ArchivistAllQuerySchema,\n ArchivistDeleteQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistInsertQuerySchema,\n ArchivistCommitQuerySchema,\n ...super.queries,\n ]\n }\n\n protected override allHandler(): PromisableArray<Payload> {\n try {\n return Object.entries(Cookies.get())\n .filter(([key]) => key.startsWith(`${this.namespace}-`))\n .map(([, value]) => JSON.parse(value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override clearHandler(): void | Promise<void> {\n try {\n Object.entries(Cookies.get()).map(([key]) => {\n if (key.startsWith(`${this.namespace}-`)) {\n Cookies.remove(key)\n }\n })\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async commitHandler(): Promise<BoundWitness[]> {\n try {\n const payloads = await this.all()\n assertEx(payloads.length > 0, 'Nothing to commit')\n const settled = await Promise.allSettled(\n compact(\n Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {\n const queryPayload: ArchivistInsertQuery = {\n schema: ArchivistInsertQuerySchema,\n }\n const query = await this.bindQuery(queryPayload, payloads)\n return (await parent?.query(query[0], query[1]))?.[0]\n }),\n ),\n )\n await this.clear()\n return compact(settled.filter(fulfilled).map((result) => result.value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async deleteHandler(hashes: string[]): Promise<string[]> {\n const payloadPairs: [string, Payload][] = await Promise.all(\n (await this.get(hashes)).map<Promise<[string, Payload]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]),\n )\n const deletedPairs: [string, Payload][] = compact(\n await Promise.all(\n payloadPairs.map<[string, Payload] | undefined>(([hash, payload]) => {\n Cookies.remove(hash)\n return [hash, payload]\n }),\n ),\n )\n return deletedPairs.map(([hash]) => hash)\n }\n\n protected override getHandler(hashes: string[]): Promisable<Payload[]> {\n return compact(\n hashes.map((hash) => {\n const cookieString = Cookies.get(this.keyFromHash(hash))\n return cookieString ? JSON.parse(cookieString) : undefined\n }),\n )\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {\n try {\n const resultPayloads: Payload[] = await Promise.all(\n payloads.map(async (payload) => {\n const wrapper = PayloadWrapper.wrap(payload)\n const key = this.keyFromHash(await wrapper.hashAsync())\n const value = JSON.stringify(wrapper.payload())\n assertEx(value.length < this.maxEntrySize, `Payload too large [${wrapper.hashAsync()}, ${value.length}]`)\n Cookies.set(key, JSON.stringify(wrapper.payload()))\n return wrapper.payload()\n }),\n )\n return resultPayloads\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n private keyFromHash(hash: string) {\n return `${this.namespace}-${hash}`\n }\n}\n"],"mappings":"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","names":["CookieArchivistConfigSchema","CookieArchivist","AbstractArchivist","domain","config","maxEntries","maxEntrySize","namespace","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","allHandler","Object","entries","Cookies","get","filter","key","startsWith","map","value","JSON","parse","ex","console","error","stringify","clearHandler","remove","commitHandler","payloads","all","assertEx","length","settled","Promise","allSettled","compact","values","parents","commit","parent","_a","queryPayload","schema","query","bindQuery","clear","fulfilled","result","deleteHandler","hashes","payloadPairs","payload","PayloadHasher","hashAsync","deletedPairs","hash","getHandler","cookieString","keyFromHash","undefined","insertHandler","resultPayloads","wrapper","PayloadWrapper","wrap","set","configSchemas"]}
@@ -1,5 +1,12 @@
1
1
  var __defProp = Object.defineProperty;
2
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
2
3
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
4
+ var __publicField = (obj, key, value) => {
5
+ __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
6
+ return value;
7
+ };
8
+
9
+ // src/CookieArchivist.ts
3
10
  import { assertEx } from "@xylabs/assert";
4
11
  import { compact } from "@xylabs/lodash";
5
12
  import { fulfilled } from "@xylabs/promise";
@@ -8,25 +15,23 @@ import { ArchivistAllQuerySchema, ArchivistClearQuerySchema, ArchivistCommitQuer
8
15
  import { PayloadHasher } from "@xyo-network/core";
9
16
  import { PayloadWrapper } from "@xyo-network/payload-wrapper";
10
17
  import Cookies from "js-cookie";
11
- const CookieArchivistConfigSchema = "network.xyo.archivist.cookie.config";
12
- class CookieArchivist extends AbstractArchivist {
13
- static {
14
- __name(this, "CookieArchivist");
15
- }
16
- static configSchemas = [
17
- CookieArchivistConfigSchema
18
- ];
18
+ var CookieArchivistConfigSchema = "network.xyo.archivist.cookie.config";
19
+ var _CookieArchivist = class _CookieArchivist extends AbstractArchivist {
19
20
  get domain() {
20
- return this.config?.domain;
21
+ var _a;
22
+ return (_a = this.config) == null ? void 0 : _a.domain;
21
23
  }
22
24
  get maxEntries() {
23
- return this.config?.maxEntries ?? 60;
25
+ var _a;
26
+ return ((_a = this.config) == null ? void 0 : _a.maxEntries) ?? 60;
24
27
  }
25
28
  get maxEntrySize() {
26
- return this.config?.maxEntrySize ?? 4e3;
29
+ var _a;
30
+ return ((_a = this.config) == null ? void 0 : _a.maxEntrySize) ?? 4e3;
27
31
  }
28
32
  get namespace() {
29
- return this.config?.namespace ?? "xyoarch";
33
+ var _a;
34
+ return ((_a = this.config) == null ? void 0 : _a.namespace) ?? "xyoarch";
30
35
  }
31
36
  get queries() {
32
37
  return [
@@ -59,15 +64,17 @@ class CookieArchivist extends AbstractArchivist {
59
64
  }
60
65
  }
61
66
  async commitHandler() {
67
+ var _a;
62
68
  try {
63
69
  const payloads = await this.all();
64
70
  assertEx(payloads.length > 0, "Nothing to commit");
65
- const settled = await Promise.allSettled(compact(Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {
71
+ const settled = await Promise.allSettled(compact((_a = Object.values((await this.parents()).commit ?? [])) == null ? void 0 : _a.map(async (parent) => {
72
+ var _a2;
66
73
  const queryPayload = {
67
74
  schema: ArchivistInsertQuerySchema
68
75
  };
69
76
  const query = await this.bindQuery(queryPayload, payloads);
70
- return (await parent?.query(query[0], query[1]))?.[0];
77
+ return (_a2 = await (parent == null ? void 0 : parent.query(query[0], query[1]))) == null ? void 0 : _a2[0];
71
78
  })));
72
79
  await this.clear();
73
80
  return compact(settled.filter(fulfilled).map((result) => result.value));
@@ -115,7 +122,12 @@ class CookieArchivist extends AbstractArchivist {
115
122
  keyFromHash(hash) {
116
123
  return `${this.namespace}-${hash}`;
117
124
  }
118
- }
125
+ };
126
+ __name(_CookieArchivist, "CookieArchivist");
127
+ __publicField(_CookieArchivist, "configSchemas", [
128
+ CookieArchivistConfigSchema
129
+ ]);
130
+ var CookieArchivist = _CookieArchivist;
119
131
  export {
120
132
  CookieArchivist,
121
133
  CookieArchivistConfigSchema
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/CookieArchivist.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { compact } from '@xylabs/lodash'\nimport { fulfilled } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuery,\n ArchivistInsertQuerySchema,\n ArchivistModuleEventData,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { AnyConfigSchema } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\nimport { Promisable, PromisableArray } from '@xyo-network/promise'\nimport Cookies from 'js-cookie'\n\nexport type CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\nexport const CookieArchivistConfigSchema: CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\n\nexport type CookieArchivistConfig = ArchivistConfig<{\n domain?: string\n maxEntries?: number\n maxEntrySize?: number\n namespace?: string\n schema: CookieArchivistConfigSchema\n}>\n\nexport type CookieArchivistParams = ArchivistParams<AnyConfigSchema<CookieArchivistConfig>>\n\nexport class CookieArchivist<\n TParams extends CookieArchivistParams,\n TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,\n> extends AbstractArchivist<TParams, TEventData> {\n static override configSchemas = [CookieArchivistConfigSchema]\n\n get domain() {\n return this.config?.domain\n }\n\n get maxEntries() {\n //all browsers support at least 60 cookies\n return this.config?.maxEntries ?? 60\n }\n\n get maxEntrySize() {\n //all browsers support at least 4000 length per cookie\n return this.config?.maxEntrySize ?? 4000\n }\n\n get namespace() {\n return this.config?.namespace ?? 'xyoarch'\n }\n\n override get queries(): string[] {\n return [\n ArchivistAllQuerySchema,\n ArchivistDeleteQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistInsertQuerySchema,\n ArchivistCommitQuerySchema,\n ...super.queries,\n ]\n }\n\n protected override allHandler(): PromisableArray<Payload> {\n try {\n return Object.entries(Cookies.get())\n .filter(([key]) => key.startsWith(`${this.namespace}-`))\n .map(([, value]) => JSON.parse(value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override clearHandler(): void | Promise<void> {\n try {\n Object.entries(Cookies.get()).map(([key]) => {\n if (key.startsWith(`${this.namespace}-`)) {\n Cookies.remove(key)\n }\n })\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async commitHandler(): Promise<BoundWitness[]> {\n try {\n const payloads = await this.all()\n assertEx(payloads.length > 0, 'Nothing to commit')\n const settled = await Promise.allSettled(\n compact(\n Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {\n const queryPayload: ArchivistInsertQuery = {\n schema: ArchivistInsertQuerySchema,\n }\n const query = await this.bindQuery(queryPayload, payloads)\n return (await parent?.query(query[0], query[1]))?.[0]\n }),\n ),\n )\n await this.clear()\n return compact(settled.filter(fulfilled).map((result) => result.value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async deleteHandler(hashes: string[]): Promise<string[]> {\n const payloadPairs: [string, Payload][] = await Promise.all(\n (await this.get(hashes)).map<Promise<[string, Payload]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]),\n )\n const deletedPairs: [string, Payload][] = compact(\n await Promise.all(\n payloadPairs.map<[string, Payload] | undefined>(([hash, payload]) => {\n Cookies.remove(hash)\n return [hash, payload]\n }),\n ),\n )\n return deletedPairs.map(([hash]) => hash)\n }\n\n protected override getHandler(hashes: string[]): Promisable<Payload[]> {\n return compact(\n hashes.map((hash) => {\n const cookieString = Cookies.get(this.keyFromHash(hash))\n return cookieString ? JSON.parse(cookieString) : undefined\n }),\n )\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {\n try {\n const resultPayloads: Payload[] = await Promise.all(\n payloads.map(async (payload) => {\n const wrapper = PayloadWrapper.wrap(payload)\n const key = this.keyFromHash(await wrapper.hashAsync())\n const value = JSON.stringify(wrapper.payload())\n assertEx(value.length < this.maxEntrySize, `Payload too large [${wrapper.hashAsync()}, ${value.length}]`)\n Cookies.set(key, JSON.stringify(wrapper.payload()))\n return wrapper.payload()\n }),\n )\n return resultPayloads\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n private keyFromHash(hash: string) {\n return `${this.namespace}-${hash}`\n }\n}\n"],"mappings":"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","names":["assertEx","compact","fulfilled","AbstractArchivist","ArchivistAllQuerySchema","ArchivistClearQuerySchema","ArchivistCommitQuerySchema","ArchivistDeleteQuerySchema","ArchivistInsertQuerySchema","PayloadHasher","PayloadWrapper","Cookies","CookieArchivistConfigSchema","CookieArchivist","configSchemas","domain","config","maxEntries","maxEntrySize","namespace","queries","allHandler","Object","entries","get","filter","key","startsWith","map","value","JSON","parse","ex","console","error","stringify","clearHandler","remove","commitHandler","payloads","all","length","settled","Promise","allSettled","values","parents","commit","parent","queryPayload","schema","query","bindQuery","clear","result","deleteHandler","hashes","payloadPairs","payload","hashAsync","deletedPairs","hash","getHandler","cookieString","keyFromHash","undefined","insertHandler","resultPayloads","wrapper","wrap","set"]}
1
+ {"version":3,"sources":["../../src/CookieArchivist.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { compact } from '@xylabs/lodash'\nimport { fulfilled } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuery,\n ArchivistInsertQuerySchema,\n ArchivistModuleEventData,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { AnyConfigSchema } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\nimport { Promisable, PromisableArray } from '@xyo-network/promise'\nimport Cookies from 'js-cookie'\n\nexport type CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\nexport const CookieArchivistConfigSchema: CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\n\nexport type CookieArchivistConfig = ArchivistConfig<{\n domain?: string\n maxEntries?: number\n maxEntrySize?: number\n namespace?: string\n schema: CookieArchivistConfigSchema\n}>\n\nexport type CookieArchivistParams = ArchivistParams<AnyConfigSchema<CookieArchivistConfig>>\n\nexport class CookieArchivist<\n TParams extends CookieArchivistParams,\n TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,\n> extends AbstractArchivist<TParams, TEventData> {\n static override configSchemas = [CookieArchivistConfigSchema]\n\n get domain() {\n return this.config?.domain\n }\n\n get maxEntries() {\n //all browsers support at least 60 cookies\n return this.config?.maxEntries ?? 60\n }\n\n get maxEntrySize() {\n //all browsers support at least 4000 length per cookie\n return this.config?.maxEntrySize ?? 4000\n }\n\n get namespace() {\n return this.config?.namespace ?? 'xyoarch'\n }\n\n override get queries(): string[] {\n return [\n ArchivistAllQuerySchema,\n ArchivistDeleteQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistInsertQuerySchema,\n ArchivistCommitQuerySchema,\n ...super.queries,\n ]\n }\n\n protected override allHandler(): PromisableArray<Payload> {\n try {\n return Object.entries(Cookies.get())\n .filter(([key]) => key.startsWith(`${this.namespace}-`))\n .map(([, value]) => JSON.parse(value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override clearHandler(): void | Promise<void> {\n try {\n Object.entries(Cookies.get()).map(([key]) => {\n if (key.startsWith(`${this.namespace}-`)) {\n Cookies.remove(key)\n }\n })\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async commitHandler(): Promise<BoundWitness[]> {\n try {\n const payloads = await this.all()\n assertEx(payloads.length > 0, 'Nothing to commit')\n const settled = await Promise.allSettled(\n compact(\n Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {\n const queryPayload: ArchivistInsertQuery = {\n schema: ArchivistInsertQuerySchema,\n }\n const query = await this.bindQuery(queryPayload, payloads)\n return (await parent?.query(query[0], query[1]))?.[0]\n }),\n ),\n )\n await this.clear()\n return compact(settled.filter(fulfilled).map((result) => result.value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async deleteHandler(hashes: string[]): Promise<string[]> {\n const payloadPairs: [string, Payload][] = await Promise.all(\n (await this.get(hashes)).map<Promise<[string, Payload]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]),\n )\n const deletedPairs: [string, Payload][] = compact(\n await Promise.all(\n payloadPairs.map<[string, Payload] | undefined>(([hash, payload]) => {\n Cookies.remove(hash)\n return [hash, payload]\n }),\n ),\n )\n return deletedPairs.map(([hash]) => hash)\n }\n\n protected override getHandler(hashes: string[]): Promisable<Payload[]> {\n return compact(\n hashes.map((hash) => {\n const cookieString = Cookies.get(this.keyFromHash(hash))\n return cookieString ? JSON.parse(cookieString) : undefined\n }),\n )\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {\n try {\n const resultPayloads: Payload[] = await Promise.all(\n payloads.map(async (payload) => {\n const wrapper = PayloadWrapper.wrap(payload)\n const key = this.keyFromHash(await wrapper.hashAsync())\n const value = JSON.stringify(wrapper.payload())\n assertEx(value.length < this.maxEntrySize, `Payload too large [${wrapper.hashAsync()}, ${value.length}]`)\n Cookies.set(key, JSON.stringify(wrapper.payload()))\n return wrapper.payload()\n }),\n )\n return resultPayloads\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n private keyFromHash(hash: string) {\n return `${this.namespace}-${hash}`\n }\n}\n"],"mappings":"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","names":["assertEx","compact","fulfilled","AbstractArchivist","ArchivistAllQuerySchema","ArchivistClearQuerySchema","ArchivistCommitQuerySchema","ArchivistDeleteQuerySchema","ArchivistInsertQuerySchema","PayloadHasher","PayloadWrapper","Cookies","CookieArchivistConfigSchema","CookieArchivist","AbstractArchivist","domain","config","maxEntries","maxEntrySize","namespace","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","allHandler","Object","entries","Cookies","get","filter","key","startsWith","map","value","JSON","parse","ex","console","error","stringify","clearHandler","remove","commitHandler","payloads","all","assertEx","length","settled","Promise","allSettled","compact","values","parents","commit","parent","_a","queryPayload","schema","query","bindQuery","clear","fulfilled","result","deleteHandler","hashes","payloadPairs","payload","PayloadHasher","hashAsync","deletedPairs","hash","getHandler","cookieString","keyFromHash","undefined","insertHandler","resultPayloads","wrapper","PayloadWrapper","wrap","set","configSchemas"]}
@@ -0,0 +1,39 @@
1
+ import { AbstractArchivist } from '@xyo-network/archivist-abstract';
2
+ import { ArchivistConfig, ArchivistInstance, ArchivistModuleEventData, ArchivistParams } from '@xyo-network/archivist-model';
3
+ import { BoundWitness } from '@xyo-network/boundwitness-model';
4
+ import { AnyConfigSchema } from '@xyo-network/module';
5
+ import { Payload } from '@xyo-network/payload-model';
6
+ import { Promisable, PromisableArray } from '@xyo-network/promise';
7
+ export type StorageArchivistConfigSchema = 'network.xyo.archivist.storage.config';
8
+ export declare const StorageArchivistConfigSchema: StorageArchivistConfigSchema;
9
+ export type StorageArchivistConfig = ArchivistConfig<{
10
+ maxEntries?: number;
11
+ maxEntrySize?: number;
12
+ namespace?: string;
13
+ persistAccount?: boolean;
14
+ schema: StorageArchivistConfigSchema;
15
+ type?: 'local' | 'session' | 'page';
16
+ }>;
17
+ export type StorageArchivistParams = ArchivistParams<AnyConfigSchema<StorageArchivistConfig>>;
18
+ export declare class StorageArchivist<TParams extends StorageArchivistParams = StorageArchivistParams, TEventData extends ArchivistModuleEventData = ArchivistModuleEventData> extends AbstractArchivist<TParams, TEventData> implements ArchivistInstance {
19
+ static configSchemas: "network.xyo.archivist.storage.config"[];
20
+ private _privateStorage;
21
+ private _storage;
22
+ get maxEntries(): number;
23
+ get maxEntrySize(): number;
24
+ get namespace(): string;
25
+ get persistAccount(): boolean;
26
+ get queries(): string[];
27
+ get type(): "local" | "session" | "page";
28
+ private get privateStorage();
29
+ private get storage();
30
+ protected allHandler(): PromisableArray<Payload>;
31
+ protected clearHandler(): void | Promise<void>;
32
+ protected commitHandler(): Promise<BoundWitness[]>;
33
+ protected deleteHandler(hashes: string[]): Promise<string[]>;
34
+ protected getHandler(hashes: string[]): Promisable<Payload[]>;
35
+ protected insertHandler(payloads: Payload[]): Promise<Payload[]>;
36
+ protected saveAccount(): void;
37
+ protected startHandler(): Promise<boolean>;
38
+ }
39
+ //# sourceMappingURL=StorageArchivist.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StorageArchivist.d.ts","sourceRoot":"","sources":["../../src/StorageArchivist.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,EAIL,eAAe,EAIf,iBAAiB,EACjB,wBAAwB,EACxB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAE9D,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAGlE,MAAM,MAAM,4BAA4B,GAAG,sCAAsC,CAAA;AACjF,eAAO,MAAM,4BAA4B,EAAE,4BAAqE,CAAA;AAEhH,MAAM,MAAM,sBAAsB,GAAG,eAAe,CAAC;IACnD,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,MAAM,EAAE,4BAA4B,CAAA;IACpC,IAAI,CAAC,EAAE,OAAO,GAAG,SAAS,GAAG,MAAM,CAAA;CACpC,CAAC,CAAA;AAEF,MAAM,MAAM,sBAAsB,GAAG,eAAe,CAAC,eAAe,CAAC,sBAAsB,CAAC,CAAC,CAAA;AAC7F,qBAAa,gBAAgB,CACzB,OAAO,SAAS,sBAAsB,GAAG,sBAAsB,EAC/D,UAAU,SAAS,wBAAwB,GAAG,wBAAwB,CAExE,SAAQ,iBAAiB,CAAC,OAAO,EAAE,UAAU,CAC7C,YAAW,iBAAiB;IAE5B,OAAgB,aAAa,2CAAiC;IAE9D,OAAO,CAAC,eAAe,CAAuB;IAC9C,OAAO,CAAC,QAAQ,CAAuB;IAEvC,IAAI,UAAU,WAEb;IAED,IAAI,YAAY,WAEf;IAED,IAAI,SAAS,WAEZ;IAED,IAAI,cAAc,YAEjB;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAS/B;IAED,IAAI,IAAI,iCAEP;IAGD,OAAO,KAAK,cAAc,GAGzB;IAGD,OAAO,KAAK,OAAO,GAGlB;cAoBkB,UAAU,IAAI,eAAe,CAAC,OAAO,CAAC;cAKtC,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAM9B,aAAa,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;cAoBxC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;cAexD,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;cAQ7C,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAc/E,SAAS,CAAC,WAAW;cAQI,YAAY;CAKtC"}
@@ -5,6 +5,7 @@ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
5
  var __getOwnPropNames = Object.getOwnPropertyNames;
6
6
  var __getProtoOf = Object.getPrototypeOf;
7
7
  var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
9
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
9
10
  var __export = (target, all) => {
10
11
  for (var name in all)
@@ -27,6 +28,12 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
27
28
  mod
28
29
  ));
29
30
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
31
+ var __publicField = (obj, key, value) => {
32
+ __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
33
+ return value;
34
+ };
35
+
36
+ // src/StorageArchivist.ts
30
37
  var StorageArchivist_exports = {};
31
38
  __export(StorageArchivist_exports, {
32
39
  StorageArchivist: () => StorageArchivist,
@@ -41,27 +48,25 @@ var import_archivist_model = require("@xyo-network/archivist-model");
41
48
  var import_core = require("@xyo-network/core");
42
49
  var import_payload_wrapper = require("@xyo-network/payload-wrapper");
43
50
  var import_store2 = __toESM(require("store2"));
44
- const StorageArchivistConfigSchema = "network.xyo.archivist.storage.config";
45
- class StorageArchivist extends import_archivist_abstract.AbstractArchivist {
46
- static {
47
- __name(this, "StorageArchivist");
48
- }
49
- static configSchemas = [
50
- StorageArchivistConfigSchema
51
- ];
51
+ var StorageArchivistConfigSchema = "network.xyo.archivist.storage.config";
52
+ var _StorageArchivist = class _StorageArchivist extends import_archivist_abstract.AbstractArchivist {
52
53
  _privateStorage;
53
54
  _storage;
54
55
  get maxEntries() {
55
- return this.config?.maxEntries ?? 1e3;
56
+ var _a;
57
+ return ((_a = this.config) == null ? void 0 : _a.maxEntries) ?? 1e3;
56
58
  }
57
59
  get maxEntrySize() {
58
- return this.config?.maxEntrySize ?? 16e3;
60
+ var _a;
61
+ return ((_a = this.config) == null ? void 0 : _a.maxEntrySize) ?? 16e3;
59
62
  }
60
63
  get namespace() {
61
- return this.config?.namespace ?? "xyo-archivist";
64
+ var _a;
65
+ return ((_a = this.config) == null ? void 0 : _a.namespace) ?? "xyo-archivist";
62
66
  }
63
67
  get persistAccount() {
64
- return this.config?.persistAccount ?? false;
68
+ var _a;
69
+ return ((_a = this.config) == null ? void 0 : _a.persistAccount) ?? false;
65
70
  }
66
71
  get queries() {
67
72
  return [
@@ -74,7 +79,8 @@ class StorageArchivist extends import_archivist_abstract.AbstractArchivist {
74
79
  ];
75
80
  }
76
81
  get type() {
77
- return this.config?.type ?? "local";
82
+ var _a;
83
+ return ((_a = this.config) == null ? void 0 : _a.type) ?? "local";
78
84
  }
79
85
  /* This has to be a getter so that it can access it during construction */
80
86
  get privateStorage() {
@@ -104,26 +110,30 @@ class StorageArchivist extends import_archivist_abstract.AbstractArchivist {
104
110
  return await super.loadAccount()
105
111
  }*/
106
112
  allHandler() {
107
- this.logger?.log(`this.storage.length: ${this.storage.length}`);
113
+ var _a;
114
+ (_a = this.logger) == null ? void 0 : _a.log(`this.storage.length: ${this.storage.length}`);
108
115
  return Object.entries(this.storage.getAll()).map(([, value]) => value);
109
116
  }
110
117
  clearHandler() {
111
- this.logger?.log(`this.storage.length: ${this.storage.length}`);
118
+ var _a;
119
+ (_a = this.logger) == null ? void 0 : _a.log(`this.storage.length: ${this.storage.length}`);
112
120
  this.storage.clear();
113
121
  return this.emit("cleared", {
114
122
  module: this
115
123
  });
116
124
  }
117
125
  async commitHandler() {
118
- this.logger?.log(`this.storage.length: ${this.storage.length}`);
126
+ var _a, _b;
127
+ (_a = this.logger) == null ? void 0 : _a.log(`this.storage.length: ${this.storage.length}`);
119
128
  const payloads = await this.all();
120
129
  (0, import_assert.assertEx)(payloads.length > 0, "Nothing to commit");
121
- const settled = await Promise.allSettled((0, import_lodash.compact)(Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {
130
+ const settled = await Promise.allSettled((0, import_lodash.compact)((_b = Object.values((await this.parents()).commit ?? [])) == null ? void 0 : _b.map(async (parent) => {
131
+ var _a2;
122
132
  const queryPayload = {
123
133
  schema: import_archivist_model.ArchivistInsertQuerySchema
124
134
  };
125
135
  const query = await this.bindQuery(queryPayload, payloads);
126
- return (await parent?.query(query[0], query[1]))?.[0];
136
+ return (_a2 = await (parent == null ? void 0 : parent.query(query[0], query[1]))) == null ? void 0 : _a2[0];
127
137
  })));
128
138
  await this.clear();
129
139
  return (0, import_lodash.compact)(settled.filter(import_promise.fulfilled).map((result) => result.value));
@@ -159,9 +169,10 @@ class StorageArchivist extends import_archivist_abstract.AbstractArchivist {
159
169
  return resultPayloads;
160
170
  }
161
171
  saveAccount() {
172
+ var _a;
162
173
  if (this.persistAccount) {
163
174
  const account = this.account;
164
- this.logger?.log(account.address);
175
+ (_a = this.logger) == null ? void 0 : _a.log(account.address);
165
176
  this.privateStorage.set("privateKey", account.private.hex);
166
177
  }
167
178
  }
@@ -170,7 +181,12 @@ class StorageArchivist extends import_archivist_abstract.AbstractArchivist {
170
181
  this.saveAccount();
171
182
  return true;
172
183
  }
173
- }
184
+ };
185
+ __name(_StorageArchivist, "StorageArchivist");
186
+ __publicField(_StorageArchivist, "configSchemas", [
187
+ StorageArchivistConfigSchema
188
+ ]);
189
+ var StorageArchivist = _StorageArchivist;
174
190
  // Annotate the CommonJS export names for ESM import in node:
175
191
  0 && (module.exports = {
176
192
  StorageArchivist,