@xyo-network/diviner-address-history 2.90.15 → 2.90.17

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.
@@ -51,7 +51,7 @@ var AddressHistoryDiviner = class extends import_diviner_abstract.AbstractDivine
51
51
  const allBoundWitnesses = await this.allBoundWitnesses();
52
52
  const bwRecords = await import_payload_builder.PayloadBuilder.toDataHashMap(allBoundWitnesses);
53
53
  const chains = Object.values(this.buildAddressChains(this.queryAddress, bwRecords));
54
- return await Promise.all(chains.map(async (chain) => (0, import_assert.assertEx)(await import_payload_wrapper.PayloadWrapper.unwrap(chain.shift()))));
54
+ return chains.map((chain) => (0, import_assert.assertEx)(import_payload_wrapper.PayloadWrapper.unwrap(chain.shift())));
55
55
  }
56
56
  async allBoundWitnesses() {
57
57
  const archivists = (await Promise.all(await this.resolve({
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/Diviner.ts"],"sourcesContent":["export * from './Diviner'\nexport * from '@xyo-network/diviner-address-history-model'\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { ArchivistGetQuerySchema, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { AddressHistoryDivinerConfigSchema, AddressHistoryDivinerParams } from '@xyo-network/diviner-address-history-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\n// This diviner returns the most recent boundwitness signed by the address that can be found\n// if multiple broken chains are found, all the heads are returned\n\nexport class AddressHistoryDiviner<TParams extends AddressHistoryDivinerParams = AddressHistoryDivinerParams> extends AbstractDiviner<TParams> {\n static override configSchemas = [AddressHistoryDivinerConfigSchema]\n\n get queryAddress() {\n return assertEx(this.config.address, 'Missing address')\n }\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n assertEx(!payloads?.length, 'MemoryAddressHistoryDiviner.divine does not allow payloads to be sent')\n\n const allBoundWitnesses = await this.allBoundWitnesses()\n const bwRecords = await PayloadBuilder.toDataHashMap(allBoundWitnesses)\n const chains = Object.values(this.buildAddressChains(this.queryAddress, bwRecords))\n\n // Return the heads of each chain (get the last bw on each chain)\n return await Promise.all(chains.map(async (chain) => assertEx(await PayloadWrapper.unwrap(chain.shift()))))\n }\n\n private async allBoundWitnesses() {\n const archivists =\n (await Promise.all(await this.resolve({ query: [[ArchivistGetQuerySchema]] }))).map((module) =>\n asArchivistInstance(module, `Failed to cast module to Archivist [${module.config.name}]`),\n ) ?? []\n assertEx(archivists.length > 0, 'Did not find any archivists')\n return (\n await Promise.all(\n archivists.map(async (archivist) => {\n const all = await archivist.all?.()\n return all?.filter(isBoundWitnessWithMeta)\n }),\n )\n )\n .flat()\n .filter(exists)\n }\n\n private buildAddressChains(address: string, bwRecords: Record<string, BoundWitness>): Record<string, BoundWitness[]> {\n // eslint-disable-next-line unicorn/no-array-reduce\n const arrayedResult = Object.entries(bwRecords).reduce<Record<string, BoundWitness[]>>((prev, [key, value]) => {\n prev[key] = [value]\n return prev\n }, {})\n // eslint-disable-next-line unicorn/no-array-reduce\n return Object.entries(bwRecords).reduce<Record<string, BoundWitness[]>>((prev, [key, value]) => {\n //check if key is still there (may have been deleted as prevHash)\n if (prev[key]) {\n const previousHash = BoundWitnessBuilder.previousHash(value, address)\n if (\n previousHash && //if we have the previousHash, move this bw to its chain\n prev[previousHash]\n ) {\n prev[key].push(...prev[previousHash])\n delete prev[previousHash]\n }\n }\n return prev\n }, arrayedResult)\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;AACzB,oBAAuB;AACvB,6BAA6D;AAC7D,kCAAoC;AACpC,gCAAqD;AACrD,8BAAgC;AAChC,2CAA+E;AAC/E,6BAA+B;AAE/B,6BAA+B;AAKxB,IAAMA,wBAAN,cAA+GC,wCAAAA;EAdtH,OAcsHA;;;EACpH,OAAgBC,gBAAgB;IAACC;;EAEjC,IAAIC,eAAe;AACjB,eAAOC,wBAAS,KAAKC,OAAOC,SAAS,iBAAA;EACvC;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,gCAAS,CAACI,UAAUC,QAAQ,uEAAA;AAE5B,UAAMC,oBAAoB,MAAM,KAAKA,kBAAiB;AACtD,UAAMC,YAAY,MAAMC,sCAAeC,cAAcH,iBAAAA;AACrD,UAAMI,SAASC,OAAOC,OAAO,KAAKC,mBAAmB,KAAKd,cAAcQ,SAAAA,CAAAA;AAGxE,WAAO,MAAMO,QAAQC,IAAIL,OAAOM,IAAI,OAAOC,cAAUjB,wBAAS,MAAMkB,sCAAeC,OAAOF,MAAMG,MAAK,CAAA,CAAA,CAAA,CAAA;EACvG;EAEA,MAAcd,oBAAoB;AAChC,UAAMe,cACH,MAAMP,QAAQC,IAAI,MAAM,KAAKO,QAAQ;MAAEC,OAAO;QAAC;UAACC;;;IAA0B,CAAA,CAAA,GAAKR,IAAI,CAACS,gBACnFC,4CAAoBD,SAAQ,uCAAuCA,QAAOxB,OAAO0B,IAAI,GAAG,CAAA,KACrF,CAAA;AACP3B,gCAASqB,WAAWhB,SAAS,GAAG,6BAAA;AAChC,YACE,MAAMS,QAAQC,IACZM,WAAWL,IAAI,OAAOY,cAAAA;AACpB,YAAMb,MAAM,MAAMa,UAAUb,MAAG;AAC/B,aAAOA,KAAKc,OAAOC,gDAAAA;IACrB,CAAA,CAAA,GAGDC,KAAI,EACJF,OAAOG,oBAAAA;EACZ;EAEQnB,mBAAmBX,SAAiBK,WAAyE;AAEnH,UAAM0B,gBAAgBtB,OAAOuB,QAAQ3B,SAAAA,EAAW4B,OAAuC,CAACC,MAAM,CAACC,KAAKC,KAAAA,MAAM;AACxGF,WAAKC,GAAAA,IAAO;QAACC;;AACb,aAAOF;IACT,GAAG,CAAC,CAAA;AAEJ,WAAOzB,OAAOuB,QAAQ3B,SAAAA,EAAW4B,OAAuC,CAACC,MAAM,CAACC,KAAKC,KAAAA,MAAM;AAEzF,UAAIF,KAAKC,GAAAA,GAAM;AACb,cAAME,eAAeC,gDAAoBD,aAAaD,OAAOpC,OAAAA;AAC7D,YACEqC;QACAH,KAAKG,YAAAA,GACL;AACAH,eAAKC,GAAAA,EAAKI,KAAI,GAAIL,KAAKG,YAAAA,CAAa;AACpC,iBAAOH,KAAKG,YAAAA;QACd;MACF;AACA,aAAOH;IACT,GAAGH,aAAAA;EACL;AACF;;;ADvEA,wBAAc,uDADd;","names":["AddressHistoryDiviner","AbstractDiviner","configSchemas","AddressHistoryDivinerConfigSchema","queryAddress","assertEx","config","address","divineHandler","payloads","length","allBoundWitnesses","bwRecords","PayloadBuilder","toDataHashMap","chains","Object","values","buildAddressChains","Promise","all","map","chain","PayloadWrapper","unwrap","shift","archivists","resolve","query","ArchivistGetQuerySchema","module","asArchivistInstance","name","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/Diviner.ts"],"sourcesContent":["export * from './Diviner'\nexport * from '@xyo-network/diviner-address-history-model'\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { ArchivistGetQuerySchema, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { AddressHistoryDivinerConfigSchema, AddressHistoryDivinerParams } from '@xyo-network/diviner-address-history-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\n// This diviner returns the most recent boundwitness signed by the address that can be found\n// if multiple broken chains are found, all the heads are returned\n\nexport class AddressHistoryDiviner<TParams extends AddressHistoryDivinerParams = AddressHistoryDivinerParams> extends AbstractDiviner<TParams> {\n static override configSchemas = [AddressHistoryDivinerConfigSchema]\n\n get queryAddress() {\n return assertEx(this.config.address, 'Missing address')\n }\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n assertEx(!payloads?.length, 'MemoryAddressHistoryDiviner.divine does not allow payloads to be sent')\n\n const allBoundWitnesses = await this.allBoundWitnesses()\n const bwRecords = await PayloadBuilder.toDataHashMap(allBoundWitnesses)\n const chains = Object.values(this.buildAddressChains(this.queryAddress, bwRecords))\n\n // Return the heads of each chain (get the last bw on each chain)\n return chains.map((chain) => assertEx(PayloadWrapper.unwrap(chain.shift())))\n }\n\n private async allBoundWitnesses() {\n const archivists =\n (await Promise.all(await this.resolve({ query: [[ArchivistGetQuerySchema]] }))).map((module) =>\n asArchivistInstance(module, `Failed to cast module to Archivist [${module.config.name}]`),\n ) ?? []\n assertEx(archivists.length > 0, 'Did not find any archivists')\n return (\n await Promise.all(\n archivists.map(async (archivist) => {\n const all = await archivist.all?.()\n return all?.filter(isBoundWitnessWithMeta)\n }),\n )\n )\n .flat()\n .filter(exists)\n }\n\n private buildAddressChains(address: string, bwRecords: Record<string, BoundWitness>): Record<string, BoundWitness[]> {\n // eslint-disable-next-line unicorn/no-array-reduce\n const arrayedResult = Object.entries(bwRecords).reduce<Record<string, BoundWitness[]>>((prev, [key, value]) => {\n prev[key] = [value]\n return prev\n }, {})\n // eslint-disable-next-line unicorn/no-array-reduce\n return Object.entries(bwRecords).reduce<Record<string, BoundWitness[]>>((prev, [key, value]) => {\n //check if key is still there (may have been deleted as prevHash)\n if (prev[key]) {\n const previousHash = BoundWitnessBuilder.previousHash(value, address)\n if (\n previousHash && //if we have the previousHash, move this bw to its chain\n prev[previousHash]\n ) {\n prev[key].push(...prev[previousHash])\n delete prev[previousHash]\n }\n }\n return prev\n }, arrayedResult)\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;AACzB,oBAAuB;AACvB,6BAA6D;AAC7D,kCAAoC;AACpC,gCAAqD;AACrD,8BAAgC;AAChC,2CAA+E;AAC/E,6BAA+B;AAE/B,6BAA+B;AAKxB,IAAMA,wBAAN,cAA+GC,wCAAAA;EAdtH,OAcsHA;;;EACpH,OAAgBC,gBAAgB;IAACC;;EAEjC,IAAIC,eAAe;AACjB,eAAOC,wBAAS,KAAKC,OAAOC,SAAS,iBAAA;EACvC;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,gCAAS,CAACI,UAAUC,QAAQ,uEAAA;AAE5B,UAAMC,oBAAoB,MAAM,KAAKA,kBAAiB;AACtD,UAAMC,YAAY,MAAMC,sCAAeC,cAAcH,iBAAAA;AACrD,UAAMI,SAASC,OAAOC,OAAO,KAAKC,mBAAmB,KAAKd,cAAcQ,SAAAA,CAAAA;AAGxE,WAAOG,OAAOI,IAAI,CAACC,cAAUf,wBAASgB,sCAAeC,OAAOF,MAAMG,MAAK,CAAA,CAAA,CAAA;EACzE;EAEA,MAAcZ,oBAAoB;AAChC,UAAMa,cACH,MAAMC,QAAQC,IAAI,MAAM,KAAKC,QAAQ;MAAEC,OAAO;QAAC;UAACC;;;IAA0B,CAAA,CAAA,GAAKV,IAAI,CAACW,gBACnFC,4CAAoBD,SAAQ,uCAAuCA,QAAOxB,OAAO0B,IAAI,GAAG,CAAA,KACrF,CAAA;AACP3B,gCAASmB,WAAWd,SAAS,GAAG,6BAAA;AAChC,YACE,MAAMe,QAAQC,IACZF,WAAWL,IAAI,OAAOc,cAAAA;AACpB,YAAMP,MAAM,MAAMO,UAAUP,MAAG;AAC/B,aAAOA,KAAKQ,OAAOC,gDAAAA;IACrB,CAAA,CAAA,GAGDC,KAAI,EACJF,OAAOG,oBAAAA;EACZ;EAEQnB,mBAAmBX,SAAiBK,WAAyE;AAEnH,UAAM0B,gBAAgBtB,OAAOuB,QAAQ3B,SAAAA,EAAW4B,OAAuC,CAACC,MAAM,CAACC,KAAKC,KAAAA,MAAM;AACxGF,WAAKC,GAAAA,IAAO;QAACC;;AACb,aAAOF;IACT,GAAG,CAAC,CAAA;AAEJ,WAAOzB,OAAOuB,QAAQ3B,SAAAA,EAAW4B,OAAuC,CAACC,MAAM,CAACC,KAAKC,KAAAA,MAAM;AAEzF,UAAIF,KAAKC,GAAAA,GAAM;AACb,cAAME,eAAeC,gDAAoBD,aAAaD,OAAOpC,OAAAA;AAC7D,YACEqC;QACAH,KAAKG,YAAAA,GACL;AACAH,eAAKC,GAAAA,EAAKI,KAAI,GAAIL,KAAKG,YAAAA,CAAa;AACpC,iBAAOH,KAAKG,YAAAA;QACd;MACF;AACA,aAAOH;IACT,GAAGH,aAAAA;EACL;AACF;;;ADvEA,wBAAc,uDADd;","names":["AddressHistoryDiviner","AbstractDiviner","configSchemas","AddressHistoryDivinerConfigSchema","queryAddress","assertEx","config","address","divineHandler","payloads","length","allBoundWitnesses","bwRecords","PayloadBuilder","toDataHashMap","chains","Object","values","buildAddressChains","map","chain","PayloadWrapper","unwrap","shift","archivists","Promise","all","resolve","query","ArchivistGetQuerySchema","module","asArchivistInstance","name","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push"]}
@@ -26,7 +26,7 @@ var AddressHistoryDiviner = class extends AbstractDiviner {
26
26
  const allBoundWitnesses = await this.allBoundWitnesses();
27
27
  const bwRecords = await PayloadBuilder.toDataHashMap(allBoundWitnesses);
28
28
  const chains = Object.values(this.buildAddressChains(this.queryAddress, bwRecords));
29
- return await Promise.all(chains.map(async (chain) => assertEx(await PayloadWrapper.unwrap(chain.shift()))));
29
+ return chains.map((chain) => assertEx(PayloadWrapper.unwrap(chain.shift())));
30
30
  }
31
31
  async allBoundWitnesses() {
32
32
  const archivists = (await Promise.all(await this.resolve({
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/Diviner.ts","../../src/index.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { ArchivistGetQuerySchema, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { AddressHistoryDivinerConfigSchema, AddressHistoryDivinerParams } from '@xyo-network/diviner-address-history-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\n// This diviner returns the most recent boundwitness signed by the address that can be found\n// if multiple broken chains are found, all the heads are returned\n\nexport class AddressHistoryDiviner<TParams extends AddressHistoryDivinerParams = AddressHistoryDivinerParams> extends AbstractDiviner<TParams> {\n static override configSchemas = [AddressHistoryDivinerConfigSchema]\n\n get queryAddress() {\n return assertEx(this.config.address, 'Missing address')\n }\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n assertEx(!payloads?.length, 'MemoryAddressHistoryDiviner.divine does not allow payloads to be sent')\n\n const allBoundWitnesses = await this.allBoundWitnesses()\n const bwRecords = await PayloadBuilder.toDataHashMap(allBoundWitnesses)\n const chains = Object.values(this.buildAddressChains(this.queryAddress, bwRecords))\n\n // Return the heads of each chain (get the last bw on each chain)\n return await Promise.all(chains.map(async (chain) => assertEx(await PayloadWrapper.unwrap(chain.shift()))))\n }\n\n private async allBoundWitnesses() {\n const archivists =\n (await Promise.all(await this.resolve({ query: [[ArchivistGetQuerySchema]] }))).map((module) =>\n asArchivistInstance(module, `Failed to cast module to Archivist [${module.config.name}]`),\n ) ?? []\n assertEx(archivists.length > 0, 'Did not find any archivists')\n return (\n await Promise.all(\n archivists.map(async (archivist) => {\n const all = await archivist.all?.()\n return all?.filter(isBoundWitnessWithMeta)\n }),\n )\n )\n .flat()\n .filter(exists)\n }\n\n private buildAddressChains(address: string, bwRecords: Record<string, BoundWitness>): Record<string, BoundWitness[]> {\n // eslint-disable-next-line unicorn/no-array-reduce\n const arrayedResult = Object.entries(bwRecords).reduce<Record<string, BoundWitness[]>>((prev, [key, value]) => {\n prev[key] = [value]\n return prev\n }, {})\n // eslint-disable-next-line unicorn/no-array-reduce\n return Object.entries(bwRecords).reduce<Record<string, BoundWitness[]>>((prev, [key, value]) => {\n //check if key is still there (may have been deleted as prevHash)\n if (prev[key]) {\n const previousHash = BoundWitnessBuilder.previousHash(value, address)\n if (\n previousHash && //if we have the previousHash, move this bw to its chain\n prev[previousHash]\n ) {\n prev[key].push(...prev[previousHash])\n delete prev[previousHash]\n }\n }\n return prev\n }, arrayedResult)\n }\n}\n","export * from './Diviner'\nexport * from '@xyo-network/diviner-address-history-model'\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,cAAc;AACvB,SAASC,yBAAyBC,2BAA2B;AAC7D,SAASC,2BAA2B;AACpC,SAAuBC,8BAA8B;AACrD,SAASC,uBAAuB;AAChC,SAASC,yCAAsE;AAC/E,SAASC,sBAAsB;AAE/B,SAASC,sBAAsB;AAKxB,IAAMC,wBAAN,cAA+GC,gBAAAA;EAdtH,OAcsHA;;;EACpH,OAAgBC,gBAAgB;IAACC;;EAEjC,IAAIC,eAAe;AACjB,WAAOC,SAAS,KAAKC,OAAOC,SAAS,iBAAA;EACvC;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,aAAS,CAACI,UAAUC,QAAQ,uEAAA;AAE5B,UAAMC,oBAAoB,MAAM,KAAKA,kBAAiB;AACtD,UAAMC,YAAY,MAAMC,eAAeC,cAAcH,iBAAAA;AACrD,UAAMI,SAASC,OAAOC,OAAO,KAAKC,mBAAmB,KAAKd,cAAcQ,SAAAA,CAAAA;AAGxE,WAAO,MAAMO,QAAQC,IAAIL,OAAOM,IAAI,OAAOC,UAAUjB,SAAS,MAAMkB,eAAeC,OAAOF,MAAMG,MAAK,CAAA,CAAA,CAAA,CAAA;EACvG;EAEA,MAAcd,oBAAoB;AAChC,UAAMe,cACH,MAAMP,QAAQC,IAAI,MAAM,KAAKO,QAAQ;MAAEC,OAAO;QAAC;UAACC;;;IAA0B,CAAA,CAAA,GAAKR,IAAI,CAACS,WACnFC,oBAAoBD,QAAQ,uCAAuCA,OAAOxB,OAAO0B,IAAI,GAAG,CAAA,KACrF,CAAA;AACP3B,aAASqB,WAAWhB,SAAS,GAAG,6BAAA;AAChC,YACE,MAAMS,QAAQC,IACZM,WAAWL,IAAI,OAAOY,cAAAA;AACpB,YAAMb,MAAM,MAAMa,UAAUb,MAAG;AAC/B,aAAOA,KAAKc,OAAOC,sBAAAA;IACrB,CAAA,CAAA,GAGDC,KAAI,EACJF,OAAOG,MAAAA;EACZ;EAEQnB,mBAAmBX,SAAiBK,WAAyE;AAEnH,UAAM0B,gBAAgBtB,OAAOuB,QAAQ3B,SAAAA,EAAW4B,OAAuC,CAACC,MAAM,CAACC,KAAKC,KAAAA,MAAM;AACxGF,WAAKC,GAAAA,IAAO;QAACC;;AACb,aAAOF;IACT,GAAG,CAAC,CAAA;AAEJ,WAAOzB,OAAOuB,QAAQ3B,SAAAA,EAAW4B,OAAuC,CAACC,MAAM,CAACC,KAAKC,KAAAA,MAAM;AAEzF,UAAIF,KAAKC,GAAAA,GAAM;AACb,cAAME,eAAeC,oBAAoBD,aAAaD,OAAOpC,OAAAA;AAC7D,YACEqC;QACAH,KAAKG,YAAAA,GACL;AACAH,eAAKC,GAAAA,EAAKI,KAAI,GAAIL,KAAKG,YAAAA,CAAa;AACpC,iBAAOH,KAAKG,YAAAA;QACd;MACF;AACA,aAAOH;IACT,GAAGH,aAAAA;EACL;AACF;;;ACvEA,cAAc;","names":["assertEx","exists","ArchivistGetQuerySchema","asArchivistInstance","BoundWitnessBuilder","isBoundWitnessWithMeta","AbstractDiviner","AddressHistoryDivinerConfigSchema","PayloadBuilder","PayloadWrapper","AddressHistoryDiviner","AbstractDiviner","configSchemas","AddressHistoryDivinerConfigSchema","queryAddress","assertEx","config","address","divineHandler","payloads","length","allBoundWitnesses","bwRecords","PayloadBuilder","toDataHashMap","chains","Object","values","buildAddressChains","Promise","all","map","chain","PayloadWrapper","unwrap","shift","archivists","resolve","query","ArchivistGetQuerySchema","module","asArchivistInstance","name","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push"]}
1
+ {"version":3,"sources":["../../src/Diviner.ts","../../src/index.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { ArchivistGetQuerySchema, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { AddressHistoryDivinerConfigSchema, AddressHistoryDivinerParams } from '@xyo-network/diviner-address-history-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\n// This diviner returns the most recent boundwitness signed by the address that can be found\n// if multiple broken chains are found, all the heads are returned\n\nexport class AddressHistoryDiviner<TParams extends AddressHistoryDivinerParams = AddressHistoryDivinerParams> extends AbstractDiviner<TParams> {\n static override configSchemas = [AddressHistoryDivinerConfigSchema]\n\n get queryAddress() {\n return assertEx(this.config.address, 'Missing address')\n }\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n assertEx(!payloads?.length, 'MemoryAddressHistoryDiviner.divine does not allow payloads to be sent')\n\n const allBoundWitnesses = await this.allBoundWitnesses()\n const bwRecords = await PayloadBuilder.toDataHashMap(allBoundWitnesses)\n const chains = Object.values(this.buildAddressChains(this.queryAddress, bwRecords))\n\n // Return the heads of each chain (get the last bw on each chain)\n return chains.map((chain) => assertEx(PayloadWrapper.unwrap(chain.shift())))\n }\n\n private async allBoundWitnesses() {\n const archivists =\n (await Promise.all(await this.resolve({ query: [[ArchivistGetQuerySchema]] }))).map((module) =>\n asArchivistInstance(module, `Failed to cast module to Archivist [${module.config.name}]`),\n ) ?? []\n assertEx(archivists.length > 0, 'Did not find any archivists')\n return (\n await Promise.all(\n archivists.map(async (archivist) => {\n const all = await archivist.all?.()\n return all?.filter(isBoundWitnessWithMeta)\n }),\n )\n )\n .flat()\n .filter(exists)\n }\n\n private buildAddressChains(address: string, bwRecords: Record<string, BoundWitness>): Record<string, BoundWitness[]> {\n // eslint-disable-next-line unicorn/no-array-reduce\n const arrayedResult = Object.entries(bwRecords).reduce<Record<string, BoundWitness[]>>((prev, [key, value]) => {\n prev[key] = [value]\n return prev\n }, {})\n // eslint-disable-next-line unicorn/no-array-reduce\n return Object.entries(bwRecords).reduce<Record<string, BoundWitness[]>>((prev, [key, value]) => {\n //check if key is still there (may have been deleted as prevHash)\n if (prev[key]) {\n const previousHash = BoundWitnessBuilder.previousHash(value, address)\n if (\n previousHash && //if we have the previousHash, move this bw to its chain\n prev[previousHash]\n ) {\n prev[key].push(...prev[previousHash])\n delete prev[previousHash]\n }\n }\n return prev\n }, arrayedResult)\n }\n}\n","export * from './Diviner'\nexport * from '@xyo-network/diviner-address-history-model'\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,cAAc;AACvB,SAASC,yBAAyBC,2BAA2B;AAC7D,SAASC,2BAA2B;AACpC,SAAuBC,8BAA8B;AACrD,SAASC,uBAAuB;AAChC,SAASC,yCAAsE;AAC/E,SAASC,sBAAsB;AAE/B,SAASC,sBAAsB;AAKxB,IAAMC,wBAAN,cAA+GC,gBAAAA;EAdtH,OAcsHA;;;EACpH,OAAgBC,gBAAgB;IAACC;;EAEjC,IAAIC,eAAe;AACjB,WAAOC,SAAS,KAAKC,OAAOC,SAAS,iBAAA;EACvC;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,aAAS,CAACI,UAAUC,QAAQ,uEAAA;AAE5B,UAAMC,oBAAoB,MAAM,KAAKA,kBAAiB;AACtD,UAAMC,YAAY,MAAMC,eAAeC,cAAcH,iBAAAA;AACrD,UAAMI,SAASC,OAAOC,OAAO,KAAKC,mBAAmB,KAAKd,cAAcQ,SAAAA,CAAAA;AAGxE,WAAOG,OAAOI,IAAI,CAACC,UAAUf,SAASgB,eAAeC,OAAOF,MAAMG,MAAK,CAAA,CAAA,CAAA;EACzE;EAEA,MAAcZ,oBAAoB;AAChC,UAAMa,cACH,MAAMC,QAAQC,IAAI,MAAM,KAAKC,QAAQ;MAAEC,OAAO;QAAC;UAACC;;;IAA0B,CAAA,CAAA,GAAKV,IAAI,CAACW,WACnFC,oBAAoBD,QAAQ,uCAAuCA,OAAOxB,OAAO0B,IAAI,GAAG,CAAA,KACrF,CAAA;AACP3B,aAASmB,WAAWd,SAAS,GAAG,6BAAA;AAChC,YACE,MAAMe,QAAQC,IACZF,WAAWL,IAAI,OAAOc,cAAAA;AACpB,YAAMP,MAAM,MAAMO,UAAUP,MAAG;AAC/B,aAAOA,KAAKQ,OAAOC,sBAAAA;IACrB,CAAA,CAAA,GAGDC,KAAI,EACJF,OAAOG,MAAAA;EACZ;EAEQnB,mBAAmBX,SAAiBK,WAAyE;AAEnH,UAAM0B,gBAAgBtB,OAAOuB,QAAQ3B,SAAAA,EAAW4B,OAAuC,CAACC,MAAM,CAACC,KAAKC,KAAAA,MAAM;AACxGF,WAAKC,GAAAA,IAAO;QAACC;;AACb,aAAOF;IACT,GAAG,CAAC,CAAA;AAEJ,WAAOzB,OAAOuB,QAAQ3B,SAAAA,EAAW4B,OAAuC,CAACC,MAAM,CAACC,KAAKC,KAAAA,MAAM;AAEzF,UAAIF,KAAKC,GAAAA,GAAM;AACb,cAAME,eAAeC,oBAAoBD,aAAaD,OAAOpC,OAAAA;AAC7D,YACEqC;QACAH,KAAKG,YAAAA,GACL;AACAH,eAAKC,GAAAA,EAAKI,KAAI,GAAIL,KAAKG,YAAAA,CAAa;AACpC,iBAAOH,KAAKG,YAAAA;QACd;MACF;AACA,aAAOH;IACT,GAAGH,aAAAA;EACL;AACF;;;ACvEA,cAAc;","names":["assertEx","exists","ArchivistGetQuerySchema","asArchivistInstance","BoundWitnessBuilder","isBoundWitnessWithMeta","AbstractDiviner","AddressHistoryDivinerConfigSchema","PayloadBuilder","PayloadWrapper","AddressHistoryDiviner","AbstractDiviner","configSchemas","AddressHistoryDivinerConfigSchema","queryAddress","assertEx","config","address","divineHandler","payloads","length","allBoundWitnesses","bwRecords","PayloadBuilder","toDataHashMap","chains","Object","values","buildAddressChains","map","chain","PayloadWrapper","unwrap","shift","archivists","Promise","all","resolve","query","ArchivistGetQuerySchema","module","asArchivistInstance","name","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push"]}
@@ -50,7 +50,7 @@ var _AddressHistoryDiviner = class _AddressHistoryDiviner extends import_diviner
50
50
  const allBoundWitnesses = await this.allBoundWitnesses();
51
51
  const bwRecords = await import_payload_builder.PayloadBuilder.toDataHashMap(allBoundWitnesses);
52
52
  const chains = Object.values(this.buildAddressChains(this.queryAddress, bwRecords));
53
- return await Promise.all(chains.map(async (chain) => (0, import_assert.assertEx)(await import_payload_wrapper.PayloadWrapper.unwrap(chain.shift()))));
53
+ return chains.map((chain) => (0, import_assert.assertEx)(import_payload_wrapper.PayloadWrapper.unwrap(chain.shift())));
54
54
  }
55
55
  async allBoundWitnesses() {
56
56
  const archivists = (await Promise.all(await this.resolve({
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/Diviner.ts"],"sourcesContent":["export * from './Diviner'\nexport * from '@xyo-network/diviner-address-history-model'\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { ArchivistGetQuerySchema, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { AddressHistoryDivinerConfigSchema, AddressHistoryDivinerParams } from '@xyo-network/diviner-address-history-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\n// This diviner returns the most recent boundwitness signed by the address that can be found\n// if multiple broken chains are found, all the heads are returned\n\nexport class AddressHistoryDiviner<TParams extends AddressHistoryDivinerParams = AddressHistoryDivinerParams> extends AbstractDiviner<TParams> {\n static override configSchemas = [AddressHistoryDivinerConfigSchema]\n\n get queryAddress() {\n return assertEx(this.config.address, 'Missing address')\n }\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n assertEx(!payloads?.length, 'MemoryAddressHistoryDiviner.divine does not allow payloads to be sent')\n\n const allBoundWitnesses = await this.allBoundWitnesses()\n const bwRecords = await PayloadBuilder.toDataHashMap(allBoundWitnesses)\n const chains = Object.values(this.buildAddressChains(this.queryAddress, bwRecords))\n\n // Return the heads of each chain (get the last bw on each chain)\n return await Promise.all(chains.map(async (chain) => assertEx(await PayloadWrapper.unwrap(chain.shift()))))\n }\n\n private async allBoundWitnesses() {\n const archivists =\n (await Promise.all(await this.resolve({ query: [[ArchivistGetQuerySchema]] }))).map((module) =>\n asArchivistInstance(module, `Failed to cast module to Archivist [${module.config.name}]`),\n ) ?? []\n assertEx(archivists.length > 0, 'Did not find any archivists')\n return (\n await Promise.all(\n archivists.map(async (archivist) => {\n const all = await archivist.all?.()\n return all?.filter(isBoundWitnessWithMeta)\n }),\n )\n )\n .flat()\n .filter(exists)\n }\n\n private buildAddressChains(address: string, bwRecords: Record<string, BoundWitness>): Record<string, BoundWitness[]> {\n // eslint-disable-next-line unicorn/no-array-reduce\n const arrayedResult = Object.entries(bwRecords).reduce<Record<string, BoundWitness[]>>((prev, [key, value]) => {\n prev[key] = [value]\n return prev\n }, {})\n // eslint-disable-next-line unicorn/no-array-reduce\n return Object.entries(bwRecords).reduce<Record<string, BoundWitness[]>>((prev, [key, value]) => {\n //check if key is still there (may have been deleted as prevHash)\n if (prev[key]) {\n const previousHash = BoundWitnessBuilder.previousHash(value, address)\n if (\n previousHash && //if we have the previousHash, move this bw to its chain\n prev[previousHash]\n ) {\n prev[key].push(...prev[previousHash])\n delete prev[previousHash]\n }\n }\n return prev\n }, arrayedResult)\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;AACzB,oBAAuB;AACvB,6BAA6D;AAC7D,kCAAoC;AACpC,gCAAqD;AACrD,8BAAgC;AAChC,2CAA+E;AAC/E,6BAA+B;AAE/B,6BAA+B;AAKxB,IAAMA,yBAAN,MAAMA,+BAAyGC,wCAAAA;EAGpH,IAAIC,eAAe;AACjB,eAAOC,wBAAS,KAAKC,OAAOC,SAAS,iBAAA;EACvC;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,gCAAS,EAACI,qCAAUC,SAAQ,uEAAA;AAE5B,UAAMC,oBAAoB,MAAM,KAAKA,kBAAiB;AACtD,UAAMC,YAAY,MAAMC,sCAAeC,cAAcH,iBAAAA;AACrD,UAAMI,SAASC,OAAOC,OAAO,KAAKC,mBAAmB,KAAKd,cAAcQ,SAAAA,CAAAA;AAGxE,WAAO,MAAMO,QAAQC,IAAIL,OAAOM,IAAI,OAAOC,cAAUjB,wBAAS,MAAMkB,sCAAeC,OAAOF,MAAMG,MAAK,CAAA,CAAA,CAAA,CAAA;EACvG;EAEA,MAAcd,oBAAoB;AAChC,UAAMe,cACH,MAAMP,QAAQC,IAAI,MAAM,KAAKO,QAAQ;MAAEC,OAAO;QAAC;UAACC;;;IAA0B,CAAA,CAAA,GAAKR,IAAI,CAACS,gBACnFC,4CAAoBD,SAAQ,uCAAuCA,QAAOxB,OAAO0B,IAAI,GAAG,CAAA,KACrF,CAAA;AACP3B,gCAASqB,WAAWhB,SAAS,GAAG,6BAAA;AAChC,YACE,MAAMS,QAAQC,IACZM,WAAWL,IAAI,OAAOY,cAAAA;AAxC9B;AAyCU,YAAMb,MAAM,QAAMa,eAAUb,QAAVa;AAClB,aAAOb,2BAAKc,OAAOC;IACrB,CAAA,CAAA,GAGDC,KAAI,EACJF,OAAOG,oBAAAA;EACZ;EAEQnB,mBAAmBX,SAAiBK,WAAyE;AAEnH,UAAM0B,gBAAgBtB,OAAOuB,QAAQ3B,SAAAA,EAAW4B,OAAuC,CAACC,MAAM,CAACC,KAAKC,KAAAA,MAAM;AACxGF,WAAKC,GAAAA,IAAO;QAACC;;AACb,aAAOF;IACT,GAAG,CAAC,CAAA;AAEJ,WAAOzB,OAAOuB,QAAQ3B,SAAAA,EAAW4B,OAAuC,CAACC,MAAM,CAACC,KAAKC,KAAAA,MAAM;AAEzF,UAAIF,KAAKC,GAAAA,GAAM;AACb,cAAME,eAAeC,gDAAoBD,aAAaD,OAAOpC,OAAAA;AAC7D,YACEqC;QACAH,KAAKG,YAAAA,GACL;AACAH,eAAKC,GAAAA,EAAKI,KAAI,GAAIL,KAAKG,YAAAA,CAAa;AACpC,iBAAOH,KAAKG,YAAAA;QACd;MACF;AACA,aAAOH;IACT,GAAGH,aAAAA;EACL;AACF;AA1DsHnC;AACpH,cADWD,wBACK6C,iBAAgB;EAACC;;AAD5B,IAAM9C,wBAAN;;;ADbP,wBAAc,uDADd;","names":["AddressHistoryDiviner","AbstractDiviner","queryAddress","assertEx","config","address","divineHandler","payloads","length","allBoundWitnesses","bwRecords","PayloadBuilder","toDataHashMap","chains","Object","values","buildAddressChains","Promise","all","map","chain","PayloadWrapper","unwrap","shift","archivists","resolve","query","ArchivistGetQuerySchema","module","asArchivistInstance","name","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push","configSchemas","AddressHistoryDivinerConfigSchema"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/Diviner.ts"],"sourcesContent":["export * from './Diviner'\nexport * from '@xyo-network/diviner-address-history-model'\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { ArchivistGetQuerySchema, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { AddressHistoryDivinerConfigSchema, AddressHistoryDivinerParams } from '@xyo-network/diviner-address-history-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\n// This diviner returns the most recent boundwitness signed by the address that can be found\n// if multiple broken chains are found, all the heads are returned\n\nexport class AddressHistoryDiviner<TParams extends AddressHistoryDivinerParams = AddressHistoryDivinerParams> extends AbstractDiviner<TParams> {\n static override configSchemas = [AddressHistoryDivinerConfigSchema]\n\n get queryAddress() {\n return assertEx(this.config.address, 'Missing address')\n }\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n assertEx(!payloads?.length, 'MemoryAddressHistoryDiviner.divine does not allow payloads to be sent')\n\n const allBoundWitnesses = await this.allBoundWitnesses()\n const bwRecords = await PayloadBuilder.toDataHashMap(allBoundWitnesses)\n const chains = Object.values(this.buildAddressChains(this.queryAddress, bwRecords))\n\n // Return the heads of each chain (get the last bw on each chain)\n return chains.map((chain) => assertEx(PayloadWrapper.unwrap(chain.shift())))\n }\n\n private async allBoundWitnesses() {\n const archivists =\n (await Promise.all(await this.resolve({ query: [[ArchivistGetQuerySchema]] }))).map((module) =>\n asArchivistInstance(module, `Failed to cast module to Archivist [${module.config.name}]`),\n ) ?? []\n assertEx(archivists.length > 0, 'Did not find any archivists')\n return (\n await Promise.all(\n archivists.map(async (archivist) => {\n const all = await archivist.all?.()\n return all?.filter(isBoundWitnessWithMeta)\n }),\n )\n )\n .flat()\n .filter(exists)\n }\n\n private buildAddressChains(address: string, bwRecords: Record<string, BoundWitness>): Record<string, BoundWitness[]> {\n // eslint-disable-next-line unicorn/no-array-reduce\n const arrayedResult = Object.entries(bwRecords).reduce<Record<string, BoundWitness[]>>((prev, [key, value]) => {\n prev[key] = [value]\n return prev\n }, {})\n // eslint-disable-next-line unicorn/no-array-reduce\n return Object.entries(bwRecords).reduce<Record<string, BoundWitness[]>>((prev, [key, value]) => {\n //check if key is still there (may have been deleted as prevHash)\n if (prev[key]) {\n const previousHash = BoundWitnessBuilder.previousHash(value, address)\n if (\n previousHash && //if we have the previousHash, move this bw to its chain\n prev[previousHash]\n ) {\n prev[key].push(...prev[previousHash])\n delete prev[previousHash]\n }\n }\n return prev\n }, arrayedResult)\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;AACzB,oBAAuB;AACvB,6BAA6D;AAC7D,kCAAoC;AACpC,gCAAqD;AACrD,8BAAgC;AAChC,2CAA+E;AAC/E,6BAA+B;AAE/B,6BAA+B;AAKxB,IAAMA,yBAAN,MAAMA,+BAAyGC,wCAAAA;EAGpH,IAAIC,eAAe;AACjB,eAAOC,wBAAS,KAAKC,OAAOC,SAAS,iBAAA;EACvC;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,gCAAS,EAACI,qCAAUC,SAAQ,uEAAA;AAE5B,UAAMC,oBAAoB,MAAM,KAAKA,kBAAiB;AACtD,UAAMC,YAAY,MAAMC,sCAAeC,cAAcH,iBAAAA;AACrD,UAAMI,SAASC,OAAOC,OAAO,KAAKC,mBAAmB,KAAKd,cAAcQ,SAAAA,CAAAA;AAGxE,WAAOG,OAAOI,IAAI,CAACC,cAAUf,wBAASgB,sCAAeC,OAAOF,MAAMG,MAAK,CAAA,CAAA,CAAA;EACzE;EAEA,MAAcZ,oBAAoB;AAChC,UAAMa,cACH,MAAMC,QAAQC,IAAI,MAAM,KAAKC,QAAQ;MAAEC,OAAO;QAAC;UAACC;;;IAA0B,CAAA,CAAA,GAAKV,IAAI,CAACW,gBACnFC,4CAAoBD,SAAQ,uCAAuCA,QAAOxB,OAAO0B,IAAI,GAAG,CAAA,KACrF,CAAA;AACP3B,gCAASmB,WAAWd,SAAS,GAAG,6BAAA;AAChC,YACE,MAAMe,QAAQC,IACZF,WAAWL,IAAI,OAAOc,cAAAA;AAxC9B;AAyCU,YAAMP,MAAM,QAAMO,eAAUP,QAAVO;AAClB,aAAOP,2BAAKQ,OAAOC;IACrB,CAAA,CAAA,GAGDC,KAAI,EACJF,OAAOG,oBAAAA;EACZ;EAEQnB,mBAAmBX,SAAiBK,WAAyE;AAEnH,UAAM0B,gBAAgBtB,OAAOuB,QAAQ3B,SAAAA,EAAW4B,OAAuC,CAACC,MAAM,CAACC,KAAKC,KAAAA,MAAM;AACxGF,WAAKC,GAAAA,IAAO;QAACC;;AACb,aAAOF;IACT,GAAG,CAAC,CAAA;AAEJ,WAAOzB,OAAOuB,QAAQ3B,SAAAA,EAAW4B,OAAuC,CAACC,MAAM,CAACC,KAAKC,KAAAA,MAAM;AAEzF,UAAIF,KAAKC,GAAAA,GAAM;AACb,cAAME,eAAeC,gDAAoBD,aAAaD,OAAOpC,OAAAA;AAC7D,YACEqC;QACAH,KAAKG,YAAAA,GACL;AACAH,eAAKC,GAAAA,EAAKI,KAAI,GAAIL,KAAKG,YAAAA,CAAa;AACpC,iBAAOH,KAAKG,YAAAA;QACd;MACF;AACA,aAAOH;IACT,GAAGH,aAAAA;EACL;AACF;AA1DsHnC;AACpH,cADWD,wBACK6C,iBAAgB;EAACC;;AAD5B,IAAM9C,wBAAN;;;ADbP,wBAAc,uDADd;","names":["AddressHistoryDiviner","AbstractDiviner","queryAddress","assertEx","config","address","divineHandler","payloads","length","allBoundWitnesses","bwRecords","PayloadBuilder","toDataHashMap","chains","Object","values","buildAddressChains","map","chain","PayloadWrapper","unwrap","shift","archivists","Promise","all","resolve","query","ArchivistGetQuerySchema","module","asArchivistInstance","name","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push","configSchemas","AddressHistoryDivinerConfigSchema"]}
@@ -25,7 +25,7 @@ var _AddressHistoryDiviner = class _AddressHistoryDiviner extends AbstractDivine
25
25
  const allBoundWitnesses = await this.allBoundWitnesses();
26
26
  const bwRecords = await PayloadBuilder.toDataHashMap(allBoundWitnesses);
27
27
  const chains = Object.values(this.buildAddressChains(this.queryAddress, bwRecords));
28
- return await Promise.all(chains.map(async (chain) => assertEx(await PayloadWrapper.unwrap(chain.shift()))));
28
+ return chains.map((chain) => assertEx(PayloadWrapper.unwrap(chain.shift())));
29
29
  }
30
30
  async allBoundWitnesses() {
31
31
  const archivists = (await Promise.all(await this.resolve({
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/Diviner.ts","../../src/index.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { ArchivistGetQuerySchema, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { AddressHistoryDivinerConfigSchema, AddressHistoryDivinerParams } from '@xyo-network/diviner-address-history-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\n// This diviner returns the most recent boundwitness signed by the address that can be found\n// if multiple broken chains are found, all the heads are returned\n\nexport class AddressHistoryDiviner<TParams extends AddressHistoryDivinerParams = AddressHistoryDivinerParams> extends AbstractDiviner<TParams> {\n static override configSchemas = [AddressHistoryDivinerConfigSchema]\n\n get queryAddress() {\n return assertEx(this.config.address, 'Missing address')\n }\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n assertEx(!payloads?.length, 'MemoryAddressHistoryDiviner.divine does not allow payloads to be sent')\n\n const allBoundWitnesses = await this.allBoundWitnesses()\n const bwRecords = await PayloadBuilder.toDataHashMap(allBoundWitnesses)\n const chains = Object.values(this.buildAddressChains(this.queryAddress, bwRecords))\n\n // Return the heads of each chain (get the last bw on each chain)\n return await Promise.all(chains.map(async (chain) => assertEx(await PayloadWrapper.unwrap(chain.shift()))))\n }\n\n private async allBoundWitnesses() {\n const archivists =\n (await Promise.all(await this.resolve({ query: [[ArchivistGetQuerySchema]] }))).map((module) =>\n asArchivistInstance(module, `Failed to cast module to Archivist [${module.config.name}]`),\n ) ?? []\n assertEx(archivists.length > 0, 'Did not find any archivists')\n return (\n await Promise.all(\n archivists.map(async (archivist) => {\n const all = await archivist.all?.()\n return all?.filter(isBoundWitnessWithMeta)\n }),\n )\n )\n .flat()\n .filter(exists)\n }\n\n private buildAddressChains(address: string, bwRecords: Record<string, BoundWitness>): Record<string, BoundWitness[]> {\n // eslint-disable-next-line unicorn/no-array-reduce\n const arrayedResult = Object.entries(bwRecords).reduce<Record<string, BoundWitness[]>>((prev, [key, value]) => {\n prev[key] = [value]\n return prev\n }, {})\n // eslint-disable-next-line unicorn/no-array-reduce\n return Object.entries(bwRecords).reduce<Record<string, BoundWitness[]>>((prev, [key, value]) => {\n //check if key is still there (may have been deleted as prevHash)\n if (prev[key]) {\n const previousHash = BoundWitnessBuilder.previousHash(value, address)\n if (\n previousHash && //if we have the previousHash, move this bw to its chain\n prev[previousHash]\n ) {\n prev[key].push(...prev[previousHash])\n delete prev[previousHash]\n }\n }\n return prev\n }, arrayedResult)\n }\n}\n","export * from './Diviner'\nexport * from '@xyo-network/diviner-address-history-model'\n"],"mappings":";;;;;;;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,cAAc;AACvB,SAASC,yBAAyBC,2BAA2B;AAC7D,SAASC,2BAA2B;AACpC,SAAuBC,8BAA8B;AACrD,SAASC,uBAAuB;AAChC,SAASC,yCAAsE;AAC/E,SAASC,sBAAsB;AAE/B,SAASC,sBAAsB;AAKxB,IAAMC,yBAAN,MAAMA,+BAAyGC,gBAAAA;EAGpH,IAAIC,eAAe;AACjB,WAAOC,SAAS,KAAKC,OAAOC,SAAS,iBAAA;EACvC;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,aAAS,EAACI,qCAAUC,SAAQ,uEAAA;AAE5B,UAAMC,oBAAoB,MAAM,KAAKA,kBAAiB;AACtD,UAAMC,YAAY,MAAMC,eAAeC,cAAcH,iBAAAA;AACrD,UAAMI,SAASC,OAAOC,OAAO,KAAKC,mBAAmB,KAAKd,cAAcQ,SAAAA,CAAAA;AAGxE,WAAO,MAAMO,QAAQC,IAAIL,OAAOM,IAAI,OAAOC,UAAUjB,SAAS,MAAMkB,eAAeC,OAAOF,MAAMG,MAAK,CAAA,CAAA,CAAA,CAAA;EACvG;EAEA,MAAcd,oBAAoB;AAChC,UAAMe,cACH,MAAMP,QAAQC,IAAI,MAAM,KAAKO,QAAQ;MAAEC,OAAO;QAAC;UAACC;;;IAA0B,CAAA,CAAA,GAAKR,IAAI,CAACS,WACnFC,oBAAoBD,QAAQ,uCAAuCA,OAAOxB,OAAO0B,IAAI,GAAG,CAAA,KACrF,CAAA;AACP3B,aAASqB,WAAWhB,SAAS,GAAG,6BAAA;AAChC,YACE,MAAMS,QAAQC,IACZM,WAAWL,IAAI,OAAOY,cAAAA;AAxC9B;AAyCU,YAAMb,MAAM,QAAMa,eAAUb,QAAVa;AAClB,aAAOb,2BAAKc,OAAOC;IACrB,CAAA,CAAA,GAGDC,KAAI,EACJF,OAAOG,MAAAA;EACZ;EAEQnB,mBAAmBX,SAAiBK,WAAyE;AAEnH,UAAM0B,gBAAgBtB,OAAOuB,QAAQ3B,SAAAA,EAAW4B,OAAuC,CAACC,MAAM,CAACC,KAAKC,KAAAA,MAAM;AACxGF,WAAKC,GAAAA,IAAO;QAACC;;AACb,aAAOF;IACT,GAAG,CAAC,CAAA;AAEJ,WAAOzB,OAAOuB,QAAQ3B,SAAAA,EAAW4B,OAAuC,CAACC,MAAM,CAACC,KAAKC,KAAAA,MAAM;AAEzF,UAAIF,KAAKC,GAAAA,GAAM;AACb,cAAME,eAAeC,oBAAoBD,aAAaD,OAAOpC,OAAAA;AAC7D,YACEqC;QACAH,KAAKG,YAAAA,GACL;AACAH,eAAKC,GAAAA,EAAKI,KAAI,GAAIL,KAAKG,YAAAA,CAAa;AACpC,iBAAOH,KAAKG,YAAAA;QACd;MACF;AACA,aAAOH;IACT,GAAGH,aAAAA;EACL;AACF;AA1DsHnC;AACpH,cADWD,wBACK6C,iBAAgB;EAACC;;AAD5B,IAAM9C,wBAAN;;;ACbP,cAAc;","names":["assertEx","exists","ArchivistGetQuerySchema","asArchivistInstance","BoundWitnessBuilder","isBoundWitnessWithMeta","AbstractDiviner","AddressHistoryDivinerConfigSchema","PayloadBuilder","PayloadWrapper","AddressHistoryDiviner","AbstractDiviner","queryAddress","assertEx","config","address","divineHandler","payloads","length","allBoundWitnesses","bwRecords","PayloadBuilder","toDataHashMap","chains","Object","values","buildAddressChains","Promise","all","map","chain","PayloadWrapper","unwrap","shift","archivists","resolve","query","ArchivistGetQuerySchema","module","asArchivistInstance","name","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push","configSchemas","AddressHistoryDivinerConfigSchema"]}
1
+ {"version":3,"sources":["../../src/Diviner.ts","../../src/index.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { ArchivistGetQuerySchema, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { AddressHistoryDivinerConfigSchema, AddressHistoryDivinerParams } from '@xyo-network/diviner-address-history-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\n// This diviner returns the most recent boundwitness signed by the address that can be found\n// if multiple broken chains are found, all the heads are returned\n\nexport class AddressHistoryDiviner<TParams extends AddressHistoryDivinerParams = AddressHistoryDivinerParams> extends AbstractDiviner<TParams> {\n static override configSchemas = [AddressHistoryDivinerConfigSchema]\n\n get queryAddress() {\n return assertEx(this.config.address, 'Missing address')\n }\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n assertEx(!payloads?.length, 'MemoryAddressHistoryDiviner.divine does not allow payloads to be sent')\n\n const allBoundWitnesses = await this.allBoundWitnesses()\n const bwRecords = await PayloadBuilder.toDataHashMap(allBoundWitnesses)\n const chains = Object.values(this.buildAddressChains(this.queryAddress, bwRecords))\n\n // Return the heads of each chain (get the last bw on each chain)\n return chains.map((chain) => assertEx(PayloadWrapper.unwrap(chain.shift())))\n }\n\n private async allBoundWitnesses() {\n const archivists =\n (await Promise.all(await this.resolve({ query: [[ArchivistGetQuerySchema]] }))).map((module) =>\n asArchivistInstance(module, `Failed to cast module to Archivist [${module.config.name}]`),\n ) ?? []\n assertEx(archivists.length > 0, 'Did not find any archivists')\n return (\n await Promise.all(\n archivists.map(async (archivist) => {\n const all = await archivist.all?.()\n return all?.filter(isBoundWitnessWithMeta)\n }),\n )\n )\n .flat()\n .filter(exists)\n }\n\n private buildAddressChains(address: string, bwRecords: Record<string, BoundWitness>): Record<string, BoundWitness[]> {\n // eslint-disable-next-line unicorn/no-array-reduce\n const arrayedResult = Object.entries(bwRecords).reduce<Record<string, BoundWitness[]>>((prev, [key, value]) => {\n prev[key] = [value]\n return prev\n }, {})\n // eslint-disable-next-line unicorn/no-array-reduce\n return Object.entries(bwRecords).reduce<Record<string, BoundWitness[]>>((prev, [key, value]) => {\n //check if key is still there (may have been deleted as prevHash)\n if (prev[key]) {\n const previousHash = BoundWitnessBuilder.previousHash(value, address)\n if (\n previousHash && //if we have the previousHash, move this bw to its chain\n prev[previousHash]\n ) {\n prev[key].push(...prev[previousHash])\n delete prev[previousHash]\n }\n }\n return prev\n }, arrayedResult)\n }\n}\n","export * from './Diviner'\nexport * from '@xyo-network/diviner-address-history-model'\n"],"mappings":";;;;;;;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,cAAc;AACvB,SAASC,yBAAyBC,2BAA2B;AAC7D,SAASC,2BAA2B;AACpC,SAAuBC,8BAA8B;AACrD,SAASC,uBAAuB;AAChC,SAASC,yCAAsE;AAC/E,SAASC,sBAAsB;AAE/B,SAASC,sBAAsB;AAKxB,IAAMC,yBAAN,MAAMA,+BAAyGC,gBAAAA;EAGpH,IAAIC,eAAe;AACjB,WAAOC,SAAS,KAAKC,OAAOC,SAAS,iBAAA;EACvC;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,aAAS,EAACI,qCAAUC,SAAQ,uEAAA;AAE5B,UAAMC,oBAAoB,MAAM,KAAKA,kBAAiB;AACtD,UAAMC,YAAY,MAAMC,eAAeC,cAAcH,iBAAAA;AACrD,UAAMI,SAASC,OAAOC,OAAO,KAAKC,mBAAmB,KAAKd,cAAcQ,SAAAA,CAAAA;AAGxE,WAAOG,OAAOI,IAAI,CAACC,UAAUf,SAASgB,eAAeC,OAAOF,MAAMG,MAAK,CAAA,CAAA,CAAA;EACzE;EAEA,MAAcZ,oBAAoB;AAChC,UAAMa,cACH,MAAMC,QAAQC,IAAI,MAAM,KAAKC,QAAQ;MAAEC,OAAO;QAAC;UAACC;;;IAA0B,CAAA,CAAA,GAAKV,IAAI,CAACW,WACnFC,oBAAoBD,QAAQ,uCAAuCA,OAAOxB,OAAO0B,IAAI,GAAG,CAAA,KACrF,CAAA;AACP3B,aAASmB,WAAWd,SAAS,GAAG,6BAAA;AAChC,YACE,MAAMe,QAAQC,IACZF,WAAWL,IAAI,OAAOc,cAAAA;AAxC9B;AAyCU,YAAMP,MAAM,QAAMO,eAAUP,QAAVO;AAClB,aAAOP,2BAAKQ,OAAOC;IACrB,CAAA,CAAA,GAGDC,KAAI,EACJF,OAAOG,MAAAA;EACZ;EAEQnB,mBAAmBX,SAAiBK,WAAyE;AAEnH,UAAM0B,gBAAgBtB,OAAOuB,QAAQ3B,SAAAA,EAAW4B,OAAuC,CAACC,MAAM,CAACC,KAAKC,KAAAA,MAAM;AACxGF,WAAKC,GAAAA,IAAO;QAACC;;AACb,aAAOF;IACT,GAAG,CAAC,CAAA;AAEJ,WAAOzB,OAAOuB,QAAQ3B,SAAAA,EAAW4B,OAAuC,CAACC,MAAM,CAACC,KAAKC,KAAAA,MAAM;AAEzF,UAAIF,KAAKC,GAAAA,GAAM;AACb,cAAME,eAAeC,oBAAoBD,aAAaD,OAAOpC,OAAAA;AAC7D,YACEqC;QACAH,KAAKG,YAAAA,GACL;AACAH,eAAKC,GAAAA,EAAKI,KAAI,GAAIL,KAAKG,YAAAA,CAAa;AACpC,iBAAOH,KAAKG,YAAAA;QACd;MACF;AACA,aAAOH;IACT,GAAGH,aAAAA;EACL;AACF;AA1DsHnC;AACpH,cADWD,wBACK6C,iBAAgB;EAACC;;AAD5B,IAAM9C,wBAAN;;;ACbP,cAAc;","names":["assertEx","exists","ArchivistGetQuerySchema","asArchivistInstance","BoundWitnessBuilder","isBoundWitnessWithMeta","AbstractDiviner","AddressHistoryDivinerConfigSchema","PayloadBuilder","PayloadWrapper","AddressHistoryDiviner","AbstractDiviner","queryAddress","assertEx","config","address","divineHandler","payloads","length","allBoundWitnesses","bwRecords","PayloadBuilder","toDataHashMap","chains","Object","values","buildAddressChains","map","chain","PayloadWrapper","unwrap","shift","archivists","Promise","all","resolve","query","ArchivistGetQuerySchema","module","asArchivistInstance","name","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push","configSchemas","AddressHistoryDivinerConfigSchema"]}
package/package.json CHANGED
@@ -12,22 +12,22 @@
12
12
  "dependencies": {
13
13
  "@xylabs/assert": "^2.14.2",
14
14
  "@xylabs/exists": "^2.14.2",
15
- "@xyo-network/archivist-model": "~2.90.15",
16
- "@xyo-network/boundwitness-builder": "~2.90.15",
17
- "@xyo-network/boundwitness-model": "~2.90.15",
18
- "@xyo-network/diviner-abstract": "~2.90.15",
19
- "@xyo-network/diviner-address-history-model": "~2.90.15",
20
- "@xyo-network/payload-builder": "~2.90.15",
21
- "@xyo-network/payload-model": "~2.90.15",
22
- "@xyo-network/payload-wrapper": "~2.90.15"
15
+ "@xyo-network/archivist-model": "~2.90.17",
16
+ "@xyo-network/boundwitness-builder": "~2.90.17",
17
+ "@xyo-network/boundwitness-model": "~2.90.17",
18
+ "@xyo-network/diviner-abstract": "~2.90.17",
19
+ "@xyo-network/diviner-address-history-model": "~2.90.17",
20
+ "@xyo-network/payload-builder": "~2.90.17",
21
+ "@xyo-network/payload-model": "~2.90.17",
22
+ "@xyo-network/payload-wrapper": "~2.90.17"
23
23
  },
24
24
  "devDependencies": {
25
25
  "@xylabs/ts-scripts-yarn3": "^3.2.42",
26
26
  "@xylabs/tsconfig": "^3.2.42",
27
- "@xyo-network/account": "~2.90.15",
28
- "@xyo-network/archivist-memory": "~2.90.15",
29
- "@xyo-network/archivist-wrapper": "~2.90.15",
30
- "@xyo-network/node-memory": "~2.90.15",
27
+ "@xyo-network/account": "~2.90.17",
28
+ "@xyo-network/archivist-memory": "~2.90.17",
29
+ "@xyo-network/archivist-wrapper": "~2.90.17",
30
+ "@xyo-network/node-memory": "~2.90.17",
31
31
  "typescript": "^5.3.3"
32
32
  },
33
33
  "description": "Primary SDK for using XYO Protocol 2.0",
@@ -69,6 +69,6 @@
69
69
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
70
70
  },
71
71
  "sideEffects": false,
72
- "version": "2.90.15",
72
+ "version": "2.90.17",
73
73
  "type": "module"
74
74
  }
package/src/Diviner.ts CHANGED
@@ -27,7 +27,7 @@ export class AddressHistoryDiviner<TParams extends AddressHistoryDivinerParams =
27
27
  const chains = Object.values(this.buildAddressChains(this.queryAddress, bwRecords))
28
28
 
29
29
  // Return the heads of each chain (get the last bw on each chain)
30
- return await Promise.all(chains.map(async (chain) => assertEx(await PayloadWrapper.unwrap(chain.shift()))))
30
+ return chains.map((chain) => assertEx(PayloadWrapper.unwrap(chain.shift())))
31
31
  }
32
32
 
33
33
  private async allBoundWitnesses() {