@xyo-network/filesystem-archivist 2.103.9 → 2.104.1

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.
@@ -38,12 +38,8 @@ var import_module_model = require("@xyo-network/module-model");
38
38
  var import_payload_builder = require("@xyo-network/payload-builder");
39
39
  function _ts_decorate(decorators, target, key, desc) {
40
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")
42
- r = Reflect.decorate(decorators, target, key, desc);
43
- else
44
- for (var i = decorators.length - 1; i >= 0; i--)
45
- if (d = decorators[i])
46
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
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;
47
43
  return c > 3 && r && Object.defineProperty(target, key, r), r;
48
44
  }
49
45
  __name(_ts_decorate, "_ts_decorate");
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/FilesystemArchivist.ts"],"sourcesContent":["export * from './FilesystemArchivist'\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{\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;;;EAGR,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,OAAOC,YAAY,MAAMC,sCAAeC,MAAMF,OAAAA,CAAAA,CAAAA;EACzF;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,IAAI,CAACC,YAAYC,sCAAeC,MAAMF,OAAAA,CAAAA,CAAAA,CAAAA;IAC3G,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;AA5EarD,sBAAAA,aAAAA;MADZsD,qCAAAA;GACYtD,mBAAAA;","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","creatableModule"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/FilesystemArchivist.ts"],"sourcesContent":["export * from './FilesystemArchivist'\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{\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;;;EAGR,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,OAAOC,YAAY,MAAMC,sCAAeC,MAAMF,OAAAA,CAAAA,CAAAA;EACzF;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,IAAI,CAACC,YAAYC,sCAAeC,MAAMF,OAAAA,CAAAA,CAAAA,CAAAA;IAC3G,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;AA5EarD,sBAAAA,aAAAA;MADZsD,qCAAAA;GACYtD,mBAAAA;","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","creatableModule"]}
@@ -13,12 +13,8 @@ import { creatableModule } from "@xyo-network/module-model";
13
13
  import { PayloadBuilder } from "@xyo-network/payload-builder";
14
14
  function _ts_decorate(decorators, target, key, desc) {
15
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")
17
- r = Reflect.decorate(decorators, target, key, desc);
18
- else
19
- for (var i = decorators.length - 1; i >= 0; i--)
20
- if (d = decorators[i])
21
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
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;
22
18
  return c > 3 && r && Object.defineProperty(target, key, r), r;
23
19
  }
24
20
  __name(_ts_decorate, "_ts_decorate");
@@ -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{\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;;;EAGR,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,OAAOC,YAAY,MAAMC,eAAeC,MAAMF,OAAAA,CAAAA,CAAAA;EACzF;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,IAAI,CAACC,YAAYC,eAAeC,MAAMF,OAAAA,CAAAA,CAAAA,CAAAA;IAC3G,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;AA5EarD,sBAAAA,aAAAA;EADZsD,gBAAAA;GACYtD,mBAAAA;","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","creatableModule"]}
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{\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;;;EAGR,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,OAAOC,YAAY,MAAMC,eAAeC,MAAMF,OAAAA,CAAAA,CAAAA;EACzF;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,IAAI,CAACC,YAAYC,eAAeC,MAAMF,OAAAA,CAAAA,CAAAA,CAAAA;IAC3G,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;AA5EarD,sBAAAA,aAAAA;EADZsD,gBAAAA;GACYtD,mBAAAA;","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","creatableModule"]}
@@ -20,10 +20,7 @@ var __copyProps = (to, from, except, desc) => {
20
20
  return to;
21
21
  };
22
22
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
23
- var __publicField = (obj, key, value) => {
24
- __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
25
- return value;
26
- };
23
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
27
24
  var __superGet = (cls, obj, key) => __reflectGet(__getProtoOf(cls), key, obj);
28
25
 
29
26
  // src/index.ts
@@ -46,12 +43,8 @@ var import_module_model = require("@xyo-network/module-model");
46
43
  var import_payload_builder = require("@xyo-network/payload-builder");
47
44
  function _ts_decorate(decorators, target, key, desc) {
48
45
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
49
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
50
- r = Reflect.decorate(decorators, target, key, desc);
51
- else
52
- for (var i = decorators.length - 1; i >= 0; i--)
53
- if (d = decorators[i])
54
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
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;
55
48
  return c > 3 && r && Object.defineProperty(target, key, r), r;
56
49
  }
57
50
  __name(_ts_decorate, "_ts_decorate");
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/FilesystemArchivist.ts"],"sourcesContent":["export * from './FilesystemArchivist'\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{\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;EAMAC;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,OAAOC,YAAY,MAAMC,sCAAeC,MAAMF,OAAAA,CAAAA,CAAAA;EACzF;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,IAAI,CAACC,YAAYC,sCAAeC,MAAMF,OAAAA,CAAAA,CAAAA,CAAAA;IAC3G,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;AA3EUlD;AAGR,cAJWD,sBAIcoD,iBAA0B;KAAI,uDAAMA;EAAerD;;AAC5E,cALWC,sBAKcqD,uBAA8BtD;AALlD,IAAMC,sBAAN;AAAMA,sBAAAA,aAAAA;MADZsD,qCAAAA;GACYtD,mBAAAA;","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","creatableModule"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/FilesystemArchivist.ts"],"sourcesContent":["export * from './FilesystemArchivist'\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{\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;EAMAC;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,OAAOC,YAAY,MAAMC,sCAAeC,MAAMF,OAAAA,CAAAA,CAAAA;EACzF;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,IAAI,CAACC,YAAYC,sCAAeC,MAAMF,OAAAA,CAAAA,CAAAA,CAAAA;IAC3G,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;AA3EUlD;AAGR,cAJWD,sBAIcoD,iBAA0B;KAAI,uDAAMA;EAAerD;;AAC5E,cALWC,sBAKcqD,uBAA8BtD;AALlD,IAAMC,sBAAN;AAAMA,sBAAAA,aAAAA;MADZsD,qCAAAA;GACYtD,mBAAAA;","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","creatableModule"]}
@@ -3,10 +3,7 @@ var __getProtoOf = Object.getPrototypeOf;
3
3
  var __reflectGet = Reflect.get;
4
4
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
5
5
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
6
- var __publicField = (obj, key, value) => {
7
- __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
8
- return value;
9
- };
6
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
10
7
  var __superGet = (cls, obj, key) => __reflectGet(__getProtoOf(cls), key, obj);
11
8
 
12
9
  // src/FilesystemArchivist.ts
@@ -21,12 +18,8 @@ import { creatableModule } from "@xyo-network/module-model";
21
18
  import { PayloadBuilder } from "@xyo-network/payload-builder";
22
19
  function _ts_decorate(decorators, target, key, desc) {
23
20
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
24
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
25
- r = Reflect.decorate(decorators, target, key, desc);
26
- else
27
- for (var i = decorators.length - 1; i >= 0; i--)
28
- if (d = decorators[i])
29
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
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;
30
23
  return c > 3 && r && Object.defineProperty(target, key, r), r;
31
24
  }
32
25
  __name(_ts_decorate, "_ts_decorate");
@@ -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{\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;EAMAC;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,OAAOC,YAAY,MAAMC,eAAeC,MAAMF,OAAAA,CAAAA,CAAAA;EACzF;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,IAAI,CAACC,YAAYC,eAAeC,MAAMF,OAAAA,CAAAA,CAAAA,CAAAA;IAC3G,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;AA3EUlD;AAGR,cAJWD,sBAIcoD,iBAA0B;KAAI,uDAAMA;EAAerD;;AAC5E,cALWC,sBAKcqD,uBAA8BtD;AALlD,IAAMC,sBAAN;AAAMA,sBAAAA,aAAAA;EADZsD,gBAAAA;GACYtD,mBAAAA;","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","creatableModule"]}
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{\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;EAMAC;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,OAAOC,YAAY,MAAMC,eAAeC,MAAMF,OAAAA,CAAAA,CAAAA;EACzF;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,IAAI,CAACC,YAAYC,eAAeC,MAAMF,OAAAA,CAAAA,CAAAA,CAAAA;IAC3G,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;AA3EUlD;AAGR,cAJWD,sBAIcoD,iBAA0B;KAAI,uDAAMA;EAAerD;;AAC5E,cALWC,sBAKcqD,uBAA8BtD;AALlD,IAAMC,sBAAN;AAAMA,sBAAAA,aAAAA;EADZsD,gBAAAA;GACYtD,mBAAAA;","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","creatableModule"]}
package/package.json CHANGED
@@ -10,22 +10,22 @@
10
10
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/issues"
11
11
  },
12
12
  "dependencies": {
13
- "@xylabs/assert": "^3.5.0",
14
- "@xylabs/error": "^3.5.0",
15
- "@xylabs/hex": "^3.5.0",
16
- "@xylabs/promise": "^3.5.0",
17
- "@xyo-network/account": "~2.103.9",
18
- "@xyo-network/archivist-abstract": "~2.103.9",
19
- "@xyo-network/archivist-memory": "~2.103.9",
20
- "@xyo-network/archivist-model": "~2.103.9",
21
- "@xyo-network/boundwitness-model": "~2.103.9",
22
- "@xyo-network/module-model": "~2.103.9",
23
- "@xyo-network/payload-builder": "~2.103.9",
24
- "@xyo-network/payload-model": "~2.103.9"
13
+ "@xylabs/assert": "^3.5.1",
14
+ "@xylabs/error": "^3.5.1",
15
+ "@xylabs/hex": "^3.5.1",
16
+ "@xylabs/promise": "^3.5.1",
17
+ "@xyo-network/account": "~2.104.1",
18
+ "@xyo-network/archivist-abstract": "~2.104.1",
19
+ "@xyo-network/archivist-memory": "~2.104.1",
20
+ "@xyo-network/archivist-model": "~2.104.1",
21
+ "@xyo-network/boundwitness-model": "~2.104.1",
22
+ "@xyo-network/module-model": "~2.104.1",
23
+ "@xyo-network/payload-builder": "~2.104.1",
24
+ "@xyo-network/payload-model": "~2.104.1"
25
25
  },
26
26
  "devDependencies": {
27
- "@xylabs/ts-scripts-yarn3": "^3.10.4",
28
- "@xylabs/tsconfig": "^3.10.4",
27
+ "@xylabs/ts-scripts-yarn3": "^3.11.2",
28
+ "@xylabs/tsconfig": "^3.11.2",
29
29
  "typescript": "^5.4.5"
30
30
  },
31
31
  "description": "Primary SDK for using XYO Protocol 2.0",
@@ -57,6 +57,6 @@
57
57
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
58
58
  },
59
59
  "sideEffects": false,
60
- "version": "2.103.9",
60
+ "version": "2.104.1",
61
61
  "type": "module"
62
62
  }