@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,128 @@
1
+ import { mustAt } from "./must.js";
2
+ import { digestBeltsToBase58, digestFromBase58, digestFromBelts, } from "./digest.js";
3
+ import { hashFixed, hashVarlen } from "./tip5/index.js";
4
+ function beltsToDigest(belts) {
5
+ return digestBeltsToBase58(belts);
6
+ }
7
+ export function hashU64(v) {
8
+ return digestFromBelts(hashVarlen([1n, v]));
9
+ }
10
+ export function hashPair(a, b) {
11
+ return digestFromBelts(hashFixed([...a, ...b]));
12
+ }
13
+ export function hashBool(v) {
14
+ return hashU64(v ? 0n : 1n);
15
+ }
16
+ function hashDigestIdentity(d) {
17
+ return digestFromBase58(d);
18
+ }
19
+ export function hashTuple(a, b) {
20
+ return digestFromBelts(hashFixed([...a, ...b]));
21
+ }
22
+ export function hashString(s) {
23
+ let folded = 0n;
24
+ for (let i = 0; i < s.length; i++) {
25
+ folded |= BigInt(s.charCodeAt(i)) << BigInt(i * 8);
26
+ }
27
+ return hashU64(folded);
28
+ }
29
+ function hashOption(value, hashSome) {
30
+ if (value === null || value === undefined) {
31
+ return hashU64(0n);
32
+ }
33
+ return hashTuple(hashU64(0n), hashSome(value));
34
+ }
35
+ function hashZBaseEmpty() {
36
+ return hashU64(0n);
37
+ }
38
+ function digestListFromWire(hashes) {
39
+ if (Array.isArray(hashes)) {
40
+ return hashes;
41
+ }
42
+ return [];
43
+ }
44
+ function hashZSetDigests(digests) {
45
+ if (digests.length === 0) {
46
+ return hashZBaseEmpty();
47
+ }
48
+ if (digests.length === 1) {
49
+ const key = hashDigestIdentity(mustAt(digests, 0));
50
+ return hashTuple(key, hashTuple(hashZBaseEmpty(), hashZBaseEmpty()));
51
+ }
52
+ throw new Error("multi-element ZSet hashing not implemented");
53
+ }
54
+ export function hashPkh(pkh) {
55
+ const hashes = digestListFromWire(pkh.hashes);
56
+ return hashTuple(hashU64(BigInt(pkh.m)), hashZSetDigests(hashes));
57
+ }
58
+ export function hashHax(hax) {
59
+ const preimages = digestListFromWire(hax.preimages);
60
+ return hashZSetDigests(preimages);
61
+ }
62
+ function hashTimelockRange(range) {
63
+ return hashTuple(hashOption(range.min, (v) => hashU64(BigInt(v))), hashOption(range.max, (v) => hashU64(BigInt(v))));
64
+ }
65
+ function hashLockTim(tim) {
66
+ return hashTuple(hashTimelockRange(tim.rel), hashTimelockRange(tim.abs));
67
+ }
68
+ export function hashLockPrimitive(prim) {
69
+ switch (prim.tag) {
70
+ case "pkh":
71
+ return hashTuple(hashString("pkh"), hashPkh(prim));
72
+ case "tim":
73
+ return hashTuple(hashString("tim"), hashLockTim(prim));
74
+ case "hax":
75
+ return hashTuple(hashString("hax"), hashHax(prim));
76
+ case "brn":
77
+ return hashString("brn");
78
+ }
79
+ }
80
+ export function hashSpendCondition(sc) {
81
+ let acc = hashU64(0n);
82
+ for (let i = sc.length - 1; i >= 0; i--) {
83
+ acc = hashTuple(hashLockPrimitive(mustAt(sc, i)), acc);
84
+ }
85
+ return acc;
86
+ }
87
+ function hashLockV2(v) {
88
+ return hashTuple(hashSpendCondition(v.p), hashSpendCondition(v.q));
89
+ }
90
+ function hashLockV4(v) {
91
+ return hashTuple(hashLockV2(v.p), hashLockV2(v.q));
92
+ }
93
+ function hashLockV8(v) {
94
+ return hashTuple(hashLockV4(v.p), hashLockV4(v.q));
95
+ }
96
+ function hashLockV16(v) {
97
+ return hashTuple(hashLockV8(v.p), hashLockV8(v.q));
98
+ }
99
+ export function hashLock(lock) {
100
+ if (Array.isArray(lock)) {
101
+ return hashSpendCondition(lock);
102
+ }
103
+ switch (lock.tag) {
104
+ case 2:
105
+ return hashTuple(hashU64(2n), hashLockV2(lock));
106
+ case 4:
107
+ return hashTuple(hashU64(4n), hashLockV4(lock));
108
+ case 8:
109
+ return hashTuple(hashU64(8n), hashLockV8(lock));
110
+ case 16:
111
+ return hashTuple(hashU64(16n), hashLockV16(lock));
112
+ default:
113
+ throw new Error(`unsupported lock tag ${lock.tag}`);
114
+ }
115
+ }
116
+ export function hashLockRoot(root) {
117
+ if (typeof root === "string") {
118
+ return hashDigestIdentity(root);
119
+ }
120
+ return hashLock(root);
121
+ }
122
+ export function hashNicks(nicks) {
123
+ return hashU64(BigInt(nicks));
124
+ }
125
+ export function hashToDigest(belts) {
126
+ return beltsToDigest(belts);
127
+ }
128
+ //# sourceMappingURL=hashable.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hashable.js","sourceRoot":"","sources":["../../src/core/hashable.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import type { Lock, SpendCondition } from "../types.js";
2
+ import type { Digest } from "../types.js";
3
+ export declare function lockHeight(lock: Lock): number;
4
+ export declare function lockSpendCondition(lock: Lock, index: number): SpendCondition;
5
+ export declare function lockLeafCount(lock: Lock): number;
6
+ export declare function lockHashablePair(lock: Lock): [Lock, Lock] | null;
7
+ export declare function lockRootDigest(lock: Lock): Digest;
8
+ //# sourceMappingURL=lock.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lock.d.ts","sourceRoot":"","sources":["../../src/core/lock.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAExD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAE1C,wBAAgB,UAAU,CAAC,IAAI,EAAE,IAAI,GAAG,MAAM,CAc7C;AAgDD,wBAAgB,kBAAkB,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,GAAG,cAAc,CAqB5E;AAED,wBAAgB,aAAa,CAAC,IAAI,EAAE,IAAI,GAAG,MAAM,CAchD;AAED,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,IAAI,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,IAAI,CAchE;AAED,wBAAgB,cAAc,CAAC,IAAI,EAAE,IAAI,GAAG,MAAM,CAKjD"}
@@ -0,0 +1,95 @@
1
+ import { hashLock, hashSpendCondition, hashToDigest } from "./hashable.js";
2
+ export function lockHeight(lock) {
3
+ if (Array.isArray(lock))
4
+ return 1;
5
+ switch (lock.tag) {
6
+ case 2:
7
+ return 2;
8
+ case 4:
9
+ return 3;
10
+ case 8:
11
+ return 4;
12
+ case 16:
13
+ return 5;
14
+ default:
15
+ throw new Error(`unsupported lock tag ${lock.tag}`);
16
+ }
17
+ }
18
+ function lockV2Index(v, idx) {
19
+ return idx < 1 ? v.p : v.q;
20
+ }
21
+ function lockV4Index(v, idx) {
22
+ return idx < 2 ? lockV2Index(v.p, idx % 2) : lockV2Index(v.q, idx % 2);
23
+ }
24
+ function lockV8Index(v, idx) {
25
+ return idx < 4 ? lockV4Index(v.p, idx % 4) : lockV4Index(v.q, idx % 4);
26
+ }
27
+ function lockV16Index(v, idx) {
28
+ return idx < 8 ? lockV8Index(v.p, idx % 8) : lockV8Index(v.q, idx % 8);
29
+ }
30
+ export function lockSpendCondition(lock, index) {
31
+ if (Array.isArray(lock)) {
32
+ if (index >= 1)
33
+ throw new Error(`Index ${index} out of range for lock of height 1`);
34
+ return lock;
35
+ }
36
+ switch (lock.tag) {
37
+ case 2:
38
+ if (index >= 2)
39
+ throw new Error(`Index ${index} out of range for lock of height 2`);
40
+ return lockV2Index(lock, index);
41
+ case 4:
42
+ if (index >= 4)
43
+ throw new Error(`Index ${index} out of range for lock of height 4`);
44
+ return lockV4Index(lock, index);
45
+ case 8:
46
+ if (index >= 8)
47
+ throw new Error(`Index ${index} out of range for lock of height 8`);
48
+ return lockV8Index(lock, index);
49
+ case 16:
50
+ if (index >= 16)
51
+ throw new Error(`Index ${index} out of range for lock of height 16`);
52
+ return lockV16Index(lock, index);
53
+ default:
54
+ throw new Error(`unsupported lock tag ${lock.tag}`);
55
+ }
56
+ }
57
+ export function lockLeafCount(lock) {
58
+ if (Array.isArray(lock))
59
+ return 1;
60
+ switch (lock.tag) {
61
+ case 2:
62
+ return 1;
63
+ case 4:
64
+ return 2;
65
+ case 8:
66
+ return 4;
67
+ case 16:
68
+ return 8;
69
+ default:
70
+ throw new Error(`unsupported lock tag ${lock.tag}`);
71
+ }
72
+ }
73
+ export function lockHashablePair(lock) {
74
+ if (Array.isArray(lock))
75
+ return null;
76
+ switch (lock.tag) {
77
+ case 2:
78
+ return [lock.p, lock.q];
79
+ case 4:
80
+ return [lock.p, lock.q];
81
+ case 8:
82
+ return [lock.p, lock.q];
83
+ case 16:
84
+ return [lock.p, lock.q];
85
+ default:
86
+ throw new Error(`unsupported lock tag ${lock.tag}`);
87
+ }
88
+ }
89
+ export function lockRootDigest(lock) {
90
+ if (Array.isArray(lock)) {
91
+ return hashToDigest(hashSpendCondition(lock));
92
+ }
93
+ return hashToDigest(hashLock(lock));
94
+ }
95
+ //# sourceMappingURL=lock.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lock.js","sourceRoot":"","sources":["../../src/core/lock.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import type { Lock, MerkleProof } from "../types.js";
2
+ export interface MerkleProvenAxis {
3
+ proof: MerkleProof;
4
+ axis: bigint;
5
+ }
6
+ export declare function proveHashableLock(lock: Lock, index: number): MerkleProvenAxis;
7
+ //# sourceMappingURL=merkle.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"merkle.d.ts","sourceRoot":"","sources":["../../src/core/merkle.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAErD,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,WAAW,CAAC;IACnB,IAAI,EAAE,MAAM,CAAC;CACd;AAwBD,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,GAAG,gBAAgB,CAiC7E"}
@@ -0,0 +1,57 @@
1
+ import { digestFromBase58 } from "./digest.js";
2
+ import { hashLock, hashPair, hashSpendCondition, hashToDigest } from "./hashable.js";
3
+ import { lockHashablePair, lockLeafCount } from "./lock.js";
4
+ function leadingZeros64(v) {
5
+ if (v === 0n)
6
+ return 64;
7
+ let n = 0;
8
+ let x = v;
9
+ while ((x & (1n << 63n)) === 0n) {
10
+ n++;
11
+ x <<= 1n;
12
+ }
13
+ return n;
14
+ }
15
+ function hashLockSubtree(lock) {
16
+ const pair = lockHashablePair(lock);
17
+ if (!pair) {
18
+ if (Array.isArray(lock))
19
+ return hashSpendCondition(lock);
20
+ return hashLock(lock);
21
+ }
22
+ const [left, right] = pair;
23
+ return hashPair(hashLockSubtree(left), hashLockSubtree(right));
24
+ }
25
+ export function proveHashableLock(lock, index) {
26
+ const pair = lockHashablePair(lock);
27
+ if (!pair) {
28
+ const leaf = hashToDigest(hashLockSubtree(lock));
29
+ return {
30
+ proof: { root: leaf, path: [] },
31
+ axis: 1n,
32
+ };
33
+ }
34
+ const [left, right] = pair;
35
+ const lc = lockLeafCount(left);
36
+ if (index < lc) {
37
+ const rec = proveHashableLock(left, index);
38
+ const sib = hashToDigest(hashLockSubtree(right));
39
+ const root = hashToDigest(hashPair(digestFromBase58(rec.proof.root), digestFromBase58(sib)));
40
+ const alz = leadingZeros64(rec.axis);
41
+ const axis = rec.axis ^ (3n << BigInt(63 - alz));
42
+ return {
43
+ proof: { root, path: [...rec.proof.path, sib] },
44
+ axis,
45
+ };
46
+ }
47
+ const rec = proveHashableLock(right, index - lc);
48
+ const sib = hashToDigest(hashLockSubtree(left));
49
+ const root = hashToDigest(hashPair(digestFromBase58(sib), digestFromBase58(rec.proof.root)));
50
+ const alz = leadingZeros64(rec.axis);
51
+ const axis = rec.axis ^ (2n << BigInt(63 - alz));
52
+ return {
53
+ proof: { root, path: [...rec.proof.path, sib] },
54
+ axis,
55
+ };
56
+ }
57
+ //# sourceMappingURL=merkle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"merkle.js","sourceRoot":"","sources":["../../src/core/merkle.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export declare function must<T>(value: T | null | undefined, message?: string): T;
2
+ export declare function mustAt<T>(arr: ArrayLike<T>, index: number, message?: string): T;
3
+ //# sourceMappingURL=must.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"must.d.ts","sourceRoot":"","sources":["../../src/core/must.ts"],"names":[],"mappings":"AACA,wBAAgB,IAAI,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,GAAG,IAAI,GAAG,SAAS,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,CAAC,CAKxE;AAGD,wBAAgB,MAAM,CAAC,CAAC,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,CAAC,CAM/E"}
@@ -0,0 +1,14 @@
1
+ export function must(value, message) {
2
+ if (value === null || value === undefined) {
3
+ throw new Error(message ?? "expected value");
4
+ }
5
+ return value;
6
+ }
7
+ export function mustAt(arr, index, message) {
8
+ const value = arr[index];
9
+ if (value === undefined) {
10
+ throw new Error(message ?? `expected element at index ${index}`);
11
+ }
12
+ return value;
13
+ }
14
+ //# sourceMappingURL=must.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"must.js","sourceRoot":"","sources":["../../src/core/must.ts"],"names":[],"mappings":"AACA,MAAM,UAAU,IAAI,CAAI,KAA2B,EAAE,OAAgB;IACnE,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;QAC1C,MAAM,IAAI,KAAK,CAAC,OAAO,IAAI,gBAAgB,CAAC,CAAC;IAC/C,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAGD,MAAM,UAAU,MAAM,CAAI,GAAiB,EAAE,KAAa,EAAE,OAAgB;IAC1E,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC;IACzB,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;QACxB,MAAM,IAAI,KAAK,CAAC,OAAO,IAAI,6BAA6B,KAAK,EAAE,CAAC,CAAC;IACnE,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC"}
@@ -0,0 +1,10 @@
1
+ export declare const DIGEST_LENGTH = 5;
2
+ export declare const STATE_SIZE = 16;
3
+ export declare const NUM_SPLIT_AND_LOOKUP = 4;
4
+ export declare const RATE = 10;
5
+ export declare const NUM_ROUNDS = 7;
6
+ export declare const R = 18446744073709551616n;
7
+ export declare const LOOKUP_TABLE: Uint8Array<ArrayBuffer>;
8
+ export declare const ROUND_CONSTANTS: BigUint64Array<ArrayBuffer>;
9
+ export declare const MDS_MATRIX: bigint[][];
10
+ //# sourceMappingURL=constants.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/core/tip5/constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,aAAa,IAAI,CAAC;AAC/B,eAAO,MAAM,UAAU,KAAK,CAAC;AAC7B,eAAO,MAAM,oBAAoB,IAAI,CAAC;AACtC,eAAO,MAAM,IAAI,KAAK,CAAC;AACvB,eAAO,MAAM,UAAU,IAAI,CAAC;AAC5B,eAAO,MAAM,CAAC,wBAAwB,CAAC;AAEvC,eAAO,MAAM,YAAY,yBAcvB,CAAC;AAEH,eAAO,MAAM,eAAe,6BA6B1B,CAAC;AAEH,eAAO,MAAM,UAAU,EAAE,MAAM,EAAE,EAiBhC,CAAC"}
@@ -0,0 +1,70 @@
1
+ export const DIGEST_LENGTH = 5;
2
+ export const STATE_SIZE = 16;
3
+ export const NUM_SPLIT_AND_LOOKUP = 4;
4
+ export const RATE = 10;
5
+ export const NUM_ROUNDS = 7;
6
+ export const R = 18446744073709551616n;
7
+ export const LOOKUP_TABLE = new Uint8Array([
8
+ 0, 7, 26, 63, 124, 215, 85, 254, 214, 228, 45, 185, 140, 173, 33, 240, 29, 177, 176, 32, 8,
9
+ 110, 87, 202, 204, 99, 150, 106, 230, 14, 235, 128, 213, 239, 212, 138, 23, 130, 208, 6, 44,
10
+ 71, 93, 116, 146, 189, 251, 81, 199, 97, 38, 28, 73, 179, 95, 84, 152, 48, 35, 119, 49, 88,
11
+ 242, 3, 148, 169, 72, 120, 62, 161, 166, 83, 175, 191, 137, 19, 100, 129, 112, 55, 221, 102,
12
+ 218, 61, 151, 237, 68, 164, 17, 147, 46, 234, 203, 216, 22, 141, 65, 57, 123, 12, 244, 54, 219,
13
+ 231, 96, 77, 180, 154, 5, 253, 133, 165, 98, 195, 205, 134, 245, 30, 9, 188, 59, 142, 186, 197,
14
+ 181, 144, 92, 31, 224, 163, 111, 74, 58, 69, 113, 196, 67, 246, 225, 10, 121, 50, 60, 157, 90,
15
+ 122, 2, 250, 101, 75, 178, 159, 24, 36, 201, 11, 243, 132, 198, 190, 114, 233, 39, 52, 21, 209,
16
+ 108, 238, 91, 187, 18, 104, 194, 37, 153, 34, 200, 143, 126, 155, 236, 118, 64, 80, 172, 89,
17
+ 94, 193, 135, 183, 86, 107, 252, 13, 167, 206, 136, 220, 207, 103, 171, 160, 76, 182, 227, 217,
18
+ 158, 56, 174, 4, 66, 109, 139, 162, 184, 211, 249, 47, 125, 232, 117, 43, 16, 42, 127, 20, 241,
19
+ 25, 149, 105, 156, 51, 53, 168, 145, 247, 223, 79, 78, 226, 15, 222, 82, 115, 70, 210, 27, 41,
20
+ 1, 170, 40, 131, 192, 229, 248, 255,
21
+ ]);
22
+ export const ROUND_CONSTANTS = new BigUint64Array([
23
+ 1332676891236936200n, 16607633045354064669n, 12746538998793080786n, 15240351333789289931n,
24
+ 10333439796058208418n, 986873372968378050n, 153505017314310505n, 703086547770691416n,
25
+ 8522628845961587962n, 1727254290898686320n, 199492491401196126n, 2969174933639985366n,
26
+ 1607536590362293391n, 16971515075282501568n, 15401316942841283351n, 14178982151025681389n,
27
+ 2916963588744282587n, 5474267501391258599n, 5350367839445462659n, 7436373192934779388n,
28
+ 12563531800071493891n, 12265318129758141428n, 6524649031155262053n, 1388069597090660214n,
29
+ 3049665785814990091n, 5225141380721656276n, 10399487208361035835n, 6576713996114457203n,
30
+ 12913805829885867278n, 10299910245954679423n, 12980779960345402499n, 593670858850716490n,
31
+ 12184128243723146967n, 1315341360419235257n, 9107195871057030023n, 4354141752578294067n,
32
+ 8824457881527486794n, 14811586928506712910n, 7768837314956434138n, 2807636171572954860n,
33
+ 9487703495117094125n, 13452575580428891895n, 14689488045617615844n, 16144091782672017853n,
34
+ 15471922440568867245n, 17295382518415944107n, 15054306047726632486n, 5708955503115886019n,
35
+ 9596017237020520842n, 16520851172964236909n, 8513472793890943175n, 8503326067026609602n,
36
+ 9402483918549940854n, 8614816312698982446n, 7744830563717871780n, 14419404818700162041n,
37
+ 8090742384565069824n, 15547662568163517559n, 17314710073626307254n, 10008393716631058961n,
38
+ 14480243402290327574n, 13569194973291808551n, 10573516815088946209n, 15120483436559336219n,
39
+ 3515151310595301563n, 1095382462248757907n, 5323307938514209350n, 14204542692543834582n,
40
+ 12448773944668684656n, 13967843398310696452n, 14838288394107326806n, 13718313940616442191n,
41
+ 15032565440414177483n, 13769903572116157488n, 17074377440395071208n, 16931086385239297738n,
42
+ 8723550055169003617n, 590842605971518043n, 16642348030861036090n, 10708719298241282592n,
43
+ 12766914315707517909n, 11780889552403245587n, 113183285481780712n, 9019899125655375514n,
44
+ 3300264967390964820n, 12802381622653377935n, 891063765000023873n, 15939045541699412539n,
45
+ 3240223189948727743n, 4087221142360949772n, 10980466041788253952n, 18199914337033135244n,
46
+ 7168108392363190150n, 16860278046098150740n, 13088202265571714855n, 4712275036097525581n,
47
+ 16338034078141228133n, 1455012125527134274n, 5024057780895012002n, 9289161311673217186n,
48
+ 9401110072402537104n, 11919498251456187748n, 4173156070774045271n, 15647643457869530627n,
49
+ 15642078237964257476n, 1405048341078324037n, 3059193199283698832n, 1605012781983592984n,
50
+ 7134876918849821827n, 5796994175286958720n, 7251651436095127661n, 4565856221886323991n,
51
+ ]);
52
+ export const MDS_MATRIX = [
53
+ [61402n, 17845n, 26798n, 59689n, 12021n, 40901n, 41351n, 27521n, 56951n, 12034n, 53865n, 43244n, 7454n, 33823n, 28750n, 1108n],
54
+ [1108n, 61402n, 17845n, 26798n, 59689n, 12021n, 40901n, 41351n, 27521n, 56951n, 12034n, 53865n, 43244n, 7454n, 33823n, 28750n],
55
+ [28750n, 1108n, 61402n, 17845n, 26798n, 59689n, 12021n, 40901n, 41351n, 27521n, 56951n, 12034n, 53865n, 43244n, 7454n, 33823n],
56
+ [33823n, 28750n, 1108n, 61402n, 17845n, 26798n, 59689n, 12021n, 40901n, 41351n, 27521n, 56951n, 12034n, 53865n, 43244n, 7454n],
57
+ [7454n, 33823n, 28750n, 1108n, 61402n, 17845n, 26798n, 59689n, 12021n, 40901n, 41351n, 27521n, 56951n, 12034n, 53865n, 43244n],
58
+ [43244n, 7454n, 33823n, 28750n, 1108n, 61402n, 17845n, 26798n, 59689n, 12021n, 40901n, 41351n, 27521n, 56951n, 12034n, 53865n],
59
+ [53865n, 43244n, 7454n, 33823n, 28750n, 1108n, 61402n, 17845n, 26798n, 59689n, 12021n, 40901n, 41351n, 27521n, 56951n, 12034n],
60
+ [12034n, 53865n, 43244n, 7454n, 33823n, 28750n, 1108n, 61402n, 17845n, 26798n, 59689n, 12021n, 40901n, 41351n, 27521n, 56951n],
61
+ [56951n, 12034n, 53865n, 43244n, 7454n, 33823n, 28750n, 1108n, 61402n, 17845n, 26798n, 59689n, 12021n, 40901n, 41351n, 27521n],
62
+ [27521n, 56951n, 12034n, 53865n, 43244n, 7454n, 33823n, 28750n, 1108n, 61402n, 17845n, 26798n, 59689n, 12021n, 40901n, 41351n],
63
+ [41351n, 27521n, 56951n, 12034n, 53865n, 43244n, 7454n, 33823n, 28750n, 1108n, 61402n, 17845n, 26798n, 59689n, 12021n, 40901n],
64
+ [40901n, 41351n, 27521n, 56951n, 12034n, 53865n, 43244n, 7454n, 33823n, 28750n, 1108n, 61402n, 17845n, 26798n, 59689n, 12021n],
65
+ [12021n, 40901n, 41351n, 27521n, 56951n, 12034n, 53865n, 43244n, 7454n, 33823n, 28750n, 1108n, 61402n, 17845n, 26798n, 59689n],
66
+ [59689n, 12021n, 40901n, 41351n, 27521n, 56951n, 12034n, 53865n, 43244n, 7454n, 33823n, 28750n, 1108n, 61402n, 17845n, 26798n],
67
+ [26798n, 59689n, 12021n, 40901n, 41351n, 27521n, 56951n, 12034n, 53865n, 43244n, 7454n, 33823n, 28750n, 1108n, 61402n, 17845n],
68
+ [17845n, 26798n, 59689n, 12021n, 40901n, 41351n, 27521n, 56951n, 12034n, 53865n, 43244n, 7454n, 33823n, 28750n, 1108n, 61402n],
69
+ ];
70
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../src/core/tip5/constants.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,CAAC;AAC/B,MAAM,CAAC,MAAM,UAAU,GAAG,EAAE,CAAC;AAC7B,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,CAAC;AACtC,MAAM,CAAC,MAAM,IAAI,GAAG,EAAE,CAAC;AACvB,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,CAAC;AAC5B,MAAM,CAAC,MAAM,CAAC,GAAG,qBAAqB,CAAC;AAEvC,MAAM,CAAC,MAAM,YAAY,GAAG,IAAI,UAAU,CAAC;IACzC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC;IAC1F,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE;IAC3F,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE;IAC1F,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG;IAC3F,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG;IAC9F,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;IAC9F,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE;IAC7F,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG;IAC9F,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE;IAC3F,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;IAC9F,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE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MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC;IAC9H,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC;IAC9H,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC;IAC9H,CAAC,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC;IAC9H,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC;IAC9H,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC;IAC9H,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC;IAC9H,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC;IAC9H,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC;IAC9H,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC;IAC9H,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC;IAC9H,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC;IAC9H,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC;IAC9H,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC;CAC/H,CAAC"}
@@ -0,0 +1,5 @@
1
+ import { type Belt } from "../belt.js";
2
+ export declare function permute(sponge: Belt[]): void;
3
+ export declare function hashVarlen(input: Belt[]): Belt[];
4
+ export declare function hashFixed(input: Belt[]): Belt[];
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/core/tip5/index.ts"],"names":[],"mappings":"AACA,OAAO,EAML,KAAK,IAAI,EAEV,MAAM,YAAY,CAAC;AAiDpB,wBAAgB,OAAO,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,IAAI,CAS5C;AAmDD,wBAAgB,UAAU,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,CAIhD;AAED,wBAAgB,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,CAI/C"}
@@ -0,0 +1,100 @@
1
+ import { mustAt } from "../must.js";
2
+ import { badd, bmul, bpow, montReduction, montify, PRIME_128, } from "../belt.js";
3
+ import { LOOKUP_TABLE, MDS_MATRIX, NUM_ROUNDS, NUM_SPLIT_AND_LOOKUP, R, RATE, ROUND_CONSTANTS, STATE_SIZE, } from "./constants.js";
4
+ function sboxLayer(state) {
5
+ const res = new Array(STATE_SIZE).fill(0n);
6
+ for (let i = 0; i < NUM_SPLIT_AND_LOOKUP; i++) {
7
+ const bytes = new Uint8Array(8);
8
+ let v = mustAt(state, i);
9
+ for (let j = 0; j < 8; j++) {
10
+ bytes[j] = Number(v & 0xffn);
11
+ v >>= 8n;
12
+ }
13
+ for (let j = 0; j < 8; j++) {
14
+ bytes[j] = mustAt(LOOKUP_TABLE, mustAt(bytes, j));
15
+ }
16
+ let out = 0n;
17
+ for (let j = 7; j >= 0; j--) {
18
+ out = (out << 8n) | BigInt(mustAt(bytes, j));
19
+ }
20
+ res[i] = out;
21
+ }
22
+ for (let j = NUM_SPLIT_AND_LOOKUP; j < STATE_SIZE; j++) {
23
+ res[j] = bpow(mustAt(state, j), 7n);
24
+ }
25
+ return res;
26
+ }
27
+ function linearLayer(state) {
28
+ const result = new Array(STATE_SIZE).fill(0n);
29
+ for (let i = 0; i < STATE_SIZE; i++) {
30
+ for (let j = 0; j < STATE_SIZE; j++) {
31
+ const product = bmul(mustAt(mustAt(MDS_MATRIX, i), j), mustAt(state, j));
32
+ result[i] = badd(mustAt(result, i), product);
33
+ }
34
+ }
35
+ return result;
36
+ }
37
+ export function permute(sponge) {
38
+ for (let i = 0; i < NUM_ROUNDS; i++) {
39
+ const a = sboxLayer(sponge);
40
+ const b = linearLayer(a);
41
+ for (let j = 0; j < STATE_SIZE; j++) {
42
+ const rCons = ((mustAt(ROUND_CONSTANTS, i * STATE_SIZE + j) * R) % PRIME_128);
43
+ sponge[j] = badd(rCons, mustAt(b, j));
44
+ }
45
+ }
46
+ }
47
+ function tip5MontifyVec(input) {
48
+ return input.map((b) => montify(b));
49
+ }
50
+ function tip5CalcDigest(sponge) {
51
+ return sponge.slice(0, 5).map((v) => montReduction(v));
52
+ }
53
+ function createInitSpongeVariable() {
54
+ return new Array(STATE_SIZE).fill(0n);
55
+ }
56
+ function createInitSpongeFixed() {
57
+ const sponge = new Array(STATE_SIZE).fill(0n);
58
+ for (let i = 10; i < STATE_SIZE; i++) {
59
+ sponge[i] = 4294967295n;
60
+ }
61
+ return sponge;
62
+ }
63
+ function tip5AbsorbSponge(sponge, input, pad) {
64
+ const r = input.length % RATE;
65
+ const fullChunks = Math.floor(input.length / RATE);
66
+ for (let chunkIdx = 0; chunkIdx < fullChunks; chunkIdx++) {
67
+ const chunk = tip5MontifyVec(input.slice(chunkIdx * RATE, (chunkIdx + 1) * RATE));
68
+ for (let i = 0; i < RATE; i++) {
69
+ sponge[i] = mustAt(chunk, i);
70
+ }
71
+ permute(sponge);
72
+ }
73
+ if (pad) {
74
+ const tail = new Array(RATE).fill(0n);
75
+ const end = input.slice(fullChunks * RATE);
76
+ for (let i = 0; i < end.length; i++) {
77
+ tail[i] = mustAt(end, i);
78
+ }
79
+ tail[end.length] = 1n;
80
+ const chunk = tip5MontifyVec(tail);
81
+ for (let i = 0; i < RATE; i++) {
82
+ sponge[i] = mustAt(chunk, i);
83
+ }
84
+ permute(sponge);
85
+ }
86
+ else if (r !== 0) {
87
+ throw new Error("unpadded input must be multiple of RATE");
88
+ }
89
+ }
90
+ export function hashVarlen(input) {
91
+ const sponge = createInitSpongeVariable();
92
+ tip5AbsorbSponge(sponge, input, true);
93
+ return tip5CalcDigest(sponge);
94
+ }
95
+ export function hashFixed(input) {
96
+ const sponge = createInitSpongeFixed();
97
+ tip5AbsorbSponge(sponge, input, false);
98
+ return tip5CalcDigest(sponge);
99
+ }
100
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core/tip5/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ export declare class U256 {
2
+ readonly value: bigint;
3
+ constructor(value: bigint);
4
+ static readonly ZERO: U256;
5
+ static fromU64(n: bigint): U256;
6
+ static fromBeBytes(bytes: Uint8Array): U256;
7
+ static fromLeBytes(bytes: Uint8Array): U256;
8
+ static fromLeHex(hex: string): U256;
9
+ toBeBytes(): Uint8Array;
10
+ toLeBytes(): Uint8Array;
11
+ lt(other: U256): boolean;
12
+ eq(other: U256): boolean;
13
+ addMod(other: U256, modulus: U256): U256;
14
+ mulMod(other: U256, modulus: U256): U256;
15
+ }
16
+ export declare const G_ORDER: U256;
17
+ export declare const P_BIG: U256;
18
+ export declare const P_BIG_2: U256;
19
+ export declare const P_BIG_3: U256;
20
+ export declare function truncGOrder(digest: bigint[]): U256;
21
+ //# sourceMappingURL=u256.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"u256.d.ts","sourceRoot":"","sources":["../../src/core/u256.ts"],"names":[],"mappings":"AAUA,qBAAa,IAAI;IACf,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;gBAEX,KAAK,EAAE,MAAM;IAIzB,MAAM,CAAC,QAAQ,CAAC,IAAI,OAAgB;IAEpC,MAAM,CAAC,OAAO,CAAC,CAAC,EAAE,MAAM,GAAG,IAAI;IAI/B,MAAM,CAAC,WAAW,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;IAQ3C,MAAM,CAAC,WAAW,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;IAQ3C,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAYnC,SAAS,IAAI,UAAU;IAUvB,SAAS,IAAI,UAAU;IAUvB,EAAE,CAAC,KAAK,EAAE,IAAI,GAAG,OAAO;IAIxB,EAAE,CAAC,KAAK,EAAE,IAAI,GAAG,OAAO;IAIxB,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,GAAG,IAAI;IAIxC,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,GAAG,IAAI;CAGzC;AAGD,eAAO,MAAM,OAAO,MAKnB,CAAC;AAEF,eAAO,MAAM,KAAK,MAKjB,CAAC;AAEF,eAAO,MAAM,OAAO,MAKnB,CAAC;AAEF,eAAO,MAAM,OAAO,MAKnB,CAAC;AAEF,wBAAgB,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAQlD"}