@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,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":"AACA,OAAO,EAAE,QAAQ,EAAE,kBAAkB,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAG3E,MAAM,UAAU,UAAU,CAAC,IAAU;IACnC,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC;QAAE,OAAO,CAAC,CAAC;IAClC,QAAQ,IAAI,CAAC,GAAG,EAAE,CAAC;QACjB,KAAK,CAAC;YACJ,OAAO,CAAC,CAAC;QACX,KAAK,CAAC;YACJ,OAAO,CAAC,CAAC;QACX,KAAK,CAAC;YACJ,OAAO,CAAC,CAAC;QACX,KAAK,EAAE;YACL,OAAO,CAAC,CAAC;QACX;YACE,MAAM,IAAI,KAAK,CAAC,wBAAyB,IAAwB,CAAC,GAAG,EAAE,CAAC,CAAC;IAC7E,CAAC;AACH,CAAC;AAED,SAAS,WAAW,CAAC,CAA2C,EAAE,GAAW;IAC3E,OAAO,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAC7B,CAAC;AAED,SAAS,WAAW,CAAC,CAA+F,EAAE,GAAW;IAC/H,OAAO,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC;AACzE,CAAC;AAED,SAAS,WAAW,CAClB,CAGC,EACD,GAAW;IAEX,OAAO,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC;AACzE,CAAC;AAED,SAAS,YAAY,CACnB,CAqBC,EACD,GAAW;IAEX,OAAO,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC;AACzE,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,IAAU,EAAE,KAAa;IAC1D,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;QACxB,IAAI,KAAK,IAAI,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,SAAS,KAAK,oCAAoC,CAAC,CAAC;QACpF,OAAO,IAAI,CAAC;IACd,CAAC;IACD,QAAQ,IAAI,CAAC,GAAG,EAAE,CAAC;QACjB,KAAK,CAAC;YACJ,IAAI,KAAK,IAAI,CAAC;gBAAE,MAAM,IAAI,KAAK,CAAC,SAAS,KAAK,oCAAoC,CAAC,CAAC;YACpF,OAAO,WAAW,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QAClC,KAAK,CAAC;YACJ,IAAI,KAAK,IAAI,CAAC;gBAAE,MAAM,IAAI,KAAK,CAAC,SAAS,KAAK,oCAAoC,CAAC,CAAC;YACpF,OAAO,WAAW,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QAClC,KAAK,CAAC;YACJ,IAAI,KAAK,IAAI,CAAC;gBAAE,MAAM,IAAI,KAAK,CAAC,SAAS,KAAK,oCAAoC,CAAC,CAAC;YACpF,OAAO,WAAW,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QAClC,KAAK,EAAE;YACL,IAAI,KAAK,IAAI,EAAE;gBAAE,MAAM,IAAI,KAAK,CAAC,SAAS,KAAK,qCAAqC,CAAC,CAAC;YACtF,OAAO,YAAY,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACnC;YACE,MAAM,IAAI,KAAK,CAAC,wBAAyB,IAAwB,CAAC,GAAG,EAAE,CAAC,CAAC;IAC7E,CAAC;AACH,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,IAAU;IACtC,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC;QAAE,OAAO,CAAC,CAAC;IAClC,QAAQ,IAAI,CAAC,GAAG,EAAE,CAAC;QACjB,KAAK,CAAC;YACJ,OAAO,CAAC,CAAC;QACX,KAAK,CAAC;YACJ,OAAO,CAAC,CAAC;QACX,KAAK,CAAC;YACJ,OAAO,CAAC,CAAC;QACX,KAAK,EAAE;YACL,OAAO,CAAC,CAAC;QACX;YACE,MAAM,IAAI,KAAK,CAAC,wBAAyB,IAAwB,CAAC,GAAG,EAAE,CAAC,CAAC;IAC7E,CAAC;AACH,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,IAAU;IACzC,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC;QAAE,OAAO,IAAI,CAAC;IACrC,QAAQ,IAAI,CAAC,GAAG,EAAE,CAAC;QACjB,KAAK,CAAC;YACJ,OAAO,CAAC,IAAI,CAAC,CAAS,EAAE,IAAI,CAAC,CAAS,CAAC,CAAC;QAC1C,KAAK,CAAC;YACJ,OAAO,CAAC,IAAI,CAAC,CAAS,EAAE,IAAI,CAAC,CAAS,CAAC,CAAC;QAC1C,KAAK,CAAC;YACJ,OAAO,CAAC,IAAI,CAAC,CAAS,EAAE,IAAI,CAAC,CAAS,CAAC,CAAC;QAC1C,KAAK,EAAE;YACL,OAAO,CAAC,IAAI,CAAC,CAAS,EAAE,IAAI,CAAC,CAAS,CAAC,CAAC;QAC1C;YACE,MAAM,IAAI,KAAK,CAAC,wBAAyB,IAAwB,CAAC,GAAG,EAAE,CAAC,CAAC;IAC7E,CAAC;AACH,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,IAAU;IACvC,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;QACxB,OAAO,YAAY,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,CAAC;IAChD,CAAC;IACD,OAAO,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;AACtC,CAAC"}
|
|
@@ -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 @@
|
|
|
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 @@
|
|
|
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"}
|