@xyo-network/archivist-memory 2.107.3 → 2.107.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/index.cjs +164 -1
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.js +143 -1
- package/dist/browser/index.js.map +1 -1
- package/dist/neutral/index.cjs +164 -1
- package/dist/neutral/index.cjs.map +1 -1
- package/dist/neutral/index.js +143 -1
- package/dist/neutral/index.js.map +1 -1
- package/dist/node/index.cjs +176 -1
- package/dist/node/index.cjs.map +1 -1
- package/dist/node/index.js +150 -1
- package/dist/node/index.js.map +1 -1
- package/package.json +10 -10
package/dist/node/index.js
CHANGED
|
@@ -1,2 +1,151 @@
|
|
|
1
|
-
var
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
3
|
+
var __reflectGet = Reflect.get;
|
|
4
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
5
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
6
|
+
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
7
|
+
var __superGet = (cls, obj, key) => __reflectGet(__getProtoOf(cls), key, obj);
|
|
8
|
+
|
|
9
|
+
// src/MemoryArchivist.ts
|
|
10
|
+
import { assertEx } from "@xylabs/assert";
|
|
11
|
+
import { exists } from "@xylabs/exists";
|
|
12
|
+
import { compact } from "@xylabs/lodash";
|
|
13
|
+
import { fulfilled } from "@xylabs/promise";
|
|
14
|
+
import { AbstractArchivist, addStorageMeta, removeStorageMeta, sortByStorageMeta } from "@xyo-network/archivist-abstract";
|
|
15
|
+
import { ArchivistAllQuerySchema, ArchivistClearQuerySchema, ArchivistCommitQuerySchema, ArchivistDeleteQuerySchema, ArchivistInsertQuerySchema, ArchivistNextQuerySchema } from "@xyo-network/archivist-model";
|
|
16
|
+
import { creatableModule } from "@xyo-network/module-model";
|
|
17
|
+
import { PayloadBuilder } from "@xyo-network/payload-builder";
|
|
18
|
+
import { LRUCache } from "lru-cache";
|
|
19
|
+
function _ts_decorate(decorators, target, key, desc) {
|
|
20
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
21
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
22
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
23
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
24
|
+
}
|
|
25
|
+
__name(_ts_decorate, "_ts_decorate");
|
|
26
|
+
var MemoryArchivistConfigSchema = "network.xyo.archivist.memory.config";
|
|
27
|
+
var _MemoryArchivist = class _MemoryArchivist extends AbstractArchivist {
|
|
28
|
+
_cache;
|
|
29
|
+
_dataHashIndex;
|
|
30
|
+
get queries() {
|
|
31
|
+
return [
|
|
32
|
+
ArchivistAllQuerySchema,
|
|
33
|
+
ArchivistDeleteQuerySchema,
|
|
34
|
+
ArchivistClearQuerySchema,
|
|
35
|
+
ArchivistInsertQuerySchema,
|
|
36
|
+
ArchivistCommitQuerySchema,
|
|
37
|
+
ArchivistNextQuerySchema,
|
|
38
|
+
...super.queries
|
|
39
|
+
];
|
|
40
|
+
}
|
|
41
|
+
get cache() {
|
|
42
|
+
this._cache = this._cache ?? new LRUCache({
|
|
43
|
+
max: this.max
|
|
44
|
+
});
|
|
45
|
+
return this._cache;
|
|
46
|
+
}
|
|
47
|
+
get dataHashIndex() {
|
|
48
|
+
this._dataHashIndex = this._dataHashIndex ?? new LRUCache({
|
|
49
|
+
max: this.max
|
|
50
|
+
});
|
|
51
|
+
return this._dataHashIndex;
|
|
52
|
+
}
|
|
53
|
+
get max() {
|
|
54
|
+
var _a;
|
|
55
|
+
return ((_a = this.config) == null ? void 0 : _a.max) ?? 1e4;
|
|
56
|
+
}
|
|
57
|
+
allHandler() {
|
|
58
|
+
const all = compact(this.cache.dump().map(([, item]) => item.value));
|
|
59
|
+
return sortByStorageMeta(all).map((payload) => removeStorageMeta(payload));
|
|
60
|
+
}
|
|
61
|
+
clearHandler() {
|
|
62
|
+
this.cache.clear();
|
|
63
|
+
this.dataHashIndex.clear();
|
|
64
|
+
return this.emit("cleared", {
|
|
65
|
+
module: this
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
async commitHandler() {
|
|
69
|
+
var _a;
|
|
70
|
+
const payloads = assertEx(await this.allHandler(), () => "Nothing to commit");
|
|
71
|
+
const settled = await Promise.allSettled(compact((_a = Object.values((await this.parentArchivists()).commit ?? [])) == null ? void 0 : _a.map(async (parent) => {
|
|
72
|
+
var _a2;
|
|
73
|
+
const queryPayload = {
|
|
74
|
+
schema: ArchivistInsertQuerySchema
|
|
75
|
+
};
|
|
76
|
+
const query = await this.bindQuery(queryPayload, payloads);
|
|
77
|
+
return (_a2 = await (parent == null ? void 0 : parent.query(query[0], query[1]))) == null ? void 0 : _a2[0];
|
|
78
|
+
})));
|
|
79
|
+
await this.clearHandler();
|
|
80
|
+
return compact(settled.filter(fulfilled).map((result) => result.value));
|
|
81
|
+
}
|
|
82
|
+
deleteHandler(hashes) {
|
|
83
|
+
const deletedHashes = this.cache.dump().map(([key, item]) => {
|
|
84
|
+
if (hashes.includes(key) || hashes.includes(item.value.$hash)) {
|
|
85
|
+
this.cache.delete(key);
|
|
86
|
+
return key;
|
|
87
|
+
}
|
|
88
|
+
}).filter(exists);
|
|
89
|
+
this.rebuildDataHashIndex();
|
|
90
|
+
return deletedHashes;
|
|
91
|
+
}
|
|
92
|
+
getHandler(hashes) {
|
|
93
|
+
return compact(hashes.map((hash) => {
|
|
94
|
+
const resolvedHash = this.dataHashIndex.get(hash) ?? hash;
|
|
95
|
+
const result = this.cache.get(resolvedHash);
|
|
96
|
+
if (resolvedHash !== hash && !result) {
|
|
97
|
+
throw new Error("Missing referenced payload");
|
|
98
|
+
}
|
|
99
|
+
return removeStorageMeta(result);
|
|
100
|
+
}));
|
|
101
|
+
}
|
|
102
|
+
async insertHandler(payloads) {
|
|
103
|
+
const pairs = await PayloadBuilder.hashPairs(payloads, {
|
|
104
|
+
stamp: false
|
|
105
|
+
});
|
|
106
|
+
const insertedPayloads = pairs.map(([payload, hash], index) => {
|
|
107
|
+
return this.cache.get(hash) ?? this.insertPayloadIntoCache(payload, hash, index);
|
|
108
|
+
});
|
|
109
|
+
return removeStorageMeta(insertedPayloads);
|
|
110
|
+
}
|
|
111
|
+
async nextHandler(options) {
|
|
112
|
+
const { limit, offset, order } = options ?? {};
|
|
113
|
+
let all = await this.allHandler();
|
|
114
|
+
if (order === "desc") {
|
|
115
|
+
all = all.reverse();
|
|
116
|
+
}
|
|
117
|
+
const allPairs = await PayloadBuilder.hashPairs(all);
|
|
118
|
+
const startIndex = offset ? allPairs.findIndex(([, hash]) => hash === offset) + 1 : 0;
|
|
119
|
+
return allPairs.slice(startIndex, limit ? startIndex + limit : void 0).map(([payload]) => payload);
|
|
120
|
+
}
|
|
121
|
+
insertPayloadIntoCache(payload, hash, index = 0) {
|
|
122
|
+
const withMeta = addStorageMeta(payload, index);
|
|
123
|
+
this.cache.set(hash, withMeta);
|
|
124
|
+
this.dataHashIndex.set(withMeta.$hash, hash);
|
|
125
|
+
return withMeta;
|
|
126
|
+
}
|
|
127
|
+
rebuildDataHashIndex() {
|
|
128
|
+
this._dataHashIndex = new LRUCache({
|
|
129
|
+
max: this.max
|
|
130
|
+
});
|
|
131
|
+
const pairs = this.cache.dump();
|
|
132
|
+
for (const [hash, payload] of pairs) {
|
|
133
|
+
this.dataHashIndex.set(payload.value.$hash, hash);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
};
|
|
137
|
+
__name(_MemoryArchivist, "MemoryArchivist");
|
|
138
|
+
__publicField(_MemoryArchivist, "configSchemas", [
|
|
139
|
+
...__superGet(_MemoryArchivist, _MemoryArchivist, "configSchemas"),
|
|
140
|
+
MemoryArchivistConfigSchema
|
|
141
|
+
]);
|
|
142
|
+
__publicField(_MemoryArchivist, "defaultConfigSchema", MemoryArchivistConfigSchema);
|
|
143
|
+
var MemoryArchivist = _MemoryArchivist;
|
|
144
|
+
MemoryArchivist = _ts_decorate([
|
|
145
|
+
creatableModule()
|
|
146
|
+
], MemoryArchivist);
|
|
147
|
+
export {
|
|
148
|
+
MemoryArchivist,
|
|
149
|
+
MemoryArchivistConfigSchema
|
|
150
|
+
};
|
|
2
151
|
//# sourceMappingURL=index.js.map
|
package/dist/node/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/MemoryArchivist.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Hash } from '@xylabs/hex'\nimport { compact } from '@xylabs/lodash'\nimport { EmptyObject, WithAdditional } from '@xylabs/object'\nimport { fulfilled, Promisable } from '@xylabs/promise'\nimport { AbstractArchivist, addStorageMeta, removeStorageMeta, sortByStorageMeta, WithStorageMeta } from '@xyo-network/archivist-abstract'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuery,\n ArchivistInsertQuerySchema,\n ArchivistModuleEventData,\n ArchivistNextOptions,\n ArchivistNextQuerySchema,\n AttachableArchivistInstance,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { AnyConfigSchema, creatableModule, ModuleInstance, ModuleParams } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, PayloadWithMeta, Schema, WithMeta } from '@xyo-network/payload-model'\nimport { LRUCache } from 'lru-cache'\n\nexport type MemoryArchivistConfigSchema = 'network.xyo.archivist.memory.config'\nexport const MemoryArchivistConfigSchema: MemoryArchivistConfigSchema = 'network.xyo.archivist.memory.config'\n\nexport type MemoryArchivistConfig<TConfig extends Payload | EmptyObject | void = void, TSchema extends Schema | void = void> = ArchivistConfig<\n WithAdditional<\n {\n max?: number\n },\n TConfig\n >,\n TSchema extends Schema ? TSchema : MemoryArchivistConfigSchema | ArchivistConfig['schema']\n>\n\nexport type MemoryArchivistParams<TConfig extends AnyConfigSchema<MemoryArchivistConfig> = AnyConfigSchema<MemoryArchivistConfig>> =\n ModuleParams<TConfig>\n@creatableModule()\nexport class MemoryArchivist<\n TParams extends MemoryArchivistParams<AnyConfigSchema<MemoryArchivistConfig>> = MemoryArchivistParams,\n TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,\n >\n extends AbstractArchivist<TParams, TEventData>\n implements AttachableArchivistInstance, ModuleInstance\n{\n static override readonly configSchemas: Schema[] = [...super.configSchemas, MemoryArchivistConfigSchema]\n static override readonly defaultConfigSchema: Schema = MemoryArchivistConfigSchema\n\n private _cache?: LRUCache<Hash, WithStorageMeta<PayloadWithMeta>>\n private _dataHashIndex?: LRUCache<Hash, Hash>\n\n override get queries() {\n return [\n ArchivistAllQuerySchema,\n ArchivistDeleteQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistInsertQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistNextQuerySchema,\n ...super.queries,\n ]\n }\n\n protected get cache() {\n this._cache = this._cache ?? new LRUCache<Hash, WithStorageMeta<PayloadWithMeta>>({ max: this.max })\n return this._cache\n }\n\n protected get dataHashIndex() {\n this._dataHashIndex = this._dataHashIndex ?? new LRUCache<Hash, Hash>({ max: this.max })\n return this._dataHashIndex\n }\n\n protected get max() {\n return this.config?.max ?? 10_000\n }\n\n protected override allHandler(): Promisable<PayloadWithMeta[]> {\n const all = compact(this.cache.dump().map(([, item]) => item.value))\n return sortByStorageMeta(all).map((payload) => removeStorageMeta(payload))\n }\n\n protected override clearHandler(): void | Promise<void> {\n this.cache.clear()\n this.dataHashIndex.clear()\n return this.emit('cleared', { module: this })\n }\n\n protected override async commitHandler(): Promise<WithMeta<BoundWitness>[]> {\n const payloads = assertEx(await this.allHandler(), () => '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 await this.clearHandler()\n return compact(settled.filter(fulfilled).map((result) => result.value))\n }\n\n protected override deleteHandler(hashes: Hash[]): Promisable<Hash[]> {\n const deletedHashes: Hash[] = this.cache\n .dump()\n .map(([key, item]) => {\n if (hashes.includes(key) || hashes.includes(item.value.$hash)) {\n this.cache.delete(key)\n return key\n }\n })\n .filter(exists)\n this.rebuildDataHashIndex()\n return deletedHashes\n }\n\n protected override getHandler(hashes: Hash[]): Promisable<PayloadWithMeta[]> {\n return compact(\n hashes.map((hash) => {\n const resolvedHash = this.dataHashIndex.get(hash) ?? hash\n const result = this.cache.get(resolvedHash)\n if (resolvedHash !== hash && !result) {\n throw new Error('Missing referenced payload')\n }\n return removeStorageMeta(result)\n }),\n )\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]> {\n const pairs = await PayloadBuilder.hashPairs(payloads, { stamp: false })\n const insertedPayloads = pairs.map(([payload, hash], index) => {\n return this.cache.get(hash) ?? this.insertPayloadIntoCache(payload, hash, index)\n })\n\n return removeStorageMeta(insertedPayloads)\n }\n\n protected override async nextHandler(options?: ArchivistNextOptions): Promise<PayloadWithMeta[]> {\n const { limit, offset, order } = options ?? {}\n let all = await this.allHandler()\n if (order === 'desc') {\n all = all.reverse()\n }\n const allPairs = await PayloadBuilder.hashPairs(all)\n const startIndex = offset ? allPairs.findIndex(([, hash]) => hash === offset) + 1 : 0\n return allPairs.slice(startIndex, limit ? startIndex + limit : undefined).map(([payload]) => payload)\n }\n\n private insertPayloadIntoCache(payload: PayloadWithMeta, hash: Hash, index = 0): WithStorageMeta<PayloadWithMeta> {\n const withMeta = addStorageMeta(payload, index)\n this.cache.set(hash, withMeta)\n this.dataHashIndex.set(withMeta.$hash, hash)\n return withMeta\n }\n\n private rebuildDataHashIndex() {\n this._dataHashIndex = new LRUCache<Hash, Hash>({ max: this.max })\n const pairs = this.cache.dump()\n for (const [hash, payload] of pairs) {\n this.dataHashIndex.set(payload.value.$hash, hash)\n }\n }\n}\n"],"mappings":"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","names":["assertEx","exists","compact","fulfilled","AbstractArchivist","addStorageMeta","removeStorageMeta","sortByStorageMeta","ArchivistAllQuerySchema","ArchivistClearQuerySchema","ArchivistCommitQuerySchema","ArchivistDeleteQuerySchema","ArchivistInsertQuerySchema","ArchivistNextQuerySchema","creatableModule","PayloadBuilder","LRUCache","MemoryArchivistConfigSchema","MemoryArchivist","AbstractArchivist","_cache","_dataHashIndex","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","ArchivistNextQuerySchema","cache","LRUCache","max","dataHashIndex","_a","config","allHandler","all","compact","dump","map","item","value","sortByStorageMeta","payload","removeStorageMeta","clearHandler","clear","emit","module","commitHandler","payloads","assertEx","settled","Promise","allSettled","Object","values","parentArchivists","commit","parent","queryPayload","schema","query","bindQuery","filter","fulfilled","result","deleteHandler","hashes","deletedHashes","key","includes","$hash","delete","exists","rebuildDataHashIndex","getHandler","hash","resolvedHash","get","Error","insertHandler","insertedPayloads","PayloadBuilder","hashPairs","stamp","index","insertPayloadIntoCache","nextHandler","options","limit","offset","order","reverse","allPairs","startIndex","findIndex","slice","undefined","withMeta","addStorageMeta","set","pairs","__publicField","configSchemas","__superGet","_MemoryArchivist","defaultConfigSchema"]}
|
|
1
|
+
{"version":3,"sources":["../../src/MemoryArchivist.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Hash } from '@xylabs/hex'\nimport { compact } from '@xylabs/lodash'\nimport { EmptyObject, WithAdditional } from '@xylabs/object'\nimport { fulfilled, Promisable } from '@xylabs/promise'\nimport { AbstractArchivist, addStorageMeta, removeStorageMeta, sortByStorageMeta, WithStorageMeta } from '@xyo-network/archivist-abstract'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuery,\n ArchivistInsertQuerySchema,\n ArchivistModuleEventData,\n ArchivistNextOptions,\n ArchivistNextQuerySchema,\n AttachableArchivistInstance,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { AnyConfigSchema, creatableModule, ModuleInstance, ModuleParams } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, PayloadWithMeta, Schema, WithMeta } from '@xyo-network/payload-model'\nimport { LRUCache } from 'lru-cache'\n\nexport type MemoryArchivistConfigSchema = 'network.xyo.archivist.memory.config'\nexport const MemoryArchivistConfigSchema: MemoryArchivistConfigSchema = 'network.xyo.archivist.memory.config'\n\nexport type MemoryArchivistConfig<TConfig extends Payload | EmptyObject | void = void, TSchema extends Schema | void = void> = ArchivistConfig<\n WithAdditional<\n {\n max?: number\n },\n TConfig\n >,\n TSchema extends Schema ? TSchema : MemoryArchivistConfigSchema | ArchivistConfig['schema']\n>\n\nexport type MemoryArchivistParams<TConfig extends AnyConfigSchema<MemoryArchivistConfig> = AnyConfigSchema<MemoryArchivistConfig>> =\n ModuleParams<TConfig>\n@creatableModule()\nexport class MemoryArchivist<\n TParams extends MemoryArchivistParams<AnyConfigSchema<MemoryArchivistConfig>> = MemoryArchivistParams,\n TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,\n >\n extends AbstractArchivist<TParams, TEventData>\n implements AttachableArchivistInstance, ModuleInstance\n{\n static override readonly configSchemas: Schema[] = [...super.configSchemas, MemoryArchivistConfigSchema]\n static override readonly defaultConfigSchema: Schema = MemoryArchivistConfigSchema\n\n private _cache?: LRUCache<Hash, WithStorageMeta<PayloadWithMeta>>\n private _dataHashIndex?: LRUCache<Hash, Hash>\n\n override get queries() {\n return [\n ArchivistAllQuerySchema,\n ArchivistDeleteQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistInsertQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistNextQuerySchema,\n ...super.queries,\n ]\n }\n\n protected get cache() {\n this._cache = this._cache ?? new LRUCache<Hash, WithStorageMeta<PayloadWithMeta>>({ max: this.max })\n return this._cache\n }\n\n protected get dataHashIndex() {\n this._dataHashIndex = this._dataHashIndex ?? new LRUCache<Hash, Hash>({ max: this.max })\n return this._dataHashIndex\n }\n\n protected get max() {\n return this.config?.max ?? 10_000\n }\n\n protected override allHandler(): Promisable<PayloadWithMeta[]> {\n const all = compact(this.cache.dump().map(([, item]) => item.value))\n return sortByStorageMeta(all).map((payload) => removeStorageMeta(payload))\n }\n\n protected override clearHandler(): void | Promise<void> {\n this.cache.clear()\n this.dataHashIndex.clear()\n return this.emit('cleared', { module: this })\n }\n\n protected override async commitHandler(): Promise<WithMeta<BoundWitness>[]> {\n const payloads = assertEx(await this.allHandler(), () => '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 await this.clearHandler()\n return compact(settled.filter(fulfilled).map((result) => result.value))\n }\n\n protected override deleteHandler(hashes: Hash[]): Promisable<Hash[]> {\n const deletedHashes: Hash[] = this.cache\n .dump()\n .map(([key, item]) => {\n if (hashes.includes(key) || hashes.includes(item.value.$hash)) {\n this.cache.delete(key)\n return key\n }\n })\n .filter(exists)\n this.rebuildDataHashIndex()\n return deletedHashes\n }\n\n protected override getHandler(hashes: Hash[]): Promisable<PayloadWithMeta[]> {\n return compact(\n hashes.map((hash) => {\n const resolvedHash = this.dataHashIndex.get(hash) ?? hash\n const result = this.cache.get(resolvedHash)\n if (resolvedHash !== hash && !result) {\n throw new Error('Missing referenced payload')\n }\n return removeStorageMeta(result)\n }),\n )\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]> {\n const pairs = await PayloadBuilder.hashPairs(payloads, { stamp: false })\n const insertedPayloads = pairs.map(([payload, hash], index) => {\n return this.cache.get(hash) ?? this.insertPayloadIntoCache(payload, hash, index)\n })\n\n return removeStorageMeta(insertedPayloads)\n }\n\n protected override async nextHandler(options?: ArchivistNextOptions): Promise<PayloadWithMeta[]> {\n const { limit, offset, order } = options ?? {}\n let all = await this.allHandler()\n if (order === 'desc') {\n all = all.reverse()\n }\n const allPairs = await PayloadBuilder.hashPairs(all)\n const startIndex = offset ? allPairs.findIndex(([, hash]) => hash === offset) + 1 : 0\n return allPairs.slice(startIndex, limit ? startIndex + limit : undefined).map(([payload]) => payload)\n }\n\n private insertPayloadIntoCache(payload: PayloadWithMeta, hash: Hash, index = 0): WithStorageMeta<PayloadWithMeta> {\n const withMeta = addStorageMeta(payload, index)\n this.cache.set(hash, withMeta)\n this.dataHashIndex.set(withMeta.$hash, hash)\n return withMeta\n }\n\n private rebuildDataHashIndex() {\n this._dataHashIndex = new LRUCache<Hash, Hash>({ max: this.max })\n const pairs = this.cache.dump()\n for (const [hash, payload] of pairs) {\n this.dataHashIndex.set(payload.value.$hash, hash)\n }\n }\n}\n"],"mappings":"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","names":["assertEx","exists","compact","fulfilled","AbstractArchivist","addStorageMeta","removeStorageMeta","sortByStorageMeta","ArchivistAllQuerySchema","ArchivistClearQuerySchema","ArchivistCommitQuerySchema","ArchivistDeleteQuerySchema","ArchivistInsertQuerySchema","ArchivistNextQuerySchema","creatableModule","PayloadBuilder","LRUCache","MemoryArchivistConfigSchema","MemoryArchivist","AbstractArchivist","_cache","_dataHashIndex","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","ArchivistNextQuerySchema","cache","LRUCache","max","dataHashIndex","config","allHandler","all","compact","dump","map","item","value","sortByStorageMeta","payload","removeStorageMeta","clearHandler","clear","emit","module","commitHandler","payloads","assertEx","settled","Promise","allSettled","Object","values","parentArchivists","commit","parent","queryPayload","schema","query","bindQuery","_a","filter","fulfilled","result","deleteHandler","hashes","deletedHashes","key","includes","$hash","delete","exists","rebuildDataHashIndex","getHandler","hash","resolvedHash","get","Error","insertHandler","pairs","PayloadBuilder","hashPairs","stamp","insertedPayloads","index","insertPayloadIntoCache","nextHandler","options","limit","offset","order","reverse","allPairs","startIndex","findIndex","slice","undefined","withMeta","addStorageMeta","set","configSchemas","defaultConfigSchema"]}
|
package/package.json
CHANGED
|
@@ -16,18 +16,18 @@
|
|
|
16
16
|
"@xylabs/lodash": "^3.5.1",
|
|
17
17
|
"@xylabs/object": "^3.5.1",
|
|
18
18
|
"@xylabs/promise": "^3.5.1",
|
|
19
|
-
"@xyo-network/archivist-abstract": "~2.107.
|
|
20
|
-
"@xyo-network/archivist-model": "~2.107.
|
|
21
|
-
"@xyo-network/boundwitness-model": "~2.107.
|
|
22
|
-
"@xyo-network/module-model": "~2.107.
|
|
23
|
-
"@xyo-network/payload-builder": "~2.107.
|
|
24
|
-
"@xyo-network/payload-model": "~2.107.
|
|
19
|
+
"@xyo-network/archivist-abstract": "~2.107.5",
|
|
20
|
+
"@xyo-network/archivist-model": "~2.107.5",
|
|
21
|
+
"@xyo-network/boundwitness-model": "~2.107.5",
|
|
22
|
+
"@xyo-network/module-model": "~2.107.5",
|
|
23
|
+
"@xyo-network/payload-builder": "~2.107.5",
|
|
24
|
+
"@xyo-network/payload-model": "~2.107.5",
|
|
25
25
|
"lru-cache": "^10.2.2"
|
|
26
26
|
},
|
|
27
27
|
"devDependencies": {
|
|
28
|
-
"@xylabs/ts-scripts-yarn3": "^3.11.
|
|
29
|
-
"@xylabs/tsconfig": "^3.11.
|
|
30
|
-
"@xyo-network/account": "~2.107.
|
|
28
|
+
"@xylabs/ts-scripts-yarn3": "^3.11.10",
|
|
29
|
+
"@xylabs/tsconfig": "^3.11.10",
|
|
30
|
+
"@xyo-network/account": "~2.107.5",
|
|
31
31
|
"typescript": "^5.5.2"
|
|
32
32
|
},
|
|
33
33
|
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
@@ -69,6 +69,6 @@
|
|
|
69
69
|
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
|
|
70
70
|
},
|
|
71
71
|
"sideEffects": false,
|
|
72
|
-
"version": "2.107.
|
|
72
|
+
"version": "2.107.5",
|
|
73
73
|
"type": "module"
|
|
74
74
|
}
|