@xyo-network/diviner-payload-pointer-memory 2.110.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (115) hide show
  1. package/LICENSE +165 -0
  2. package/README.md +13 -0
  3. package/dist/browser/Diviner.d.cts +13 -0
  4. package/dist/browser/Diviner.d.cts.map +1 -0
  5. package/dist/browser/Diviner.d.mts +13 -0
  6. package/dist/browser/Diviner.d.mts.map +1 -0
  7. package/dist/browser/Diviner.d.ts +13 -0
  8. package/dist/browser/Diviner.d.ts.map +1 -0
  9. package/dist/browser/combineRules.d.cts +3 -0
  10. package/dist/browser/combineRules.d.cts.map +1 -0
  11. package/dist/browser/combineRules.d.mts +3 -0
  12. package/dist/browser/combineRules.d.mts.map +1 -0
  13. package/dist/browser/combineRules.d.ts +3 -0
  14. package/dist/browser/combineRules.d.ts.map +1 -0
  15. package/dist/browser/findPayload.d.cts +7 -0
  16. package/dist/browser/findPayload.d.cts.map +1 -0
  17. package/dist/browser/findPayload.d.mts +7 -0
  18. package/dist/browser/findPayload.d.mts.map +1 -0
  19. package/dist/browser/findPayload.d.ts +7 -0
  20. package/dist/browser/findPayload.d.ts.map +1 -0
  21. package/dist/browser/index.cjs +170 -0
  22. package/dist/browser/index.cjs.map +1 -0
  23. package/dist/browser/index.d.cts +2 -0
  24. package/dist/browser/index.d.cts.map +1 -0
  25. package/dist/browser/index.d.mts +2 -0
  26. package/dist/browser/index.d.mts.map +1 -0
  27. package/dist/browser/index.d.ts +2 -0
  28. package/dist/browser/index.d.ts.map +1 -0
  29. package/dist/browser/index.js +149 -0
  30. package/dist/browser/index.js.map +1 -0
  31. package/dist/neutral/Diviner.d.cts +13 -0
  32. package/dist/neutral/Diviner.d.cts.map +1 -0
  33. package/dist/neutral/Diviner.d.mts +13 -0
  34. package/dist/neutral/Diviner.d.mts.map +1 -0
  35. package/dist/neutral/Diviner.d.ts +13 -0
  36. package/dist/neutral/Diviner.d.ts.map +1 -0
  37. package/dist/neutral/combineRules.d.cts +3 -0
  38. package/dist/neutral/combineRules.d.cts.map +1 -0
  39. package/dist/neutral/combineRules.d.mts +3 -0
  40. package/dist/neutral/combineRules.d.mts.map +1 -0
  41. package/dist/neutral/combineRules.d.ts +3 -0
  42. package/dist/neutral/combineRules.d.ts.map +1 -0
  43. package/dist/neutral/findPayload.d.cts +7 -0
  44. package/dist/neutral/findPayload.d.cts.map +1 -0
  45. package/dist/neutral/findPayload.d.mts +7 -0
  46. package/dist/neutral/findPayload.d.mts.map +1 -0
  47. package/dist/neutral/findPayload.d.ts +7 -0
  48. package/dist/neutral/findPayload.d.ts.map +1 -0
  49. package/dist/neutral/index.cjs +170 -0
  50. package/dist/neutral/index.cjs.map +1 -0
  51. package/dist/neutral/index.d.cts +2 -0
  52. package/dist/neutral/index.d.cts.map +1 -0
  53. package/dist/neutral/index.d.mts +2 -0
  54. package/dist/neutral/index.d.mts.map +1 -0
  55. package/dist/neutral/index.d.ts +2 -0
  56. package/dist/neutral/index.d.ts.map +1 -0
  57. package/dist/neutral/index.js +149 -0
  58. package/dist/neutral/index.js.map +1 -0
  59. package/dist/node/Diviner.d.cts +13 -0
  60. package/dist/node/Diviner.d.cts.map +1 -0
  61. package/dist/node/Diviner.d.mts +13 -0
  62. package/dist/node/Diviner.d.mts.map +1 -0
  63. package/dist/node/Diviner.d.ts +13 -0
  64. package/dist/node/Diviner.d.ts.map +1 -0
  65. package/dist/node/combineRules.d.cts +3 -0
  66. package/dist/node/combineRules.d.cts.map +1 -0
  67. package/dist/node/combineRules.d.mts +3 -0
  68. package/dist/node/combineRules.d.mts.map +1 -0
  69. package/dist/node/combineRules.d.ts +3 -0
  70. package/dist/node/combineRules.d.ts.map +1 -0
  71. package/dist/node/findPayload.d.cts +7 -0
  72. package/dist/node/findPayload.d.cts.map +1 -0
  73. package/dist/node/findPayload.d.mts +7 -0
  74. package/dist/node/findPayload.d.mts.map +1 -0
  75. package/dist/node/findPayload.d.ts +7 -0
  76. package/dist/node/findPayload.d.ts.map +1 -0
  77. package/dist/node/index.cjs +182 -0
  78. package/dist/node/index.cjs.map +1 -0
  79. package/dist/node/index.d.cts +2 -0
  80. package/dist/node/index.d.cts.map +1 -0
  81. package/dist/node/index.d.mts +2 -0
  82. package/dist/node/index.d.mts.map +1 -0
  83. package/dist/node/index.d.ts +2 -0
  84. package/dist/node/index.d.ts.map +1 -0
  85. package/dist/node/index.js +157 -0
  86. package/dist/node/index.js.map +1 -0
  87. package/package.json +87 -0
  88. package/src/Diviner.ts +70 -0
  89. package/src/combineRules.ts +42 -0
  90. package/src/findPayload.ts +67 -0
  91. package/src/index.ts +1 -0
  92. package/src/spec/testUtil/Account/index.ts +12 -0
  93. package/src/spec/testUtil/Archivist/getArchivist.ts +9 -0
  94. package/src/spec/testUtil/Archivist/index.ts +1 -0
  95. package/src/spec/testUtil/Block/getNewBlock.ts +35 -0
  96. package/src/spec/testUtil/Block/index.ts +2 -0
  97. package/src/spec/testUtil/Block/insertBlock.ts +11 -0
  98. package/src/spec/testUtil/BoundWitness/getNewBoundWitness.ts +25 -0
  99. package/src/spec/testUtil/BoundWitness/index.ts +1 -0
  100. package/src/spec/testUtil/Diviner/getPayloadPointerDiviner.ts +10 -0
  101. package/src/spec/testUtil/Diviner/index.ts +1 -0
  102. package/src/spec/testUtil/Model/TestWeb3User.ts +4 -0
  103. package/src/spec/testUtil/Model/index.ts +1 -0
  104. package/src/spec/testUtil/Node/getTestNode.ts +43 -0
  105. package/src/spec/testUtil/Node/index.ts +1 -0
  106. package/src/spec/testUtil/Payload/getNewPayload.ts +14 -0
  107. package/src/spec/testUtil/Payload/index.ts +2 -0
  108. package/src/spec/testUtil/Payload/insertPayload.ts +10 -0
  109. package/src/spec/testUtil/Payload/schema.ts +1 -0
  110. package/src/spec/testUtil/Pointer/createPointer.ts +38 -0
  111. package/src/spec/testUtil/Pointer/index.ts +1 -0
  112. package/src/spec/testUtil/Schema/getTestSchemaName.ts +7 -0
  113. package/src/spec/testUtil/Schema/index.ts +1 -0
  114. package/src/spec/testUtil/index.ts +10 -0
  115. package/typedoc.json +5 -0
@@ -0,0 +1,157 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getProtoOf = Object.getPrototypeOf;
3
+ var __reflectGet = Reflect.get;
4
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
5
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
6
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
7
+ var __superGet = (cls, obj, key) => __reflectGet(__getProtoOf(cls), key, obj);
8
+
9
+ // src/Diviner.ts
10
+ import { assertEx as assertEx2 } from "@xylabs/assert";
11
+ import { AbstractDiviner } from "@xyo-network/diviner-abstract";
12
+ import { asDivinerInstance } from "@xyo-network/diviner-model";
13
+ import { isPointerPayload, PayloadPointerDivinerConfigSchema } from "@xyo-network/diviner-payload-pointer-model";
14
+
15
+ // src/findPayload.ts
16
+ import { BoundWitnessWrapper } from "@xyo-network/boundwitness-wrapper";
17
+ import { BoundWitnessDivinerQuerySchema } from "@xyo-network/diviner-boundwitness-model";
18
+ import { PayloadDivinerQuerySchema } from "@xyo-network/diviner-payload-model";
19
+ import { isBoundWitnessPointer } from "@xyo-network/diviner-payload-pointer-model";
20
+ import { PayloadWrapper } from "@xyo-network/payload-wrapper";
21
+
22
+ // src/combineRules.ts
23
+ import { assertEx } from "@xylabs/assert";
24
+ import { exists } from "@xylabs/exists";
25
+ import { isPayloadAddressRule, isPayloadSchemaRule, isPayloadTimestampOrderRule } from "@xyo-network/diviner-payload-pointer-model";
26
+ var combineRules = /* @__PURE__ */ __name((rules) => {
27
+ var _a, _b;
28
+ const addresses = rules.flat().filter(isPayloadAddressRule).map((r) => r.address).filter(exists);
29
+ const schemas = rules.flat().filter(isPayloadSchemaRule).map((r) => r.schema).filter(exists);
30
+ assertEx(schemas.length, () => "At least one schema must be supplied");
31
+ const directionTimestamp = rules.flat().filter(isPayloadTimestampOrderRule).filter(exists);
32
+ assertEx(directionTimestamp.length < 2, () => "Must not supply more than 1 direction/timestamp rule");
33
+ const order = ((_a = directionTimestamp[0]) == null ? void 0 : _a.order) || "desc";
34
+ const timestamp = directionTimestamp.length > 0 ? (_b = directionTimestamp[0]) == null ? void 0 : _b.timestamp : Date.now();
35
+ return {
36
+ addresses,
37
+ order,
38
+ schemas,
39
+ timestamp
40
+ };
41
+ }, "combineRules");
42
+
43
+ // src/findPayload.ts
44
+ var limit = 1;
45
+ var createBoundWitnessFilterFromSearchCriteria = /* @__PURE__ */ __name((searchCriteria) => {
46
+ const { addresses, order = "desc", schemas, timestamp } = searchCriteria;
47
+ const query = {
48
+ addresses,
49
+ limit,
50
+ order,
51
+ payload_schemas: schemas,
52
+ schema: BoundWitnessDivinerQuerySchema,
53
+ timestamp
54
+ };
55
+ return [
56
+ query
57
+ ];
58
+ }, "createBoundWitnessFilterFromSearchCriteria");
59
+ var createPayloadFilterFromSearchCriteria = /* @__PURE__ */ __name((searchCriteria) => {
60
+ const { order = "desc", schemas, timestamp } = searchCriteria;
61
+ const query = {
62
+ limit,
63
+ order,
64
+ schema: PayloadDivinerQuerySchema,
65
+ schemas,
66
+ timestamp
67
+ };
68
+ return [
69
+ query
70
+ ];
71
+ }, "createPayloadFilterFromSearchCriteria");
72
+ var findPayload = /* @__PURE__ */ __name(async (archivist, boundWitnessDiviner, payloadDiviner, pointer) => {
73
+ const searchCriteria = combineRules(pointer.reference);
74
+ const { addresses } = searchCriteria;
75
+ const findWitnessedPayload = addresses == null ? void 0 : addresses.length;
76
+ const returnBoundWitness = isBoundWitnessPointer(pointer);
77
+ if (returnBoundWitness || findWitnessedPayload) {
78
+ const filter = createBoundWitnessFilterFromSearchCriteria(searchCriteria);
79
+ const result = await boundWitnessDiviner.divine(filter);
80
+ const bw = (result == null ? void 0 : result[0]) ? BoundWitnessWrapper.parse(result[0]) : void 0;
81
+ if (bw) {
82
+ if (returnBoundWitness) return bw.payload;
83
+ const { schemas, order = "desc" } = searchCriteria;
84
+ let payloadIndex = order === "asc" ? 0 : bw.payloadHashes.length - 1;
85
+ if (schemas) {
86
+ const schemaInSearchCriteria = /* @__PURE__ */ __name((schema) => schemas.includes(schema), "schemaInSearchCriteria");
87
+ payloadIndex = order === "asc" ? bw.payloadSchemas.findIndex(schemaInSearchCriteria) : bw.payloadSchemas.findLastIndex(schemaInSearchCriteria);
88
+ }
89
+ const hash = bw.payloadHashes[payloadIndex];
90
+ const result2 = await archivist.get([
91
+ hash
92
+ ]);
93
+ return (result2 == null ? void 0 : result2[0]) ? PayloadWrapper.wrap(result2 == null ? void 0 : result2[0]).payload : void 0;
94
+ }
95
+ } else {
96
+ const filter = createPayloadFilterFromSearchCriteria(searchCriteria);
97
+ const result = await payloadDiviner.divine(filter);
98
+ return (result == null ? void 0 : result[0]) ? PayloadWrapper.wrap(result == null ? void 0 : result[0]).payload : void 0;
99
+ }
100
+ }, "findPayload");
101
+
102
+ // src/Diviner.ts
103
+ var _PayloadPointerDiviner = class _PayloadPointerDiviner extends AbstractDiviner {
104
+ async divineHandler(payloads) {
105
+ const pointer = payloads == null ? void 0 : payloads.find(isPointerPayload);
106
+ if (!pointer) return [];
107
+ const archivist = await this.getConfigArchivist();
108
+ const boundWitnessDiviner = await this.getBoundWitnessDiviner();
109
+ const payloadDiviner = await this.getPayloadDiviner();
110
+ const result = await findPayload(archivist, boundWitnessDiviner, payloadDiviner, pointer);
111
+ return result ? [
112
+ result
113
+ ] : [];
114
+ }
115
+ /**
116
+ * Returns the archivist instance for the given config
117
+ * @returns The archivist instance corresponding to the config
118
+ */
119
+ async getBoundWitnessDiviner() {
120
+ var _a;
121
+ const name = assertEx2((_a = this.config) == null ? void 0 : _a.boundWitnessDiviner, () => "Missing archivist in config");
122
+ const mod = assertEx2(await this.resolve(name), () => `Config.boundWitnessDiviner module value of ${name} not resolved`);
123
+ const diviner = assertEx2(asDivinerInstance(mod), () => `Module ${name} is not an BoundWitnessDiviner`);
124
+ return diviner;
125
+ }
126
+ /**
127
+ * Returns the archivist instance for the given config
128
+ * @returns The archivist instance corresponding to the config
129
+ */
130
+ async getConfigArchivist() {
131
+ var _a;
132
+ const name = assertEx2((_a = this.config) == null ? void 0 : _a.archivist, () => "Missing archivist in config");
133
+ return assertEx2(await this.getArchivist(), () => `Config.archivist module value of ${name} not resolved`);
134
+ }
135
+ /**
136
+ * Returns the archivist instance for the given config
137
+ * @returns The archivist instance corresponding to the config
138
+ */
139
+ async getPayloadDiviner() {
140
+ var _a;
141
+ const name = assertEx2((_a = this.config) == null ? void 0 : _a.payloadDiviner, () => "Missing payloadDiviner in config");
142
+ const mod = assertEx2(await this.resolve(name), () => `Config.payloadDiviner module value of ${name} not resolved`);
143
+ const diviner = assertEx2(asDivinerInstance(mod), () => `Module ${name} is not an PayloadDiviner`);
144
+ return diviner;
145
+ }
146
+ };
147
+ __name(_PayloadPointerDiviner, "PayloadPointerDiviner");
148
+ __publicField(_PayloadPointerDiviner, "configSchemas", [
149
+ ...__superGet(_PayloadPointerDiviner, _PayloadPointerDiviner, "configSchemas"),
150
+ PayloadPointerDivinerConfigSchema
151
+ ]);
152
+ __publicField(_PayloadPointerDiviner, "defaultConfigSchema", PayloadPointerDivinerConfigSchema);
153
+ var PayloadPointerDiviner = _PayloadPointerDiviner;
154
+ export {
155
+ PayloadPointerDiviner
156
+ };
157
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/Diviner.ts","../../src/findPayload.ts","../../src/combineRules.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { BoundWitnessDiviner } from '@xyo-network/diviner-boundwitness-abstract'\nimport { asDivinerInstance, DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPointerPayload,\n PayloadPointerDivinerConfigSchema,\n PayloadPointerDivinerParams,\n PointerPayload,\n} from '@xyo-network/diviner-payload-pointer-model'\nimport { Payload, Schema } from '@xyo-network/payload-model'\n\nimport { findPayload } from './findPayload.js'\n\nexport class PayloadPointerDiviner<\n TParams extends PayloadPointerDivinerParams = PayloadPointerDivinerParams,\n TIn extends PointerPayload = PointerPayload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends AbstractDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadPointerDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadPointerDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n const pointer = payloads?.find(isPointerPayload)\n if (!pointer) return []\n const archivist = await this.getConfigArchivist()\n const boundWitnessDiviner = await this.getBoundWitnessDiviner()\n const payloadDiviner = await this.getPayloadDiviner()\n const result = (await findPayload(archivist, boundWitnessDiviner, payloadDiviner, pointer)) as TOut | undefined\n return result ? [result] : []\n }\n\n /**\n * Returns the archivist instance for the given config\n * @returns The archivist instance corresponding to the config\n */\n private async getBoundWitnessDiviner(): Promise<BoundWitnessDiviner> {\n const name = assertEx(this.config?.boundWitnessDiviner, () => 'Missing archivist in config')\n const mod = assertEx(await this.resolve(name), () => `Config.boundWitnessDiviner module value of ${name} not resolved`)\n const diviner = assertEx(asDivinerInstance(mod), () => `Module ${name} is not an BoundWitnessDiviner`)\n return diviner as BoundWitnessDiviner\n }\n\n /**\n * Returns the archivist instance for the given config\n * @returns The archivist instance corresponding to the config\n */\n private async getConfigArchivist(): Promise<ArchivistInstance> {\n const name = assertEx(this.config?.archivist, () => 'Missing archivist in config')\n return assertEx(await this.getArchivist(), () => `Config.archivist module value of ${name} not resolved`)\n }\n\n /**\n * Returns the archivist instance for the given config\n * @returns The archivist instance corresponding to the config\n */\n private async getPayloadDiviner(): Promise<PayloadDiviner> {\n const name = assertEx(this.config?.payloadDiviner, () => 'Missing payloadDiviner in config')\n const mod = assertEx(await this.resolve(name), () => `Config.payloadDiviner module value of ${name} not resolved`)\n const diviner = assertEx(asDivinerInstance(mod), () => `Module ${name} is not an PayloadDiviner`)\n return diviner as PayloadDiviner\n }\n}\n","import { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { BoundWitnessDiviner } from '@xyo-network/diviner-boundwitness-abstract'\nimport { BoundWitnessDivinerQueryPayload, BoundWitnessDivinerQuerySchema } from '@xyo-network/diviner-boundwitness-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport { PayloadDivinerQueryPayload, PayloadDivinerQuerySchema } from '@xyo-network/diviner-payload-model'\nimport { isBoundWitnessPointer, PayloadSearchCriteria, PointerPayload } from '@xyo-network/diviner-payload-pointer-model'\nimport { Payload, Schema } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nimport { combineRules } from './combineRules.js'\n\nconst limit = 1\n\nconst createBoundWitnessFilterFromSearchCriteria = (searchCriteria: PayloadSearchCriteria): BoundWitnessDivinerQueryPayload[] => {\n const { addresses, order = 'desc', schemas, timestamp } = searchCriteria\n const query: BoundWitnessDivinerQueryPayload = {\n addresses,\n limit,\n order,\n payload_schemas: schemas,\n schema: BoundWitnessDivinerQuerySchema,\n timestamp,\n }\n return [query]\n}\n\nconst createPayloadFilterFromSearchCriteria = (searchCriteria: PayloadSearchCriteria): Payload[] => {\n const { order = 'desc', schemas, timestamp } = searchCriteria\n const query: PayloadDivinerQueryPayload = { limit, order, schema: PayloadDivinerQuerySchema, schemas, timestamp }\n return [query]\n}\n\nexport const findPayload = async (\n archivist: ArchivistInstance,\n boundWitnessDiviner: BoundWitnessDiviner,\n payloadDiviner: PayloadDiviner,\n pointer: PointerPayload,\n): Promise<Payload | undefined> => {\n const searchCriteria = combineRules(pointer.reference)\n const { addresses } = searchCriteria\n const findWitnessedPayload = addresses?.length\n const returnBoundWitness = isBoundWitnessPointer(pointer)\n if (returnBoundWitness || findWitnessedPayload) {\n const filter = createBoundWitnessFilterFromSearchCriteria(searchCriteria)\n const result = await boundWitnessDiviner.divine(filter)\n const bw = result?.[0] ? BoundWitnessWrapper.parse(result[0]) : undefined\n if (bw) {\n if (returnBoundWitness) return bw.payload\n const { schemas, order = 'desc' } = searchCriteria\n let payloadIndex = order === 'asc' ? 0 : bw.payloadHashes.length - 1\n if (schemas) {\n const schemaInSearchCriteria = (schema: Schema) => schemas.includes(schema)\n payloadIndex = order === 'asc' ? bw.payloadSchemas.findIndex(schemaInSearchCriteria) : bw.payloadSchemas.findLastIndex(schemaInSearchCriteria)\n }\n const hash = bw.payloadHashes[payloadIndex]\n const result = await archivist.get([hash])\n return result?.[0] ? PayloadWrapper.wrap(result?.[0]).payload : undefined\n }\n }\n // Find payload\n else {\n const filter = createPayloadFilterFromSearchCriteria(searchCriteria)\n const result = await payloadDiviner.divine(filter)\n return result?.[0] ? PayloadWrapper.wrap(result?.[0]).payload : undefined\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\nimport { Order } from '@xyo-network/diviner-payload-model'\nimport {\n isPayloadAddressRule,\n isPayloadSchemaRule,\n isPayloadTimestampOrderRule,\n PayloadRule,\n PayloadSearchCriteria,\n} from '@xyo-network/diviner-payload-pointer-model'\n\n// TODO: Could make it so that composability is such that we:\n// • AND first dimension of array\n// • OR 2nd dimension of array\nexport const combineRules = (rules: PayloadRule[][]): PayloadSearchCriteria => {\n const addresses = rules\n .flat()\n .filter(isPayloadAddressRule)\n .map((r) => r.address)\n .filter(exists) as Address[]\n\n const schemas = rules\n .flat()\n .filter(isPayloadSchemaRule)\n .map((r) => r.schema)\n .filter(exists)\n assertEx(schemas.length, () => 'At least one schema must be supplied')\n\n const directionTimestamp = rules.flat().filter(isPayloadTimestampOrderRule).filter(exists)\n assertEx(directionTimestamp.length < 2, () => 'Must not supply more than 1 direction/timestamp rule')\n\n const order: Order = directionTimestamp[0]?.order || 'desc'\n const timestamp: number = directionTimestamp.length > 0 ? directionTimestamp[0]?.timestamp : Date.now()\n\n return {\n addresses,\n order,\n schemas,\n timestamp,\n }\n}\n"],"mappings":"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","names":["assertEx","AbstractDiviner","asDivinerInstance","isPointerPayload","PayloadPointerDivinerConfigSchema","BoundWitnessWrapper","BoundWitnessDivinerQuerySchema","PayloadDivinerQuerySchema","isBoundWitnessPointer","PayloadWrapper","assertEx","exists","isPayloadAddressRule","isPayloadSchemaRule","isPayloadTimestampOrderRule","combineRules","rules","addresses","flat","filter","isPayloadAddressRule","map","r","address","exists","schemas","isPayloadSchemaRule","schema","assertEx","length","directionTimestamp","isPayloadTimestampOrderRule","order","timestamp","Date","now","limit","createBoundWitnessFilterFromSearchCriteria","searchCriteria","addresses","order","schemas","timestamp","query","payload_schemas","schema","BoundWitnessDivinerQuerySchema","createPayloadFilterFromSearchCriteria","PayloadDivinerQuerySchema","findPayload","archivist","boundWitnessDiviner","payloadDiviner","pointer","combineRules","reference","findWitnessedPayload","length","returnBoundWitness","isBoundWitnessPointer","filter","result","divine","bw","BoundWitnessWrapper","parse","undefined","payload","payloadIndex","payloadHashes","schemaInSearchCriteria","includes","payloadSchemas","findIndex","findLastIndex","hash","get","PayloadWrapper","wrap","PayloadPointerDiviner","AbstractDiviner","divineHandler","payloads","pointer","find","isPointerPayload","archivist","getConfigArchivist","boundWitnessDiviner","getBoundWitnessDiviner","payloadDiviner","getPayloadDiviner","result","findPayload","name","assertEx","config","mod","resolve","diviner","asDivinerInstance","getArchivist","configSchemas","PayloadPointerDivinerConfigSchema","defaultConfigSchema"]}
package/package.json ADDED
@@ -0,0 +1,87 @@
1
+ {
2
+ "name": "@xyo-network/diviner-payload-pointer-memory",
3
+ "author": {
4
+ "email": "support@xyo.network",
5
+ "name": "XYO Development Team",
6
+ "url": "https://xyo.network"
7
+ },
8
+ "bugs": {
9
+ "email": "support@xyo.network",
10
+ "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/issues"
11
+ },
12
+ "dependencies": {
13
+ "@xylabs/assert": "^3.6.5",
14
+ "@xylabs/exists": "^3.6.5",
15
+ "@xylabs/hex": "^3.6.5",
16
+ "@xyo-network/archivist-model": "^2.110.13",
17
+ "@xyo-network/boundwitness-wrapper": "^2.110.13",
18
+ "@xyo-network/diviner-abstract": "^2.110.13",
19
+ "@xyo-network/diviner-boundwitness-abstract": "^2.110.13",
20
+ "@xyo-network/diviner-boundwitness-model": "^2.110.13",
21
+ "@xyo-network/diviner-model": "^2.110.13",
22
+ "@xyo-network/diviner-payload-abstract": "^2.110.13",
23
+ "@xyo-network/diviner-payload-model": "^2.110.13",
24
+ "@xyo-network/diviner-payload-pointer-model": "^2.110.11",
25
+ "@xyo-network/payload-model": "^2.110.13",
26
+ "@xyo-network/payload-wrapper": "^2.110.13"
27
+ },
28
+ "devDependencies": {
29
+ "@types/uuid": "^10.0.0",
30
+ "@xylabs/ts-scripts-yarn3": "^3.13.3",
31
+ "@xylabs/tsconfig": "^3.13.3",
32
+ "@xyo-network/account": "^2.110.13",
33
+ "@xyo-network/account-model": "^2.110.13",
34
+ "@xyo-network/archivist-memory": "^2.110.13",
35
+ "@xyo-network/boundwitness-builder": "^2.110.13",
36
+ "@xyo-network/boundwitness-model": "^2.110.13",
37
+ "@xyo-network/diviner-boundwitness-memory": "^2.110.13",
38
+ "@xyo-network/diviner-payload-memory": "^2.110.13",
39
+ "@xyo-network/node-memory": "^2.110.13",
40
+ "@xyo-network/node-model": "^2.110.13",
41
+ "@xyo-network/payload-builder": "^2.110.13",
42
+ "@xyo-network/wallet-model": "^2.110.13",
43
+ "typescript": "^5.5.4",
44
+ "uuid": "^10.0.0"
45
+ },
46
+ "description": "Primary SDK for using XYO Protocol 2.0",
47
+ "types": "dist/node/index.d.ts",
48
+ "exports": {
49
+ ".": {
50
+ "browser": {
51
+ "require": {
52
+ "types": "./dist/browser/index.d.cts",
53
+ "default": "./dist/browser/index.cjs"
54
+ },
55
+ "import": {
56
+ "types": "./dist/browser/index.d.mts",
57
+ "default": "./dist/browser/index.js"
58
+ }
59
+ },
60
+ "node": {
61
+ "require": {
62
+ "types": "./dist/node/index.d.cts",
63
+ "default": "./dist/node/index.cjs"
64
+ },
65
+ "import": {
66
+ "types": "./dist/node/index.d.mts",
67
+ "default": "./dist/node/index.js"
68
+ }
69
+ }
70
+ },
71
+ "./package.json": "./package.json"
72
+ },
73
+ "main": "dist/node/index.cjs",
74
+ "module": "dist/node/index.js",
75
+ "homepage": "https://xyo.network",
76
+ "license": "LGPL-3.0-only",
77
+ "publishConfig": {
78
+ "access": "public"
79
+ },
80
+ "repository": {
81
+ "type": "git",
82
+ "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
83
+ },
84
+ "sideEffects": false,
85
+ "version": "2.110.11",
86
+ "type": "module"
87
+ }
package/src/Diviner.ts ADDED
@@ -0,0 +1,70 @@
1
+ import { assertEx } from '@xylabs/assert'
2
+ import { ArchivistInstance } from '@xyo-network/archivist-model'
3
+ import { AbstractDiviner } from '@xyo-network/diviner-abstract'
4
+ import { BoundWitnessDiviner } from '@xyo-network/diviner-boundwitness-abstract'
5
+ import { asDivinerInstance, DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'
6
+ import { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'
7
+ import {
8
+ isPointerPayload,
9
+ PayloadPointerDivinerConfigSchema,
10
+ PayloadPointerDivinerParams,
11
+ PointerPayload,
12
+ } from '@xyo-network/diviner-payload-pointer-model'
13
+ import { Payload, Schema } from '@xyo-network/payload-model'
14
+
15
+ import { findPayload } from './findPayload.js'
16
+
17
+ export class PayloadPointerDiviner<
18
+ TParams extends PayloadPointerDivinerParams = PayloadPointerDivinerParams,
19
+ TIn extends PointerPayload = PointerPayload,
20
+ TOut extends Payload = Payload,
21
+ TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<
22
+ DivinerInstance<TParams, TIn, TOut>,
23
+ TIn,
24
+ TOut
25
+ >,
26
+ > extends AbstractDiviner<TParams, TIn, TOut, TEventData> {
27
+ static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadPointerDivinerConfigSchema]
28
+ static override readonly defaultConfigSchema: Schema = PayloadPointerDivinerConfigSchema
29
+
30
+ protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {
31
+ const pointer = payloads?.find(isPointerPayload)
32
+ if (!pointer) return []
33
+ const archivist = await this.getConfigArchivist()
34
+ const boundWitnessDiviner = await this.getBoundWitnessDiviner()
35
+ const payloadDiviner = await this.getPayloadDiviner()
36
+ const result = (await findPayload(archivist, boundWitnessDiviner, payloadDiviner, pointer)) as TOut | undefined
37
+ return result ? [result] : []
38
+ }
39
+
40
+ /**
41
+ * Returns the archivist instance for the given config
42
+ * @returns The archivist instance corresponding to the config
43
+ */
44
+ private async getBoundWitnessDiviner(): Promise<BoundWitnessDiviner> {
45
+ const name = assertEx(this.config?.boundWitnessDiviner, () => 'Missing archivist in config')
46
+ const mod = assertEx(await this.resolve(name), () => `Config.boundWitnessDiviner module value of ${name} not resolved`)
47
+ const diviner = assertEx(asDivinerInstance(mod), () => `Module ${name} is not an BoundWitnessDiviner`)
48
+ return diviner as BoundWitnessDiviner
49
+ }
50
+
51
+ /**
52
+ * Returns the archivist instance for the given config
53
+ * @returns The archivist instance corresponding to the config
54
+ */
55
+ private async getConfigArchivist(): Promise<ArchivistInstance> {
56
+ const name = assertEx(this.config?.archivist, () => 'Missing archivist in config')
57
+ return assertEx(await this.getArchivist(), () => `Config.archivist module value of ${name} not resolved`)
58
+ }
59
+
60
+ /**
61
+ * Returns the archivist instance for the given config
62
+ * @returns The archivist instance corresponding to the config
63
+ */
64
+ private async getPayloadDiviner(): Promise<PayloadDiviner> {
65
+ const name = assertEx(this.config?.payloadDiviner, () => 'Missing payloadDiviner in config')
66
+ const mod = assertEx(await this.resolve(name), () => `Config.payloadDiviner module value of ${name} not resolved`)
67
+ const diviner = assertEx(asDivinerInstance(mod), () => `Module ${name} is not an PayloadDiviner`)
68
+ return diviner as PayloadDiviner
69
+ }
70
+ }
@@ -0,0 +1,42 @@
1
+ import { assertEx } from '@xylabs/assert'
2
+ import { exists } from '@xylabs/exists'
3
+ import { Address } from '@xylabs/hex'
4
+ import { Order } from '@xyo-network/diviner-payload-model'
5
+ import {
6
+ isPayloadAddressRule,
7
+ isPayloadSchemaRule,
8
+ isPayloadTimestampOrderRule,
9
+ PayloadRule,
10
+ PayloadSearchCriteria,
11
+ } from '@xyo-network/diviner-payload-pointer-model'
12
+
13
+ // TODO: Could make it so that composability is such that we:
14
+ // • AND first dimension of array
15
+ // • OR 2nd dimension of array
16
+ export const combineRules = (rules: PayloadRule[][]): PayloadSearchCriteria => {
17
+ const addresses = rules
18
+ .flat()
19
+ .filter(isPayloadAddressRule)
20
+ .map((r) => r.address)
21
+ .filter(exists) as Address[]
22
+
23
+ const schemas = rules
24
+ .flat()
25
+ .filter(isPayloadSchemaRule)
26
+ .map((r) => r.schema)
27
+ .filter(exists)
28
+ assertEx(schemas.length, () => 'At least one schema must be supplied')
29
+
30
+ const directionTimestamp = rules.flat().filter(isPayloadTimestampOrderRule).filter(exists)
31
+ assertEx(directionTimestamp.length < 2, () => 'Must not supply more than 1 direction/timestamp rule')
32
+
33
+ const order: Order = directionTimestamp[0]?.order || 'desc'
34
+ const timestamp: number = directionTimestamp.length > 0 ? directionTimestamp[0]?.timestamp : Date.now()
35
+
36
+ return {
37
+ addresses,
38
+ order,
39
+ schemas,
40
+ timestamp,
41
+ }
42
+ }
@@ -0,0 +1,67 @@
1
+ import { ArchivistInstance } from '@xyo-network/archivist-model'
2
+ import { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'
3
+ import { BoundWitnessDiviner } from '@xyo-network/diviner-boundwitness-abstract'
4
+ import { BoundWitnessDivinerQueryPayload, BoundWitnessDivinerQuerySchema } from '@xyo-network/diviner-boundwitness-model'
5
+ import { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'
6
+ import { PayloadDivinerQueryPayload, PayloadDivinerQuerySchema } from '@xyo-network/diviner-payload-model'
7
+ import { isBoundWitnessPointer, PayloadSearchCriteria, PointerPayload } from '@xyo-network/diviner-payload-pointer-model'
8
+ import { Payload, Schema } from '@xyo-network/payload-model'
9
+ import { PayloadWrapper } from '@xyo-network/payload-wrapper'
10
+
11
+ import { combineRules } from './combineRules.js'
12
+
13
+ const limit = 1
14
+
15
+ const createBoundWitnessFilterFromSearchCriteria = (searchCriteria: PayloadSearchCriteria): BoundWitnessDivinerQueryPayload[] => {
16
+ const { addresses, order = 'desc', schemas, timestamp } = searchCriteria
17
+ const query: BoundWitnessDivinerQueryPayload = {
18
+ addresses,
19
+ limit,
20
+ order,
21
+ payload_schemas: schemas,
22
+ schema: BoundWitnessDivinerQuerySchema,
23
+ timestamp,
24
+ }
25
+ return [query]
26
+ }
27
+
28
+ const createPayloadFilterFromSearchCriteria = (searchCriteria: PayloadSearchCriteria): Payload[] => {
29
+ const { order = 'desc', schemas, timestamp } = searchCriteria
30
+ const query: PayloadDivinerQueryPayload = { limit, order, schema: PayloadDivinerQuerySchema, schemas, timestamp }
31
+ return [query]
32
+ }
33
+
34
+ export const findPayload = async (
35
+ archivist: ArchivistInstance,
36
+ boundWitnessDiviner: BoundWitnessDiviner,
37
+ payloadDiviner: PayloadDiviner,
38
+ pointer: PointerPayload,
39
+ ): Promise<Payload | undefined> => {
40
+ const searchCriteria = combineRules(pointer.reference)
41
+ const { addresses } = searchCriteria
42
+ const findWitnessedPayload = addresses?.length
43
+ const returnBoundWitness = isBoundWitnessPointer(pointer)
44
+ if (returnBoundWitness || findWitnessedPayload) {
45
+ const filter = createBoundWitnessFilterFromSearchCriteria(searchCriteria)
46
+ const result = await boundWitnessDiviner.divine(filter)
47
+ const bw = result?.[0] ? BoundWitnessWrapper.parse(result[0]) : undefined
48
+ if (bw) {
49
+ if (returnBoundWitness) return bw.payload
50
+ const { schemas, order = 'desc' } = searchCriteria
51
+ let payloadIndex = order === 'asc' ? 0 : bw.payloadHashes.length - 1
52
+ if (schemas) {
53
+ const schemaInSearchCriteria = (schema: Schema) => schemas.includes(schema)
54
+ payloadIndex = order === 'asc' ? bw.payloadSchemas.findIndex(schemaInSearchCriteria) : bw.payloadSchemas.findLastIndex(schemaInSearchCriteria)
55
+ }
56
+ const hash = bw.payloadHashes[payloadIndex]
57
+ const result = await archivist.get([hash])
58
+ return result?.[0] ? PayloadWrapper.wrap(result?.[0]).payload : undefined
59
+ }
60
+ }
61
+ // Find payload
62
+ else {
63
+ const filter = createPayloadFilterFromSearchCriteria(searchCriteria)
64
+ const result = await payloadDiviner.divine(filter)
65
+ return result?.[0] ? PayloadWrapper.wrap(result?.[0]).payload : undefined
66
+ }
67
+ }
package/src/index.ts ADDED
@@ -0,0 +1 @@
1
+ export * from './Diviner.js'
@@ -0,0 +1,12 @@
1
+ import { Account } from '@xyo-network/account'
2
+ import { AccountInstance } from '@xyo-network/account-model'
3
+
4
+ let _unitTestSigningAccount: Promise<AccountInstance> | undefined
5
+ let _otherUnitTestSigningAccount: Promise<AccountInstance> | undefined
6
+
7
+ export const unitTestSigningAccount = () =>
8
+ (_unitTestSigningAccount =
9
+ _unitTestSigningAccount ?? Account.create({ phrase: 'draw seven setup planet bitter return old bronze neither nephew panel pelican' }))
10
+ export const otherUnitTestSigningAccount = () =>
11
+ (_otherUnitTestSigningAccount =
12
+ _otherUnitTestSigningAccount ?? Account.create({ phrase: 'pitch rich dentist meadow few club place dirt push sustain innocent fix' }))
@@ -0,0 +1,9 @@
1
+ import { assertEx } from '@xylabs/assert'
2
+ import { ArchivistInstance, asArchivistInstance } from '@xyo-network/archivist-model'
3
+ import { NodeInstance } from '@xyo-network/node-model'
4
+
5
+ import { ArchivistName } from '../Node/getTestNode.js'
6
+
7
+ export const getArchivist = async (node: NodeInstance, name = ArchivistName): Promise<ArchivistInstance> => {
8
+ return assertEx(asArchivistInstance(await node.resolve(name)), () => `Could not find archivist with name ${name}`)
9
+ }
@@ -0,0 +1 @@
1
+ export * from './getArchivist.js'
@@ -0,0 +1,35 @@
1
+ import { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'
2
+ import { BoundWitness } from '@xyo-network/boundwitness-model'
3
+ import { Payload } from '@xyo-network/payload-model'
4
+
5
+ import { unitTestSigningAccount } from '../Account/index.js'
6
+ import { getNewPayloads } from '../Payload/index.js'
7
+
8
+ export const getNewBlock = async (...payloads: Payload[]): Promise<BoundWitness> => {
9
+ return (await (await new BoundWitnessBuilder().witness(await unitTestSigningAccount()).payloads(payloads)).build())[0]
10
+ }
11
+
12
+ export const getNewBlockWithPayloads = async (numPayloads = 1) => {
13
+ return getNewBlock(...(await getNewPayloads(numPayloads)))
14
+ }
15
+
16
+ export const getNewBlocks = async (numBoundWitnesses = 1): Promise<Array<BoundWitness>> => {
17
+ const sequence = Array.from({ length: numBoundWitnesses }).fill(0)
18
+ return await Promise.all(
19
+ sequence.map(async () => {
20
+ return (await new BoundWitnessBuilder().witness(await unitTestSigningAccount()).build())[0]
21
+ }),
22
+ )
23
+ }
24
+
25
+ export const getNewBlocksWithPayloads = async (numBoundWitnesses = 1, numPayloads = 1): Promise<Array<BoundWitness>> => {
26
+ return await Promise.all(
27
+ Array.from({ length: numBoundWitnesses })
28
+ .fill(0)
29
+ .map(async () => {
30
+ return (
31
+ await (await new BoundWitnessBuilder().witness(await unitTestSigningAccount()).payloads(await getNewPayloads(numPayloads))).build()
32
+ )[0]
33
+ }),
34
+ )
35
+ }
@@ -0,0 +1,2 @@
1
+ export * from './getNewBlock.js'
2
+ export * from './insertBlock.js'
@@ -0,0 +1,11 @@
1
+ import { ArchivistInstance } from '@xyo-network/archivist-model'
2
+ import { BoundWitness } from '@xyo-network/boundwitness-model'
3
+ import { Payload, WithMeta } from '@xyo-network/payload-model'
4
+
5
+ import { getNewBlock } from './getNewBlock.js'
6
+
7
+ export const insertBlock = async (archivist: ArchivistInstance, boundWitnesses?: BoundWitness | BoundWitness[]): Promise<WithMeta<Payload>[]> => {
8
+ boundWitnesses = boundWitnesses ?? (await getNewBlock())
9
+ const data = Array.isArray(boundWitnesses) ? boundWitnesses : [boundWitnesses]
10
+ return archivist.insert(data)
11
+ }
@@ -0,0 +1,25 @@
1
+ import { AccountInstance } from '@xyo-network/account-model'
2
+ import { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'
3
+ import { BoundWitness } from '@xyo-network/boundwitness-model'
4
+ import { ModuleError, Payload } from '@xyo-network/payload-model'
5
+
6
+ import { unitTestSigningAccount } from '../Account/index.js'
7
+ import { getNewPayloads } from '../Payload/index.js'
8
+
9
+ export const getNewBoundWitness = async (signers?: AccountInstance[], payloads?: Payload[]): Promise<[BoundWitness, Payload[], ModuleError[]]> => {
10
+ return await (await new BoundWitnessBuilder().payloads(payloads ?? (await getNewPayloads(1))))
11
+ .witnesses(signers ?? [await unitTestSigningAccount()])
12
+ .build()
13
+ }
14
+
15
+ export const getNewBoundWitnesses = async (
16
+ signers?: AccountInstance[],
17
+ numBoundWitnesses = 1,
18
+ numPayloads = 1,
19
+ ): Promise<[BoundWitness, Payload[], ModuleError[]][]> => {
20
+ const response: [BoundWitness, Payload[], ModuleError[]][] = []
21
+ for (let i = 0; i < numBoundWitnesses; i++) {
22
+ response.push(await getNewBoundWitness(signers ?? [await unitTestSigningAccount()], await getNewPayloads(numPayloads)))
23
+ }
24
+ return response
25
+ }
@@ -0,0 +1 @@
1
+ export * from './getNewBoundWitness.js'
@@ -0,0 +1,10 @@
1
+ import { asDivinerInstance } from '@xyo-network/diviner-model'
2
+ import { NodeInstance } from '@xyo-network/node-model'
3
+
4
+ import { PayloadPointerDiviner } from '../../../Diviner.js'
5
+ import { getTestNode, PayloadPointerDivinerName } from '../Node/index.js'
6
+
7
+ export const getPayloadPointerDiviner = async (node?: NodeInstance) => {
8
+ if (!node) node = await getTestNode()
9
+ return asDivinerInstance(await node?.resolve(PayloadPointerDivinerName)) as PayloadPointerDiviner
10
+ }
@@ -0,0 +1 @@
1
+ export * from './getPayloadPointerDiviner.js'
@@ -0,0 +1,4 @@
1
+ export interface TestWeb3User {
2
+ address: string
3
+ privateKey: string
4
+ }
@@ -0,0 +1 @@
1
+ export * from './TestWeb3User.js'
@@ -0,0 +1,43 @@
1
+ import { MemoryArchivist, MemoryArchivistConfigSchema } from '@xyo-network/archivist-memory'
2
+ import { MemoryBoundWitnessDiviner } from '@xyo-network/diviner-boundwitness-memory'
3
+ import { BoundWitnessDivinerConfigSchema } from '@xyo-network/diviner-boundwitness-model'
4
+ import { MemoryPayloadDiviner } from '@xyo-network/diviner-payload-memory'
5
+ import { PayloadDivinerConfigSchema } from '@xyo-network/diviner-payload-model'
6
+ import { PayloadPointerDivinerConfig, PayloadPointerDivinerConfigSchema } from '@xyo-network/diviner-payload-pointer-model'
7
+ import { MemoryNode } from '@xyo-network/node-memory'
8
+ import { NodeInstance } from '@xyo-network/node-model'
9
+
10
+ import { PayloadPointerDiviner } from '../../../Diviner.js'
11
+
12
+ export const ArchivistName = 'Archivist'
13
+ export const BoundWitnessDivinerName = 'BoundWitnessDiviner'
14
+ export const PayloadDivinerName = 'PayloadDiviner'
15
+ export const PayloadPointerDivinerName = 'PayloadPointerDiviner'
16
+
17
+ export const getTestNode = async (): Promise<NodeInstance> => {
18
+ const node = await MemoryNode.create()
19
+ const archivist = await MemoryArchivist.create({ account: 'random', config: { schema: MemoryArchivistConfigSchema, name: ArchivistName } })
20
+ const payloadDiviner = await MemoryPayloadDiviner.create({
21
+ account: 'random',
22
+ config: { schema: PayloadDivinerConfigSchema, name: PayloadDivinerName, archivist: ArchivistName },
23
+ })
24
+ const boundWitnessDiviner = await MemoryBoundWitnessDiviner.create({
25
+ account: 'random',
26
+ config: { schema: BoundWitnessDivinerConfigSchema, name: BoundWitnessDivinerName, archivist: ArchivistName },
27
+ })
28
+ const config: PayloadPointerDivinerConfig = {
29
+ schema: PayloadPointerDivinerConfigSchema,
30
+ archivist: ArchivistName,
31
+
32
+ payloadDiviner: PayloadDivinerName,
33
+ boundWitnessDiviner: BoundWitnessDivinerName,
34
+ name: PayloadPointerDivinerName,
35
+ }
36
+ const payloadPointerDiviner = await PayloadPointerDiviner.create({ account: 'random', config })
37
+ const children = [archivist, payloadDiviner, boundWitnessDiviner, payloadPointerDiviner]
38
+ for (const child of children) {
39
+ await node.register(child)
40
+ await node.attach(child.address, true)
41
+ }
42
+ return node
43
+ }
@@ -0,0 +1 @@
1
+ export * from './getTestNode.js'