@xyo-network/archivist 2.74.5 → 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 (92) hide show
  1. package/dist/browser/AbstractArchivingModule.cjs +51 -0
  2. package/dist/browser/AbstractArchivingModule.cjs.map +1 -0
  3. package/dist/browser/AbstractArchivingModule.d.cts.map +1 -0
  4. package/dist/browser/AbstractArchivingModule.d.mts.map +1 -0
  5. package/dist/browser/AbstractArchivingModule.d.ts +14 -0
  6. package/dist/browser/AbstractArchivingModule.d.ts.map +1 -0
  7. package/dist/browser/AbstractArchivingModule.js +30 -0
  8. package/dist/browser/AbstractArchivingModule.js.map +1 -0
  9. package/dist/browser/CookieArchivist.cjs +154 -0
  10. package/dist/browser/CookieArchivist.cjs.map +1 -0
  11. package/dist/browser/CookieArchivist.d.cts.map +1 -0
  12. package/dist/browser/CookieArchivist.d.mts.map +1 -0
  13. package/dist/browser/CookieArchivist.d.ts +32 -0
  14. package/dist/browser/CookieArchivist.d.ts.map +1 -0
  15. package/dist/browser/CookieArchivist.js +123 -0
  16. package/dist/browser/CookieArchivist.js.map +1 -0
  17. package/dist/browser/StorageArchivist.cjs +176 -0
  18. package/dist/browser/StorageArchivist.cjs.map +1 -0
  19. package/dist/browser/StorageArchivist.d.cts.map +1 -0
  20. package/dist/browser/StorageArchivist.d.mts.map +1 -0
  21. package/dist/browser/StorageArchivist.d.ts +39 -0
  22. package/dist/browser/StorageArchivist.d.ts.map +1 -0
  23. package/dist/browser/StorageArchivist.js +145 -0
  24. package/dist/browser/StorageArchivist.js.map +1 -0
  25. package/dist/{index.js → browser/index.cjs} +1 -13
  26. package/dist/browser/index.cjs.map +1 -0
  27. package/dist/browser/index.d.cts.map +1 -0
  28. package/dist/browser/index.d.mts.map +1 -0
  29. package/dist/browser/index.d.ts +8 -0
  30. package/dist/browser/index.d.ts.map +1 -0
  31. package/dist/browser/index.js +8 -0
  32. package/dist/browser/index.js.map +1 -0
  33. package/dist/docs.json +3124 -3124
  34. package/dist/node/AbstractArchivingModule.d.cts +14 -0
  35. package/dist/node/AbstractArchivingModule.d.cts.map +1 -0
  36. package/dist/node/AbstractArchivingModule.d.mts +14 -0
  37. package/dist/node/AbstractArchivingModule.d.mts.map +1 -0
  38. package/dist/node/AbstractArchivingModule.d.ts +14 -0
  39. package/dist/node/AbstractArchivingModule.d.ts.map +1 -0
  40. package/dist/node/AbstractArchivingModule.js +55 -0
  41. package/dist/node/AbstractArchivingModule.js.map +1 -0
  42. package/dist/node/AbstractArchivingModule.mjs +32 -0
  43. package/dist/node/AbstractArchivingModule.mjs.map +1 -0
  44. package/dist/node/CookieArchivist.d.cts +32 -0
  45. package/dist/node/CookieArchivist.d.cts.map +1 -0
  46. package/dist/node/CookieArchivist.d.mts +32 -0
  47. package/dist/node/CookieArchivist.d.mts.map +1 -0
  48. package/dist/node/CookieArchivist.d.ts +32 -0
  49. package/dist/node/CookieArchivist.d.ts.map +1 -0
  50. package/dist/node/CookieArchivist.js +169 -0
  51. package/dist/node/CookieArchivist.js.map +1 -0
  52. package/dist/node/CookieArchivist.mjs +135 -0
  53. package/dist/node/CookieArchivist.mjs.map +1 -0
  54. package/dist/node/StorageArchivist.d.cts +39 -0
  55. package/dist/node/StorageArchivist.d.cts.map +1 -0
  56. package/dist/node/StorageArchivist.d.mts +39 -0
  57. package/dist/node/StorageArchivist.d.mts.map +1 -0
  58. package/dist/node/StorageArchivist.d.ts +39 -0
  59. package/dist/node/StorageArchivist.d.ts.map +1 -0
  60. package/dist/node/StorageArchivist.js +195 -0
  61. package/dist/node/StorageArchivist.js.map +1 -0
  62. package/dist/node/StorageArchivist.mjs +161 -0
  63. package/dist/node/StorageArchivist.mjs.map +1 -0
  64. package/dist/node/index.d.cts +8 -0
  65. package/dist/node/index.d.cts.map +1 -0
  66. package/dist/node/index.d.mts +8 -0
  67. package/dist/node/index.d.mts.map +1 -0
  68. package/dist/node/index.d.ts +8 -0
  69. package/dist/node/index.d.ts.map +1 -0
  70. package/dist/node/index.js +363 -0
  71. package/dist/node/index.js.map +1 -0
  72. package/dist/{index.mjs → node/index.mjs} +55 -36
  73. package/dist/node/index.mjs.map +1 -0
  74. package/package.json +40 -37
  75. package/dist/AbstractArchivingModule.d.mts.map +0 -1
  76. package/dist/AbstractArchivingModule.d.ts.map +0 -1
  77. package/dist/CookieArchivist.d.mts.map +0 -1
  78. package/dist/CookieArchivist.d.ts.map +0 -1
  79. package/dist/StorageArchivist.d.mts.map +0 -1
  80. package/dist/StorageArchivist.d.ts.map +0 -1
  81. package/dist/index.d.mts.map +0 -1
  82. package/dist/index.d.ts.map +0 -1
  83. package/dist/index.js.map +0 -1
  84. package/dist/index.mjs.map +0 -1
  85. /package/dist/{AbstractArchivingModule.d.mts → browser/AbstractArchivingModule.d.cts} +0 -0
  86. /package/dist/{AbstractArchivingModule.d.ts → browser/AbstractArchivingModule.d.mts} +0 -0
  87. /package/dist/{CookieArchivist.d.mts → browser/CookieArchivist.d.cts} +0 -0
  88. /package/dist/{CookieArchivist.d.ts → browser/CookieArchivist.d.mts} +0 -0
  89. /package/dist/{StorageArchivist.d.mts → browser/StorageArchivist.d.cts} +0 -0
  90. /package/dist/{StorageArchivist.d.ts → browser/StorageArchivist.d.mts} +0 -0
  91. /package/dist/{index.d.mts → browser/index.d.cts} +0 -0
  92. /package/dist/{index.d.ts → browser/index.d.mts} +0 -0
@@ -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"}
@@ -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"}
@@ -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"}
@@ -0,0 +1,55 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
20
+
21
+ // src/AbstractArchivingModule.ts
22
+ var AbstractArchivingModule_exports = {};
23
+ __export(AbstractArchivingModule_exports, {
24
+ AbstractArchivingModule: () => AbstractArchivingModule
25
+ });
26
+ module.exports = __toCommonJS(AbstractArchivingModule_exports);
27
+ var import_lodash = require("@xylabs/lodash");
28
+ var import_archivist_model = require("@xyo-network/archivist-model");
29
+ var import_module = require("@xyo-network/module");
30
+ var _AbstractArchivingModule = class _AbstractArchivingModule extends import_module.AbstractModuleInstance {
31
+ async bindQueryResult(query, payloads, additionalWitnesses = [], errorPayloads = []) {
32
+ const result = await super.bindQueryResult(query, payloads, additionalWitnesses, errorPayloads);
33
+ await this.storeToArchivists(result.flat());
34
+ return result;
35
+ }
36
+ async resolveArchivists() {
37
+ return (0, import_lodash.compact)((await Promise.all(await this.resolve({
38
+ address: this.config.archivists ?? []
39
+ }) ?? [])).map((module2) => (0, import_archivist_model.asArchivistInstance)(module2, () => `Module failed to cast to Archivist [${module2.config.name}]`)));
40
+ }
41
+ async storeToArchivists(payloads) {
42
+ const archivists = await this.resolveArchivists();
43
+ return (await Promise.all(archivists.map((archivist) => {
44
+ var _a;
45
+ return (_a = archivist.insert) == null ? void 0 : _a.call(archivist, payloads);
46
+ }))).map(([bw]) => bw);
47
+ }
48
+ };
49
+ __name(_AbstractArchivingModule, "AbstractArchivingModule");
50
+ var AbstractArchivingModule = _AbstractArchivingModule;
51
+ // Annotate the CommonJS export names for ESM import in node:
52
+ 0 && (module.exports = {
53
+ AbstractArchivingModule
54
+ });
55
+ //# sourceMappingURL=AbstractArchivingModule.js.map
@@ -0,0 +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;;;;;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"]}
@@ -0,0 +1,32 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+
4
+ // src/AbstractArchivingModule.ts
5
+ import { compact } from "@xylabs/lodash";
6
+ import { asArchivistInstance } from "@xyo-network/archivist-model";
7
+ import { AbstractModuleInstance } from "@xyo-network/module";
8
+ var _AbstractArchivingModule = class _AbstractArchivingModule extends AbstractModuleInstance {
9
+ async bindQueryResult(query, payloads, additionalWitnesses = [], errorPayloads = []) {
10
+ const result = await super.bindQueryResult(query, payloads, additionalWitnesses, errorPayloads);
11
+ await this.storeToArchivists(result.flat());
12
+ return result;
13
+ }
14
+ async resolveArchivists() {
15
+ return compact((await Promise.all(await this.resolve({
16
+ address: this.config.archivists ?? []
17
+ }) ?? [])).map((module) => asArchivistInstance(module, () => `Module failed to cast to Archivist [${module.config.name}]`)));
18
+ }
19
+ async storeToArchivists(payloads) {
20
+ const archivists = await this.resolveArchivists();
21
+ return (await Promise.all(archivists.map((archivist) => {
22
+ var _a;
23
+ return (_a = archivist.insert) == null ? void 0 : _a.call(archivist, payloads);
24
+ }))).map(([bw]) => bw);
25
+ }
26
+ };
27
+ __name(_AbstractArchivingModule, "AbstractArchivingModule");
28
+ var AbstractArchivingModule = _AbstractArchivingModule;
29
+ export {
30
+ AbstractArchivingModule
31
+ };
32
+ //# sourceMappingURL=AbstractArchivingModule.mjs.map
@@ -0,0 +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,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"}
@@ -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"}
@@ -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"}
@@ -0,0 +1,169 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
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;
9
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
10
+ var __export = (target, all) => {
11
+ for (var name in all)
12
+ __defProp(target, name, { get: all[name], enumerable: true });
13
+ };
14
+ var __copyProps = (to, from, except, desc) => {
15
+ if (from && typeof from === "object" || typeof from === "function") {
16
+ for (let key of __getOwnPropNames(from))
17
+ if (!__hasOwnProp.call(to, key) && key !== except)
18
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
19
+ }
20
+ return to;
21
+ };
22
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
23
+ // If the importer is in node compatibility mode or this is not an ESM
24
+ // file that has been converted to a CommonJS file using a Babel-
25
+ // compatible transform (i.e. "__esModule" has not been set), then set
26
+ // "default" to the CommonJS "module.exports" for node compatibility.
27
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
28
+ mod
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
37
+ var CookieArchivist_exports = {};
38
+ __export(CookieArchivist_exports, {
39
+ CookieArchivist: () => CookieArchivist,
40
+ CookieArchivistConfigSchema: () => CookieArchivistConfigSchema
41
+ });
42
+ module.exports = __toCommonJS(CookieArchivist_exports);
43
+ var import_assert = require("@xylabs/assert");
44
+ var import_lodash = require("@xylabs/lodash");
45
+ var import_promise = require("@xylabs/promise");
46
+ var import_archivist_abstract = require("@xyo-network/archivist-abstract");
47
+ var import_archivist_model = require("@xyo-network/archivist-model");
48
+ var import_core = require("@xyo-network/core");
49
+ var import_payload_wrapper = require("@xyo-network/payload-wrapper");
50
+ var import_js_cookie = __toESM(require("js-cookie"));
51
+ var CookieArchivistConfigSchema = "network.xyo.archivist.cookie.config";
52
+ var _CookieArchivist = class _CookieArchivist extends import_archivist_abstract.AbstractArchivist {
53
+ get domain() {
54
+ var _a;
55
+ return (_a = this.config) == null ? void 0 : _a.domain;
56
+ }
57
+ get maxEntries() {
58
+ var _a;
59
+ return ((_a = this.config) == null ? void 0 : _a.maxEntries) ?? 60;
60
+ }
61
+ get maxEntrySize() {
62
+ var _a;
63
+ return ((_a = this.config) == null ? void 0 : _a.maxEntrySize) ?? 4e3;
64
+ }
65
+ get namespace() {
66
+ var _a;
67
+ return ((_a = this.config) == null ? void 0 : _a.namespace) ?? "xyoarch";
68
+ }
69
+ get queries() {
70
+ return [
71
+ import_archivist_model.ArchivistAllQuerySchema,
72
+ import_archivist_model.ArchivistDeleteQuerySchema,
73
+ import_archivist_model.ArchivistClearQuerySchema,
74
+ import_archivist_model.ArchivistInsertQuerySchema,
75
+ import_archivist_model.ArchivistCommitQuerySchema,
76
+ ...super.queries
77
+ ];
78
+ }
79
+ allHandler() {
80
+ try {
81
+ return Object.entries(import_js_cookie.default.get()).filter(([key]) => key.startsWith(`${this.namespace}-`)).map(([, value]) => JSON.parse(value));
82
+ } catch (ex) {
83
+ console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
84
+ throw ex;
85
+ }
86
+ }
87
+ clearHandler() {
88
+ try {
89
+ Object.entries(import_js_cookie.default.get()).map(([key]) => {
90
+ if (key.startsWith(`${this.namespace}-`)) {
91
+ import_js_cookie.default.remove(key);
92
+ }
93
+ });
94
+ } catch (ex) {
95
+ console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
96
+ throw ex;
97
+ }
98
+ }
99
+ async commitHandler() {
100
+ var _a;
101
+ try {
102
+ const payloads = await this.all();
103
+ (0, import_assert.assertEx)(payloads.length > 0, "Nothing to commit");
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;
106
+ const queryPayload = {
107
+ schema: import_archivist_model.ArchivistInsertQuerySchema
108
+ };
109
+ const query = await this.bindQuery(queryPayload, payloads);
110
+ return (_a2 = await (parent == null ? void 0 : parent.query(query[0], query[1]))) == null ? void 0 : _a2[0];
111
+ })));
112
+ await this.clear();
113
+ return (0, import_lodash.compact)(settled.filter(import_promise.fulfilled).map((result) => result.value));
114
+ } catch (ex) {
115
+ console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
116
+ throw ex;
117
+ }
118
+ }
119
+ async deleteHandler(hashes) {
120
+ const payloadPairs = await Promise.all((await this.get(hashes)).map(async (payload) => [
121
+ await import_core.PayloadHasher.hashAsync(payload),
122
+ payload
123
+ ]));
124
+ const deletedPairs = (0, import_lodash.compact)(await Promise.all(payloadPairs.map(([hash, payload]) => {
125
+ import_js_cookie.default.remove(hash);
126
+ return [
127
+ hash,
128
+ payload
129
+ ];
130
+ })));
131
+ return deletedPairs.map(([hash]) => hash);
132
+ }
133
+ getHandler(hashes) {
134
+ return (0, import_lodash.compact)(hashes.map((hash) => {
135
+ const cookieString = import_js_cookie.default.get(this.keyFromHash(hash));
136
+ return cookieString ? JSON.parse(cookieString) : void 0;
137
+ }));
138
+ }
139
+ async insertHandler(payloads) {
140
+ try {
141
+ const resultPayloads = await Promise.all(payloads.map(async (payload) => {
142
+ const wrapper = import_payload_wrapper.PayloadWrapper.wrap(payload);
143
+ const key = this.keyFromHash(await wrapper.hashAsync());
144
+ const value = JSON.stringify(wrapper.payload());
145
+ (0, import_assert.assertEx)(value.length < this.maxEntrySize, `Payload too large [${wrapper.hashAsync()}, ${value.length}]`);
146
+ import_js_cookie.default.set(key, JSON.stringify(wrapper.payload()));
147
+ return wrapper.payload();
148
+ }));
149
+ return resultPayloads;
150
+ } catch (ex) {
151
+ console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
152
+ throw ex;
153
+ }
154
+ }
155
+ keyFromHash(hash) {
156
+ return `${this.namespace}-${hash}`;
157
+ }
158
+ };
159
+ __name(_CookieArchivist, "CookieArchivist");
160
+ __publicField(_CookieArchivist, "configSchemas", [
161
+ CookieArchivistConfigSchema
162
+ ]);
163
+ var CookieArchivist = _CookieArchivist;
164
+ // Annotate the CommonJS export names for ESM import in node:
165
+ 0 && (module.exports = {
166
+ CookieArchivist,
167
+ CookieArchivistConfigSchema
168
+ });
169
+ //# sourceMappingURL=CookieArchivist.js.map
@@ -0,0 +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","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,135 @@
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;
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
10
+ import { assertEx } from "@xylabs/assert";
11
+ import { compact } from "@xylabs/lodash";
12
+ import { fulfilled } from "@xylabs/promise";
13
+ import { AbstractArchivist } from "@xyo-network/archivist-abstract";
14
+ import { ArchivistAllQuerySchema, ArchivistClearQuerySchema, ArchivistCommitQuerySchema, ArchivistDeleteQuerySchema, ArchivistInsertQuerySchema } from "@xyo-network/archivist-model";
15
+ import { PayloadHasher } from "@xyo-network/core";
16
+ import { PayloadWrapper } from "@xyo-network/payload-wrapper";
17
+ import Cookies from "js-cookie";
18
+ var CookieArchivistConfigSchema = "network.xyo.archivist.cookie.config";
19
+ var _CookieArchivist = class _CookieArchivist extends AbstractArchivist {
20
+ get domain() {
21
+ var _a;
22
+ return (_a = this.config) == null ? void 0 : _a.domain;
23
+ }
24
+ get maxEntries() {
25
+ var _a;
26
+ return ((_a = this.config) == null ? void 0 : _a.maxEntries) ?? 60;
27
+ }
28
+ get maxEntrySize() {
29
+ var _a;
30
+ return ((_a = this.config) == null ? void 0 : _a.maxEntrySize) ?? 4e3;
31
+ }
32
+ get namespace() {
33
+ var _a;
34
+ return ((_a = this.config) == null ? void 0 : _a.namespace) ?? "xyoarch";
35
+ }
36
+ get queries() {
37
+ return [
38
+ ArchivistAllQuerySchema,
39
+ ArchivistDeleteQuerySchema,
40
+ ArchivistClearQuerySchema,
41
+ ArchivistInsertQuerySchema,
42
+ ArchivistCommitQuerySchema,
43
+ ...super.queries
44
+ ];
45
+ }
46
+ allHandler() {
47
+ try {
48
+ return Object.entries(Cookies.get()).filter(([key]) => key.startsWith(`${this.namespace}-`)).map(([, value]) => JSON.parse(value));
49
+ } catch (ex) {
50
+ console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
51
+ throw ex;
52
+ }
53
+ }
54
+ clearHandler() {
55
+ try {
56
+ Object.entries(Cookies.get()).map(([key]) => {
57
+ if (key.startsWith(`${this.namespace}-`)) {
58
+ Cookies.remove(key);
59
+ }
60
+ });
61
+ } catch (ex) {
62
+ console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
63
+ throw ex;
64
+ }
65
+ }
66
+ async commitHandler() {
67
+ var _a;
68
+ try {
69
+ const payloads = await this.all();
70
+ assertEx(payloads.length > 0, "Nothing to commit");
71
+ const settled = await Promise.allSettled(compact((_a = Object.values((await this.parents()).commit ?? [])) == null ? void 0 : _a.map(async (parent) => {
72
+ var _a2;
73
+ const queryPayload = {
74
+ schema: ArchivistInsertQuerySchema
75
+ };
76
+ const query = await this.bindQuery(queryPayload, payloads);
77
+ return (_a2 = await (parent == null ? void 0 : parent.query(query[0], query[1]))) == null ? void 0 : _a2[0];
78
+ })));
79
+ await this.clear();
80
+ return compact(settled.filter(fulfilled).map((result) => result.value));
81
+ } catch (ex) {
82
+ console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
83
+ throw ex;
84
+ }
85
+ }
86
+ async deleteHandler(hashes) {
87
+ const payloadPairs = await Promise.all((await this.get(hashes)).map(async (payload) => [
88
+ await PayloadHasher.hashAsync(payload),
89
+ payload
90
+ ]));
91
+ const deletedPairs = compact(await Promise.all(payloadPairs.map(([hash, payload]) => {
92
+ Cookies.remove(hash);
93
+ return [
94
+ hash,
95
+ payload
96
+ ];
97
+ })));
98
+ return deletedPairs.map(([hash]) => hash);
99
+ }
100
+ getHandler(hashes) {
101
+ return compact(hashes.map((hash) => {
102
+ const cookieString = Cookies.get(this.keyFromHash(hash));
103
+ return cookieString ? JSON.parse(cookieString) : void 0;
104
+ }));
105
+ }
106
+ async insertHandler(payloads) {
107
+ try {
108
+ const resultPayloads = await Promise.all(payloads.map(async (payload) => {
109
+ const wrapper = PayloadWrapper.wrap(payload);
110
+ const key = this.keyFromHash(await wrapper.hashAsync());
111
+ const value = JSON.stringify(wrapper.payload());
112
+ assertEx(value.length < this.maxEntrySize, `Payload too large [${wrapper.hashAsync()}, ${value.length}]`);
113
+ Cookies.set(key, JSON.stringify(wrapper.payload()));
114
+ return wrapper.payload();
115
+ }));
116
+ return resultPayloads;
117
+ } catch (ex) {
118
+ console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
119
+ throw ex;
120
+ }
121
+ }
122
+ keyFromHash(hash) {
123
+ return `${this.namespace}-${hash}`;
124
+ }
125
+ };
126
+ __name(_CookieArchivist, "CookieArchivist");
127
+ __publicField(_CookieArchivist, "configSchemas", [
128
+ CookieArchivistConfigSchema
129
+ ]);
130
+ var CookieArchivist = _CookieArchivist;
131
+ export {
132
+ CookieArchivist,
133
+ CookieArchivistConfigSchema
134
+ };
135
+ //# sourceMappingURL=CookieArchivist.mjs.map