@xyo-network/archivist-storage 2.107.1 → 2.107.4

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.
@@ -1,2 +1,188 @@
1
- "use strict";var S=Object.create;var n=Object.defineProperty;var A=Object.getOwnPropertyDescriptor;var x=Object.getOwnPropertyNames;var w=Object.getPrototypeOf,$=Object.prototype.hasOwnProperty;var p=(r,t)=>n(r,"name",{value:t,configurable:!0});var H=(r,t)=>{for(var e in t)n(r,e,{get:t[e],enumerable:!0})},f=(r,t,e,s)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of x(t))!$.call(r,a)&&a!==e&&n(r,a,{get:()=>t[a],enumerable:!(s=A(t,a))||s.enumerable});return r};var _=(r,t,e)=>(e=r!=null?S(w(r)):{},f(t||!r||!r.__esModule?n(e,"default",{value:r,enumerable:!0}):e,r)),P=r=>f(n({},"__esModule",{value:!0}),r);var E={};H(E,{StorageArchivist:()=>u,StorageArchivistConfigSchema:()=>g});module.exports=P(E);var c=require("@xylabs/assert"),h=require("@xylabs/lodash"),d=require("@xylabs/promise"),y=require("@xyo-network/archivist-abstract"),i=require("@xyo-network/archivist-model"),v=require("@xyo-network/payload-builder"),l=_(require("store2"),1);var g="network.xyo.archivist.storage.config",u=class extends y.AbstractArchivist{static{p(this,"StorageArchivist")}static configSchemas=[...super.configSchemas,g];static defaultConfigSchema=g;_privateStorage;_storage;get maxEntries(){return this.config?.maxEntries??1e3}get maxEntrySize(){return this.config?.maxEntrySize??16e3}get namespace(){return this.config?.namespace??"xyo-archivist"}get persistAccount(){return this.config?.persistAccount??!1}get queries(){return[i.ArchivistAllQuerySchema,i.ArchivistDeleteQuerySchema,i.ArchivistClearQuerySchema,i.ArchivistInsertQuerySchema,i.ArchivistCommitQuerySchema,...super.queries]}get type(){return this.config?.type??"local"}get privateStorage(){return this._privateStorage=this._storage??l.default[this.type].namespace(`${this.namespace}|private`),this._privateStorage}get storage(){return this._storage=this._storage??l.default[this.type].namespace(this.namespace),this._storage}allHandler(){let t=new Set;return this.logger?.log(`this.storage.length: ${this.storage.length}`),Object.entries(this.storage.getAll()).map(([,e])=>e).filter(e=>t.has(e.$hash)?!1:(t.add(e.$hash),!0))}clearHandler(){return this.logger?.log(`this.storage.length: ${this.storage.length}`),this.storage.clear(),this.emit("cleared",{module:this})}async commitHandler(){this.logger?.log(`this.storage.length: ${this.storage.length}`);let t=await this.all();(0,c.assertEx)(t.length>0,()=>"Nothing to commit");let e=await Promise.allSettled((0,h.compact)(Object.values((await this.parentArchivists()).commit??[])?.map(async s=>{let a={schema:i.ArchivistInsertQuerySchema},o=await this.bindQuery(a,t);return(await s?.query(o[0],o[1]))?.[0]})));return await this.clear(),(0,h.compact)(e.filter(d.fulfilled).map(s=>s.value))}async deleteHandler(t){return(0,h.compact)(await Promise.all(t.map(s=>(this.storage.remove(s),s))))}getHandler(t){let e=new Set;return(0,h.compact)(t.map(s=>this.storage.get(s))).filter(s=>e.has(s.$hash)?!1:(e.add(s.$hash),!0))}async insertHandler(t){return(await v.PayloadBuilder.hashPairs(t)).map(([a,o])=>{let m=JSON.stringify(a);return(0,c.assertEx)(m.length<this.maxEntrySize,()=>`Payload too large [${o}, ${m.length}]`),this.storage.set(o,a),this.storage.set(a.$hash,a),a})}saveAccount(){if(this.persistAccount){let t=this.account;this.logger?.log(t.address),this.privateStorage.set("privateKey",t.private.hex)}}async startHandler(){return await super.startHandler(),this.saveAccount(),!0}};
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __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
+ var __copyProps = (to, from, except, desc) => {
14
+ if (from && typeof from === "object" || typeof from === "function") {
15
+ for (let key of __getOwnPropNames(from))
16
+ if (!__hasOwnProp.call(to, key) && key !== except)
17
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
18
+ }
19
+ return to;
20
+ };
21
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
22
+ // If the importer is in node compatibility mode or this is not an ESM
23
+ // file that has been converted to a CommonJS file using a Babel-
24
+ // compatible transform (i.e. "__esModule" has not been set), then set
25
+ // "default" to the CommonJS "module.exports" for node compatibility.
26
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
27
+ mod
28
+ ));
29
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
30
+
31
+ // src/index.ts
32
+ var src_exports = {};
33
+ __export(src_exports, {
34
+ StorageArchivist: () => StorageArchivist,
35
+ StorageArchivistConfigSchema: () => StorageArchivistConfigSchema
36
+ });
37
+ module.exports = __toCommonJS(src_exports);
38
+
39
+ // src/StorageArchivist.ts
40
+ var import_assert = require("@xylabs/assert");
41
+ var import_lodash = require("@xylabs/lodash");
42
+ var import_promise = require("@xylabs/promise");
43
+ var import_archivist_abstract = require("@xyo-network/archivist-abstract");
44
+ var import_archivist_model = require("@xyo-network/archivist-model");
45
+ var import_payload_builder = require("@xyo-network/payload-builder");
46
+ var import_store2 = __toESM(require("store2"), 1);
47
+ var StorageArchivistConfigSchema = "network.xyo.archivist.storage.config";
48
+ var StorageArchivist = class extends import_archivist_abstract.AbstractArchivist {
49
+ static {
50
+ __name(this, "StorageArchivist");
51
+ }
52
+ static configSchemas = [
53
+ ...super.configSchemas,
54
+ StorageArchivistConfigSchema
55
+ ];
56
+ static defaultConfigSchema = StorageArchivistConfigSchema;
57
+ _privateStorage;
58
+ _storage;
59
+ get maxEntries() {
60
+ return this.config?.maxEntries ?? 1e3;
61
+ }
62
+ get maxEntrySize() {
63
+ return this.config?.maxEntrySize ?? 16e3;
64
+ }
65
+ get namespace() {
66
+ return this.config?.namespace ?? "xyo-archivist";
67
+ }
68
+ get persistAccount() {
69
+ return this.config?.persistAccount ?? false;
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
+ get type() {
82
+ return this.config?.type ?? "local";
83
+ }
84
+ /* This has to be a getter so that it can access it during construction */
85
+ get privateStorage() {
86
+ this._privateStorage = this._storage ?? import_store2.default[this.type].namespace(`${this.namespace}|private`);
87
+ return this._privateStorage;
88
+ }
89
+ /* This has to be a getter so that it can access it during construction */
90
+ get storage() {
91
+ this._storage = this._storage ?? import_store2.default[this.type].namespace(this.namespace);
92
+ return this._storage;
93
+ }
94
+ /*override async loadAccount(account?: AccountInstance, persistAccount?: boolean, privateStorage?: StoreBase, _logger?: Logger) {
95
+ if (!this._account) {
96
+ if (persistAccount) {
97
+ const privateKey = privateStorage?.get('privateKey')
98
+ if (privateKey) {
99
+ try {
100
+ this._account = await Account.create({ privateKey })
101
+ return this._account
102
+ } catch (ex) {
103
+ console.error(`Error reading Account from storage [${ex}] - Recreating Account`)
104
+ privateStorage?.remove('privateKey')
105
+ }
106
+ }
107
+ }
108
+ }
109
+ return await super.loadAccount()
110
+ }*/
111
+ allHandler() {
112
+ const found = /* @__PURE__ */ new Set();
113
+ this.logger?.log(`this.storage.length: ${this.storage.length}`);
114
+ return Object.entries(this.storage.getAll()).map(([, value]) => value).filter((payload) => {
115
+ if (found.has(payload.$hash)) {
116
+ return false;
117
+ } else {
118
+ found.add(payload.$hash);
119
+ return true;
120
+ }
121
+ });
122
+ }
123
+ clearHandler() {
124
+ this.logger?.log(`this.storage.length: ${this.storage.length}`);
125
+ this.storage.clear();
126
+ return this.emit("cleared", {
127
+ module: this
128
+ });
129
+ }
130
+ async commitHandler() {
131
+ this.logger?.log(`this.storage.length: ${this.storage.length}`);
132
+ const payloads = await this.all();
133
+ (0, import_assert.assertEx)(payloads.length > 0, () => "Nothing to commit");
134
+ const settled = await Promise.allSettled((0, import_lodash.compact)(Object.values((await this.parentArchivists()).commit ?? [])?.map(async (parent) => {
135
+ const queryPayload = {
136
+ schema: import_archivist_model.ArchivistInsertQuerySchema
137
+ };
138
+ const query = await this.bindQuery(queryPayload, payloads);
139
+ return (await parent?.query(query[0], query[1]))?.[0];
140
+ })));
141
+ await this.clear();
142
+ return (0, import_lodash.compact)(settled.filter(import_promise.fulfilled).map((result) => result.value));
143
+ }
144
+ async deleteHandler(hashes) {
145
+ const deletedHashes = (0, import_lodash.compact)(await Promise.all(hashes.map((hash) => {
146
+ this.storage.remove(hash);
147
+ return hash;
148
+ })));
149
+ return deletedHashes;
150
+ }
151
+ getHandler(hashes) {
152
+ const found = /* @__PURE__ */ new Set();
153
+ return (0, import_lodash.compact)(hashes.map((hash) => {
154
+ return this.storage.get(hash);
155
+ })).filter((payload) => {
156
+ if (found.has(payload.$hash)) {
157
+ return false;
158
+ } else {
159
+ found.add(payload.$hash);
160
+ return true;
161
+ }
162
+ });
163
+ }
164
+ async insertHandler(payloads) {
165
+ const pairs = await import_payload_builder.PayloadBuilder.hashPairs(payloads);
166
+ const resultPayloads = pairs.map(([payload, hash]) => {
167
+ const value = JSON.stringify(payload);
168
+ (0, import_assert.assertEx)(value.length < this.maxEntrySize, () => `Payload too large [${hash}, ${value.length}]`);
169
+ this.storage.set(hash, payload);
170
+ this.storage.set(payload.$hash, payload);
171
+ return payload;
172
+ });
173
+ return resultPayloads;
174
+ }
175
+ saveAccount() {
176
+ if (this.persistAccount) {
177
+ const account = this.account;
178
+ this.logger?.log(account.address);
179
+ this.privateStorage.set("privateKey", account.private.hex);
180
+ }
181
+ }
182
+ async startHandler() {
183
+ await super.startHandler();
184
+ this.saveAccount();
185
+ return true;
186
+ }
187
+ };
2
188
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/StorageArchivist.ts"],"sourcesContent":["export * from './StorageArchivist'\n","import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\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 { AnyConfigSchema } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, PayloadWithMeta, Schema, WithMeta } from '@xyo-network/payload-model'\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 readonly configSchemas: Schema[] = [...super.configSchemas, StorageArchivistConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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<PayloadWithMeta> {\n const found = new Set<string>()\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\n return Object.entries(this.storage.getAll())\n .map(([, value]) => value)\n .filter((payload) => {\n if (found.has(payload.$hash)) {\n return false\n } else {\n found.add(payload.$hash)\n return true\n }\n })\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<WithMeta<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.parentArchivists()).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: Hash[]): Promise<Hash[]> {\n const deletedHashes = compact(\n await Promise.all(\n hashes.map((hash) => {\n this.storage.remove(hash)\n return hash\n }),\n ),\n )\n return deletedHashes\n }\n\n protected override getHandler(hashes: string[]): Promisable<PayloadWithMeta[]> {\n const found = new Set<string>()\n return compact(\n hashes.map((hash) => {\n return this.storage.get(hash)\n }),\n ).filter((payload) => {\n if (found.has(payload.$hash)) {\n return false\n } else {\n found.add(payload.$hash)\n return true\n }\n })\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]> {\n const pairs = await PayloadBuilder.hashPairs(payloads)\n const resultPayloads = pairs.map(([payload, hash]) => {\n const value = JSON.stringify(payload)\n assertEx(value.length < this.maxEntrySize, () => `Payload too large [${hash}, ${value.length}]`)\n this.storage.set(hash, payload)\n this.storage.set(payload.$hash, payload)\n return payload\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":["src_exports","__export","StorageArchivist","StorageArchivistConfigSchema","__toCommonJS","import_assert","import_lodash","import_promise","import_archivist_abstract","import_archivist_model","import_payload_builder","import_store2","StorageArchivistConfigSchema","StorageArchivist","AbstractArchivist","configSchemas","defaultConfigSchema","_privateStorage","_storage","maxEntries","config","maxEntrySize","namespace","persistAccount","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","type","privateStorage","store","storage","allHandler","found","Set","logger","log","length","Object","entries","getAll","map","value","filter","payload","has","$hash","add","clearHandler","clear","emit","module","commitHandler","payloads","all","assertEx","settled","Promise","allSettled","compact","values","parentArchivists","commit","parent","queryPayload","schema","query","bindQuery","fulfilled","result","deleteHandler","hashes","hash","remove","getHandler","get","insertHandler","PayloadBuilder","hashPairs","JSON","stringify","set","saveAccount","account","address","private","hex","startHandler"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/StorageArchivist.ts"],"sourcesContent":["export * from './StorageArchivist'\n","import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\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 { AnyConfigSchema } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, PayloadWithMeta, Schema, WithMeta } from '@xyo-network/payload-model'\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 readonly configSchemas: Schema[] = [...super.configSchemas, StorageArchivistConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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<PayloadWithMeta> {\n const found = new Set<string>()\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\n return Object.entries(this.storage.getAll())\n .map(([, value]) => value)\n .filter((payload) => {\n if (found.has(payload.$hash)) {\n return false\n } else {\n found.add(payload.$hash)\n return true\n }\n })\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<WithMeta<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.parentArchivists()).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: Hash[]): Promise<Hash[]> {\n const deletedHashes = compact(\n await Promise.all(\n hashes.map((hash) => {\n this.storage.remove(hash)\n return hash\n }),\n ),\n )\n return deletedHashes\n }\n\n protected override getHandler(hashes: string[]): Promisable<PayloadWithMeta[]> {\n const found = new Set<string>()\n return compact(\n hashes.map((hash) => {\n return this.storage.get(hash)\n }),\n ).filter((payload) => {\n if (found.has(payload.$hash)) {\n return false\n } else {\n found.add(payload.$hash)\n return true\n }\n })\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]> {\n const pairs = await PayloadBuilder.hashPairs(payloads)\n const resultPayloads = pairs.map(([payload, hash]) => {\n const value = JSON.stringify(payload)\n assertEx(value.length < this.maxEntrySize, () => `Payload too large [${hash}, ${value.length}]`)\n this.storage.set(hash, payload)\n this.storage.set(payload.$hash, payload)\n return payload\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","defaultConfigSchema","_privateStorage","_storage","maxEntries","config","maxEntrySize","namespace","persistAccount","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","type","privateStorage","store","storage","allHandler","found","Set","logger","log","length","Object","entries","getAll","map","value","filter","payload","has","$hash","add","clearHandler","clear","emit","module","commitHandler","payloads","all","assertEx","settled","Promise","allSettled","compact","values","parentArchivists","commit","parent","queryPayload","schema","query","bindQuery","fulfilled","result","deleteHandler","hashes","deletedHashes","hash","remove","getHandler","get","insertHandler","pairs","PayloadBuilder","hashPairs","resultPayloads","JSON","stringify","set","saveAccount","account","address","private","hex","startHandler"]}
@@ -1,2 +1,157 @@
1
- var p=Object.defineProperty;var h=(o,t)=>p(o,"name",{value:t,configurable:!0});import{assertEx as c}from"@xylabs/assert";import{compact as i}from"@xylabs/lodash";import{fulfilled as f}from"@xylabs/promise";import{AbstractArchivist as d}from"@xyo-network/archivist-abstract";import{ArchivistAllQuerySchema as y,ArchivistClearQuerySchema as v,ArchivistCommitQuerySchema as S,ArchivistDeleteQuerySchema as A,ArchivistInsertQuerySchema as l}from"@xyo-network/archivist-model";import{PayloadBuilder as x}from"@xyo-network/payload-builder";import g from"store2";var u="network.xyo.archivist.storage.config",m=class extends d{static{h(this,"StorageArchivist")}static configSchemas=[...super.configSchemas,u];static defaultConfigSchema=u;_privateStorage;_storage;get maxEntries(){return this.config?.maxEntries??1e3}get maxEntrySize(){return this.config?.maxEntrySize??16e3}get namespace(){return this.config?.namespace??"xyo-archivist"}get persistAccount(){return this.config?.persistAccount??!1}get queries(){return[y,A,v,l,S,...super.queries]}get type(){return this.config?.type??"local"}get privateStorage(){return this._privateStorage=this._storage??g[this.type].namespace(`${this.namespace}|private`),this._privateStorage}get storage(){return this._storage=this._storage??g[this.type].namespace(this.namespace),this._storage}allHandler(){let t=new Set;return this.logger?.log(`this.storage.length: ${this.storage.length}`),Object.entries(this.storage.getAll()).map(([,r])=>r).filter(r=>t.has(r.$hash)?!1:(t.add(r.$hash),!0))}clearHandler(){return this.logger?.log(`this.storage.length: ${this.storage.length}`),this.storage.clear(),this.emit("cleared",{module:this})}async commitHandler(){this.logger?.log(`this.storage.length: ${this.storage.length}`);let t=await this.all();c(t.length>0,()=>"Nothing to commit");let r=await Promise.allSettled(i(Object.values((await this.parentArchivists()).commit??[])?.map(async e=>{let s={schema:l},a=await this.bindQuery(s,t);return(await e?.query(a[0],a[1]))?.[0]})));return await this.clear(),i(r.filter(f).map(e=>e.value))}async deleteHandler(t){return i(await Promise.all(t.map(e=>(this.storage.remove(e),e))))}getHandler(t){let r=new Set;return i(t.map(e=>this.storage.get(e))).filter(e=>r.has(e.$hash)?!1:(r.add(e.$hash),!0))}async insertHandler(t){return(await x.hashPairs(t)).map(([s,a])=>{let n=JSON.stringify(s);return c(n.length<this.maxEntrySize,()=>`Payload too large [${a}, ${n.length}]`),this.storage.set(a,s),this.storage.set(s.$hash,s),s})}saveAccount(){if(this.persistAccount){let t=this.account;this.logger?.log(t.address),this.privateStorage.set("privateKey",t.private.hex)}}async startHandler(){return await super.startHandler(),this.saveAccount(),!0}};export{m as StorageArchivist,u as StorageArchivistConfigSchema};
1
+ var __defProp = Object.defineProperty;
2
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+
4
+ // src/StorageArchivist.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 { PayloadBuilder } from "@xyo-network/payload-builder";
11
+ import store from "store2";
12
+ var StorageArchivistConfigSchema = "network.xyo.archivist.storage.config";
13
+ var StorageArchivist = class extends AbstractArchivist {
14
+ static {
15
+ __name(this, "StorageArchivist");
16
+ }
17
+ static configSchemas = [
18
+ ...super.configSchemas,
19
+ StorageArchivistConfigSchema
20
+ ];
21
+ static defaultConfigSchema = StorageArchivistConfigSchema;
22
+ _privateStorage;
23
+ _storage;
24
+ get maxEntries() {
25
+ return this.config?.maxEntries ?? 1e3;
26
+ }
27
+ get maxEntrySize() {
28
+ return this.config?.maxEntrySize ?? 16e3;
29
+ }
30
+ get namespace() {
31
+ return this.config?.namespace ?? "xyo-archivist";
32
+ }
33
+ get persistAccount() {
34
+ return this.config?.persistAccount ?? false;
35
+ }
36
+ get queries() {
37
+ return [
38
+ ArchivistAllQuerySchema,
39
+ ArchivistDeleteQuerySchema,
40
+ ArchivistClearQuerySchema,
41
+ ArchivistInsertQuerySchema,
42
+ ArchivistCommitQuerySchema,
43
+ ...super.queries
44
+ ];
45
+ }
46
+ get type() {
47
+ return this.config?.type ?? "local";
48
+ }
49
+ /* This has to be a getter so that it can access it during construction */
50
+ get privateStorage() {
51
+ this._privateStorage = this._storage ?? store[this.type].namespace(`${this.namespace}|private`);
52
+ return this._privateStorage;
53
+ }
54
+ /* This has to be a getter so that it can access it during construction */
55
+ get storage() {
56
+ this._storage = this._storage ?? store[this.type].namespace(this.namespace);
57
+ return this._storage;
58
+ }
59
+ /*override async loadAccount(account?: AccountInstance, persistAccount?: boolean, privateStorage?: StoreBase, _logger?: Logger) {
60
+ if (!this._account) {
61
+ if (persistAccount) {
62
+ const privateKey = privateStorage?.get('privateKey')
63
+ if (privateKey) {
64
+ try {
65
+ this._account = await Account.create({ privateKey })
66
+ return this._account
67
+ } catch (ex) {
68
+ console.error(`Error reading Account from storage [${ex}] - Recreating Account`)
69
+ privateStorage?.remove('privateKey')
70
+ }
71
+ }
72
+ }
73
+ }
74
+ return await super.loadAccount()
75
+ }*/
76
+ allHandler() {
77
+ const found = /* @__PURE__ */ new Set();
78
+ this.logger?.log(`this.storage.length: ${this.storage.length}`);
79
+ return Object.entries(this.storage.getAll()).map(([, value]) => value).filter((payload) => {
80
+ if (found.has(payload.$hash)) {
81
+ return false;
82
+ } else {
83
+ found.add(payload.$hash);
84
+ return true;
85
+ }
86
+ });
87
+ }
88
+ clearHandler() {
89
+ this.logger?.log(`this.storage.length: ${this.storage.length}`);
90
+ this.storage.clear();
91
+ return this.emit("cleared", {
92
+ module: this
93
+ });
94
+ }
95
+ async commitHandler() {
96
+ this.logger?.log(`this.storage.length: ${this.storage.length}`);
97
+ const payloads = await this.all();
98
+ assertEx(payloads.length > 0, () => "Nothing to commit");
99
+ const settled = await Promise.allSettled(compact(Object.values((await this.parentArchivists()).commit ?? [])?.map(async (parent) => {
100
+ const queryPayload = {
101
+ schema: ArchivistInsertQuerySchema
102
+ };
103
+ const query = await this.bindQuery(queryPayload, payloads);
104
+ return (await parent?.query(query[0], query[1]))?.[0];
105
+ })));
106
+ await this.clear();
107
+ return compact(settled.filter(fulfilled).map((result) => result.value));
108
+ }
109
+ async deleteHandler(hashes) {
110
+ const deletedHashes = compact(await Promise.all(hashes.map((hash) => {
111
+ this.storage.remove(hash);
112
+ return hash;
113
+ })));
114
+ return deletedHashes;
115
+ }
116
+ getHandler(hashes) {
117
+ const found = /* @__PURE__ */ new Set();
118
+ return compact(hashes.map((hash) => {
119
+ return this.storage.get(hash);
120
+ })).filter((payload) => {
121
+ if (found.has(payload.$hash)) {
122
+ return false;
123
+ } else {
124
+ found.add(payload.$hash);
125
+ return true;
126
+ }
127
+ });
128
+ }
129
+ async insertHandler(payloads) {
130
+ const pairs = await PayloadBuilder.hashPairs(payloads);
131
+ const resultPayloads = pairs.map(([payload, hash]) => {
132
+ const value = JSON.stringify(payload);
133
+ assertEx(value.length < this.maxEntrySize, () => `Payload too large [${hash}, ${value.length}]`);
134
+ this.storage.set(hash, payload);
135
+ this.storage.set(payload.$hash, payload);
136
+ return payload;
137
+ });
138
+ return resultPayloads;
139
+ }
140
+ saveAccount() {
141
+ if (this.persistAccount) {
142
+ const account = this.account;
143
+ this.logger?.log(account.address);
144
+ this.privateStorage.set("privateKey", account.private.hex);
145
+ }
146
+ }
147
+ async startHandler() {
148
+ await super.startHandler();
149
+ this.saveAccount();
150
+ return true;
151
+ }
152
+ };
153
+ export {
154
+ StorageArchivist,
155
+ StorageArchivistConfigSchema
156
+ };
2
157
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/StorageArchivist.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\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 { AnyConfigSchema } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, PayloadWithMeta, Schema, WithMeta } from '@xyo-network/payload-model'\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 readonly configSchemas: Schema[] = [...super.configSchemas, StorageArchivistConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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<PayloadWithMeta> {\n const found = new Set<string>()\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\n return Object.entries(this.storage.getAll())\n .map(([, value]) => value)\n .filter((payload) => {\n if (found.has(payload.$hash)) {\n return false\n } else {\n found.add(payload.$hash)\n return true\n }\n })\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<WithMeta<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.parentArchivists()).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: Hash[]): Promise<Hash[]> {\n const deletedHashes = compact(\n await Promise.all(\n hashes.map((hash) => {\n this.storage.remove(hash)\n return hash\n }),\n ),\n )\n return deletedHashes\n }\n\n protected override getHandler(hashes: string[]): Promisable<PayloadWithMeta[]> {\n const found = new Set<string>()\n return compact(\n hashes.map((hash) => {\n return this.storage.get(hash)\n }),\n ).filter((payload) => {\n if (found.has(payload.$hash)) {\n return false\n } else {\n found.add(payload.$hash)\n return true\n }\n })\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]> {\n const pairs = await PayloadBuilder.hashPairs(payloads)\n const resultPayloads = pairs.map(([payload, hash]) => {\n const value = JSON.stringify(payload)\n assertEx(value.length < this.maxEntrySize, () => `Payload too large [${hash}, ${value.length}]`)\n this.storage.set(hash, payload)\n this.storage.set(payload.$hash, payload)\n return payload\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":"+EAAA,OAASA,YAAAA,MAAgB,iBAEzB,OAASC,WAAAA,MAAe,iBACxB,OAASC,aAAAA,MAA8C,kBACvD,OAASC,qBAAAA,MAAyB,kCAClC,OACEC,2BAAAA,EACAC,6BAAAA,EACAC,8BAAAA,EAEAC,8BAAAA,EAEAC,8BAAAA,MAIK,+BAGP,OAASC,kBAAAA,MAAsB,+BAE/B,OAAOC,MAA0B,SAG1B,IAAMC,EAA6D,uCAY7DC,EAAN,cAIGC,CAAAA,CAxCV,MAwCUA,CAAAA,EAAAA,yBAGR,OAAyBC,cAA0B,IAAI,MAAMA,cAAeH,GAC5E,OAAyBI,oBAA8BJ,EAE/CK,gBACAC,SAER,IAAIC,YAAa,CACf,OAAO,KAAKC,QAAQD,YAAc,GACpC,CAEA,IAAIE,cAAe,CACjB,OAAO,KAAKD,QAAQC,cAAgB,IACtC,CAEA,IAAIC,WAAY,CACd,OAAO,KAAKF,QAAQE,WAAa,eACnC,CAEA,IAAIC,gBAAiB,CACnB,OAAO,KAAKH,QAAQG,gBAAkB,EACxC,CAEA,IAAaC,SAAoB,CAC/B,MAAO,CACLC,EACAC,EACAC,EACAC,EACAC,KACG,MAAML,QAEb,CAEA,IAAIM,MAAO,CACT,OAAO,KAAKV,QAAQU,MAAQ,OAC9B,CAGA,IAAYC,gBAA4B,CACtC,YAAKd,gBAAkB,KAAKC,UAAYc,EAAM,KAAKF,IAAI,EAAER,UAAU,GAAG,KAAKA,SAAS,UAAU,EACvF,KAAKL,eACd,CAGA,IAAYgB,SAAqB,CAC/B,YAAKf,SAAW,KAAKA,UAAYc,EAAM,KAAKF,IAAI,EAAER,UAAU,KAAKA,SAAS,EACnE,KAAKJ,QACd,CAoBmBgB,YAA+C,CAChE,IAAMC,EAAQ,IAAIC,IAClB,YAAKC,QAAQC,IAAI,wBAAwB,KAAKL,QAAQM,MAAM,EAAE,EACvDC,OAAOC,QAAQ,KAAKR,QAAQS,OAAM,CAAA,EACtCC,IAAI,CAAC,CAAA,CAAGC,CAAAA,IAAWA,CAAAA,EACnBC,OAAQC,GACHX,EAAMY,IAAID,EAAQE,KAAK,EAClB,IAEPb,EAAMc,IAAIH,EAAQE,KAAK,EAChB,GAEX,CACJ,CAEmBE,cAAqC,CACtD,YAAKb,QAAQC,IAAI,wBAAwB,KAAKL,QAAQM,MAAM,EAAE,EAC9D,KAAKN,QAAQkB,MAAK,EACX,KAAKC,KAAK,UAAW,CAAEC,OAAQ,IAAK,CAAA,CAC7C,CAEA,MAAyBC,eAAmD,CAC1E,KAAKjB,QAAQC,IAAI,wBAAwB,KAAKL,QAAQM,MAAM,EAAE,EAC9D,IAAMgB,EAAW,MAAM,KAAKC,IAAG,EAC/BC,EAASF,EAAShB,OAAS,EAAG,IAAM,mBAAA,EACpC,IAAMmB,EAAU,MAAMC,QAAQC,WAC5BC,EACErB,OAAOsB,QAAQ,MAAM,KAAKC,iBAAgB,GAAIC,QAAU,CAAA,CAAE,GAAGrB,IAAI,MAAOsB,GAAAA,CACtE,IAAMC,EAAqC,CACzCC,OAAQvC,CACV,EACMwC,EAAQ,MAAM,KAAKC,UAAUH,EAAcX,CAAAA,EACjD,OAAQ,MAAMU,GAAQG,MAAMA,EAAM,CAAA,EAAIA,EAAM,CAAA,CAAE,KAAK,CAAA,CACrD,CAAA,CAAA,CAAA,EAIJ,aAAM,KAAKjB,MAAK,EACTU,EAAQH,EAAQb,OAAOyB,CAAAA,EAAW3B,IAAK4B,GAAWA,EAAO3B,KAAK,CAAA,CACvE,CAEA,MAAyB4B,cAAcC,EAAiC,CAStE,OARsBZ,EACpB,MAAMF,QAAQH,IACZiB,EAAO9B,IAAK+B,IACV,KAAKzC,QAAQ0C,OAAOD,CAAAA,EACbA,EACT,CAAA,CAAA,CAIN,CAEmBE,WAAWH,EAAiD,CAC7E,IAAMtC,EAAQ,IAAIC,IAClB,OAAOyB,EACLY,EAAO9B,IAAK+B,GACH,KAAKzC,QAAQ4C,IAAIH,CAAAA,CAC1B,CAAA,EACA7B,OAAQC,GACJX,EAAMY,IAAID,EAAQE,KAAK,EAClB,IAEPb,EAAMc,IAAIH,EAAQE,KAAK,EAChB,GAEX,CACF,CAEA,MAAyB8B,cAAcvB,EAAiD,CAStF,OARc,MAAMwB,EAAeC,UAAUzB,CAAAA,GAChBZ,IAAI,CAAC,CAACG,EAAS4B,CAAAA,IAAK,CAC/C,IAAM9B,EAAQqC,KAAKC,UAAUpC,CAAAA,EAC7BW,OAAAA,EAASb,EAAML,OAAS,KAAKlB,aAAc,IAAM,sBAAsBqD,CAAAA,KAAS9B,EAAML,MAAM,GAAG,EAC/F,KAAKN,QAAQkD,IAAIT,EAAM5B,CAAAA,EACvB,KAAKb,QAAQkD,IAAIrC,EAAQE,MAAOF,CAAAA,EACzBA,CACT,CAAA,CAEF,CAEUsC,aAAc,CACtB,GAAI,KAAK7D,eAAgB,CACvB,IAAM8D,EAAU,KAAKA,QACrB,KAAKhD,QAAQC,IAAI+C,EAAQC,OAAO,EAChC,KAAKvD,eAAeoD,IAAI,aAAcE,EAAQE,QAAQC,GAAG,CAC3D,CACF,CAEA,MAAyBC,cAAe,CACtC,aAAM,MAAMA,aAAAA,EACZ,KAAKL,YAAW,EACT,EACT,CACF","names":["assertEx","compact","fulfilled","AbstractArchivist","ArchivistAllQuerySchema","ArchivistClearQuerySchema","ArchivistCommitQuerySchema","ArchivistDeleteQuerySchema","ArchivistInsertQuerySchema","PayloadBuilder","store","StorageArchivistConfigSchema","StorageArchivist","AbstractArchivist","configSchemas","defaultConfigSchema","_privateStorage","_storage","maxEntries","config","maxEntrySize","namespace","persistAccount","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","type","privateStorage","store","storage","allHandler","found","Set","logger","log","length","Object","entries","getAll","map","value","filter","payload","has","$hash","add","clearHandler","clear","emit","module","commitHandler","payloads","all","assertEx","settled","Promise","allSettled","compact","values","parentArchivists","commit","parent","queryPayload","schema","query","bindQuery","fulfilled","result","deleteHandler","hashes","hash","remove","getHandler","get","insertHandler","PayloadBuilder","hashPairs","JSON","stringify","set","saveAccount","account","address","private","hex","startHandler"]}
1
+ {"version":3,"sources":["../../src/StorageArchivist.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\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 { AnyConfigSchema } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, PayloadWithMeta, Schema, WithMeta } from '@xyo-network/payload-model'\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 readonly configSchemas: Schema[] = [...super.configSchemas, StorageArchivistConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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<PayloadWithMeta> {\n const found = new Set<string>()\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\n return Object.entries(this.storage.getAll())\n .map(([, value]) => value)\n .filter((payload) => {\n if (found.has(payload.$hash)) {\n return false\n } else {\n found.add(payload.$hash)\n return true\n }\n })\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<WithMeta<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.parentArchivists()).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: Hash[]): Promise<Hash[]> {\n const deletedHashes = compact(\n await Promise.all(\n hashes.map((hash) => {\n this.storage.remove(hash)\n return hash\n }),\n ),\n )\n return deletedHashes\n }\n\n protected override getHandler(hashes: string[]): Promisable<PayloadWithMeta[]> {\n const found = new Set<string>()\n return compact(\n hashes.map((hash) => {\n return this.storage.get(hash)\n }),\n ).filter((payload) => {\n if (found.has(payload.$hash)) {\n return false\n } else {\n found.add(payload.$hash)\n return true\n }\n })\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]> {\n const pairs = await PayloadBuilder.hashPairs(payloads)\n const resultPayloads = pairs.map(([payload, hash]) => {\n const value = JSON.stringify(payload)\n assertEx(value.length < this.maxEntrySize, () => `Payload too large [${hash}, ${value.length}]`)\n this.storage.set(hash, payload)\n this.storage.set(payload.$hash, payload)\n return payload\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","PayloadBuilder","store","StorageArchivistConfigSchema","StorageArchivist","AbstractArchivist","configSchemas","defaultConfigSchema","_privateStorage","_storage","maxEntries","config","maxEntrySize","namespace","persistAccount","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","type","privateStorage","store","storage","allHandler","found","Set","logger","log","length","Object","entries","getAll","map","value","filter","payload","has","$hash","add","clearHandler","clear","emit","module","commitHandler","payloads","all","assertEx","settled","Promise","allSettled","compact","values","parentArchivists","commit","parent","queryPayload","schema","query","bindQuery","fulfilled","result","deleteHandler","hashes","deletedHashes","hash","remove","getHandler","get","insertHandler","pairs","PayloadBuilder","hashPairs","resultPayloads","JSON","stringify","set","saveAccount","account","address","private","hex","startHandler"]}