@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.
- package/README.md +373 -0
- package/dist/constants.d.ts +2 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +2 -0
- package/dist/constants.js.map +1 -0
- package/dist/core/belt.d.ts +16 -0
- package/dist/core/belt.d.ts.map +1 -0
- package/dist/core/belt.js +120 -0
- package/dist/core/belt.js.map +1 -0
- package/dist/core/digest.d.ts +9 -0
- package/dist/core/digest.d.ts.map +1 -0
- package/dist/core/digest.js +76 -0
- package/dist/core/digest.js.map +1 -0
- package/dist/core/hashable.d.ts +21 -0
- package/dist/core/hashable.d.ts.map +1 -0
- package/dist/core/hashable.js +128 -0
- package/dist/core/hashable.js.map +1 -0
- package/dist/core/lock.d.ts +8 -0
- package/dist/core/lock.d.ts.map +1 -0
- package/dist/core/lock.js +95 -0
- package/dist/core/lock.js.map +1 -0
- package/dist/core/merkle.d.ts +7 -0
- package/dist/core/merkle.d.ts.map +1 -0
- package/dist/core/merkle.js +57 -0
- package/dist/core/merkle.js.map +1 -0
- package/dist/core/must.d.ts +3 -0
- package/dist/core/must.d.ts.map +1 -0
- package/dist/core/must.js +14 -0
- package/dist/core/must.js.map +1 -0
- package/dist/core/tip5/constants.d.ts +10 -0
- package/dist/core/tip5/constants.d.ts.map +1 -0
- package/dist/core/tip5/constants.js +70 -0
- package/dist/core/tip5/constants.js.map +1 -0
- package/dist/core/tip5/index.d.ts +5 -0
- package/dist/core/tip5/index.d.ts.map +1 -0
- package/dist/core/tip5/index.js +100 -0
- package/dist/core/tip5/index.js.map +1 -0
- package/dist/core/u256.d.ts +21 -0
- package/dist/core/u256.d.ts.map +1 -0
- package/dist/core/u256.js +96 -0
- package/dist/core/u256.js.map +1 -0
- package/dist/core/ubig.d.ts +20 -0
- package/dist/core/ubig.d.ts.map +1 -0
- package/dist/core/ubig.js +81 -0
- package/dist/core/ubig.js.map +1 -0
- package/dist/core/zbase.d.ts +11 -0
- package/dist/core/zbase.d.ts.map +1 -0
- package/dist/core/zbase.js +82 -0
- package/dist/core/zbase.js.map +1 -0
- package/dist/crypto/bpoly.d.ts +3 -0
- package/dist/crypto/bpoly.d.ts.map +1 -0
- package/dist/crypto/bpoly.js +121 -0
- package/dist/crypto/bpoly.js.map +1 -0
- package/dist/crypto/cheetah.d.ts +25 -0
- package/dist/crypto/cheetah.d.ts.map +1 -0
- package/dist/crypto/cheetah.js +250 -0
- package/dist/crypto/cheetah.js.map +1 -0
- package/dist/crypto/index.d.ts +7 -0
- package/dist/crypto/index.d.ts.map +1 -0
- package/dist/crypto/index.js +24 -0
- package/dist/crypto/index.js.map +1 -0
- package/dist/crypto/privateKey.d.ts +11 -0
- package/dist/crypto/privateKey.d.ts.map +1 -0
- package/dist/crypto/privateKey.js +88 -0
- package/dist/crypto/privateKey.js.map +1 -0
- package/dist/crypto/publicKey.d.ts +18 -0
- package/dist/crypto/publicKey.d.ts.map +1 -0
- package/dist/crypto/publicKey.js +79 -0
- package/dist/crypto/publicKey.js.map +1 -0
- package/dist/crypto/slip10.d.ts +10 -0
- package/dist/crypto/slip10.d.ts.map +1 -0
- package/dist/crypto/slip10.js +104 -0
- package/dist/crypto/slip10.js.map +1 -0
- package/dist/grpc/index.d.ts +12 -0
- package/dist/grpc/index.d.ts.map +1 -0
- package/dist/grpc/index.js +13 -0
- package/dist/grpc/index.js.map +1 -0
- package/dist/grpc/proto.d.ts +26 -0
- package/dist/grpc/proto.d.ts.map +1 -0
- package/dist/grpc/proto.js +219 -0
- package/dist/grpc/proto.js.map +1 -0
- package/dist/hash/index.d.ts +32 -0
- package/dist/hash/index.d.ts.map +1 -0
- package/dist/hash/index.js +138 -0
- package/dist/hash/index.js.map +1 -0
- package/dist/hash/note.d.ts +13 -0
- package/dist/hash/note.d.ts.map +1 -0
- package/dist/hash/note.js +78 -0
- package/dist/hash/note.js.map +1 -0
- package/dist/hash/noteData.d.ts +12 -0
- package/dist/hash/noteData.d.ts.map +1 -0
- package/dist/hash/noteData.js +115 -0
- package/dist/hash/noteData.js.map +1 -0
- package/dist/hash/noun.d.ts +4 -0
- package/dist/hash/noun.d.ts.map +1 -0
- package/dist/hash/noun.js +15 -0
- package/dist/hash/noun.js.map +1 -0
- package/dist/hash/structural.d.ts +5 -0
- package/dist/hash/structural.d.ts.map +1 -0
- package/dist/hash/structural.js +41 -0
- package/dist/hash/structural.js.map +1 -0
- package/dist/hash/tx.d.ts +15 -0
- package/dist/hash/tx.d.ts.map +1 -0
- package/dist/hash/tx.js +146 -0
- package/dist/hash/tx.js.map +1 -0
- package/dist/index.d.ts +14 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +10 -0
- package/dist/index.js.map +1 -0
- package/dist/noun/belts.d.ts +9 -0
- package/dist/noun/belts.d.ts.map +1 -0
- package/dist/noun/belts.js +73 -0
- package/dist/noun/belts.js.map +1 -0
- package/dist/noun/bitwriter.d.ts +14 -0
- package/dist/noun/bitwriter.d.ts.map +1 -0
- package/dist/noun/bitwriter.js +100 -0
- package/dist/noun/bitwriter.js.map +1 -0
- package/dist/noun/codec.d.ts +9 -0
- package/dist/noun/codec.d.ts.map +1 -0
- package/dist/noun/codec.js +144 -0
- package/dist/noun/codec.js.map +1 -0
- package/dist/noun/cue.d.ts +3 -0
- package/dist/noun/cue.d.ts.map +1 -0
- package/dist/noun/cue.js +152 -0
- package/dist/noun/cue.js.map +1 -0
- package/dist/noun/encode.d.ts +12 -0
- package/dist/noun/encode.d.ts.map +1 -0
- package/dist/noun/encode.js +37 -0
- package/dist/noun/encode.js.map +1 -0
- package/dist/noun/index.d.ts +10 -0
- package/dist/noun/index.d.ts.map +1 -0
- package/dist/noun/index.js +29 -0
- package/dist/noun/index.js.map +1 -0
- package/dist/noun/jam.d.ts +3 -0
- package/dist/noun/jam.d.ts.map +1 -0
- package/dist/noun/jam.js +107 -0
- package/dist/noun/jam.js.map +1 -0
- package/dist/noun/types.d.ts +21 -0
- package/dist/noun/types.d.ts.map +1 -0
- package/dist/noun/types.js +66 -0
- package/dist/noun/types.js.map +1 -0
- package/dist/noun/words.d.ts +3 -0
- package/dist/noun/words.d.ts.map +1 -0
- package/dist/noun/words.js +6 -0
- package/dist/noun/words.js.map +1 -0
- package/dist/proto/decode.d.ts +10 -0
- package/dist/proto/decode.d.ts.map +1 -0
- package/dist/proto/decode.js +44 -0
- package/dist/proto/decode.js.map +1 -0
- package/dist/proto/digest.d.ts +21 -0
- package/dist/proto/digest.d.ts.map +1 -0
- package/dist/proto/digest.js +29 -0
- package/dist/proto/digest.js.map +1 -0
- package/dist/proto/index.d.ts +9 -0
- package/dist/proto/index.d.ts.map +1 -0
- package/dist/proto/index.js +140 -0
- package/dist/proto/index.js.map +1 -0
- package/dist/proto/note.d.ts +4 -0
- package/dist/proto/note.d.ts.map +1 -0
- package/dist/proto/note.js +99 -0
- package/dist/proto/note.js.map +1 -0
- package/dist/proto/rawTx.d.ts +3 -0
- package/dist/proto/rawTx.d.ts.map +1 -0
- package/dist/proto/rawTx.js +186 -0
- package/dist/proto/rawTx.js.map +1 -0
- package/dist/rpc/client.d.ts +13 -0
- package/dist/rpc/client.d.ts.map +1 -0
- package/dist/rpc/client.js +75 -0
- package/dist/rpc/client.js.map +1 -0
- package/dist/rpc/types.d.ts +18 -0
- package/dist/rpc/types.d.ts.map +1 -0
- package/dist/rpc/types.js +2 -0
- package/dist/rpc/types.js.map +1 -0
- package/dist/rpc/wire/encode.d.ts +4 -0
- package/dist/rpc/wire/encode.d.ts.map +1 -0
- package/dist/rpc/wire/encode.js +168 -0
- package/dist/rpc/wire/encode.js.map +1 -0
- package/dist/rpc/wire/protobuf.d.ts +10 -0
- package/dist/rpc/wire/protobuf.d.ts.map +1 -0
- package/dist/rpc/wire/protobuf.js +50 -0
- package/dist/rpc/wire/protobuf.js.map +1 -0
- package/dist/stubs.d.ts +6 -0
- package/dist/stubs.d.ts.map +1 -0
- package/dist/stubs.js +12 -0
- package/dist/stubs.js.map +1 -0
- package/dist/tx/accessors.d.ts +13 -0
- package/dist/tx/accessors.d.ts.map +1 -0
- package/dist/tx/accessors.js +65 -0
- package/dist/tx/accessors.js.map +1 -0
- package/dist/tx/builder.d.ts +63 -0
- package/dist/tx/builder.d.ts.map +1 -0
- package/dist/tx/builder.js +601 -0
- package/dist/tx/builder.js.map +1 -0
- package/dist/tx/display.d.ts +7 -0
- package/dist/tx/display.d.ts.map +1 -0
- package/dist/tx/display.js +34 -0
- package/dist/tx/display.js.map +1 -0
- package/dist/tx/fee.d.ts +8 -0
- package/dist/tx/fee.d.ts.map +1 -0
- package/dist/tx/fee.js +81 -0
- package/dist/tx/fee.js.map +1 -0
- package/dist/tx/htlc.d.ts +21 -0
- package/dist/tx/htlc.d.ts.map +1 -0
- package/dist/tx/htlc.js +65 -0
- package/dist/tx/htlc.js.map +1 -0
- package/dist/tx/index.d.ts +19 -0
- package/dist/tx/index.d.ts.map +1 -0
- package/dist/tx/index.js +64 -0
- package/dist/tx/index.js.map +1 -0
- package/dist/tx/multisig.d.ts +3 -0
- package/dist/tx/multisig.d.ts.map +1 -0
- package/dist/tx/multisig.js +8 -0
- package/dist/tx/multisig.js.map +1 -0
- package/dist/tx/outputs.d.ts +3 -0
- package/dist/tx/outputs.d.ts.map +1 -0
- package/dist/tx/outputs.js +57 -0
- package/dist/tx/outputs.js.map +1 -0
- package/dist/tx/spend.d.ts +10 -0
- package/dist/tx/spend.d.ts.map +1 -0
- package/dist/tx/spend.js +17 -0
- package/dist/tx/spend.js.map +1 -0
- package/dist/tx/spends.d.ts +8 -0
- package/dist/tx/spends.d.ts.map +1 -0
- package/dist/tx/spends.js +48 -0
- package/dist/tx/spends.js.map +1 -0
- package/dist/tx/types.d.ts +5 -0
- package/dist/tx/types.d.ts.map +1 -0
- package/dist/tx/types.js +2 -0
- package/dist/tx/types.js.map +1 -0
- package/dist/tx/unlocks.d.ts +4 -0
- package/dist/tx/unlocks.d.ts.map +1 -0
- package/dist/tx/unlocks.js +49 -0
- package/dist/tx/unlocks.js.map +1 -0
- package/dist/tx/witness.d.ts +14 -0
- package/dist/tx/witness.d.ts.map +1 -0
- package/dist/tx/witness.js +81 -0
- package/dist/tx/witness.js.map +1 -0
- package/dist/types.d.ts +311 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- 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 @@
|
|
|
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"}
|