@xyo-network/filesystem-archivist 2.111.3 → 3.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (34) hide show
  1. package/dist/node/index.d.ts +38 -2
  2. package/dist/node/index.mjs +11 -17
  3. package/dist/node/index.mjs.map +1 -1
  4. package/package.json +12 -17
  5. package/xy.config.ts +1 -0
  6. package/dist/neutral/FilesystemArchivist.d.cts +0 -36
  7. package/dist/neutral/FilesystemArchivist.d.cts.map +0 -1
  8. package/dist/neutral/FilesystemArchivist.d.mts +0 -36
  9. package/dist/neutral/FilesystemArchivist.d.mts.map +0 -1
  10. package/dist/neutral/FilesystemArchivist.d.ts +0 -36
  11. package/dist/neutral/FilesystemArchivist.d.ts.map +0 -1
  12. package/dist/neutral/index.cjs +0 -123
  13. package/dist/neutral/index.cjs.map +0 -1
  14. package/dist/neutral/index.d.cts +0 -2
  15. package/dist/neutral/index.d.cts.map +0 -1
  16. package/dist/neutral/index.d.mts +0 -2
  17. package/dist/neutral/index.d.mts.map +0 -1
  18. package/dist/neutral/index.d.ts +0 -2
  19. package/dist/neutral/index.d.ts.map +0 -1
  20. package/dist/neutral/index.mjs +0 -102
  21. package/dist/neutral/index.mjs.map +0 -1
  22. package/dist/node/FilesystemArchivist.d.cts +0 -36
  23. package/dist/node/FilesystemArchivist.d.cts.map +0 -1
  24. package/dist/node/FilesystemArchivist.d.mts +0 -36
  25. package/dist/node/FilesystemArchivist.d.mts.map +0 -1
  26. package/dist/node/FilesystemArchivist.d.ts +0 -36
  27. package/dist/node/FilesystemArchivist.d.ts.map +0 -1
  28. package/dist/node/index.cjs +0 -134
  29. package/dist/node/index.cjs.map +0 -1
  30. package/dist/node/index.d.cts +0 -2
  31. package/dist/node/index.d.cts.map +0 -1
  32. package/dist/node/index.d.mts +0 -2
  33. package/dist/node/index.d.mts.map +0 -1
  34. package/dist/node/index.d.ts.map +0 -1
@@ -1,2 +1,38 @@
1
- export * from './FilesystemArchivist.ts';
2
- //# sourceMappingURL=index.d.ts.map
1
+ import { Hash } from '@xylabs/hex';
2
+ import { PromisableArray } from '@xylabs/promise';
3
+ import { AbstractArchivist } from '@xyo-network/archivist-abstract';
4
+ import { ArchivistConfig, ArchivistParams, ArchivistInstance } from '@xyo-network/archivist-model';
5
+ import { BoundWitness } from '@xyo-network/boundwitness-model';
6
+ import { AnyConfigSchema } from '@xyo-network/module-model';
7
+ import { Payload, Schema, PayloadWithMeta, WithMeta } from '@xyo-network/payload-model';
8
+
9
+ interface FileSystemArchivistData {
10
+ payloads: Payload[];
11
+ }
12
+ type FilesystemArchivistConfigSchema = 'network.xyo.archivist.filesystem.config';
13
+ declare const FilesystemArchivistConfigSchema: FilesystemArchivistConfigSchema;
14
+ type FilesystemArchivistConfig = ArchivistConfig<{
15
+ filePath?: string;
16
+ schema: FilesystemArchivistConfigSchema;
17
+ }>;
18
+ type FilesystemArchivistParams = ArchivistParams<AnyConfigSchema<FilesystemArchivistConfig>>;
19
+ declare class FilesystemArchivist<TParams extends FilesystemArchivistParams = FilesystemArchivistParams> extends AbstractArchivist<TParams> implements ArchivistInstance {
20
+ static readonly configSchemas: Schema[];
21
+ static readonly defaultConfigSchema: Schema;
22
+ private _memoryArchivist?;
23
+ get filePath(): string;
24
+ get queries(): string[];
25
+ private get memoryArchivist();
26
+ private static dataFromRawJson;
27
+ private static payloadsFromRawPayloads;
28
+ protected allHandler(): PromisableArray<PayloadWithMeta>;
29
+ protected clearHandler(): void | Promise<void>;
30
+ protected commitHandler(): Promise<WithMeta<BoundWitness>[]>;
31
+ protected deleteHandler(hashes: Hash[]): PromisableArray<Hash>;
32
+ protected getHandler(hashes: Hash[]): Promise<PayloadWithMeta[]>;
33
+ protected insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]>;
34
+ protected startHandler(): Promise<boolean>;
35
+ private rawJsonFromFile;
36
+ }
37
+
38
+ export { type FileSystemArchivistData, FilesystemArchivist, type FilesystemArchivistConfig, FilesystemArchivistConfigSchema, type FilesystemArchivistParams };
@@ -1,10 +1,5 @@
1
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
2
  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
3
 
9
4
  // src/FilesystemArchivist.ts
10
5
  import { readFile } from "node:fs/promises";
@@ -24,11 +19,18 @@ function _ts_decorate(decorators, target, key, desc) {
24
19
  }
25
20
  __name(_ts_decorate, "_ts_decorate");
26
21
  var FilesystemArchivistConfigSchema = "network.xyo.archivist.filesystem.config";
27
- var _FilesystemArchivist = class _FilesystemArchivist extends AbstractArchivist {
22
+ var FilesystemArchivist = class _FilesystemArchivist extends AbstractArchivist {
23
+ static {
24
+ __name(this, "FilesystemArchivist");
25
+ }
26
+ static configSchemas = [
27
+ ...super.configSchemas,
28
+ FilesystemArchivistConfigSchema
29
+ ];
30
+ static defaultConfigSchema = FilesystemArchivistConfigSchema;
28
31
  _memoryArchivist;
29
32
  get filePath() {
30
- var _a;
31
- return ((_a = this.config) == null ? void 0 : _a.filePath) ?? "archivist.xyo.json";
33
+ return this.config?.filePath ?? "archivist.xyo.json";
32
34
  }
33
35
  get queries() {
34
36
  return [
@@ -78,8 +80,7 @@ var _FilesystemArchivist = class _FilesystemArchivist extends AbstractArchivist
78
80
  await this._memoryArchivist.insert(await Promise.all(data.payloads.map((payload) => PayloadBuilder.build(payload))));
79
81
  } catch (ex) {
80
82
  handleError(ex, (error) => {
81
- var _a;
82
- (_a = this.logger) == null ? void 0 : _a.error(error.message);
83
+ this.logger?.error(error.message);
83
84
  });
84
85
  return false;
85
86
  }
@@ -91,13 +92,6 @@ var _FilesystemArchivist = class _FilesystemArchivist extends AbstractArchivist
91
92
  });
92
93
  }
93
94
  };
94
- __name(_FilesystemArchivist, "FilesystemArchivist");
95
- __publicField(_FilesystemArchivist, "configSchemas", [
96
- ...__superGet(_FilesystemArchivist, _FilesystemArchivist, "configSchemas"),
97
- FilesystemArchivistConfigSchema
98
- ]);
99
- __publicField(_FilesystemArchivist, "defaultConfigSchema", FilesystemArchivistConfigSchema);
100
- var FilesystemArchivist = _FilesystemArchivist;
101
95
  FilesystemArchivist = _ts_decorate([
102
96
  creatableModule()
103
97
  ], FilesystemArchivist);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/FilesystemArchivist.ts"],"sourcesContent":["import { readFile } from 'node:fs/promises'\n\nimport { assertEx } from '@xylabs/assert'\nimport { handleError } from '@xylabs/error'\nimport { Hash } from '@xylabs/hex'\nimport { PromisableArray } from '@xylabs/promise'\nimport { HDWallet } from '@xyo-network/account'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport { MemoryArchivist } from '@xyo-network/archivist-memory'\nimport {\n ArchivistAllQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistInstance,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, PayloadWithMeta, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport interface FileSystemArchivistData {\n payloads: Payload[]\n}\n\nexport type FilesystemArchivistConfigSchema = 'network.xyo.archivist.filesystem.config'\nexport const FilesystemArchivistConfigSchema: FilesystemArchivistConfigSchema = 'network.xyo.archivist.filesystem.config'\n\nexport type FilesystemArchivistConfig = ArchivistConfig<{\n filePath?: string\n schema: FilesystemArchivistConfigSchema\n}>\n\nexport type FilesystemArchivistParams = ArchivistParams<AnyConfigSchema<FilesystemArchivistConfig>>\n\n/** @description Currently only a read-only archivist that loads payloads from filesystem\n * but allows for future expansion to read/write\n */\n@creatableModule()\nexport class FilesystemArchivist<TParams extends FilesystemArchivistParams = FilesystemArchivistParams>\n extends AbstractArchivist<TParams>\n implements ArchivistInstance {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, FilesystemArchivistConfigSchema]\n static override readonly defaultConfigSchema: Schema = FilesystemArchivistConfigSchema\n\n private _memoryArchivist?: MemoryArchivist\n\n get filePath() {\n return this.config?.filePath ?? 'archivist.xyo.json'\n }\n\n override get queries() {\n return [ArchivistAllQuerySchema, ArchivistCommitQuerySchema, ...super.queries]\n }\n\n private get memoryArchivist() {\n return assertEx(this._memoryArchivist)\n }\n\n private static async dataFromRawJson(rawJson: string) {\n const data: FileSystemArchivistData = JSON.parse(rawJson)\n assertEx(typeof data === 'object', () => 'Archivist Data must be object')\n assertEx(Array.isArray(data.payloads), () => 'Archivist Data \"payloads\" field must be array of payloads')\n data.payloads = await this.payloadsFromRawPayloads(data.payloads)\n return data\n }\n\n private static async payloadsFromRawPayloads(rawPayloads: Payload[]) {\n // validation should be done in here. I don't believe parse does much validation yet.\n return await Promise.all(rawPayloads.map(async payload => await PayloadBuilder.build(payload)))\n }\n\n protected override allHandler(): PromisableArray<PayloadWithMeta> {\n return this.memoryArchivist.all()\n }\n\n protected override clearHandler(): void | Promise<void> {\n return this.memoryArchivist.clear()\n }\n\n protected override async commitHandler(): Promise<WithMeta<BoundWitness>[]> {\n return await this.memoryArchivist.commit()\n }\n\n protected override deleteHandler(hashes: Hash[]): PromisableArray<Hash> {\n return this.memoryArchivist.delete(hashes)\n }\n\n protected override async getHandler(hashes: Hash[]): Promise<PayloadWithMeta[]> {\n return await this.memoryArchivist.get(hashes)\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]> {\n return await this.memoryArchivist.insert(payloads)\n }\n\n protected override async startHandler() {\n await super.startHandler()\n this._memoryArchivist = await MemoryArchivist.create({ account: await HDWallet.random() })\n try {\n const data = await FilesystemArchivist.dataFromRawJson(await this.rawJsonFromFile())\n await this._memoryArchivist.insert(await Promise.all(data.payloads.map(payload => PayloadBuilder.build(payload))))\n } catch (ex) {\n handleError(ex, (error) => {\n this.logger?.error(error.message)\n })\n return false\n }\n return true\n }\n\n private async rawJsonFromFile() {\n return await readFile(this.filePath, { encoding: 'utf8' })\n }\n}\n"],"mappings":";;;;;;;;;AAAA,SAASA,gBAAgB;AAEzB,SAASC,gBAAgB;AACzB,SAASC,mBAAmB;AAG5B,SAASC,gBAAgB;AACzB,SAASC,yBAAyB;AAClC,SAASC,uBAAuB;AAChC,SACEC,yBACAC,kCAIK;AAEP,SAA0BC,uBAAuB;AACjD,SAASC,sBAAsB;;;;;;;;AAQxB,IAAMC,kCAAmE;AAazE,IAAMC,uBAAN,MAAMA,6BACHC,kBAAAA;EAKAC;EAER,IAAIC,WAAW;;AACb,aAAO,UAAKC,WAAL,mBAAaD,aAAY;EAClC;EAEA,IAAaE,UAAU;AACrB,WAAO;MAACC;MAAyBC;SAA+B,MAAMF;;EACxE;EAEA,IAAYG,kBAAkB;AAC5B,WAAOC,SAAS,KAAKP,gBAAgB;EACvC;EAEA,aAAqBQ,gBAAgBC,SAAiB;AACpD,UAAMC,OAAgCC,KAAKC,MAAMH,OAAAA;AACjDF,aAAS,OAAOG,SAAS,UAAU,MAAM,+BAAA;AACzCH,aAASM,MAAMC,QAAQJ,KAAKK,QAAQ,GAAG,MAAM,2DAAA;AAC7CL,SAAKK,WAAW,MAAM,KAAKC,wBAAwBN,KAAKK,QAAQ;AAChE,WAAOL;EACT;EAEA,aAAqBM,wBAAwBC,aAAwB;AAEnE,WAAO,MAAMC,QAAQC,IAAIF,YAAYG,IAAI,OAAMC,YAAW,MAAMC,eAAeC,MAAMF,OAAAA,CAAAA,CAAAA;EACvF;EAEmBG,aAA+C;AAChE,WAAO,KAAKlB,gBAAgBa,IAAG;EACjC;EAEmBM,eAAqC;AACtD,WAAO,KAAKnB,gBAAgBoB,MAAK;EACnC;EAEA,MAAyBC,gBAAmD;AAC1E,WAAO,MAAM,KAAKrB,gBAAgBsB,OAAM;EAC1C;EAEmBC,cAAcC,QAAuC;AACtE,WAAO,KAAKxB,gBAAgByB,OAAOD,MAAAA;EACrC;EAEA,MAAyBE,WAAWF,QAA4C;AAC9E,WAAO,MAAM,KAAKxB,gBAAgB2B,IAAIH,MAAAA;EACxC;EAEA,MAAyBI,cAAcnB,UAAiD;AACtF,WAAO,MAAM,KAAKT,gBAAgB6B,OAAOpB,QAAAA;EAC3C;EAEA,MAAyBqB,eAAe;AACtC,UAAM,MAAMA,aAAAA;AACZ,SAAKpC,mBAAmB,MAAMqC,gBAAgBC,OAAO;MAAEC,SAAS,MAAMC,SAASC,OAAM;IAAG,CAAA;AACxF,QAAI;AACF,YAAM/B,OAAO,MAAMZ,qBAAoBU,gBAAgB,MAAM,KAAKkC,gBAAe,CAAA;AACjF,YAAM,KAAK1C,iBAAiBmC,OAAO,MAAMjB,QAAQC,IAAIT,KAAKK,SAASK,IAAIC,CAAAA,YAAWC,eAAeC,MAAMF,OAAAA,CAAAA,CAAAA,CAAAA;IACzG,SAASsB,IAAI;AACXC,kBAAYD,IAAI,CAACE,UAAAA;;AACf,mBAAKC,WAAL,mBAAaD,MAAMA,MAAME;MAC3B,CAAA;AACA,aAAO;IACT;AACA,WAAO;EACT;EAEA,MAAcL,kBAAkB;AAC9B,WAAO,MAAMM,SAAS,KAAK/C,UAAU;MAAEgD,UAAU;IAAO,CAAA;EAC1D;AACF;AA1EUlD;AAER,cAHWD,sBAGcoD,iBAA0B;KAAI,uDAAMA;EAAerD;;AAC5E,cAJWC,sBAIcqD,uBAA8BtD;AAJlD,IAAMC,sBAAN;;;;","names":["readFile","assertEx","handleError","HDWallet","AbstractArchivist","MemoryArchivist","ArchivistAllQuerySchema","ArchivistCommitQuerySchema","creatableModule","PayloadBuilder","FilesystemArchivistConfigSchema","FilesystemArchivist","AbstractArchivist","_memoryArchivist","filePath","config","queries","ArchivistAllQuerySchema","ArchivistCommitQuerySchema","memoryArchivist","assertEx","dataFromRawJson","rawJson","data","JSON","parse","Array","isArray","payloads","payloadsFromRawPayloads","rawPayloads","Promise","all","map","payload","PayloadBuilder","build","allHandler","clearHandler","clear","commitHandler","commit","deleteHandler","hashes","delete","getHandler","get","insertHandler","insert","startHandler","MemoryArchivist","create","account","HDWallet","random","rawJsonFromFile","ex","handleError","error","logger","message","readFile","encoding","configSchemas","defaultConfigSchema"]}
1
+ {"version":3,"sources":["../../src/FilesystemArchivist.ts"],"sourcesContent":["import { readFile } from 'node:fs/promises'\n\nimport { assertEx } from '@xylabs/assert'\nimport { handleError } from '@xylabs/error'\nimport { Hash } from '@xylabs/hex'\nimport { PromisableArray } from '@xylabs/promise'\nimport { HDWallet } from '@xyo-network/account'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport { MemoryArchivist } from '@xyo-network/archivist-memory'\nimport {\n ArchivistAllQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistInstance,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, PayloadWithMeta, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport interface FileSystemArchivistData {\n payloads: Payload[]\n}\n\nexport type FilesystemArchivistConfigSchema = 'network.xyo.archivist.filesystem.config'\nexport const FilesystemArchivistConfigSchema: FilesystemArchivistConfigSchema = 'network.xyo.archivist.filesystem.config'\n\nexport type FilesystemArchivistConfig = ArchivistConfig<{\n filePath?: string\n schema: FilesystemArchivistConfigSchema\n}>\n\nexport type FilesystemArchivistParams = ArchivistParams<AnyConfigSchema<FilesystemArchivistConfig>>\n\n/** @description Currently only a read-only archivist that loads payloads from filesystem\n * but allows for future expansion to read/write\n */\n@creatableModule()\nexport class FilesystemArchivist<TParams extends FilesystemArchivistParams = FilesystemArchivistParams>\n extends AbstractArchivist<TParams>\n implements ArchivistInstance {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, FilesystemArchivistConfigSchema]\n static override readonly defaultConfigSchema: Schema = FilesystemArchivistConfigSchema\n\n private _memoryArchivist?: MemoryArchivist\n\n get filePath() {\n return this.config?.filePath ?? 'archivist.xyo.json'\n }\n\n override get queries() {\n return [ArchivistAllQuerySchema, ArchivistCommitQuerySchema, ...super.queries]\n }\n\n private get memoryArchivist() {\n return assertEx(this._memoryArchivist)\n }\n\n private static async dataFromRawJson(rawJson: string) {\n const data: FileSystemArchivistData = JSON.parse(rawJson)\n assertEx(typeof data === 'object', () => 'Archivist Data must be object')\n assertEx(Array.isArray(data.payloads), () => 'Archivist Data \"payloads\" field must be array of payloads')\n data.payloads = await this.payloadsFromRawPayloads(data.payloads)\n return data\n }\n\n private static async payloadsFromRawPayloads(rawPayloads: Payload[]) {\n // validation should be done in here. I don't believe parse does much validation yet.\n return await Promise.all(rawPayloads.map(async payload => await PayloadBuilder.build(payload)))\n }\n\n protected override allHandler(): PromisableArray<PayloadWithMeta> {\n return this.memoryArchivist.all()\n }\n\n protected override clearHandler(): void | Promise<void> {\n return this.memoryArchivist.clear()\n }\n\n protected override async commitHandler(): Promise<WithMeta<BoundWitness>[]> {\n return await this.memoryArchivist.commit()\n }\n\n protected override deleteHandler(hashes: Hash[]): PromisableArray<Hash> {\n return this.memoryArchivist.delete(hashes)\n }\n\n protected override async getHandler(hashes: Hash[]): Promise<PayloadWithMeta[]> {\n return await this.memoryArchivist.get(hashes)\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]> {\n return await this.memoryArchivist.insert(payloads)\n }\n\n protected override async startHandler() {\n await super.startHandler()\n this._memoryArchivist = await MemoryArchivist.create({ account: await HDWallet.random() })\n try {\n const data = await FilesystemArchivist.dataFromRawJson(await this.rawJsonFromFile())\n await this._memoryArchivist.insert(await Promise.all(data.payloads.map(payload => PayloadBuilder.build(payload))))\n } catch (ex) {\n handleError(ex, (error) => {\n this.logger?.error(error.message)\n })\n return false\n }\n return true\n }\n\n private async rawJsonFromFile() {\n return await readFile(this.filePath, { encoding: 'utf8' })\n }\n}\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AAEzB,SAASC,gBAAgB;AACzB,SAASC,mBAAmB;AAG5B,SAASC,gBAAgB;AACzB,SAASC,yBAAyB;AAClC,SAASC,uBAAuB;AAChC,SACEC,yBACAC,kCAIK;AAEP,SAA0BC,uBAAuB;AACjD,SAASC,sBAAsB;;;;;;;;AAQxB,IAAMC,kCAAmE;AAazE,IAAMC,sBAAN,MAAMA,6BACHC,kBAAAA;SAAAA;;;EAER,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeH;;EAC5E,OAAyBI,sBAA8BJ;EAE/CK;EAER,IAAIC,WAAW;AACb,WAAO,KAAKC,QAAQD,YAAY;EAClC;EAEA,IAAaE,UAAU;AACrB,WAAO;MAACC;MAAyBC;SAA+B,MAAMF;;EACxE;EAEA,IAAYG,kBAAkB;AAC5B,WAAOC,SAAS,KAAKP,gBAAgB;EACvC;EAEA,aAAqBQ,gBAAgBC,SAAiB;AACpD,UAAMC,OAAgCC,KAAKC,MAAMH,OAAAA;AACjDF,aAAS,OAAOG,SAAS,UAAU,MAAM,+BAAA;AACzCH,aAASM,MAAMC,QAAQJ,KAAKK,QAAQ,GAAG,MAAM,2DAAA;AAC7CL,SAAKK,WAAW,MAAM,KAAKC,wBAAwBN,KAAKK,QAAQ;AAChE,WAAOL;EACT;EAEA,aAAqBM,wBAAwBC,aAAwB;AAEnE,WAAO,MAAMC,QAAQC,IAAIF,YAAYG,IAAI,OAAMC,YAAW,MAAMC,eAAeC,MAAMF,OAAAA,CAAAA,CAAAA;EACvF;EAEmBG,aAA+C;AAChE,WAAO,KAAKlB,gBAAgBa,IAAG;EACjC;EAEmBM,eAAqC;AACtD,WAAO,KAAKnB,gBAAgBoB,MAAK;EACnC;EAEA,MAAyBC,gBAAmD;AAC1E,WAAO,MAAM,KAAKrB,gBAAgBsB,OAAM;EAC1C;EAEmBC,cAAcC,QAAuC;AACtE,WAAO,KAAKxB,gBAAgByB,OAAOD,MAAAA;EACrC;EAEA,MAAyBE,WAAWF,QAA4C;AAC9E,WAAO,MAAM,KAAKxB,gBAAgB2B,IAAIH,MAAAA;EACxC;EAEA,MAAyBI,cAAcnB,UAAiD;AACtF,WAAO,MAAM,KAAKT,gBAAgB6B,OAAOpB,QAAAA;EAC3C;EAEA,MAAyBqB,eAAe;AACtC,UAAM,MAAMA,aAAAA;AACZ,SAAKpC,mBAAmB,MAAMqC,gBAAgBC,OAAO;MAAEC,SAAS,MAAMC,SAASC,OAAM;IAAG,CAAA;AACxF,QAAI;AACF,YAAM/B,OAAO,MAAMd,qBAAoBY,gBAAgB,MAAM,KAAKkC,gBAAe,CAAA;AACjF,YAAM,KAAK1C,iBAAiBmC,OAAO,MAAMjB,QAAQC,IAAIT,KAAKK,SAASK,IAAIC,CAAAA,YAAWC,eAAeC,MAAMF,OAAAA,CAAAA,CAAAA,CAAAA;IACzG,SAASsB,IAAI;AACXC,kBAAYD,IAAI,CAACE,UAAAA;AACf,aAAKC,QAAQD,MAAMA,MAAME,OAAO;MAClC,CAAA;AACA,aAAO;IACT;AACA,WAAO;EACT;EAEA,MAAcL,kBAAkB;AAC9B,WAAO,MAAMM,SAAS,KAAK/C,UAAU;MAAEgD,UAAU;IAAO,CAAA;EAC1D;AACF;;;;","names":["readFile","assertEx","handleError","HDWallet","AbstractArchivist","MemoryArchivist","ArchivistAllQuerySchema","ArchivistCommitQuerySchema","creatableModule","PayloadBuilder","FilesystemArchivistConfigSchema","FilesystemArchivist","AbstractArchivist","configSchemas","defaultConfigSchema","_memoryArchivist","filePath","config","queries","ArchivistAllQuerySchema","ArchivistCommitQuerySchema","memoryArchivist","assertEx","dataFromRawJson","rawJson","data","JSON","parse","Array","isArray","payloads","payloadsFromRawPayloads","rawPayloads","Promise","all","map","payload","PayloadBuilder","build","allHandler","clearHandler","clear","commitHandler","commit","deleteHandler","hashes","delete","getHandler","get","insertHandler","insert","startHandler","MemoryArchivist","create","account","HDWallet","random","rawJsonFromFile","ex","handleError","error","logger","message","readFile","encoding"]}
package/package.json CHANGED
@@ -14,37 +14,32 @@
14
14
  "@xylabs/error": "^3.6.12",
15
15
  "@xylabs/hex": "^3.6.12",
16
16
  "@xylabs/promise": "^3.6.12",
17
- "@xyo-network/account": "^2.111.3",
18
- "@xyo-network/archivist-abstract": "^2.111.3",
19
- "@xyo-network/archivist-memory": "^2.111.3",
20
- "@xyo-network/archivist-model": "^2.111.3",
21
- "@xyo-network/boundwitness-model": "^2.111.3",
22
- "@xyo-network/module-model": "^2.111.3",
23
- "@xyo-network/payload-builder": "^2.111.3",
24
- "@xyo-network/payload-model": "^2.111.3"
17
+ "@xyo-network/account": "^3.0.0",
18
+ "@xyo-network/archivist-abstract": "^3.0.0",
19
+ "@xyo-network/archivist-memory": "^3.0.0",
20
+ "@xyo-network/archivist-model": "^3.0.0",
21
+ "@xyo-network/boundwitness-model": "^3.0.0",
22
+ "@xyo-network/module-model": "^3.0.0",
23
+ "@xyo-network/payload-builder": "^3.0.0",
24
+ "@xyo-network/payload-model": "^3.0.0"
25
25
  },
26
26
  "devDependencies": {
27
- "@xylabs/ts-scripts-yarn3": "^3.15.14",
28
- "@xylabs/tsconfig": "^3.15.14",
27
+ "@xylabs/ts-scripts-yarn3": "next",
28
+ "@xylabs/tsconfig": "next",
29
29
  "typescript": "^5.5.4"
30
30
  },
31
31
  "description": "Primary SDK for using XYO Protocol 2.0",
32
32
  "exports": {
33
33
  ".": {
34
34
  "node": {
35
- "require": {
36
- "types": "./dist/node/index.d.cts",
37
- "default": "./dist/node/index.cjs"
38
- },
39
35
  "import": {
40
- "types": "./dist/node/index.d.mts",
36
+ "types": "./dist/node/index.d.ts",
41
37
  "default": "./dist/node/index.mjs"
42
38
  }
43
39
  }
44
40
  },
45
41
  "./package.json": "./package.json"
46
42
  },
47
- "main": "dist/node/index.cjs",
48
43
  "module": "dist/node/index.mjs",
49
44
  "types": "dist/node/index.d.ts",
50
45
  "homepage": "https://xyo.network",
@@ -57,6 +52,6 @@
57
52
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
58
53
  },
59
54
  "sideEffects": false,
60
- "version": "2.111.3",
55
+ "version": "3.0.0",
61
56
  "type": "module"
62
57
  }
package/xy.config.ts CHANGED
@@ -5,6 +5,7 @@ const config: XyTsupConfig = {
5
5
  node: {
6
6
  src: true,
7
7
  },
8
+ neutral: {},
8
9
  },
9
10
  }
10
11
 
@@ -1,36 +0,0 @@
1
- import { Hash } from '@xylabs/hex';
2
- import { PromisableArray } from '@xylabs/promise';
3
- import { AbstractArchivist } from '@xyo-network/archivist-abstract';
4
- import { ArchivistConfig, ArchivistInstance, ArchivistParams } from '@xyo-network/archivist-model';
5
- import { BoundWitness } from '@xyo-network/boundwitness-model';
6
- import { AnyConfigSchema } from '@xyo-network/module-model';
7
- import { Payload, PayloadWithMeta, Schema, WithMeta } from '@xyo-network/payload-model';
8
- export interface FileSystemArchivistData {
9
- payloads: Payload[];
10
- }
11
- export type FilesystemArchivistConfigSchema = 'network.xyo.archivist.filesystem.config';
12
- export declare const FilesystemArchivistConfigSchema: FilesystemArchivistConfigSchema;
13
- export type FilesystemArchivistConfig = ArchivistConfig<{
14
- filePath?: string;
15
- schema: FilesystemArchivistConfigSchema;
16
- }>;
17
- export type FilesystemArchivistParams = ArchivistParams<AnyConfigSchema<FilesystemArchivistConfig>>;
18
- export declare class FilesystemArchivist<TParams extends FilesystemArchivistParams = FilesystemArchivistParams> extends AbstractArchivist<TParams> implements ArchivistInstance {
19
- static readonly configSchemas: Schema[];
20
- static readonly defaultConfigSchema: Schema;
21
- private _memoryArchivist?;
22
- get filePath(): string;
23
- get queries(): string[];
24
- private get memoryArchivist();
25
- private static dataFromRawJson;
26
- private static payloadsFromRawPayloads;
27
- protected allHandler(): PromisableArray<PayloadWithMeta>;
28
- protected clearHandler(): void | Promise<void>;
29
- protected commitHandler(): Promise<WithMeta<BoundWitness>[]>;
30
- protected deleteHandler(hashes: Hash[]): PromisableArray<Hash>;
31
- protected getHandler(hashes: Hash[]): Promise<PayloadWithMeta[]>;
32
- protected insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]>;
33
- protected startHandler(): Promise<boolean>;
34
- private rawJsonFromFile;
35
- }
36
- //# sourceMappingURL=FilesystemArchivist.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"FilesystemArchivist.d.ts","sourceRoot":"","sources":["../../src/FilesystemArchivist.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAClC,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAEjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAEnE,OAAO,EAGL,eAAe,EACf,iBAAiB,EACjB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAC9D,OAAO,EAAE,eAAe,EAAmB,MAAM,2BAA2B,CAAA;AAE5E,OAAO,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEvF,MAAM,WAAW,uBAAuB;IACtC,QAAQ,EAAE,OAAO,EAAE,CAAA;CACpB;AAED,MAAM,MAAM,+BAA+B,GAAG,yCAAyC,CAAA;AACvF,eAAO,MAAM,+BAA+B,EAAE,+BAA2E,CAAA;AAEzH,MAAM,MAAM,yBAAyB,GAAG,eAAe,CAAC;IACtD,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,MAAM,EAAE,+BAA+B,CAAA;CACxC,CAAC,CAAA;AAEF,MAAM,MAAM,yBAAyB,GAAG,eAAe,CAAC,eAAe,CAAC,yBAAyB,CAAC,CAAC,CAAA;AAKnG,qBACa,mBAAmB,CAAC,OAAO,SAAS,yBAAyB,GAAG,yBAAyB,CACpG,SAAQ,iBAAiB,CAAC,OAAO,CACjC,YAAW,iBAAiB;IAC5B,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAA4D;IAC5G,gBAAyB,mBAAmB,EAAE,MAAM,CAAkC;IAEtF,OAAO,CAAC,gBAAgB,CAAC,CAAiB;IAE1C,IAAI,QAAQ,WAEX;IAED,IAAa,OAAO,aAEnB;IAED,OAAO,KAAK,eAAe,GAE1B;mBAEoB,eAAe;mBAQf,uBAAuB;cAKzB,UAAU,IAAI,eAAe,CAAC,eAAe,CAAC;cAI9C,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAI9B,aAAa,IAAI,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC;cAIxD,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,eAAe,CAAC,IAAI,CAAC;cAI9C,UAAU,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;cAItD,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;cAI9D,YAAY;YAevB,eAAe;CAG9B"}
@@ -1,36 +0,0 @@
1
- import { Hash } from '@xylabs/hex';
2
- import { PromisableArray } from '@xylabs/promise';
3
- import { AbstractArchivist } from '@xyo-network/archivist-abstract';
4
- import { ArchivistConfig, ArchivistInstance, ArchivistParams } from '@xyo-network/archivist-model';
5
- import { BoundWitness } from '@xyo-network/boundwitness-model';
6
- import { AnyConfigSchema } from '@xyo-network/module-model';
7
- import { Payload, PayloadWithMeta, Schema, WithMeta } from '@xyo-network/payload-model';
8
- export interface FileSystemArchivistData {
9
- payloads: Payload[];
10
- }
11
- export type FilesystemArchivistConfigSchema = 'network.xyo.archivist.filesystem.config';
12
- export declare const FilesystemArchivistConfigSchema: FilesystemArchivistConfigSchema;
13
- export type FilesystemArchivistConfig = ArchivistConfig<{
14
- filePath?: string;
15
- schema: FilesystemArchivistConfigSchema;
16
- }>;
17
- export type FilesystemArchivistParams = ArchivistParams<AnyConfigSchema<FilesystemArchivistConfig>>;
18
- export declare class FilesystemArchivist<TParams extends FilesystemArchivistParams = FilesystemArchivistParams> extends AbstractArchivist<TParams> implements ArchivistInstance {
19
- static readonly configSchemas: Schema[];
20
- static readonly defaultConfigSchema: Schema;
21
- private _memoryArchivist?;
22
- get filePath(): string;
23
- get queries(): string[];
24
- private get memoryArchivist();
25
- private static dataFromRawJson;
26
- private static payloadsFromRawPayloads;
27
- protected allHandler(): PromisableArray<PayloadWithMeta>;
28
- protected clearHandler(): void | Promise<void>;
29
- protected commitHandler(): Promise<WithMeta<BoundWitness>[]>;
30
- protected deleteHandler(hashes: Hash[]): PromisableArray<Hash>;
31
- protected getHandler(hashes: Hash[]): Promise<PayloadWithMeta[]>;
32
- protected insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]>;
33
- protected startHandler(): Promise<boolean>;
34
- private rawJsonFromFile;
35
- }
36
- //# sourceMappingURL=FilesystemArchivist.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"FilesystemArchivist.d.ts","sourceRoot":"","sources":["../../src/FilesystemArchivist.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAClC,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAEjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAEnE,OAAO,EAGL,eAAe,EACf,iBAAiB,EACjB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAC9D,OAAO,EAAE,eAAe,EAAmB,MAAM,2BAA2B,CAAA;AAE5E,OAAO,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEvF,MAAM,WAAW,uBAAuB;IACtC,QAAQ,EAAE,OAAO,EAAE,CAAA;CACpB;AAED,MAAM,MAAM,+BAA+B,GAAG,yCAAyC,CAAA;AACvF,eAAO,MAAM,+BAA+B,EAAE,+BAA2E,CAAA;AAEzH,MAAM,MAAM,yBAAyB,GAAG,eAAe,CAAC;IACtD,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,MAAM,EAAE,+BAA+B,CAAA;CACxC,CAAC,CAAA;AAEF,MAAM,MAAM,yBAAyB,GAAG,eAAe,CAAC,eAAe,CAAC,yBAAyB,CAAC,CAAC,CAAA;AAKnG,qBACa,mBAAmB,CAAC,OAAO,SAAS,yBAAyB,GAAG,yBAAyB,CACpG,SAAQ,iBAAiB,CAAC,OAAO,CACjC,YAAW,iBAAiB;IAC5B,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAA4D;IAC5G,gBAAyB,mBAAmB,EAAE,MAAM,CAAkC;IAEtF,OAAO,CAAC,gBAAgB,CAAC,CAAiB;IAE1C,IAAI,QAAQ,WAEX;IAED,IAAa,OAAO,aAEnB;IAED,OAAO,KAAK,eAAe,GAE1B;mBAEoB,eAAe;mBAQf,uBAAuB;cAKzB,UAAU,IAAI,eAAe,CAAC,eAAe,CAAC;cAI9C,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAI9B,aAAa,IAAI,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC;cAIxD,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,eAAe,CAAC,IAAI,CAAC;cAI9C,UAAU,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;cAItD,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;cAI9D,YAAY;YAevB,eAAe;CAG9B"}
@@ -1,36 +0,0 @@
1
- import { Hash } from '@xylabs/hex';
2
- import { PromisableArray } from '@xylabs/promise';
3
- import { AbstractArchivist } from '@xyo-network/archivist-abstract';
4
- import { ArchivistConfig, ArchivistInstance, ArchivistParams } from '@xyo-network/archivist-model';
5
- import { BoundWitness } from '@xyo-network/boundwitness-model';
6
- import { AnyConfigSchema } from '@xyo-network/module-model';
7
- import { Payload, PayloadWithMeta, Schema, WithMeta } from '@xyo-network/payload-model';
8
- export interface FileSystemArchivistData {
9
- payloads: Payload[];
10
- }
11
- export type FilesystemArchivistConfigSchema = 'network.xyo.archivist.filesystem.config';
12
- export declare const FilesystemArchivistConfigSchema: FilesystemArchivistConfigSchema;
13
- export type FilesystemArchivistConfig = ArchivistConfig<{
14
- filePath?: string;
15
- schema: FilesystemArchivistConfigSchema;
16
- }>;
17
- export type FilesystemArchivistParams = ArchivistParams<AnyConfigSchema<FilesystemArchivistConfig>>;
18
- export declare class FilesystemArchivist<TParams extends FilesystemArchivistParams = FilesystemArchivistParams> extends AbstractArchivist<TParams> implements ArchivistInstance {
19
- static readonly configSchemas: Schema[];
20
- static readonly defaultConfigSchema: Schema;
21
- private _memoryArchivist?;
22
- get filePath(): string;
23
- get queries(): string[];
24
- private get memoryArchivist();
25
- private static dataFromRawJson;
26
- private static payloadsFromRawPayloads;
27
- protected allHandler(): PromisableArray<PayloadWithMeta>;
28
- protected clearHandler(): void | Promise<void>;
29
- protected commitHandler(): Promise<WithMeta<BoundWitness>[]>;
30
- protected deleteHandler(hashes: Hash[]): PromisableArray<Hash>;
31
- protected getHandler(hashes: Hash[]): Promise<PayloadWithMeta[]>;
32
- protected insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]>;
33
- protected startHandler(): Promise<boolean>;
34
- private rawJsonFromFile;
35
- }
36
- //# sourceMappingURL=FilesystemArchivist.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"FilesystemArchivist.d.ts","sourceRoot":"","sources":["../../src/FilesystemArchivist.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAClC,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAEjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAEnE,OAAO,EAGL,eAAe,EACf,iBAAiB,EACjB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAC9D,OAAO,EAAE,eAAe,EAAmB,MAAM,2BAA2B,CAAA;AAE5E,OAAO,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEvF,MAAM,WAAW,uBAAuB;IACtC,QAAQ,EAAE,OAAO,EAAE,CAAA;CACpB;AAED,MAAM,MAAM,+BAA+B,GAAG,yCAAyC,CAAA;AACvF,eAAO,MAAM,+BAA+B,EAAE,+BAA2E,CAAA;AAEzH,MAAM,MAAM,yBAAyB,GAAG,eAAe,CAAC;IACtD,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,MAAM,EAAE,+BAA+B,CAAA;CACxC,CAAC,CAAA;AAEF,MAAM,MAAM,yBAAyB,GAAG,eAAe,CAAC,eAAe,CAAC,yBAAyB,CAAC,CAAC,CAAA;AAKnG,qBACa,mBAAmB,CAAC,OAAO,SAAS,yBAAyB,GAAG,yBAAyB,CACpG,SAAQ,iBAAiB,CAAC,OAAO,CACjC,YAAW,iBAAiB;IAC5B,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAA4D;IAC5G,gBAAyB,mBAAmB,EAAE,MAAM,CAAkC;IAEtF,OAAO,CAAC,gBAAgB,CAAC,CAAiB;IAE1C,IAAI,QAAQ,WAEX;IAED,IAAa,OAAO,aAEnB;IAED,OAAO,KAAK,eAAe,GAE1B;mBAEoB,eAAe;mBAQf,uBAAuB;cAKzB,UAAU,IAAI,eAAe,CAAC,eAAe,CAAC;cAI9C,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAI9B,aAAa,IAAI,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC;cAIxD,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,eAAe,CAAC,IAAI,CAAC;cAI9C,UAAU,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;cAItD,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;cAI9D,YAAY;YAevB,eAAe;CAG9B"}
@@ -1,123 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
7
- var __export = (target, all) => {
8
- for (var name in all)
9
- __defProp(target, name, { get: all[name], enumerable: true });
10
- };
11
- var __copyProps = (to, from, except, desc) => {
12
- if (from && typeof from === "object" || typeof from === "function") {
13
- for (let key of __getOwnPropNames(from))
14
- if (!__hasOwnProp.call(to, key) && key !== except)
15
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
- }
17
- return to;
18
- };
19
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
20
-
21
- // src/index.ts
22
- var src_exports = {};
23
- __export(src_exports, {
24
- FilesystemArchivist: () => FilesystemArchivist,
25
- FilesystemArchivistConfigSchema: () => FilesystemArchivistConfigSchema
26
- });
27
- module.exports = __toCommonJS(src_exports);
28
-
29
- // src/FilesystemArchivist.ts
30
- var import_promises = require("fs/promises");
31
- var import_assert = require("@xylabs/assert");
32
- var import_error = require("@xylabs/error");
33
- var import_account = require("@xyo-network/account");
34
- var import_archivist_abstract = require("@xyo-network/archivist-abstract");
35
- var import_archivist_memory = require("@xyo-network/archivist-memory");
36
- var import_archivist_model = require("@xyo-network/archivist-model");
37
- var import_module_model = require("@xyo-network/module-model");
38
- var import_payload_builder = require("@xyo-network/payload-builder");
39
- function _ts_decorate(decorators, target, key, desc) {
40
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
41
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
42
- 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;
43
- return c > 3 && r && Object.defineProperty(target, key, r), r;
44
- }
45
- __name(_ts_decorate, "_ts_decorate");
46
- var FilesystemArchivistConfigSchema = "network.xyo.archivist.filesystem.config";
47
- var FilesystemArchivist = class _FilesystemArchivist extends import_archivist_abstract.AbstractArchivist {
48
- static {
49
- __name(this, "FilesystemArchivist");
50
- }
51
- static configSchemas = [
52
- ...super.configSchemas,
53
- FilesystemArchivistConfigSchema
54
- ];
55
- static defaultConfigSchema = FilesystemArchivistConfigSchema;
56
- _memoryArchivist;
57
- get filePath() {
58
- return this.config?.filePath ?? "archivist.xyo.json";
59
- }
60
- get queries() {
61
- return [
62
- import_archivist_model.ArchivistAllQuerySchema,
63
- import_archivist_model.ArchivistCommitQuerySchema,
64
- ...super.queries
65
- ];
66
- }
67
- get memoryArchivist() {
68
- return (0, import_assert.assertEx)(this._memoryArchivist);
69
- }
70
- static async dataFromRawJson(rawJson) {
71
- const data = JSON.parse(rawJson);
72
- (0, import_assert.assertEx)(typeof data === "object", () => "Archivist Data must be object");
73
- (0, import_assert.assertEx)(Array.isArray(data.payloads), () => 'Archivist Data "payloads" field must be array of payloads');
74
- data.payloads = await this.payloadsFromRawPayloads(data.payloads);
75
- return data;
76
- }
77
- static async payloadsFromRawPayloads(rawPayloads) {
78
- return await Promise.all(rawPayloads.map(async (payload) => await import_payload_builder.PayloadBuilder.build(payload)));
79
- }
80
- allHandler() {
81
- return this.memoryArchivist.all();
82
- }
83
- clearHandler() {
84
- return this.memoryArchivist.clear();
85
- }
86
- async commitHandler() {
87
- return await this.memoryArchivist.commit();
88
- }
89
- deleteHandler(hashes) {
90
- return this.memoryArchivist.delete(hashes);
91
- }
92
- async getHandler(hashes) {
93
- return await this.memoryArchivist.get(hashes);
94
- }
95
- async insertHandler(payloads) {
96
- return await this.memoryArchivist.insert(payloads);
97
- }
98
- async startHandler() {
99
- await super.startHandler();
100
- this._memoryArchivist = await import_archivist_memory.MemoryArchivist.create({
101
- account: await import_account.HDWallet.random()
102
- });
103
- try {
104
- const data = await _FilesystemArchivist.dataFromRawJson(await this.rawJsonFromFile());
105
- await this._memoryArchivist.insert(await Promise.all(data.payloads.map((payload) => import_payload_builder.PayloadBuilder.build(payload))));
106
- } catch (ex) {
107
- (0, import_error.handleError)(ex, (error) => {
108
- this.logger?.error(error.message);
109
- });
110
- return false;
111
- }
112
- return true;
113
- }
114
- async rawJsonFromFile() {
115
- return await (0, import_promises.readFile)(this.filePath, {
116
- encoding: "utf8"
117
- });
118
- }
119
- };
120
- FilesystemArchivist = _ts_decorate([
121
- (0, import_module_model.creatableModule)()
122
- ], FilesystemArchivist);
123
- //# sourceMappingURL=index.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/FilesystemArchivist.ts"],"sourcesContent":["export * from './FilesystemArchivist.ts'\n","import { readFile } from 'node:fs/promises'\n\nimport { assertEx } from '@xylabs/assert'\nimport { handleError } from '@xylabs/error'\nimport { Hash } from '@xylabs/hex'\nimport { PromisableArray } from '@xylabs/promise'\nimport { HDWallet } from '@xyo-network/account'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport { MemoryArchivist } from '@xyo-network/archivist-memory'\nimport {\n ArchivistAllQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistInstance,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, PayloadWithMeta, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport interface FileSystemArchivistData {\n payloads: Payload[]\n}\n\nexport type FilesystemArchivistConfigSchema = 'network.xyo.archivist.filesystem.config'\nexport const FilesystemArchivistConfigSchema: FilesystemArchivistConfigSchema = 'network.xyo.archivist.filesystem.config'\n\nexport type FilesystemArchivistConfig = ArchivistConfig<{\n filePath?: string\n schema: FilesystemArchivistConfigSchema\n}>\n\nexport type FilesystemArchivistParams = ArchivistParams<AnyConfigSchema<FilesystemArchivistConfig>>\n\n/** @description Currently only a read-only archivist that loads payloads from filesystem\n * but allows for future expansion to read/write\n */\n@creatableModule()\nexport class FilesystemArchivist<TParams extends FilesystemArchivistParams = FilesystemArchivistParams>\n extends AbstractArchivist<TParams>\n implements ArchivistInstance {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, FilesystemArchivistConfigSchema]\n static override readonly defaultConfigSchema: Schema = FilesystemArchivistConfigSchema\n\n private _memoryArchivist?: MemoryArchivist\n\n get filePath() {\n return this.config?.filePath ?? 'archivist.xyo.json'\n }\n\n override get queries() {\n return [ArchivistAllQuerySchema, ArchivistCommitQuerySchema, ...super.queries]\n }\n\n private get memoryArchivist() {\n return assertEx(this._memoryArchivist)\n }\n\n private static async dataFromRawJson(rawJson: string) {\n const data: FileSystemArchivistData = JSON.parse(rawJson)\n assertEx(typeof data === 'object', () => 'Archivist Data must be object')\n assertEx(Array.isArray(data.payloads), () => 'Archivist Data \"payloads\" field must be array of payloads')\n data.payloads = await this.payloadsFromRawPayloads(data.payloads)\n return data\n }\n\n private static async payloadsFromRawPayloads(rawPayloads: Payload[]) {\n // validation should be done in here. I don't believe parse does much validation yet.\n return await Promise.all(rawPayloads.map(async payload => await PayloadBuilder.build(payload)))\n }\n\n protected override allHandler(): PromisableArray<PayloadWithMeta> {\n return this.memoryArchivist.all()\n }\n\n protected override clearHandler(): void | Promise<void> {\n return this.memoryArchivist.clear()\n }\n\n protected override async commitHandler(): Promise<WithMeta<BoundWitness>[]> {\n return await this.memoryArchivist.commit()\n }\n\n protected override deleteHandler(hashes: Hash[]): PromisableArray<Hash> {\n return this.memoryArchivist.delete(hashes)\n }\n\n protected override async getHandler(hashes: Hash[]): Promise<PayloadWithMeta[]> {\n return await this.memoryArchivist.get(hashes)\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]> {\n return await this.memoryArchivist.insert(payloads)\n }\n\n protected override async startHandler() {\n await super.startHandler()\n this._memoryArchivist = await MemoryArchivist.create({ account: await HDWallet.random() })\n try {\n const data = await FilesystemArchivist.dataFromRawJson(await this.rawJsonFromFile())\n await this._memoryArchivist.insert(await Promise.all(data.payloads.map(payload => PayloadBuilder.build(payload))))\n } catch (ex) {\n handleError(ex, (error) => {\n this.logger?.error(error.message)\n })\n return false\n }\n return true\n }\n\n private async rawJsonFromFile() {\n return await readFile(this.filePath, { encoding: 'utf8' })\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;;ACAA,sBAAyB;AAEzB,oBAAyB;AACzB,mBAA4B;AAG5B,qBAAyB;AACzB,gCAAkC;AAClC,8BAAgC;AAChC,6BAMO;AAEP,0BAAiD;AACjD,6BAA+B;;;;;;;;AAQxB,IAAMA,kCAAmE;AAazE,IAAMC,sBAAN,MAAMA,6BACHC,4CAAAA;SAAAA;;;EAER,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeH;;EAC5E,OAAyBI,sBAA8BJ;EAE/CK;EAER,IAAIC,WAAW;AACb,WAAO,KAAKC,QAAQD,YAAY;EAClC;EAEA,IAAaE,UAAU;AACrB,WAAO;MAACC;MAAyBC;SAA+B,MAAMF;;EACxE;EAEA,IAAYG,kBAAkB;AAC5B,eAAOC,wBAAS,KAAKP,gBAAgB;EACvC;EAEA,aAAqBQ,gBAAgBC,SAAiB;AACpD,UAAMC,OAAgCC,KAAKC,MAAMH,OAAAA;AACjDF,gCAAS,OAAOG,SAAS,UAAU,MAAM,+BAAA;AACzCH,gCAASM,MAAMC,QAAQJ,KAAKK,QAAQ,GAAG,MAAM,2DAAA;AAC7CL,SAAKK,WAAW,MAAM,KAAKC,wBAAwBN,KAAKK,QAAQ;AAChE,WAAOL;EACT;EAEA,aAAqBM,wBAAwBC,aAAwB;AAEnE,WAAO,MAAMC,QAAQC,IAAIF,YAAYG,IAAI,OAAMC,YAAW,MAAMC,sCAAeC,MAAMF,OAAAA,CAAAA,CAAAA;EACvF;EAEmBG,aAA+C;AAChE,WAAO,KAAKlB,gBAAgBa,IAAG;EACjC;EAEmBM,eAAqC;AACtD,WAAO,KAAKnB,gBAAgBoB,MAAK;EACnC;EAEA,MAAyBC,gBAAmD;AAC1E,WAAO,MAAM,KAAKrB,gBAAgBsB,OAAM;EAC1C;EAEmBC,cAAcC,QAAuC;AACtE,WAAO,KAAKxB,gBAAgByB,OAAOD,MAAAA;EACrC;EAEA,MAAyBE,WAAWF,QAA4C;AAC9E,WAAO,MAAM,KAAKxB,gBAAgB2B,IAAIH,MAAAA;EACxC;EAEA,MAAyBI,cAAcnB,UAAiD;AACtF,WAAO,MAAM,KAAKT,gBAAgB6B,OAAOpB,QAAAA;EAC3C;EAEA,MAAyBqB,eAAe;AACtC,UAAM,MAAMA,aAAAA;AACZ,SAAKpC,mBAAmB,MAAMqC,wCAAgBC,OAAO;MAAEC,SAAS,MAAMC,wBAASC,OAAM;IAAG,CAAA;AACxF,QAAI;AACF,YAAM/B,OAAO,MAAMd,qBAAoBY,gBAAgB,MAAM,KAAKkC,gBAAe,CAAA;AACjF,YAAM,KAAK1C,iBAAiBmC,OAAO,MAAMjB,QAAQC,IAAIT,KAAKK,SAASK,IAAIC,CAAAA,YAAWC,sCAAeC,MAAMF,OAAAA,CAAAA,CAAAA,CAAAA;IACzG,SAASsB,IAAI;AACXC,oCAAYD,IAAI,CAACE,UAAAA;AACf,aAAKC,QAAQD,MAAMA,MAAME,OAAO;MAClC,CAAA;AACA,aAAO;IACT;AACA,WAAO;EACT;EAEA,MAAcL,kBAAkB;AAC9B,WAAO,UAAMM,0BAAS,KAAK/C,UAAU;MAAEgD,UAAU;IAAO,CAAA;EAC1D;AACF;;;;","names":["FilesystemArchivistConfigSchema","FilesystemArchivist","AbstractArchivist","configSchemas","defaultConfigSchema","_memoryArchivist","filePath","config","queries","ArchivistAllQuerySchema","ArchivistCommitQuerySchema","memoryArchivist","assertEx","dataFromRawJson","rawJson","data","JSON","parse","Array","isArray","payloads","payloadsFromRawPayloads","rawPayloads","Promise","all","map","payload","PayloadBuilder","build","allHandler","clearHandler","clear","commitHandler","commit","deleteHandler","hashes","delete","getHandler","get","insertHandler","insert","startHandler","MemoryArchivist","create","account","HDWallet","random","rawJsonFromFile","ex","handleError","error","logger","message","readFile","encoding"]}
@@ -1,2 +0,0 @@
1
- export * from './FilesystemArchivist.ts';
2
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAA"}
@@ -1,2 +0,0 @@
1
- export * from './FilesystemArchivist.ts';
2
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAA"}
@@ -1,2 +0,0 @@
1
- export * from './FilesystemArchivist.ts';
2
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAA"}
@@ -1,102 +0,0 @@
1
- var __defProp = Object.defineProperty;
2
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
-
4
- // src/FilesystemArchivist.ts
5
- import { readFile } from "node:fs/promises";
6
- import { assertEx } from "@xylabs/assert";
7
- import { handleError } from "@xylabs/error";
8
- import { HDWallet } from "@xyo-network/account";
9
- import { AbstractArchivist } from "@xyo-network/archivist-abstract";
10
- import { MemoryArchivist } from "@xyo-network/archivist-memory";
11
- import { ArchivistAllQuerySchema, ArchivistCommitQuerySchema } from "@xyo-network/archivist-model";
12
- import { creatableModule } from "@xyo-network/module-model";
13
- import { PayloadBuilder } from "@xyo-network/payload-builder";
14
- function _ts_decorate(decorators, target, key, desc) {
15
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
16
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
17
- 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;
18
- return c > 3 && r && Object.defineProperty(target, key, r), r;
19
- }
20
- __name(_ts_decorate, "_ts_decorate");
21
- var FilesystemArchivistConfigSchema = "network.xyo.archivist.filesystem.config";
22
- var FilesystemArchivist = class _FilesystemArchivist extends AbstractArchivist {
23
- static {
24
- __name(this, "FilesystemArchivist");
25
- }
26
- static configSchemas = [
27
- ...super.configSchemas,
28
- FilesystemArchivistConfigSchema
29
- ];
30
- static defaultConfigSchema = FilesystemArchivistConfigSchema;
31
- _memoryArchivist;
32
- get filePath() {
33
- return this.config?.filePath ?? "archivist.xyo.json";
34
- }
35
- get queries() {
36
- return [
37
- ArchivistAllQuerySchema,
38
- ArchivistCommitQuerySchema,
39
- ...super.queries
40
- ];
41
- }
42
- get memoryArchivist() {
43
- return assertEx(this._memoryArchivist);
44
- }
45
- static async dataFromRawJson(rawJson) {
46
- const data = JSON.parse(rawJson);
47
- assertEx(typeof data === "object", () => "Archivist Data must be object");
48
- assertEx(Array.isArray(data.payloads), () => 'Archivist Data "payloads" field must be array of payloads');
49
- data.payloads = await this.payloadsFromRawPayloads(data.payloads);
50
- return data;
51
- }
52
- static async payloadsFromRawPayloads(rawPayloads) {
53
- return await Promise.all(rawPayloads.map(async (payload) => await PayloadBuilder.build(payload)));
54
- }
55
- allHandler() {
56
- return this.memoryArchivist.all();
57
- }
58
- clearHandler() {
59
- return this.memoryArchivist.clear();
60
- }
61
- async commitHandler() {
62
- return await this.memoryArchivist.commit();
63
- }
64
- deleteHandler(hashes) {
65
- return this.memoryArchivist.delete(hashes);
66
- }
67
- async getHandler(hashes) {
68
- return await this.memoryArchivist.get(hashes);
69
- }
70
- async insertHandler(payloads) {
71
- return await this.memoryArchivist.insert(payloads);
72
- }
73
- async startHandler() {
74
- await super.startHandler();
75
- this._memoryArchivist = await MemoryArchivist.create({
76
- account: await HDWallet.random()
77
- });
78
- try {
79
- const data = await _FilesystemArchivist.dataFromRawJson(await this.rawJsonFromFile());
80
- await this._memoryArchivist.insert(await Promise.all(data.payloads.map((payload) => PayloadBuilder.build(payload))));
81
- } catch (ex) {
82
- handleError(ex, (error) => {
83
- this.logger?.error(error.message);
84
- });
85
- return false;
86
- }
87
- return true;
88
- }
89
- async rawJsonFromFile() {
90
- return await readFile(this.filePath, {
91
- encoding: "utf8"
92
- });
93
- }
94
- };
95
- FilesystemArchivist = _ts_decorate([
96
- creatableModule()
97
- ], FilesystemArchivist);
98
- export {
99
- FilesystemArchivist,
100
- FilesystemArchivistConfigSchema
101
- };
102
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/FilesystemArchivist.ts"],"sourcesContent":["import { readFile } from 'node:fs/promises'\n\nimport { assertEx } from '@xylabs/assert'\nimport { handleError } from '@xylabs/error'\nimport { Hash } from '@xylabs/hex'\nimport { PromisableArray } from '@xylabs/promise'\nimport { HDWallet } from '@xyo-network/account'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport { MemoryArchivist } from '@xyo-network/archivist-memory'\nimport {\n ArchivistAllQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistInstance,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, PayloadWithMeta, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport interface FileSystemArchivistData {\n payloads: Payload[]\n}\n\nexport type FilesystemArchivistConfigSchema = 'network.xyo.archivist.filesystem.config'\nexport const FilesystemArchivistConfigSchema: FilesystemArchivistConfigSchema = 'network.xyo.archivist.filesystem.config'\n\nexport type FilesystemArchivistConfig = ArchivistConfig<{\n filePath?: string\n schema: FilesystemArchivistConfigSchema\n}>\n\nexport type FilesystemArchivistParams = ArchivistParams<AnyConfigSchema<FilesystemArchivistConfig>>\n\n/** @description Currently only a read-only archivist that loads payloads from filesystem\n * but allows for future expansion to read/write\n */\n@creatableModule()\nexport class FilesystemArchivist<TParams extends FilesystemArchivistParams = FilesystemArchivistParams>\n extends AbstractArchivist<TParams>\n implements ArchivistInstance {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, FilesystemArchivistConfigSchema]\n static override readonly defaultConfigSchema: Schema = FilesystemArchivistConfigSchema\n\n private _memoryArchivist?: MemoryArchivist\n\n get filePath() {\n return this.config?.filePath ?? 'archivist.xyo.json'\n }\n\n override get queries() {\n return [ArchivistAllQuerySchema, ArchivistCommitQuerySchema, ...super.queries]\n }\n\n private get memoryArchivist() {\n return assertEx(this._memoryArchivist)\n }\n\n private static async dataFromRawJson(rawJson: string) {\n const data: FileSystemArchivistData = JSON.parse(rawJson)\n assertEx(typeof data === 'object', () => 'Archivist Data must be object')\n assertEx(Array.isArray(data.payloads), () => 'Archivist Data \"payloads\" field must be array of payloads')\n data.payloads = await this.payloadsFromRawPayloads(data.payloads)\n return data\n }\n\n private static async payloadsFromRawPayloads(rawPayloads: Payload[]) {\n // validation should be done in here. I don't believe parse does much validation yet.\n return await Promise.all(rawPayloads.map(async payload => await PayloadBuilder.build(payload)))\n }\n\n protected override allHandler(): PromisableArray<PayloadWithMeta> {\n return this.memoryArchivist.all()\n }\n\n protected override clearHandler(): void | Promise<void> {\n return this.memoryArchivist.clear()\n }\n\n protected override async commitHandler(): Promise<WithMeta<BoundWitness>[]> {\n return await this.memoryArchivist.commit()\n }\n\n protected override deleteHandler(hashes: Hash[]): PromisableArray<Hash> {\n return this.memoryArchivist.delete(hashes)\n }\n\n protected override async getHandler(hashes: Hash[]): Promise<PayloadWithMeta[]> {\n return await this.memoryArchivist.get(hashes)\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]> {\n return await this.memoryArchivist.insert(payloads)\n }\n\n protected override async startHandler() {\n await super.startHandler()\n this._memoryArchivist = await MemoryArchivist.create({ account: await HDWallet.random() })\n try {\n const data = await FilesystemArchivist.dataFromRawJson(await this.rawJsonFromFile())\n await this._memoryArchivist.insert(await Promise.all(data.payloads.map(payload => PayloadBuilder.build(payload))))\n } catch (ex) {\n handleError(ex, (error) => {\n this.logger?.error(error.message)\n })\n return false\n }\n return true\n }\n\n private async rawJsonFromFile() {\n return await readFile(this.filePath, { encoding: 'utf8' })\n }\n}\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AAEzB,SAASC,gBAAgB;AACzB,SAASC,mBAAmB;AAG5B,SAASC,gBAAgB;AACzB,SAASC,yBAAyB;AAClC,SAASC,uBAAuB;AAChC,SACEC,yBACAC,kCAIK;AAEP,SAA0BC,uBAAuB;AACjD,SAASC,sBAAsB;;;;;;;;AAQxB,IAAMC,kCAAmE;AAazE,IAAMC,sBAAN,MAAMA,6BACHC,kBAAAA;SAAAA;;;EAER,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeH;;EAC5E,OAAyBI,sBAA8BJ;EAE/CK;EAER,IAAIC,WAAW;AACb,WAAO,KAAKC,QAAQD,YAAY;EAClC;EAEA,IAAaE,UAAU;AACrB,WAAO;MAACC;MAAyBC;SAA+B,MAAMF;;EACxE;EAEA,IAAYG,kBAAkB;AAC5B,WAAOC,SAAS,KAAKP,gBAAgB;EACvC;EAEA,aAAqBQ,gBAAgBC,SAAiB;AACpD,UAAMC,OAAgCC,KAAKC,MAAMH,OAAAA;AACjDF,aAAS,OAAOG,SAAS,UAAU,MAAM,+BAAA;AACzCH,aAASM,MAAMC,QAAQJ,KAAKK,QAAQ,GAAG,MAAM,2DAAA;AAC7CL,SAAKK,WAAW,MAAM,KAAKC,wBAAwBN,KAAKK,QAAQ;AAChE,WAAOL;EACT;EAEA,aAAqBM,wBAAwBC,aAAwB;AAEnE,WAAO,MAAMC,QAAQC,IAAIF,YAAYG,IAAI,OAAMC,YAAW,MAAMC,eAAeC,MAAMF,OAAAA,CAAAA,CAAAA;EACvF;EAEmBG,aAA+C;AAChE,WAAO,KAAKlB,gBAAgBa,IAAG;EACjC;EAEmBM,eAAqC;AACtD,WAAO,KAAKnB,gBAAgBoB,MAAK;EACnC;EAEA,MAAyBC,gBAAmD;AAC1E,WAAO,MAAM,KAAKrB,gBAAgBsB,OAAM;EAC1C;EAEmBC,cAAcC,QAAuC;AACtE,WAAO,KAAKxB,gBAAgByB,OAAOD,MAAAA;EACrC;EAEA,MAAyBE,WAAWF,QAA4C;AAC9E,WAAO,MAAM,KAAKxB,gBAAgB2B,IAAIH,MAAAA;EACxC;EAEA,MAAyBI,cAAcnB,UAAiD;AACtF,WAAO,MAAM,KAAKT,gBAAgB6B,OAAOpB,QAAAA;EAC3C;EAEA,MAAyBqB,eAAe;AACtC,UAAM,MAAMA,aAAAA;AACZ,SAAKpC,mBAAmB,MAAMqC,gBAAgBC,OAAO;MAAEC,SAAS,MAAMC,SAASC,OAAM;IAAG,CAAA;AACxF,QAAI;AACF,YAAM/B,OAAO,MAAMd,qBAAoBY,gBAAgB,MAAM,KAAKkC,gBAAe,CAAA;AACjF,YAAM,KAAK1C,iBAAiBmC,OAAO,MAAMjB,QAAQC,IAAIT,KAAKK,SAASK,IAAIC,CAAAA,YAAWC,eAAeC,MAAMF,OAAAA,CAAAA,CAAAA,CAAAA;IACzG,SAASsB,IAAI;AACXC,kBAAYD,IAAI,CAACE,UAAAA;AACf,aAAKC,QAAQD,MAAMA,MAAME,OAAO;MAClC,CAAA;AACA,aAAO;IACT;AACA,WAAO;EACT;EAEA,MAAcL,kBAAkB;AAC9B,WAAO,MAAMM,SAAS,KAAK/C,UAAU;MAAEgD,UAAU;IAAO,CAAA;EAC1D;AACF;;;;","names":["readFile","assertEx","handleError","HDWallet","AbstractArchivist","MemoryArchivist","ArchivistAllQuerySchema","ArchivistCommitQuerySchema","creatableModule","PayloadBuilder","FilesystemArchivistConfigSchema","FilesystemArchivist","AbstractArchivist","configSchemas","defaultConfigSchema","_memoryArchivist","filePath","config","queries","ArchivistAllQuerySchema","ArchivistCommitQuerySchema","memoryArchivist","assertEx","dataFromRawJson","rawJson","data","JSON","parse","Array","isArray","payloads","payloadsFromRawPayloads","rawPayloads","Promise","all","map","payload","PayloadBuilder","build","allHandler","clearHandler","clear","commitHandler","commit","deleteHandler","hashes","delete","getHandler","get","insertHandler","insert","startHandler","MemoryArchivist","create","account","HDWallet","random","rawJsonFromFile","ex","handleError","error","logger","message","readFile","encoding"]}
@@ -1,36 +0,0 @@
1
- import { Hash } from '@xylabs/hex';
2
- import { PromisableArray } from '@xylabs/promise';
3
- import { AbstractArchivist } from '@xyo-network/archivist-abstract';
4
- import { ArchivistConfig, ArchivistInstance, ArchivistParams } from '@xyo-network/archivist-model';
5
- import { BoundWitness } from '@xyo-network/boundwitness-model';
6
- import { AnyConfigSchema } from '@xyo-network/module-model';
7
- import { Payload, PayloadWithMeta, Schema, WithMeta } from '@xyo-network/payload-model';
8
- export interface FileSystemArchivistData {
9
- payloads: Payload[];
10
- }
11
- export type FilesystemArchivistConfigSchema = 'network.xyo.archivist.filesystem.config';
12
- export declare const FilesystemArchivistConfigSchema: FilesystemArchivistConfigSchema;
13
- export type FilesystemArchivistConfig = ArchivistConfig<{
14
- filePath?: string;
15
- schema: FilesystemArchivistConfigSchema;
16
- }>;
17
- export type FilesystemArchivistParams = ArchivistParams<AnyConfigSchema<FilesystemArchivistConfig>>;
18
- export declare class FilesystemArchivist<TParams extends FilesystemArchivistParams = FilesystemArchivistParams> extends AbstractArchivist<TParams> implements ArchivistInstance {
19
- static readonly configSchemas: Schema[];
20
- static readonly defaultConfigSchema: Schema;
21
- private _memoryArchivist?;
22
- get filePath(): string;
23
- get queries(): string[];
24
- private get memoryArchivist();
25
- private static dataFromRawJson;
26
- private static payloadsFromRawPayloads;
27
- protected allHandler(): PromisableArray<PayloadWithMeta>;
28
- protected clearHandler(): void | Promise<void>;
29
- protected commitHandler(): Promise<WithMeta<BoundWitness>[]>;
30
- protected deleteHandler(hashes: Hash[]): PromisableArray<Hash>;
31
- protected getHandler(hashes: Hash[]): Promise<PayloadWithMeta[]>;
32
- protected insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]>;
33
- protected startHandler(): Promise<boolean>;
34
- private rawJsonFromFile;
35
- }
36
- //# sourceMappingURL=FilesystemArchivist.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"FilesystemArchivist.d.ts","sourceRoot":"","sources":["../../src/FilesystemArchivist.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAClC,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAEjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAEnE,OAAO,EAGL,eAAe,EACf,iBAAiB,EACjB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAC9D,OAAO,EAAE,eAAe,EAAmB,MAAM,2BAA2B,CAAA;AAE5E,OAAO,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEvF,MAAM,WAAW,uBAAuB;IACtC,QAAQ,EAAE,OAAO,EAAE,CAAA;CACpB;AAED,MAAM,MAAM,+BAA+B,GAAG,yCAAyC,CAAA;AACvF,eAAO,MAAM,+BAA+B,EAAE,+BAA2E,CAAA;AAEzH,MAAM,MAAM,yBAAyB,GAAG,eAAe,CAAC;IACtD,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,MAAM,EAAE,+BAA+B,CAAA;CACxC,CAAC,CAAA;AAEF,MAAM,MAAM,yBAAyB,GAAG,eAAe,CAAC,eAAe,CAAC,yBAAyB,CAAC,CAAC,CAAA;AAKnG,qBACa,mBAAmB,CAAC,OAAO,SAAS,yBAAyB,GAAG,yBAAyB,CACpG,SAAQ,iBAAiB,CAAC,OAAO,CACjC,YAAW,iBAAiB;IAC5B,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAA4D;IAC5G,gBAAyB,mBAAmB,EAAE,MAAM,CAAkC;IAEtF,OAAO,CAAC,gBAAgB,CAAC,CAAiB;IAE1C,IAAI,QAAQ,WAEX;IAED,IAAa,OAAO,aAEnB;IAED,OAAO,KAAK,eAAe,GAE1B;mBAEoB,eAAe;mBAQf,uBAAuB;cAKzB,UAAU,IAAI,eAAe,CAAC,eAAe,CAAC;cAI9C,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAI9B,aAAa,IAAI,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC;cAIxD,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,eAAe,CAAC,IAAI,CAAC;cAI9C,UAAU,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;cAItD,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;cAI9D,YAAY;YAevB,eAAe;CAG9B"}
@@ -1,36 +0,0 @@
1
- import { Hash } from '@xylabs/hex';
2
- import { PromisableArray } from '@xylabs/promise';
3
- import { AbstractArchivist } from '@xyo-network/archivist-abstract';
4
- import { ArchivistConfig, ArchivistInstance, ArchivistParams } from '@xyo-network/archivist-model';
5
- import { BoundWitness } from '@xyo-network/boundwitness-model';
6
- import { AnyConfigSchema } from '@xyo-network/module-model';
7
- import { Payload, PayloadWithMeta, Schema, WithMeta } from '@xyo-network/payload-model';
8
- export interface FileSystemArchivistData {
9
- payloads: Payload[];
10
- }
11
- export type FilesystemArchivistConfigSchema = 'network.xyo.archivist.filesystem.config';
12
- export declare const FilesystemArchivistConfigSchema: FilesystemArchivistConfigSchema;
13
- export type FilesystemArchivistConfig = ArchivistConfig<{
14
- filePath?: string;
15
- schema: FilesystemArchivistConfigSchema;
16
- }>;
17
- export type FilesystemArchivistParams = ArchivistParams<AnyConfigSchema<FilesystemArchivistConfig>>;
18
- export declare class FilesystemArchivist<TParams extends FilesystemArchivistParams = FilesystemArchivistParams> extends AbstractArchivist<TParams> implements ArchivistInstance {
19
- static readonly configSchemas: Schema[];
20
- static readonly defaultConfigSchema: Schema;
21
- private _memoryArchivist?;
22
- get filePath(): string;
23
- get queries(): string[];
24
- private get memoryArchivist();
25
- private static dataFromRawJson;
26
- private static payloadsFromRawPayloads;
27
- protected allHandler(): PromisableArray<PayloadWithMeta>;
28
- protected clearHandler(): void | Promise<void>;
29
- protected commitHandler(): Promise<WithMeta<BoundWitness>[]>;
30
- protected deleteHandler(hashes: Hash[]): PromisableArray<Hash>;
31
- protected getHandler(hashes: Hash[]): Promise<PayloadWithMeta[]>;
32
- protected insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]>;
33
- protected startHandler(): Promise<boolean>;
34
- private rawJsonFromFile;
35
- }
36
- //# sourceMappingURL=FilesystemArchivist.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"FilesystemArchivist.d.ts","sourceRoot":"","sources":["../../src/FilesystemArchivist.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAClC,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAEjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAEnE,OAAO,EAGL,eAAe,EACf,iBAAiB,EACjB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAC9D,OAAO,EAAE,eAAe,EAAmB,MAAM,2BAA2B,CAAA;AAE5E,OAAO,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEvF,MAAM,WAAW,uBAAuB;IACtC,QAAQ,EAAE,OAAO,EAAE,CAAA;CACpB;AAED,MAAM,MAAM,+BAA+B,GAAG,yCAAyC,CAAA;AACvF,eAAO,MAAM,+BAA+B,EAAE,+BAA2E,CAAA;AAEzH,MAAM,MAAM,yBAAyB,GAAG,eAAe,CAAC;IACtD,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,MAAM,EAAE,+BAA+B,CAAA;CACxC,CAAC,CAAA;AAEF,MAAM,MAAM,yBAAyB,GAAG,eAAe,CAAC,eAAe,CAAC,yBAAyB,CAAC,CAAC,CAAA;AAKnG,qBACa,mBAAmB,CAAC,OAAO,SAAS,yBAAyB,GAAG,yBAAyB,CACpG,SAAQ,iBAAiB,CAAC,OAAO,CACjC,YAAW,iBAAiB;IAC5B,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAA4D;IAC5G,gBAAyB,mBAAmB,EAAE,MAAM,CAAkC;IAEtF,OAAO,CAAC,gBAAgB,CAAC,CAAiB;IAE1C,IAAI,QAAQ,WAEX;IAED,IAAa,OAAO,aAEnB;IAED,OAAO,KAAK,eAAe,GAE1B;mBAEoB,eAAe;mBAQf,uBAAuB;cAKzB,UAAU,IAAI,eAAe,CAAC,eAAe,CAAC;cAI9C,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAI9B,aAAa,IAAI,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC;cAIxD,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,eAAe,CAAC,IAAI,CAAC;cAI9C,UAAU,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;cAItD,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;cAI9D,YAAY;YAevB,eAAe;CAG9B"}
@@ -1,36 +0,0 @@
1
- import { Hash } from '@xylabs/hex';
2
- import { PromisableArray } from '@xylabs/promise';
3
- import { AbstractArchivist } from '@xyo-network/archivist-abstract';
4
- import { ArchivistConfig, ArchivistInstance, ArchivistParams } from '@xyo-network/archivist-model';
5
- import { BoundWitness } from '@xyo-network/boundwitness-model';
6
- import { AnyConfigSchema } from '@xyo-network/module-model';
7
- import { Payload, PayloadWithMeta, Schema, WithMeta } from '@xyo-network/payload-model';
8
- export interface FileSystemArchivistData {
9
- payloads: Payload[];
10
- }
11
- export type FilesystemArchivistConfigSchema = 'network.xyo.archivist.filesystem.config';
12
- export declare const FilesystemArchivistConfigSchema: FilesystemArchivistConfigSchema;
13
- export type FilesystemArchivistConfig = ArchivistConfig<{
14
- filePath?: string;
15
- schema: FilesystemArchivistConfigSchema;
16
- }>;
17
- export type FilesystemArchivistParams = ArchivistParams<AnyConfigSchema<FilesystemArchivistConfig>>;
18
- export declare class FilesystemArchivist<TParams extends FilesystemArchivistParams = FilesystemArchivistParams> extends AbstractArchivist<TParams> implements ArchivistInstance {
19
- static readonly configSchemas: Schema[];
20
- static readonly defaultConfigSchema: Schema;
21
- private _memoryArchivist?;
22
- get filePath(): string;
23
- get queries(): string[];
24
- private get memoryArchivist();
25
- private static dataFromRawJson;
26
- private static payloadsFromRawPayloads;
27
- protected allHandler(): PromisableArray<PayloadWithMeta>;
28
- protected clearHandler(): void | Promise<void>;
29
- protected commitHandler(): Promise<WithMeta<BoundWitness>[]>;
30
- protected deleteHandler(hashes: Hash[]): PromisableArray<Hash>;
31
- protected getHandler(hashes: Hash[]): Promise<PayloadWithMeta[]>;
32
- protected insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]>;
33
- protected startHandler(): Promise<boolean>;
34
- private rawJsonFromFile;
35
- }
36
- //# sourceMappingURL=FilesystemArchivist.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"FilesystemArchivist.d.ts","sourceRoot":"","sources":["../../src/FilesystemArchivist.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAClC,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAEjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAEnE,OAAO,EAGL,eAAe,EACf,iBAAiB,EACjB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAC9D,OAAO,EAAE,eAAe,EAAmB,MAAM,2BAA2B,CAAA;AAE5E,OAAO,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEvF,MAAM,WAAW,uBAAuB;IACtC,QAAQ,EAAE,OAAO,EAAE,CAAA;CACpB;AAED,MAAM,MAAM,+BAA+B,GAAG,yCAAyC,CAAA;AACvF,eAAO,MAAM,+BAA+B,EAAE,+BAA2E,CAAA;AAEzH,MAAM,MAAM,yBAAyB,GAAG,eAAe,CAAC;IACtD,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,MAAM,EAAE,+BAA+B,CAAA;CACxC,CAAC,CAAA;AAEF,MAAM,MAAM,yBAAyB,GAAG,eAAe,CAAC,eAAe,CAAC,yBAAyB,CAAC,CAAC,CAAA;AAKnG,qBACa,mBAAmB,CAAC,OAAO,SAAS,yBAAyB,GAAG,yBAAyB,CACpG,SAAQ,iBAAiB,CAAC,OAAO,CACjC,YAAW,iBAAiB;IAC5B,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAA4D;IAC5G,gBAAyB,mBAAmB,EAAE,MAAM,CAAkC;IAEtF,OAAO,CAAC,gBAAgB,CAAC,CAAiB;IAE1C,IAAI,QAAQ,WAEX;IAED,IAAa,OAAO,aAEnB;IAED,OAAO,KAAK,eAAe,GAE1B;mBAEoB,eAAe;mBAQf,uBAAuB;cAKzB,UAAU,IAAI,eAAe,CAAC,eAAe,CAAC;cAI9C,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAI9B,aAAa,IAAI,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC;cAIxD,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,eAAe,CAAC,IAAI,CAAC;cAI9C,UAAU,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;cAItD,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;cAI9D,YAAY;YAevB,eAAe;CAG9B"}
@@ -1,134 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __getProtoOf = Object.getPrototypeOf;
6
- var __hasOwnProp = Object.prototype.hasOwnProperty;
7
- var __reflectGet = Reflect.get;
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 __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
23
- var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
24
- var __superGet = (cls, obj, key) => __reflectGet(__getProtoOf(cls), key, obj);
25
-
26
- // src/index.ts
27
- var src_exports = {};
28
- __export(src_exports, {
29
- FilesystemArchivist: () => FilesystemArchivist,
30
- FilesystemArchivistConfigSchema: () => FilesystemArchivistConfigSchema
31
- });
32
- module.exports = __toCommonJS(src_exports);
33
-
34
- // src/FilesystemArchivist.ts
35
- var import_promises = require("fs/promises");
36
- var import_assert = require("@xylabs/assert");
37
- var import_error = require("@xylabs/error");
38
- var import_account = require("@xyo-network/account");
39
- var import_archivist_abstract = require("@xyo-network/archivist-abstract");
40
- var import_archivist_memory = require("@xyo-network/archivist-memory");
41
- var import_archivist_model = require("@xyo-network/archivist-model");
42
- var import_module_model = require("@xyo-network/module-model");
43
- var import_payload_builder = require("@xyo-network/payload-builder");
44
- function _ts_decorate(decorators, target, key, desc) {
45
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
46
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
47
- 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;
48
- return c > 3 && r && Object.defineProperty(target, key, r), r;
49
- }
50
- __name(_ts_decorate, "_ts_decorate");
51
- var FilesystemArchivistConfigSchema = "network.xyo.archivist.filesystem.config";
52
- var _FilesystemArchivist = class _FilesystemArchivist extends import_archivist_abstract.AbstractArchivist {
53
- _memoryArchivist;
54
- get filePath() {
55
- var _a;
56
- return ((_a = this.config) == null ? void 0 : _a.filePath) ?? "archivist.xyo.json";
57
- }
58
- get queries() {
59
- return [
60
- import_archivist_model.ArchivistAllQuerySchema,
61
- import_archivist_model.ArchivistCommitQuerySchema,
62
- ...super.queries
63
- ];
64
- }
65
- get memoryArchivist() {
66
- return (0, import_assert.assertEx)(this._memoryArchivist);
67
- }
68
- static async dataFromRawJson(rawJson) {
69
- const data = JSON.parse(rawJson);
70
- (0, import_assert.assertEx)(typeof data === "object", () => "Archivist Data must be object");
71
- (0, import_assert.assertEx)(Array.isArray(data.payloads), () => 'Archivist Data "payloads" field must be array of payloads');
72
- data.payloads = await this.payloadsFromRawPayloads(data.payloads);
73
- return data;
74
- }
75
- static async payloadsFromRawPayloads(rawPayloads) {
76
- return await Promise.all(rawPayloads.map(async (payload) => await import_payload_builder.PayloadBuilder.build(payload)));
77
- }
78
- allHandler() {
79
- return this.memoryArchivist.all();
80
- }
81
- clearHandler() {
82
- return this.memoryArchivist.clear();
83
- }
84
- async commitHandler() {
85
- return await this.memoryArchivist.commit();
86
- }
87
- deleteHandler(hashes) {
88
- return this.memoryArchivist.delete(hashes);
89
- }
90
- async getHandler(hashes) {
91
- return await this.memoryArchivist.get(hashes);
92
- }
93
- async insertHandler(payloads) {
94
- return await this.memoryArchivist.insert(payloads);
95
- }
96
- async startHandler() {
97
- await super.startHandler();
98
- this._memoryArchivist = await import_archivist_memory.MemoryArchivist.create({
99
- account: await import_account.HDWallet.random()
100
- });
101
- try {
102
- const data = await _FilesystemArchivist.dataFromRawJson(await this.rawJsonFromFile());
103
- await this._memoryArchivist.insert(await Promise.all(data.payloads.map((payload) => import_payload_builder.PayloadBuilder.build(payload))));
104
- } catch (ex) {
105
- (0, import_error.handleError)(ex, (error) => {
106
- var _a;
107
- (_a = this.logger) == null ? void 0 : _a.error(error.message);
108
- });
109
- return false;
110
- }
111
- return true;
112
- }
113
- async rawJsonFromFile() {
114
- return await (0, import_promises.readFile)(this.filePath, {
115
- encoding: "utf8"
116
- });
117
- }
118
- };
119
- __name(_FilesystemArchivist, "FilesystemArchivist");
120
- __publicField(_FilesystemArchivist, "configSchemas", [
121
- ...__superGet(_FilesystemArchivist, _FilesystemArchivist, "configSchemas"),
122
- FilesystemArchivistConfigSchema
123
- ]);
124
- __publicField(_FilesystemArchivist, "defaultConfigSchema", FilesystemArchivistConfigSchema);
125
- var FilesystemArchivist = _FilesystemArchivist;
126
- FilesystemArchivist = _ts_decorate([
127
- (0, import_module_model.creatableModule)()
128
- ], FilesystemArchivist);
129
- // Annotate the CommonJS export names for ESM import in node:
130
- 0 && (module.exports = {
131
- FilesystemArchivist,
132
- FilesystemArchivistConfigSchema
133
- });
134
- //# sourceMappingURL=index.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/FilesystemArchivist.ts"],"sourcesContent":["export * from './FilesystemArchivist.ts'\n","import { readFile } from 'node:fs/promises'\n\nimport { assertEx } from '@xylabs/assert'\nimport { handleError } from '@xylabs/error'\nimport { Hash } from '@xylabs/hex'\nimport { PromisableArray } from '@xylabs/promise'\nimport { HDWallet } from '@xyo-network/account'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport { MemoryArchivist } from '@xyo-network/archivist-memory'\nimport {\n ArchivistAllQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistInstance,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, PayloadWithMeta, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport interface FileSystemArchivistData {\n payloads: Payload[]\n}\n\nexport type FilesystemArchivistConfigSchema = 'network.xyo.archivist.filesystem.config'\nexport const FilesystemArchivistConfigSchema: FilesystemArchivistConfigSchema = 'network.xyo.archivist.filesystem.config'\n\nexport type FilesystemArchivistConfig = ArchivistConfig<{\n filePath?: string\n schema: FilesystemArchivistConfigSchema\n}>\n\nexport type FilesystemArchivistParams = ArchivistParams<AnyConfigSchema<FilesystemArchivistConfig>>\n\n/** @description Currently only a read-only archivist that loads payloads from filesystem\n * but allows for future expansion to read/write\n */\n@creatableModule()\nexport class FilesystemArchivist<TParams extends FilesystemArchivistParams = FilesystemArchivistParams>\n extends AbstractArchivist<TParams>\n implements ArchivistInstance {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, FilesystemArchivistConfigSchema]\n static override readonly defaultConfigSchema: Schema = FilesystemArchivistConfigSchema\n\n private _memoryArchivist?: MemoryArchivist\n\n get filePath() {\n return this.config?.filePath ?? 'archivist.xyo.json'\n }\n\n override get queries() {\n return [ArchivistAllQuerySchema, ArchivistCommitQuerySchema, ...super.queries]\n }\n\n private get memoryArchivist() {\n return assertEx(this._memoryArchivist)\n }\n\n private static async dataFromRawJson(rawJson: string) {\n const data: FileSystemArchivistData = JSON.parse(rawJson)\n assertEx(typeof data === 'object', () => 'Archivist Data must be object')\n assertEx(Array.isArray(data.payloads), () => 'Archivist Data \"payloads\" field must be array of payloads')\n data.payloads = await this.payloadsFromRawPayloads(data.payloads)\n return data\n }\n\n private static async payloadsFromRawPayloads(rawPayloads: Payload[]) {\n // validation should be done in here. I don't believe parse does much validation yet.\n return await Promise.all(rawPayloads.map(async payload => await PayloadBuilder.build(payload)))\n }\n\n protected override allHandler(): PromisableArray<PayloadWithMeta> {\n return this.memoryArchivist.all()\n }\n\n protected override clearHandler(): void | Promise<void> {\n return this.memoryArchivist.clear()\n }\n\n protected override async commitHandler(): Promise<WithMeta<BoundWitness>[]> {\n return await this.memoryArchivist.commit()\n }\n\n protected override deleteHandler(hashes: Hash[]): PromisableArray<Hash> {\n return this.memoryArchivist.delete(hashes)\n }\n\n protected override async getHandler(hashes: Hash[]): Promise<PayloadWithMeta[]> {\n return await this.memoryArchivist.get(hashes)\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<PayloadWithMeta[]> {\n return await this.memoryArchivist.insert(payloads)\n }\n\n protected override async startHandler() {\n await super.startHandler()\n this._memoryArchivist = await MemoryArchivist.create({ account: await HDWallet.random() })\n try {\n const data = await FilesystemArchivist.dataFromRawJson(await this.rawJsonFromFile())\n await this._memoryArchivist.insert(await Promise.all(data.payloads.map(payload => PayloadBuilder.build(payload))))\n } catch (ex) {\n handleError(ex, (error) => {\n this.logger?.error(error.message)\n })\n return false\n }\n return true\n }\n\n private async rawJsonFromFile() {\n return await readFile(this.filePath, { encoding: 'utf8' })\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;;ACAA,sBAAyB;AAEzB,oBAAyB;AACzB,mBAA4B;AAG5B,qBAAyB;AACzB,gCAAkC;AAClC,8BAAgC;AAChC,6BAMO;AAEP,0BAAiD;AACjD,6BAA+B;;;;;;;;AAQxB,IAAMA,kCAAmE;AAazE,IAAMC,uBAAN,MAAMA,6BACHC,4CAAAA;EAKAC;EAER,IAAIC,WAAW;;AACb,aAAO,UAAKC,WAAL,mBAAaD,aAAY;EAClC;EAEA,IAAaE,UAAU;AACrB,WAAO;MAACC;MAAyBC;SAA+B,MAAMF;;EACxE;EAEA,IAAYG,kBAAkB;AAC5B,eAAOC,wBAAS,KAAKP,gBAAgB;EACvC;EAEA,aAAqBQ,gBAAgBC,SAAiB;AACpD,UAAMC,OAAgCC,KAAKC,MAAMH,OAAAA;AACjDF,gCAAS,OAAOG,SAAS,UAAU,MAAM,+BAAA;AACzCH,gCAASM,MAAMC,QAAQJ,KAAKK,QAAQ,GAAG,MAAM,2DAAA;AAC7CL,SAAKK,WAAW,MAAM,KAAKC,wBAAwBN,KAAKK,QAAQ;AAChE,WAAOL;EACT;EAEA,aAAqBM,wBAAwBC,aAAwB;AAEnE,WAAO,MAAMC,QAAQC,IAAIF,YAAYG,IAAI,OAAMC,YAAW,MAAMC,sCAAeC,MAAMF,OAAAA,CAAAA,CAAAA;EACvF;EAEmBG,aAA+C;AAChE,WAAO,KAAKlB,gBAAgBa,IAAG;EACjC;EAEmBM,eAAqC;AACtD,WAAO,KAAKnB,gBAAgBoB,MAAK;EACnC;EAEA,MAAyBC,gBAAmD;AAC1E,WAAO,MAAM,KAAKrB,gBAAgBsB,OAAM;EAC1C;EAEmBC,cAAcC,QAAuC;AACtE,WAAO,KAAKxB,gBAAgByB,OAAOD,MAAAA;EACrC;EAEA,MAAyBE,WAAWF,QAA4C;AAC9E,WAAO,MAAM,KAAKxB,gBAAgB2B,IAAIH,MAAAA;EACxC;EAEA,MAAyBI,cAAcnB,UAAiD;AACtF,WAAO,MAAM,KAAKT,gBAAgB6B,OAAOpB,QAAAA;EAC3C;EAEA,MAAyBqB,eAAe;AACtC,UAAM,MAAMA,aAAAA;AACZ,SAAKpC,mBAAmB,MAAMqC,wCAAgBC,OAAO;MAAEC,SAAS,MAAMC,wBAASC,OAAM;IAAG,CAAA;AACxF,QAAI;AACF,YAAM/B,OAAO,MAAMZ,qBAAoBU,gBAAgB,MAAM,KAAKkC,gBAAe,CAAA;AACjF,YAAM,KAAK1C,iBAAiBmC,OAAO,MAAMjB,QAAQC,IAAIT,KAAKK,SAASK,IAAIC,CAAAA,YAAWC,sCAAeC,MAAMF,OAAAA,CAAAA,CAAAA,CAAAA;IACzG,SAASsB,IAAI;AACXC,oCAAYD,IAAI,CAACE,UAAAA;;AACf,mBAAKC,WAAL,mBAAaD,MAAMA,MAAME;MAC3B,CAAA;AACA,aAAO;IACT;AACA,WAAO;EACT;EAEA,MAAcL,kBAAkB;AAC9B,WAAO,UAAMM,0BAAS,KAAK/C,UAAU;MAAEgD,UAAU;IAAO,CAAA;EAC1D;AACF;AA1EUlD;AAER,cAHWD,sBAGcoD,iBAA0B;KAAI,uDAAMA;EAAerD;;AAC5E,cAJWC,sBAIcqD,uBAA8BtD;AAJlD,IAAMC,sBAAN;;;;","names":["FilesystemArchivistConfigSchema","FilesystemArchivist","AbstractArchivist","_memoryArchivist","filePath","config","queries","ArchivistAllQuerySchema","ArchivistCommitQuerySchema","memoryArchivist","assertEx","dataFromRawJson","rawJson","data","JSON","parse","Array","isArray","payloads","payloadsFromRawPayloads","rawPayloads","Promise","all","map","payload","PayloadBuilder","build","allHandler","clearHandler","clear","commitHandler","commit","deleteHandler","hashes","delete","getHandler","get","insertHandler","insert","startHandler","MemoryArchivist","create","account","HDWallet","random","rawJsonFromFile","ex","handleError","error","logger","message","readFile","encoding","configSchemas","defaultConfigSchema"]}
@@ -1,2 +0,0 @@
1
- export * from './FilesystemArchivist.ts';
2
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAA"}
@@ -1,2 +0,0 @@
1
- export * from './FilesystemArchivist.ts';
2
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAA"}