@xyo-network/boundwitness-builder 2.74.5 → 2.75.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (158) hide show
  1. package/dist/browser/Builder.cjs +161 -0
  2. package/dist/browser/Builder.cjs.map +1 -0
  3. package/dist/browser/Builder.d.cts.map +1 -0
  4. package/dist/browser/Builder.d.mts.map +1 -0
  5. package/dist/browser/Builder.d.ts +41 -0
  6. package/dist/browser/Builder.d.ts.map +1 -0
  7. package/dist/browser/Builder.js +139 -0
  8. package/dist/browser/Builder.js.map +1 -0
  9. package/dist/browser/Query/QueryBoundWitness.cjs +30 -0
  10. package/dist/browser/Query/QueryBoundWitness.cjs.map +1 -0
  11. package/dist/browser/Query/QueryBoundWitness.d.cts.map +1 -0
  12. package/dist/browser/Query/QueryBoundWitness.d.mts.map +1 -0
  13. package/dist/browser/Query/QueryBoundWitness.d.ts +17 -0
  14. package/dist/browser/Query/QueryBoundWitness.d.ts.map +1 -0
  15. package/dist/browser/Query/QueryBoundWitness.js +8 -0
  16. package/dist/browser/Query/QueryBoundWitness.js.map +1 -0
  17. package/dist/browser/Query/QueryBoundWitnessBuilder.cjs +192 -0
  18. package/dist/browser/Query/QueryBoundWitnessBuilder.cjs.map +1 -0
  19. package/dist/browser/Query/QueryBoundWitnessBuilder.d.cts.map +1 -0
  20. package/dist/browser/Query/QueryBoundWitnessBuilder.d.mts.map +1 -0
  21. package/dist/browser/Query/QueryBoundWitnessBuilder.d.ts +11 -0
  22. package/dist/browser/Query/QueryBoundWitnessBuilder.d.ts.map +1 -0
  23. package/dist/browser/Query/QueryBoundWitnessBuilder.js +29 -0
  24. package/dist/browser/Query/QueryBoundWitnessBuilder.js.map +1 -0
  25. package/dist/browser/Query/QueryBoundWitnessValidator.cjs +76 -0
  26. package/dist/browser/Query/QueryBoundWitnessValidator.cjs.map +1 -0
  27. package/dist/browser/Query/QueryBoundWitnessValidator.d.cts.map +1 -0
  28. package/dist/browser/Query/QueryBoundWitnessValidator.d.mts.map +1 -0
  29. package/dist/browser/Query/QueryBoundWitnessValidator.d.ts +11 -0
  30. package/dist/browser/Query/QueryBoundWitnessValidator.d.ts.map +1 -0
  31. package/dist/browser/Query/QueryBoundWitnessValidator.js +49 -0
  32. package/dist/browser/Query/QueryBoundWitnessValidator.js.map +1 -0
  33. package/dist/browser/Query/QueryBoundWitnessWrapper.cjs +127 -0
  34. package/dist/browser/Query/QueryBoundWitnessWrapper.cjs.map +1 -0
  35. package/dist/browser/Query/QueryBoundWitnessWrapper.d.cts.map +1 -0
  36. package/dist/browser/Query/QueryBoundWitnessWrapper.d.mts.map +1 -0
  37. package/dist/browser/Query/QueryBoundWitnessWrapper.d.ts +18 -0
  38. package/dist/browser/Query/QueryBoundWitnessWrapper.d.ts.map +1 -0
  39. package/dist/browser/Query/QueryBoundWitnessWrapper.js +52 -0
  40. package/dist/browser/Query/QueryBoundWitnessWrapper.js.map +1 -0
  41. package/dist/browser/Query/index.cjs +294 -0
  42. package/dist/browser/Query/index.cjs.map +1 -0
  43. package/dist/browser/Query/index.d.cts.map +1 -0
  44. package/dist/browser/Query/index.d.mts.map +1 -0
  45. package/dist/browser/Query/index.d.ts +5 -0
  46. package/dist/browser/Query/index.d.ts.map +1 -0
  47. package/dist/browser/Query/index.js +5 -0
  48. package/dist/browser/Query/index.js.map +1 -0
  49. package/dist/{index.js → browser/index.cjs} +1 -10
  50. package/dist/browser/index.cjs.map +1 -0
  51. package/dist/browser/index.d.cts.map +1 -0
  52. package/dist/browser/index.d.mts.map +1 -0
  53. package/dist/browser/index.d.ts +3 -0
  54. package/dist/browser/index.d.ts.map +1 -0
  55. package/dist/browser/index.js +3 -0
  56. package/dist/browser/index.js.map +1 -0
  57. package/dist/docs.json +478 -478
  58. package/dist/node/Builder.d.cts +41 -0
  59. package/dist/node/Builder.d.cts.map +1 -0
  60. package/dist/node/Builder.d.mts +41 -0
  61. package/dist/node/Builder.d.mts.map +1 -0
  62. package/dist/node/Builder.d.ts +41 -0
  63. package/dist/node/Builder.d.ts.map +1 -0
  64. package/dist/node/Builder.js +169 -0
  65. package/dist/node/Builder.js.map +1 -0
  66. package/dist/node/Builder.mjs +144 -0
  67. package/dist/node/Builder.mjs.map +1 -0
  68. package/dist/node/Query/QueryBoundWitness.d.cts +17 -0
  69. package/dist/node/Query/QueryBoundWitness.d.cts.map +1 -0
  70. package/dist/node/Query/QueryBoundWitness.d.mts +17 -0
  71. package/dist/node/Query/QueryBoundWitness.d.mts.map +1 -0
  72. package/dist/node/Query/QueryBoundWitness.d.ts +17 -0
  73. package/dist/node/Query/QueryBoundWitness.d.ts.map +1 -0
  74. package/dist/node/Query/QueryBoundWitness.js +35 -0
  75. package/dist/node/Query/QueryBoundWitness.js.map +1 -0
  76. package/dist/node/Query/QueryBoundWitness.mjs +9 -0
  77. package/dist/node/Query/QueryBoundWitness.mjs.map +1 -0
  78. package/dist/node/Query/QueryBoundWitnessBuilder.d.cts +11 -0
  79. package/dist/node/Query/QueryBoundWitnessBuilder.d.cts.map +1 -0
  80. package/dist/node/Query/QueryBoundWitnessBuilder.d.mts +11 -0
  81. package/dist/node/Query/QueryBoundWitnessBuilder.d.mts.map +1 -0
  82. package/dist/node/Query/QueryBoundWitnessBuilder.d.ts +11 -0
  83. package/dist/node/Query/QueryBoundWitnessBuilder.d.ts.map +1 -0
  84. package/dist/node/Query/QueryBoundWitnessBuilder.js +201 -0
  85. package/dist/node/Query/QueryBoundWitnessBuilder.js.map +1 -0
  86. package/dist/node/Query/QueryBoundWitnessBuilder.mjs +176 -0
  87. package/dist/node/Query/QueryBoundWitnessBuilder.mjs.map +1 -0
  88. package/dist/node/Query/QueryBoundWitnessValidator.d.cts +11 -0
  89. package/dist/node/Query/QueryBoundWitnessValidator.d.cts.map +1 -0
  90. package/dist/node/Query/QueryBoundWitnessValidator.d.mts +11 -0
  91. package/dist/node/Query/QueryBoundWitnessValidator.d.mts.map +1 -0
  92. package/dist/node/Query/QueryBoundWitnessValidator.d.ts +11 -0
  93. package/dist/node/Query/QueryBoundWitnessValidator.d.ts.map +1 -0
  94. package/dist/node/Query/QueryBoundWitnessValidator.js +80 -0
  95. package/dist/node/Query/QueryBoundWitnessValidator.js.map +1 -0
  96. package/dist/node/Query/QueryBoundWitnessValidator.mjs +55 -0
  97. package/dist/node/Query/QueryBoundWitnessValidator.mjs.map +1 -0
  98. package/dist/node/Query/QueryBoundWitnessWrapper.d.cts +18 -0
  99. package/dist/node/Query/QueryBoundWitnessWrapper.d.cts.map +1 -0
  100. package/dist/node/Query/QueryBoundWitnessWrapper.d.mts +18 -0
  101. package/dist/node/Query/QueryBoundWitnessWrapper.d.mts.map +1 -0
  102. package/dist/node/Query/QueryBoundWitnessWrapper.d.ts +18 -0
  103. package/dist/node/Query/QueryBoundWitnessWrapper.d.ts.map +1 -0
  104. package/dist/node/Query/QueryBoundWitnessWrapper.js +131 -0
  105. package/dist/node/Query/QueryBoundWitnessWrapper.js.map +1 -0
  106. package/dist/node/Query/QueryBoundWitnessWrapper.mjs +106 -0
  107. package/dist/node/Query/QueryBoundWitnessWrapper.mjs.map +1 -0
  108. package/dist/node/Query/index.d.cts +5 -0
  109. package/dist/node/Query/index.d.cts.map +1 -0
  110. package/dist/node/Query/index.d.mts +5 -0
  111. package/dist/node/Query/index.d.mts.map +1 -0
  112. package/dist/node/Query/index.d.ts +5 -0
  113. package/dist/node/Query/index.d.ts.map +1 -0
  114. package/dist/node/Query/index.js +307 -0
  115. package/dist/node/Query/index.js.map +1 -0
  116. package/dist/node/Query/index.mjs +276 -0
  117. package/dist/node/Query/index.mjs.map +1 -0
  118. package/dist/node/index.d.cts +3 -0
  119. package/dist/node/index.d.cts.map +1 -0
  120. package/dist/node/index.d.mts +3 -0
  121. package/dist/node/index.d.mts.map +1 -0
  122. package/dist/node/index.d.ts +3 -0
  123. package/dist/node/index.d.ts.map +1 -0
  124. package/dist/node/index.js +307 -0
  125. package/dist/node/index.js.map +1 -0
  126. package/dist/{index.mjs → node/index.mjs} +16 -11
  127. package/dist/node/index.mjs.map +1 -0
  128. package/package.json +37 -34
  129. package/dist/Builder.d.mts.map +0 -1
  130. package/dist/Builder.d.ts.map +0 -1
  131. package/dist/Query/QueryBoundWitness.d.mts.map +0 -1
  132. package/dist/Query/QueryBoundWitness.d.ts.map +0 -1
  133. package/dist/Query/QueryBoundWitnessBuilder.d.mts.map +0 -1
  134. package/dist/Query/QueryBoundWitnessBuilder.d.ts.map +0 -1
  135. package/dist/Query/QueryBoundWitnessValidator.d.mts.map +0 -1
  136. package/dist/Query/QueryBoundWitnessValidator.d.ts.map +0 -1
  137. package/dist/Query/QueryBoundWitnessWrapper.d.mts.map +0 -1
  138. package/dist/Query/QueryBoundWitnessWrapper.d.ts.map +0 -1
  139. package/dist/Query/index.d.mts.map +0 -1
  140. package/dist/Query/index.d.ts.map +0 -1
  141. package/dist/index.d.mts.map +0 -1
  142. package/dist/index.d.ts.map +0 -1
  143. package/dist/index.js.map +0 -1
  144. package/dist/index.mjs.map +0 -1
  145. /package/dist/{Builder.d.mts → browser/Builder.d.cts} +0 -0
  146. /package/dist/{Builder.d.ts → browser/Builder.d.mts} +0 -0
  147. /package/dist/{Query/QueryBoundWitness.d.mts → browser/Query/QueryBoundWitness.d.cts} +0 -0
  148. /package/dist/{Query/QueryBoundWitness.d.ts → browser/Query/QueryBoundWitness.d.mts} +0 -0
  149. /package/dist/{Query/QueryBoundWitnessBuilder.d.mts → browser/Query/QueryBoundWitnessBuilder.d.cts} +0 -0
  150. /package/dist/{Query/QueryBoundWitnessBuilder.d.ts → browser/Query/QueryBoundWitnessBuilder.d.mts} +0 -0
  151. /package/dist/{Query/QueryBoundWitnessValidator.d.mts → browser/Query/QueryBoundWitnessValidator.d.cts} +0 -0
  152. /package/dist/{Query/QueryBoundWitnessValidator.d.ts → browser/Query/QueryBoundWitnessValidator.d.mts} +0 -0
  153. /package/dist/{Query/QueryBoundWitnessWrapper.d.mts → browser/Query/QueryBoundWitnessWrapper.d.cts} +0 -0
  154. /package/dist/{Query/QueryBoundWitnessWrapper.d.ts → browser/Query/QueryBoundWitnessWrapper.d.mts} +0 -0
  155. /package/dist/{Query/index.d.mts → browser/Query/index.d.cts} +0 -0
  156. /package/dist/{Query/index.d.ts → browser/Query/index.d.mts} +0 -0
  157. /package/dist/{index.d.mts → browser/index.d.cts} +0 -0
  158. /package/dist/{index.d.ts → browser/index.d.mts} +0 -0
@@ -0,0 +1,41 @@
1
+ import { AccountInstance } from '@xyo-network/account-model';
2
+ import { BoundWitness } from '@xyo-network/boundwitness-model';
3
+ import { Data } from '@xyo-network/core';
4
+ import { ModuleError, Payload } from '@xyo-network/payload-model';
5
+ import { Logger } from '@xyo-network/shared';
6
+ export interface BoundWitnessBuilderConfig {
7
+ /** Whether or not the payloads should be included in the metadata sent to and recorded by the ArchivistApi */
8
+ readonly inlinePayloads?: boolean;
9
+ readonly meta?: boolean;
10
+ readonly timestamp?: boolean;
11
+ }
12
+ export declare class BoundWitnessBuilder<TBoundWitness extends BoundWitness<{
13
+ schema: string;
14
+ }> = BoundWitness, TPayload extends Payload = Payload> {
15
+ readonly config: BoundWitnessBuilderConfig;
16
+ protected readonly logger?: Logger | undefined;
17
+ private static readonly _buildMutex;
18
+ private _accounts;
19
+ private _errorHashes;
20
+ private _errors;
21
+ private _payloadHashes;
22
+ private _payloadSchemas;
23
+ private _payloads;
24
+ private _timestamp;
25
+ constructor(config?: BoundWitnessBuilderConfig, logger?: Logger | undefined);
26
+ private get _payload_schemas();
27
+ build(meta?: boolean): Promise<[TBoundWitness, TPayload[], ModuleError[]]>;
28
+ error(payload?: ModuleError): this;
29
+ errors(errors?: (ModuleError | null)[]): this;
30
+ hashableFields(): Promise<TBoundWitness>;
31
+ hashes(hashes: string[], schema: string[]): this;
32
+ payload(payload?: TPayload): this;
33
+ payloads(payloads?: (TPayload | null)[]): this;
34
+ witness(account: AccountInstance): this;
35
+ witnesses(accounts: AccountInstance[]): this;
36
+ protected signatures(_hash: string, previousHashes: (string | Data | undefined)[]): Promise<string[]>;
37
+ private getPayloadHashes;
38
+ private inlinePayloads;
39
+ private missingSchemaMessage;
40
+ }
41
+ //# sourceMappingURL=Builder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Builder.d.ts","sourceRoot":"","sources":["../../src/Builder.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AAC5D,OAAO,EAAE,YAAY,EAAsB,MAAM,iCAAiC,CAAA;AAElF,OAAO,EAAE,IAAI,EAA6B,MAAM,mBAAmB,CAAA;AAEnE,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACjE,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AAG5C,MAAM,WAAW,yBAAyB;IACxC,8GAA8G;IAC9G,QAAQ,CAAC,cAAc,CAAC,EAAE,OAAO,CAAA;IACjC,QAAQ,CAAC,IAAI,CAAC,EAAE,OAAO,CAAA;IACvB,QAAQ,CAAC,SAAS,CAAC,EAAE,OAAO,CAAA;CAC7B;AAED,qBAAa,mBAAmB,CAAC,aAAa,SAAS,YAAY,CAAC;IAAE,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC,GAAG,YAAY,EAAE,QAAQ,SAAS,OAAO,GAAG,OAAO;IAWtI,QAAQ,CAAC,MAAM,EAAE,yBAAyB;IAC1C,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC;IAX5B,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,WAAW,CAAc;IACjD,OAAO,CAAC,SAAS,CAAwB;IACzC,OAAO,CAAC,YAAY,CAAsB;IAC1C,OAAO,CAAC,OAAO,CAAoB;IACnC,OAAO,CAAC,cAAc,CAAsB;IAC5C,OAAO,CAAC,eAAe,CAAsB;IAC7C,OAAO,CAAC,SAAS,CAAiB;IAClC,OAAO,CAAC,UAAU,CAAa;gBAGpB,MAAM,GAAE,yBAAqD,EACnD,MAAM,CAAC,oBAAQ;IAGpC,OAAO,KAAK,gBAAgB,GAO3B;IAEK,KAAK,CAAC,IAAI,UAAQ,GAAG,OAAO,CAAC,CAAC,aAAa,EAAE,QAAQ,EAAE,EAAE,WAAW,EAAE,CAAC,CAAC;IA6B9E,KAAK,CAAC,OAAO,CAAC,EAAE,WAAW;IAS3B,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,WAAW,GAAG,IAAI,CAAC,EAAE;IAShC,cAAc,IAAI,OAAO,CAAC,aAAa,CAAC;IA0B9C,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE;IAOzC,OAAO,CAAC,OAAO,CAAC,EAAE,QAAQ;IAS1B,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,GAAG,IAAI,CAAC,EAAE;IASvC,OAAO,CAAC,OAAO,EAAE,eAAe;IAKhC,SAAS,CAAC,QAAQ,EAAE,eAAe,EAAE;cAKrB,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,cAAc,EAAE,CAAC,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC,EAAE;YAOzE,gBAAgB;IAI9B,OAAO,CAAC,cAAc;IAStB,OAAO,CAAC,oBAAoB;CAG7B"}
@@ -0,0 +1,41 @@
1
+ import { AccountInstance } from '@xyo-network/account-model';
2
+ import { BoundWitness } from '@xyo-network/boundwitness-model';
3
+ import { Data } from '@xyo-network/core';
4
+ import { ModuleError, Payload } from '@xyo-network/payload-model';
5
+ import { Logger } from '@xyo-network/shared';
6
+ export interface BoundWitnessBuilderConfig {
7
+ /** Whether or not the payloads should be included in the metadata sent to and recorded by the ArchivistApi */
8
+ readonly inlinePayloads?: boolean;
9
+ readonly meta?: boolean;
10
+ readonly timestamp?: boolean;
11
+ }
12
+ export declare class BoundWitnessBuilder<TBoundWitness extends BoundWitness<{
13
+ schema: string;
14
+ }> = BoundWitness, TPayload extends Payload = Payload> {
15
+ readonly config: BoundWitnessBuilderConfig;
16
+ protected readonly logger?: Logger | undefined;
17
+ private static readonly _buildMutex;
18
+ private _accounts;
19
+ private _errorHashes;
20
+ private _errors;
21
+ private _payloadHashes;
22
+ private _payloadSchemas;
23
+ private _payloads;
24
+ private _timestamp;
25
+ constructor(config?: BoundWitnessBuilderConfig, logger?: Logger | undefined);
26
+ private get _payload_schemas();
27
+ build(meta?: boolean): Promise<[TBoundWitness, TPayload[], ModuleError[]]>;
28
+ error(payload?: ModuleError): this;
29
+ errors(errors?: (ModuleError | null)[]): this;
30
+ hashableFields(): Promise<TBoundWitness>;
31
+ hashes(hashes: string[], schema: string[]): this;
32
+ payload(payload?: TPayload): this;
33
+ payloads(payloads?: (TPayload | null)[]): this;
34
+ witness(account: AccountInstance): this;
35
+ witnesses(accounts: AccountInstance[]): this;
36
+ protected signatures(_hash: string, previousHashes: (string | Data | undefined)[]): Promise<string[]>;
37
+ private getPayloadHashes;
38
+ private inlinePayloads;
39
+ private missingSchemaMessage;
40
+ }
41
+ //# sourceMappingURL=Builder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Builder.d.ts","sourceRoot":"","sources":["../../src/Builder.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AAC5D,OAAO,EAAE,YAAY,EAAsB,MAAM,iCAAiC,CAAA;AAElF,OAAO,EAAE,IAAI,EAA6B,MAAM,mBAAmB,CAAA;AAEnE,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACjE,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AAG5C,MAAM,WAAW,yBAAyB;IACxC,8GAA8G;IAC9G,QAAQ,CAAC,cAAc,CAAC,EAAE,OAAO,CAAA;IACjC,QAAQ,CAAC,IAAI,CAAC,EAAE,OAAO,CAAA;IACvB,QAAQ,CAAC,SAAS,CAAC,EAAE,OAAO,CAAA;CAC7B;AAED,qBAAa,mBAAmB,CAAC,aAAa,SAAS,YAAY,CAAC;IAAE,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC,GAAG,YAAY,EAAE,QAAQ,SAAS,OAAO,GAAG,OAAO;IAWtI,QAAQ,CAAC,MAAM,EAAE,yBAAyB;IAC1C,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC;IAX5B,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,WAAW,CAAc;IACjD,OAAO,CAAC,SAAS,CAAwB;IACzC,OAAO,CAAC,YAAY,CAAsB;IAC1C,OAAO,CAAC,OAAO,CAAoB;IACnC,OAAO,CAAC,cAAc,CAAsB;IAC5C,OAAO,CAAC,eAAe,CAAsB;IAC7C,OAAO,CAAC,SAAS,CAAiB;IAClC,OAAO,CAAC,UAAU,CAAa;gBAGpB,MAAM,GAAE,yBAAqD,EACnD,MAAM,CAAC,oBAAQ;IAGpC,OAAO,KAAK,gBAAgB,GAO3B;IAEK,KAAK,CAAC,IAAI,UAAQ,GAAG,OAAO,CAAC,CAAC,aAAa,EAAE,QAAQ,EAAE,EAAE,WAAW,EAAE,CAAC,CAAC;IA6B9E,KAAK,CAAC,OAAO,CAAC,EAAE,WAAW;IAS3B,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,WAAW,GAAG,IAAI,CAAC,EAAE;IAShC,cAAc,IAAI,OAAO,CAAC,aAAa,CAAC;IA0B9C,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE;IAOzC,OAAO,CAAC,OAAO,CAAC,EAAE,QAAQ;IAS1B,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,GAAG,IAAI,CAAC,EAAE;IASvC,OAAO,CAAC,OAAO,EAAE,eAAe;IAKhC,SAAS,CAAC,QAAQ,EAAE,eAAe,EAAE;cAKrB,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,cAAc,EAAE,CAAC,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC,EAAE;YAOzE,gBAAgB;IAI9B,OAAO,CAAC,cAAc;IAStB,OAAO,CAAC,oBAAoB;CAG7B"}
@@ -0,0 +1,41 @@
1
+ import { AccountInstance } from '@xyo-network/account-model';
2
+ import { BoundWitness } from '@xyo-network/boundwitness-model';
3
+ import { Data } from '@xyo-network/core';
4
+ import { ModuleError, Payload } from '@xyo-network/payload-model';
5
+ import { Logger } from '@xyo-network/shared';
6
+ export interface BoundWitnessBuilderConfig {
7
+ /** Whether or not the payloads should be included in the metadata sent to and recorded by the ArchivistApi */
8
+ readonly inlinePayloads?: boolean;
9
+ readonly meta?: boolean;
10
+ readonly timestamp?: boolean;
11
+ }
12
+ export declare class BoundWitnessBuilder<TBoundWitness extends BoundWitness<{
13
+ schema: string;
14
+ }> = BoundWitness, TPayload extends Payload = Payload> {
15
+ readonly config: BoundWitnessBuilderConfig;
16
+ protected readonly logger?: Logger | undefined;
17
+ private static readonly _buildMutex;
18
+ private _accounts;
19
+ private _errorHashes;
20
+ private _errors;
21
+ private _payloadHashes;
22
+ private _payloadSchemas;
23
+ private _payloads;
24
+ private _timestamp;
25
+ constructor(config?: BoundWitnessBuilderConfig, logger?: Logger | undefined);
26
+ private get _payload_schemas();
27
+ build(meta?: boolean): Promise<[TBoundWitness, TPayload[], ModuleError[]]>;
28
+ error(payload?: ModuleError): this;
29
+ errors(errors?: (ModuleError | null)[]): this;
30
+ hashableFields(): Promise<TBoundWitness>;
31
+ hashes(hashes: string[], schema: string[]): this;
32
+ payload(payload?: TPayload): this;
33
+ payloads(payloads?: (TPayload | null)[]): this;
34
+ witness(account: AccountInstance): this;
35
+ witnesses(accounts: AccountInstance[]): this;
36
+ protected signatures(_hash: string, previousHashes: (string | Data | undefined)[]): Promise<string[]>;
37
+ private getPayloadHashes;
38
+ private inlinePayloads;
39
+ private missingSchemaMessage;
40
+ }
41
+ //# sourceMappingURL=Builder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Builder.d.ts","sourceRoot":"","sources":["../../src/Builder.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AAC5D,OAAO,EAAE,YAAY,EAAsB,MAAM,iCAAiC,CAAA;AAElF,OAAO,EAAE,IAAI,EAA6B,MAAM,mBAAmB,CAAA;AAEnE,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACjE,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AAG5C,MAAM,WAAW,yBAAyB;IACxC,8GAA8G;IAC9G,QAAQ,CAAC,cAAc,CAAC,EAAE,OAAO,CAAA;IACjC,QAAQ,CAAC,IAAI,CAAC,EAAE,OAAO,CAAA;IACvB,QAAQ,CAAC,SAAS,CAAC,EAAE,OAAO,CAAA;CAC7B;AAED,qBAAa,mBAAmB,CAAC,aAAa,SAAS,YAAY,CAAC;IAAE,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC,GAAG,YAAY,EAAE,QAAQ,SAAS,OAAO,GAAG,OAAO;IAWtI,QAAQ,CAAC,MAAM,EAAE,yBAAyB;IAC1C,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC;IAX5B,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,WAAW,CAAc;IACjD,OAAO,CAAC,SAAS,CAAwB;IACzC,OAAO,CAAC,YAAY,CAAsB;IAC1C,OAAO,CAAC,OAAO,CAAoB;IACnC,OAAO,CAAC,cAAc,CAAsB;IAC5C,OAAO,CAAC,eAAe,CAAsB;IAC7C,OAAO,CAAC,SAAS,CAAiB;IAClC,OAAO,CAAC,UAAU,CAAa;gBAGpB,MAAM,GAAE,yBAAqD,EACnD,MAAM,CAAC,oBAAQ;IAGpC,OAAO,KAAK,gBAAgB,GAO3B;IAEK,KAAK,CAAC,IAAI,UAAQ,GAAG,OAAO,CAAC,CAAC,aAAa,EAAE,QAAQ,EAAE,EAAE,WAAW,EAAE,CAAC,CAAC;IA6B9E,KAAK,CAAC,OAAO,CAAC,EAAE,WAAW;IAS3B,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,WAAW,GAAG,IAAI,CAAC,EAAE;IAShC,cAAc,IAAI,OAAO,CAAC,aAAa,CAAC;IA0B9C,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE;IAOzC,OAAO,CAAC,OAAO,CAAC,EAAE,QAAQ;IAS1B,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,GAAG,IAAI,CAAC,EAAE;IASvC,OAAO,CAAC,OAAO,EAAE,eAAe;IAKhC,SAAS,CAAC,QAAQ,EAAE,eAAe,EAAE;cAKrB,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,cAAc,EAAE,CAAC,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC,EAAE;YAOzE,gBAAgB;IAI9B,OAAO,CAAC,cAAc;IAStB,OAAO,CAAC,oBAAoB;CAG7B"}
@@ -0,0 +1,169 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/Builder.ts
21
+ var Builder_exports = {};
22
+ __export(Builder_exports, {
23
+ BoundWitnessBuilder: () => BoundWitnessBuilder
24
+ });
25
+ module.exports = __toCommonJS(Builder_exports);
26
+ var import_assert = require("@xylabs/assert");
27
+ var import_buffer = require("@xylabs/buffer");
28
+ var import_boundwitness_model = require("@xyo-network/boundwitness-model");
29
+ var import_boundwitness_wrapper = require("@xyo-network/boundwitness-wrapper");
30
+ var import_core = require("@xyo-network/core");
31
+ var import_payload = require("@xyo-network/payload");
32
+ var import_async_mutex = require("async-mutex");
33
+ var BoundWitnessBuilder = class _BoundWitnessBuilder {
34
+ constructor(config = { inlinePayloads: false }, logger) {
35
+ this.config = config;
36
+ this.logger = logger;
37
+ }
38
+ static _buildMutex = new import_async_mutex.Mutex();
39
+ _accounts = [];
40
+ _errorHashes;
41
+ _errors = [];
42
+ _payloadHashes;
43
+ _payloadSchemas;
44
+ _payloads = [];
45
+ _timestamp = Date.now();
46
+ get _payload_schemas() {
47
+ return this._payloadSchemas ?? this._payloads.map((payload) => {
48
+ return (0, import_assert.assertEx)(payload.schema, () => this.missingSchemaMessage(payload));
49
+ });
50
+ }
51
+ async build(meta = false) {
52
+ return await _BoundWitnessBuilder._buildMutex.runExclusive(async () => {
53
+ var _a;
54
+ const hashableFields = await this.hashableFields();
55
+ const _hash = await import_boundwitness_wrapper.BoundWitnessWrapper.hashAsync(hashableFields);
56
+ const previousHashes = this._accounts.map((account) => account.previousHash);
57
+ const ret = {
58
+ ...hashableFields,
59
+ _signatures: await this.signatures(_hash, previousHashes)
60
+ };
61
+ if (meta ?? ((_a = this.config) == null ? void 0 : _a.meta)) {
62
+ const bwWithMeta = ret;
63
+ bwWithMeta._client = "js";
64
+ bwWithMeta._hash = _hash;
65
+ bwWithMeta._timestamp = this._timestamp;
66
+ }
67
+ if (this.config.inlinePayloads) {
68
+ const anyRet = ret;
69
+ anyRet._payloads = this.inlinePayloads();
70
+ }
71
+ return [ret, this._payloads, this._errors];
72
+ });
73
+ }
74
+ error(payload) {
75
+ const unwrappedPayload = import_payload.PayloadWrapper.unwrap(payload);
76
+ (0, import_assert.assertEx)(this._errorHashes === void 0, "Can not set errors when hashes already set");
77
+ if (unwrappedPayload) {
78
+ this._errors.push((0, import_assert.assertEx)((0, import_core.sortFields)(unwrappedPayload)));
79
+ }
80
+ return this;
81
+ }
82
+ errors(errors) {
83
+ errors == null ? void 0 : errors.forEach((error) => {
84
+ if (error !== null) {
85
+ this.error(error);
86
+ }
87
+ });
88
+ return this;
89
+ }
90
+ async hashableFields() {
91
+ var _a, _b;
92
+ const addresses = this._accounts.map((account) => account.address);
93
+ const previous_hashes = this._accounts.map((account) => account.previousHash ?? null);
94
+ const payload_hashes = (0, import_assert.assertEx)(await this.getPayloadHashes(), "Missing payload_hashes");
95
+ const payload_schemas = (0, import_assert.assertEx)(this._payload_schemas, "Missing payload_schemas");
96
+ const result = {
97
+ addresses: (0, import_assert.assertEx)(addresses, "Missing addresses"),
98
+ payload_hashes,
99
+ payload_schemas,
100
+ previous_hashes,
101
+ schema: import_boundwitness_model.BoundWitnessSchema
102
+ };
103
+ (0, import_assert.assertEx)(((_a = result.payload_hashes) == null ? void 0 : _a.length) === ((_b = result.payload_schemas) == null ? void 0 : _b.length), "Payload hash/schema mismatch");
104
+ (0, import_assert.assertEx)(!result.payload_hashes.reduce((inValid, hash) => inValid || !hash, false), "nulls found in hashes");
105
+ (0, import_assert.assertEx)(!result.payload_schemas.reduce((inValid, schema) => inValid || !schema, false), "nulls found in schemas");
106
+ if (this.config.timestamp ?? true) {
107
+ result.timestamp = this._timestamp;
108
+ }
109
+ return result;
110
+ }
111
+ hashes(hashes, schema) {
112
+ (0, import_assert.assertEx)(this.payloads.length === 0, "Can not set hashes when payloads already set");
113
+ this._payloadHashes = hashes;
114
+ this._payloadSchemas = schema;
115
+ return this;
116
+ }
117
+ payload(payload) {
118
+ const unwrappedPayload = import_payload.PayloadWrapper.unwrap(payload);
119
+ (0, import_assert.assertEx)(this._payloadHashes === void 0, "Can not set payloads when hashes already set");
120
+ if (unwrappedPayload) {
121
+ this._payloads.push((0, import_assert.assertEx)((0, import_core.sortFields)(unwrappedPayload)));
122
+ }
123
+ return this;
124
+ }
125
+ payloads(payloads) {
126
+ payloads == null ? void 0 : payloads.forEach((payload) => {
127
+ if (payload !== null) {
128
+ this.payload(payload);
129
+ }
130
+ });
131
+ return this;
132
+ }
133
+ witness(account) {
134
+ var _a;
135
+ (_a = this._accounts) == null ? void 0 : _a.push(account);
136
+ return this;
137
+ }
138
+ witnesses(accounts) {
139
+ var _a;
140
+ (_a = this._accounts) == null ? void 0 : _a.push(...accounts);
141
+ return this;
142
+ }
143
+ async signatures(_hash, previousHashes) {
144
+ const hash = import_buffer.Buffer.from(_hash, "hex");
145
+ return await Promise.all(
146
+ this._accounts.map(async (account, index) => import_buffer.Buffer.from(await account.sign(hash, previousHashes[index])).toString("hex"))
147
+ );
148
+ }
149
+ async getPayloadHashes() {
150
+ return this._payloadHashes ?? await Promise.all(this._payloads.map((payload) => import_core.PayloadHasher.hashAsync(payload)));
151
+ }
152
+ inlinePayloads() {
153
+ return this._payloads.map((payload, index) => {
154
+ return {
155
+ ...payload,
156
+ schema: this._payload_schemas[index]
157
+ };
158
+ });
159
+ }
160
+ missingSchemaMessage(payload) {
161
+ return `Builder: Missing Schema
162
+ ${JSON.stringify(payload, null, 2)}`;
163
+ }
164
+ };
165
+ // Annotate the CommonJS export names for ESM import in node:
166
+ 0 && (module.exports = {
167
+ BoundWitnessBuilder
168
+ });
169
+ //# sourceMappingURL=Builder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/Builder.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Buffer } from '@xylabs/buffer'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { BoundWitness, BoundWitnessSchema } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { Data, PayloadHasher, sortFields } from '@xyo-network/core'\nimport { PayloadWrapper } from '@xyo-network/payload'\nimport { ModuleError, Payload } from '@xyo-network/payload-model'\nimport { Logger } from '@xyo-network/shared'\nimport { Mutex } from 'async-mutex'\n\nexport interface BoundWitnessBuilderConfig {\n /** Whether or not the payloads should be included in the metadata sent to and recorded by the ArchivistApi */\n readonly inlinePayloads?: boolean\n readonly meta?: boolean\n readonly timestamp?: boolean\n}\n\nexport class BoundWitnessBuilder<TBoundWitness extends BoundWitness<{ schema: string }> = BoundWitness, TPayload extends Payload = Payload> {\n private static readonly _buildMutex = new Mutex()\n private _accounts: AccountInstance[] = []\n private _errorHashes: string[] | undefined\n private _errors: ModuleError[] = []\n private _payloadHashes: string[] | undefined\n private _payloadSchemas: string[] | undefined\n private _payloads: TPayload[] = []\n private _timestamp = Date.now()\n\n constructor(\n readonly config: BoundWitnessBuilderConfig = { inlinePayloads: false },\n protected readonly logger?: Logger,\n ) {}\n\n private get _payload_schemas(): string[] {\n return (\n this._payloadSchemas ??\n this._payloads.map((payload) => {\n return assertEx(payload.schema, () => this.missingSchemaMessage(payload))\n })\n )\n }\n\n async build(meta = false): Promise<[TBoundWitness, TPayload[], ModuleError[]]> {\n return await BoundWitnessBuilder._buildMutex.runExclusive(async () => {\n const hashableFields = await this.hashableFields()\n const _hash = await BoundWitnessWrapper.hashAsync(hashableFields)\n\n /* get all the previousHashes to verify atomic signing */\n const previousHashes = this._accounts.map((account) => account.previousHash)\n\n const ret: TBoundWitness = {\n ...hashableFields,\n _signatures: await this.signatures(_hash, previousHashes),\n }\n if (meta ?? this.config?.meta) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const bwWithMeta = ret as any\n bwWithMeta._client = 'js'\n bwWithMeta._hash = _hash\n bwWithMeta._timestamp = this._timestamp\n }\n if (this.config.inlinePayloads) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const anyRet = ret as any\n //leaving this in here to prevent breaking code (for now)\n anyRet._payloads = this.inlinePayloads()\n }\n return [ret, this._payloads, this._errors]\n })\n }\n\n error(payload?: ModuleError) {\n const unwrappedPayload = PayloadWrapper.unwrap(payload)\n assertEx(this._errorHashes === undefined, 'Can not set errors when hashes already set')\n if (unwrappedPayload) {\n this._errors.push(assertEx(sortFields(unwrappedPayload)))\n }\n return this\n }\n\n errors(errors?: (ModuleError | null)[]) {\n errors?.forEach((error) => {\n if (error !== null) {\n this.error(error)\n }\n })\n return this\n }\n\n async hashableFields(): Promise<TBoundWitness> {\n const addresses = this._accounts.map((account) => account.address)\n const previous_hashes = this._accounts.map((account) => account.previousHash ?? null)\n const payload_hashes = assertEx(await this.getPayloadHashes(), 'Missing payload_hashes')\n const payload_schemas = assertEx(this._payload_schemas, 'Missing payload_schemas')\n const result: TBoundWitness = {\n addresses: assertEx(addresses, 'Missing addresses'),\n payload_hashes,\n payload_schemas,\n previous_hashes,\n schema: BoundWitnessSchema,\n } as TBoundWitness\n\n assertEx(result.payload_hashes?.length === result.payload_schemas?.length, 'Payload hash/schema mismatch')\n\n assertEx(!result.payload_hashes.reduce((inValid, hash) => inValid || !hash, false), 'nulls found in hashes')\n\n assertEx(!result.payload_schemas.reduce((inValid, schema) => inValid || !schema, false), 'nulls found in schemas')\n\n if (this.config.timestamp ?? true) {\n result.timestamp = this._timestamp\n }\n\n return result\n }\n\n hashes(hashes: string[], schema: string[]) {\n assertEx(this.payloads.length === 0, 'Can not set hashes when payloads already set')\n this._payloadHashes = hashes\n this._payloadSchemas = schema\n return this\n }\n\n payload(payload?: TPayload) {\n const unwrappedPayload = PayloadWrapper.unwrap<TPayload>(payload)\n assertEx(this._payloadHashes === undefined, 'Can not set payloads when hashes already set')\n if (unwrappedPayload) {\n this._payloads.push(assertEx(sortFields<TPayload>(unwrappedPayload)))\n }\n return this\n }\n\n payloads(payloads?: (TPayload | null)[]) {\n payloads?.forEach((payload) => {\n if (payload !== null) {\n this.payload(payload)\n }\n })\n return this\n }\n\n witness(account: AccountInstance) {\n this._accounts?.push(account)\n return this\n }\n\n witnesses(accounts: AccountInstance[]) {\n this._accounts?.push(...accounts)\n return this\n }\n\n protected async signatures(_hash: string, previousHashes: (string | Data | undefined)[]) {\n const hash = Buffer.from(_hash, 'hex')\n return await Promise.all(\n this._accounts.map(async (account, index) => Buffer.from(await account.sign(hash, previousHashes[index])).toString('hex')),\n )\n }\n\n private async getPayloadHashes(): Promise<string[]> {\n return this._payloadHashes ?? (await Promise.all(this._payloads.map((payload) => PayloadHasher.hashAsync(payload))))\n }\n\n private inlinePayloads() {\n return this._payloads.map<TPayload>((payload, index) => {\n return {\n ...payload,\n schema: this._payload_schemas[index],\n }\n })\n }\n\n private missingSchemaMessage(payload: Payload) {\n return `Builder: Missing Schema\\n${JSON.stringify(payload, null, 2)}`\n }\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1,144 @@
1
+ // src/Builder.ts
2
+ import { assertEx } from "@xylabs/assert";
3
+ import { Buffer } from "@xylabs/buffer";
4
+ import { BoundWitnessSchema } from "@xyo-network/boundwitness-model";
5
+ import { BoundWitnessWrapper } from "@xyo-network/boundwitness-wrapper";
6
+ import { PayloadHasher, sortFields } from "@xyo-network/core";
7
+ import { PayloadWrapper } from "@xyo-network/payload";
8
+ import { Mutex } from "async-mutex";
9
+ var BoundWitnessBuilder = class _BoundWitnessBuilder {
10
+ constructor(config = { inlinePayloads: false }, logger) {
11
+ this.config = config;
12
+ this.logger = logger;
13
+ }
14
+ static _buildMutex = new Mutex();
15
+ _accounts = [];
16
+ _errorHashes;
17
+ _errors = [];
18
+ _payloadHashes;
19
+ _payloadSchemas;
20
+ _payloads = [];
21
+ _timestamp = Date.now();
22
+ get _payload_schemas() {
23
+ return this._payloadSchemas ?? this._payloads.map((payload) => {
24
+ return assertEx(payload.schema, () => this.missingSchemaMessage(payload));
25
+ });
26
+ }
27
+ async build(meta = false) {
28
+ return await _BoundWitnessBuilder._buildMutex.runExclusive(async () => {
29
+ var _a;
30
+ const hashableFields = await this.hashableFields();
31
+ const _hash = await BoundWitnessWrapper.hashAsync(hashableFields);
32
+ const previousHashes = this._accounts.map((account) => account.previousHash);
33
+ const ret = {
34
+ ...hashableFields,
35
+ _signatures: await this.signatures(_hash, previousHashes)
36
+ };
37
+ if (meta ?? ((_a = this.config) == null ? void 0 : _a.meta)) {
38
+ const bwWithMeta = ret;
39
+ bwWithMeta._client = "js";
40
+ bwWithMeta._hash = _hash;
41
+ bwWithMeta._timestamp = this._timestamp;
42
+ }
43
+ if (this.config.inlinePayloads) {
44
+ const anyRet = ret;
45
+ anyRet._payloads = this.inlinePayloads();
46
+ }
47
+ return [ret, this._payloads, this._errors];
48
+ });
49
+ }
50
+ error(payload) {
51
+ const unwrappedPayload = PayloadWrapper.unwrap(payload);
52
+ assertEx(this._errorHashes === void 0, "Can not set errors when hashes already set");
53
+ if (unwrappedPayload) {
54
+ this._errors.push(assertEx(sortFields(unwrappedPayload)));
55
+ }
56
+ return this;
57
+ }
58
+ errors(errors) {
59
+ errors == null ? void 0 : errors.forEach((error) => {
60
+ if (error !== null) {
61
+ this.error(error);
62
+ }
63
+ });
64
+ return this;
65
+ }
66
+ async hashableFields() {
67
+ var _a, _b;
68
+ const addresses = this._accounts.map((account) => account.address);
69
+ const previous_hashes = this._accounts.map((account) => account.previousHash ?? null);
70
+ const payload_hashes = assertEx(await this.getPayloadHashes(), "Missing payload_hashes");
71
+ const payload_schemas = assertEx(this._payload_schemas, "Missing payload_schemas");
72
+ const result = {
73
+ addresses: assertEx(addresses, "Missing addresses"),
74
+ payload_hashes,
75
+ payload_schemas,
76
+ previous_hashes,
77
+ schema: BoundWitnessSchema
78
+ };
79
+ assertEx(((_a = result.payload_hashes) == null ? void 0 : _a.length) === ((_b = result.payload_schemas) == null ? void 0 : _b.length), "Payload hash/schema mismatch");
80
+ assertEx(!result.payload_hashes.reduce((inValid, hash) => inValid || !hash, false), "nulls found in hashes");
81
+ assertEx(!result.payload_schemas.reduce((inValid, schema) => inValid || !schema, false), "nulls found in schemas");
82
+ if (this.config.timestamp ?? true) {
83
+ result.timestamp = this._timestamp;
84
+ }
85
+ return result;
86
+ }
87
+ hashes(hashes, schema) {
88
+ assertEx(this.payloads.length === 0, "Can not set hashes when payloads already set");
89
+ this._payloadHashes = hashes;
90
+ this._payloadSchemas = schema;
91
+ return this;
92
+ }
93
+ payload(payload) {
94
+ const unwrappedPayload = PayloadWrapper.unwrap(payload);
95
+ assertEx(this._payloadHashes === void 0, "Can not set payloads when hashes already set");
96
+ if (unwrappedPayload) {
97
+ this._payloads.push(assertEx(sortFields(unwrappedPayload)));
98
+ }
99
+ return this;
100
+ }
101
+ payloads(payloads) {
102
+ payloads == null ? void 0 : payloads.forEach((payload) => {
103
+ if (payload !== null) {
104
+ this.payload(payload);
105
+ }
106
+ });
107
+ return this;
108
+ }
109
+ witness(account) {
110
+ var _a;
111
+ (_a = this._accounts) == null ? void 0 : _a.push(account);
112
+ return this;
113
+ }
114
+ witnesses(accounts) {
115
+ var _a;
116
+ (_a = this._accounts) == null ? void 0 : _a.push(...accounts);
117
+ return this;
118
+ }
119
+ async signatures(_hash, previousHashes) {
120
+ const hash = Buffer.from(_hash, "hex");
121
+ return await Promise.all(
122
+ this._accounts.map(async (account, index) => Buffer.from(await account.sign(hash, previousHashes[index])).toString("hex"))
123
+ );
124
+ }
125
+ async getPayloadHashes() {
126
+ return this._payloadHashes ?? await Promise.all(this._payloads.map((payload) => PayloadHasher.hashAsync(payload)));
127
+ }
128
+ inlinePayloads() {
129
+ return this._payloads.map((payload, index) => {
130
+ return {
131
+ ...payload,
132
+ schema: this._payload_schemas[index]
133
+ };
134
+ });
135
+ }
136
+ missingSchemaMessage(payload) {
137
+ return `Builder: Missing Schema
138
+ ${JSON.stringify(payload, null, 2)}`;
139
+ }
140
+ };
141
+ export {
142
+ BoundWitnessBuilder
143
+ };
144
+ //# sourceMappingURL=Builder.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/Builder.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Buffer } from '@xylabs/buffer'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { BoundWitness, BoundWitnessSchema } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { Data, PayloadHasher, sortFields } from '@xyo-network/core'\nimport { PayloadWrapper } from '@xyo-network/payload'\nimport { ModuleError, Payload } from '@xyo-network/payload-model'\nimport { Logger } from '@xyo-network/shared'\nimport { Mutex } from 'async-mutex'\n\nexport interface BoundWitnessBuilderConfig {\n /** Whether or not the payloads should be included in the metadata sent to and recorded by the ArchivistApi */\n readonly inlinePayloads?: boolean\n readonly meta?: boolean\n readonly timestamp?: boolean\n}\n\nexport class BoundWitnessBuilder<TBoundWitness extends BoundWitness<{ schema: string }> = BoundWitness, TPayload extends Payload = Payload> {\n private static readonly _buildMutex = new Mutex()\n private _accounts: AccountInstance[] = []\n private _errorHashes: string[] | undefined\n private _errors: ModuleError[] = []\n private _payloadHashes: string[] | undefined\n private _payloadSchemas: string[] | undefined\n private _payloads: TPayload[] = []\n private _timestamp = Date.now()\n\n constructor(\n readonly config: BoundWitnessBuilderConfig = { inlinePayloads: false },\n protected readonly logger?: Logger,\n ) {}\n\n private get _payload_schemas(): string[] {\n return (\n this._payloadSchemas ??\n this._payloads.map((payload) => {\n return assertEx(payload.schema, () => this.missingSchemaMessage(payload))\n })\n )\n }\n\n async build(meta = false): Promise<[TBoundWitness, TPayload[], ModuleError[]]> {\n return await BoundWitnessBuilder._buildMutex.runExclusive(async () => {\n const hashableFields = await this.hashableFields()\n const _hash = await BoundWitnessWrapper.hashAsync(hashableFields)\n\n /* get all the previousHashes to verify atomic signing */\n const previousHashes = this._accounts.map((account) => account.previousHash)\n\n const ret: TBoundWitness = {\n ...hashableFields,\n _signatures: await this.signatures(_hash, previousHashes),\n }\n if (meta ?? this.config?.meta) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const bwWithMeta = ret as any\n bwWithMeta._client = 'js'\n bwWithMeta._hash = _hash\n bwWithMeta._timestamp = this._timestamp\n }\n if (this.config.inlinePayloads) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const anyRet = ret as any\n //leaving this in here to prevent breaking code (for now)\n anyRet._payloads = this.inlinePayloads()\n }\n return [ret, this._payloads, this._errors]\n })\n }\n\n error(payload?: ModuleError) {\n const unwrappedPayload = PayloadWrapper.unwrap(payload)\n assertEx(this._errorHashes === undefined, 'Can not set errors when hashes already set')\n if (unwrappedPayload) {\n this._errors.push(assertEx(sortFields(unwrappedPayload)))\n }\n return this\n }\n\n errors(errors?: (ModuleError | null)[]) {\n errors?.forEach((error) => {\n if (error !== null) {\n this.error(error)\n }\n })\n return this\n }\n\n async hashableFields(): Promise<TBoundWitness> {\n const addresses = this._accounts.map((account) => account.address)\n const previous_hashes = this._accounts.map((account) => account.previousHash ?? null)\n const payload_hashes = assertEx(await this.getPayloadHashes(), 'Missing payload_hashes')\n const payload_schemas = assertEx(this._payload_schemas, 'Missing payload_schemas')\n const result: TBoundWitness = {\n addresses: assertEx(addresses, 'Missing addresses'),\n payload_hashes,\n payload_schemas,\n previous_hashes,\n schema: BoundWitnessSchema,\n } as TBoundWitness\n\n assertEx(result.payload_hashes?.length === result.payload_schemas?.length, 'Payload hash/schema mismatch')\n\n assertEx(!result.payload_hashes.reduce((inValid, hash) => inValid || !hash, false), 'nulls found in hashes')\n\n assertEx(!result.payload_schemas.reduce((inValid, schema) => inValid || !schema, false), 'nulls found in schemas')\n\n if (this.config.timestamp ?? true) {\n result.timestamp = this._timestamp\n }\n\n return result\n }\n\n hashes(hashes: string[], schema: string[]) {\n assertEx(this.payloads.length === 0, 'Can not set hashes when payloads already set')\n this._payloadHashes = hashes\n this._payloadSchemas = schema\n return this\n }\n\n payload(payload?: TPayload) {\n const unwrappedPayload = PayloadWrapper.unwrap<TPayload>(payload)\n assertEx(this._payloadHashes === undefined, 'Can not set payloads when hashes already set')\n if (unwrappedPayload) {\n this._payloads.push(assertEx(sortFields<TPayload>(unwrappedPayload)))\n }\n return this\n }\n\n payloads(payloads?: (TPayload | null)[]) {\n payloads?.forEach((payload) => {\n if (payload !== null) {\n this.payload(payload)\n }\n })\n return this\n }\n\n witness(account: AccountInstance) {\n this._accounts?.push(account)\n return this\n }\n\n witnesses(accounts: AccountInstance[]) {\n this._accounts?.push(...accounts)\n return this\n }\n\n protected async signatures(_hash: string, previousHashes: (string | Data | undefined)[]) {\n const hash = Buffer.from(_hash, 'hex')\n return await Promise.all(\n this._accounts.map(async (account, index) => Buffer.from(await account.sign(hash, previousHashes[index])).toString('hex')),\n )\n }\n\n private async getPayloadHashes(): Promise<string[]> {\n return this._payloadHashes ?? (await Promise.all(this._payloads.map((payload) => PayloadHasher.hashAsync(payload))))\n }\n\n private inlinePayloads() {\n return this._payloads.map<TPayload>((payload, index) => {\n return {\n ...payload,\n schema: this._payload_schemas[index],\n }\n })\n }\n\n private missingSchemaMessage(payload: Payload) {\n return `Builder: Missing Schema\\n${JSON.stringify(payload, null, 2)}`\n }\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1,17 @@
1
+ import { BoundWitness, BoundWitnessSchema } from '@xyo-network/boundwitness-model';
2
+ import { Payload } from '@xyo-network/payload-model';
3
+ export type QueryBoundWitnessSchema = BoundWitnessSchema;
4
+ export declare const QueryBoundWitnessSchema: QueryBoundWitnessSchema;
5
+ export type QueryBoundWitness = BoundWitness<{
6
+ query: string;
7
+ resultSet?: string;
8
+ schema: BoundWitnessSchema;
9
+ }>;
10
+ export declare const isQueryBoundWitness: (x?: Payload | null) => x is import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/boundwitness-model").BoundWitnessFields & {
11
+ query: string;
12
+ resultSet?: string | undefined;
13
+ schema: BoundWitnessSchema;
14
+ }, "schema"> & {
15
+ schema: "network.xyo.boundwitness";
16
+ };
17
+ //# sourceMappingURL=QueryBoundWitness.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"QueryBoundWitness.d.ts","sourceRoot":"","sources":["../../../src/Query/QueryBoundWitness.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAkB,MAAM,iCAAiC,CAAA;AAClG,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,MAAM,MAAM,uBAAuB,GAAG,kBAAkB,CAAA;AACxD,eAAO,MAAM,uBAAuB,EAAE,uBAA4C,CAAA;AAElF,MAAM,MAAM,iBAAiB,GAAG,YAAY,CAAC;IAC3C,KAAK,EAAE,MAAM,CAAA;IACb,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,kBAAkB,CAAA;CAC3B,CAAC,CAAA;AAEF,eAAO,MAAM,mBAAmB,OAAQ,OAAO,GAAG,IAAI;WAL7C,MAAM;;YAEL,kBAAkB;;;CAGyH,CAAA"}
@@ -0,0 +1,17 @@
1
+ import { BoundWitness, BoundWitnessSchema } from '@xyo-network/boundwitness-model';
2
+ import { Payload } from '@xyo-network/payload-model';
3
+ export type QueryBoundWitnessSchema = BoundWitnessSchema;
4
+ export declare const QueryBoundWitnessSchema: QueryBoundWitnessSchema;
5
+ export type QueryBoundWitness = BoundWitness<{
6
+ query: string;
7
+ resultSet?: string;
8
+ schema: BoundWitnessSchema;
9
+ }>;
10
+ export declare const isQueryBoundWitness: (x?: Payload | null) => x is import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/boundwitness-model").BoundWitnessFields & {
11
+ query: string;
12
+ resultSet?: string | undefined;
13
+ schema: BoundWitnessSchema;
14
+ }, "schema"> & {
15
+ schema: "network.xyo.boundwitness";
16
+ };
17
+ //# sourceMappingURL=QueryBoundWitness.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"QueryBoundWitness.d.ts","sourceRoot":"","sources":["../../../src/Query/QueryBoundWitness.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAkB,MAAM,iCAAiC,CAAA;AAClG,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,MAAM,MAAM,uBAAuB,GAAG,kBAAkB,CAAA;AACxD,eAAO,MAAM,uBAAuB,EAAE,uBAA4C,CAAA;AAElF,MAAM,MAAM,iBAAiB,GAAG,YAAY,CAAC;IAC3C,KAAK,EAAE,MAAM,CAAA;IACb,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,kBAAkB,CAAA;CAC3B,CAAC,CAAA;AAEF,eAAO,MAAM,mBAAmB,OAAQ,OAAO,GAAG,IAAI;WAL7C,MAAM;;YAEL,kBAAkB;;;CAGyH,CAAA"}
@@ -0,0 +1,17 @@
1
+ import { BoundWitness, BoundWitnessSchema } from '@xyo-network/boundwitness-model';
2
+ import { Payload } from '@xyo-network/payload-model';
3
+ export type QueryBoundWitnessSchema = BoundWitnessSchema;
4
+ export declare const QueryBoundWitnessSchema: QueryBoundWitnessSchema;
5
+ export type QueryBoundWitness = BoundWitness<{
6
+ query: string;
7
+ resultSet?: string;
8
+ schema: BoundWitnessSchema;
9
+ }>;
10
+ export declare const isQueryBoundWitness: (x?: Payload | null) => x is import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/boundwitness-model").BoundWitnessFields & {
11
+ query: string;
12
+ resultSet?: string | undefined;
13
+ schema: BoundWitnessSchema;
14
+ }, "schema"> & {
15
+ schema: "network.xyo.boundwitness";
16
+ };
17
+ //# sourceMappingURL=QueryBoundWitness.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"QueryBoundWitness.d.ts","sourceRoot":"","sources":["../../../src/Query/QueryBoundWitness.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAkB,MAAM,iCAAiC,CAAA;AAClG,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,MAAM,MAAM,uBAAuB,GAAG,kBAAkB,CAAA;AACxD,eAAO,MAAM,uBAAuB,EAAE,uBAA4C,CAAA;AAElF,MAAM,MAAM,iBAAiB,GAAG,YAAY,CAAC;IAC3C,KAAK,EAAE,MAAM,CAAA;IACb,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,kBAAkB,CAAA;CAC3B,CAAC,CAAA;AAEF,eAAO,MAAM,mBAAmB,OAAQ,OAAO,GAAG,IAAI;WAL7C,MAAM;;YAEL,kBAAkB;;;CAGyH,CAAA"}
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/Query/QueryBoundWitness.ts
21
+ var QueryBoundWitness_exports = {};
22
+ __export(QueryBoundWitness_exports, {
23
+ QueryBoundWitnessSchema: () => QueryBoundWitnessSchema,
24
+ isQueryBoundWitness: () => isQueryBoundWitness
25
+ });
26
+ module.exports = __toCommonJS(QueryBoundWitness_exports);
27
+ var import_boundwitness_model = require("@xyo-network/boundwitness-model");
28
+ var QueryBoundWitnessSchema = import_boundwitness_model.BoundWitnessSchema;
29
+ var isQueryBoundWitness = (x) => (0, import_boundwitness_model.isBoundWitness)(x) && (x == null ? void 0 : x.query) !== void 0;
30
+ // Annotate the CommonJS export names for ESM import in node:
31
+ 0 && (module.exports = {
32
+ QueryBoundWitnessSchema,
33
+ isQueryBoundWitness
34
+ });
35
+ //# sourceMappingURL=QueryBoundWitness.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/Query/QueryBoundWitness.ts"],"sourcesContent":["import { BoundWitness, BoundWitnessSchema, isBoundWitness } from '@xyo-network/boundwitness-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport type QueryBoundWitnessSchema = BoundWitnessSchema\nexport const QueryBoundWitnessSchema: QueryBoundWitnessSchema = BoundWitnessSchema\n\nexport type QueryBoundWitness = BoundWitness<{\n query: string\n resultSet?: string\n schema: BoundWitnessSchema\n}>\n\nexport const isQueryBoundWitness = (x?: Payload | null): x is QueryBoundWitness => isBoundWitness(x) && (x as QueryBoundWitness)?.query !== undefined\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,gCAAiE;AAI1D,IAAM,0BAAmD;AAQzD,IAAM,sBAAsB,CAAC,UAA+C,0CAAe,CAAC,MAAM,uBAAyB,WAAU;","names":[]}
@@ -0,0 +1,9 @@
1
+ // src/Query/QueryBoundWitness.ts
2
+ import { BoundWitnessSchema, isBoundWitness } from "@xyo-network/boundwitness-model";
3
+ var QueryBoundWitnessSchema = BoundWitnessSchema;
4
+ var isQueryBoundWitness = (x) => isBoundWitness(x) && (x == null ? void 0 : x.query) !== void 0;
5
+ export {
6
+ QueryBoundWitnessSchema,
7
+ isQueryBoundWitness
8
+ };
9
+ //# sourceMappingURL=QueryBoundWitness.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/Query/QueryBoundWitness.ts"],"sourcesContent":["import { BoundWitness, BoundWitnessSchema, isBoundWitness } from '@xyo-network/boundwitness-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport type QueryBoundWitnessSchema = BoundWitnessSchema\nexport const QueryBoundWitnessSchema: QueryBoundWitnessSchema = BoundWitnessSchema\n\nexport type QueryBoundWitness = BoundWitness<{\n query: string\n resultSet?: string\n schema: BoundWitnessSchema\n}>\n\nexport const isQueryBoundWitness = (x?: Payload | null): x is QueryBoundWitness => isBoundWitness(x) && (x as QueryBoundWitness)?.query !== undefined\n"],"mappings":";AAAA,SAAuB,oBAAoB,sBAAsB;AAI1D,IAAM,0BAAmD;AAQzD,IAAM,sBAAsB,CAAC,MAA+C,eAAe,CAAC,MAAM,uBAAyB,WAAU;","names":[]}
@@ -0,0 +1,11 @@
1
+ import { PayloadSetPayload, Query } from '@xyo-network/payload-model';
2
+ import { BoundWitnessBuilder } from '../Builder';
3
+ import { QueryBoundWitness } from './QueryBoundWitness';
4
+ export declare class QueryBoundWitnessBuilder<TBoundWitness extends QueryBoundWitness = QueryBoundWitness, TQuery extends Query = Query> extends BoundWitnessBuilder<TBoundWitness> {
5
+ private _query;
6
+ private _resultSet;
7
+ hashableFields(): Promise<TBoundWitness>;
8
+ query<T extends TQuery>(query: T): this;
9
+ resultSet<T extends PayloadSetPayload>(payloadSet: T): this;
10
+ }
11
+ //# sourceMappingURL=QueryBoundWitnessBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"QueryBoundWitnessBuilder.d.ts","sourceRoot":"","sources":["../../../src/Query/QueryBoundWitnessBuilder.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,KAAK,EAAE,MAAM,4BAA4B,CAAA;AAGrE,OAAO,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAA;AAChD,OAAO,EAAE,iBAAiB,EAA2B,MAAM,qBAAqB,CAAA;AAEhF,qBAAa,wBAAwB,CACnC,aAAa,SAAS,iBAAiB,GAAG,iBAAiB,EAC3D,MAAM,SAAS,KAAK,GAAG,KAAK,CAC5B,SAAQ,mBAAmB,CAAC,aAAa,CAAC;IAC1C,OAAO,CAAC,MAAM,CAAoC;IAClD,OAAO,CAAC,UAAU,CAA+C;IAElD,cAAc,IAAI,OAAO,CAAC,aAAa,CAAC;IAQvD,KAAK,CAAC,CAAC,SAAS,MAAM,EAAE,KAAK,EAAE,CAAC;IAMhC,SAAS,CAAC,CAAC,SAAS,iBAAiB,EAAE,UAAU,EAAE,CAAC;CAKrD"}