@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
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/StorageArchivist.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 ArchivistInstance,\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 store, { StoreBase } from 'store2'\n\nexport type StorageArchivistConfigSchema = 'network.xyo.archivist.storage.config'\nexport const StorageArchivistConfigSchema: StorageArchivistConfigSchema = 'network.xyo.archivist.storage.config'\n\nexport type StorageArchivistConfig = ArchivistConfig<{\n maxEntries?: number\n maxEntrySize?: number\n namespace?: string\n persistAccount?: boolean\n schema: StorageArchivistConfigSchema\n type?: 'local' | 'session' | 'page'\n}>\n\nexport type StorageArchivistParams = ArchivistParams<AnyConfigSchema<StorageArchivistConfig>>\nexport class StorageArchivist<\n TParams extends StorageArchivistParams = StorageArchivistParams,\n TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,\n >\n extends AbstractArchivist<TParams, TEventData>\n implements ArchivistInstance\n{\n static override configSchemas = [StorageArchivistConfigSchema]\n\n private _privateStorage: StoreBase | undefined\n private _storage: StoreBase | undefined\n\n get maxEntries() {\n return this.config?.maxEntries ?? 1000\n }\n\n get maxEntrySize() {\n return this.config?.maxEntrySize ?? 16000\n }\n\n get namespace() {\n return this.config?.namespace ?? 'xyo-archivist'\n }\n\n get persistAccount() {\n return this.config?.persistAccount ?? false\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 get type() {\n return this.config?.type ?? 'local'\n }\n\n /* This has to be a getter so that it can access it during construction */\n private get privateStorage(): StoreBase {\n this._privateStorage = this._storage ?? store[this.type].namespace(`${this.namespace}|private`)\n return this._privateStorage\n }\n\n /* This has to be a getter so that it can access it during construction */\n private get storage(): StoreBase {\n this._storage = this._storage ?? store[this.type].namespace(this.namespace)\n return this._storage\n }\n\n /*override async loadAccount(account?: AccountInstance, persistAccount?: boolean, privateStorage?: StoreBase, _logger?: Logger) {\n if (!this._account) {\n if (persistAccount) {\n const privateKey = privateStorage?.get('privateKey')\n if (privateKey) {\n try {\n this._account = await Account.create({ privateKey })\n return this._account\n } catch (ex) {\n console.error(`Error reading Account from storage [${ex}] - Recreating Account`)\n privateStorage?.remove('privateKey')\n }\n }\n }\n }\n return await super.loadAccount()\n }*/\n\n protected override allHandler(): PromisableArray<Payload> {\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\n return Object.entries(this.storage.getAll()).map(([, value]) => value)\n }\n\n protected override clearHandler(): void | Promise<void> {\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\n this.storage.clear()\n return this.emit('cleared', { module: this })\n }\n\n protected override async commitHandler(): Promise<BoundWitness[]> {\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\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 // TODO - rather than clear, delete the payloads that come back as successfully inserted\n await this.clear()\n return compact(settled.filter(fulfilled).map((result) => result.value))\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 this.storage.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 return this.storage.get(hash)\n }),\n )\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {\n const resultPayloads = await Promise.all(\n payloads.map(async (payload) => {\n const wrapper = PayloadWrapper.wrap(payload)\n const hash = await wrapper.hashAsync()\n const value = JSON.stringify(wrapper.payload())\n assertEx(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`)\n this.storage.set(hash, wrapper.payload())\n return wrapper.payload()\n }),\n )\n return resultPayloads\n }\n\n protected saveAccount() {\n if (this.persistAccount) {\n const account = this.account\n this.logger?.log(account.address)\n this.privateStorage.set('privateKey', account.private.hex)\n }\n }\n\n protected override async startHandler() {\n await super.startHandler()\n this.saveAccount()\n return true\n }\n}\n"],"mappings":"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","names":["StorageArchivistConfigSchema","StorageArchivist","AbstractArchivist","configSchemas","_privateStorage","_storage","maxEntries","config","maxEntrySize","namespace","persistAccount","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","type","privateStorage","store","storage","allHandler","logger","log","length","Object","entries","getAll","map","value","clearHandler","clear","emit","module","commitHandler","payloads","all","assertEx","settled","Promise","allSettled","compact","values","parents","commit","parent","queryPayload","schema","query","bindQuery","filter","fulfilled","result","deleteHandler","hashes","payloadPairs","get","payload","PayloadHasher","hashAsync","deletedPairs","hash","remove","getHandler","insertHandler","resultPayloads","wrapper","PayloadWrapper","wrap","JSON","stringify","set","saveAccount","account","address","private","hex","startHandler"]}
1
+ {"version":3,"sources":["../../src/StorageArchivist.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 ArchivistInstance,\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 store, { StoreBase } from 'store2'\n\nexport type StorageArchivistConfigSchema = 'network.xyo.archivist.storage.config'\nexport const StorageArchivistConfigSchema: StorageArchivistConfigSchema = 'network.xyo.archivist.storage.config'\n\nexport type StorageArchivistConfig = ArchivistConfig<{\n maxEntries?: number\n maxEntrySize?: number\n namespace?: string\n persistAccount?: boolean\n schema: StorageArchivistConfigSchema\n type?: 'local' | 'session' | 'page'\n}>\n\nexport type StorageArchivistParams = ArchivistParams<AnyConfigSchema<StorageArchivistConfig>>\nexport class StorageArchivist<\n TParams extends StorageArchivistParams = StorageArchivistParams,\n TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,\n >\n extends AbstractArchivist<TParams, TEventData>\n implements ArchivistInstance\n{\n static override configSchemas = [StorageArchivistConfigSchema]\n\n private _privateStorage: StoreBase | undefined\n private _storage: StoreBase | undefined\n\n get maxEntries() {\n return this.config?.maxEntries ?? 1000\n }\n\n get maxEntrySize() {\n return this.config?.maxEntrySize ?? 16000\n }\n\n get namespace() {\n return this.config?.namespace ?? 'xyo-archivist'\n }\n\n get persistAccount() {\n return this.config?.persistAccount ?? false\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 get type() {\n return this.config?.type ?? 'local'\n }\n\n /* This has to be a getter so that it can access it during construction */\n private get privateStorage(): StoreBase {\n this._privateStorage = this._storage ?? store[this.type].namespace(`${this.namespace}|private`)\n return this._privateStorage\n }\n\n /* This has to be a getter so that it can access it during construction */\n private get storage(): StoreBase {\n this._storage = this._storage ?? store[this.type].namespace(this.namespace)\n return this._storage\n }\n\n /*override async loadAccount(account?: AccountInstance, persistAccount?: boolean, privateStorage?: StoreBase, _logger?: Logger) {\n if (!this._account) {\n if (persistAccount) {\n const privateKey = privateStorage?.get('privateKey')\n if (privateKey) {\n try {\n this._account = await Account.create({ privateKey })\n return this._account\n } catch (ex) {\n console.error(`Error reading Account from storage [${ex}] - Recreating Account`)\n privateStorage?.remove('privateKey')\n }\n }\n }\n }\n return await super.loadAccount()\n }*/\n\n protected override allHandler(): PromisableArray<Payload> {\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\n return Object.entries(this.storage.getAll()).map(([, value]) => value)\n }\n\n protected override clearHandler(): void | Promise<void> {\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\n this.storage.clear()\n return this.emit('cleared', { module: this })\n }\n\n protected override async commitHandler(): Promise<BoundWitness[]> {\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\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 // TODO - rather than clear, delete the payloads that come back as successfully inserted\n await this.clear()\n return compact(settled.filter(fulfilled).map((result) => result.value))\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 this.storage.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 return this.storage.get(hash)\n }),\n )\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {\n const resultPayloads = await Promise.all(\n payloads.map(async (payload) => {\n const wrapper = PayloadWrapper.wrap(payload)\n const hash = await wrapper.hashAsync()\n const value = JSON.stringify(wrapper.payload())\n assertEx(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`)\n this.storage.set(hash, wrapper.payload())\n return wrapper.payload()\n }),\n )\n return resultPayloads\n }\n\n protected saveAccount() {\n if (this.persistAccount) {\n const account = this.account\n this.logger?.log(account.address)\n this.privateStorage.set('privateKey', account.private.hex)\n }\n }\n\n protected override async startHandler() {\n await super.startHandler()\n this.saveAccount()\n return true\n }\n}\n"],"mappings":"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","names":["StorageArchivistConfigSchema","StorageArchivist","AbstractArchivist","_privateStorage","_storage","maxEntries","config","maxEntrySize","namespace","persistAccount","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","type","privateStorage","store","storage","allHandler","logger","log","length","Object","entries","getAll","map","value","clearHandler","clear","emit","module","commitHandler","payloads","all","assertEx","settled","Promise","allSettled","compact","values","parents","commit","parent","_a","queryPayload","schema","query","bindQuery","filter","fulfilled","result","deleteHandler","hashes","payloadPairs","get","payload","PayloadHasher","hashAsync","deletedPairs","hash","remove","getHandler","insertHandler","resultPayloads","wrapper","PayloadWrapper","wrap","JSON","stringify","set","saveAccount","account","address","private","hex","startHandler","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/StorageArchivist.ts
3
10
  import { assertEx } from "@xylabs/assert";
4
11
  import { compact } from "@xylabs/lodash";
5
12
  import { fulfilled } from "@xylabs/promise";
@@ -8,27 +15,25 @@ import { ArchivistAllQuerySchema, ArchivistClearQuerySchema, ArchivistCommitQuer
8
15
  import { PayloadHasher } from "@xyo-network/core";
9
16
  import { PayloadWrapper } from "@xyo-network/payload-wrapper";
10
17
  import store from "store2";
11
- const StorageArchivistConfigSchema = "network.xyo.archivist.storage.config";
12
- class StorageArchivist extends AbstractArchivist {
13
- static {
14
- __name(this, "StorageArchivist");
15
- }
16
- static configSchemas = [
17
- StorageArchivistConfigSchema
18
- ];
18
+ var StorageArchivistConfigSchema = "network.xyo.archivist.storage.config";
19
+ var _StorageArchivist = class _StorageArchivist extends AbstractArchivist {
19
20
  _privateStorage;
20
21
  _storage;
21
22
  get maxEntries() {
22
- return this.config?.maxEntries ?? 1e3;
23
+ var _a;
24
+ return ((_a = this.config) == null ? void 0 : _a.maxEntries) ?? 1e3;
23
25
  }
24
26
  get maxEntrySize() {
25
- return this.config?.maxEntrySize ?? 16e3;
27
+ var _a;
28
+ return ((_a = this.config) == null ? void 0 : _a.maxEntrySize) ?? 16e3;
26
29
  }
27
30
  get namespace() {
28
- return this.config?.namespace ?? "xyo-archivist";
31
+ var _a;
32
+ return ((_a = this.config) == null ? void 0 : _a.namespace) ?? "xyo-archivist";
29
33
  }
30
34
  get persistAccount() {
31
- return this.config?.persistAccount ?? false;
35
+ var _a;
36
+ return ((_a = this.config) == null ? void 0 : _a.persistAccount) ?? false;
32
37
  }
33
38
  get queries() {
34
39
  return [
@@ -41,7 +46,8 @@ class StorageArchivist extends AbstractArchivist {
41
46
  ];
42
47
  }
43
48
  get type() {
44
- return this.config?.type ?? "local";
49
+ var _a;
50
+ return ((_a = this.config) == null ? void 0 : _a.type) ?? "local";
45
51
  }
46
52
  /* This has to be a getter so that it can access it during construction */
47
53
  get privateStorage() {
@@ -71,26 +77,30 @@ class StorageArchivist extends AbstractArchivist {
71
77
  return await super.loadAccount()
72
78
  }*/
73
79
  allHandler() {
74
- this.logger?.log(`this.storage.length: ${this.storage.length}`);
80
+ var _a;
81
+ (_a = this.logger) == null ? void 0 : _a.log(`this.storage.length: ${this.storage.length}`);
75
82
  return Object.entries(this.storage.getAll()).map(([, value]) => value);
76
83
  }
77
84
  clearHandler() {
78
- this.logger?.log(`this.storage.length: ${this.storage.length}`);
85
+ var _a;
86
+ (_a = this.logger) == null ? void 0 : _a.log(`this.storage.length: ${this.storage.length}`);
79
87
  this.storage.clear();
80
88
  return this.emit("cleared", {
81
89
  module: this
82
90
  });
83
91
  }
84
92
  async commitHandler() {
85
- this.logger?.log(`this.storage.length: ${this.storage.length}`);
93
+ var _a, _b;
94
+ (_a = this.logger) == null ? void 0 : _a.log(`this.storage.length: ${this.storage.length}`);
86
95
  const payloads = await this.all();
87
96
  assertEx(payloads.length > 0, "Nothing to commit");
88
- const settled = await Promise.allSettled(compact(Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {
97
+ const settled = await Promise.allSettled(compact((_b = Object.values((await this.parents()).commit ?? [])) == null ? void 0 : _b.map(async (parent) => {
98
+ var _a2;
89
99
  const queryPayload = {
90
100
  schema: ArchivistInsertQuerySchema
91
101
  };
92
102
  const query = await this.bindQuery(queryPayload, payloads);
93
- return (await parent?.query(query[0], query[1]))?.[0];
103
+ return (_a2 = await (parent == null ? void 0 : parent.query(query[0], query[1]))) == null ? void 0 : _a2[0];
94
104
  })));
95
105
  await this.clear();
96
106
  return compact(settled.filter(fulfilled).map((result) => result.value));
@@ -126,9 +136,10 @@ class StorageArchivist extends AbstractArchivist {
126
136
  return resultPayloads;
127
137
  }
128
138
  saveAccount() {
139
+ var _a;
129
140
  if (this.persistAccount) {
130
141
  const account = this.account;
131
- this.logger?.log(account.address);
142
+ (_a = this.logger) == null ? void 0 : _a.log(account.address);
132
143
  this.privateStorage.set("privateKey", account.private.hex);
133
144
  }
134
145
  }
@@ -137,7 +148,12 @@ class StorageArchivist extends AbstractArchivist {
137
148
  this.saveAccount();
138
149
  return true;
139
150
  }
140
- }
151
+ };
152
+ __name(_StorageArchivist, "StorageArchivist");
153
+ __publicField(_StorageArchivist, "configSchemas", [
154
+ StorageArchivistConfigSchema
155
+ ]);
156
+ var StorageArchivist = _StorageArchivist;
141
157
  export {
142
158
  StorageArchivist,
143
159
  StorageArchivistConfigSchema
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/StorageArchivist.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 ArchivistInstance,\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 store, { StoreBase } from 'store2'\n\nexport type StorageArchivistConfigSchema = 'network.xyo.archivist.storage.config'\nexport const StorageArchivistConfigSchema: StorageArchivistConfigSchema = 'network.xyo.archivist.storage.config'\n\nexport type StorageArchivistConfig = ArchivistConfig<{\n maxEntries?: number\n maxEntrySize?: number\n namespace?: string\n persistAccount?: boolean\n schema: StorageArchivistConfigSchema\n type?: 'local' | 'session' | 'page'\n}>\n\nexport type StorageArchivistParams = ArchivistParams<AnyConfigSchema<StorageArchivistConfig>>\nexport class StorageArchivist<\n TParams extends StorageArchivistParams = StorageArchivistParams,\n TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,\n >\n extends AbstractArchivist<TParams, TEventData>\n implements ArchivistInstance\n{\n static override configSchemas = [StorageArchivistConfigSchema]\n\n private _privateStorage: StoreBase | undefined\n private _storage: StoreBase | undefined\n\n get maxEntries() {\n return this.config?.maxEntries ?? 1000\n }\n\n get maxEntrySize() {\n return this.config?.maxEntrySize ?? 16000\n }\n\n get namespace() {\n return this.config?.namespace ?? 'xyo-archivist'\n }\n\n get persistAccount() {\n return this.config?.persistAccount ?? false\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 get type() {\n return this.config?.type ?? 'local'\n }\n\n /* This has to be a getter so that it can access it during construction */\n private get privateStorage(): StoreBase {\n this._privateStorage = this._storage ?? store[this.type].namespace(`${this.namespace}|private`)\n return this._privateStorage\n }\n\n /* This has to be a getter so that it can access it during construction */\n private get storage(): StoreBase {\n this._storage = this._storage ?? store[this.type].namespace(this.namespace)\n return this._storage\n }\n\n /*override async loadAccount(account?: AccountInstance, persistAccount?: boolean, privateStorage?: StoreBase, _logger?: Logger) {\n if (!this._account) {\n if (persistAccount) {\n const privateKey = privateStorage?.get('privateKey')\n if (privateKey) {\n try {\n this._account = await Account.create({ privateKey })\n return this._account\n } catch (ex) {\n console.error(`Error reading Account from storage [${ex}] - Recreating Account`)\n privateStorage?.remove('privateKey')\n }\n }\n }\n }\n return await super.loadAccount()\n }*/\n\n protected override allHandler(): PromisableArray<Payload> {\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\n return Object.entries(this.storage.getAll()).map(([, value]) => value)\n }\n\n protected override clearHandler(): void | Promise<void> {\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\n this.storage.clear()\n return this.emit('cleared', { module: this })\n }\n\n protected override async commitHandler(): Promise<BoundWitness[]> {\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\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 // TODO - rather than clear, delete the payloads that come back as successfully inserted\n await this.clear()\n return compact(settled.filter(fulfilled).map((result) => result.value))\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 this.storage.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 return this.storage.get(hash)\n }),\n )\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {\n const resultPayloads = await Promise.all(\n payloads.map(async (payload) => {\n const wrapper = PayloadWrapper.wrap(payload)\n const hash = await wrapper.hashAsync()\n const value = JSON.stringify(wrapper.payload())\n assertEx(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`)\n this.storage.set(hash, wrapper.payload())\n return wrapper.payload()\n }),\n )\n return resultPayloads\n }\n\n protected saveAccount() {\n if (this.persistAccount) {\n const account = this.account\n this.logger?.log(account.address)\n this.privateStorage.set('privateKey', account.private.hex)\n }\n }\n\n protected override async startHandler() {\n await super.startHandler()\n this.saveAccount()\n return true\n }\n}\n"],"mappings":";;AAAA,SAASA,gBAAgB;AACzB,SAASC,eAAe;AACxB,SAASC,iBAAiB;AAC1B,SAASC,yBAAyB;AAClC,SACEC,yBACAC,2BACAC,4BAEAC,4BAEAC,kCAIK;AAEP,SAASC,qBAAqB;AAG9B,SAASC,sBAAsB;AAE/B,OAAOC,WAA0B;AAG1B,MAAMC,+BAA6D;AAYnE,MAAMC,yBAIHV,kBAAAA;EAzCV,OAyCUA;;;EAGR,OAAgBW,gBAAgB;IAACF;;EAEzBG;EACAC;EAER,IAAIC,aAAa;AACf,WAAO,KAAKC,QAAQD,cAAc;EACpC;EAEA,IAAIE,eAAe;AACjB,WAAO,KAAKD,QAAQC,gBAAgB;EACtC;EAEA,IAAIC,YAAY;AACd,WAAO,KAAKF,QAAQE,aAAa;EACnC;EAEA,IAAIC,iBAAiB;AACnB,WAAO,KAAKH,QAAQG,kBAAkB;EACxC;EAEA,IAAaC,UAAoB;AAC/B,WAAO;MACLlB;MACAG;MACAF;MACAG;MACAF;SACG,MAAMgB;;EAEb;EAEA,IAAIC,OAAO;AACT,WAAO,KAAKL,QAAQK,QAAQ;EAC9B;;EAGA,IAAYC,iBAA4B;AACtC,SAAKT,kBAAkB,KAAKC,YAAYL,MAAM,KAAKY,IAAI,EAAEH,UAAU,GAAG,KAAKA,SAAS,UAAU;AAC9F,WAAO,KAAKL;EACd;;EAGA,IAAYU,UAAqB;AAC/B,SAAKT,WAAW,KAAKA,YAAYL,MAAM,KAAKY,IAAI,EAAEH,UAAU,KAAKA,SAAS;AAC1E,WAAO,KAAKJ;EACd;;;;;;;;;;;;;;;;;;EAoBmBU,aAAuC;AACxD,SAAKC,QAAQC,IAAI,wBAAwB,KAAKH,QAAQI,MAAM,EAAE;AAC9D,WAAOC,OAAOC,QAAQ,KAAKN,QAAQO,OAAM,CAAA,EAAIC,IAAI,CAAC,CAAA,EAAGC,KAAAA,MAAWA,KAAAA;EAClE;EAEmBC,eAAqC;AACtD,SAAKR,QAAQC,IAAI,wBAAwB,KAAKH,QAAQI,MAAM,EAAE;AAC9D,SAAKJ,QAAQW,MAAK;AAClB,WAAO,KAAKC,KAAK,WAAW;MAAEC,QAAQ;IAAK,CAAA;EAC7C;EAEA,MAAyBC,gBAAyC;AAChE,SAAKZ,QAAQC,IAAI,wBAAwB,KAAKH,QAAQI,MAAM,EAAE;AAC9D,UAAMW,WAAW,MAAM,KAAKC,IAAG;AAC/BzC,aAASwC,SAASX,SAAS,GAAG,mBAAA;AAC9B,UAAMa,UAAU,MAAMC,QAAQC,WAC5B3C,QACE6B,OAAOe,QAAQ,MAAM,KAAKC,QAAO,GAAIC,UAAU,CAAA,CAAE,GAAGd,IAAI,OAAOe,WAAAA;AAC7D,YAAMC,eAAqC;QACzCC,QAAQ1C;MACV;AACA,YAAM2C,QAAQ,MAAM,KAAKC,UAAUH,cAAcT,QAAAA;AACjD,cAAQ,MAAMQ,QAAQG,MAAMA,MAAM,CAAA,GAAIA,MAAM,CAAA,CAAE,KAAK,CAAA;IACrD,CAAA,CAAA,CAAA;AAIJ,UAAM,KAAKf,MAAK;AAChB,WAAOnC,QAAQyC,QAAQW,OAAOnD,SAAAA,EAAW+B,IAAI,CAACqB,WAAWA,OAAOpB,KAAK,CAAA;EACvE;EAEA,MAAyBqB,cAAcC,QAAqC;AAC1E,UAAMC,eAAoC,MAAMd,QAAQF,KACrD,MAAM,KAAKiB,IAAIF,MAAAA,GAASvB,IAAgC,OAAO0B,YAAY;MAAC,MAAMlD,cAAcmD,UAAUD,OAAAA;MAAUA;KAAQ,CAAA;AAE/H,UAAME,eAAoC5D,QACxC,MAAM0C,QAAQF,IACZgB,aAAaxB,IAAmC,CAAC,CAAC6B,MAAMH,OAAAA,MAAQ;AAC9D,WAAKlC,QAAQsC,OAAOD,IAAAA;AACpB,aAAO;QAACA;QAAMH;;IAChB,CAAA,CAAA,CAAA;AAGJ,WAAOE,aAAa5B,IAAI,CAAC,CAAC6B,IAAAA,MAAUA,IAAAA;EACtC;EAEmBE,WAAWR,QAAyC;AACrE,WAAOvD,QACLuD,OAAOvB,IAAI,CAAC6B,SAAAA;AACV,aAAO,KAAKrC,QAAQiC,IAAII,IAAAA;IAC1B,CAAA,CAAA;EAEJ;EAEA,MAAyBG,cAAczB,UAAyC;AAC9E,UAAM0B,iBAAiB,MAAMvB,QAAQF,IACnCD,SAASP,IAAI,OAAO0B,YAAAA;AAClB,YAAMQ,UAAUzD,eAAe0D,KAAKT,OAAAA;AACpC,YAAMG,OAAO,MAAMK,QAAQP,UAAS;AACpC,YAAM1B,QAAQmC,KAAKC,UAAUH,QAAQR,QAAO,CAAA;AAC5C3D,eAASkC,MAAML,SAAS,KAAKV,cAAc,sBAAsB2C,IAAAA,KAAS5B,MAAML,MAAM,GAAG;AACzF,WAAKJ,QAAQ8C,IAAIT,MAAMK,QAAQR,QAAO,CAAA;AACtC,aAAOQ,QAAQR,QAAO;IACxB,CAAA,CAAA;AAEF,WAAOO;EACT;EAEUM,cAAc;AACtB,QAAI,KAAKnD,gBAAgB;AACvB,YAAMoD,UAAU,KAAKA;AACrB,WAAK9C,QAAQC,IAAI6C,QAAQC,OAAO;AAChC,WAAKlD,eAAe+C,IAAI,cAAcE,QAAQE,QAAQC,GAAG;IAC3D;EACF;EAEA,MAAyBC,eAAe;AACtC,UAAM,MAAMA,aAAAA;AACZ,SAAKL,YAAW;AAChB,WAAO;EACT;AACF;","names":["assertEx","compact","fulfilled","AbstractArchivist","ArchivistAllQuerySchema","ArchivistClearQuerySchema","ArchivistCommitQuerySchema","ArchivistDeleteQuerySchema","ArchivistInsertQuerySchema","PayloadHasher","PayloadWrapper","store","StorageArchivistConfigSchema","StorageArchivist","configSchemas","_privateStorage","_storage","maxEntries","config","maxEntrySize","namespace","persistAccount","queries","type","privateStorage","storage","allHandler","logger","log","length","Object","entries","getAll","map","value","clearHandler","clear","emit","module","commitHandler","payloads","all","settled","Promise","allSettled","values","parents","commit","parent","queryPayload","schema","query","bindQuery","filter","result","deleteHandler","hashes","payloadPairs","get","payload","hashAsync","deletedPairs","hash","remove","getHandler","insertHandler","resultPayloads","wrapper","wrap","JSON","stringify","set","saveAccount","account","address","private","hex","startHandler"]}
1
+ {"version":3,"sources":["../../src/StorageArchivist.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 ArchivistInstance,\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 store, { StoreBase } from 'store2'\n\nexport type StorageArchivistConfigSchema = 'network.xyo.archivist.storage.config'\nexport const StorageArchivistConfigSchema: StorageArchivistConfigSchema = 'network.xyo.archivist.storage.config'\n\nexport type StorageArchivistConfig = ArchivistConfig<{\n maxEntries?: number\n maxEntrySize?: number\n namespace?: string\n persistAccount?: boolean\n schema: StorageArchivistConfigSchema\n type?: 'local' | 'session' | 'page'\n}>\n\nexport type StorageArchivistParams = ArchivistParams<AnyConfigSchema<StorageArchivistConfig>>\nexport class StorageArchivist<\n TParams extends StorageArchivistParams = StorageArchivistParams,\n TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,\n >\n extends AbstractArchivist<TParams, TEventData>\n implements ArchivistInstance\n{\n static override configSchemas = [StorageArchivistConfigSchema]\n\n private _privateStorage: StoreBase | undefined\n private _storage: StoreBase | undefined\n\n get maxEntries() {\n return this.config?.maxEntries ?? 1000\n }\n\n get maxEntrySize() {\n return this.config?.maxEntrySize ?? 16000\n }\n\n get namespace() {\n return this.config?.namespace ?? 'xyo-archivist'\n }\n\n get persistAccount() {\n return this.config?.persistAccount ?? false\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 get type() {\n return this.config?.type ?? 'local'\n }\n\n /* This has to be a getter so that it can access it during construction */\n private get privateStorage(): StoreBase {\n this._privateStorage = this._storage ?? store[this.type].namespace(`${this.namespace}|private`)\n return this._privateStorage\n }\n\n /* This has to be a getter so that it can access it during construction */\n private get storage(): StoreBase {\n this._storage = this._storage ?? store[this.type].namespace(this.namespace)\n return this._storage\n }\n\n /*override async loadAccount(account?: AccountInstance, persistAccount?: boolean, privateStorage?: StoreBase, _logger?: Logger) {\n if (!this._account) {\n if (persistAccount) {\n const privateKey = privateStorage?.get('privateKey')\n if (privateKey) {\n try {\n this._account = await Account.create({ privateKey })\n return this._account\n } catch (ex) {\n console.error(`Error reading Account from storage [${ex}] - Recreating Account`)\n privateStorage?.remove('privateKey')\n }\n }\n }\n }\n return await super.loadAccount()\n }*/\n\n protected override allHandler(): PromisableArray<Payload> {\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\n return Object.entries(this.storage.getAll()).map(([, value]) => value)\n }\n\n protected override clearHandler(): void | Promise<void> {\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\n this.storage.clear()\n return this.emit('cleared', { module: this })\n }\n\n protected override async commitHandler(): Promise<BoundWitness[]> {\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\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 // TODO - rather than clear, delete the payloads that come back as successfully inserted\n await this.clear()\n return compact(settled.filter(fulfilled).map((result) => result.value))\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 this.storage.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 return this.storage.get(hash)\n }),\n )\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {\n const resultPayloads = await Promise.all(\n payloads.map(async (payload) => {\n const wrapper = PayloadWrapper.wrap(payload)\n const hash = await wrapper.hashAsync()\n const value = JSON.stringify(wrapper.payload())\n assertEx(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`)\n this.storage.set(hash, wrapper.payload())\n return wrapper.payload()\n }),\n )\n return resultPayloads\n }\n\n protected saveAccount() {\n if (this.persistAccount) {\n const account = this.account\n this.logger?.log(account.address)\n this.privateStorage.set('privateKey', account.private.hex)\n }\n }\n\n protected override async startHandler() {\n await super.startHandler()\n this.saveAccount()\n return true\n }\n}\n"],"mappings":"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","names":["assertEx","compact","fulfilled","AbstractArchivist","ArchivistAllQuerySchema","ArchivistClearQuerySchema","ArchivistCommitQuerySchema","ArchivistDeleteQuerySchema","ArchivistInsertQuerySchema","PayloadHasher","PayloadWrapper","store","StorageArchivistConfigSchema","StorageArchivist","AbstractArchivist","_privateStorage","_storage","maxEntries","config","maxEntrySize","namespace","persistAccount","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","type","privateStorage","store","storage","allHandler","logger","log","length","Object","entries","getAll","map","value","clearHandler","clear","emit","module","commitHandler","payloads","all","assertEx","settled","Promise","allSettled","compact","values","parents","commit","parent","_a","queryPayload","schema","query","bindQuery","filter","fulfilled","result","deleteHandler","hashes","payloadPairs","get","payload","PayloadHasher","hashAsync","deletedPairs","hash","remove","getHandler","insertHandler","resultPayloads","wrapper","PayloadWrapper","wrap","JSON","stringify","set","saveAccount","account","address","private","hex","startHandler","configSchemas"]}
@@ -0,0 +1,8 @@
1
+ export * from './AbstractArchivingModule';
2
+ export * from './CookieArchivist';
3
+ export * from './StorageArchivist';
4
+ export * from '@xyo-network/archivist-abstract';
5
+ export * from '@xyo-network/archivist-model';
6
+ export * from '@xyo-network/archivist-wrapper';
7
+ export * from '@xyo-network/memory-archivist';
8
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,2BAA2B,CAAA;AACzC,cAAc,mBAAmB,CAAA;AACjC,cAAc,oBAAoB,CAAA;AAClC,cAAc,iCAAiC,CAAA;AAC/C,cAAc,8BAA8B,CAAA;AAC5C,cAAc,gCAAgC,CAAA;AAC9C,cAAc,+BAA+B,CAAA"}
@@ -1,8 +1,16 @@
1
1
  "use strict";
2
+ var __create = Object.create;
2
3
  var __defProp = Object.defineProperty;
3
4
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
5
  var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
5
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
+ };
6
14
  var __copyProps = (to, from, except, desc) => {
7
15
  if (from && typeof from === "object" || typeof from === "function") {
8
16
  for (let key of __getOwnPropNames(from))
@@ -12,21 +20,341 @@ var __copyProps = (to, from, except, desc) => {
12
20
  return to;
13
21
  };
14
22
  var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
23
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
24
+ // If the importer is in node compatibility mode or this is not an ESM
25
+ // file that has been converted to a CommonJS file using a Babel-
26
+ // compatible transform (i.e. "__esModule" has not been set), then set
27
+ // "default" to the CommonJS "module.exports" for node compatibility.
28
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
29
+ mod
30
+ ));
15
31
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
32
+ var __publicField = (obj, key, value) => {
33
+ __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
34
+ return value;
35
+ };
36
+
37
+ // src/index.ts
16
38
  var src_exports = {};
39
+ __export(src_exports, {
40
+ AbstractArchivingModule: () => AbstractArchivingModule,
41
+ CookieArchivist: () => CookieArchivist,
42
+ CookieArchivistConfigSchema: () => CookieArchivistConfigSchema,
43
+ StorageArchivist: () => StorageArchivist,
44
+ StorageArchivistConfigSchema: () => StorageArchivistConfigSchema
45
+ });
17
46
  module.exports = __toCommonJS(src_exports);
18
- __reExport(src_exports, require("./AbstractArchivingModule"), module.exports);
19
- __reExport(src_exports, require("./CookieArchivist"), module.exports);
20
- __reExport(src_exports, require("./StorageArchivist"), module.exports);
47
+
48
+ // src/AbstractArchivingModule.ts
49
+ var import_lodash = require("@xylabs/lodash");
50
+ var import_archivist_model = require("@xyo-network/archivist-model");
51
+ var import_module = require("@xyo-network/module");
52
+ var _AbstractArchivingModule = class _AbstractArchivingModule extends import_module.AbstractModuleInstance {
53
+ async bindQueryResult(query, payloads, additionalWitnesses = [], errorPayloads = []) {
54
+ const result = await super.bindQueryResult(query, payloads, additionalWitnesses, errorPayloads);
55
+ await this.storeToArchivists(result.flat());
56
+ return result;
57
+ }
58
+ async resolveArchivists() {
59
+ return (0, import_lodash.compact)((await Promise.all(await this.resolve({
60
+ address: this.config.archivists ?? []
61
+ }) ?? [])).map((module2) => (0, import_archivist_model.asArchivistInstance)(module2, () => `Module failed to cast to Archivist [${module2.config.name}]`)));
62
+ }
63
+ async storeToArchivists(payloads) {
64
+ const archivists = await this.resolveArchivists();
65
+ return (await Promise.all(archivists.map((archivist) => {
66
+ var _a;
67
+ return (_a = archivist.insert) == null ? void 0 : _a.call(archivist, payloads);
68
+ }))).map(([bw]) => bw);
69
+ }
70
+ };
71
+ __name(_AbstractArchivingModule, "AbstractArchivingModule");
72
+ var AbstractArchivingModule = _AbstractArchivingModule;
73
+
74
+ // src/CookieArchivist.ts
75
+ var import_assert = require("@xylabs/assert");
76
+ var import_lodash2 = require("@xylabs/lodash");
77
+ var import_promise = require("@xylabs/promise");
78
+ var import_archivist_abstract = require("@xyo-network/archivist-abstract");
79
+ var import_archivist_model2 = require("@xyo-network/archivist-model");
80
+ var import_core = require("@xyo-network/core");
81
+ var import_payload_wrapper = require("@xyo-network/payload-wrapper");
82
+ var import_js_cookie = __toESM(require("js-cookie"));
83
+ var CookieArchivistConfigSchema = "network.xyo.archivist.cookie.config";
84
+ var _CookieArchivist = class _CookieArchivist extends import_archivist_abstract.AbstractArchivist {
85
+ get domain() {
86
+ var _a;
87
+ return (_a = this.config) == null ? void 0 : _a.domain;
88
+ }
89
+ get maxEntries() {
90
+ var _a;
91
+ return ((_a = this.config) == null ? void 0 : _a.maxEntries) ?? 60;
92
+ }
93
+ get maxEntrySize() {
94
+ var _a;
95
+ return ((_a = this.config) == null ? void 0 : _a.maxEntrySize) ?? 4e3;
96
+ }
97
+ get namespace() {
98
+ var _a;
99
+ return ((_a = this.config) == null ? void 0 : _a.namespace) ?? "xyoarch";
100
+ }
101
+ get queries() {
102
+ return [
103
+ import_archivist_model2.ArchivistAllQuerySchema,
104
+ import_archivist_model2.ArchivistDeleteQuerySchema,
105
+ import_archivist_model2.ArchivistClearQuerySchema,
106
+ import_archivist_model2.ArchivistInsertQuerySchema,
107
+ import_archivist_model2.ArchivistCommitQuerySchema,
108
+ ...super.queries
109
+ ];
110
+ }
111
+ allHandler() {
112
+ try {
113
+ return Object.entries(import_js_cookie.default.get()).filter(([key]) => key.startsWith(`${this.namespace}-`)).map(([, value]) => JSON.parse(value));
114
+ } catch (ex) {
115
+ console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
116
+ throw ex;
117
+ }
118
+ }
119
+ clearHandler() {
120
+ try {
121
+ Object.entries(import_js_cookie.default.get()).map(([key]) => {
122
+ if (key.startsWith(`${this.namespace}-`)) {
123
+ import_js_cookie.default.remove(key);
124
+ }
125
+ });
126
+ } catch (ex) {
127
+ console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
128
+ throw ex;
129
+ }
130
+ }
131
+ async commitHandler() {
132
+ var _a;
133
+ try {
134
+ const payloads = await this.all();
135
+ (0, import_assert.assertEx)(payloads.length > 0, "Nothing to commit");
136
+ const settled = await Promise.allSettled((0, import_lodash2.compact)((_a = Object.values((await this.parents()).commit ?? [])) == null ? void 0 : _a.map(async (parent) => {
137
+ var _a2;
138
+ const queryPayload = {
139
+ schema: import_archivist_model2.ArchivistInsertQuerySchema
140
+ };
141
+ const query = await this.bindQuery(queryPayload, payloads);
142
+ return (_a2 = await (parent == null ? void 0 : parent.query(query[0], query[1]))) == null ? void 0 : _a2[0];
143
+ })));
144
+ await this.clear();
145
+ return (0, import_lodash2.compact)(settled.filter(import_promise.fulfilled).map((result) => result.value));
146
+ } catch (ex) {
147
+ console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
148
+ throw ex;
149
+ }
150
+ }
151
+ async deleteHandler(hashes) {
152
+ const payloadPairs = await Promise.all((await this.get(hashes)).map(async (payload) => [
153
+ await import_core.PayloadHasher.hashAsync(payload),
154
+ payload
155
+ ]));
156
+ const deletedPairs = (0, import_lodash2.compact)(await Promise.all(payloadPairs.map(([hash, payload]) => {
157
+ import_js_cookie.default.remove(hash);
158
+ return [
159
+ hash,
160
+ payload
161
+ ];
162
+ })));
163
+ return deletedPairs.map(([hash]) => hash);
164
+ }
165
+ getHandler(hashes) {
166
+ return (0, import_lodash2.compact)(hashes.map((hash) => {
167
+ const cookieString = import_js_cookie.default.get(this.keyFromHash(hash));
168
+ return cookieString ? JSON.parse(cookieString) : void 0;
169
+ }));
170
+ }
171
+ async insertHandler(payloads) {
172
+ try {
173
+ const resultPayloads = await Promise.all(payloads.map(async (payload) => {
174
+ const wrapper = import_payload_wrapper.PayloadWrapper.wrap(payload);
175
+ const key = this.keyFromHash(await wrapper.hashAsync());
176
+ const value = JSON.stringify(wrapper.payload());
177
+ (0, import_assert.assertEx)(value.length < this.maxEntrySize, `Payload too large [${wrapper.hashAsync()}, ${value.length}]`);
178
+ import_js_cookie.default.set(key, JSON.stringify(wrapper.payload()));
179
+ return wrapper.payload();
180
+ }));
181
+ return resultPayloads;
182
+ } catch (ex) {
183
+ console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
184
+ throw ex;
185
+ }
186
+ }
187
+ keyFromHash(hash) {
188
+ return `${this.namespace}-${hash}`;
189
+ }
190
+ };
191
+ __name(_CookieArchivist, "CookieArchivist");
192
+ __publicField(_CookieArchivist, "configSchemas", [
193
+ CookieArchivistConfigSchema
194
+ ]);
195
+ var CookieArchivist = _CookieArchivist;
196
+
197
+ // src/StorageArchivist.ts
198
+ var import_assert2 = require("@xylabs/assert");
199
+ var import_lodash3 = require("@xylabs/lodash");
200
+ var import_promise2 = require("@xylabs/promise");
201
+ var import_archivist_abstract2 = require("@xyo-network/archivist-abstract");
202
+ var import_archivist_model3 = require("@xyo-network/archivist-model");
203
+ var import_core2 = require("@xyo-network/core");
204
+ var import_payload_wrapper2 = require("@xyo-network/payload-wrapper");
205
+ var import_store2 = __toESM(require("store2"));
206
+ var StorageArchivistConfigSchema = "network.xyo.archivist.storage.config";
207
+ var _StorageArchivist = class _StorageArchivist extends import_archivist_abstract2.AbstractArchivist {
208
+ _privateStorage;
209
+ _storage;
210
+ get maxEntries() {
211
+ var _a;
212
+ return ((_a = this.config) == null ? void 0 : _a.maxEntries) ?? 1e3;
213
+ }
214
+ get maxEntrySize() {
215
+ var _a;
216
+ return ((_a = this.config) == null ? void 0 : _a.maxEntrySize) ?? 16e3;
217
+ }
218
+ get namespace() {
219
+ var _a;
220
+ return ((_a = this.config) == null ? void 0 : _a.namespace) ?? "xyo-archivist";
221
+ }
222
+ get persistAccount() {
223
+ var _a;
224
+ return ((_a = this.config) == null ? void 0 : _a.persistAccount) ?? false;
225
+ }
226
+ get queries() {
227
+ return [
228
+ import_archivist_model3.ArchivistAllQuerySchema,
229
+ import_archivist_model3.ArchivistDeleteQuerySchema,
230
+ import_archivist_model3.ArchivistClearQuerySchema,
231
+ import_archivist_model3.ArchivistInsertQuerySchema,
232
+ import_archivist_model3.ArchivistCommitQuerySchema,
233
+ ...super.queries
234
+ ];
235
+ }
236
+ get type() {
237
+ var _a;
238
+ return ((_a = this.config) == null ? void 0 : _a.type) ?? "local";
239
+ }
240
+ /* This has to be a getter so that it can access it during construction */
241
+ get privateStorage() {
242
+ this._privateStorage = this._storage ?? import_store2.default[this.type].namespace(`${this.namespace}|private`);
243
+ return this._privateStorage;
244
+ }
245
+ /* This has to be a getter so that it can access it during construction */
246
+ get storage() {
247
+ this._storage = this._storage ?? import_store2.default[this.type].namespace(this.namespace);
248
+ return this._storage;
249
+ }
250
+ /*override async loadAccount(account?: AccountInstance, persistAccount?: boolean, privateStorage?: StoreBase, _logger?: Logger) {
251
+ if (!this._account) {
252
+ if (persistAccount) {
253
+ const privateKey = privateStorage?.get('privateKey')
254
+ if (privateKey) {
255
+ try {
256
+ this._account = await Account.create({ privateKey })
257
+ return this._account
258
+ } catch (ex) {
259
+ console.error(`Error reading Account from storage [${ex}] - Recreating Account`)
260
+ privateStorage?.remove('privateKey')
261
+ }
262
+ }
263
+ }
264
+ }
265
+ return await super.loadAccount()
266
+ }*/
267
+ allHandler() {
268
+ var _a;
269
+ (_a = this.logger) == null ? void 0 : _a.log(`this.storage.length: ${this.storage.length}`);
270
+ return Object.entries(this.storage.getAll()).map(([, value]) => value);
271
+ }
272
+ clearHandler() {
273
+ var _a;
274
+ (_a = this.logger) == null ? void 0 : _a.log(`this.storage.length: ${this.storage.length}`);
275
+ this.storage.clear();
276
+ return this.emit("cleared", {
277
+ module: this
278
+ });
279
+ }
280
+ async commitHandler() {
281
+ var _a, _b;
282
+ (_a = this.logger) == null ? void 0 : _a.log(`this.storage.length: ${this.storage.length}`);
283
+ const payloads = await this.all();
284
+ (0, import_assert2.assertEx)(payloads.length > 0, "Nothing to commit");
285
+ const settled = await Promise.allSettled((0, import_lodash3.compact)((_b = Object.values((await this.parents()).commit ?? [])) == null ? void 0 : _b.map(async (parent) => {
286
+ var _a2;
287
+ const queryPayload = {
288
+ schema: import_archivist_model3.ArchivistInsertQuerySchema
289
+ };
290
+ const query = await this.bindQuery(queryPayload, payloads);
291
+ return (_a2 = await (parent == null ? void 0 : parent.query(query[0], query[1]))) == null ? void 0 : _a2[0];
292
+ })));
293
+ await this.clear();
294
+ return (0, import_lodash3.compact)(settled.filter(import_promise2.fulfilled).map((result) => result.value));
295
+ }
296
+ async deleteHandler(hashes) {
297
+ const payloadPairs = await Promise.all((await this.get(hashes)).map(async (payload) => [
298
+ await import_core2.PayloadHasher.hashAsync(payload),
299
+ payload
300
+ ]));
301
+ const deletedPairs = (0, import_lodash3.compact)(await Promise.all(payloadPairs.map(([hash, payload]) => {
302
+ this.storage.remove(hash);
303
+ return [
304
+ hash,
305
+ payload
306
+ ];
307
+ })));
308
+ return deletedPairs.map(([hash]) => hash);
309
+ }
310
+ getHandler(hashes) {
311
+ return (0, import_lodash3.compact)(hashes.map((hash) => {
312
+ return this.storage.get(hash);
313
+ }));
314
+ }
315
+ async insertHandler(payloads) {
316
+ const resultPayloads = await Promise.all(payloads.map(async (payload) => {
317
+ const wrapper = import_payload_wrapper2.PayloadWrapper.wrap(payload);
318
+ const hash = await wrapper.hashAsync();
319
+ const value = JSON.stringify(wrapper.payload());
320
+ (0, import_assert2.assertEx)(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`);
321
+ this.storage.set(hash, wrapper.payload());
322
+ return wrapper.payload();
323
+ }));
324
+ return resultPayloads;
325
+ }
326
+ saveAccount() {
327
+ var _a;
328
+ if (this.persistAccount) {
329
+ const account = this.account;
330
+ (_a = this.logger) == null ? void 0 : _a.log(account.address);
331
+ this.privateStorage.set("privateKey", account.private.hex);
332
+ }
333
+ }
334
+ async startHandler() {
335
+ await super.startHandler();
336
+ this.saveAccount();
337
+ return true;
338
+ }
339
+ };
340
+ __name(_StorageArchivist, "StorageArchivist");
341
+ __publicField(_StorageArchivist, "configSchemas", [
342
+ StorageArchivistConfigSchema
343
+ ]);
344
+ var StorageArchivist = _StorageArchivist;
345
+
346
+ // src/index.ts
21
347
  __reExport(src_exports, require("@xyo-network/archivist-abstract"), module.exports);
22
348
  __reExport(src_exports, require("@xyo-network/archivist-model"), module.exports);
23
349
  __reExport(src_exports, require("@xyo-network/archivist-wrapper"), module.exports);
24
350
  __reExport(src_exports, require("@xyo-network/memory-archivist"), module.exports);
25
351
  // Annotate the CommonJS export names for ESM import in node:
26
352
  0 && (module.exports = {
27
- ...require("./AbstractArchivingModule"),
28
- ...require("./CookieArchivist"),
29
- ...require("./StorageArchivist"),
353
+ AbstractArchivingModule,
354
+ CookieArchivist,
355
+ CookieArchivistConfigSchema,
356
+ StorageArchivist,
357
+ StorageArchivistConfigSchema,
30
358
  ...require("@xyo-network/archivist-abstract"),
31
359
  ...require("@xyo-network/archivist-model"),
32
360
  ...require("@xyo-network/archivist-wrapper"),