@xyo-network/archivist 2.85.3 → 2.85.5

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 (49) hide show
  1. package/dist/browser/index.cjs +1 -282
  2. package/dist/browser/index.cjs.map +1 -1
  3. package/dist/browser/index.d.cts +1 -3
  4. package/dist/browser/index.d.cts.map +1 -1
  5. package/dist/browser/index.d.mts +1 -3
  6. package/dist/browser/index.d.mts.map +1 -1
  7. package/dist/browser/index.d.ts +1 -3
  8. package/dist/browser/index.d.ts.map +1 -1
  9. package/dist/browser/index.js +1 -268
  10. package/dist/browser/index.js.map +1 -1
  11. package/dist/node/index.cjs +3 -307
  12. package/dist/node/index.cjs.map +1 -1
  13. package/dist/node/index.d.cts +1 -3
  14. package/dist/node/index.d.cts.map +1 -1
  15. package/dist/node/index.d.mts +1 -3
  16. package/dist/node/index.d.mts.map +1 -1
  17. package/dist/node/index.d.ts +1 -3
  18. package/dist/node/index.d.ts.map +1 -1
  19. package/dist/node/index.js +1 -287
  20. package/dist/node/index.js.map +1 -1
  21. package/package.json +5 -21
  22. package/src/index.ts +1 -3
  23. package/dist/browser/CookieArchivist.d.cts +0 -32
  24. package/dist/browser/CookieArchivist.d.cts.map +0 -1
  25. package/dist/browser/CookieArchivist.d.mts +0 -32
  26. package/dist/browser/CookieArchivist.d.mts.map +0 -1
  27. package/dist/browser/CookieArchivist.d.ts +0 -32
  28. package/dist/browser/CookieArchivist.d.ts.map +0 -1
  29. package/dist/browser/StorageArchivist.d.cts +0 -39
  30. package/dist/browser/StorageArchivist.d.cts.map +0 -1
  31. package/dist/browser/StorageArchivist.d.mts +0 -39
  32. package/dist/browser/StorageArchivist.d.mts.map +0 -1
  33. package/dist/browser/StorageArchivist.d.ts +0 -39
  34. package/dist/browser/StorageArchivist.d.ts.map +0 -1
  35. package/dist/node/CookieArchivist.d.cts +0 -32
  36. package/dist/node/CookieArchivist.d.cts.map +0 -1
  37. package/dist/node/CookieArchivist.d.mts +0 -32
  38. package/dist/node/CookieArchivist.d.mts.map +0 -1
  39. package/dist/node/CookieArchivist.d.ts +0 -32
  40. package/dist/node/CookieArchivist.d.ts.map +0 -1
  41. package/dist/node/StorageArchivist.d.cts +0 -39
  42. package/dist/node/StorageArchivist.d.cts.map +0 -1
  43. package/dist/node/StorageArchivist.d.mts +0 -39
  44. package/dist/node/StorageArchivist.d.mts.map +0 -1
  45. package/dist/node/StorageArchivist.d.ts +0 -39
  46. package/dist/node/StorageArchivist.d.ts.map +0 -1
  47. package/src/CookieArchivist.ts +0 -164
  48. package/src/StorageArchivist.ts +0 -191
  49. package/src/spec/testArchivist.ts +0 -50
@@ -1,15 +1,8 @@
1
1
  "use strict";
2
- var __create = Object.create;
3
2
  var __defProp = Object.defineProperty;
4
3
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
4
  var __getOwnPropNames = Object.getOwnPropertyNames;
6
- var __getProtoOf = Object.getPrototypeOf;
7
5
  var __hasOwnProp = Object.prototype.hasOwnProperty;
8
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
9
- var __export = (target, all) => {
10
- for (var name in all)
11
- __defProp(target, name, { get: all[name], enumerable: true });
12
- };
13
6
  var __copyProps = (to, from, except, desc) => {
14
7
  if (from && typeof from === "object" || typeof from === "function") {
15
8
  for (let key of __getOwnPropNames(from))
@@ -19,287 +12,13 @@ var __copyProps = (to, from, except, desc) => {
19
12
  return to;
20
13
  };
21
14
  var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
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
15
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
31
16
 
32
17
  // src/index.ts
33
18
  var src_exports = {};
34
- __export(src_exports, {
35
- CookieArchivist: () => CookieArchivist,
36
- CookieArchivistConfigSchema: () => CookieArchivistConfigSchema,
37
- StorageArchivist: () => StorageArchivist,
38
- StorageArchivistConfigSchema: () => StorageArchivistConfigSchema
39
- });
40
19
  module.exports = __toCommonJS(src_exports);
41
-
42
- // src/CookieArchivist.ts
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_hash = require("@xyo-network/hash");
49
- var import_payload_wrapper = require("@xyo-network/payload-wrapper");
50
- var import_js_cookie = __toESM(require("js-cookie"), 1);
51
- var CookieArchivistConfigSchema = "network.xyo.archivist.cookie.config";
52
- var CookieArchivist = class extends import_archivist_abstract.AbstractArchivist {
53
- static {
54
- __name(this, "CookieArchivist");
55
- }
56
- static configSchemas = [
57
- CookieArchivistConfigSchema
58
- ];
59
- get domain() {
60
- return this.config?.domain;
61
- }
62
- get maxEntries() {
63
- return this.config?.maxEntries ?? 60;
64
- }
65
- get maxEntrySize() {
66
- return this.config?.maxEntrySize ?? 4e3;
67
- }
68
- get namespace() {
69
- return this.config?.namespace ?? "xyoarch";
70
- }
71
- get queries() {
72
- return [
73
- import_archivist_model.ArchivistAllQuerySchema,
74
- import_archivist_model.ArchivistDeleteQuerySchema,
75
- import_archivist_model.ArchivistClearQuerySchema,
76
- import_archivist_model.ArchivistInsertQuerySchema,
77
- import_archivist_model.ArchivistCommitQuerySchema,
78
- ...super.queries
79
- ];
80
- }
81
- allHandler() {
82
- try {
83
- return Object.entries(import_js_cookie.default.get()).filter(([key]) => key.startsWith(`${this.namespace}-`)).map(([, value]) => JSON.parse(value));
84
- } catch (ex) {
85
- console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
86
- throw ex;
87
- }
88
- }
89
- clearHandler() {
90
- try {
91
- Object.entries(import_js_cookie.default.get()).map(([key]) => {
92
- if (key.startsWith(`${this.namespace}-`)) {
93
- import_js_cookie.default.remove(key);
94
- }
95
- });
96
- } catch (ex) {
97
- console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
98
- throw ex;
99
- }
100
- }
101
- async commitHandler() {
102
- try {
103
- const payloads = await this.all();
104
- (0, import_assert.assertEx)(payloads.length > 0, "Nothing to commit");
105
- const settled = await Promise.allSettled((0, import_lodash.compact)(Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {
106
- const queryPayload = {
107
- schema: import_archivist_model.ArchivistInsertQuerySchema
108
- };
109
- const query = await this.bindQuery(queryPayload, payloads);
110
- return (await parent?.query(query[0], query[1]))?.[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_hash.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
-
160
- // src/StorageArchivist.ts
161
- var import_assert2 = require("@xylabs/assert");
162
- var import_lodash2 = require("@xylabs/lodash");
163
- var import_promise2 = require("@xylabs/promise");
164
- var import_archivist_abstract2 = require("@xyo-network/archivist-abstract");
165
- var import_archivist_model2 = require("@xyo-network/archivist-model");
166
- var import_hash2 = require("@xyo-network/hash");
167
- var import_payload_wrapper2 = require("@xyo-network/payload-wrapper");
168
- var import_store2 = __toESM(require("store2"), 1);
169
- var StorageArchivistConfigSchema = "network.xyo.archivist.storage.config";
170
- var StorageArchivist = class extends import_archivist_abstract2.AbstractArchivist {
171
- static {
172
- __name(this, "StorageArchivist");
173
- }
174
- static configSchemas = [
175
- StorageArchivistConfigSchema
176
- ];
177
- _privateStorage;
178
- _storage;
179
- get maxEntries() {
180
- return this.config?.maxEntries ?? 1e3;
181
- }
182
- get maxEntrySize() {
183
- return this.config?.maxEntrySize ?? 16e3;
184
- }
185
- get namespace() {
186
- return this.config?.namespace ?? "xyo-archivist";
187
- }
188
- get persistAccount() {
189
- return this.config?.persistAccount ?? false;
190
- }
191
- get queries() {
192
- return [
193
- import_archivist_model2.ArchivistAllQuerySchema,
194
- import_archivist_model2.ArchivistDeleteQuerySchema,
195
- import_archivist_model2.ArchivistClearQuerySchema,
196
- import_archivist_model2.ArchivistInsertQuerySchema,
197
- import_archivist_model2.ArchivistCommitQuerySchema,
198
- ...super.queries
199
- ];
200
- }
201
- get type() {
202
- return this.config?.type ?? "local";
203
- }
204
- /* This has to be a getter so that it can access it during construction */
205
- get privateStorage() {
206
- this._privateStorage = this._storage ?? import_store2.default[this.type].namespace(`${this.namespace}|private`);
207
- return this._privateStorage;
208
- }
209
- /* This has to be a getter so that it can access it during construction */
210
- get storage() {
211
- this._storage = this._storage ?? import_store2.default[this.type].namespace(this.namespace);
212
- return this._storage;
213
- }
214
- /*override async loadAccount(account?: AccountInstance, persistAccount?: boolean, privateStorage?: StoreBase, _logger?: Logger) {
215
- if (!this._account) {
216
- if (persistAccount) {
217
- const privateKey = privateStorage?.get('privateKey')
218
- if (privateKey) {
219
- try {
220
- this._account = await Account.create({ privateKey })
221
- return this._account
222
- } catch (ex) {
223
- console.error(`Error reading Account from storage [${ex}] - Recreating Account`)
224
- privateStorage?.remove('privateKey')
225
- }
226
- }
227
- }
228
- }
229
- return await super.loadAccount()
230
- }*/
231
- allHandler() {
232
- this.logger?.log(`this.storage.length: ${this.storage.length}`);
233
- return Object.entries(this.storage.getAll()).map(([, value]) => value);
234
- }
235
- clearHandler() {
236
- this.logger?.log(`this.storage.length: ${this.storage.length}`);
237
- this.storage.clear();
238
- return this.emit("cleared", {
239
- module: this
240
- });
241
- }
242
- async commitHandler() {
243
- this.logger?.log(`this.storage.length: ${this.storage.length}`);
244
- const payloads = await this.all();
245
- (0, import_assert2.assertEx)(payloads.length > 0, "Nothing to commit");
246
- const settled = await Promise.allSettled((0, import_lodash2.compact)(Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {
247
- const queryPayload = {
248
- schema: import_archivist_model2.ArchivistInsertQuerySchema
249
- };
250
- const query = await this.bindQuery(queryPayload, payloads);
251
- return (await parent?.query(query[0], query[1]))?.[0];
252
- })));
253
- await this.clear();
254
- return (0, import_lodash2.compact)(settled.filter(import_promise2.fulfilled).map((result) => result.value));
255
- }
256
- async deleteHandler(hashes) {
257
- const payloadPairs = await Promise.all((await this.get(hashes)).map(async (payload) => [
258
- await import_hash2.PayloadHasher.hashAsync(payload),
259
- payload
260
- ]));
261
- const deletedPairs = (0, import_lodash2.compact)(await Promise.all(payloadPairs.map(([hash, payload]) => {
262
- this.storage.remove(hash);
263
- return [
264
- hash,
265
- payload
266
- ];
267
- })));
268
- return deletedPairs.map(([hash]) => hash);
269
- }
270
- getHandler(hashes) {
271
- return (0, import_lodash2.compact)(hashes.map((hash) => {
272
- return this.storage.get(hash);
273
- }));
274
- }
275
- async insertHandler(payloads) {
276
- const resultPayloads = await Promise.all(payloads.map(async (payload) => {
277
- const wrapper = import_payload_wrapper2.PayloadWrapper.wrap(payload);
278
- const hash = await wrapper.hashAsync();
279
- const value = JSON.stringify(wrapper.payload());
280
- (0, import_assert2.assertEx)(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`);
281
- this.storage.set(hash, wrapper.payload());
282
- return wrapper.payload();
283
- }));
284
- return resultPayloads;
285
- }
286
- saveAccount() {
287
- if (this.persistAccount) {
288
- const account = this.account;
289
- this.logger?.log(account.address);
290
- this.privateStorage.set("privateKey", account.private.hex);
291
- }
292
- }
293
- async startHandler() {
294
- await super.startHandler();
295
- this.saveAccount();
296
- return true;
297
- }
298
- };
299
-
300
- // src/index.ts
301
20
  __reExport(src_exports, require("@xyo-network/archivist-abstract"), module.exports);
21
+ __reExport(src_exports, require("@xyo-network/archivist-memory"), module.exports);
302
22
  __reExport(src_exports, require("@xyo-network/archivist-model"), module.exports);
303
23
  __reExport(src_exports, require("@xyo-network/archivist-wrapper"), module.exports);
304
- __reExport(src_exports, require("@xyo-network/memory-archivist"), module.exports);
305
24
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/CookieArchivist.ts","../../src/StorageArchivist.ts"],"sourcesContent":["export * from './CookieArchivist'\nexport * from './StorageArchivist'\nexport * from '@xyo-network/archivist-abstract'\nexport * from '@xyo-network/archivist-model'\nexport * from '@xyo-network/archivist-wrapper'\nexport * from '@xyo-network/memory-archivist'\n","import { assertEx } from '@xylabs/assert'\nimport { compact } from '@xylabs/lodash'\nimport { fulfilled, Promisable, PromisableArray } 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/hash'\nimport { AnyConfigSchema } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\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","import { assertEx } from '@xylabs/assert'\nimport { compact } from '@xylabs/lodash'\nimport { fulfilled, Promisable, PromisableArray } 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/hash'\nimport { AnyConfigSchema } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\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 ?? 16_000\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":["CookieArchivistConfigSchema","CookieArchivist","AbstractArchivist","configSchemas","domain","config","maxEntries","maxEntrySize","namespace","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","allHandler","Object","entries","Cookies","get","filter","key","startsWith","map","value","JSON","parse","ex","console","error","stringify","clearHandler","remove","commitHandler","payloads","all","assertEx","length","settled","Promise","allSettled","compact","values","parents","commit","parent","queryPayload","schema","query","bindQuery","clear","fulfilled","result","deleteHandler","hashes","payloadPairs","payload","PayloadHasher","hashAsync","deletedPairs","hash","getHandler","cookieString","keyFromHash","undefined","insertHandler","resultPayloads","wrapper","PayloadWrapper","wrap","set","import_assert","import_lodash","import_promise","import_archivist_abstract","import_archivist_model","import_hash","import_payload_wrapper","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/index.ts"],"sourcesContent":["export * from '@xyo-network/archivist-abstract'\nexport * from '@xyo-network/archivist-memory'\nexport * from '@xyo-network/archivist-model'\nexport * from '@xyo-network/archivist-wrapper'\n"],"mappings":";;;;;;;;;;;;;;;;;AAAA;;wBAAc,4CAAd;AACA,wBAAc,0CADd;AAEA,wBAAc,yCAFd;AAGA,wBAAc,2CAHd;","names":[]}
@@ -1,7 +1,5 @@
1
- export * from './CookieArchivist';
2
- export * from './StorageArchivist';
3
1
  export * from '@xyo-network/archivist-abstract';
2
+ export * from '@xyo-network/archivist-memory';
4
3
  export * from '@xyo-network/archivist-model';
5
4
  export * from '@xyo-network/archivist-wrapper';
6
- export * from '@xyo-network/memory-archivist';
7
5
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,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
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,iCAAiC,CAAA;AAC/C,cAAc,+BAA+B,CAAA;AAC7C,cAAc,8BAA8B,CAAA;AAC5C,cAAc,gCAAgC,CAAA"}
@@ -1,7 +1,5 @@
1
- export * from './CookieArchivist';
2
- export * from './StorageArchivist';
3
1
  export * from '@xyo-network/archivist-abstract';
2
+ export * from '@xyo-network/archivist-memory';
4
3
  export * from '@xyo-network/archivist-model';
5
4
  export * from '@xyo-network/archivist-wrapper';
6
- export * from '@xyo-network/memory-archivist';
7
5
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,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
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,iCAAiC,CAAA;AAC/C,cAAc,+BAA+B,CAAA;AAC7C,cAAc,8BAA8B,CAAA;AAC5C,cAAc,gCAAgC,CAAA"}
@@ -1,7 +1,5 @@
1
- export * from './CookieArchivist';
2
- export * from './StorageArchivist';
3
1
  export * from '@xyo-network/archivist-abstract';
2
+ export * from '@xyo-network/archivist-memory';
4
3
  export * from '@xyo-network/archivist-model';
5
4
  export * from '@xyo-network/archivist-wrapper';
6
- export * from '@xyo-network/memory-archivist';
7
5
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,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
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,iCAAiC,CAAA;AAC/C,cAAc,+BAA+B,CAAA;AAC7C,cAAc,8BAA8B,CAAA;AAC5C,cAAc,gCAAgC,CAAA"}
@@ -1,273 +1,6 @@
1
- var __defProp = Object.defineProperty;
2
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
-
4
- // src/CookieArchivist.ts
5
- import { assertEx } from "@xylabs/assert";
6
- import { compact } from "@xylabs/lodash";
7
- import { fulfilled } from "@xylabs/promise";
8
- import { AbstractArchivist } from "@xyo-network/archivist-abstract";
9
- import { ArchivistAllQuerySchema, ArchivistClearQuerySchema, ArchivistCommitQuerySchema, ArchivistDeleteQuerySchema, ArchivistInsertQuerySchema } from "@xyo-network/archivist-model";
10
- import { PayloadHasher } from "@xyo-network/hash";
11
- import { PayloadWrapper } from "@xyo-network/payload-wrapper";
12
- import Cookies from "js-cookie";
13
- var CookieArchivistConfigSchema = "network.xyo.archivist.cookie.config";
14
- var CookieArchivist = class extends AbstractArchivist {
15
- static {
16
- __name(this, "CookieArchivist");
17
- }
18
- static configSchemas = [
19
- CookieArchivistConfigSchema
20
- ];
21
- get domain() {
22
- return this.config?.domain;
23
- }
24
- get maxEntries() {
25
- return this.config?.maxEntries ?? 60;
26
- }
27
- get maxEntrySize() {
28
- return this.config?.maxEntrySize ?? 4e3;
29
- }
30
- get namespace() {
31
- return this.config?.namespace ?? "xyoarch";
32
- }
33
- get queries() {
34
- return [
35
- ArchivistAllQuerySchema,
36
- ArchivistDeleteQuerySchema,
37
- ArchivistClearQuerySchema,
38
- ArchivistInsertQuerySchema,
39
- ArchivistCommitQuerySchema,
40
- ...super.queries
41
- ];
42
- }
43
- allHandler() {
44
- try {
45
- return Object.entries(Cookies.get()).filter(([key]) => key.startsWith(`${this.namespace}-`)).map(([, value]) => JSON.parse(value));
46
- } catch (ex) {
47
- console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
48
- throw ex;
49
- }
50
- }
51
- clearHandler() {
52
- try {
53
- Object.entries(Cookies.get()).map(([key]) => {
54
- if (key.startsWith(`${this.namespace}-`)) {
55
- Cookies.remove(key);
56
- }
57
- });
58
- } catch (ex) {
59
- console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
60
- throw ex;
61
- }
62
- }
63
- async commitHandler() {
64
- try {
65
- const payloads = await this.all();
66
- assertEx(payloads.length > 0, "Nothing to commit");
67
- const settled = await Promise.allSettled(compact(Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {
68
- const queryPayload = {
69
- schema: ArchivistInsertQuerySchema
70
- };
71
- const query = await this.bindQuery(queryPayload, payloads);
72
- return (await parent?.query(query[0], query[1]))?.[0];
73
- })));
74
- await this.clear();
75
- return compact(settled.filter(fulfilled).map((result) => result.value));
76
- } catch (ex) {
77
- console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
78
- throw ex;
79
- }
80
- }
81
- async deleteHandler(hashes) {
82
- const payloadPairs = await Promise.all((await this.get(hashes)).map(async (payload) => [
83
- await PayloadHasher.hashAsync(payload),
84
- payload
85
- ]));
86
- const deletedPairs = compact(await Promise.all(payloadPairs.map(([hash, payload]) => {
87
- Cookies.remove(hash);
88
- return [
89
- hash,
90
- payload
91
- ];
92
- })));
93
- return deletedPairs.map(([hash]) => hash);
94
- }
95
- getHandler(hashes) {
96
- return compact(hashes.map((hash) => {
97
- const cookieString = Cookies.get(this.keyFromHash(hash));
98
- return cookieString ? JSON.parse(cookieString) : void 0;
99
- }));
100
- }
101
- async insertHandler(payloads) {
102
- try {
103
- const resultPayloads = await Promise.all(payloads.map(async (payload) => {
104
- const wrapper = PayloadWrapper.wrap(payload);
105
- const key = this.keyFromHash(await wrapper.hashAsync());
106
- const value = JSON.stringify(wrapper.payload());
107
- assertEx(value.length < this.maxEntrySize, `Payload too large [${wrapper.hashAsync()}, ${value.length}]`);
108
- Cookies.set(key, JSON.stringify(wrapper.payload()));
109
- return wrapper.payload();
110
- }));
111
- return resultPayloads;
112
- } catch (ex) {
113
- console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
114
- throw ex;
115
- }
116
- }
117
- keyFromHash(hash) {
118
- return `${this.namespace}-${hash}`;
119
- }
120
- };
121
-
122
- // src/StorageArchivist.ts
123
- import { assertEx as assertEx2 } from "@xylabs/assert";
124
- import { compact as compact2 } from "@xylabs/lodash";
125
- import { fulfilled as fulfilled2 } from "@xylabs/promise";
126
- import { AbstractArchivist as AbstractArchivist2 } from "@xyo-network/archivist-abstract";
127
- import { ArchivistAllQuerySchema as ArchivistAllQuerySchema2, ArchivistClearQuerySchema as ArchivistClearQuerySchema2, ArchivistCommitQuerySchema as ArchivistCommitQuerySchema2, ArchivistDeleteQuerySchema as ArchivistDeleteQuerySchema2, ArchivistInsertQuerySchema as ArchivistInsertQuerySchema2 } from "@xyo-network/archivist-model";
128
- import { PayloadHasher as PayloadHasher2 } from "@xyo-network/hash";
129
- import { PayloadWrapper as PayloadWrapper2 } from "@xyo-network/payload-wrapper";
130
- import store from "store2";
131
- var StorageArchivistConfigSchema = "network.xyo.archivist.storage.config";
132
- var StorageArchivist = class extends AbstractArchivist2 {
133
- static {
134
- __name(this, "StorageArchivist");
135
- }
136
- static configSchemas = [
137
- StorageArchivistConfigSchema
138
- ];
139
- _privateStorage;
140
- _storage;
141
- get maxEntries() {
142
- return this.config?.maxEntries ?? 1e3;
143
- }
144
- get maxEntrySize() {
145
- return this.config?.maxEntrySize ?? 16e3;
146
- }
147
- get namespace() {
148
- return this.config?.namespace ?? "xyo-archivist";
149
- }
150
- get persistAccount() {
151
- return this.config?.persistAccount ?? false;
152
- }
153
- get queries() {
154
- return [
155
- ArchivistAllQuerySchema2,
156
- ArchivistDeleteQuerySchema2,
157
- ArchivistClearQuerySchema2,
158
- ArchivistInsertQuerySchema2,
159
- ArchivistCommitQuerySchema2,
160
- ...super.queries
161
- ];
162
- }
163
- get type() {
164
- return this.config?.type ?? "local";
165
- }
166
- /* This has to be a getter so that it can access it during construction */
167
- get privateStorage() {
168
- this._privateStorage = this._storage ?? store[this.type].namespace(`${this.namespace}|private`);
169
- return this._privateStorage;
170
- }
171
- /* This has to be a getter so that it can access it during construction */
172
- get storage() {
173
- this._storage = this._storage ?? store[this.type].namespace(this.namespace);
174
- return this._storage;
175
- }
176
- /*override async loadAccount(account?: AccountInstance, persistAccount?: boolean, privateStorage?: StoreBase, _logger?: Logger) {
177
- if (!this._account) {
178
- if (persistAccount) {
179
- const privateKey = privateStorage?.get('privateKey')
180
- if (privateKey) {
181
- try {
182
- this._account = await Account.create({ privateKey })
183
- return this._account
184
- } catch (ex) {
185
- console.error(`Error reading Account from storage [${ex}] - Recreating Account`)
186
- privateStorage?.remove('privateKey')
187
- }
188
- }
189
- }
190
- }
191
- return await super.loadAccount()
192
- }*/
193
- allHandler() {
194
- this.logger?.log(`this.storage.length: ${this.storage.length}`);
195
- return Object.entries(this.storage.getAll()).map(([, value]) => value);
196
- }
197
- clearHandler() {
198
- this.logger?.log(`this.storage.length: ${this.storage.length}`);
199
- this.storage.clear();
200
- return this.emit("cleared", {
201
- module: this
202
- });
203
- }
204
- async commitHandler() {
205
- this.logger?.log(`this.storage.length: ${this.storage.length}`);
206
- const payloads = await this.all();
207
- assertEx2(payloads.length > 0, "Nothing to commit");
208
- const settled = await Promise.allSettled(compact2(Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {
209
- const queryPayload = {
210
- schema: ArchivistInsertQuerySchema2
211
- };
212
- const query = await this.bindQuery(queryPayload, payloads);
213
- return (await parent?.query(query[0], query[1]))?.[0];
214
- })));
215
- await this.clear();
216
- return compact2(settled.filter(fulfilled2).map((result) => result.value));
217
- }
218
- async deleteHandler(hashes) {
219
- const payloadPairs = await Promise.all((await this.get(hashes)).map(async (payload) => [
220
- await PayloadHasher2.hashAsync(payload),
221
- payload
222
- ]));
223
- const deletedPairs = compact2(await Promise.all(payloadPairs.map(([hash, payload]) => {
224
- this.storage.remove(hash);
225
- return [
226
- hash,
227
- payload
228
- ];
229
- })));
230
- return deletedPairs.map(([hash]) => hash);
231
- }
232
- getHandler(hashes) {
233
- return compact2(hashes.map((hash) => {
234
- return this.storage.get(hash);
235
- }));
236
- }
237
- async insertHandler(payloads) {
238
- const resultPayloads = await Promise.all(payloads.map(async (payload) => {
239
- const wrapper = PayloadWrapper2.wrap(payload);
240
- const hash = await wrapper.hashAsync();
241
- const value = JSON.stringify(wrapper.payload());
242
- assertEx2(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`);
243
- this.storage.set(hash, wrapper.payload());
244
- return wrapper.payload();
245
- }));
246
- return resultPayloads;
247
- }
248
- saveAccount() {
249
- if (this.persistAccount) {
250
- const account = this.account;
251
- this.logger?.log(account.address);
252
- this.privateStorage.set("privateKey", account.private.hex);
253
- }
254
- }
255
- async startHandler() {
256
- await super.startHandler();
257
- this.saveAccount();
258
- return true;
259
- }
260
- };
261
-
262
1
  // src/index.ts
263
2
  export * from "@xyo-network/archivist-abstract";
3
+ export * from "@xyo-network/archivist-memory";
264
4
  export * from "@xyo-network/archivist-model";
265
5
  export * from "@xyo-network/archivist-wrapper";
266
- export * from "@xyo-network/memory-archivist";
267
- export {
268
- CookieArchivist,
269
- CookieArchivistConfigSchema,
270
- StorageArchivist,
271
- StorageArchivistConfigSchema
272
- };
273
6
  //# sourceMappingURL=index.js.map