@nockchain/rose-ts 0.1.1-alpha

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 (242) hide show
  1. package/README.md +373 -0
  2. package/dist/constants.d.ts +2 -0
  3. package/dist/constants.d.ts.map +1 -0
  4. package/dist/constants.js +2 -0
  5. package/dist/constants.js.map +1 -0
  6. package/dist/core/belt.d.ts +16 -0
  7. package/dist/core/belt.d.ts.map +1 -0
  8. package/dist/core/belt.js +120 -0
  9. package/dist/core/belt.js.map +1 -0
  10. package/dist/core/digest.d.ts +9 -0
  11. package/dist/core/digest.d.ts.map +1 -0
  12. package/dist/core/digest.js +76 -0
  13. package/dist/core/digest.js.map +1 -0
  14. package/dist/core/hashable.d.ts +21 -0
  15. package/dist/core/hashable.d.ts.map +1 -0
  16. package/dist/core/hashable.js +128 -0
  17. package/dist/core/hashable.js.map +1 -0
  18. package/dist/core/lock.d.ts +8 -0
  19. package/dist/core/lock.d.ts.map +1 -0
  20. package/dist/core/lock.js +95 -0
  21. package/dist/core/lock.js.map +1 -0
  22. package/dist/core/merkle.d.ts +7 -0
  23. package/dist/core/merkle.d.ts.map +1 -0
  24. package/dist/core/merkle.js +57 -0
  25. package/dist/core/merkle.js.map +1 -0
  26. package/dist/core/must.d.ts +3 -0
  27. package/dist/core/must.d.ts.map +1 -0
  28. package/dist/core/must.js +14 -0
  29. package/dist/core/must.js.map +1 -0
  30. package/dist/core/tip5/constants.d.ts +10 -0
  31. package/dist/core/tip5/constants.d.ts.map +1 -0
  32. package/dist/core/tip5/constants.js +70 -0
  33. package/dist/core/tip5/constants.js.map +1 -0
  34. package/dist/core/tip5/index.d.ts +5 -0
  35. package/dist/core/tip5/index.d.ts.map +1 -0
  36. package/dist/core/tip5/index.js +100 -0
  37. package/dist/core/tip5/index.js.map +1 -0
  38. package/dist/core/u256.d.ts +21 -0
  39. package/dist/core/u256.d.ts.map +1 -0
  40. package/dist/core/u256.js +96 -0
  41. package/dist/core/u256.js.map +1 -0
  42. package/dist/core/ubig.d.ts +20 -0
  43. package/dist/core/ubig.d.ts.map +1 -0
  44. package/dist/core/ubig.js +81 -0
  45. package/dist/core/ubig.js.map +1 -0
  46. package/dist/core/zbase.d.ts +11 -0
  47. package/dist/core/zbase.d.ts.map +1 -0
  48. package/dist/core/zbase.js +82 -0
  49. package/dist/core/zbase.js.map +1 -0
  50. package/dist/crypto/bpoly.d.ts +3 -0
  51. package/dist/crypto/bpoly.d.ts.map +1 -0
  52. package/dist/crypto/bpoly.js +121 -0
  53. package/dist/crypto/bpoly.js.map +1 -0
  54. package/dist/crypto/cheetah.d.ts +25 -0
  55. package/dist/crypto/cheetah.d.ts.map +1 -0
  56. package/dist/crypto/cheetah.js +250 -0
  57. package/dist/crypto/cheetah.js.map +1 -0
  58. package/dist/crypto/index.d.ts +7 -0
  59. package/dist/crypto/index.d.ts.map +1 -0
  60. package/dist/crypto/index.js +24 -0
  61. package/dist/crypto/index.js.map +1 -0
  62. package/dist/crypto/privateKey.d.ts +11 -0
  63. package/dist/crypto/privateKey.d.ts.map +1 -0
  64. package/dist/crypto/privateKey.js +88 -0
  65. package/dist/crypto/privateKey.js.map +1 -0
  66. package/dist/crypto/publicKey.d.ts +18 -0
  67. package/dist/crypto/publicKey.d.ts.map +1 -0
  68. package/dist/crypto/publicKey.js +79 -0
  69. package/dist/crypto/publicKey.js.map +1 -0
  70. package/dist/crypto/slip10.d.ts +10 -0
  71. package/dist/crypto/slip10.d.ts.map +1 -0
  72. package/dist/crypto/slip10.js +104 -0
  73. package/dist/crypto/slip10.js.map +1 -0
  74. package/dist/grpc/index.d.ts +12 -0
  75. package/dist/grpc/index.d.ts.map +1 -0
  76. package/dist/grpc/index.js +13 -0
  77. package/dist/grpc/index.js.map +1 -0
  78. package/dist/grpc/proto.d.ts +26 -0
  79. package/dist/grpc/proto.d.ts.map +1 -0
  80. package/dist/grpc/proto.js +219 -0
  81. package/dist/grpc/proto.js.map +1 -0
  82. package/dist/hash/index.d.ts +32 -0
  83. package/dist/hash/index.d.ts.map +1 -0
  84. package/dist/hash/index.js +138 -0
  85. package/dist/hash/index.js.map +1 -0
  86. package/dist/hash/note.d.ts +13 -0
  87. package/dist/hash/note.d.ts.map +1 -0
  88. package/dist/hash/note.js +78 -0
  89. package/dist/hash/note.js.map +1 -0
  90. package/dist/hash/noteData.d.ts +12 -0
  91. package/dist/hash/noteData.d.ts.map +1 -0
  92. package/dist/hash/noteData.js +115 -0
  93. package/dist/hash/noteData.js.map +1 -0
  94. package/dist/hash/noun.d.ts +4 -0
  95. package/dist/hash/noun.d.ts.map +1 -0
  96. package/dist/hash/noun.js +15 -0
  97. package/dist/hash/noun.js.map +1 -0
  98. package/dist/hash/structural.d.ts +5 -0
  99. package/dist/hash/structural.d.ts.map +1 -0
  100. package/dist/hash/structural.js +41 -0
  101. package/dist/hash/structural.js.map +1 -0
  102. package/dist/hash/tx.d.ts +15 -0
  103. package/dist/hash/tx.d.ts.map +1 -0
  104. package/dist/hash/tx.js +146 -0
  105. package/dist/hash/tx.js.map +1 -0
  106. package/dist/index.d.ts +14 -0
  107. package/dist/index.d.ts.map +1 -0
  108. package/dist/index.js +10 -0
  109. package/dist/index.js.map +1 -0
  110. package/dist/noun/belts.d.ts +9 -0
  111. package/dist/noun/belts.d.ts.map +1 -0
  112. package/dist/noun/belts.js +73 -0
  113. package/dist/noun/belts.js.map +1 -0
  114. package/dist/noun/bitwriter.d.ts +14 -0
  115. package/dist/noun/bitwriter.d.ts.map +1 -0
  116. package/dist/noun/bitwriter.js +100 -0
  117. package/dist/noun/bitwriter.js.map +1 -0
  118. package/dist/noun/codec.d.ts +9 -0
  119. package/dist/noun/codec.d.ts.map +1 -0
  120. package/dist/noun/codec.js +144 -0
  121. package/dist/noun/codec.js.map +1 -0
  122. package/dist/noun/cue.d.ts +3 -0
  123. package/dist/noun/cue.d.ts.map +1 -0
  124. package/dist/noun/cue.js +152 -0
  125. package/dist/noun/cue.js.map +1 -0
  126. package/dist/noun/encode.d.ts +12 -0
  127. package/dist/noun/encode.d.ts.map +1 -0
  128. package/dist/noun/encode.js +37 -0
  129. package/dist/noun/encode.js.map +1 -0
  130. package/dist/noun/index.d.ts +10 -0
  131. package/dist/noun/index.d.ts.map +1 -0
  132. package/dist/noun/index.js +29 -0
  133. package/dist/noun/index.js.map +1 -0
  134. package/dist/noun/jam.d.ts +3 -0
  135. package/dist/noun/jam.d.ts.map +1 -0
  136. package/dist/noun/jam.js +107 -0
  137. package/dist/noun/jam.js.map +1 -0
  138. package/dist/noun/types.d.ts +21 -0
  139. package/dist/noun/types.d.ts.map +1 -0
  140. package/dist/noun/types.js +66 -0
  141. package/dist/noun/types.js.map +1 -0
  142. package/dist/noun/words.d.ts +3 -0
  143. package/dist/noun/words.d.ts.map +1 -0
  144. package/dist/noun/words.js +6 -0
  145. package/dist/noun/words.js.map +1 -0
  146. package/dist/proto/decode.d.ts +10 -0
  147. package/dist/proto/decode.d.ts.map +1 -0
  148. package/dist/proto/decode.js +44 -0
  149. package/dist/proto/decode.js.map +1 -0
  150. package/dist/proto/digest.d.ts +21 -0
  151. package/dist/proto/digest.d.ts.map +1 -0
  152. package/dist/proto/digest.js +29 -0
  153. package/dist/proto/digest.js.map +1 -0
  154. package/dist/proto/index.d.ts +9 -0
  155. package/dist/proto/index.d.ts.map +1 -0
  156. package/dist/proto/index.js +140 -0
  157. package/dist/proto/index.js.map +1 -0
  158. package/dist/proto/note.d.ts +4 -0
  159. package/dist/proto/note.d.ts.map +1 -0
  160. package/dist/proto/note.js +99 -0
  161. package/dist/proto/note.js.map +1 -0
  162. package/dist/proto/rawTx.d.ts +3 -0
  163. package/dist/proto/rawTx.d.ts.map +1 -0
  164. package/dist/proto/rawTx.js +186 -0
  165. package/dist/proto/rawTx.js.map +1 -0
  166. package/dist/rpc/client.d.ts +13 -0
  167. package/dist/rpc/client.d.ts.map +1 -0
  168. package/dist/rpc/client.js +75 -0
  169. package/dist/rpc/client.js.map +1 -0
  170. package/dist/rpc/types.d.ts +18 -0
  171. package/dist/rpc/types.d.ts.map +1 -0
  172. package/dist/rpc/types.js +2 -0
  173. package/dist/rpc/types.js.map +1 -0
  174. package/dist/rpc/wire/encode.d.ts +4 -0
  175. package/dist/rpc/wire/encode.d.ts.map +1 -0
  176. package/dist/rpc/wire/encode.js +168 -0
  177. package/dist/rpc/wire/encode.js.map +1 -0
  178. package/dist/rpc/wire/protobuf.d.ts +10 -0
  179. package/dist/rpc/wire/protobuf.d.ts.map +1 -0
  180. package/dist/rpc/wire/protobuf.js +50 -0
  181. package/dist/rpc/wire/protobuf.js.map +1 -0
  182. package/dist/stubs.d.ts +6 -0
  183. package/dist/stubs.d.ts.map +1 -0
  184. package/dist/stubs.js +12 -0
  185. package/dist/stubs.js.map +1 -0
  186. package/dist/tx/accessors.d.ts +13 -0
  187. package/dist/tx/accessors.d.ts.map +1 -0
  188. package/dist/tx/accessors.js +65 -0
  189. package/dist/tx/accessors.js.map +1 -0
  190. package/dist/tx/builder.d.ts +63 -0
  191. package/dist/tx/builder.d.ts.map +1 -0
  192. package/dist/tx/builder.js +601 -0
  193. package/dist/tx/builder.js.map +1 -0
  194. package/dist/tx/display.d.ts +7 -0
  195. package/dist/tx/display.d.ts.map +1 -0
  196. package/dist/tx/display.js +34 -0
  197. package/dist/tx/display.js.map +1 -0
  198. package/dist/tx/fee.d.ts +8 -0
  199. package/dist/tx/fee.d.ts.map +1 -0
  200. package/dist/tx/fee.js +81 -0
  201. package/dist/tx/fee.js.map +1 -0
  202. package/dist/tx/htlc.d.ts +21 -0
  203. package/dist/tx/htlc.d.ts.map +1 -0
  204. package/dist/tx/htlc.js +65 -0
  205. package/dist/tx/htlc.js.map +1 -0
  206. package/dist/tx/index.d.ts +19 -0
  207. package/dist/tx/index.d.ts.map +1 -0
  208. package/dist/tx/index.js +64 -0
  209. package/dist/tx/index.js.map +1 -0
  210. package/dist/tx/multisig.d.ts +3 -0
  211. package/dist/tx/multisig.d.ts.map +1 -0
  212. package/dist/tx/multisig.js +8 -0
  213. package/dist/tx/multisig.js.map +1 -0
  214. package/dist/tx/outputs.d.ts +3 -0
  215. package/dist/tx/outputs.d.ts.map +1 -0
  216. package/dist/tx/outputs.js +57 -0
  217. package/dist/tx/outputs.js.map +1 -0
  218. package/dist/tx/spend.d.ts +10 -0
  219. package/dist/tx/spend.d.ts.map +1 -0
  220. package/dist/tx/spend.js +17 -0
  221. package/dist/tx/spend.js.map +1 -0
  222. package/dist/tx/spends.d.ts +8 -0
  223. package/dist/tx/spends.d.ts.map +1 -0
  224. package/dist/tx/spends.js +48 -0
  225. package/dist/tx/spends.js.map +1 -0
  226. package/dist/tx/types.d.ts +5 -0
  227. package/dist/tx/types.d.ts.map +1 -0
  228. package/dist/tx/types.js +2 -0
  229. package/dist/tx/types.js.map +1 -0
  230. package/dist/tx/unlocks.d.ts +4 -0
  231. package/dist/tx/unlocks.d.ts.map +1 -0
  232. package/dist/tx/unlocks.js +49 -0
  233. package/dist/tx/unlocks.js.map +1 -0
  234. package/dist/tx/witness.d.ts +14 -0
  235. package/dist/tx/witness.d.ts.map +1 -0
  236. package/dist/tx/witness.js +81 -0
  237. package/dist/tx/witness.js.map +1 -0
  238. package/dist/types.d.ts +311 -0
  239. package/dist/types.d.ts.map +1 -0
  240. package/dist/types.js +2 -0
  241. package/dist/types.js.map +1 -0
  242. package/package.json +45 -0
@@ -0,0 +1,34 @@
1
+ import { nameKey } from "./spends.js";
2
+ function findInZMap(inputs, name) {
3
+ const key = nameKey(name);
4
+ for (const [n, v] of inputs) {
5
+ if (nameKey(n) === key)
6
+ return v;
7
+ }
8
+ return undefined;
9
+ }
10
+ export function getDisplayInput(display, name) {
11
+ if ("tag" in display && display.tag === 1) {
12
+ const sc = findInZMap(display.inputs, name);
13
+ return sc;
14
+ }
15
+ if ("tag" in display && display.tag === 0) {
16
+ const sig = findInZMap(display.inputs, name);
17
+ if (sig !== undefined)
18
+ return { tag: "v0", sig };
19
+ }
20
+ if ("inputs" in display && !("tag" in display)) {
21
+ const entry = findInZMap(display.inputs, name);
22
+ if (entry === undefined)
23
+ return undefined;
24
+ if (Array.isArray(entry) || (typeof entry === "object" && entry !== null && "tag" in entry)) {
25
+ return entry;
26
+ }
27
+ return { tag: "v0", sig: entry };
28
+ }
29
+ return undefined;
30
+ }
31
+ export function isV1DisplayInput(input) {
32
+ return input !== undefined && !(typeof input === "object" && "tag" in input && input.tag === "v0");
33
+ }
34
+ //# sourceMappingURL=display.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"display.js","sourceRoot":"","sources":["../../src/tx/display.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAEtC,SAAS,UAAU,CACjB,MAAmB,EACnB,IAAU;IAEV,MAAM,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC1B,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,MAAM,EAAE,CAAC;QAC5B,IAAI,OAAO,CAAC,CAAC,CAAC,KAAK,GAAG;YAAE,OAAO,CAAC,CAAC;IACnC,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC;AAGD,MAAM,UAAU,eAAe,CAC7B,OAAqB,EACrB,IAAU;IAEV,IAAI,KAAK,IAAI,OAAO,IAAI,OAAO,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC;QAC1C,MAAM,EAAE,GAAG,UAAU,CAAC,OAAO,CAAC,MAAkC,EAAE,IAAI,CAAC,CAAC;QACxE,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,IAAI,KAAK,IAAI,OAAO,IAAI,OAAO,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC;QAC1C,MAAM,GAAG,GAAG,UAAU,CAAC,OAAO,CAAC,MAA2B,EAAE,IAAI,CAAC,CAAC;QAClE,IAAI,GAAG,KAAK,SAAS;YAAE,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC;IACnD,CAAC;IACD,IAAI,QAAQ,IAAI,OAAO,IAAI,CAAC,CAAC,KAAK,IAAI,OAAO,CAAC,EAAE,CAAC;QAC/C,MAAM,KAAK,GAAG,UAAU,CACtB,OAAO,CAAC,MAA0E,EAClF,IAAI,CACL,CAAC;QACF,IAAI,KAAK,KAAK,SAAS;YAAE,OAAO,SAAS,CAAC;QAC1C,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,IAAI,KAAK,CAAC,EAAE,CAAC;YAC5F,OAAO,KAAuB,CAAC;QACjC,CAAC;QACD,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;IACnC,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,gBAAgB,CAC9B,KAAyC;IAEzC,OAAO,KAAK,KAAK,SAAS,IAAI,CAAC,CAAC,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,IAAI,KAAK,IAAI,KAAK,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC;AACrG,CAAC"}
@@ -0,0 +1,8 @@
1
+ import type { LockRoot, Name, SpendV1, TxEngineSettings } from "../types.js";
2
+ export declare function spendCalcWords(spend: SpendV1): [bigint, bigint];
3
+ export declare function wordsForOrderedSpends(spends: Iterable<SpendV1>, settings: TxEngineSettings): [bigint, bigint];
4
+ export declare function wordsForUnorderedSpends(spends: Iterable<[Name, SpendV1]>, settings: TxEngineSettings): [bigint, bigint];
5
+ export declare function calcFeeFromSpends(spends: Iterable<SpendV1>, settings: TxEngineSettings): bigint;
6
+ export declare function missingUnlocksFee(spend: SpendV1, settings: TxEngineSettings): bigint;
7
+ export declare function lockRootKey(root: LockRoot): string;
8
+ //# sourceMappingURL=fee.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fee.d.ts","sourceRoot":"","sources":["../../src/tx/fee.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,QAAQ,EACR,IAAI,EAIJ,OAAO,EACP,gBAAgB,EACjB,MAAM,aAAa,CAAC;AAQrB,wBAAgB,cAAc,CAAC,KAAK,EAAE,OAAO,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAW/D;AAqBD,wBAAgB,qBAAqB,CACnC,MAAM,EAAE,QAAQ,CAAC,OAAO,CAAC,EACzB,QAAQ,EAAE,gBAAgB,GACzB,CAAC,MAAM,EAAE,MAAM,CAAC,CAuBlB;AAED,wBAAgB,uBAAuB,CACrC,MAAM,EAAE,QAAQ,CAAC,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,EACjC,QAAQ,EAAE,gBAAgB,GACzB,CAAC,MAAM,EAAE,MAAM,CAAC,CAKlB;AAED,wBAAgB,iBAAiB,CAC/B,MAAM,EAAE,QAAQ,CAAC,OAAO,CAAC,EACzB,QAAQ,EAAE,gBAAgB,GACzB,MAAM,CAOR;AAED,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,gBAAgB,GAAG,MAAM,CAEpF;AAED,wBAAgB,WAAW,CAAC,IAAI,EAAE,QAAQ,GAAG,MAAM,CAElD"}
package/dist/tx/fee.js ADDED
@@ -0,0 +1,81 @@
1
+ import { encodeWitness } from "../noun/codec.js";
2
+ import { nounWords } from "../noun/words.js";
3
+ import { noteDataFeeWords } from "../hash/note.js";
4
+ import { lockRootHash } from "../hash/index.js";
5
+ import { missingUnlocksFee as missingUnlocksFeeImpl } from "./unlocks.js";
6
+ function seedNoteDataWords(seed) {
7
+ return noteDataFeeWords(seed.note_data);
8
+ }
9
+ export function spendCalcWords(spend) {
10
+ if (spend.tag !== 1) {
11
+ const seeds = Array.isArray(spend.seeds) ? spend.seeds : [];
12
+ const seedWords = seeds.reduce((acc, s) => acc + seedNoteDataWords(s), 0n);
13
+ return [seedWords, 0n];
14
+ }
15
+ const s = spend;
16
+ const seeds = Array.isArray(s.seeds) ? s.seeds : [];
17
+ const seedWords = seeds.reduce((acc, sd) => acc + seedNoteDataWords(sd), 0n);
18
+ const witnessWords = nounWords(encodeWitness(s.witness));
19
+ return [seedWords, witnessWords];
20
+ }
21
+ function mergeNoteDataByLockRoot(spends) {
22
+ const merged = new Map();
23
+ for (const spend of spends) {
24
+ const seeds = spend.tag === 1 ? spend.seeds : spend.seeds;
25
+ for (const seed of seeds) {
26
+ const key = lockRootHash(seed.lock_root);
27
+ const prev = merged.get(key);
28
+ if (!prev) {
29
+ merged.set(key, [...seed.note_data]);
30
+ continue;
31
+ }
32
+ const map = new Map(prev);
33
+ for (const [k, v] of seed.note_data)
34
+ map.set(k, v);
35
+ merged.set(key, [...map.entries()]);
36
+ }
37
+ }
38
+ return merged;
39
+ }
40
+ export function wordsForOrderedSpends(spends, settings) {
41
+ if (settings.tx_engine_version === 0) {
42
+ throw new Error("fee() called on v0 settings");
43
+ }
44
+ const list = [...spends];
45
+ let sw = 0n;
46
+ let ww = 0n;
47
+ if (settings.tx_engine_patch === 0) {
48
+ for (const spend of list) {
49
+ const [s, w] = spendCalcWords(spend);
50
+ sw += s;
51
+ ww += w;
52
+ }
53
+ }
54
+ else {
55
+ for (const spend of list) {
56
+ const [, w] = spendCalcWords(spend);
57
+ ww += w;
58
+ }
59
+ for (const noteData of mergeNoteDataByLockRoot(list).values()) {
60
+ sw += noteDataFeeWords(noteData);
61
+ }
62
+ }
63
+ return [sw, ww];
64
+ }
65
+ export function wordsForUnorderedSpends(spends, settings) {
66
+ return wordsForOrderedSpends([...spends].map(([, s]) => s), settings);
67
+ }
68
+ export function calcFeeFromSpends(spends, settings) {
69
+ const [sw, ww] = wordsForOrderedSpends(spends, settings);
70
+ const fee = BigInt(settings.cost_per_word) * sw +
71
+ (BigInt(settings.cost_per_word) * ww) / BigInt(settings.witness_word_div);
72
+ const minFee = BigInt(settings.min_fee);
73
+ return fee > minFee ? fee : minFee;
74
+ }
75
+ export function missingUnlocksFee(spend, settings) {
76
+ return missingUnlocksFeeImpl(spend, settings);
77
+ }
78
+ export function lockRootKey(root) {
79
+ return lockRootHash(root);
80
+ }
81
+ //# sourceMappingURL=fee.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fee.js","sourceRoot":"","sources":["../../src/tx/fee.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ import type { Digest, Lock, Note, TxEngineSettings } from "../types.js";
2
+ export declare function htlcOrLock(hNock: Digest, buyerPkh: Digest, sellerPkh: Digest, refundHeight: bigint): Lock;
3
+ export declare function htlcLockRootDigest(hNock: Digest, buyerPkh: Digest, sellerPkh: Digest, refundHeight: bigint): Digest;
4
+ export declare function giftOutputFirstNameFromLockOutputs(outputs: {
5
+ name: {
6
+ first: string;
7
+ };
8
+ assets: unknown;
9
+ }[], giftNicks: bigint): Digest;
10
+ export declare function htlcGiftOutputFirstName(params: {
11
+ hNock: Digest;
12
+ buyerPkh: Digest;
13
+ sellerPkh: Digest;
14
+ refundHeight: bigint;
15
+ giftNicks: bigint;
16
+ inputNote: Note;
17
+ parentHash?: Digest;
18
+ inputPkh?: Digest;
19
+ settings?: TxEngineSettings;
20
+ }): Digest;
21
+ //# sourceMappingURL=htlc.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"htlc.d.ts","sourceRoot":"","sources":["../../src/tx/htlc.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,IAAI,EAAS,IAAI,EAAwB,gBAAgB,EAAE,MAAM,aAAa,CAAC;AA6BrG,wBAAgB,UAAU,CACxB,KAAK,EAAE,MAAM,EACb,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,EACjB,YAAY,EAAE,MAAM,GACnB,IAAI,CAcN;AAGD,wBAAgB,kBAAkB,CAChC,KAAK,EAAE,MAAM,EACb,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,EACjB,YAAY,EAAE,MAAM,GACnB,MAAM,CAER;AAGD,wBAAgB,kCAAkC,CAChD,OAAO,EAAE;IAAE,IAAI,EAAE;QAAE,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC;IAAC,MAAM,EAAE,OAAO,CAAA;CAAE,EAAE,EACvD,SAAS,EAAE,MAAM,GAChB,MAAM,CAOR;AAMD,wBAAgB,uBAAuB,CAAC,MAAM,EAAE;IAC9C,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,IAAI,CAAC;IAEhB,UAAU,CAAC,EAAE,MAAM,CAAC;IAEpB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,gBAAgB,CAAC;CAC7B,GAAG,MAAM,CA8BT"}
@@ -0,0 +1,65 @@
1
+ import { rawTxV1CalcId } from "../hash/tx.js";
2
+ import { lockFromList, lockRootHash, noteDataEmpty, noteHash, pkhSingle, spendConditionNewPkh, } from "../hash/index.js";
3
+ import { SpendBuilder, TxBuilder } from "./builder.js";
4
+ import { rawTxV1Outputs } from "./outputs.js";
5
+ import { applyWitness } from "./spends.js";
6
+ const TX_ENGINE_SETTINGS_V1_BYTHOS_DEFAULT = {
7
+ tx_engine_version: 1,
8
+ tx_engine_patch: 1,
9
+ min_fee: "256",
10
+ cost_per_word: "16384",
11
+ witness_word_div: 4,
12
+ };
13
+ function nockchainTxToRawTx(tx) {
14
+ const spends = applyWitness(tx.spends, tx.witness_data);
15
+ const id = rawTxV1CalcId({ version: 1, id: "", spends });
16
+ return { version: 1, id, spends };
17
+ }
18
+ export function htlcOrLock(hNock, buyerPkh, sellerPkh, refundHeight) {
19
+ const pkhSc = spendConditionNewPkh(pkhSingle(buyerPkh));
20
+ const haxPrim = { tag: "hax", preimages: [hNock] };
21
+ const claimSpendCondition = [...pkhSc, haxPrim];
22
+ const refundPkhSc = spendConditionNewPkh(pkhSingle(sellerPkh));
23
+ const timPrim = {
24
+ tag: "tim",
25
+ rel: { min: null, max: null },
26
+ abs: { min: Number(refundHeight), max: null },
27
+ };
28
+ const refundSpendCondition = [...refundPkhSc, timPrim];
29
+ return lockFromList([claimSpendCondition, refundSpendCondition]);
30
+ }
31
+ export function htlcLockRootDigest(hNock, buyerPkh, sellerPkh, refundHeight) {
32
+ return lockRootHash(htlcOrLock(hNock, buyerPkh, sellerPkh, refundHeight));
33
+ }
34
+ export function giftOutputFirstNameFromLockOutputs(outputs, giftNicks) {
35
+ for (const out of outputs) {
36
+ if (BigInt(out.assets) === giftNicks) {
37
+ return out.name.first;
38
+ }
39
+ }
40
+ throw new Error("HTLC gift output not found in lock transaction outputs");
41
+ }
42
+ export function htlcGiftOutputFirstName(params) {
43
+ const lockRootDigest = htlcLockRootDigest(params.hNock, params.buyerPkh, params.sellerPkh, params.refundHeight);
44
+ const parentHash = params.parentHash ?? noteHash(params.inputNote);
45
+ const inputLock = lockFromList([
46
+ spendConditionNewPkh(pkhSingle((params.inputPkh ?? params.sellerPkh))),
47
+ ]);
48
+ const spend = SpendBuilder.new(params.inputNote, inputLock, 0, inputLock);
49
+ spend.seed({
50
+ lock_root: lockRootDigest,
51
+ note_data: noteDataEmpty(),
52
+ gift: String(params.giftNicks),
53
+ parent_hash: parentHash,
54
+ output_source: null,
55
+ });
56
+ spend.computeRefund(false);
57
+ const settings = params.settings ?? TX_ENGINE_SETTINGS_V1_BYTHOS_DEFAULT;
58
+ const builder = new TxBuilder(settings);
59
+ builder.spend(spend);
60
+ builder.recalcAndSetFee(false);
61
+ const raw = nockchainTxToRawTx(builder.build());
62
+ const outputs = rawTxV1Outputs(raw, 0, settings);
63
+ return giftOutputFirstNameFromLockOutputs(outputs, params.giftNicks);
64
+ }
65
+ //# sourceMappingURL=htlc.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"htlc.js","sourceRoot":"","sources":["../../src/tx/htlc.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EACL,YAAY,EACZ,YAAY,EACZ,aAAa,EACb,QAAQ,EACR,SAAS,EACT,oBAAoB,GACrB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,oCAAoC,GAAqB;IAC7D,iBAAiB,EAAE,CAAC;IACpB,eAAe,EAAE,CAAC;IAClB,OAAO,EAAE,KAAc;IACvB,aAAa,EAAE,OAAgB;IAC/B,gBAAgB,EAAE,CAAC;CACpB,CAAC;AAEF,SAAS,kBAAkB,CAAC,EAAe;IACzC,MAAM,MAAM,GAAG,YAAY,CAAC,EAAE,CAAC,MAAM,EAAE,EAAE,CAAC,YAAY,CAAC,CAAC;IACxD,MAAM,EAAE,GAAG,aAAa,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,EAAE,EAAE,EAAY,EAAE,MAAM,EAAE,CAAC,CAAC;IACnE,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC;AACpC,CAAC;AAGD,MAAM,UAAU,UAAU,CACxB,KAAa,EACb,QAAgB,EAChB,SAAiB,EACjB,YAAoB;IAEpB,MAAM,KAAK,GAAG,oBAAoB,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;IACxD,MAAM,OAAO,GAAG,EAAE,GAAG,EAAE,KAAc,EAAE,SAAS,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC;IAC5D,MAAM,mBAAmB,GAAG,CAAC,GAAG,KAAK,EAAE,OAAO,CAAC,CAAC;IAEhD,MAAM,WAAW,GAAG,oBAAoB,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC;IAC/D,MAAM,OAAO,GAAG;QACd,GAAG,EAAE,KAAc;QACnB,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE;QAC7B,GAAG,EAAE,EAAE,GAAG,EAAE,MAAM,CAAC,YAAY,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE;KAC9C,CAAC;IACF,MAAM,oBAAoB,GAAG,CAAC,GAAG,WAAW,EAAE,OAAO,CAAC,CAAC;IAEvD,OAAO,YAAY,CAAC,CAAC,mBAAmB,EAAE,oBAAoB,CAAC,CAAC,CAAC;AACnE,CAAC;AAGD,MAAM,UAAU,kBAAkB,CAChC,KAAa,EACb,QAAgB,EAChB,SAAiB,EACjB,YAAoB;IAEpB,OAAO,YAAY,CAAC,UAAU,CAAC,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,YAAY,CAAC,CAAC,CAAC;AAC5E,CAAC;AAGD,MAAM,UAAU,kCAAkC,CAChD,OAAuD,EACvD,SAAiB;IAEjB,KAAK,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;QAC1B,IAAI,MAAM,CAAC,GAAG,CAAC,MAAkC,CAAC,KAAK,SAAS,EAAE,CAAC;YACjE,OAAO,GAAG,CAAC,IAAI,CAAC,KAAe,CAAC;QAClC,CAAC;IACH,CAAC;IACD,MAAM,IAAI,KAAK,CAAC,wDAAwD,CAAC,CAAC;AAC5E,CAAC;AAMD,MAAM,UAAU,uBAAuB,CAAC,MAYvC;IACC,MAAM,cAAc,GAAG,kBAAkB,CACvC,MAAM,CAAC,KAAK,EACZ,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,YAAY,CACpB,CAAC;IAEF,MAAM,UAAU,GAAG,MAAM,CAAC,UAAU,IAAI,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IACnE,MAAM,SAAS,GAAG,YAAY,CAAC;QAC7B,oBAAoB,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,SAAS,CAAW,CAAC,CAAC;KACjF,CAAC,CAAC;IACH,MAAM,KAAK,GAAG,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,EAAE,CAAC,EAAE,SAAS,CAAC,CAAC;IAC1E,KAAK,CAAC,IAAI,CAAC;QACT,SAAS,EAAE,cAAc;QACzB,SAAS,EAAE,aAAa,EAAE;QAC1B,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,SAAS,CAAU;QACvC,WAAW,EAAE,UAAU;QACvB,aAAa,EAAE,IAAI;KACpB,CAAC,CAAC;IACH,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAE3B,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,IAAI,oCAAoC,CAAC;IACzE,MAAM,OAAO,GAAG,IAAI,SAAS,CAAC,QAAQ,CAAC,CAAC;IACxC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACrB,OAAO,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;IAE/B,MAAM,GAAG,GAAG,kBAAkB,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC;IAChD,MAAM,OAAO,GAAG,cAAc,CAAC,GAAG,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC;IACjD,OAAO,kCAAkC,CAAC,OAAO,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC;AACvE,CAAC"}
@@ -0,0 +1,19 @@
1
+ import type { Digest, Nicks, NockchainTx, Note, RawTxV1, SpendsV1, TxEngineSettings } from "../types.js";
2
+ export { SpendBuilder, TxBuilder, type SimpleSpendLockOptions } from "./builder.js";
3
+ export { giftOutputFirstNameFromLockOutputs, htlcGiftOutputFirstName, htlcOrLock, htlcLockRootDigest, } from "./htlc.js";
4
+ export { multisigLock } from "./multisig.js";
5
+ export { witnessFromLock, witnessNew, lockMerkleProofFromLock, witnessFromLockMerkleProof, witnessClearSignatures, witnessWithPkhSignature, witnessWithHaxPreimage, spendV1FromLock, spendConditionFromWitness, } from "./witness.js";
6
+ export { applyWitness, splitWitness } from "./spends.js";
7
+ export declare function txEngineSettingsV1Default(): TxEngineSettings;
8
+ export declare function txEngineSettingsV1BythosDefault(): TxEngineSettings;
9
+ export { rawTxV1InputNames, rawTxV1InputSpendConditions, rawTxV1New, rawTxV1Version, spendV1Fee, spendV1TotalGifts, spendV1UnclampedFee, spendsV1Fee, spendsV1TotalFees, spendsV1TotalGifts, spendsV1UnclampedFee, } from "./accessors.js";
10
+ export { spendV1NewWitness, spendV1NewLegacy, spendV1SigHash } from "./spend.js";
11
+ export type { OutputNoteData } from "./types.js";
12
+ export declare function spendsV1ApplyWitness(spends: SpendsV1, witnessData: NockchainTx["witness_data"]): SpendsV1;
13
+ export declare function nockchainTxToRawTx(tx: NockchainTx): RawTxV1;
14
+ export declare function rawTxV1ToNockchainTx(raw: RawTxV1): NockchainTx;
15
+ export declare function rawTxV1Outputs(obj: RawTxV1, originPage: number, settings: TxEngineSettings): Note[];
16
+ export declare function rawTxTotalFees(obj: RawTxV1): Nicks;
17
+ export declare function rawTxV1CalcId(obj: RawTxV1): Digest;
18
+ export declare function nockchainTxOutputs(tx: NockchainTx, originPage: number, settings: TxEngineSettings): Note[];
19
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/tx/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,MAAM,EACN,KAAK,EACL,WAAW,EACX,IAAI,EACJ,OAAO,EACP,QAAQ,EACR,gBAAgB,EACjB,MAAM,aAAa,CAAC;AAKrB,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,KAAK,sBAAsB,EAAE,MAAM,cAAc,CAAC;AACpF,OAAO,EACL,kCAAkC,EAClC,uBAAuB,EACvB,UAAU,EACV,kBAAkB,GACnB,MAAM,WAAW,CAAC;AACnB,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,EACL,eAAe,EACf,UAAU,EACV,uBAAuB,EACvB,0BAA0B,EAC1B,sBAAsB,EACtB,uBAAuB,EACvB,sBAAsB,EACtB,eAAe,EACf,yBAAyB,GAC1B,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAEzD,wBAAgB,yBAAyB,IAAI,gBAAgB,CAQ5D;AAED,wBAAgB,+BAA+B,IAAI,gBAAgB,CAQlE;AAED,OAAO,EACL,iBAAiB,EACjB,2BAA2B,EAC3B,UAAU,EACV,cAAc,EACd,UAAU,EACV,iBAAiB,EACjB,mBAAmB,EACnB,WAAW,EACX,iBAAiB,EACjB,kBAAkB,EAClB,oBAAoB,GACrB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AACjF,YAAY,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAEjD,wBAAgB,oBAAoB,CAClC,MAAM,EAAE,QAAQ,EAChB,WAAW,EAAE,WAAW,CAAC,cAAc,CAAC,GACvC,QAAQ,CAEV;AAED,wBAAgB,kBAAkB,CAAC,EAAE,EAAE,WAAW,GAAG,OAAO,CAI3D;AAGD,wBAAgB,oBAAoB,CAAC,GAAG,EAAE,OAAO,GAAG,WAAW,CAU9D;AAED,wBAAgB,cAAc,CAC5B,GAAG,EAAE,OAAO,EACZ,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,gBAAgB,GACzB,IAAI,EAAE,CAER;AAED,wBAAgB,cAAc,CAAC,GAAG,EAAE,OAAO,GAAG,KAAK,CAMlD;AAED,wBAAgB,aAAa,CAAC,GAAG,EAAE,OAAO,GAAG,MAAM,CAElD;AAED,wBAAgB,kBAAkB,CAChC,EAAE,EAAE,WAAW,EACf,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,gBAAgB,GACzB,IAAI,EAAE,CAER"}
@@ -0,0 +1,64 @@
1
+ import { rawTxV1Outputs as outputs } from "./outputs.js";
2
+ import { rawTxV1CalcId as calcId } from "../hash/tx.js";
3
+ import { applyWitness, splitWitness } from "./spends.js";
4
+ export { SpendBuilder, TxBuilder } from "./builder.js";
5
+ export { giftOutputFirstNameFromLockOutputs, htlcGiftOutputFirstName, htlcOrLock, htlcLockRootDigest, } from "./htlc.js";
6
+ export { multisigLock } from "./multisig.js";
7
+ export { witnessFromLock, witnessNew, lockMerkleProofFromLock, witnessFromLockMerkleProof, witnessClearSignatures, witnessWithPkhSignature, witnessWithHaxPreimage, spendV1FromLock, spendConditionFromWitness, } from "./witness.js";
8
+ export { applyWitness, splitWitness } from "./spends.js";
9
+ export function txEngineSettingsV1Default() {
10
+ return {
11
+ tx_engine_version: 1,
12
+ tx_engine_patch: 0,
13
+ min_fee: "256",
14
+ cost_per_word: "32768",
15
+ witness_word_div: 1,
16
+ };
17
+ }
18
+ export function txEngineSettingsV1BythosDefault() {
19
+ return {
20
+ tx_engine_version: 1,
21
+ tx_engine_patch: 1,
22
+ min_fee: "256",
23
+ cost_per_word: "16384",
24
+ witness_word_div: 4,
25
+ };
26
+ }
27
+ export { rawTxV1InputNames, rawTxV1InputSpendConditions, rawTxV1New, rawTxV1Version, spendV1Fee, spendV1TotalGifts, spendV1UnclampedFee, spendsV1Fee, spendsV1TotalFees, spendsV1TotalGifts, spendsV1UnclampedFee, } from "./accessors.js";
28
+ export { spendV1NewWitness, spendV1NewLegacy, spendV1SigHash } from "./spend.js";
29
+ export function spendsV1ApplyWitness(spends, witnessData) {
30
+ return applyWitness(spends, witnessData);
31
+ }
32
+ export function nockchainTxToRawTx(tx) {
33
+ const spends = applyWitness(tx.spends, tx.witness_data);
34
+ const id = calcId({ version: 1, id: "", spends });
35
+ return { version: 1, id, spends };
36
+ }
37
+ export function rawTxV1ToNockchainTx(raw) {
38
+ const { spends, witnessData } = splitWitness(raw.spends);
39
+ const id = calcId({ version: 1, id: "", spends });
40
+ return {
41
+ version: 1,
42
+ id,
43
+ spends,
44
+ display: { inputs: { tag: 0, inputs: [] }, outputs: [] },
45
+ witness_data: witnessData,
46
+ };
47
+ }
48
+ export function rawTxV1Outputs(obj, originPage, settings) {
49
+ return outputs(obj, originPage, settings);
50
+ }
51
+ export function rawTxTotalFees(obj) {
52
+ let total = 0n;
53
+ for (const [, spend] of obj.spends) {
54
+ total += BigInt(spend.fee);
55
+ }
56
+ return String(total);
57
+ }
58
+ export function rawTxV1CalcId(obj) {
59
+ return calcId(obj);
60
+ }
61
+ export function nockchainTxOutputs(tx, originPage, settings) {
62
+ return outputs(nockchainTxToRawTx(tx), originPage, settings);
63
+ }
64
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/tx/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { Digest, Lock } from "../types.js";
2
+ export declare function multisigLock(m: number, pkhDigests: readonly Digest[]): Lock;
3
+ //# sourceMappingURL=multisig.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"multisig.d.ts","sourceRoot":"","sources":["../../src/tx/multisig.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAIhD,wBAAgB,YAAY,CAAC,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,MAAM,EAAE,GAAG,IAAI,CAK3E"}
@@ -0,0 +1,8 @@
1
+ import { lockFromList, pkhNew, spendConditionNewPkh } from "../hash/index.js";
2
+ export function multisigLock(m, pkhDigests) {
3
+ if (m < 1 || m > pkhDigests.length) {
4
+ throw new Error(`invalid multisig m=${m} of n=${pkhDigests.length}`);
5
+ }
6
+ return lockFromList([spendConditionNewPkh(pkhNew(m, [...pkhDigests]))]);
7
+ }
8
+ //# sourceMappingURL=multisig.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"multisig.js","sourceRoot":"","sources":["../../src/tx/multisig.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAG9E,MAAM,UAAU,YAAY,CAAC,CAAS,EAAE,UAA6B;IACnE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC;QACnC,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,SAAS,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC;IACvE,CAAC;IACD,OAAO,YAAY,CAAC,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAC1E,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { Note, RawTxV1, TxEngineSettings } from "../types.js";
2
+ export declare function rawTxV1Outputs(obj: RawTxV1, originPage: number, settings: TxEngineSettings): Note[];
3
+ //# sourceMappingURL=outputs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"outputs.d.ts","sourceRoot":"","sources":["../../src/tx/outputs.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAIV,IAAI,EAGJ,OAAO,EAGP,gBAAgB,EACjB,MAAM,aAAa,CAAC;AAsBrB,wBAAgB,cAAc,CAC5B,GAAG,EAAE,OAAO,EACZ,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,gBAAgB,GACzB,IAAI,EAAE,CAuCR"}
@@ -0,0 +1,57 @@
1
+ import { mustAt } from "../core/must.js";
2
+ import { hashSeedV1, hashSeedsV1Digest } from "../hash/tx.js";
3
+ import { hashToDigest } from "../core/hashable.js";
4
+ import { hashZSetSingleton } from "../core/zbase.js";
5
+ import { lockRootHash } from "../hash/index.js";
6
+ import { nameV1 } from "../hash/note.js";
7
+ function normalizedSeed(seed) {
8
+ return { ...seed, output_source: null };
9
+ }
10
+ function mergeNoteData(entries) {
11
+ const map = new Map();
12
+ for (const data of entries) {
13
+ for (const [k, v] of data)
14
+ map.set(k, v);
15
+ }
16
+ return [...map.entries()];
17
+ }
18
+ function hashNormalizedSeedSet(seeds) {
19
+ const normalized = seeds.map(normalizedSeed);
20
+ if (normalized.length === 1) {
21
+ return hashToDigest(hashZSetSingleton(mustAt(normalized, 0), hashSeedV1));
22
+ }
23
+ return hashSeedsV1Digest(normalized);
24
+ }
25
+ export function rawTxV1Outputs(obj, originPage, settings) {
26
+ const seedsByLock = new Map();
27
+ for (const [, spend] of obj.spends) {
28
+ const seeds = spend.tag === 1 ? spend.seeds : spend.seeds;
29
+ for (const seed of seeds) {
30
+ const key = lockRootHash(seed.lock_root);
31
+ const list = seedsByLock.get(key) ?? [];
32
+ list.push(seed);
33
+ seedsByLock.set(key, list);
34
+ }
35
+ }
36
+ const outputs = [];
37
+ for (const [lockRootHashKey, seeds] of seedsByLock) {
38
+ if (seeds.length === 0)
39
+ continue;
40
+ const totalAssets = seeds.reduce((acc, s) => acc + BigInt(s.gift), 0n);
41
+ const noteData = settings.tx_engine_patch >= 1
42
+ ? mergeNoteData(seeds.map((s) => s.note_data))
43
+ : mustAt(seeds, 0).note_data;
44
+ const srcSetHash = hashNormalizedSeedSet(seeds);
45
+ const src = { hash: srcSetHash, is_coinbase: false };
46
+ const name = nameV1(lockRootHashKey, src);
47
+ outputs.push({
48
+ version: 1,
49
+ origin_page: originPage,
50
+ name,
51
+ note_data: noteData,
52
+ assets: String(totalAssets),
53
+ });
54
+ }
55
+ return outputs;
56
+ }
57
+ //# sourceMappingURL=outputs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"outputs.js","sourceRoot":"","sources":["../../src/tx/outputs.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import type { Nicks, SpendV1, SeedsV1, Witness } from "../types.js";
2
+ import type { Digest } from "../types.js";
3
+ export type LegacySignature = [string, {
4
+ c: string;
5
+ s: string;
6
+ }][];
7
+ export declare function spendV1NewWitness(witness: Witness, seeds: SeedsV1, fee: Nicks): SpendV1;
8
+ export declare function spendV1NewLegacy(seeds: SeedsV1, fee: Nicks): SpendV1;
9
+ export declare function spendV1SigHash(spend: SpendV1): Digest;
10
+ //# sourceMappingURL=spend.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spend.d.ts","sourceRoot":"","sources":["../../src/tx/spend.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAY,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAI9E,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAE1C,MAAM,MAAM,eAAe,GAAG,CAAC,MAAM,EAAE;IAAE,CAAC,EAAE,MAAM,CAAC;IAAC,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC,EAAE,CAAC;AAEnE,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,EAAE,KAAK,GAAG,OAAO,CAGvF;AAED,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,OAAO,EAAE,GAAG,EAAE,KAAK,GAAG,OAAO,CAEpE;AAGD,wBAAgB,cAAc,CAAC,KAAK,EAAE,OAAO,GAAG,MAAM,CAOrD"}
@@ -0,0 +1,17 @@
1
+ import { digestFromBase58 } from "../core/digest.js";
2
+ import { hashNicks, hashToDigest, hashTuple } from "../core/hashable.js";
3
+ import { hashSpendV1SigHash, seedsV1SigHash } from "../hash/tx.js";
4
+ export function spendV1NewWitness(witness, seeds, fee) {
5
+ const spend = { witness, seeds, fee };
6
+ return { tag: 1, ...spend };
7
+ }
8
+ export function spendV1NewLegacy(seeds, fee) {
9
+ return { tag: 0, signature: [], seeds, fee };
10
+ }
11
+ export function spendV1SigHash(spend) {
12
+ if (spend.tag === 1) {
13
+ return hashSpendV1SigHash(spend);
14
+ }
15
+ return hashToDigest(hashTuple(digestFromBase58(seedsV1SigHash(spend.seeds)), hashNicks(spend.fee)));
16
+ }
17
+ //# sourceMappingURL=spend.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spend.js","sourceRoot":"","sources":["../../src/tx/spend.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AACzE,OAAO,EAAE,kBAAkB,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAKnE,MAAM,UAAU,iBAAiB,CAAC,OAAgB,EAAE,KAAc,EAAE,GAAU;IAC5E,MAAM,KAAK,GAAa,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;IAChD,OAAO,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,KAAK,EAAE,CAAC;AAC9B,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,KAAc,EAAE,GAAU;IACzD,OAAO,EAAE,GAAG,EAAE,CAAC,EAAE,SAAS,EAAE,EAAqB,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;AAClE,CAAC;AAGD,MAAM,UAAU,cAAc,CAAC,KAAc;IAC3C,IAAI,KAAK,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC;QACpB,OAAO,kBAAkB,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IACD,OAAO,YAAY,CACjB,SAAS,CAAC,gBAAgB,CAAC,cAAc,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAC/E,CAAC;AACJ,CAAC"}
@@ -0,0 +1,8 @@
1
+ import type { Name, NockchainTx, SpendsV1, WitnessData } from "../types.js";
2
+ export declare function nameKey(name: Name): string;
3
+ export declare function splitWitness(spends: SpendsV1): {
4
+ spends: SpendsV1;
5
+ witnessData: WitnessData;
6
+ };
7
+ export declare function applyWitness(spends: SpendsV1, witnessData: NockchainTx["witness_data"]): SpendsV1;
8
+ //# sourceMappingURL=spends.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spends.d.ts","sourceRoot":"","sources":["../../src/tx/spends.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,WAAW,EAAW,QAAQ,EAAW,WAAW,EAAE,MAAM,aAAa,CAAC;AAE9F,wBAAgB,OAAO,CAAC,IAAI,EAAE,IAAI,GAAG,MAAM,CAE1C;AAqBD,wBAAgB,YAAY,CAAC,MAAM,EAAE,QAAQ,GAAG;IAAE,MAAM,EAAE,QAAQ,CAAC;IAAC,WAAW,EAAE,WAAW,CAAA;CAAE,CAe7F;AAED,wBAAgB,YAAY,CAC1B,MAAM,EAAE,QAAQ,EAChB,WAAW,EAAE,WAAW,CAAC,cAAc,CAAC,GACvC,QAAQ,CAYV"}
@@ -0,0 +1,48 @@
1
+ export function nameKey(name) {
2
+ return `${name.first}:${name.last}:${name._sig ?? 0}`;
3
+ }
4
+ function cloneWitness(w) {
5
+ return {
6
+ lock_merkle_proof: w.lock_merkle_proof,
7
+ pkh_signature: Array.isArray(w.pkh_signature) ? [...w.pkh_signature] : [],
8
+ hax_map: Array.isArray(w.hax_map) ? [...w.hax_map] : [],
9
+ tim: w.tim ?? null,
10
+ };
11
+ }
12
+ function stripWitness(w) {
13
+ return {
14
+ lock_merkle_proof: w.lock_merkle_proof,
15
+ pkh_signature: [],
16
+ hax_map: [],
17
+ tim: null,
18
+ };
19
+ }
20
+ export function splitWitness(spends) {
21
+ const outSpends = [];
22
+ const data = [];
23
+ for (const [name, spend] of spends) {
24
+ if (spend.tag !== 1) {
25
+ outSpends.push([name, spend]);
26
+ continue;
27
+ }
28
+ const witness = cloneWitness(spend.witness);
29
+ outSpends.push([name, { ...spend, witness: stripWitness(witness) }]);
30
+ data.push([name, witness]);
31
+ }
32
+ return { spends: outSpends, witnessData: { data } };
33
+ }
34
+ export function applyWitness(spends, witnessData) {
35
+ const witnessByName = new Map();
36
+ for (const [name, witness] of witnessData.data) {
37
+ witnessByName.set(nameKey(name), witness);
38
+ }
39
+ return spends.map(([name, spend]) => {
40
+ if (spend.tag !== 1)
41
+ return [name, spend];
42
+ const witness = witnessByName.get(nameKey(name));
43
+ if (!witness)
44
+ return [name, spend];
45
+ return [name, { ...spend, witness: cloneWitness(witness) }];
46
+ });
47
+ }
48
+ //# sourceMappingURL=spends.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spends.js","sourceRoot":"","sources":["../../src/tx/spends.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,OAAO,CAAC,IAAU;IAChC,OAAO,GAAG,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,EAAE,CAAC;AACxD,CAAC;AAED,SAAS,YAAY,CAAC,CAAU;IAC9B,OAAO;QACL,iBAAiB,EAAE,CAAC,CAAC,iBAAiB;QACtC,aAAa,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,EAAE;QACzE,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE;QACvD,GAAG,EAAE,CAAC,CAAC,GAAG,IAAI,IAAI;KACnB,CAAC;AACJ,CAAC;AAED,SAAS,YAAY,CAAC,CAAU;IAC9B,OAAO;QACL,iBAAiB,EAAE,CAAC,CAAC,iBAAiB;QACtC,aAAa,EAAE,EAAE;QACjB,OAAO,EAAE,EAAE;QACX,GAAG,EAAE,IAAI;KACV,CAAC;AACJ,CAAC;AAGD,MAAM,UAAU,YAAY,CAAC,MAAgB;IAC3C,MAAM,SAAS,GAAa,EAAE,CAAC;IAC/B,MAAM,IAAI,GAAsB,EAAE,CAAC;IAEnC,KAAK,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,MAAM,EAAE,CAAC;QACnC,IAAI,KAAK,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC;YACpB,SAAS,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC;YAC9B,SAAS;QACX,CAAC;QACD,MAAM,OAAO,GAAG,YAAY,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAC5C,SAAS,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,GAAG,KAAK,EAAE,OAAO,EAAE,YAAY,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC;QACrE,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;IAC7B,CAAC;IAED,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,WAAW,EAAE,EAAE,IAAI,EAAE,EAAE,CAAC;AACtD,CAAC;AAED,MAAM,UAAU,YAAY,CAC1B,MAAgB,EAChB,WAAwC;IAExC,MAAM,aAAa,GAAG,IAAI,GAAG,EAAmB,CAAC;IACjD,KAAK,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,IAAI,WAAW,CAAC,IAAI,EAAE,CAAC;QAC/C,aAAa,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC;IAC5C,CAAC;IAED,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,EAAE;QAClC,IAAI,KAAK,CAAC,GAAG,KAAK,CAAC;YAAE,OAAO,CAAC,IAAI,EAAE,KAAK,CAAoB,CAAC;QAC7D,MAAM,OAAO,GAAG,aAAa,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;QACjD,IAAI,CAAC,OAAO;YAAE,OAAO,CAAC,IAAI,EAAE,KAAK,CAAoB,CAAC;QACtD,OAAO,CAAC,IAAI,EAAE,EAAE,GAAG,KAAK,EAAE,OAAO,EAAE,YAAY,CAAC,OAAO,CAAC,EAAE,CAAoB,CAAC;IACjF,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,5 @@
1
+ export interface OutputNoteData {
2
+ memo?: string;
3
+ blob?: string;
4
+ }
5
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/tx/types.ts"],"names":[],"mappings":"AACA,MAAM,WAAW,cAAc;IAC7B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;CACf"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/tx/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,4 @@
1
+ import type { MissingUnlocks, SpendV1, TxEngineSettings } from "../types.js";
2
+ export declare function computeMissingUnlocks(spend: SpendV1): MissingUnlocks[];
3
+ export declare function missingUnlocksFee(spend: SpendV1, settings: TxEngineSettings): bigint;
4
+ //# sourceMappingURL=unlocks.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"unlocks.d.ts","sourceRoot":"","sources":["../../src/tx/unlocks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAU,cAAc,EAA4B,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAe/G,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,OAAO,GAAG,cAAc,EAAE,CAkCtE;AAGD,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,gBAAgB,GAAG,MAAM,CAUpF"}
@@ -0,0 +1,49 @@
1
+ function spendConditionPkh(sc) {
2
+ return sc.filter((p) => p.tag === "pkh");
3
+ }
4
+ function spendConditionHax(sc) {
5
+ return sc.filter((p) => p.tag === "hax");
6
+ }
7
+ function spendConditionBrn(sc) {
8
+ return sc.some((p) => p.tag === "brn");
9
+ }
10
+ export function computeMissingUnlocks(spend) {
11
+ if (spend.tag !== 1)
12
+ return [];
13
+ const s = spend;
14
+ const missing = [];
15
+ const presentSigs = new Set((Array.isArray(s.witness.pkh_signature) ? s.witness.pkh_signature : []).map(([pkh]) => pkh));
16
+ const sc = s.witness.lock_merkle_proof.spend_condition;
17
+ for (const p of spendConditionPkh(sc)) {
18
+ const hashes = Array.isArray(p.hashes) ? p.hashes : [];
19
+ const checked = hashes.filter((h) => presentSigs.has(h));
20
+ if (checked.length < p.m) {
21
+ const sigOf = hashes.filter((h) => !presentSigs.has(h));
22
+ missing.push({ Pkh: { num_sigs: p.m - checked.length, sig_of: sigOf } });
23
+ }
24
+ }
25
+ for (const h of spendConditionHax(sc)) {
26
+ const valid = new Set(Array.isArray(h.preimages) ? h.preimages : []);
27
+ const current = new Set((Array.isArray(s.witness.hax_map) ? s.witness.hax_map : []).map(([digest]) => digest));
28
+ const preimagesFor = [...valid].filter((d) => !current.has(d));
29
+ if (preimagesFor.length > 0) {
30
+ missing.push({ Hax: { preimages_for: preimagesFor } });
31
+ }
32
+ }
33
+ if (spendConditionBrn(sc)) {
34
+ missing.push("Brn");
35
+ }
36
+ return missing;
37
+ }
38
+ export function missingUnlocksFee(spend, settings) {
39
+ let fee = 0n;
40
+ for (const mu of computeMissingUnlocks(spend)) {
41
+ if (typeof mu === "object" && "Pkh" in mu) {
42
+ fee +=
43
+ (BigInt(settings.cost_per_word) * 35n * BigInt(mu.Pkh.num_sigs)) /
44
+ BigInt(settings.witness_word_div);
45
+ }
46
+ }
47
+ return fee;
48
+ }
49
+ //# sourceMappingURL=unlocks.js.map