@xyo-network/diviner-address-history 2.110.18 → 2.111.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -79,8 +79,7 @@ var AddressHistoryDiviner = class extends import_diviner_abstract.AbstractDivine
79
79
  return Object.entries(bwRecords).reduce((prev, [key, value]) => {
80
80
  if (prev[key]) {
81
81
  const previousHash = import_boundwitness_builder.BoundWitnessBuilder.previousHash(value, address);
82
- if (previousHash && //if we have the previousHash, move this bw to its chain
83
- prev[previousHash]) {
82
+ if (previousHash && prev[previousHash]) {
84
83
  prev[key].push(...prev[previousHash]);
85
84
  delete prev[previousHash];
86
85
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/Diviner.ts"],"sourcesContent":["export * from './Diviner.ts'\nexport * from '@xyo-network/diviner-address-history-model'\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\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, Schema } 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 readonly configSchemas: Schema[] = [...super.configSchemas, AddressHistoryDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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((mod) =>\n asArchivistInstance(mod, `Failed to cast module to Archivist [${mod.id}]`),\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: Address, 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;AAEvB,6BAA6D;AAC7D,kCAAoC;AACpC,gCAAqD;AACrD,8BAAgC;AAChC,2CAA+E;AAC/E,6BAA+B;AAE/B,6BAA+B;AAKxB,IAAMA,wBAAN,cAA+GC,wCAAAA;EAftH,OAesHA;;;EACpH,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,IAAIE,eAAe;AACjB,eAAOC,wBAAS,KAAKC,OAAOC,SAAS,MAAM,iBAAA;EAC7C;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,gCAAS,CAACI,UAAUC,QAAQ,MAAM,uEAAA;AAElC,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,YACnFC,4CAAoBD,KAAK,uCAAuCA,IAAIE,EAAE,GAAG,CAAA,KACtE,CAAA;AACP3B,gCAASmB,WAAWd,SAAS,GAAG,MAAM,6BAAA;AACtC,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,SAAkBK,WAAyE;AAEpH,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;;;ADzEA,wBAAc,uDADd;","names":["AddressHistoryDiviner","AbstractDiviner","configSchemas","AddressHistoryDivinerConfigSchema","defaultConfigSchema","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","mod","asArchivistInstance","id","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.ts'\nexport * from '@xyo-network/diviner-address-history-model'\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\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, Schema } 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 readonly configSchemas: Schema[] = [...super.configSchemas, AddressHistoryDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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(mod =>\n asArchivistInstance(mod, `Failed to cast module to Archivist [${mod.id}]`),\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: Address, 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;AAEvB,6BAA6D;AAC7D,kCAAoC;AACpC,gCAAqD;AACrD,8BAAgC;AAChC,2CAA+E;AAC/E,6BAA+B;AAE/B,6BAA+B;AAKxB,IAAMA,wBAAN,cAA+GC,wCAAAA;EAftH,OAesHA;;;EACpH,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,IAAIE,eAAe;AACjB,eAAOC,wBAAS,KAAKC,OAAOC,SAAS,MAAM,iBAAA;EAC7C;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,gCAAS,CAACI,UAAUC,QAAQ,MAAM,uEAAA;AAElC,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,IAAIC,CAAAA,cAASf,wBAASgB,sCAAeC,OAAOF,MAAMG,MAAK,CAAA,CAAA,CAAA;EACvE;EAEA,MAAcZ,oBAAoB;AAChC,UAAMa,cACD,MAAMC,QAAQC,IAAI,MAAM,KAAKC,QAAQ;MAAEC,OAAO;QAAC;UAACC;;;IAA0B,CAAA,CAAA,GAAKV,IAAIW,CAAAA,YACpFC,4CAAoBD,KAAK,uCAAuCA,IAAIE,EAAE,GAAG,CAAA,KACtE,CAAA;AACP3B,gCAASmB,WAAWd,SAAS,GAAG,MAAM,6BAAA;AACtC,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,SAAkBK,WAAyE;AAEpH,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,gBACGH,KAAKG,YAAAA,GACR;AACAH,eAAKC,GAAAA,EAAKI,KAAI,GAAIL,KAAKG,YAAAA,CAAa;AACpC,iBAAOH,KAAKG,YAAAA;QACd;MACF;AACA,aAAOH;IACT,GAAGH,aAAAA;EACL;AACF;;;ADzEA,wBAAc,uDADd;","names":["AddressHistoryDiviner","AbstractDiviner","configSchemas","AddressHistoryDivinerConfigSchema","defaultConfigSchema","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","mod","asArchivistInstance","id","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push"]}
@@ -54,8 +54,7 @@ var AddressHistoryDiviner = class extends AbstractDiviner {
54
54
  return Object.entries(bwRecords).reduce((prev, [key, value]) => {
55
55
  if (prev[key]) {
56
56
  const previousHash = BoundWitnessBuilder.previousHash(value, address);
57
- if (previousHash && //if we have the previousHash, move this bw to its chain
58
- prev[previousHash]) {
57
+ if (previousHash && prev[previousHash]) {
59
58
  prev[key].push(...prev[previousHash]);
60
59
  delete prev[previousHash];
61
60
  }
@@ -70,4 +69,4 @@ export * from "@xyo-network/diviner-address-history-model";
70
69
  export {
71
70
  AddressHistoryDiviner
72
71
  };
73
- //# sourceMappingURL=index.js.map
72
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/Diviner.ts","../../src/index.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\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, Schema } 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 readonly configSchemas: Schema[] = [...super.configSchemas, AddressHistoryDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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(mod =>\n asArchivistInstance(mod, `Failed to cast module to Archivist [${mod.id}]`),\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: Address, 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.ts'\nexport * from '@xyo-network/diviner-address-history-model'\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,cAAc;AAEvB,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;EAftH,OAesHA;;;EACpH,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,IAAIE,eAAe;AACjB,WAAOC,SAAS,KAAKC,OAAOC,SAAS,MAAM,iBAAA;EAC7C;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,aAAS,CAACI,UAAUC,QAAQ,MAAM,uEAAA;AAElC,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,IAAIC,CAAAA,UAASf,SAASgB,eAAeC,OAAOF,MAAMG,MAAK,CAAA,CAAA,CAAA;EACvE;EAEA,MAAcZ,oBAAoB;AAChC,UAAMa,cACD,MAAMC,QAAQC,IAAI,MAAM,KAAKC,QAAQ;MAAEC,OAAO;QAAC;UAACC;;;IAA0B,CAAA,CAAA,GAAKV,IAAIW,CAAAA,QACpFC,oBAAoBD,KAAK,uCAAuCA,IAAIE,EAAE,GAAG,CAAA,KACtE,CAAA;AACP3B,aAASmB,WAAWd,SAAS,GAAG,MAAM,6BAAA;AACtC,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,SAAkBK,WAAyE;AAEpH,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,gBACGH,KAAKG,YAAAA,GACR;AACAH,eAAKC,GAAAA,EAAKI,KAAI,GAAIL,KAAKG,YAAAA,CAAa;AACpC,iBAAOH,KAAKG,YAAAA;QACd;MACF;AACA,aAAOH;IACT,GAAGH,aAAAA;EACL;AACF;;;ACzEA,cAAc;","names":["assertEx","exists","ArchivistGetQuerySchema","asArchivistInstance","BoundWitnessBuilder","isBoundWitnessWithMeta","AbstractDiviner","AddressHistoryDivinerConfigSchema","PayloadBuilder","PayloadWrapper","AddressHistoryDiviner","AbstractDiviner","configSchemas","AddressHistoryDivinerConfigSchema","defaultConfigSchema","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","mod","asArchivistInstance","id","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push"]}
@@ -79,8 +79,7 @@ var AddressHistoryDiviner = class extends import_diviner_abstract.AbstractDivine
79
79
  return Object.entries(bwRecords).reduce((prev, [key, value]) => {
80
80
  if (prev[key]) {
81
81
  const previousHash = import_boundwitness_builder.BoundWitnessBuilder.previousHash(value, address);
82
- if (previousHash && //if we have the previousHash, move this bw to its chain
83
- prev[previousHash]) {
82
+ if (previousHash && prev[previousHash]) {
84
83
  prev[key].push(...prev[previousHash]);
85
84
  delete prev[previousHash];
86
85
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/Diviner.ts"],"sourcesContent":["export * from './Diviner.ts'\nexport * from '@xyo-network/diviner-address-history-model'\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\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, Schema } 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 readonly configSchemas: Schema[] = [...super.configSchemas, AddressHistoryDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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((mod) =>\n asArchivistInstance(mod, `Failed to cast module to Archivist [${mod.id}]`),\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: Address, 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;AAEvB,6BAA6D;AAC7D,kCAAoC;AACpC,gCAAqD;AACrD,8BAAgC;AAChC,2CAA+E;AAC/E,6BAA+B;AAE/B,6BAA+B;AAKxB,IAAMA,wBAAN,cAA+GC,wCAAAA;EAftH,OAesHA;;;EACpH,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,IAAIE,eAAe;AACjB,eAAOC,wBAAS,KAAKC,OAAOC,SAAS,MAAM,iBAAA;EAC7C;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,gCAAS,CAACI,UAAUC,QAAQ,MAAM,uEAAA;AAElC,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,YACnFC,4CAAoBD,KAAK,uCAAuCA,IAAIE,EAAE,GAAG,CAAA,KACtE,CAAA;AACP3B,gCAASmB,WAAWd,SAAS,GAAG,MAAM,6BAAA;AACtC,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,SAAkBK,WAAyE;AAEpH,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;;;ADzEA,wBAAc,uDADd;","names":["AddressHistoryDiviner","AbstractDiviner","configSchemas","AddressHistoryDivinerConfigSchema","defaultConfigSchema","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","mod","asArchivistInstance","id","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.ts'\nexport * from '@xyo-network/diviner-address-history-model'\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\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, Schema } 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 readonly configSchemas: Schema[] = [...super.configSchemas, AddressHistoryDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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(mod =>\n asArchivistInstance(mod, `Failed to cast module to Archivist [${mod.id}]`),\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: Address, 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;AAEvB,6BAA6D;AAC7D,kCAAoC;AACpC,gCAAqD;AACrD,8BAAgC;AAChC,2CAA+E;AAC/E,6BAA+B;AAE/B,6BAA+B;AAKxB,IAAMA,wBAAN,cAA+GC,wCAAAA;EAftH,OAesHA;;;EACpH,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,IAAIE,eAAe;AACjB,eAAOC,wBAAS,KAAKC,OAAOC,SAAS,MAAM,iBAAA;EAC7C;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,gCAAS,CAACI,UAAUC,QAAQ,MAAM,uEAAA;AAElC,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,IAAIC,CAAAA,cAASf,wBAASgB,sCAAeC,OAAOF,MAAMG,MAAK,CAAA,CAAA,CAAA;EACvE;EAEA,MAAcZ,oBAAoB;AAChC,UAAMa,cACD,MAAMC,QAAQC,IAAI,MAAM,KAAKC,QAAQ;MAAEC,OAAO;QAAC;UAACC;;;IAA0B,CAAA,CAAA,GAAKV,IAAIW,CAAAA,YACpFC,4CAAoBD,KAAK,uCAAuCA,IAAIE,EAAE,GAAG,CAAA,KACtE,CAAA;AACP3B,gCAASmB,WAAWd,SAAS,GAAG,MAAM,6BAAA;AACtC,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,SAAkBK,WAAyE;AAEpH,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,gBACGH,KAAKG,YAAAA,GACR;AACAH,eAAKC,GAAAA,EAAKI,KAAI,GAAIL,KAAKG,YAAAA,CAAa;AACpC,iBAAOH,KAAKG,YAAAA;QACd;MACF;AACA,aAAOH;IACT,GAAGH,aAAAA;EACL;AACF;;;ADzEA,wBAAc,uDADd;","names":["AddressHistoryDiviner","AbstractDiviner","configSchemas","AddressHistoryDivinerConfigSchema","defaultConfigSchema","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","mod","asArchivistInstance","id","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push"]}
@@ -54,8 +54,7 @@ var AddressHistoryDiviner = class extends AbstractDiviner {
54
54
  return Object.entries(bwRecords).reduce((prev, [key, value]) => {
55
55
  if (prev[key]) {
56
56
  const previousHash = BoundWitnessBuilder.previousHash(value, address);
57
- if (previousHash && //if we have the previousHash, move this bw to its chain
58
- prev[previousHash]) {
57
+ if (previousHash && prev[previousHash]) {
59
58
  prev[key].push(...prev[previousHash]);
60
59
  delete prev[previousHash];
61
60
  }
@@ -70,4 +69,4 @@ export * from "@xyo-network/diviner-address-history-model";
70
69
  export {
71
70
  AddressHistoryDiviner
72
71
  };
73
- //# sourceMappingURL=index.js.map
72
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/Diviner.ts","../../src/index.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\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, Schema } 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 readonly configSchemas: Schema[] = [...super.configSchemas, AddressHistoryDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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(mod =>\n asArchivistInstance(mod, `Failed to cast module to Archivist [${mod.id}]`),\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: Address, 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.ts'\nexport * from '@xyo-network/diviner-address-history-model'\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,cAAc;AAEvB,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;EAftH,OAesHA;;;EACpH,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,IAAIE,eAAe;AACjB,WAAOC,SAAS,KAAKC,OAAOC,SAAS,MAAM,iBAAA;EAC7C;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,aAAS,CAACI,UAAUC,QAAQ,MAAM,uEAAA;AAElC,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,IAAIC,CAAAA,UAASf,SAASgB,eAAeC,OAAOF,MAAMG,MAAK,CAAA,CAAA,CAAA;EACvE;EAEA,MAAcZ,oBAAoB;AAChC,UAAMa,cACD,MAAMC,QAAQC,IAAI,MAAM,KAAKC,QAAQ;MAAEC,OAAO;QAAC;UAACC;;;IAA0B,CAAA,CAAA,GAAKV,IAAIW,CAAAA,QACpFC,oBAAoBD,KAAK,uCAAuCA,IAAIE,EAAE,GAAG,CAAA,KACtE,CAAA;AACP3B,aAASmB,WAAWd,SAAS,GAAG,MAAM,6BAAA;AACtC,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,SAAkBK,WAAyE;AAEpH,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,gBACGH,KAAKG,YAAAA,GACR;AACAH,eAAKC,GAAAA,EAAKI,KAAI,GAAIL,KAAKG,YAAAA,CAAa;AACpC,iBAAOH,KAAKG,YAAAA;QACd;MACF;AACA,aAAOH;IACT,GAAGH,aAAAA;EACL;AACF;;;ACzEA,cAAc;","names":["assertEx","exists","ArchivistGetQuerySchema","asArchivistInstance","BoundWitnessBuilder","isBoundWitnessWithMeta","AbstractDiviner","AddressHistoryDivinerConfigSchema","PayloadBuilder","PayloadWrapper","AddressHistoryDiviner","AbstractDiviner","configSchemas","AddressHistoryDivinerConfigSchema","defaultConfigSchema","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","mod","asArchivistInstance","id","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push"]}
@@ -77,8 +77,7 @@ var _AddressHistoryDiviner = class _AddressHistoryDiviner extends import_diviner
77
77
  return Object.entries(bwRecords).reduce((prev, [key, value]) => {
78
78
  if (prev[key]) {
79
79
  const previousHash = import_boundwitness_builder.BoundWitnessBuilder.previousHash(value, address);
80
- if (previousHash && //if we have the previousHash, move this bw to its chain
81
- prev[previousHash]) {
80
+ if (previousHash && prev[previousHash]) {
82
81
  prev[key].push(...prev[previousHash]);
83
82
  delete prev[previousHash];
84
83
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/Diviner.ts"],"sourcesContent":["export * from './Diviner.ts'\nexport * from '@xyo-network/diviner-address-history-model'\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\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, Schema } 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 readonly configSchemas: Schema[] = [...super.configSchemas, AddressHistoryDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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((mod) =>\n asArchivistInstance(mod, `Failed to cast module to Archivist [${mod.id}]`),\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: Address, 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;AAEvB,6BAA6D;AAC7D,kCAAoC;AACpC,gCAAqD;AACrD,8BAAgC;AAChC,2CAA+E;AAC/E,6BAA+B;AAE/B,6BAA+B;AAKxB,IAAMA,yBAAN,MAAMA,+BAAyGC,wCAAAA;EAIpH,IAAIC,eAAe;AACjB,eAAOC,wBAAS,KAAKC,OAAOC,SAAS,MAAM,iBAAA;EAC7C;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,gCAAS,EAACI,qCAAUC,SAAQ,MAAM,uEAAA;AAElC,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,YACnFC,4CAAoBD,KAAK,uCAAuCA,IAAIE,EAAE,GAAG,CAAA,KACtE,CAAA;AACP3B,gCAASmB,WAAWd,SAAS,GAAG,MAAM,6BAAA;AACtC,YACE,MAAMe,QAAQC,IACZF,WAAWL,IAAI,OAAOc,cAAAA;AA1C9B;AA2CU,YAAMP,MAAM,QAAMO,eAAUP,QAAVO;AAClB,aAAOP,2BAAKQ,OAAOC;IACrB,CAAA,CAAA,GAGDC,KAAI,EACJF,OAAOG,oBAAAA;EACZ;EAEQnB,mBAAmBX,SAAkBK,WAAyE;AAEpH,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;AA3DsHnC;AACpH,cADWD,wBACc6C,iBAA0B;KAAI,2DAAMA;EAAeC;;AAC5E,cAFW9C,wBAEc+C,uBAA8BD;AAFlD,IAAM9C,wBAAN;;;ADdP,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","mod","asArchivistInstance","id","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push","configSchemas","AddressHistoryDivinerConfigSchema","defaultConfigSchema"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/Diviner.ts"],"sourcesContent":["export * from './Diviner.ts'\nexport * from '@xyo-network/diviner-address-history-model'\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\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, Schema } 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 readonly configSchemas: Schema[] = [...super.configSchemas, AddressHistoryDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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(mod =>\n asArchivistInstance(mod, `Failed to cast module to Archivist [${mod.id}]`),\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: Address, 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;AAEvB,6BAA6D;AAC7D,kCAAoC;AACpC,gCAAqD;AACrD,8BAAgC;AAChC,2CAA+E;AAC/E,6BAA+B;AAE/B,6BAA+B;AAKxB,IAAMA,yBAAN,MAAMA,+BAAyGC,wCAAAA;EAIpH,IAAIC,eAAe;AACjB,eAAOC,wBAAS,KAAKC,OAAOC,SAAS,MAAM,iBAAA;EAC7C;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,gCAAS,EAACI,qCAAUC,SAAQ,MAAM,uEAAA;AAElC,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,IAAIC,CAAAA,cAASf,wBAASgB,sCAAeC,OAAOF,MAAMG,MAAK,CAAA,CAAA,CAAA;EACvE;EAEA,MAAcZ,oBAAoB;AAChC,UAAMa,cACD,MAAMC,QAAQC,IAAI,MAAM,KAAKC,QAAQ;MAAEC,OAAO;QAAC;UAACC;;;IAA0B,CAAA,CAAA,GAAKV,IAAIW,CAAAA,YACpFC,4CAAoBD,KAAK,uCAAuCA,IAAIE,EAAE,GAAG,CAAA,KACtE,CAAA;AACP3B,gCAASmB,WAAWd,SAAS,GAAG,MAAM,6BAAA;AACtC,YACE,MAAMe,QAAQC,IACZF,WAAWL,IAAI,OAAOc,cAAAA;AA1C9B;AA2CU,YAAMP,MAAM,QAAMO,eAAUP,QAAVO;AAClB,aAAOP,2BAAKQ,OAAOC;IACrB,CAAA,CAAA,GAGDC,KAAI,EACJF,OAAOG,oBAAAA;EACZ;EAEQnB,mBAAmBX,SAAkBK,WAAyE;AAEpH,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,gBACGH,KAAKG,YAAAA,GACR;AACAH,eAAKC,GAAAA,EAAKI,KAAI,GAAIL,KAAKG,YAAAA,CAAa;AACpC,iBAAOH,KAAKG,YAAAA;QACd;MACF;AACA,aAAOH;IACT,GAAGH,aAAAA;EACL;AACF;AA3DsHnC;AACpH,cADWD,wBACc6C,iBAA0B;KAAI,2DAAMA;EAAeC;;AAC5E,cAFW9C,wBAEc+C,uBAA8BD;AAFlD,IAAM9C,wBAAN;;;ADdP,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","mod","asArchivistInstance","id","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push","configSchemas","AddressHistoryDivinerConfigSchema","defaultConfigSchema"]}
@@ -52,8 +52,7 @@ var _AddressHistoryDiviner = class _AddressHistoryDiviner extends AbstractDivine
52
52
  return Object.entries(bwRecords).reduce((prev, [key, value]) => {
53
53
  if (prev[key]) {
54
54
  const previousHash = BoundWitnessBuilder.previousHash(value, address);
55
- if (previousHash && //if we have the previousHash, move this bw to its chain
56
- prev[previousHash]) {
55
+ if (previousHash && prev[previousHash]) {
57
56
  prev[key].push(...prev[previousHash]);
58
57
  delete prev[previousHash];
59
58
  }
@@ -75,4 +74,4 @@ export * from "@xyo-network/diviner-address-history-model";
75
74
  export {
76
75
  AddressHistoryDiviner
77
76
  };
78
- //# sourceMappingURL=index.js.map
77
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/Diviner.ts","../../src/index.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\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, Schema } 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 readonly configSchemas: Schema[] = [...super.configSchemas, AddressHistoryDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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(mod =>\n asArchivistInstance(mod, `Failed to cast module to Archivist [${mod.id}]`),\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: Address, 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.ts'\nexport * from '@xyo-network/diviner-address-history-model'\n"],"mappings":";;;;;;;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,cAAc;AAEvB,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;EAIpH,IAAIC,eAAe;AACjB,WAAOC,SAAS,KAAKC,OAAOC,SAAS,MAAM,iBAAA;EAC7C;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,aAAS,EAACI,qCAAUC,SAAQ,MAAM,uEAAA;AAElC,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,IAAIC,CAAAA,UAASf,SAASgB,eAAeC,OAAOF,MAAMG,MAAK,CAAA,CAAA,CAAA;EACvE;EAEA,MAAcZ,oBAAoB;AAChC,UAAMa,cACD,MAAMC,QAAQC,IAAI,MAAM,KAAKC,QAAQ;MAAEC,OAAO;QAAC;UAACC;;;IAA0B,CAAA,CAAA,GAAKV,IAAIW,CAAAA,QACpFC,oBAAoBD,KAAK,uCAAuCA,IAAIE,EAAE,GAAG,CAAA,KACtE,CAAA;AACP3B,aAASmB,WAAWd,SAAS,GAAG,MAAM,6BAAA;AACtC,YACE,MAAMe,QAAQC,IACZF,WAAWL,IAAI,OAAOc,cAAAA;AA1C9B;AA2CU,YAAMP,MAAM,QAAMO,eAAUP,QAAVO;AAClB,aAAOP,2BAAKQ,OAAOC;IACrB,CAAA,CAAA,GAGDC,KAAI,EACJF,OAAOG,MAAAA;EACZ;EAEQnB,mBAAmBX,SAAkBK,WAAyE;AAEpH,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,gBACGH,KAAKG,YAAAA,GACR;AACAH,eAAKC,GAAAA,EAAKI,KAAI,GAAIL,KAAKG,YAAAA,CAAa;AACpC,iBAAOH,KAAKG,YAAAA;QACd;MACF;AACA,aAAOH;IACT,GAAGH,aAAAA;EACL;AACF;AA3DsHnC;AACpH,cADWD,wBACc6C,iBAA0B;KAAI,2DAAMA;EAAeC;;AAC5E,cAFW9C,wBAEc+C,uBAA8BD;AAFlD,IAAM9C,wBAAN;;;ACdP,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","mod","asArchivistInstance","id","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push","configSchemas","AddressHistoryDivinerConfigSchema","defaultConfigSchema"]}
package/package.json CHANGED
@@ -10,25 +10,25 @@
10
10
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/issues"
11
11
  },
12
12
  "dependencies": {
13
- "@xylabs/assert": "^3.6.6",
14
- "@xylabs/exists": "^3.6.6",
15
- "@xylabs/hex": "^3.6.6",
16
- "@xyo-network/archivist-model": "^2.110.18",
17
- "@xyo-network/boundwitness-builder": "^2.110.18",
18
- "@xyo-network/boundwitness-model": "^2.110.18",
19
- "@xyo-network/diviner-abstract": "^2.110.18",
20
- "@xyo-network/diviner-address-history-model": "^2.110.18",
21
- "@xyo-network/payload-builder": "^2.110.18",
22
- "@xyo-network/payload-model": "^2.110.18",
23
- "@xyo-network/payload-wrapper": "^2.110.18"
13
+ "@xylabs/assert": "^3.6.8",
14
+ "@xylabs/exists": "^3.6.8",
15
+ "@xylabs/hex": "^3.6.8",
16
+ "@xyo-network/archivist-model": "^2.111.0",
17
+ "@xyo-network/boundwitness-builder": "^2.111.0",
18
+ "@xyo-network/boundwitness-model": "^2.111.0",
19
+ "@xyo-network/diviner-abstract": "^2.111.0",
20
+ "@xyo-network/diviner-address-history-model": "^2.111.0",
21
+ "@xyo-network/payload-builder": "^2.111.0",
22
+ "@xyo-network/payload-model": "^2.111.0",
23
+ "@xyo-network/payload-wrapper": "^2.111.0"
24
24
  },
25
25
  "devDependencies": {
26
- "@xylabs/ts-scripts-yarn3": "^3.14.1",
27
- "@xylabs/tsconfig": "^3.14.1",
28
- "@xyo-network/account": "^2.110.18",
29
- "@xyo-network/archivist-memory": "^2.110.18",
30
- "@xyo-network/archivist-wrapper": "^2.110.18",
31
- "@xyo-network/node-memory": "^2.110.18",
26
+ "@xylabs/ts-scripts-yarn3": "^3.15.5",
27
+ "@xylabs/tsconfig": "^3.15.5",
28
+ "@xyo-network/account": "^2.111.0",
29
+ "@xyo-network/archivist-memory": "^2.111.0",
30
+ "@xyo-network/archivist-wrapper": "^2.111.0",
31
+ "@xyo-network/node-memory": "^2.111.0",
32
32
  "typescript": "^5.5.4"
33
33
  },
34
34
  "description": "Primary SDK for using XYO Protocol 2.0",
@@ -42,7 +42,7 @@
42
42
  },
43
43
  "import": {
44
44
  "types": "./dist/browser/index.d.mts",
45
- "default": "./dist/browser/index.js"
45
+ "default": "./dist/browser/index.mjs"
46
46
  }
47
47
  },
48
48
  "node": {
@@ -52,14 +52,14 @@
52
52
  },
53
53
  "import": {
54
54
  "types": "./dist/node/index.d.mts",
55
- "default": "./dist/node/index.js"
55
+ "default": "./dist/node/index.mjs"
56
56
  }
57
57
  }
58
58
  },
59
59
  "./package.json": "./package.json"
60
60
  },
61
61
  "main": "dist/node/index.cjs",
62
- "module": "dist/node/index.js",
62
+ "module": "dist/node/index.mjs",
63
63
  "homepage": "https://xyo.network",
64
64
  "license": "LGPL-3.0-only",
65
65
  "publishConfig": {
@@ -70,6 +70,6 @@
70
70
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
71
71
  },
72
72
  "sideEffects": false,
73
- "version": "2.110.18",
73
+ "version": "2.111.0",
74
74
  "type": "module"
75
75
  }
package/src/Diviner.ts CHANGED
@@ -29,12 +29,12 @@ export class AddressHistoryDiviner<TParams extends AddressHistoryDivinerParams =
29
29
  const chains = Object.values(this.buildAddressChains(this.queryAddress, bwRecords))
30
30
 
31
31
  // Return the heads of each chain (get the last bw on each chain)
32
- return chains.map((chain) => assertEx(PayloadWrapper.unwrap(chain.shift())))
32
+ return chains.map(chain => assertEx(PayloadWrapper.unwrap(chain.shift())))
33
33
  }
34
34
 
35
35
  private async allBoundWitnesses() {
36
- const archivists =
37
- (await Promise.all(await this.resolve({ query: [[ArchivistGetQuerySchema]] }))).map((mod) =>
36
+ const archivists
37
+ = (await Promise.all(await this.resolve({ query: [[ArchivistGetQuerySchema]] }))).map(mod =>
38
38
  asArchivistInstance(mod, `Failed to cast module to Archivist [${mod.id}]`),
39
39
  ) ?? []
40
40
  assertEx(archivists.length > 0, () => 'Did not find any archivists')
@@ -58,12 +58,12 @@ export class AddressHistoryDiviner<TParams extends AddressHistoryDivinerParams =
58
58
  }, {})
59
59
  // eslint-disable-next-line unicorn/no-array-reduce
60
60
  return Object.entries(bwRecords).reduce<Record<string, BoundWitness[]>>((prev, [key, value]) => {
61
- //check if key is still there (may have been deleted as prevHash)
61
+ // check if key is still there (may have been deleted as prevHash)
62
62
  if (prev[key]) {
63
63
  const previousHash = BoundWitnessBuilder.previousHash(value, address)
64
64
  if (
65
- previousHash && //if we have the previousHash, move this bw to its chain
66
- prev[previousHash]
65
+ previousHash // if we have the previousHash, move this bw to its chain
66
+ && prev[previousHash]
67
67
  ) {
68
68
  prev[key].push(...prev[previousHash])
69
69
  delete prev[previousHash]
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/Diviner.ts","../../src/index.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\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, Schema } 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 readonly configSchemas: Schema[] = [...super.configSchemas, AddressHistoryDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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((mod) =>\n asArchivistInstance(mod, `Failed to cast module to Archivist [${mod.id}]`),\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: Address, 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.ts'\nexport * from '@xyo-network/diviner-address-history-model'\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,cAAc;AAEvB,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;EAftH,OAesHA;;;EACpH,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,IAAIE,eAAe;AACjB,WAAOC,SAAS,KAAKC,OAAOC,SAAS,MAAM,iBAAA;EAC7C;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,aAAS,CAACI,UAAUC,QAAQ,MAAM,uEAAA;AAElC,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,QACnFC,oBAAoBD,KAAK,uCAAuCA,IAAIE,EAAE,GAAG,CAAA,KACtE,CAAA;AACP3B,aAASmB,WAAWd,SAAS,GAAG,MAAM,6BAAA;AACtC,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,SAAkBK,WAAyE;AAEpH,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;;;ACzEA,cAAc;","names":["assertEx","exists","ArchivistGetQuerySchema","asArchivistInstance","BoundWitnessBuilder","isBoundWitnessWithMeta","AbstractDiviner","AddressHistoryDivinerConfigSchema","PayloadBuilder","PayloadWrapper","AddressHistoryDiviner","AbstractDiviner","configSchemas","AddressHistoryDivinerConfigSchema","defaultConfigSchema","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","mod","asArchivistInstance","id","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/Diviner.ts","../../src/index.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\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, Schema } 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 readonly configSchemas: Schema[] = [...super.configSchemas, AddressHistoryDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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((mod) =>\n asArchivistInstance(mod, `Failed to cast module to Archivist [${mod.id}]`),\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: Address, 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.ts'\nexport * from '@xyo-network/diviner-address-history-model'\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,cAAc;AAEvB,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;EAftH,OAesHA;;;EACpH,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,IAAIE,eAAe;AACjB,WAAOC,SAAS,KAAKC,OAAOC,SAAS,MAAM,iBAAA;EAC7C;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,aAAS,CAACI,UAAUC,QAAQ,MAAM,uEAAA;AAElC,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,QACnFC,oBAAoBD,KAAK,uCAAuCA,IAAIE,EAAE,GAAG,CAAA,KACtE,CAAA;AACP3B,aAASmB,WAAWd,SAAS,GAAG,MAAM,6BAAA;AACtC,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,SAAkBK,WAAyE;AAEpH,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;;;ACzEA,cAAc;","names":["assertEx","exists","ArchivistGetQuerySchema","asArchivistInstance","BoundWitnessBuilder","isBoundWitnessWithMeta","AbstractDiviner","AddressHistoryDivinerConfigSchema","PayloadBuilder","PayloadWrapper","AddressHistoryDiviner","AbstractDiviner","configSchemas","AddressHistoryDivinerConfigSchema","defaultConfigSchema","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","mod","asArchivistInstance","id","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/Diviner.ts","../../src/index.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\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, Schema } 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 readonly configSchemas: Schema[] = [...super.configSchemas, AddressHistoryDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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((mod) =>\n asArchivistInstance(mod, `Failed to cast module to Archivist [${mod.id}]`),\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: Address, 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.ts'\nexport * from '@xyo-network/diviner-address-history-model'\n"],"mappings":";;;;;;;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,cAAc;AAEvB,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;EAIpH,IAAIC,eAAe;AACjB,WAAOC,SAAS,KAAKC,OAAOC,SAAS,MAAM,iBAAA;EAC7C;EAEA,MAAyBC,cAAcC,UAA0C;AAC/EJ,aAAS,EAACI,qCAAUC,SAAQ,MAAM,uEAAA;AAElC,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,QACnFC,oBAAoBD,KAAK,uCAAuCA,IAAIE,EAAE,GAAG,CAAA,KACtE,CAAA;AACP3B,aAASmB,WAAWd,SAAS,GAAG,MAAM,6BAAA;AACtC,YACE,MAAMe,QAAQC,IACZF,WAAWL,IAAI,OAAOc,cAAAA;AA1C9B;AA2CU,YAAMP,MAAM,QAAMO,eAAUP,QAAVO;AAClB,aAAOP,2BAAKQ,OAAOC;IACrB,CAAA,CAAA,GAGDC,KAAI,EACJF,OAAOG,MAAAA;EACZ;EAEQnB,mBAAmBX,SAAkBK,WAAyE;AAEpH,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;AA3DsHnC;AACpH,cADWD,wBACc6C,iBAA0B;KAAI,2DAAMA;EAAeC;;AAC5E,cAFW9C,wBAEc+C,uBAA8BD;AAFlD,IAAM9C,wBAAN;;;ACdP,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","mod","asArchivistInstance","id","archivist","filter","isBoundWitnessWithMeta","flat","exists","arrayedResult","entries","reduce","prev","key","value","previousHash","BoundWitnessBuilder","push","configSchemas","AddressHistoryDivinerConfigSchema","defaultConfigSchema"]}