@xyo-network/archivist 2.74.5 → 2.75.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/AbstractArchivingModule.cjs +51 -0
- package/dist/browser/AbstractArchivingModule.cjs.map +1 -0
- package/dist/browser/AbstractArchivingModule.d.cts.map +1 -0
- package/dist/browser/AbstractArchivingModule.d.mts.map +1 -0
- package/dist/browser/AbstractArchivingModule.d.ts +14 -0
- package/dist/browser/AbstractArchivingModule.d.ts.map +1 -0
- package/dist/browser/AbstractArchivingModule.js +30 -0
- package/dist/browser/AbstractArchivingModule.js.map +1 -0
- package/dist/browser/CookieArchivist.cjs +154 -0
- package/dist/browser/CookieArchivist.cjs.map +1 -0
- package/dist/browser/CookieArchivist.d.cts.map +1 -0
- package/dist/browser/CookieArchivist.d.mts.map +1 -0
- package/dist/browser/CookieArchivist.d.ts +32 -0
- package/dist/browser/CookieArchivist.d.ts.map +1 -0
- package/dist/browser/CookieArchivist.js +123 -0
- package/dist/browser/CookieArchivist.js.map +1 -0
- package/dist/browser/StorageArchivist.cjs +176 -0
- package/dist/browser/StorageArchivist.cjs.map +1 -0
- package/dist/browser/StorageArchivist.d.cts.map +1 -0
- package/dist/browser/StorageArchivist.d.mts.map +1 -0
- package/dist/browser/StorageArchivist.d.ts +39 -0
- package/dist/browser/StorageArchivist.d.ts.map +1 -0
- package/dist/browser/StorageArchivist.js +145 -0
- package/dist/browser/StorageArchivist.js.map +1 -0
- package/dist/{index.js → browser/index.cjs} +1 -13
- package/dist/browser/index.cjs.map +1 -0
- package/dist/browser/index.d.cts.map +1 -0
- package/dist/browser/index.d.mts.map +1 -0
- package/dist/browser/index.d.ts +8 -0
- package/dist/browser/index.d.ts.map +1 -0
- package/dist/browser/index.js +8 -0
- package/dist/browser/index.js.map +1 -0
- package/dist/docs.json +3124 -3124
- package/dist/node/AbstractArchivingModule.d.cts +14 -0
- package/dist/node/AbstractArchivingModule.d.cts.map +1 -0
- package/dist/node/AbstractArchivingModule.d.mts +14 -0
- package/dist/node/AbstractArchivingModule.d.mts.map +1 -0
- package/dist/node/AbstractArchivingModule.d.ts +14 -0
- package/dist/node/AbstractArchivingModule.d.ts.map +1 -0
- package/dist/node/AbstractArchivingModule.js +55 -0
- package/dist/node/AbstractArchivingModule.js.map +1 -0
- package/dist/node/AbstractArchivingModule.mjs +32 -0
- package/dist/node/AbstractArchivingModule.mjs.map +1 -0
- package/dist/node/CookieArchivist.d.cts +32 -0
- package/dist/node/CookieArchivist.d.cts.map +1 -0
- package/dist/node/CookieArchivist.d.mts +32 -0
- package/dist/node/CookieArchivist.d.mts.map +1 -0
- package/dist/node/CookieArchivist.d.ts +32 -0
- package/dist/node/CookieArchivist.d.ts.map +1 -0
- package/dist/node/CookieArchivist.js +169 -0
- package/dist/node/CookieArchivist.js.map +1 -0
- package/dist/node/CookieArchivist.mjs +135 -0
- package/dist/node/CookieArchivist.mjs.map +1 -0
- package/dist/node/StorageArchivist.d.cts +39 -0
- package/dist/node/StorageArchivist.d.cts.map +1 -0
- package/dist/node/StorageArchivist.d.mts +39 -0
- package/dist/node/StorageArchivist.d.mts.map +1 -0
- package/dist/node/StorageArchivist.d.ts +39 -0
- package/dist/node/StorageArchivist.d.ts.map +1 -0
- package/dist/node/StorageArchivist.js +195 -0
- package/dist/node/StorageArchivist.js.map +1 -0
- package/dist/node/StorageArchivist.mjs +161 -0
- package/dist/node/StorageArchivist.mjs.map +1 -0
- package/dist/node/index.d.cts +8 -0
- package/dist/node/index.d.cts.map +1 -0
- package/dist/node/index.d.mts +8 -0
- package/dist/node/index.d.mts.map +1 -0
- package/dist/node/index.d.ts +8 -0
- package/dist/node/index.d.ts.map +1 -0
- package/dist/node/index.js +363 -0
- package/dist/node/index.js.map +1 -0
- package/dist/{index.mjs → node/index.mjs} +55 -36
- package/dist/node/index.mjs.map +1 -0
- package/package.json +40 -37
- package/dist/AbstractArchivingModule.d.mts.map +0 -1
- package/dist/AbstractArchivingModule.d.ts.map +0 -1
- package/dist/CookieArchivist.d.mts.map +0 -1
- package/dist/CookieArchivist.d.ts.map +0 -1
- package/dist/StorageArchivist.d.mts.map +0 -1
- package/dist/StorageArchivist.d.ts.map +0 -1
- package/dist/index.d.mts.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/index.mjs.map +0 -1
- /package/dist/{AbstractArchivingModule.d.mts → browser/AbstractArchivingModule.d.cts} +0 -0
- /package/dist/{AbstractArchivingModule.d.ts → browser/AbstractArchivingModule.d.mts} +0 -0
- /package/dist/{CookieArchivist.d.mts → browser/CookieArchivist.d.cts} +0 -0
- /package/dist/{CookieArchivist.d.ts → browser/CookieArchivist.d.mts} +0 -0
- /package/dist/{StorageArchivist.d.mts → browser/StorageArchivist.d.cts} +0 -0
- /package/dist/{StorageArchivist.d.ts → browser/StorageArchivist.d.mts} +0 -0
- /package/dist/{index.d.mts → browser/index.d.cts} +0 -0
- /package/dist/{index.d.ts → browser/index.d.mts} +0 -0
|
@@ -0,0 +1,363 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
9
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
10
|
+
var __export = (target, all) => {
|
|
11
|
+
for (var name in all)
|
|
12
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
13
|
+
};
|
|
14
|
+
var __copyProps = (to, from, except, desc) => {
|
|
15
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
16
|
+
for (let key of __getOwnPropNames(from))
|
|
17
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
18
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
19
|
+
}
|
|
20
|
+
return to;
|
|
21
|
+
};
|
|
22
|
+
var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
|
|
23
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
24
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
25
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
26
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
27
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
28
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
29
|
+
mod
|
|
30
|
+
));
|
|
31
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
32
|
+
var __publicField = (obj, key, value) => {
|
|
33
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
34
|
+
return value;
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
// src/index.ts
|
|
38
|
+
var src_exports = {};
|
|
39
|
+
__export(src_exports, {
|
|
40
|
+
AbstractArchivingModule: () => AbstractArchivingModule,
|
|
41
|
+
CookieArchivist: () => CookieArchivist,
|
|
42
|
+
CookieArchivistConfigSchema: () => CookieArchivistConfigSchema,
|
|
43
|
+
StorageArchivist: () => StorageArchivist,
|
|
44
|
+
StorageArchivistConfigSchema: () => StorageArchivistConfigSchema
|
|
45
|
+
});
|
|
46
|
+
module.exports = __toCommonJS(src_exports);
|
|
47
|
+
|
|
48
|
+
// src/AbstractArchivingModule.ts
|
|
49
|
+
var import_lodash = require("@xylabs/lodash");
|
|
50
|
+
var import_archivist_model = require("@xyo-network/archivist-model");
|
|
51
|
+
var import_module = require("@xyo-network/module");
|
|
52
|
+
var _AbstractArchivingModule = class _AbstractArchivingModule extends import_module.AbstractModuleInstance {
|
|
53
|
+
async bindQueryResult(query, payloads, additionalWitnesses = [], errorPayloads = []) {
|
|
54
|
+
const result = await super.bindQueryResult(query, payloads, additionalWitnesses, errorPayloads);
|
|
55
|
+
await this.storeToArchivists(result.flat());
|
|
56
|
+
return result;
|
|
57
|
+
}
|
|
58
|
+
async resolveArchivists() {
|
|
59
|
+
return (0, import_lodash.compact)((await Promise.all(await this.resolve({
|
|
60
|
+
address: this.config.archivists ?? []
|
|
61
|
+
}) ?? [])).map((module2) => (0, import_archivist_model.asArchivistInstance)(module2, () => `Module failed to cast to Archivist [${module2.config.name}]`)));
|
|
62
|
+
}
|
|
63
|
+
async storeToArchivists(payloads) {
|
|
64
|
+
const archivists = await this.resolveArchivists();
|
|
65
|
+
return (await Promise.all(archivists.map((archivist) => {
|
|
66
|
+
var _a;
|
|
67
|
+
return (_a = archivist.insert) == null ? void 0 : _a.call(archivist, payloads);
|
|
68
|
+
}))).map(([bw]) => bw);
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
__name(_AbstractArchivingModule, "AbstractArchivingModule");
|
|
72
|
+
var AbstractArchivingModule = _AbstractArchivingModule;
|
|
73
|
+
|
|
74
|
+
// src/CookieArchivist.ts
|
|
75
|
+
var import_assert = require("@xylabs/assert");
|
|
76
|
+
var import_lodash2 = require("@xylabs/lodash");
|
|
77
|
+
var import_promise = require("@xylabs/promise");
|
|
78
|
+
var import_archivist_abstract = require("@xyo-network/archivist-abstract");
|
|
79
|
+
var import_archivist_model2 = require("@xyo-network/archivist-model");
|
|
80
|
+
var import_core = require("@xyo-network/core");
|
|
81
|
+
var import_payload_wrapper = require("@xyo-network/payload-wrapper");
|
|
82
|
+
var import_js_cookie = __toESM(require("js-cookie"));
|
|
83
|
+
var CookieArchivistConfigSchema = "network.xyo.archivist.cookie.config";
|
|
84
|
+
var _CookieArchivist = class _CookieArchivist extends import_archivist_abstract.AbstractArchivist {
|
|
85
|
+
get domain() {
|
|
86
|
+
var _a;
|
|
87
|
+
return (_a = this.config) == null ? void 0 : _a.domain;
|
|
88
|
+
}
|
|
89
|
+
get maxEntries() {
|
|
90
|
+
var _a;
|
|
91
|
+
return ((_a = this.config) == null ? void 0 : _a.maxEntries) ?? 60;
|
|
92
|
+
}
|
|
93
|
+
get maxEntrySize() {
|
|
94
|
+
var _a;
|
|
95
|
+
return ((_a = this.config) == null ? void 0 : _a.maxEntrySize) ?? 4e3;
|
|
96
|
+
}
|
|
97
|
+
get namespace() {
|
|
98
|
+
var _a;
|
|
99
|
+
return ((_a = this.config) == null ? void 0 : _a.namespace) ?? "xyoarch";
|
|
100
|
+
}
|
|
101
|
+
get queries() {
|
|
102
|
+
return [
|
|
103
|
+
import_archivist_model2.ArchivistAllQuerySchema,
|
|
104
|
+
import_archivist_model2.ArchivistDeleteQuerySchema,
|
|
105
|
+
import_archivist_model2.ArchivistClearQuerySchema,
|
|
106
|
+
import_archivist_model2.ArchivistInsertQuerySchema,
|
|
107
|
+
import_archivist_model2.ArchivistCommitQuerySchema,
|
|
108
|
+
...super.queries
|
|
109
|
+
];
|
|
110
|
+
}
|
|
111
|
+
allHandler() {
|
|
112
|
+
try {
|
|
113
|
+
return Object.entries(import_js_cookie.default.get()).filter(([key]) => key.startsWith(`${this.namespace}-`)).map(([, value]) => JSON.parse(value));
|
|
114
|
+
} catch (ex) {
|
|
115
|
+
console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
|
|
116
|
+
throw ex;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
clearHandler() {
|
|
120
|
+
try {
|
|
121
|
+
Object.entries(import_js_cookie.default.get()).map(([key]) => {
|
|
122
|
+
if (key.startsWith(`${this.namespace}-`)) {
|
|
123
|
+
import_js_cookie.default.remove(key);
|
|
124
|
+
}
|
|
125
|
+
});
|
|
126
|
+
} catch (ex) {
|
|
127
|
+
console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
|
|
128
|
+
throw ex;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
async commitHandler() {
|
|
132
|
+
var _a;
|
|
133
|
+
try {
|
|
134
|
+
const payloads = await this.all();
|
|
135
|
+
(0, import_assert.assertEx)(payloads.length > 0, "Nothing to commit");
|
|
136
|
+
const settled = await Promise.allSettled((0, import_lodash2.compact)((_a = Object.values((await this.parents()).commit ?? [])) == null ? void 0 : _a.map(async (parent) => {
|
|
137
|
+
var _a2;
|
|
138
|
+
const queryPayload = {
|
|
139
|
+
schema: import_archivist_model2.ArchivistInsertQuerySchema
|
|
140
|
+
};
|
|
141
|
+
const query = await this.bindQuery(queryPayload, payloads);
|
|
142
|
+
return (_a2 = await (parent == null ? void 0 : parent.query(query[0], query[1]))) == null ? void 0 : _a2[0];
|
|
143
|
+
})));
|
|
144
|
+
await this.clear();
|
|
145
|
+
return (0, import_lodash2.compact)(settled.filter(import_promise.fulfilled).map((result) => result.value));
|
|
146
|
+
} catch (ex) {
|
|
147
|
+
console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
|
|
148
|
+
throw ex;
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
async deleteHandler(hashes) {
|
|
152
|
+
const payloadPairs = await Promise.all((await this.get(hashes)).map(async (payload) => [
|
|
153
|
+
await import_core.PayloadHasher.hashAsync(payload),
|
|
154
|
+
payload
|
|
155
|
+
]));
|
|
156
|
+
const deletedPairs = (0, import_lodash2.compact)(await Promise.all(payloadPairs.map(([hash, payload]) => {
|
|
157
|
+
import_js_cookie.default.remove(hash);
|
|
158
|
+
return [
|
|
159
|
+
hash,
|
|
160
|
+
payload
|
|
161
|
+
];
|
|
162
|
+
})));
|
|
163
|
+
return deletedPairs.map(([hash]) => hash);
|
|
164
|
+
}
|
|
165
|
+
getHandler(hashes) {
|
|
166
|
+
return (0, import_lodash2.compact)(hashes.map((hash) => {
|
|
167
|
+
const cookieString = import_js_cookie.default.get(this.keyFromHash(hash));
|
|
168
|
+
return cookieString ? JSON.parse(cookieString) : void 0;
|
|
169
|
+
}));
|
|
170
|
+
}
|
|
171
|
+
async insertHandler(payloads) {
|
|
172
|
+
try {
|
|
173
|
+
const resultPayloads = await Promise.all(payloads.map(async (payload) => {
|
|
174
|
+
const wrapper = import_payload_wrapper.PayloadWrapper.wrap(payload);
|
|
175
|
+
const key = this.keyFromHash(await wrapper.hashAsync());
|
|
176
|
+
const value = JSON.stringify(wrapper.payload());
|
|
177
|
+
(0, import_assert.assertEx)(value.length < this.maxEntrySize, `Payload too large [${wrapper.hashAsync()}, ${value.length}]`);
|
|
178
|
+
import_js_cookie.default.set(key, JSON.stringify(wrapper.payload()));
|
|
179
|
+
return wrapper.payload();
|
|
180
|
+
}));
|
|
181
|
+
return resultPayloads;
|
|
182
|
+
} catch (ex) {
|
|
183
|
+
console.error(`Error: ${JSON.stringify(ex, null, 2)}`);
|
|
184
|
+
throw ex;
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
keyFromHash(hash) {
|
|
188
|
+
return `${this.namespace}-${hash}`;
|
|
189
|
+
}
|
|
190
|
+
};
|
|
191
|
+
__name(_CookieArchivist, "CookieArchivist");
|
|
192
|
+
__publicField(_CookieArchivist, "configSchemas", [
|
|
193
|
+
CookieArchivistConfigSchema
|
|
194
|
+
]);
|
|
195
|
+
var CookieArchivist = _CookieArchivist;
|
|
196
|
+
|
|
197
|
+
// src/StorageArchivist.ts
|
|
198
|
+
var import_assert2 = require("@xylabs/assert");
|
|
199
|
+
var import_lodash3 = require("@xylabs/lodash");
|
|
200
|
+
var import_promise2 = require("@xylabs/promise");
|
|
201
|
+
var import_archivist_abstract2 = require("@xyo-network/archivist-abstract");
|
|
202
|
+
var import_archivist_model3 = require("@xyo-network/archivist-model");
|
|
203
|
+
var import_core2 = require("@xyo-network/core");
|
|
204
|
+
var import_payload_wrapper2 = require("@xyo-network/payload-wrapper");
|
|
205
|
+
var import_store2 = __toESM(require("store2"));
|
|
206
|
+
var StorageArchivistConfigSchema = "network.xyo.archivist.storage.config";
|
|
207
|
+
var _StorageArchivist = class _StorageArchivist extends import_archivist_abstract2.AbstractArchivist {
|
|
208
|
+
_privateStorage;
|
|
209
|
+
_storage;
|
|
210
|
+
get maxEntries() {
|
|
211
|
+
var _a;
|
|
212
|
+
return ((_a = this.config) == null ? void 0 : _a.maxEntries) ?? 1e3;
|
|
213
|
+
}
|
|
214
|
+
get maxEntrySize() {
|
|
215
|
+
var _a;
|
|
216
|
+
return ((_a = this.config) == null ? void 0 : _a.maxEntrySize) ?? 16e3;
|
|
217
|
+
}
|
|
218
|
+
get namespace() {
|
|
219
|
+
var _a;
|
|
220
|
+
return ((_a = this.config) == null ? void 0 : _a.namespace) ?? "xyo-archivist";
|
|
221
|
+
}
|
|
222
|
+
get persistAccount() {
|
|
223
|
+
var _a;
|
|
224
|
+
return ((_a = this.config) == null ? void 0 : _a.persistAccount) ?? false;
|
|
225
|
+
}
|
|
226
|
+
get queries() {
|
|
227
|
+
return [
|
|
228
|
+
import_archivist_model3.ArchivistAllQuerySchema,
|
|
229
|
+
import_archivist_model3.ArchivistDeleteQuerySchema,
|
|
230
|
+
import_archivist_model3.ArchivistClearQuerySchema,
|
|
231
|
+
import_archivist_model3.ArchivistInsertQuerySchema,
|
|
232
|
+
import_archivist_model3.ArchivistCommitQuerySchema,
|
|
233
|
+
...super.queries
|
|
234
|
+
];
|
|
235
|
+
}
|
|
236
|
+
get type() {
|
|
237
|
+
var _a;
|
|
238
|
+
return ((_a = this.config) == null ? void 0 : _a.type) ?? "local";
|
|
239
|
+
}
|
|
240
|
+
/* This has to be a getter so that it can access it during construction */
|
|
241
|
+
get privateStorage() {
|
|
242
|
+
this._privateStorage = this._storage ?? import_store2.default[this.type].namespace(`${this.namespace}|private`);
|
|
243
|
+
return this._privateStorage;
|
|
244
|
+
}
|
|
245
|
+
/* This has to be a getter so that it can access it during construction */
|
|
246
|
+
get storage() {
|
|
247
|
+
this._storage = this._storage ?? import_store2.default[this.type].namespace(this.namespace);
|
|
248
|
+
return this._storage;
|
|
249
|
+
}
|
|
250
|
+
/*override async loadAccount(account?: AccountInstance, persistAccount?: boolean, privateStorage?: StoreBase, _logger?: Logger) {
|
|
251
|
+
if (!this._account) {
|
|
252
|
+
if (persistAccount) {
|
|
253
|
+
const privateKey = privateStorage?.get('privateKey')
|
|
254
|
+
if (privateKey) {
|
|
255
|
+
try {
|
|
256
|
+
this._account = await Account.create({ privateKey })
|
|
257
|
+
return this._account
|
|
258
|
+
} catch (ex) {
|
|
259
|
+
console.error(`Error reading Account from storage [${ex}] - Recreating Account`)
|
|
260
|
+
privateStorage?.remove('privateKey')
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
return await super.loadAccount()
|
|
266
|
+
}*/
|
|
267
|
+
allHandler() {
|
|
268
|
+
var _a;
|
|
269
|
+
(_a = this.logger) == null ? void 0 : _a.log(`this.storage.length: ${this.storage.length}`);
|
|
270
|
+
return Object.entries(this.storage.getAll()).map(([, value]) => value);
|
|
271
|
+
}
|
|
272
|
+
clearHandler() {
|
|
273
|
+
var _a;
|
|
274
|
+
(_a = this.logger) == null ? void 0 : _a.log(`this.storage.length: ${this.storage.length}`);
|
|
275
|
+
this.storage.clear();
|
|
276
|
+
return this.emit("cleared", {
|
|
277
|
+
module: this
|
|
278
|
+
});
|
|
279
|
+
}
|
|
280
|
+
async commitHandler() {
|
|
281
|
+
var _a, _b;
|
|
282
|
+
(_a = this.logger) == null ? void 0 : _a.log(`this.storage.length: ${this.storage.length}`);
|
|
283
|
+
const payloads = await this.all();
|
|
284
|
+
(0, import_assert2.assertEx)(payloads.length > 0, "Nothing to commit");
|
|
285
|
+
const settled = await Promise.allSettled((0, import_lodash3.compact)((_b = Object.values((await this.parents()).commit ?? [])) == null ? void 0 : _b.map(async (parent) => {
|
|
286
|
+
var _a2;
|
|
287
|
+
const queryPayload = {
|
|
288
|
+
schema: import_archivist_model3.ArchivistInsertQuerySchema
|
|
289
|
+
};
|
|
290
|
+
const query = await this.bindQuery(queryPayload, payloads);
|
|
291
|
+
return (_a2 = await (parent == null ? void 0 : parent.query(query[0], query[1]))) == null ? void 0 : _a2[0];
|
|
292
|
+
})));
|
|
293
|
+
await this.clear();
|
|
294
|
+
return (0, import_lodash3.compact)(settled.filter(import_promise2.fulfilled).map((result) => result.value));
|
|
295
|
+
}
|
|
296
|
+
async deleteHandler(hashes) {
|
|
297
|
+
const payloadPairs = await Promise.all((await this.get(hashes)).map(async (payload) => [
|
|
298
|
+
await import_core2.PayloadHasher.hashAsync(payload),
|
|
299
|
+
payload
|
|
300
|
+
]));
|
|
301
|
+
const deletedPairs = (0, import_lodash3.compact)(await Promise.all(payloadPairs.map(([hash, payload]) => {
|
|
302
|
+
this.storage.remove(hash);
|
|
303
|
+
return [
|
|
304
|
+
hash,
|
|
305
|
+
payload
|
|
306
|
+
];
|
|
307
|
+
})));
|
|
308
|
+
return deletedPairs.map(([hash]) => hash);
|
|
309
|
+
}
|
|
310
|
+
getHandler(hashes) {
|
|
311
|
+
return (0, import_lodash3.compact)(hashes.map((hash) => {
|
|
312
|
+
return this.storage.get(hash);
|
|
313
|
+
}));
|
|
314
|
+
}
|
|
315
|
+
async insertHandler(payloads) {
|
|
316
|
+
const resultPayloads = await Promise.all(payloads.map(async (payload) => {
|
|
317
|
+
const wrapper = import_payload_wrapper2.PayloadWrapper.wrap(payload);
|
|
318
|
+
const hash = await wrapper.hashAsync();
|
|
319
|
+
const value = JSON.stringify(wrapper.payload());
|
|
320
|
+
(0, import_assert2.assertEx)(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`);
|
|
321
|
+
this.storage.set(hash, wrapper.payload());
|
|
322
|
+
return wrapper.payload();
|
|
323
|
+
}));
|
|
324
|
+
return resultPayloads;
|
|
325
|
+
}
|
|
326
|
+
saveAccount() {
|
|
327
|
+
var _a;
|
|
328
|
+
if (this.persistAccount) {
|
|
329
|
+
const account = this.account;
|
|
330
|
+
(_a = this.logger) == null ? void 0 : _a.log(account.address);
|
|
331
|
+
this.privateStorage.set("privateKey", account.private.hex);
|
|
332
|
+
}
|
|
333
|
+
}
|
|
334
|
+
async startHandler() {
|
|
335
|
+
await super.startHandler();
|
|
336
|
+
this.saveAccount();
|
|
337
|
+
return true;
|
|
338
|
+
}
|
|
339
|
+
};
|
|
340
|
+
__name(_StorageArchivist, "StorageArchivist");
|
|
341
|
+
__publicField(_StorageArchivist, "configSchemas", [
|
|
342
|
+
StorageArchivistConfigSchema
|
|
343
|
+
]);
|
|
344
|
+
var StorageArchivist = _StorageArchivist;
|
|
345
|
+
|
|
346
|
+
// src/index.ts
|
|
347
|
+
__reExport(src_exports, require("@xyo-network/archivist-abstract"), module.exports);
|
|
348
|
+
__reExport(src_exports, require("@xyo-network/archivist-model"), module.exports);
|
|
349
|
+
__reExport(src_exports, require("@xyo-network/archivist-wrapper"), module.exports);
|
|
350
|
+
__reExport(src_exports, require("@xyo-network/memory-archivist"), module.exports);
|
|
351
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
352
|
+
0 && (module.exports = {
|
|
353
|
+
AbstractArchivingModule,
|
|
354
|
+
CookieArchivist,
|
|
355
|
+
CookieArchivistConfigSchema,
|
|
356
|
+
StorageArchivist,
|
|
357
|
+
StorageArchivistConfigSchema,
|
|
358
|
+
...require("@xyo-network/archivist-abstract"),
|
|
359
|
+
...require("@xyo-network/archivist-model"),
|
|
360
|
+
...require("@xyo-network/archivist-wrapper"),
|
|
361
|
+
...require("@xyo-network/memory-archivist")
|
|
362
|
+
});
|
|
363
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/AbstractArchivingModule.ts","../../src/CookieArchivist.ts","../../src/StorageArchivist.ts"],"sourcesContent":["export * from './AbstractArchivingModule'\nexport * 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 { compact } from '@xylabs/lodash'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { ArchivistInstance, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { AbstractModuleInstance, AnyConfigSchema, Module, ModuleConfig, ModuleEventData, ModuleParams, ModuleQueryResult } from '@xyo-network/module'\nimport { ModuleError, Payload, Query } from '@xyo-network/payload-model'\n\nexport type ArchivingModuleConfig<T extends ModuleConfig = ModuleConfig> = ModuleConfig<\n {\n archivists?: string[]\n schema: string\n } & T\n>\n// @creatableModule()\nexport abstract class AbstractArchivingModule<\n TParams extends ModuleParams<AnyConfigSchema<ArchivingModuleConfig>> = ModuleParams<AnyConfigSchema<ArchivingModuleConfig>>,\n TEventData extends ModuleEventData = ModuleEventData,\n >\n extends AbstractModuleInstance<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n protected override async bindQueryResult<T extends Query>(\n query: T,\n payloads: Payload[],\n additionalWitnesses: AccountInstance[] = [],\n errorPayloads: ModuleError[] = [],\n ): Promise<ModuleQueryResult> {\n const result = await super.bindQueryResult(query, payloads, additionalWitnesses, errorPayloads)\n await this.storeToArchivists(result.flat())\n return result\n }\n\n protected async resolveArchivists(): Promise<ArchivistInstance[]> {\n return compact(\n (await Promise.all((await this.resolve({ address: this.config.archivists ?? [] })) ?? [])).map((module) =>\n asArchivistInstance(module, () => `Module failed to cast to Archivist [${module.config.name}]`),\n ),\n )\n }\n\n protected async storeToArchivists(payloads: Payload[]): Promise<Payload[]> {\n const archivists = await this.resolveArchivists()\n return (\n await Promise.all(\n archivists.map((archivist) => {\n return archivist.insert?.(payloads)\n }),\n )\n ).map(([bw]) => bw)\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { compact } from '@xylabs/lodash'\nimport { fulfilled } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuery,\n ArchivistInsertQuerySchema,\n ArchivistModuleEventData,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { AnyConfigSchema } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\nimport { Promisable, PromisableArray } from '@xyo-network/promise'\nimport Cookies from 'js-cookie'\n\nexport type CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\nexport const CookieArchivistConfigSchema: CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\n\nexport type CookieArchivistConfig = ArchivistConfig<{\n domain?: string\n maxEntries?: number\n maxEntrySize?: number\n namespace?: string\n schema: CookieArchivistConfigSchema\n}>\n\nexport type CookieArchivistParams = ArchivistParams<AnyConfigSchema<CookieArchivistConfig>>\n\nexport class CookieArchivist<\n TParams extends CookieArchivistParams,\n TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,\n> extends AbstractArchivist<TParams, TEventData> {\n static override configSchemas = [CookieArchivistConfigSchema]\n\n get domain() {\n return this.config?.domain\n }\n\n get maxEntries() {\n //all browsers support at least 60 cookies\n return this.config?.maxEntries ?? 60\n }\n\n get maxEntrySize() {\n //all browsers support at least 4000 length per cookie\n return this.config?.maxEntrySize ?? 4000\n }\n\n get namespace() {\n return this.config?.namespace ?? 'xyoarch'\n }\n\n override get queries(): string[] {\n return [\n ArchivistAllQuerySchema,\n ArchivistDeleteQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistInsertQuerySchema,\n ArchivistCommitQuerySchema,\n ...super.queries,\n ]\n }\n\n protected override allHandler(): PromisableArray<Payload> {\n try {\n return Object.entries(Cookies.get())\n .filter(([key]) => key.startsWith(`${this.namespace}-`))\n .map(([, value]) => JSON.parse(value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override clearHandler(): void | Promise<void> {\n try {\n Object.entries(Cookies.get()).map(([key]) => {\n if (key.startsWith(`${this.namespace}-`)) {\n Cookies.remove(key)\n }\n })\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async commitHandler(): Promise<BoundWitness[]> {\n try {\n const payloads = await this.all()\n assertEx(payloads.length > 0, 'Nothing to commit')\n const settled = await Promise.allSettled(\n compact(\n Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {\n const queryPayload: ArchivistInsertQuery = {\n schema: ArchivistInsertQuerySchema,\n }\n const query = await this.bindQuery(queryPayload, payloads)\n return (await parent?.query(query[0], query[1]))?.[0]\n }),\n ),\n )\n await this.clear()\n return compact(settled.filter(fulfilled).map((result) => result.value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async deleteHandler(hashes: string[]): Promise<string[]> {\n const payloadPairs: [string, Payload][] = await Promise.all(\n (await this.get(hashes)).map<Promise<[string, Payload]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]),\n )\n const deletedPairs: [string, Payload][] = compact(\n await Promise.all(\n payloadPairs.map<[string, Payload] | undefined>(([hash, payload]) => {\n Cookies.remove(hash)\n return [hash, payload]\n }),\n ),\n )\n return deletedPairs.map(([hash]) => hash)\n }\n\n protected override getHandler(hashes: string[]): Promisable<Payload[]> {\n return compact(\n hashes.map((hash) => {\n const cookieString = Cookies.get(this.keyFromHash(hash))\n return cookieString ? JSON.parse(cookieString) : undefined\n }),\n )\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {\n try {\n const resultPayloads: Payload[] = await Promise.all(\n payloads.map(async (payload) => {\n const wrapper = PayloadWrapper.wrap(payload)\n const key = this.keyFromHash(await wrapper.hashAsync())\n const value = JSON.stringify(wrapper.payload())\n assertEx(value.length < this.maxEntrySize, `Payload too large [${wrapper.hashAsync()}, ${value.length}]`)\n Cookies.set(key, JSON.stringify(wrapper.payload()))\n return wrapper.payload()\n }),\n )\n return resultPayloads\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n private keyFromHash(hash: string) {\n return `${this.namespace}-${hash}`\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { compact } from '@xylabs/lodash'\nimport { fulfilled } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuery,\n ArchivistInsertQuerySchema,\n ArchivistInstance,\n ArchivistModuleEventData,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { AnyConfigSchema } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\nimport { Promisable, PromisableArray } from '@xyo-network/promise'\nimport store, { StoreBase } from 'store2'\n\nexport type StorageArchivistConfigSchema = 'network.xyo.archivist.storage.config'\nexport const StorageArchivistConfigSchema: StorageArchivistConfigSchema = 'network.xyo.archivist.storage.config'\n\nexport type StorageArchivistConfig = ArchivistConfig<{\n maxEntries?: number\n maxEntrySize?: number\n namespace?: string\n persistAccount?: boolean\n schema: StorageArchivistConfigSchema\n type?: 'local' | 'session' | 'page'\n}>\n\nexport type StorageArchivistParams = ArchivistParams<AnyConfigSchema<StorageArchivistConfig>>\nexport class StorageArchivist<\n TParams extends StorageArchivistParams = StorageArchivistParams,\n TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,\n >\n extends AbstractArchivist<TParams, TEventData>\n implements ArchivistInstance\n{\n static override configSchemas = [StorageArchivistConfigSchema]\n\n private _privateStorage: StoreBase | undefined\n private _storage: StoreBase | undefined\n\n get maxEntries() {\n return this.config?.maxEntries ?? 1000\n }\n\n get maxEntrySize() {\n return this.config?.maxEntrySize ?? 16000\n }\n\n get namespace() {\n return this.config?.namespace ?? 'xyo-archivist'\n }\n\n get persistAccount() {\n return this.config?.persistAccount ?? false\n }\n\n override get queries(): string[] {\n return [\n ArchivistAllQuerySchema,\n ArchivistDeleteQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistInsertQuerySchema,\n ArchivistCommitQuerySchema,\n ...super.queries,\n ]\n }\n\n get type() {\n return this.config?.type ?? 'local'\n }\n\n /* This has to be a getter so that it can access it during construction */\n private get privateStorage(): StoreBase {\n this._privateStorage = this._storage ?? store[this.type].namespace(`${this.namespace}|private`)\n return this._privateStorage\n }\n\n /* This has to be a getter so that it can access it during construction */\n private get storage(): StoreBase {\n this._storage = this._storage ?? store[this.type].namespace(this.namespace)\n return this._storage\n }\n\n /*override async loadAccount(account?: AccountInstance, persistAccount?: boolean, privateStorage?: StoreBase, _logger?: Logger) {\n if (!this._account) {\n if (persistAccount) {\n const privateKey = privateStorage?.get('privateKey')\n if (privateKey) {\n try {\n this._account = await Account.create({ privateKey })\n return this._account\n } catch (ex) {\n console.error(`Error reading Account from storage [${ex}] - Recreating Account`)\n privateStorage?.remove('privateKey')\n }\n }\n }\n }\n return await super.loadAccount()\n }*/\n\n protected override allHandler(): PromisableArray<Payload> {\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\n return Object.entries(this.storage.getAll()).map(([, value]) => value)\n }\n\n protected override clearHandler(): void | Promise<void> {\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\n this.storage.clear()\n return this.emit('cleared', { module: this })\n }\n\n protected override async commitHandler(): Promise<BoundWitness[]> {\n this.logger?.log(`this.storage.length: ${this.storage.length}`)\n const payloads = await this.all()\n assertEx(payloads.length > 0, 'Nothing to commit')\n const settled = await Promise.allSettled(\n compact(\n Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {\n const queryPayload: ArchivistInsertQuery = {\n schema: ArchivistInsertQuerySchema,\n }\n const query = await this.bindQuery(queryPayload, payloads)\n return (await parent?.query(query[0], query[1]))?.[0]\n }),\n ),\n )\n // TODO - rather than clear, delete the payloads that come back as successfully inserted\n await this.clear()\n return compact(settled.filter(fulfilled).map((result) => result.value))\n }\n\n protected override async deleteHandler(hashes: string[]): Promise<string[]> {\n const payloadPairs: [string, Payload][] = await Promise.all(\n (await this.get(hashes)).map<Promise<[string, Payload]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]),\n )\n const deletedPairs: [string, Payload][] = compact(\n await Promise.all(\n payloadPairs.map<[string, Payload] | undefined>(([hash, payload]) => {\n this.storage.remove(hash)\n return [hash, payload]\n }),\n ),\n )\n return deletedPairs.map(([hash]) => hash)\n }\n\n protected override getHandler(hashes: string[]): Promisable<Payload[]> {\n return compact(\n hashes.map((hash) => {\n return this.storage.get(hash)\n }),\n )\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {\n const resultPayloads = await Promise.all(\n payloads.map(async (payload) => {\n const wrapper = PayloadWrapper.wrap(payload)\n const hash = await wrapper.hashAsync()\n const value = JSON.stringify(wrapper.payload())\n assertEx(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`)\n this.storage.set(hash, wrapper.payload())\n return wrapper.payload()\n }),\n )\n return resultPayloads\n }\n\n protected saveAccount() {\n if (this.persistAccount) {\n const account = this.account\n this.logger?.log(account.address)\n this.privateStorage.set('privateKey', account.private.hex)\n }\n }\n\n protected override async startHandler() {\n await super.startHandler()\n this.saveAccount()\n return true\n }\n}\n"],"mappings":"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","names":["AbstractArchivingModule","AbstractModuleInstance","bindQueryResult","query","payloads","additionalWitnesses","errorPayloads","result","storeToArchivists","flat","resolveArchivists","compact","Promise","all","resolve","address","config","archivists","map","module","asArchivistInstance","name","archivist","insert","bw","import_lodash","import_archivist_model","CookieArchivistConfigSchema","CookieArchivist","AbstractArchivist","domain","config","maxEntries","maxEntrySize","namespace","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","allHandler","Object","entries","Cookies","get","filter","key","startsWith","map","value","JSON","parse","ex","console","error","stringify","clearHandler","remove","commitHandler","payloads","all","assertEx","length","settled","Promise","allSettled","compact","values","parents","commit","parent","_a","queryPayload","schema","query","bindQuery","clear","fulfilled","result","deleteHandler","hashes","payloadPairs","payload","PayloadHasher","hashAsync","deletedPairs","hash","getHandler","cookieString","keyFromHash","undefined","insertHandler","resultPayloads","wrapper","PayloadWrapper","wrap","set","configSchemas","import_assert","import_lodash","import_promise","import_archivist_abstract","import_archivist_model","import_core","import_payload_wrapper","StorageArchivistConfigSchema","StorageArchivist","AbstractArchivist","_privateStorage","_storage","maxEntries","config","maxEntrySize","namespace","persistAccount","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","type","privateStorage","store","storage","allHandler","logger","log","length","Object","entries","getAll","map","value","clearHandler","clear","emit","module","commitHandler","payloads","all","assertEx","settled","Promise","allSettled","compact","values","parents","commit","parent","_a","queryPayload","schema","query","bindQuery","filter","fulfilled","result","deleteHandler","hashes","payloadPairs","get","payload","PayloadHasher","hashAsync","deletedPairs","hash","remove","getHandler","insertHandler","resultPayloads","wrapper","PayloadWrapper","wrap","JSON","stringify","set","saveAccount","account","address","private","hex","startHandler","configSchemas"]}
|
|
@@ -1,14 +1,16 @@
|
|
|
1
1
|
var __defProp = Object.defineProperty;
|
|
2
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
2
3
|
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
4
|
+
var __publicField = (obj, key, value) => {
|
|
5
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
6
|
+
return value;
|
|
7
|
+
};
|
|
3
8
|
|
|
4
9
|
// src/AbstractArchivingModule.ts
|
|
5
10
|
import { compact } from "@xylabs/lodash";
|
|
6
11
|
import { asArchivistInstance } from "@xyo-network/archivist-model";
|
|
7
12
|
import { AbstractModuleInstance } from "@xyo-network/module";
|
|
8
|
-
var
|
|
9
|
-
static {
|
|
10
|
-
__name(this, "AbstractArchivingModule");
|
|
11
|
-
}
|
|
13
|
+
var _AbstractArchivingModule = class _AbstractArchivingModule extends AbstractModuleInstance {
|
|
12
14
|
async bindQueryResult(query, payloads, additionalWitnesses = [], errorPayloads = []) {
|
|
13
15
|
const result = await super.bindQueryResult(query, payloads, additionalWitnesses, errorPayloads);
|
|
14
16
|
await this.storeToArchivists(result.flat());
|
|
@@ -22,10 +24,13 @@ var AbstractArchivingModule = class extends AbstractModuleInstance {
|
|
|
22
24
|
async storeToArchivists(payloads) {
|
|
23
25
|
const archivists = await this.resolveArchivists();
|
|
24
26
|
return (await Promise.all(archivists.map((archivist) => {
|
|
25
|
-
|
|
27
|
+
var _a;
|
|
28
|
+
return (_a = archivist.insert) == null ? void 0 : _a.call(archivist, payloads);
|
|
26
29
|
}))).map(([bw]) => bw);
|
|
27
30
|
}
|
|
28
31
|
};
|
|
32
|
+
__name(_AbstractArchivingModule, "AbstractArchivingModule");
|
|
33
|
+
var AbstractArchivingModule = _AbstractArchivingModule;
|
|
29
34
|
|
|
30
35
|
// src/CookieArchivist.ts
|
|
31
36
|
import { assertEx } from "@xylabs/assert";
|
|
@@ -37,24 +42,22 @@ import { PayloadHasher } from "@xyo-network/core";
|
|
|
37
42
|
import { PayloadWrapper } from "@xyo-network/payload-wrapper";
|
|
38
43
|
import Cookies from "js-cookie";
|
|
39
44
|
var CookieArchivistConfigSchema = "network.xyo.archivist.cookie.config";
|
|
40
|
-
var
|
|
41
|
-
static {
|
|
42
|
-
__name(this, "CookieArchivist");
|
|
43
|
-
}
|
|
44
|
-
static configSchemas = [
|
|
45
|
-
CookieArchivistConfigSchema
|
|
46
|
-
];
|
|
45
|
+
var _CookieArchivist = class _CookieArchivist extends AbstractArchivist {
|
|
47
46
|
get domain() {
|
|
48
|
-
|
|
47
|
+
var _a;
|
|
48
|
+
return (_a = this.config) == null ? void 0 : _a.domain;
|
|
49
49
|
}
|
|
50
50
|
get maxEntries() {
|
|
51
|
-
|
|
51
|
+
var _a;
|
|
52
|
+
return ((_a = this.config) == null ? void 0 : _a.maxEntries) ?? 60;
|
|
52
53
|
}
|
|
53
54
|
get maxEntrySize() {
|
|
54
|
-
|
|
55
|
+
var _a;
|
|
56
|
+
return ((_a = this.config) == null ? void 0 : _a.maxEntrySize) ?? 4e3;
|
|
55
57
|
}
|
|
56
58
|
get namespace() {
|
|
57
|
-
|
|
59
|
+
var _a;
|
|
60
|
+
return ((_a = this.config) == null ? void 0 : _a.namespace) ?? "xyoarch";
|
|
58
61
|
}
|
|
59
62
|
get queries() {
|
|
60
63
|
return [
|
|
@@ -87,15 +90,17 @@ var CookieArchivist = class extends AbstractArchivist {
|
|
|
87
90
|
}
|
|
88
91
|
}
|
|
89
92
|
async commitHandler() {
|
|
93
|
+
var _a;
|
|
90
94
|
try {
|
|
91
95
|
const payloads = await this.all();
|
|
92
96
|
assertEx(payloads.length > 0, "Nothing to commit");
|
|
93
|
-
const settled = await Promise.allSettled(compact2(Object.values((await this.parents()).commit ?? [])
|
|
97
|
+
const settled = await Promise.allSettled(compact2((_a = Object.values((await this.parents()).commit ?? [])) == null ? void 0 : _a.map(async (parent) => {
|
|
98
|
+
var _a2;
|
|
94
99
|
const queryPayload = {
|
|
95
100
|
schema: ArchivistInsertQuerySchema
|
|
96
101
|
};
|
|
97
102
|
const query = await this.bindQuery(queryPayload, payloads);
|
|
98
|
-
return (await parent
|
|
103
|
+
return (_a2 = await (parent == null ? void 0 : parent.query(query[0], query[1]))) == null ? void 0 : _a2[0];
|
|
99
104
|
})));
|
|
100
105
|
await this.clear();
|
|
101
106
|
return compact2(settled.filter(fulfilled).map((result) => result.value));
|
|
@@ -144,6 +149,11 @@ var CookieArchivist = class extends AbstractArchivist {
|
|
|
144
149
|
return `${this.namespace}-${hash}`;
|
|
145
150
|
}
|
|
146
151
|
};
|
|
152
|
+
__name(_CookieArchivist, "CookieArchivist");
|
|
153
|
+
__publicField(_CookieArchivist, "configSchemas", [
|
|
154
|
+
CookieArchivistConfigSchema
|
|
155
|
+
]);
|
|
156
|
+
var CookieArchivist = _CookieArchivist;
|
|
147
157
|
|
|
148
158
|
// src/StorageArchivist.ts
|
|
149
159
|
import { assertEx as assertEx2 } from "@xylabs/assert";
|
|
@@ -155,26 +165,24 @@ import { PayloadHasher as PayloadHasher2 } from "@xyo-network/core";
|
|
|
155
165
|
import { PayloadWrapper as PayloadWrapper2 } from "@xyo-network/payload-wrapper";
|
|
156
166
|
import store from "store2";
|
|
157
167
|
var StorageArchivistConfigSchema = "network.xyo.archivist.storage.config";
|
|
158
|
-
var
|
|
159
|
-
static {
|
|
160
|
-
__name(this, "StorageArchivist");
|
|
161
|
-
}
|
|
162
|
-
static configSchemas = [
|
|
163
|
-
StorageArchivistConfigSchema
|
|
164
|
-
];
|
|
168
|
+
var _StorageArchivist = class _StorageArchivist extends AbstractArchivist2 {
|
|
165
169
|
_privateStorage;
|
|
166
170
|
_storage;
|
|
167
171
|
get maxEntries() {
|
|
168
|
-
|
|
172
|
+
var _a;
|
|
173
|
+
return ((_a = this.config) == null ? void 0 : _a.maxEntries) ?? 1e3;
|
|
169
174
|
}
|
|
170
175
|
get maxEntrySize() {
|
|
171
|
-
|
|
176
|
+
var _a;
|
|
177
|
+
return ((_a = this.config) == null ? void 0 : _a.maxEntrySize) ?? 16e3;
|
|
172
178
|
}
|
|
173
179
|
get namespace() {
|
|
174
|
-
|
|
180
|
+
var _a;
|
|
181
|
+
return ((_a = this.config) == null ? void 0 : _a.namespace) ?? "xyo-archivist";
|
|
175
182
|
}
|
|
176
183
|
get persistAccount() {
|
|
177
|
-
|
|
184
|
+
var _a;
|
|
185
|
+
return ((_a = this.config) == null ? void 0 : _a.persistAccount) ?? false;
|
|
178
186
|
}
|
|
179
187
|
get queries() {
|
|
180
188
|
return [
|
|
@@ -187,7 +195,8 @@ var StorageArchivist = class extends AbstractArchivist2 {
|
|
|
187
195
|
];
|
|
188
196
|
}
|
|
189
197
|
get type() {
|
|
190
|
-
|
|
198
|
+
var _a;
|
|
199
|
+
return ((_a = this.config) == null ? void 0 : _a.type) ?? "local";
|
|
191
200
|
}
|
|
192
201
|
/* This has to be a getter so that it can access it during construction */
|
|
193
202
|
get privateStorage() {
|
|
@@ -217,26 +226,30 @@ var StorageArchivist = class extends AbstractArchivist2 {
|
|
|
217
226
|
return await super.loadAccount()
|
|
218
227
|
}*/
|
|
219
228
|
allHandler() {
|
|
220
|
-
|
|
229
|
+
var _a;
|
|
230
|
+
(_a = this.logger) == null ? void 0 : _a.log(`this.storage.length: ${this.storage.length}`);
|
|
221
231
|
return Object.entries(this.storage.getAll()).map(([, value]) => value);
|
|
222
232
|
}
|
|
223
233
|
clearHandler() {
|
|
224
|
-
|
|
234
|
+
var _a;
|
|
235
|
+
(_a = this.logger) == null ? void 0 : _a.log(`this.storage.length: ${this.storage.length}`);
|
|
225
236
|
this.storage.clear();
|
|
226
237
|
return this.emit("cleared", {
|
|
227
238
|
module: this
|
|
228
239
|
});
|
|
229
240
|
}
|
|
230
241
|
async commitHandler() {
|
|
231
|
-
|
|
242
|
+
var _a, _b;
|
|
243
|
+
(_a = this.logger) == null ? void 0 : _a.log(`this.storage.length: ${this.storage.length}`);
|
|
232
244
|
const payloads = await this.all();
|
|
233
245
|
assertEx2(payloads.length > 0, "Nothing to commit");
|
|
234
|
-
const settled = await Promise.allSettled(compact3(Object.values((await this.parents()).commit ?? [])
|
|
246
|
+
const settled = await Promise.allSettled(compact3((_b = Object.values((await this.parents()).commit ?? [])) == null ? void 0 : _b.map(async (parent) => {
|
|
247
|
+
var _a2;
|
|
235
248
|
const queryPayload = {
|
|
236
249
|
schema: ArchivistInsertQuerySchema2
|
|
237
250
|
};
|
|
238
251
|
const query = await this.bindQuery(queryPayload, payloads);
|
|
239
|
-
return (await parent
|
|
252
|
+
return (_a2 = await (parent == null ? void 0 : parent.query(query[0], query[1]))) == null ? void 0 : _a2[0];
|
|
240
253
|
})));
|
|
241
254
|
await this.clear();
|
|
242
255
|
return compact3(settled.filter(fulfilled2).map((result) => result.value));
|
|
@@ -272,9 +285,10 @@ var StorageArchivist = class extends AbstractArchivist2 {
|
|
|
272
285
|
return resultPayloads;
|
|
273
286
|
}
|
|
274
287
|
saveAccount() {
|
|
288
|
+
var _a;
|
|
275
289
|
if (this.persistAccount) {
|
|
276
290
|
const account = this.account;
|
|
277
|
-
this.logger
|
|
291
|
+
(_a = this.logger) == null ? void 0 : _a.log(account.address);
|
|
278
292
|
this.privateStorage.set("privateKey", account.private.hex);
|
|
279
293
|
}
|
|
280
294
|
}
|
|
@@ -284,6 +298,11 @@ var StorageArchivist = class extends AbstractArchivist2 {
|
|
|
284
298
|
return true;
|
|
285
299
|
}
|
|
286
300
|
};
|
|
301
|
+
__name(_StorageArchivist, "StorageArchivist");
|
|
302
|
+
__publicField(_StorageArchivist, "configSchemas", [
|
|
303
|
+
StorageArchivistConfigSchema
|
|
304
|
+
]);
|
|
305
|
+
var StorageArchivist = _StorageArchivist;
|
|
287
306
|
|
|
288
307
|
// src/index.ts
|
|
289
308
|
export * from "@xyo-network/archivist-abstract";
|