@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,96 @@
1
+ import { mustAt } from "./must.js";
2
+ const U256_MASK = (1n << 256n) - 1n;
3
+ function mod256(x) {
4
+ return x & U256_MASK;
5
+ }
6
+ export class U256 {
7
+ value;
8
+ constructor(value) {
9
+ this.value = mod256(value);
10
+ }
11
+ static ZERO = new U256(0n);
12
+ static fromU64(n) {
13
+ return new U256(n);
14
+ }
15
+ static fromBeBytes(bytes) {
16
+ let v = 0n;
17
+ for (const b of bytes) {
18
+ v = (v << 8n) | BigInt(b);
19
+ }
20
+ return new U256(v);
21
+ }
22
+ static fromLeBytes(bytes) {
23
+ let v = 0n;
24
+ for (let i = bytes.length - 1; i >= 0; i--) {
25
+ v = (v << 8n) | BigInt(mustAt(bytes, i));
26
+ }
27
+ return new U256(v);
28
+ }
29
+ static fromLeHex(hex) {
30
+ const clean = hex.startsWith("0x") ? hex.slice(2) : hex;
31
+ if (clean.length === 0)
32
+ return U256.ZERO;
33
+ const padded = clean.length % 2 === 0 ? clean : "0" + clean;
34
+ const bytes = new Uint8Array(padded.length / 2);
35
+ for (let i = 0; i < bytes.length; i++) {
36
+ bytes[i] = parseInt(padded.slice(i * 2, i * 2 + 2), 16);
37
+ }
38
+ return U256.fromLeBytes(bytes);
39
+ }
40
+ toBeBytes() {
41
+ const out = new Uint8Array(32);
42
+ let v = this.value;
43
+ for (let i = 31; i >= 0; i--) {
44
+ out[i] = Number(v & 0xffn);
45
+ v >>= 8n;
46
+ }
47
+ return out;
48
+ }
49
+ toLeBytes() {
50
+ const out = new Uint8Array(32);
51
+ let v = this.value;
52
+ for (let i = 0; i < 32; i++) {
53
+ out[i] = Number(v & 0xffn);
54
+ v >>= 8n;
55
+ }
56
+ return out;
57
+ }
58
+ lt(other) {
59
+ return this.value < other.value;
60
+ }
61
+ eq(other) {
62
+ return this.value === other.value;
63
+ }
64
+ addMod(other, modulus) {
65
+ return new U256((this.value + other.value) % modulus.value);
66
+ }
67
+ mulMod(other, modulus) {
68
+ return new U256((this.value * other.value) % modulus.value);
69
+ }
70
+ }
71
+ export const G_ORDER = U256.fromBeBytes(new Uint8Array([
72
+ 0x7a, 0xf2, 0x59, 0x9b, 0x3b, 0x3f, 0x22, 0xd0, 0x56, 0x3f, 0xbf, 0x0f, 0x99, 0x0a, 0x37, 0xb5,
73
+ 0x32, 0x7a, 0xa7, 0x23, 0x30, 0x15, 0x77, 0x22, 0xd4, 0x43, 0x62, 0x3e, 0xae, 0xd4, 0xac, 0xcf,
74
+ ]));
75
+ export const P_BIG = U256.fromBeBytes(new Uint8Array([
76
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
77
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x01,
78
+ ]));
79
+ export const P_BIG_2 = U256.fromBeBytes(new Uint8Array([
80
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
81
+ 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x02, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x01,
82
+ ]));
83
+ export const P_BIG_3 = U256.fromBeBytes(new Uint8Array([
84
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xfd, 0x00, 0x00, 0x00, 0x05,
85
+ 0xff, 0xff, 0xff, 0xf9, 0x00, 0x00, 0x00, 0x05, 0xff, 0xff, 0xff, 0xfd, 0x00, 0x00, 0x00, 0x01,
86
+ ]));
87
+ export function truncGOrder(digest) {
88
+ let result = U256.fromU64(mustAt(digest, 0));
89
+ const term1 = P_BIG.mulMod(U256.fromU64(mustAt(digest, 1)), G_ORDER);
90
+ result = result.addMod(term1, G_ORDER);
91
+ const term2 = P_BIG_2.mulMod(U256.fromU64(mustAt(digest, 2)), G_ORDER);
92
+ result = result.addMod(term2, G_ORDER);
93
+ const term3 = P_BIG_3.mulMod(U256.fromU64(mustAt(digest, 3)), G_ORDER);
94
+ return result.addMod(term3, G_ORDER);
95
+ }
96
+ //# sourceMappingURL=u256.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"u256.js","sourceRoot":"","sources":["../../src/core/u256.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,20 @@
1
+ export declare class UBig {
2
+ readonly value: bigint;
3
+ private constructor();
4
+ static zero(): UBig;
5
+ static from(value: bigint | number | string): UBig;
6
+ static fromLeBytes(bytes: Uint8Array): UBig;
7
+ isZero(): boolean;
8
+ eq(other: UBig): boolean;
9
+ bitLen(): number;
10
+ toLeBytes(): Uint8Array;
11
+ toHex(): string;
12
+ tryIntoU64(): bigint | null;
13
+ divRem(divisor: bigint): {
14
+ quotient: UBig;
15
+ remainder: UBig;
16
+ };
17
+ clone(): UBig;
18
+ }
19
+ export declare function beltsFromUbig(num: UBig): bigint[];
20
+ //# sourceMappingURL=ubig.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ubig.d.ts","sourceRoot":"","sources":["../../src/core/ubig.ts"],"names":[],"mappings":"AAKA,qBAAa,IAAI;IACK,QAAQ,CAAC,KAAK,EAAE,MAAM;IAA1C,OAAO;IAEP,MAAM,CAAC,IAAI,IAAI,IAAI;IAInB,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,IAAI;IAQlD,MAAM,CAAC,WAAW,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;IAQ3C,MAAM,IAAI,OAAO;IAIjB,EAAE,CAAC,KAAK,EAAE,IAAI,GAAG,OAAO;IAIxB,MAAM,IAAI,MAAM;IAKhB,SAAS,IAAI,UAAU;IAYvB,KAAK,IAAI,MAAM;IAKf,UAAU,IAAI,MAAM,GAAG,IAAI;IAK3B,MAAM,CAAC,OAAO,EAAE,MAAM,GAAG;QAAE,QAAQ,EAAE,IAAI,CAAC;QAAC,SAAS,EAAE,IAAI,CAAA;KAAE;IAM5D,KAAK,IAAI,IAAI;CAGd;AAED,wBAAgB,aAAa,CAAC,GAAG,EAAE,IAAI,GAAG,MAAM,EAAE,CAYjD"}
@@ -0,0 +1,81 @@
1
+ import { PRIME } from "./belt.js";
2
+ import { mustAt } from "./must.js";
3
+ export class UBig {
4
+ value;
5
+ constructor(value) {
6
+ this.value = value;
7
+ }
8
+ static zero() {
9
+ return new UBig(0n);
10
+ }
11
+ static from(value) {
12
+ if (typeof value === "string") {
13
+ if (value === "" || value === "0")
14
+ return UBig.zero();
15
+ return new UBig(BigInt("0x" + value));
16
+ }
17
+ return new UBig(BigInt(value));
18
+ }
19
+ static fromLeBytes(bytes) {
20
+ let v = 0n;
21
+ for (let i = bytes.length - 1; i >= 0; i--) {
22
+ v = (v << 8n) | BigInt(mustAt(bytes, i));
23
+ }
24
+ return new UBig(v);
25
+ }
26
+ isZero() {
27
+ return this.value === 0n;
28
+ }
29
+ eq(other) {
30
+ return this.value === other.value;
31
+ }
32
+ bitLen() {
33
+ if (this.isZero())
34
+ return 0;
35
+ return this.value.toString(2).length;
36
+ }
37
+ toLeBytes() {
38
+ if (this.isZero())
39
+ return new Uint8Array([0]);
40
+ let hex = this.value.toString(16);
41
+ if (hex.length % 2 !== 0)
42
+ hex = "0" + hex;
43
+ const bytes = new Uint8Array(hex.length / 2);
44
+ for (let i = 0; i < bytes.length; i++) {
45
+ const byteHex = hex.slice(hex.length - 2 * (i + 1), hex.length - 2 * i);
46
+ bytes[i] = parseInt(byteHex, 16);
47
+ }
48
+ return bytes;
49
+ }
50
+ toHex() {
51
+ if (this.isZero())
52
+ return "0";
53
+ return this.value.toString(16);
54
+ }
55
+ tryIntoU64() {
56
+ if (this.value < 0n || this.value > 0xffffffffffffffffn)
57
+ return null;
58
+ return this.value;
59
+ }
60
+ divRem(divisor) {
61
+ const q = this.value / divisor;
62
+ const r = this.value % divisor;
63
+ return { quotient: new UBig(q), remainder: new UBig(r) };
64
+ }
65
+ clone() {
66
+ return new UBig(this.value);
67
+ }
68
+ }
69
+ export function beltsFromUbig(num) {
70
+ const belts = [];
71
+ let remainder = num;
72
+ const zero = UBig.zero();
73
+ const p = PRIME;
74
+ while (!remainder.eq(zero)) {
75
+ const { quotient, remainder: rem } = remainder.divRem(p);
76
+ belts.push(rem.value);
77
+ remainder = quotient;
78
+ }
79
+ return belts;
80
+ }
81
+ //# sourceMappingURL=ubig.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ubig.js","sourceRoot":"","sources":["../../src/core/ubig.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import { type DigestBelts } from "./digest.js";
2
+ import type { NounTree } from "../noun/types.js";
3
+ export interface ZNode<E> {
4
+ entry: E;
5
+ left: ZNode<E> | null;
6
+ right: ZNode<E> | null;
7
+ }
8
+ export declare function buildZTree<K, E>(entries: E[], getKey: (e: E) => K, keyNoun: (k: K) => NounTree): ZNode<E> | null;
9
+ export declare function hashZSetSingleton<E>(entry: E, entryHash: (e: E) => DigestBelts): DigestBelts;
10
+ export declare function hashZNode<E>(node: ZNode<E> | null, entryHash: (e: E) => DigestBelts): DigestBelts;
11
+ //# sourceMappingURL=zbase.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"zbase.d.ts","sourceRoot":"","sources":["../../src/core/zbase.ts"],"names":[],"mappings":"AAAA,OAAO,EAIL,KAAK,WAAW,EACjB,MAAM,aAAa,CAAC;AAGrB,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAEjD,MAAM,WAAW,KAAK,CAAC,CAAC;IACtB,KAAK,EAAE,CAAC,CAAC;IACT,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IACtB,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;CACxB;AAuED,wBAAgB,UAAU,CAAC,CAAC,EAAE,CAAC,EAC7B,OAAO,EAAE,CAAC,EAAE,EACZ,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,EACnB,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,QAAQ,GAC1B,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAMjB;AAGD,wBAAgB,iBAAiB,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,WAAW,GAAG,WAAW,CAG5F;AAED,wBAAgB,SAAS,CAAC,CAAC,EACzB,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,EACrB,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,WAAW,GAC/B,WAAW,CAMb"}
@@ -0,0 +1,82 @@
1
+ import { digestBeltsToBase58, digestBytesFromBase58, digestFromBase58, } from "./digest.js";
2
+ import { hashPair, hashU64 } from "./hashable.js";
3
+ import { nounOrderDigest } from "../noun/encode.js";
4
+ function compareBytes(a, b) {
5
+ for (let i = 0; i < Math.max(a.length, b.length); i++) {
6
+ const av = a[i] ?? 0;
7
+ const bv = b[i] ?? 0;
8
+ if (av !== bv)
9
+ return av < bv ? -1 : 1;
10
+ }
11
+ return 0;
12
+ }
13
+ function tipEq(a, b, keyNoun) {
14
+ return nounOrderDigest(keyNoun(a)) === nounOrderDigest(keyNoun(b));
15
+ }
16
+ function gorTip(a, b, keyNoun) {
17
+ const aBytes = digestBytesFromBase58(nounOrderDigest(keyNoun(a)));
18
+ const bBytes = digestBytesFromBase58(nounOrderDigest(keyNoun(b)));
19
+ return compareBytes(aBytes, bBytes) < 0;
20
+ }
21
+ function doubleTip(key, keyNoun) {
22
+ const h = digestFromBase58(nounOrderDigest(keyNoun(key)));
23
+ const d = hashPair(h, h);
24
+ return digestBytesFromBase58(digestBeltsToBase58(d));
25
+ }
26
+ function morTip(a, b, keyNoun) {
27
+ return compareBytes(doubleTip(a, keyNoun), doubleTip(b, keyNoun)) < 0;
28
+ }
29
+ function put(node, entry, getKey, keyNoun) {
30
+ if (!node) {
31
+ return [{ entry, left: null, right: null }, true];
32
+ }
33
+ const key = getKey(entry);
34
+ const nodeKey = getKey(node.entry);
35
+ if (tipEq(key, nodeKey, keyNoun)) {
36
+ return [node, false];
37
+ }
38
+ if (gorTip(key, nodeKey, keyNoun)) {
39
+ const [newLeft, inserted] = put(node.left, entry, getKey, keyNoun);
40
+ let n = { ...node, left: newLeft };
41
+ if (n.left && !morTip(nodeKey, getKey(n.left.entry), keyNoun)) {
42
+ const pivot = n.left;
43
+ n = {
44
+ entry: pivot.entry,
45
+ left: pivot.left,
46
+ right: { ...n, left: pivot.right },
47
+ };
48
+ }
49
+ return [n, inserted];
50
+ }
51
+ const [newRight, inserted] = put(node.right, entry, getKey, keyNoun);
52
+ let n = { ...node, right: newRight };
53
+ if (n.right && !morTip(nodeKey, getKey(n.right.entry), keyNoun)) {
54
+ const pivot = n.right;
55
+ n = {
56
+ entry: pivot.entry,
57
+ left: { ...n, right: pivot.left },
58
+ right: pivot.right,
59
+ };
60
+ }
61
+ return [n, inserted];
62
+ }
63
+ export function buildZTree(entries, getKey, keyNoun) {
64
+ let root = null;
65
+ for (const entry of entries) {
66
+ [root] = put(root, entry, getKey, keyNoun);
67
+ }
68
+ return root;
69
+ }
70
+ export function hashZSetSingleton(entry, entryHash) {
71
+ const empty = hashU64(0n);
72
+ return hashPair(entryHash(entry), hashPair(empty, empty));
73
+ }
74
+ export function hashZNode(node, entryHash) {
75
+ if (!node)
76
+ return hashU64(0n);
77
+ const left = hashZNode(node.left, entryHash);
78
+ const right = hashZNode(node.right, entryHash);
79
+ const entry = entryHash(node.entry);
80
+ return hashPair(entry, hashPair(left, right));
81
+ }
82
+ //# sourceMappingURL=zbase.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"zbase.js","sourceRoot":"","sources":["../../src/core/zbase.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { type Belt } from "../core/belt.js";
2
+ export declare function bpegcd(a: Belt[], b: Belt[], d: Belt[], u: Belt[], v: Belt[]): void;
3
+ //# sourceMappingURL=bpoly.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bpoly.d.ts","sourceRoot":"","sources":["../../src/crypto/bpoly.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgC,KAAK,IAAI,EAAE,MAAM,iBAAiB,CAAC;AAkF1E,wBAAgB,MAAM,CACpB,CAAC,EAAE,IAAI,EAAE,EACT,CAAC,EAAE,IAAI,EAAE,EACT,CAAC,EAAE,IAAI,EAAE,EACT,CAAC,EAAE,IAAI,EAAE,EACT,CAAC,EAAE,IAAI,EAAE,GACR,IAAI,CAiDN"}
@@ -0,0 +1,121 @@
1
+ import { badd, bmul, bneg, bsub, binv } from "../core/belt.js";
2
+ import { mustAt } from "../core/must.js";
3
+ const MAX_POLY_SIZE = 7;
4
+ function bdiv(a, b) {
5
+ return bmul(a, binv(b));
6
+ }
7
+ function degree(data) {
8
+ for (let i = data.length - 1; i >= 0; i--) {
9
+ if (data[i] !== 0n)
10
+ return i;
11
+ }
12
+ return 0;
13
+ }
14
+ function isZero(data) {
15
+ return data.every((x) => x === 0n);
16
+ }
17
+ function bpsub(a, b, res) {
18
+ const resLen = Math.max(a.length, b.length);
19
+ for (let i = 0; i < resLen; i++) {
20
+ if (i < a.length && i < b.length) {
21
+ res[i] = bsub(mustAt(a, i), mustAt(b, i));
22
+ }
23
+ else if (i < a.length) {
24
+ res[i] = mustAt(a, i);
25
+ }
26
+ else {
27
+ res[i] = bneg(mustAt(b, i));
28
+ }
29
+ }
30
+ }
31
+ function bpmul(a, b, res) {
32
+ res.fill(0n);
33
+ if (isZero(a) || isZero(b))
34
+ return;
35
+ for (let i = 0; i < a.length; i++) {
36
+ if (a[i] === 0n)
37
+ continue;
38
+ for (let j = 0; j < b.length; j++) {
39
+ res[i + j] = badd(res[i + j] ?? 0n, bmul(mustAt(a, i), mustAt(b, j)));
40
+ }
41
+ }
42
+ }
43
+ function bpdvr(a, b, q, res) {
44
+ if (isZero(a)) {
45
+ q.fill(0n);
46
+ res.fill(0n);
47
+ return;
48
+ }
49
+ if (isZero(b))
50
+ throw new Error("divide by zero");
51
+ q.fill(0n);
52
+ res.fill(0n);
53
+ const aEnd = degree(a);
54
+ const r = [...a.slice(0, aEnd + 1)];
55
+ const degB = degree(b);
56
+ let i = aEnd;
57
+ const endB = degB;
58
+ let degR = degree(r);
59
+ let qIndex = degR - degB;
60
+ while (degR >= degB) {
61
+ const coeff = bdiv(mustAt(r, i), mustAt(b, endB));
62
+ q[qIndex] = coeff;
63
+ for (let k = 0; k <= degB; k++) {
64
+ const index = k;
65
+ if (k <= aEnd && k < b.length && k <= i) {
66
+ r[i - index] = bsub(mustAt(r, i - index), bmul(coeff, mustAt(b, endB - index)));
67
+ }
68
+ }
69
+ degR = Math.max(0, degR - 1);
70
+ qIndex = Math.max(0, qIndex - 1);
71
+ if (degR === 0 && r[0] === 0n)
72
+ break;
73
+ i -= 1;
74
+ }
75
+ const rLen = degR + 1;
76
+ for (let j = 0; j < rLen; j++)
77
+ res[j] = mustAt(r, j);
78
+ }
79
+ export function bpegcd(a, b, d, u, v) {
80
+ let m1u = [0n];
81
+ let m2u = [1n];
82
+ let m1v = [1n];
83
+ let m2v = [0n];
84
+ d.fill(0n);
85
+ u.fill(0n);
86
+ v.fill(0n);
87
+ let aa = [...a];
88
+ let bb = [...b];
89
+ while (!isZero(bb)) {
90
+ const degA = degree(aa);
91
+ const degB = degree(bb);
92
+ const lenQ = degA - degB + 1;
93
+ const lenR = degB + 1;
94
+ const q = new Array(MAX_POLY_SIZE).fill(0n);
95
+ const r = new Array(MAX_POLY_SIZE).fill(0n);
96
+ bpdvr(aa, bb, q, r);
97
+ const newA = bb.slice(0, lenR);
98
+ const newB = r.slice(0, lenR);
99
+ const res1 = new Array(MAX_POLY_SIZE).fill(0n);
100
+ bpmul(q.slice(0, lenQ), m1u, res1);
101
+ const res2 = new Array(MAX_POLY_SIZE).fill(0n);
102
+ bpsub(m2u, res1, res2);
103
+ m2u = [...m1u];
104
+ m1u = [...res2];
105
+ bpmul(q.slice(0, lenQ), m1v, res1);
106
+ const res3 = new Array(MAX_POLY_SIZE).fill(0n);
107
+ bpsub(m2v, res1, res3);
108
+ m2v = [...m1v];
109
+ m1v = [...res3];
110
+ aa = newA;
111
+ bb = newB;
112
+ }
113
+ const aLen = degree(aa) + 1;
114
+ for (let i = 0; i < aLen; i++)
115
+ d[i] = mustAt(aa, i);
116
+ for (let i = 0; i < m2u.length && i < u.length; i++)
117
+ u[i] = mustAt(m2u, i);
118
+ for (let i = 0; i < m2v.length && i < v.length; i++)
119
+ v[i] = mustAt(m2v, i);
120
+ }
121
+ //# sourceMappingURL=bpoly.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bpoly.js","sourceRoot":"","sources":["../../src/crypto/bpoly.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,25 @@
1
+ import { type Belt } from "../core/belt.js";
2
+ import { U256 } from "../core/u256.js";
3
+ export type F6lt = Belt[];
4
+ export interface CheetahPoint {
5
+ x: F6lt;
6
+ y: F6lt;
7
+ inf: boolean;
8
+ }
9
+ export declare const F6_ZERO: F6lt;
10
+ export declare const F6_ONE: F6lt;
11
+ export declare const A_ID: CheetahPoint;
12
+ export declare const A_GEN: CheetahPoint;
13
+ export declare function f6Mul(f: F6lt, g: F6lt): F6lt;
14
+ export declare function f6Inv(f: F6lt): F6lt | null;
15
+ export declare function chNeg(p: CheetahPoint): CheetahPoint;
16
+ export declare function chAdd(p: CheetahPoint, q: CheetahPoint): CheetahPoint | null;
17
+ export declare function chScalBig(n: U256, p: CheetahPoint): CheetahPoint | null;
18
+ export declare function cheetahPointToBase58(point: CheetahPoint): string;
19
+ export declare function cheetahPointFromBase58(b58: string): CheetahPoint;
20
+ export declare function publicKeyToBeBytes(point: CheetahPoint): Uint8Array;
21
+ export declare function publicKeyToSlip10Bytes(point: CheetahPoint): Uint8Array;
22
+ export declare function publicKeyFromBeBytes(bytes: Uint8Array): CheetahPoint;
23
+ export declare function cheetahPointHash(point: CheetahPoint): string;
24
+ export declare function verifySignature(publicKeyBytes: Uint8Array, cHex: string, sHex: string, messageDigest: bigint[]): boolean;
25
+ //# sourceMappingURL=cheetah.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cheetah.d.ts","sourceRoot":"","sources":["../../src/crypto/cheetah.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgC,KAAK,IAAI,EAAE,MAAM,iBAAiB,CAAC;AAK1E,OAAO,EAAwB,IAAI,EAAE,MAAM,iBAAiB,CAAC;AAG7D,MAAM,MAAM,IAAI,GAAG,IAAI,EAAE,CAAC;AAE1B,MAAM,WAAW,YAAY;IAC3B,CAAC,EAAE,IAAI,CAAC;IACR,CAAC,EAAE,IAAI,CAAC;IACR,GAAG,EAAE,OAAO,CAAC;CACd;AAED,eAAO,MAAM,OAAO,EAAE,IAA+B,CAAC;AACtD,eAAO,MAAM,MAAM,EAAE,IAA+B,CAAC;AAErD,eAAO,MAAM,IAAI,EAAE,YAA6D,CAAC;AAEjF,eAAO,MAAM,KAAK,EAAE,YAkBnB,CAAC;AAiCF,wBAAgB,KAAK,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,GAAG,IAAI,CA6B5C;AAMD,wBAAgB,KAAK,CAAC,CAAC,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,CAU1C;AAqDD,wBAAgB,KAAK,CAAC,CAAC,EAAE,YAAY,GAAG,YAAY,CAEnD;AAED,wBAAgB,KAAK,CAAC,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,YAAY,GAAG,YAAY,GAAG,IAAI,CAM3E;AAED,wBAAgB,SAAS,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,YAAY,GAAG,YAAY,GAAG,IAAI,CAiBvE;AAID,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,YAAY,GAAG,MAAM,CAEhE;AAED,wBAAgB,sBAAsB,CAAC,GAAG,EAAE,MAAM,GAAG,YAAY,CAKhE;AAED,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,YAAY,GAAG,UAAU,CAclE;AAGD,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,YAAY,GAAG,UAAU,CAUtE;AAED,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,UAAU,GAAG,YAAY,CAqBpE;AAED,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,YAAY,GAAG,MAAM,CAO5D;AAED,wBAAgB,eAAe,CAC7B,cAAc,EAAE,UAAU,EAC1B,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,MAAM,EACZ,aAAa,EAAE,MAAM,EAAE,GACtB,OAAO,CAoBT"}