@honeybbq/teamspeak-client 0.0.0 → 0.1.0
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/LICENSE +21 -0
- package/README.md +208 -0
- package/dist/api.d.ts +17 -0
- package/dist/api.d.ts.map +1 -0
- package/dist/client.d.ts +39 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/command/command.d.ts +12 -0
- package/dist/command/command.d.ts.map +1 -0
- package/dist/command/command.test.d.ts +2 -0
- package/dist/command/command.test.d.ts.map +1 -0
- package/dist/command/index.cjs +1 -0
- package/dist/command/index.d.ts +4 -0
- package/dist/command/index.d.ts.map +1 -0
- package/dist/command/index.mjs +3 -0
- package/dist/command/parser.d.ts +3 -0
- package/dist/command/parser.d.ts.map +1 -0
- package/dist/command-Cu2v-5-K.cjs +4 -0
- package/dist/command-Cu2v-5-K.cjs.map +1 -0
- package/dist/command-caXc4h0n.js +76 -0
- package/dist/command-caXc4h0n.js.map +1 -0
- package/dist/commands.d.ts +48 -0
- package/dist/commands.d.ts.map +1 -0
- package/dist/crypt-handshake-CHmvZ2qs.js +55 -0
- package/dist/crypt-handshake-CHmvZ2qs.js.map +1 -0
- package/dist/crypt-handshake-Dbj2cSBZ.cjs +2 -0
- package/dist/crypt-handshake-Dbj2cSBZ.cjs.map +1 -0
- package/dist/crypt-init2-BIbQ7TN0.cjs +2 -0
- package/dist/crypt-init2-BIbQ7TN0.cjs.map +1 -0
- package/dist/crypt-init2-C63eypta.js +165 -0
- package/dist/crypt-init2-C63eypta.js.map +1 -0
- package/dist/crypto/crypt-ops.d.ts +7 -0
- package/dist/crypto/crypt-ops.d.ts.map +1 -0
- package/dist/crypto/crypt.d.ts +22 -0
- package/dist/crypto/crypt.d.ts.map +1 -0
- package/dist/crypto/eax.d.ts +12 -0
- package/dist/crypto/eax.d.ts.map +1 -0
- package/dist/crypto/eax.test.d.ts +2 -0
- package/dist/crypto/eax.test.d.ts.map +1 -0
- package/dist/crypto/identity.d.ts +18 -0
- package/dist/crypto/identity.d.ts.map +1 -0
- package/dist/crypto/identity.test.d.ts +2 -0
- package/dist/crypto/identity.test.d.ts.map +1 -0
- package/dist/crypto/index.cjs +1 -0
- package/dist/crypto/index.d.ts +6 -0
- package/dist/crypto/index.d.ts.map +1 -0
- package/dist/crypto/index.mjs +3 -0
- package/dist/crypto/primitives.d.ts +28 -0
- package/dist/crypto/primitives.d.ts.map +1 -0
- package/dist/crypto-C3gBJkh2.cjs +2 -0
- package/dist/crypto-C3gBJkh2.cjs.map +1 -0
- package/dist/crypto-IGJlkTAl.js +165 -0
- package/dist/crypto-IGJlkTAl.js.map +1 -0
- package/dist/discovery/index.cjs +1 -0
- package/dist/discovery/index.d.ts +2 -0
- package/dist/discovery/index.d.ts.map +1 -0
- package/dist/discovery/index.mjs +2 -0
- package/dist/discovery/resolver.d.ts +8 -0
- package/dist/discovery/resolver.d.ts.map +1 -0
- package/dist/errors.d.ts +34 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/events.d.ts +10 -0
- package/dist/events.d.ts.map +1 -0
- package/dist/handler-C2vxlHYC.js +458 -0
- package/dist/handler-C2vxlHYC.js.map +1 -0
- package/dist/handler-DQteUMKT.cjs +2 -0
- package/dist/handler-DQteUMKT.cjs.map +1 -0
- package/dist/handshake/crypt-handshake.d.ts +8 -0
- package/dist/handshake/crypt-handshake.d.ts.map +1 -0
- package/dist/handshake/crypt-init2.d.ts +7 -0
- package/dist/handshake/crypt-init2.d.ts.map +1 -0
- package/dist/handshake/index.cjs +1 -0
- package/dist/handshake/index.d.ts +4 -0
- package/dist/handshake/index.d.ts.map +1 -0
- package/dist/handshake/index.mjs +3 -0
- package/dist/handshake/license.d.ts +28 -0
- package/dist/handshake/license.d.ts.map +1 -0
- package/dist/handshake.d.ts +9 -0
- package/dist/handshake.d.ts.map +1 -0
- package/dist/helpers.d.ts +14 -0
- package/dist/helpers.d.ts.map +1 -0
- package/dist/helpers.test.d.ts +2 -0
- package/dist/helpers.test.d.ts.map +1 -0
- package/dist/index.cjs +2 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.mjs +761 -0
- package/dist/index.mjs.map +1 -0
- package/dist/integration.test.d.ts +12 -0
- package/dist/integration.test.d.ts.map +1 -0
- package/dist/notifications.d.ts +32 -0
- package/dist/notifications.d.ts.map +1 -0
- package/dist/notifications.test.d.ts +2 -0
- package/dist/notifications.test.d.ts.map +1 -0
- package/dist/parser-CJjP3LlO.js +33 -0
- package/dist/parser-CJjP3LlO.js.map +1 -0
- package/dist/parser-DhAWj-TI.cjs +2 -0
- package/dist/parser-DhAWj-TI.cjs.map +1 -0
- package/dist/primitives-BxtDMP7x.cjs +2 -0
- package/dist/primitives-BxtDMP7x.cjs.map +1 -0
- package/dist/primitives-CmIK1O7L.js +1836 -0
- package/dist/primitives-CmIK1O7L.js.map +1 -0
- package/dist/resolver-DDZWomrF.js +165 -0
- package/dist/resolver-DDZWomrF.js.map +1 -0
- package/dist/resolver-Dey6omBe.cjs +4 -0
- package/dist/resolver-Dey6omBe.cjs.map +1 -0
- package/dist/throttle.d.ts +11 -0
- package/dist/throttle.d.ts.map +1 -0
- package/dist/throttle.test.d.ts +2 -0
- package/dist/throttle.test.d.ts.map +1 -0
- package/dist/transfer.d.ts +34 -0
- package/dist/transfer.d.ts.map +1 -0
- package/dist/transport/generation-window.d.ts +15 -0
- package/dist/transport/generation-window.d.ts.map +1 -0
- package/dist/transport/generation-window.test.d.ts +2 -0
- package/dist/transport/generation-window.test.d.ts.map +1 -0
- package/dist/transport/handler.d.ts +18 -0
- package/dist/transport/handler.d.ts.map +1 -0
- package/dist/transport/index.cjs +1 -0
- package/dist/transport/index.d.ts +6 -0
- package/dist/transport/index.d.ts.map +1 -0
- package/dist/transport/index.mjs +2 -0
- package/dist/transport/packet.d.ts +36 -0
- package/dist/transport/packet.d.ts.map +1 -0
- package/dist/transport/packet.test.d.ts +2 -0
- package/dist/transport/packet.test.d.ts.map +1 -0
- package/dist/transport/quicklz.d.ts +5 -0
- package/dist/transport/quicklz.d.ts.map +1 -0
- package/dist/transport/quicklz.test.d.ts +2 -0
- package/dist/transport/quicklz.test.d.ts.map +1 -0
- package/dist/types-CGKgXvpG.js +18 -0
- package/dist/types-CGKgXvpG.js.map +1 -0
- package/dist/types-DrnoCdSW.cjs +2 -0
- package/dist/types-DrnoCdSW.cjs.map +1 -0
- package/dist/types.d.ts +114 -0
- package/dist/types.d.ts.map +1 -0
- package/package.json +87 -1
|
@@ -0,0 +1,1836 @@
|
|
|
1
|
+
import { createECDH as e, createHash as t, createPrivateKey as n, createPublicKey as r, createSign as i, createVerify as a, generateKeyPairSync as o, randomBytes as s } from "node:crypto";
|
|
2
|
+
//#region src/errors.ts
|
|
3
|
+
var c = class extends Error {
|
|
4
|
+
constructor(e, t) {
|
|
5
|
+
super(e, t), this.name = "TeamspeakError";
|
|
6
|
+
}
|
|
7
|
+
}, l = class extends c {
|
|
8
|
+
id;
|
|
9
|
+
serverMessage;
|
|
10
|
+
constructor(e, t) {
|
|
11
|
+
super(`TeamSpeak server error: ${t} (id=${e})`), this.name = "ServerError", this.id = e, this.serverMessage = t;
|
|
12
|
+
}
|
|
13
|
+
}, u = class extends c {
|
|
14
|
+
command;
|
|
15
|
+
constructor(e) {
|
|
16
|
+
super(`command timeout: ${e}`), this.name = "CommandTimeoutError", this.command = e;
|
|
17
|
+
}
|
|
18
|
+
}, d = class extends c {
|
|
19
|
+
constructor() {
|
|
20
|
+
super("already connecting or connected"), this.name = "AlreadyConnectedError";
|
|
21
|
+
}
|
|
22
|
+
}, f = class extends c {
|
|
23
|
+
constructor() {
|
|
24
|
+
super("EAX tag mismatch"), this.name = "EAXTagMismatchError";
|
|
25
|
+
}
|
|
26
|
+
}, p = class extends c {
|
|
27
|
+
constructor() {
|
|
28
|
+
super("fake signature mismatch"), this.name = "FakeSignatureMismatchError";
|
|
29
|
+
}
|
|
30
|
+
}, m = class extends c {
|
|
31
|
+
constructor(e, t) {
|
|
32
|
+
super(e, t), this.name = "FileTransferError";
|
|
33
|
+
}
|
|
34
|
+
}, h = class extends c {
|
|
35
|
+
constructor() {
|
|
36
|
+
super("timeout waiting for file transfer notification"), this.name = "FileTransferTimeoutError";
|
|
37
|
+
}
|
|
38
|
+
}, g = class extends c {
|
|
39
|
+
constructor(e, t) {
|
|
40
|
+
super(e, t), this.name = "CryptoInitError";
|
|
41
|
+
}
|
|
42
|
+
}, _ = class extends c {
|
|
43
|
+
constructor(e = "invalid identity format") {
|
|
44
|
+
super(e), this.name = "InvalidIdentityError";
|
|
45
|
+
}
|
|
46
|
+
}, v = 32, y = 65, b = 4, x = class {
|
|
47
|
+
privateKey;
|
|
48
|
+
offset;
|
|
49
|
+
constructor(e, t) {
|
|
50
|
+
this.privateKey = e, this.offset = t;
|
|
51
|
+
}
|
|
52
|
+
publicKeyBase64() {
|
|
53
|
+
let e = r(this.privateKey).export({ format: "jwk" });
|
|
54
|
+
return e.x === void 0 || e.y === void 0 || typeof e.x != "string" || typeof e.y != "string" ? "" : te(de(e.x, v), de(e.y, v));
|
|
55
|
+
}
|
|
56
|
+
toString() {
|
|
57
|
+
let e = this.privateKey.export({ format: "jwk" });
|
|
58
|
+
if (!e.d) return `:${this.offset}`;
|
|
59
|
+
let t = de(e.d, v);
|
|
60
|
+
return `${Buffer.from(t).toString("base64")}:${this.offset}`;
|
|
61
|
+
}
|
|
62
|
+
securityLevel() {
|
|
63
|
+
let e = t("sha1");
|
|
64
|
+
return e.update(this.publicKeyBase64()), e.update(this.offset.toString(10)), fe(e.digest());
|
|
65
|
+
}
|
|
66
|
+
async upgradeToLevel(e, n) {
|
|
67
|
+
let r = this.publicKeyBase64();
|
|
68
|
+
for (;;) {
|
|
69
|
+
if (n?.aborted) throw n.reason;
|
|
70
|
+
let i = t("sha1");
|
|
71
|
+
if (i.update(r), i.update(this.offset.toString(10)), fe(i.digest()) >= e) return;
|
|
72
|
+
this.offset++, this.offset % 10000n == 0n && await new Promise((e) => setImmediate(e));
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
function S(t) {
|
|
77
|
+
let r = t.lastIndexOf(":");
|
|
78
|
+
if (r < 0) throw new _();
|
|
79
|
+
let i = t.slice(0, r), a = t.slice(r + 1), o = Buffer.from(i, "base64"), s = BigInt(a);
|
|
80
|
+
if (o.length > v) throw new _("private key scalar too large");
|
|
81
|
+
let c = Buffer.alloc(v);
|
|
82
|
+
o.copy(c, v - o.length);
|
|
83
|
+
let l = e("prime256v1");
|
|
84
|
+
l.setPrivateKey(c);
|
|
85
|
+
let u = l.getPublicKey(null, "uncompressed"), d = Buffer.from(u.slice(1, 33)).toString("base64url"), f = Buffer.from(u.slice(33, 65)).toString("base64url");
|
|
86
|
+
return new x(n({
|
|
87
|
+
key: {
|
|
88
|
+
kty: "EC",
|
|
89
|
+
crv: "P-256",
|
|
90
|
+
d: c.toString("base64url"),
|
|
91
|
+
x: d,
|
|
92
|
+
y: f
|
|
93
|
+
},
|
|
94
|
+
format: "jwk"
|
|
95
|
+
}), s);
|
|
96
|
+
}
|
|
97
|
+
function C(e) {
|
|
98
|
+
let { privateKey: n } = o("ec", { namedCurve: "prime256v1" }), r = new x(n, 0n), i = r.publicKeyBase64();
|
|
99
|
+
for (;;) {
|
|
100
|
+
let n = t("sha1");
|
|
101
|
+
if (n.update(i), n.update(r.offset.toString(10)), fe(n.digest()) >= e) return r;
|
|
102
|
+
r.offset++;
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
function w(e) {
|
|
106
|
+
let n = t("sha1").update(e).digest();
|
|
107
|
+
return Buffer.from(n).toString("base64");
|
|
108
|
+
}
|
|
109
|
+
function ee(e) {
|
|
110
|
+
return t("sha512").update(e).digest();
|
|
111
|
+
}
|
|
112
|
+
function te(e, t) {
|
|
113
|
+
let n = se(3, Buffer.from([0])), r = se(2, le(32)), i = se(2, le(e)), a = se(2, le(t));
|
|
114
|
+
return se(48, Buffer.concat([
|
|
115
|
+
n,
|
|
116
|
+
r,
|
|
117
|
+
i,
|
|
118
|
+
a
|
|
119
|
+
])).toString("base64");
|
|
120
|
+
}
|
|
121
|
+
function ne(e) {
|
|
122
|
+
let t = re(e);
|
|
123
|
+
return r({
|
|
124
|
+
key: {
|
|
125
|
+
kty: "EC",
|
|
126
|
+
crv: "P-256",
|
|
127
|
+
x: Buffer.from(t.slice(1, 33)).toString("base64url"),
|
|
128
|
+
y: Buffer.from(t.slice(33, 65)).toString("base64url")
|
|
129
|
+
},
|
|
130
|
+
format: "jwk"
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
function re(e) {
|
|
134
|
+
try {
|
|
135
|
+
return ie(e);
|
|
136
|
+
} catch {}
|
|
137
|
+
return ae(e);
|
|
138
|
+
}
|
|
139
|
+
function ie(e) {
|
|
140
|
+
let t = T(e, 48).value, n = 0, r = T(t, 3, n);
|
|
141
|
+
n += r.consumed;
|
|
142
|
+
let i = T(t, 2, n);
|
|
143
|
+
n += i.consumed;
|
|
144
|
+
let a = T(t, 2, n);
|
|
145
|
+
n += a.consumed;
|
|
146
|
+
let o = T(t, 2, n);
|
|
147
|
+
return oe(ue(a.value, v), ue(o.value, v));
|
|
148
|
+
}
|
|
149
|
+
function ae(e) {
|
|
150
|
+
let t = T(e, 48).value, n = 0, r = T(t, 2, n);
|
|
151
|
+
n += r.consumed;
|
|
152
|
+
let i = T(t, 2, n);
|
|
153
|
+
return oe(ue(r.value, v), ue(i.value, v));
|
|
154
|
+
}
|
|
155
|
+
function oe(e, t) {
|
|
156
|
+
if (e.length > v || t.length > v) throw Error("invalid public key point encoding");
|
|
157
|
+
let n = new Uint8Array(y);
|
|
158
|
+
return n[0] = b, n.set(e, 1 + v - e.length), n.set(t, 1 + 2 * v - t.length), n;
|
|
159
|
+
}
|
|
160
|
+
function se(e, t) {
|
|
161
|
+
let n = ce(t.length);
|
|
162
|
+
return Buffer.concat([
|
|
163
|
+
Buffer.from([e]),
|
|
164
|
+
n,
|
|
165
|
+
t
|
|
166
|
+
]);
|
|
167
|
+
}
|
|
168
|
+
function ce(e) {
|
|
169
|
+
return e < 128 ? Buffer.from([e]) : e < 256 ? Buffer.from([129, e]) : Buffer.from([
|
|
170
|
+
130,
|
|
171
|
+
e >> 8 & 255,
|
|
172
|
+
e & 255
|
|
173
|
+
]);
|
|
174
|
+
}
|
|
175
|
+
function le(e) {
|
|
176
|
+
if (typeof e == "number") {
|
|
177
|
+
let t = [], n = e;
|
|
178
|
+
do
|
|
179
|
+
t.unshift(n & 255), n >>= 8;
|
|
180
|
+
while (n > 0);
|
|
181
|
+
return t[0] & 128 && t.unshift(0), Buffer.from(t);
|
|
182
|
+
}
|
|
183
|
+
let t = 0;
|
|
184
|
+
for (; t < e.length - 1 && e[t] === 0;) t++;
|
|
185
|
+
let n = e.slice(t);
|
|
186
|
+
return n[0] & 128 ? Buffer.concat([Buffer.from([0]), n]) : Buffer.from(n);
|
|
187
|
+
}
|
|
188
|
+
function T(e, t, n = 0) {
|
|
189
|
+
if (e[n] !== t) throw Error(`expected DER tag 0x${t.toString(16)}, got 0x${(e[n] ?? 0).toString(16)}`);
|
|
190
|
+
let r = n + 1, i, a = e[r++];
|
|
191
|
+
if (a < 128) i = a;
|
|
192
|
+
else if (a === 129) i = e[r++];
|
|
193
|
+
else if (a === 130) i = (e[r] << 8 | e[r + 1]) >>> 0, r += 2;
|
|
194
|
+
else throw Error("unsupported DER length encoding");
|
|
195
|
+
return {
|
|
196
|
+
value: e.slice(r, r + i),
|
|
197
|
+
consumed: r - n + i
|
|
198
|
+
};
|
|
199
|
+
}
|
|
200
|
+
function ue(e, t) {
|
|
201
|
+
let n = 0;
|
|
202
|
+
for (; n < e.length - 1 && e[n] === 0;) n++;
|
|
203
|
+
let r = e.slice(n);
|
|
204
|
+
if (r.length > t) throw Error("integer too large");
|
|
205
|
+
if (r.length === t) return r;
|
|
206
|
+
let i = new Uint8Array(t);
|
|
207
|
+
return i.set(r, t - r.length), i;
|
|
208
|
+
}
|
|
209
|
+
function de(e, t) {
|
|
210
|
+
let n = Buffer.from(e, "base64url");
|
|
211
|
+
if (n.length === t) return n;
|
|
212
|
+
let r = Buffer.alloc(t);
|
|
213
|
+
return n.copy(r, t - n.length), r;
|
|
214
|
+
}
|
|
215
|
+
function fe(e) {
|
|
216
|
+
let t = 0;
|
|
217
|
+
for (let n of e) if (n === 0) t += 8;
|
|
218
|
+
else for (let e = 0; e < 8; e++) if (!(n & 1 << e)) t++;
|
|
219
|
+
else return t;
|
|
220
|
+
return t;
|
|
221
|
+
}
|
|
222
|
+
//#endregion
|
|
223
|
+
//#region node_modules/.pnpm/@noble+hashes@2.0.1/node_modules/@noble/hashes/utils.js
|
|
224
|
+
function pe(e) {
|
|
225
|
+
return e instanceof Uint8Array || ArrayBuffer.isView(e) && e.constructor.name === "Uint8Array";
|
|
226
|
+
}
|
|
227
|
+
function me(e, t = "") {
|
|
228
|
+
if (!Number.isSafeInteger(e) || e < 0) {
|
|
229
|
+
let n = t && `"${t}" `;
|
|
230
|
+
throw Error(`${n}expected integer >= 0, got ${e}`);
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
function E(e, t, n = "") {
|
|
234
|
+
let r = pe(e), i = e?.length, a = t !== void 0;
|
|
235
|
+
if (!r || a && i !== t) {
|
|
236
|
+
let o = n && `"${n}" `, s = a ? ` of length ${t}` : "", c = r ? `length=${i}` : `type=${typeof e}`;
|
|
237
|
+
throw Error(o + "expected Uint8Array" + s + ", got " + c);
|
|
238
|
+
}
|
|
239
|
+
return e;
|
|
240
|
+
}
|
|
241
|
+
function he(e, t = !0) {
|
|
242
|
+
if (e.destroyed) throw Error("Hash instance has been destroyed");
|
|
243
|
+
if (t && e.finished) throw Error("Hash#digest() has already been called");
|
|
244
|
+
}
|
|
245
|
+
function ge(e, t) {
|
|
246
|
+
E(e, void 0, "digestInto() output");
|
|
247
|
+
let n = t.outputLen;
|
|
248
|
+
if (e.length < n) throw Error("\"digestInto() output\" expected to be of length >=" + n);
|
|
249
|
+
}
|
|
250
|
+
function _e(...e) {
|
|
251
|
+
for (let t = 0; t < e.length; t++) e[t].fill(0);
|
|
252
|
+
}
|
|
253
|
+
function ve(e) {
|
|
254
|
+
return new DataView(e.buffer, e.byteOffset, e.byteLength);
|
|
255
|
+
}
|
|
256
|
+
new Uint8Array(new Uint32Array([287454020]).buffer)[0];
|
|
257
|
+
var ye = typeof Uint8Array.from([]).toHex == "function" && typeof Uint8Array.fromHex == "function", be = /* @__PURE__ */ Array.from({ length: 256 }, (e, t) => t.toString(16).padStart(2, "0"));
|
|
258
|
+
function xe(e) {
|
|
259
|
+
if (E(e), ye) return e.toHex();
|
|
260
|
+
let t = "";
|
|
261
|
+
for (let n = 0; n < e.length; n++) t += be[e[n]];
|
|
262
|
+
return t;
|
|
263
|
+
}
|
|
264
|
+
var D = {
|
|
265
|
+
_0: 48,
|
|
266
|
+
_9: 57,
|
|
267
|
+
A: 65,
|
|
268
|
+
F: 70,
|
|
269
|
+
a: 97,
|
|
270
|
+
f: 102
|
|
271
|
+
};
|
|
272
|
+
function Se(e) {
|
|
273
|
+
if (e >= D._0 && e <= D._9) return e - D._0;
|
|
274
|
+
if (e >= D.A && e <= D.F) return e - (D.A - 10);
|
|
275
|
+
if (e >= D.a && e <= D.f) return e - (D.a - 10);
|
|
276
|
+
}
|
|
277
|
+
function Ce(e) {
|
|
278
|
+
if (typeof e != "string") throw Error("hex string expected, got " + typeof e);
|
|
279
|
+
if (ye) return Uint8Array.fromHex(e);
|
|
280
|
+
let t = e.length, n = t / 2;
|
|
281
|
+
if (t % 2) throw Error("hex string expected, got unpadded hex of length " + t);
|
|
282
|
+
let r = new Uint8Array(n);
|
|
283
|
+
for (let t = 0, i = 0; t < n; t++, i += 2) {
|
|
284
|
+
let n = Se(e.charCodeAt(i)), a = Se(e.charCodeAt(i + 1));
|
|
285
|
+
if (n === void 0 || a === void 0) {
|
|
286
|
+
let t = e[i] + e[i + 1];
|
|
287
|
+
throw Error("hex string expected, got non-hex character \"" + t + "\" at index " + i);
|
|
288
|
+
}
|
|
289
|
+
r[t] = n * 16 + a;
|
|
290
|
+
}
|
|
291
|
+
return r;
|
|
292
|
+
}
|
|
293
|
+
function O(...e) {
|
|
294
|
+
let t = 0;
|
|
295
|
+
for (let n = 0; n < e.length; n++) {
|
|
296
|
+
let r = e[n];
|
|
297
|
+
E(r), t += r.length;
|
|
298
|
+
}
|
|
299
|
+
let n = new Uint8Array(t);
|
|
300
|
+
for (let t = 0, r = 0; t < e.length; t++) {
|
|
301
|
+
let i = e[t];
|
|
302
|
+
n.set(i, r), r += i.length;
|
|
303
|
+
}
|
|
304
|
+
return n;
|
|
305
|
+
}
|
|
306
|
+
function we(e, t = {}) {
|
|
307
|
+
let n = (t, n) => e(n).update(t).digest(), r = e(void 0);
|
|
308
|
+
return n.outputLen = r.outputLen, n.blockLen = r.blockLen, n.create = (t) => e(t), Object.assign(n, t), Object.freeze(n);
|
|
309
|
+
}
|
|
310
|
+
function k(e = 32) {
|
|
311
|
+
let t = typeof globalThis == "object" ? globalThis.crypto : null;
|
|
312
|
+
if (typeof t?.getRandomValues != "function") throw Error("crypto.getRandomValues must be defined");
|
|
313
|
+
return t.getRandomValues(new Uint8Array(e));
|
|
314
|
+
}
|
|
315
|
+
var Te = (e) => ({ oid: Uint8Array.from([
|
|
316
|
+
6,
|
|
317
|
+
9,
|
|
318
|
+
96,
|
|
319
|
+
134,
|
|
320
|
+
72,
|
|
321
|
+
1,
|
|
322
|
+
101,
|
|
323
|
+
3,
|
|
324
|
+
4,
|
|
325
|
+
2,
|
|
326
|
+
e
|
|
327
|
+
]) }), Ee = class {
|
|
328
|
+
blockLen;
|
|
329
|
+
outputLen;
|
|
330
|
+
padOffset;
|
|
331
|
+
isLE;
|
|
332
|
+
buffer;
|
|
333
|
+
view;
|
|
334
|
+
finished = !1;
|
|
335
|
+
length = 0;
|
|
336
|
+
pos = 0;
|
|
337
|
+
destroyed = !1;
|
|
338
|
+
constructor(e, t, n, r) {
|
|
339
|
+
this.blockLen = e, this.outputLen = t, this.padOffset = n, this.isLE = r, this.buffer = new Uint8Array(e), this.view = ve(this.buffer);
|
|
340
|
+
}
|
|
341
|
+
update(e) {
|
|
342
|
+
he(this), E(e);
|
|
343
|
+
let { view: t, buffer: n, blockLen: r } = this, i = e.length;
|
|
344
|
+
for (let a = 0; a < i;) {
|
|
345
|
+
let o = Math.min(r - this.pos, i - a);
|
|
346
|
+
if (o === r) {
|
|
347
|
+
let t = ve(e);
|
|
348
|
+
for (; r <= i - a; a += r) this.process(t, a);
|
|
349
|
+
continue;
|
|
350
|
+
}
|
|
351
|
+
n.set(e.subarray(a, a + o), this.pos), this.pos += o, a += o, this.pos === r && (this.process(t, 0), this.pos = 0);
|
|
352
|
+
}
|
|
353
|
+
return this.length += e.length, this.roundClean(), this;
|
|
354
|
+
}
|
|
355
|
+
digestInto(e) {
|
|
356
|
+
he(this), ge(e, this), this.finished = !0;
|
|
357
|
+
let { buffer: t, view: n, blockLen: r, isLE: i } = this, { pos: a } = this;
|
|
358
|
+
t[a++] = 128, _e(this.buffer.subarray(a)), this.padOffset > r - a && (this.process(n, 0), a = 0);
|
|
359
|
+
for (let e = a; e < r; e++) t[e] = 0;
|
|
360
|
+
n.setBigUint64(r - 8, BigInt(this.length * 8), i), this.process(n, 0);
|
|
361
|
+
let o = ve(e), s = this.outputLen;
|
|
362
|
+
if (s % 4) throw Error("_sha2: outputLen must be aligned to 32bit");
|
|
363
|
+
let c = s / 4, l = this.get();
|
|
364
|
+
if (c > l.length) throw Error("_sha2: outputLen bigger than state");
|
|
365
|
+
for (let e = 0; e < c; e++) o.setUint32(4 * e, l[e], i);
|
|
366
|
+
}
|
|
367
|
+
digest() {
|
|
368
|
+
let { buffer: e, outputLen: t } = this;
|
|
369
|
+
this.digestInto(e);
|
|
370
|
+
let n = e.slice(0, t);
|
|
371
|
+
return this.destroy(), n;
|
|
372
|
+
}
|
|
373
|
+
_cloneInto(e) {
|
|
374
|
+
e ||= new this.constructor(), e.set(...this.get());
|
|
375
|
+
let { blockLen: t, buffer: n, length: r, finished: i, destroyed: a, pos: o } = this;
|
|
376
|
+
return e.destroyed = a, e.finished = i, e.length = r, e.pos = o, r % t && e.buffer.set(n), e;
|
|
377
|
+
}
|
|
378
|
+
clone() {
|
|
379
|
+
return this._cloneInto();
|
|
380
|
+
}
|
|
381
|
+
}, A = /* @__PURE__ */ Uint32Array.from([
|
|
382
|
+
1779033703,
|
|
383
|
+
4089235720,
|
|
384
|
+
3144134277,
|
|
385
|
+
2227873595,
|
|
386
|
+
1013904242,
|
|
387
|
+
4271175723,
|
|
388
|
+
2773480762,
|
|
389
|
+
1595750129,
|
|
390
|
+
1359893119,
|
|
391
|
+
2917565137,
|
|
392
|
+
2600822924,
|
|
393
|
+
725511199,
|
|
394
|
+
528734635,
|
|
395
|
+
4215389547,
|
|
396
|
+
1541459225,
|
|
397
|
+
327033209
|
|
398
|
+
]), De = /* @__PURE__ */ BigInt(2 ** 32 - 1), Oe = /* @__PURE__ */ BigInt(32);
|
|
399
|
+
function ke(e, t = !1) {
|
|
400
|
+
return t ? {
|
|
401
|
+
h: Number(e & De),
|
|
402
|
+
l: Number(e >> Oe & De)
|
|
403
|
+
} : {
|
|
404
|
+
h: Number(e >> Oe & De) | 0,
|
|
405
|
+
l: Number(e & De) | 0
|
|
406
|
+
};
|
|
407
|
+
}
|
|
408
|
+
function Ae(e, t = !1) {
|
|
409
|
+
let n = e.length, r = new Uint32Array(n), i = new Uint32Array(n);
|
|
410
|
+
for (let a = 0; a < n; a++) {
|
|
411
|
+
let { h: n, l: o } = ke(e[a], t);
|
|
412
|
+
[r[a], i[a]] = [n, o];
|
|
413
|
+
}
|
|
414
|
+
return [r, i];
|
|
415
|
+
}
|
|
416
|
+
var je = (e, t, n) => e >>> n, Me = (e, t, n) => e << 32 - n | t >>> n, j = (e, t, n) => e >>> n | t << 32 - n, M = (e, t, n) => e << 32 - n | t >>> n, Ne = (e, t, n) => e << 64 - n | t >>> n - 32, Pe = (e, t, n) => e >>> n - 32 | t << 64 - n;
|
|
417
|
+
function N(e, t, n, r) {
|
|
418
|
+
let i = (t >>> 0) + (r >>> 0);
|
|
419
|
+
return {
|
|
420
|
+
h: e + n + (i / 2 ** 32 | 0) | 0,
|
|
421
|
+
l: i | 0
|
|
422
|
+
};
|
|
423
|
+
}
|
|
424
|
+
var Fe = (e, t, n) => (e >>> 0) + (t >>> 0) + (n >>> 0), Ie = (e, t, n, r) => t + n + r + (e / 2 ** 32 | 0) | 0, Le = (e, t, n, r) => (e >>> 0) + (t >>> 0) + (n >>> 0) + (r >>> 0), Re = (e, t, n, r, i) => t + n + r + i + (e / 2 ** 32 | 0) | 0, ze = (e, t, n, r, i) => (e >>> 0) + (t >>> 0) + (n >>> 0) + (r >>> 0) + (i >>> 0), Be = (e, t, n, r, i, a) => t + n + r + i + a + (e / 2 ** 32 | 0) | 0, Ve = Ae((/* @__PURE__ */ "0x428a2f98d728ae22.0x7137449123ef65cd.0xb5c0fbcfec4d3b2f.0xe9b5dba58189dbbc.0x3956c25bf348b538.0x59f111f1b605d019.0x923f82a4af194f9b.0xab1c5ed5da6d8118.0xd807aa98a3030242.0x12835b0145706fbe.0x243185be4ee4b28c.0x550c7dc3d5ffb4e2.0x72be5d74f27b896f.0x80deb1fe3b1696b1.0x9bdc06a725c71235.0xc19bf174cf692694.0xe49b69c19ef14ad2.0xefbe4786384f25e3.0x0fc19dc68b8cd5b5.0x240ca1cc77ac9c65.0x2de92c6f592b0275.0x4a7484aa6ea6e483.0x5cb0a9dcbd41fbd4.0x76f988da831153b5.0x983e5152ee66dfab.0xa831c66d2db43210.0xb00327c898fb213f.0xbf597fc7beef0ee4.0xc6e00bf33da88fc2.0xd5a79147930aa725.0x06ca6351e003826f.0x142929670a0e6e70.0x27b70a8546d22ffc.0x2e1b21385c26c926.0x4d2c6dfc5ac42aed.0x53380d139d95b3df.0x650a73548baf63de.0x766a0abb3c77b2a8.0x81c2c92e47edaee6.0x92722c851482353b.0xa2bfe8a14cf10364.0xa81a664bbc423001.0xc24b8b70d0f89791.0xc76c51a30654be30.0xd192e819d6ef5218.0xd69906245565a910.0xf40e35855771202a.0x106aa07032bbd1b8.0x19a4c116b8d2d0c8.0x1e376c085141ab53.0x2748774cdf8eeb99.0x34b0bcb5e19b48a8.0x391c0cb3c5c95a63.0x4ed8aa4ae3418acb.0x5b9cca4f7763e373.0x682e6ff3d6b2b8a3.0x748f82ee5defb2fc.0x78a5636f43172f60.0x84c87814a1f0ab72.0x8cc702081a6439ec.0x90befffa23631e28.0xa4506cebde82bde9.0xbef9a3f7b2c67915.0xc67178f2e372532b.0xca273eceea26619c.0xd186b8c721c0c207.0xeada7dd6cde0eb1e.0xf57d4f7fee6ed178.0x06f067aa72176fba.0x0a637dc5a2c898a6.0x113f9804bef90dae.0x1b710b35131c471b.0x28db77f523047d84.0x32caab7b40c72493.0x3c9ebe0a15c9bebc.0x431d67c49c100d4c.0x4cc5d4becb3e42b6.0x597f299cfc657e2a.0x5fcb6fab3ad6faec.0x6c44198c4a475817".split(".")).map((e) => BigInt(e))), He = Ve[0], Ue = Ve[1], P = /* @__PURE__ */ new Uint32Array(80), F = /* @__PURE__ */ new Uint32Array(80), We = class extends Ee {
|
|
425
|
+
constructor(e) {
|
|
426
|
+
super(128, e, 16, !1);
|
|
427
|
+
}
|
|
428
|
+
get() {
|
|
429
|
+
let { Ah: e, Al: t, Bh: n, Bl: r, Ch: i, Cl: a, Dh: o, Dl: s, Eh: c, El: l, Fh: u, Fl: d, Gh: f, Gl: p, Hh: m, Hl: h } = this;
|
|
430
|
+
return [
|
|
431
|
+
e,
|
|
432
|
+
t,
|
|
433
|
+
n,
|
|
434
|
+
r,
|
|
435
|
+
i,
|
|
436
|
+
a,
|
|
437
|
+
o,
|
|
438
|
+
s,
|
|
439
|
+
c,
|
|
440
|
+
l,
|
|
441
|
+
u,
|
|
442
|
+
d,
|
|
443
|
+
f,
|
|
444
|
+
p,
|
|
445
|
+
m,
|
|
446
|
+
h
|
|
447
|
+
];
|
|
448
|
+
}
|
|
449
|
+
set(e, t, n, r, i, a, o, s, c, l, u, d, f, p, m, h) {
|
|
450
|
+
this.Ah = e | 0, this.Al = t | 0, this.Bh = n | 0, this.Bl = r | 0, this.Ch = i | 0, this.Cl = a | 0, this.Dh = o | 0, this.Dl = s | 0, this.Eh = c | 0, this.El = l | 0, this.Fh = u | 0, this.Fl = d | 0, this.Gh = f | 0, this.Gl = p | 0, this.Hh = m | 0, this.Hl = h | 0;
|
|
451
|
+
}
|
|
452
|
+
process(e, t) {
|
|
453
|
+
for (let n = 0; n < 16; n++, t += 4) P[n] = e.getUint32(t), F[n] = e.getUint32(t += 4);
|
|
454
|
+
for (let e = 16; e < 80; e++) {
|
|
455
|
+
let t = P[e - 15] | 0, n = F[e - 15] | 0, r = j(t, n, 1) ^ j(t, n, 8) ^ je(t, n, 7), i = M(t, n, 1) ^ M(t, n, 8) ^ Me(t, n, 7), a = P[e - 2] | 0, o = F[e - 2] | 0, s = j(a, o, 19) ^ Ne(a, o, 61) ^ je(a, o, 6), c = Le(i, M(a, o, 19) ^ Pe(a, o, 61) ^ Me(a, o, 6), F[e - 7], F[e - 16]);
|
|
456
|
+
P[e] = Re(c, r, s, P[e - 7], P[e - 16]) | 0, F[e] = c | 0;
|
|
457
|
+
}
|
|
458
|
+
let { Ah: n, Al: r, Bh: i, Bl: a, Ch: o, Cl: s, Dh: c, Dl: l, Eh: u, El: d, Fh: f, Fl: p, Gh: m, Gl: h, Hh: g, Hl: _ } = this;
|
|
459
|
+
for (let e = 0; e < 80; e++) {
|
|
460
|
+
let t = j(u, d, 14) ^ j(u, d, 18) ^ Ne(u, d, 41), v = M(u, d, 14) ^ M(u, d, 18) ^ Pe(u, d, 41), y = u & f ^ ~u & m, b = d & p ^ ~d & h, x = ze(_, v, b, Ue[e], F[e]), S = Be(x, g, t, y, He[e], P[e]), C = x | 0, w = j(n, r, 28) ^ Ne(n, r, 34) ^ Ne(n, r, 39), ee = M(n, r, 28) ^ Pe(n, r, 34) ^ Pe(n, r, 39), te = n & i ^ n & o ^ i & o, ne = r & a ^ r & s ^ a & s;
|
|
461
|
+
g = m | 0, _ = h | 0, m = f | 0, h = p | 0, f = u | 0, p = d | 0, {h: u, l: d} = N(c | 0, l | 0, S | 0, C | 0), c = o | 0, l = s | 0, o = i | 0, s = a | 0, i = n | 0, a = r | 0;
|
|
462
|
+
let re = Fe(C, ee, ne);
|
|
463
|
+
n = Ie(re, S, w, te), r = re | 0;
|
|
464
|
+
}
|
|
465
|
+
({h: n, l: r} = N(this.Ah | 0, this.Al | 0, n | 0, r | 0)), {h: i, l: a} = N(this.Bh | 0, this.Bl | 0, i | 0, a | 0), {h: o, l: s} = N(this.Ch | 0, this.Cl | 0, o | 0, s | 0), {h: c, l: l} = N(this.Dh | 0, this.Dl | 0, c | 0, l | 0), {h: u, l: d} = N(this.Eh | 0, this.El | 0, u | 0, d | 0), {h: f, l: p} = N(this.Fh | 0, this.Fl | 0, f | 0, p | 0), {h: m, l: h} = N(this.Gh | 0, this.Gl | 0, m | 0, h | 0), {h: g, l: _} = N(this.Hh | 0, this.Hl | 0, g | 0, _ | 0), this.set(n, r, i, a, o, s, c, l, u, d, f, p, m, h, g, _);
|
|
466
|
+
}
|
|
467
|
+
roundClean() {
|
|
468
|
+
_e(P, F);
|
|
469
|
+
}
|
|
470
|
+
destroy() {
|
|
471
|
+
_e(this.buffer), this.set(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0);
|
|
472
|
+
}
|
|
473
|
+
}, Ge = class extends We {
|
|
474
|
+
Ah = A[0] | 0;
|
|
475
|
+
Al = A[1] | 0;
|
|
476
|
+
Bh = A[2] | 0;
|
|
477
|
+
Bl = A[3] | 0;
|
|
478
|
+
Ch = A[4] | 0;
|
|
479
|
+
Cl = A[5] | 0;
|
|
480
|
+
Dh = A[6] | 0;
|
|
481
|
+
Dl = A[7] | 0;
|
|
482
|
+
Eh = A[8] | 0;
|
|
483
|
+
El = A[9] | 0;
|
|
484
|
+
Fh = A[10] | 0;
|
|
485
|
+
Fl = A[11] | 0;
|
|
486
|
+
Gh = A[12] | 0;
|
|
487
|
+
Gl = A[13] | 0;
|
|
488
|
+
Hh = A[14] | 0;
|
|
489
|
+
Hl = A[15] | 0;
|
|
490
|
+
constructor() {
|
|
491
|
+
super(64);
|
|
492
|
+
}
|
|
493
|
+
}, Ke = /* @__PURE__ */ we(() => new Ge(), /* @__PURE__ */ Te(3)), qe = /* @__PURE__ */ BigInt(0), Je = /* @__PURE__ */ BigInt(1);
|
|
494
|
+
function Ye(e, t = "") {
|
|
495
|
+
if (typeof e != "boolean") {
|
|
496
|
+
let n = t && `"${t}" `;
|
|
497
|
+
throw Error(n + "expected boolean, got type=" + typeof e);
|
|
498
|
+
}
|
|
499
|
+
return e;
|
|
500
|
+
}
|
|
501
|
+
function Xe(e) {
|
|
502
|
+
if (typeof e == "bigint") {
|
|
503
|
+
if (!rt(e)) throw Error("positive bigint expected, got " + e);
|
|
504
|
+
} else me(e);
|
|
505
|
+
return e;
|
|
506
|
+
}
|
|
507
|
+
function I(e, t = "") {
|
|
508
|
+
if (!Number.isSafeInteger(e)) {
|
|
509
|
+
let n = t && `"${t}" `;
|
|
510
|
+
throw Error(n + "expected safe integer, got type=" + typeof e);
|
|
511
|
+
}
|
|
512
|
+
}
|
|
513
|
+
function Ze(e) {
|
|
514
|
+
if (typeof e != "string") throw Error("hex string expected, got " + typeof e);
|
|
515
|
+
return e === "" ? qe : BigInt("0x" + e);
|
|
516
|
+
}
|
|
517
|
+
function Qe(e) {
|
|
518
|
+
return Ze(xe(e));
|
|
519
|
+
}
|
|
520
|
+
function L(e) {
|
|
521
|
+
return Ze(xe(nt(E(e)).reverse()));
|
|
522
|
+
}
|
|
523
|
+
function $e(e, t) {
|
|
524
|
+
me(t), e = Xe(e);
|
|
525
|
+
let n = Ce(e.toString(16).padStart(t * 2, "0"));
|
|
526
|
+
if (n.length !== t) throw Error("number too large");
|
|
527
|
+
return n;
|
|
528
|
+
}
|
|
529
|
+
function et(e, t) {
|
|
530
|
+
return $e(e, t).reverse();
|
|
531
|
+
}
|
|
532
|
+
function tt(e, t) {
|
|
533
|
+
if (e.length !== t.length) return !1;
|
|
534
|
+
let n = 0;
|
|
535
|
+
for (let r = 0; r < e.length; r++) n |= e[r] ^ t[r];
|
|
536
|
+
return n === 0;
|
|
537
|
+
}
|
|
538
|
+
function nt(e) {
|
|
539
|
+
return Uint8Array.from(e);
|
|
540
|
+
}
|
|
541
|
+
function R(e) {
|
|
542
|
+
return Uint8Array.from(e, (t, n) => {
|
|
543
|
+
let r = t.charCodeAt(0);
|
|
544
|
+
if (t.length !== 1 || r > 127) throw Error(`string contains non-ASCII character "${e[n]}" with code ${r} at position ${n}`);
|
|
545
|
+
return r;
|
|
546
|
+
});
|
|
547
|
+
}
|
|
548
|
+
var rt = (e) => typeof e == "bigint" && qe <= e;
|
|
549
|
+
function it(e, t, n) {
|
|
550
|
+
return rt(e) && rt(t) && rt(n) && t <= e && e < n;
|
|
551
|
+
}
|
|
552
|
+
function at(e, t, n, r) {
|
|
553
|
+
if (!it(t, n, r)) throw Error("expected valid " + e + ": " + n + " <= n < " + r + ", got " + t);
|
|
554
|
+
}
|
|
555
|
+
function ot(e) {
|
|
556
|
+
let t;
|
|
557
|
+
for (t = 0; e > qe; e >>= Je, t += 1);
|
|
558
|
+
return t;
|
|
559
|
+
}
|
|
560
|
+
var st = (e) => (Je << BigInt(e)) - Je;
|
|
561
|
+
function ct(e, t = {}, n = {}) {
|
|
562
|
+
if (!e || typeof e != "object") throw Error("expected valid options object");
|
|
563
|
+
function r(t, n, r) {
|
|
564
|
+
let i = e[t];
|
|
565
|
+
if (r && i === void 0) return;
|
|
566
|
+
let a = typeof i;
|
|
567
|
+
if (a !== n || i === null) throw Error(`param "${t}" is invalid: expected ${n}, got ${a}`);
|
|
568
|
+
}
|
|
569
|
+
let i = (e, t) => Object.entries(e).forEach(([e, n]) => r(e, n, t));
|
|
570
|
+
i(t, !1), i(n, !0);
|
|
571
|
+
}
|
|
572
|
+
var lt = () => {
|
|
573
|
+
throw Error("not implemented");
|
|
574
|
+
};
|
|
575
|
+
function ut(e) {
|
|
576
|
+
let t = /* @__PURE__ */ new WeakMap();
|
|
577
|
+
return (n, ...r) => {
|
|
578
|
+
let i = t.get(n);
|
|
579
|
+
if (i !== void 0) return i;
|
|
580
|
+
let a = e(n, ...r);
|
|
581
|
+
return t.set(n, a), a;
|
|
582
|
+
};
|
|
583
|
+
}
|
|
584
|
+
//#endregion
|
|
585
|
+
//#region node_modules/.pnpm/@noble+curves@2.0.1/node_modules/@noble/curves/abstract/modular.js
|
|
586
|
+
var z = /* @__PURE__ */ BigInt(0), B = /* @__PURE__ */ BigInt(1), V = /* @__PURE__ */ BigInt(2), dt = /* @__PURE__ */ BigInt(3), ft = /* @__PURE__ */ BigInt(4), pt = /* @__PURE__ */ BigInt(5), mt = /* @__PURE__ */ BigInt(7), ht = /* @__PURE__ */ BigInt(8), gt = /* @__PURE__ */ BigInt(9), _t = /* @__PURE__ */ BigInt(16);
|
|
587
|
+
function H(e, t) {
|
|
588
|
+
let n = e % t;
|
|
589
|
+
return n >= z ? n : t + n;
|
|
590
|
+
}
|
|
591
|
+
function U(e, t, n) {
|
|
592
|
+
let r = e;
|
|
593
|
+
for (; t-- > z;) r *= r, r %= n;
|
|
594
|
+
return r;
|
|
595
|
+
}
|
|
596
|
+
function vt(e, t) {
|
|
597
|
+
if (e === z) throw Error("invert: expected non-zero number");
|
|
598
|
+
if (t <= z) throw Error("invert: expected positive modulus, got " + t);
|
|
599
|
+
let n = H(e, t), r = t, i = z, a = B, o = B, s = z;
|
|
600
|
+
for (; n !== z;) {
|
|
601
|
+
let e = r / n, t = r % n, c = i - o * e, l = a - s * e;
|
|
602
|
+
r = n, n = t, i = o, a = s, o = c, s = l;
|
|
603
|
+
}
|
|
604
|
+
if (r !== B) throw Error("invert: does not exist");
|
|
605
|
+
return H(i, t);
|
|
606
|
+
}
|
|
607
|
+
function yt(e, t, n) {
|
|
608
|
+
if (!e.eql(e.sqr(t), n)) throw Error("Cannot find square root");
|
|
609
|
+
}
|
|
610
|
+
function bt(e, t) {
|
|
611
|
+
let n = (e.ORDER + B) / ft, r = e.pow(t, n);
|
|
612
|
+
return yt(e, r, t), r;
|
|
613
|
+
}
|
|
614
|
+
function xt(e, t) {
|
|
615
|
+
let n = (e.ORDER - pt) / ht, r = e.mul(t, V), i = e.pow(r, n), a = e.mul(t, i), o = e.mul(e.mul(a, V), i), s = e.mul(a, e.sub(o, e.ONE));
|
|
616
|
+
return yt(e, s, t), s;
|
|
617
|
+
}
|
|
618
|
+
function St(e) {
|
|
619
|
+
let t = Mt(e), n = Ct(e), r = n(t, t.neg(t.ONE)), i = n(t, r), a = n(t, t.neg(r)), o = (e + mt) / _t;
|
|
620
|
+
return (e, t) => {
|
|
621
|
+
let n = e.pow(t, o), s = e.mul(n, r), c = e.mul(n, i), l = e.mul(n, a), u = e.eql(e.sqr(s), t), d = e.eql(e.sqr(c), t);
|
|
622
|
+
n = e.cmov(n, s, u), s = e.cmov(l, c, d);
|
|
623
|
+
let f = e.eql(e.sqr(s), t), p = e.cmov(n, s, f);
|
|
624
|
+
return yt(e, p, t), p;
|
|
625
|
+
};
|
|
626
|
+
}
|
|
627
|
+
function Ct(e) {
|
|
628
|
+
if (e < dt) throw Error("sqrt is not defined for small field");
|
|
629
|
+
let t = e - B, n = 0;
|
|
630
|
+
for (; t % V === z;) t /= V, n++;
|
|
631
|
+
let r = V, i = Mt(e);
|
|
632
|
+
for (; kt(i, r) === 1;) if (r++ > 1e3) throw Error("Cannot find square root: probably non-prime P");
|
|
633
|
+
if (n === 1) return bt;
|
|
634
|
+
let a = i.pow(r, t), o = (t + B) / V;
|
|
635
|
+
return function(e, r) {
|
|
636
|
+
if (e.is0(r)) return r;
|
|
637
|
+
if (kt(e, r) !== 1) throw Error("Cannot find square root");
|
|
638
|
+
let i = n, s = e.mul(e.ONE, a), c = e.pow(r, t), l = e.pow(r, o);
|
|
639
|
+
for (; !e.eql(c, e.ONE);) {
|
|
640
|
+
if (e.is0(c)) return e.ZERO;
|
|
641
|
+
let t = 1, n = e.sqr(c);
|
|
642
|
+
for (; !e.eql(n, e.ONE);) if (t++, n = e.sqr(n), t === i) throw Error("Cannot find square root");
|
|
643
|
+
let r = B << BigInt(i - t - 1), a = e.pow(s, r);
|
|
644
|
+
i = t, s = e.sqr(a), c = e.mul(c, s), l = e.mul(l, a);
|
|
645
|
+
}
|
|
646
|
+
return l;
|
|
647
|
+
};
|
|
648
|
+
}
|
|
649
|
+
function wt(e) {
|
|
650
|
+
return e % ft === dt ? bt : e % ht === pt ? xt : e % _t === gt ? St(e) : Ct(e);
|
|
651
|
+
}
|
|
652
|
+
var W = (e, t) => (H(e, t) & B) === B, Tt = [
|
|
653
|
+
"create",
|
|
654
|
+
"isValid",
|
|
655
|
+
"is0",
|
|
656
|
+
"neg",
|
|
657
|
+
"inv",
|
|
658
|
+
"sqrt",
|
|
659
|
+
"sqr",
|
|
660
|
+
"eql",
|
|
661
|
+
"add",
|
|
662
|
+
"sub",
|
|
663
|
+
"mul",
|
|
664
|
+
"pow",
|
|
665
|
+
"div",
|
|
666
|
+
"addN",
|
|
667
|
+
"subN",
|
|
668
|
+
"mulN",
|
|
669
|
+
"sqrN"
|
|
670
|
+
];
|
|
671
|
+
function Et(e) {
|
|
672
|
+
return ct(e, Tt.reduce((e, t) => (e[t] = "function", e), {
|
|
673
|
+
ORDER: "bigint",
|
|
674
|
+
BYTES: "number",
|
|
675
|
+
BITS: "number"
|
|
676
|
+
})), e;
|
|
677
|
+
}
|
|
678
|
+
function Dt(e, t, n) {
|
|
679
|
+
if (n < z) throw Error("invalid exponent, negatives unsupported");
|
|
680
|
+
if (n === z) return e.ONE;
|
|
681
|
+
if (n === B) return t;
|
|
682
|
+
let r = e.ONE, i = t;
|
|
683
|
+
for (; n > z;) n & B && (r = e.mul(r, i)), i = e.sqr(i), n >>= B;
|
|
684
|
+
return r;
|
|
685
|
+
}
|
|
686
|
+
function Ot(e, t, n = !1) {
|
|
687
|
+
let r = Array(t.length).fill(n ? e.ZERO : void 0), i = t.reduce((t, n, i) => e.is0(n) ? t : (r[i] = t, e.mul(t, n)), e.ONE), a = e.inv(i);
|
|
688
|
+
return t.reduceRight((t, n, i) => e.is0(n) ? t : (r[i] = e.mul(t, r[i]), e.mul(t, n)), a), r;
|
|
689
|
+
}
|
|
690
|
+
function kt(e, t) {
|
|
691
|
+
let n = (e.ORDER - B) / V, r = e.pow(t, n), i = e.eql(r, e.ONE), a = e.eql(r, e.ZERO), o = e.eql(r, e.neg(e.ONE));
|
|
692
|
+
if (!i && !a && !o) throw Error("invalid Legendre symbol result");
|
|
693
|
+
return i ? 1 : a ? 0 : -1;
|
|
694
|
+
}
|
|
695
|
+
function At(e, t) {
|
|
696
|
+
t !== void 0 && me(t);
|
|
697
|
+
let n = t === void 0 ? e.toString(2).length : t;
|
|
698
|
+
return {
|
|
699
|
+
nBitLength: n,
|
|
700
|
+
nByteLength: Math.ceil(n / 8)
|
|
701
|
+
};
|
|
702
|
+
}
|
|
703
|
+
var jt = class {
|
|
704
|
+
ORDER;
|
|
705
|
+
BITS;
|
|
706
|
+
BYTES;
|
|
707
|
+
isLE;
|
|
708
|
+
ZERO = z;
|
|
709
|
+
ONE = B;
|
|
710
|
+
_lengths;
|
|
711
|
+
_sqrt;
|
|
712
|
+
_mod;
|
|
713
|
+
constructor(e, t = {}) {
|
|
714
|
+
if (e <= z) throw Error("invalid field: expected ORDER > 0, got " + e);
|
|
715
|
+
let n;
|
|
716
|
+
this.isLE = !1, typeof t == "object" && t && (typeof t.BITS == "number" && (n = t.BITS), typeof t.sqrt == "function" && (this.sqrt = t.sqrt), typeof t.isLE == "boolean" && (this.isLE = t.isLE), t.allowedLengths && (this._lengths = t.allowedLengths?.slice()), typeof t.modFromBytes == "boolean" && (this._mod = t.modFromBytes));
|
|
717
|
+
let { nBitLength: r, nByteLength: i } = At(e, n);
|
|
718
|
+
if (i > 2048) throw Error("invalid field: expected ORDER of <= 2048 bytes");
|
|
719
|
+
this.ORDER = e, this.BITS = r, this.BYTES = i, this._sqrt = void 0, Object.preventExtensions(this);
|
|
720
|
+
}
|
|
721
|
+
create(e) {
|
|
722
|
+
return H(e, this.ORDER);
|
|
723
|
+
}
|
|
724
|
+
isValid(e) {
|
|
725
|
+
if (typeof e != "bigint") throw Error("invalid field element: expected bigint, got " + typeof e);
|
|
726
|
+
return z <= e && e < this.ORDER;
|
|
727
|
+
}
|
|
728
|
+
is0(e) {
|
|
729
|
+
return e === z;
|
|
730
|
+
}
|
|
731
|
+
isValidNot0(e) {
|
|
732
|
+
return !this.is0(e) && this.isValid(e);
|
|
733
|
+
}
|
|
734
|
+
isOdd(e) {
|
|
735
|
+
return (e & B) === B;
|
|
736
|
+
}
|
|
737
|
+
neg(e) {
|
|
738
|
+
return H(-e, this.ORDER);
|
|
739
|
+
}
|
|
740
|
+
eql(e, t) {
|
|
741
|
+
return e === t;
|
|
742
|
+
}
|
|
743
|
+
sqr(e) {
|
|
744
|
+
return H(e * e, this.ORDER);
|
|
745
|
+
}
|
|
746
|
+
add(e, t) {
|
|
747
|
+
return H(e + t, this.ORDER);
|
|
748
|
+
}
|
|
749
|
+
sub(e, t) {
|
|
750
|
+
return H(e - t, this.ORDER);
|
|
751
|
+
}
|
|
752
|
+
mul(e, t) {
|
|
753
|
+
return H(e * t, this.ORDER);
|
|
754
|
+
}
|
|
755
|
+
pow(e, t) {
|
|
756
|
+
return Dt(this, e, t);
|
|
757
|
+
}
|
|
758
|
+
div(e, t) {
|
|
759
|
+
return H(e * vt(t, this.ORDER), this.ORDER);
|
|
760
|
+
}
|
|
761
|
+
sqrN(e) {
|
|
762
|
+
return e * e;
|
|
763
|
+
}
|
|
764
|
+
addN(e, t) {
|
|
765
|
+
return e + t;
|
|
766
|
+
}
|
|
767
|
+
subN(e, t) {
|
|
768
|
+
return e - t;
|
|
769
|
+
}
|
|
770
|
+
mulN(e, t) {
|
|
771
|
+
return e * t;
|
|
772
|
+
}
|
|
773
|
+
inv(e) {
|
|
774
|
+
return vt(e, this.ORDER);
|
|
775
|
+
}
|
|
776
|
+
sqrt(e) {
|
|
777
|
+
return this._sqrt ||= wt(this.ORDER), this._sqrt(this, e);
|
|
778
|
+
}
|
|
779
|
+
toBytes(e) {
|
|
780
|
+
return this.isLE ? et(e, this.BYTES) : $e(e, this.BYTES);
|
|
781
|
+
}
|
|
782
|
+
fromBytes(e, t = !1) {
|
|
783
|
+
E(e);
|
|
784
|
+
let { _lengths: n, BYTES: r, isLE: i, ORDER: a, _mod: o } = this;
|
|
785
|
+
if (n) {
|
|
786
|
+
if (!n.includes(e.length) || e.length > r) throw Error("Field.fromBytes: expected " + n + " bytes, got " + e.length);
|
|
787
|
+
let t = new Uint8Array(r);
|
|
788
|
+
t.set(e, i ? 0 : t.length - e.length), e = t;
|
|
789
|
+
}
|
|
790
|
+
if (e.length !== r) throw Error("Field.fromBytes: expected " + r + " bytes, got " + e.length);
|
|
791
|
+
let s = i ? L(e) : Qe(e);
|
|
792
|
+
if (o && (s = H(s, a)), !t && !this.isValid(s)) throw Error("invalid field element: outside of range 0..ORDER");
|
|
793
|
+
return s;
|
|
794
|
+
}
|
|
795
|
+
invertBatch(e) {
|
|
796
|
+
return Ot(this, e);
|
|
797
|
+
}
|
|
798
|
+
cmov(e, t, n) {
|
|
799
|
+
return n ? t : e;
|
|
800
|
+
}
|
|
801
|
+
};
|
|
802
|
+
function Mt(e, t = {}) {
|
|
803
|
+
return new jt(e, t);
|
|
804
|
+
}
|
|
805
|
+
function Nt(e, t) {
|
|
806
|
+
if (!e.isOdd) throw Error("Field doesn't have isOdd");
|
|
807
|
+
let n = e.sqrt(t);
|
|
808
|
+
return e.isOdd(n) ? e.neg(n) : n;
|
|
809
|
+
}
|
|
810
|
+
function Pt(e) {
|
|
811
|
+
if (typeof e != "bigint") throw Error("field order must be bigint");
|
|
812
|
+
let t = e.toString(2).length;
|
|
813
|
+
return Math.ceil(t / 8);
|
|
814
|
+
}
|
|
815
|
+
function Ft(e) {
|
|
816
|
+
let t = Pt(e);
|
|
817
|
+
return t + Math.ceil(t / 2);
|
|
818
|
+
}
|
|
819
|
+
function It(e, t, n = !1) {
|
|
820
|
+
E(e);
|
|
821
|
+
let r = e.length, i = Pt(t), a = Ft(t);
|
|
822
|
+
if (r < 16 || r < a || r > 1024) throw Error("expected " + a + "-1024 bytes of input, got " + r);
|
|
823
|
+
let o = H(n ? L(e) : Qe(e), t - B) + B;
|
|
824
|
+
return n ? et(o, i) : $e(o, i);
|
|
825
|
+
}
|
|
826
|
+
//#endregion
|
|
827
|
+
//#region node_modules/.pnpm/@noble+curves@2.0.1/node_modules/@noble/curves/abstract/curve.js
|
|
828
|
+
var Lt = /* @__PURE__ */ BigInt(0), Rt = /* @__PURE__ */ BigInt(1);
|
|
829
|
+
function zt(e, t) {
|
|
830
|
+
let n = t.negate();
|
|
831
|
+
return e ? n : t;
|
|
832
|
+
}
|
|
833
|
+
function Bt(e, t) {
|
|
834
|
+
let n = Ot(e.Fp, t.map((e) => e.Z));
|
|
835
|
+
return t.map((t, r) => e.fromAffine(t.toAffine(n[r])));
|
|
836
|
+
}
|
|
837
|
+
function Vt(e, t) {
|
|
838
|
+
if (!Number.isSafeInteger(e) || e <= 0 || e > t) throw Error("invalid window size, expected [1.." + t + "], got W=" + e);
|
|
839
|
+
}
|
|
840
|
+
function Ht(e, t) {
|
|
841
|
+
Vt(e, t);
|
|
842
|
+
let n = Math.ceil(t / e) + 1, r = 2 ** (e - 1), i = 2 ** e;
|
|
843
|
+
return {
|
|
844
|
+
windows: n,
|
|
845
|
+
windowSize: r,
|
|
846
|
+
mask: st(e),
|
|
847
|
+
maxNumber: i,
|
|
848
|
+
shiftBy: BigInt(e)
|
|
849
|
+
};
|
|
850
|
+
}
|
|
851
|
+
function Ut(e, t, n) {
|
|
852
|
+
let { windowSize: r, mask: i, maxNumber: a, shiftBy: o } = n, s = Number(e & i), c = e >> o;
|
|
853
|
+
s > r && (s -= a, c += Rt);
|
|
854
|
+
let l = t * r, u = l + Math.abs(s) - 1, d = s === 0, f = s < 0, p = t % 2 != 0;
|
|
855
|
+
return {
|
|
856
|
+
nextN: c,
|
|
857
|
+
offset: u,
|
|
858
|
+
isZero: d,
|
|
859
|
+
isNeg: f,
|
|
860
|
+
isNegF: p,
|
|
861
|
+
offsetF: l
|
|
862
|
+
};
|
|
863
|
+
}
|
|
864
|
+
function Wt(e, t) {
|
|
865
|
+
if (!Array.isArray(e)) throw Error("array expected");
|
|
866
|
+
e.forEach((e, n) => {
|
|
867
|
+
if (!(e instanceof t)) throw Error("invalid point at index " + n);
|
|
868
|
+
});
|
|
869
|
+
}
|
|
870
|
+
function Gt(e, t) {
|
|
871
|
+
if (!Array.isArray(e)) throw Error("array of scalars expected");
|
|
872
|
+
e.forEach((e, n) => {
|
|
873
|
+
if (!t.isValid(e)) throw Error("invalid scalar at index " + n);
|
|
874
|
+
});
|
|
875
|
+
}
|
|
876
|
+
var Kt = /* @__PURE__ */ new WeakMap(), qt = /* @__PURE__ */ new WeakMap();
|
|
877
|
+
function Jt(e) {
|
|
878
|
+
return qt.get(e) || 1;
|
|
879
|
+
}
|
|
880
|
+
function Yt(e) {
|
|
881
|
+
if (e !== Lt) throw Error("invalid wNAF");
|
|
882
|
+
}
|
|
883
|
+
var Xt = class {
|
|
884
|
+
BASE;
|
|
885
|
+
ZERO;
|
|
886
|
+
Fn;
|
|
887
|
+
bits;
|
|
888
|
+
constructor(e, t) {
|
|
889
|
+
this.BASE = e.BASE, this.ZERO = e.ZERO, this.Fn = e.Fn, this.bits = t;
|
|
890
|
+
}
|
|
891
|
+
_unsafeLadder(e, t, n = this.ZERO) {
|
|
892
|
+
let r = e;
|
|
893
|
+
for (; t > Lt;) t & Rt && (n = n.add(r)), r = r.double(), t >>= Rt;
|
|
894
|
+
return n;
|
|
895
|
+
}
|
|
896
|
+
precomputeWindow(e, t) {
|
|
897
|
+
let { windows: n, windowSize: r } = Ht(t, this.bits), i = [], a = e, o = a;
|
|
898
|
+
for (let e = 0; e < n; e++) {
|
|
899
|
+
o = a, i.push(o);
|
|
900
|
+
for (let e = 1; e < r; e++) o = o.add(a), i.push(o);
|
|
901
|
+
a = o.double();
|
|
902
|
+
}
|
|
903
|
+
return i;
|
|
904
|
+
}
|
|
905
|
+
wNAF(e, t, n) {
|
|
906
|
+
if (!this.Fn.isValid(n)) throw Error("invalid scalar");
|
|
907
|
+
let r = this.ZERO, i = this.BASE, a = Ht(e, this.bits);
|
|
908
|
+
for (let e = 0; e < a.windows; e++) {
|
|
909
|
+
let { nextN: o, offset: s, isZero: c, isNeg: l, isNegF: u, offsetF: d } = Ut(n, e, a);
|
|
910
|
+
n = o, c ? i = i.add(zt(u, t[d])) : r = r.add(zt(l, t[s]));
|
|
911
|
+
}
|
|
912
|
+
return Yt(n), {
|
|
913
|
+
p: r,
|
|
914
|
+
f: i
|
|
915
|
+
};
|
|
916
|
+
}
|
|
917
|
+
wNAFUnsafe(e, t, n, r = this.ZERO) {
|
|
918
|
+
let i = Ht(e, this.bits);
|
|
919
|
+
for (let e = 0; e < i.windows && n !== Lt; e++) {
|
|
920
|
+
let { nextN: a, offset: o, isZero: s, isNeg: c } = Ut(n, e, i);
|
|
921
|
+
if (n = a, !s) {
|
|
922
|
+
let e = t[o];
|
|
923
|
+
r = r.add(c ? e.negate() : e);
|
|
924
|
+
}
|
|
925
|
+
}
|
|
926
|
+
return Yt(n), r;
|
|
927
|
+
}
|
|
928
|
+
getPrecomputes(e, t, n) {
|
|
929
|
+
let r = Kt.get(t);
|
|
930
|
+
return r || (r = this.precomputeWindow(t, e), e !== 1 && (typeof n == "function" && (r = n(r)), Kt.set(t, r))), r;
|
|
931
|
+
}
|
|
932
|
+
cached(e, t, n) {
|
|
933
|
+
let r = Jt(e);
|
|
934
|
+
return this.wNAF(r, this.getPrecomputes(r, e, n), t);
|
|
935
|
+
}
|
|
936
|
+
unsafe(e, t, n, r) {
|
|
937
|
+
let i = Jt(e);
|
|
938
|
+
return i === 1 ? this._unsafeLadder(e, t, r) : this.wNAFUnsafe(i, this.getPrecomputes(i, e, n), t, r);
|
|
939
|
+
}
|
|
940
|
+
createCache(e, t) {
|
|
941
|
+
Vt(t, this.bits), qt.set(e, t), Kt.delete(e);
|
|
942
|
+
}
|
|
943
|
+
hasCache(e) {
|
|
944
|
+
return Jt(e) !== 1;
|
|
945
|
+
}
|
|
946
|
+
};
|
|
947
|
+
function Zt(e, t, n) {
|
|
948
|
+
let r = e.Fn;
|
|
949
|
+
Wt(t, e), Gt(n, r);
|
|
950
|
+
let i = t.length, a = n.length;
|
|
951
|
+
if (i !== a) throw Error("arrays of points and scalars must have equal length");
|
|
952
|
+
let o = e.ZERO, s = ot(BigInt(i)), c = 1;
|
|
953
|
+
s > 12 ? c = s - 3 : s > 4 ? c = s - 2 : s > 0 && (c = 2);
|
|
954
|
+
let l = st(c), u = Array(Number(l) + 1).fill(o), d = Math.floor((r.BITS - 1) / c) * c, f = o;
|
|
955
|
+
for (let e = d; e >= 0; e -= c) {
|
|
956
|
+
u.fill(o);
|
|
957
|
+
for (let r = 0; r < a; r++) {
|
|
958
|
+
let i = n[r], a = Number(i >> BigInt(e) & l);
|
|
959
|
+
u[a] = u[a].add(t[r]);
|
|
960
|
+
}
|
|
961
|
+
let r = o;
|
|
962
|
+
for (let e = u.length - 1, t = o; e > 0; e--) t = t.add(u[e]), r = r.add(t);
|
|
963
|
+
if (f = f.add(r), e !== 0) for (let e = 0; e < c; e++) f = f.double();
|
|
964
|
+
}
|
|
965
|
+
return f;
|
|
966
|
+
}
|
|
967
|
+
function Qt(e, t, n) {
|
|
968
|
+
if (t) {
|
|
969
|
+
if (t.ORDER !== e) throw Error("Field.ORDER must match order: Fp == p, Fn == n");
|
|
970
|
+
return Et(t), t;
|
|
971
|
+
} else return Mt(e, { isLE: n });
|
|
972
|
+
}
|
|
973
|
+
function $t(e, t, n = {}, r) {
|
|
974
|
+
if (r === void 0 && (r = e === "edwards"), !t || typeof t != "object") throw Error(`expected valid ${e} CURVE object`);
|
|
975
|
+
for (let e of [
|
|
976
|
+
"p",
|
|
977
|
+
"n",
|
|
978
|
+
"h"
|
|
979
|
+
]) {
|
|
980
|
+
let n = t[e];
|
|
981
|
+
if (!(typeof n == "bigint" && n > Lt)) throw Error(`CURVE.${e} must be positive bigint`);
|
|
982
|
+
}
|
|
983
|
+
let i = Qt(t.p, n.Fp, r), a = Qt(t.n, n.Fn, r), o = [
|
|
984
|
+
"Gx",
|
|
985
|
+
"Gy",
|
|
986
|
+
"a",
|
|
987
|
+
e === "weierstrass" ? "b" : "d"
|
|
988
|
+
];
|
|
989
|
+
for (let e of o) if (!i.isValid(t[e])) throw Error(`CURVE.${e} must be valid field element of CURVE.Fp`);
|
|
990
|
+
return t = Object.freeze(Object.assign({}, t)), {
|
|
991
|
+
CURVE: t,
|
|
992
|
+
Fp: i,
|
|
993
|
+
Fn: a
|
|
994
|
+
};
|
|
995
|
+
}
|
|
996
|
+
function en(e, t) {
|
|
997
|
+
return function(n) {
|
|
998
|
+
let r = e(n);
|
|
999
|
+
return {
|
|
1000
|
+
secretKey: r,
|
|
1001
|
+
publicKey: t(r)
|
|
1002
|
+
};
|
|
1003
|
+
};
|
|
1004
|
+
}
|
|
1005
|
+
//#endregion
|
|
1006
|
+
//#region node_modules/.pnpm/@noble+curves@2.0.1/node_modules/@noble/curves/abstract/edwards.js
|
|
1007
|
+
var G = BigInt(0), K = BigInt(1), tn = BigInt(2), nn = BigInt(8);
|
|
1008
|
+
function rn(e, t, n, r) {
|
|
1009
|
+
let i = e.sqr(n), a = e.sqr(r), o = e.add(e.mul(t.a, i), a), s = e.add(e.ONE, e.mul(t.d, e.mul(i, a)));
|
|
1010
|
+
return e.eql(o, s);
|
|
1011
|
+
}
|
|
1012
|
+
function an(e, t = {}) {
|
|
1013
|
+
let n = $t("edwards", e, t, t.FpFnLE), { Fp: r, Fn: i } = n, a = n.CURVE, { h: o } = a;
|
|
1014
|
+
ct(t, {}, { uvRatio: "function" });
|
|
1015
|
+
let s = tn << BigInt(i.BYTES * 8) - K, c = (e) => r.create(e), l = t.uvRatio || ((e, t) => {
|
|
1016
|
+
try {
|
|
1017
|
+
return {
|
|
1018
|
+
isValid: !0,
|
|
1019
|
+
value: r.sqrt(r.div(e, t))
|
|
1020
|
+
};
|
|
1021
|
+
} catch {
|
|
1022
|
+
return {
|
|
1023
|
+
isValid: !1,
|
|
1024
|
+
value: G
|
|
1025
|
+
};
|
|
1026
|
+
}
|
|
1027
|
+
});
|
|
1028
|
+
if (!rn(r, a, a.Gx, a.Gy)) throw Error("bad curve params: generator point");
|
|
1029
|
+
function u(e, t, n = !1) {
|
|
1030
|
+
let r = n ? K : G;
|
|
1031
|
+
return at("coordinate " + e, t, r, s), t;
|
|
1032
|
+
}
|
|
1033
|
+
function d(e) {
|
|
1034
|
+
if (!(e instanceof m)) throw Error("EdwardsPoint expected");
|
|
1035
|
+
}
|
|
1036
|
+
let f = ut((e, t) => {
|
|
1037
|
+
let { X: n, Y: i, Z: a } = e, o = e.is0();
|
|
1038
|
+
t ??= o ? nn : r.inv(a);
|
|
1039
|
+
let s = c(n * t), l = c(i * t), u = r.mul(a, t);
|
|
1040
|
+
if (o) return {
|
|
1041
|
+
x: G,
|
|
1042
|
+
y: K
|
|
1043
|
+
};
|
|
1044
|
+
if (u !== K) throw Error("invZ was invalid");
|
|
1045
|
+
return {
|
|
1046
|
+
x: s,
|
|
1047
|
+
y: l
|
|
1048
|
+
};
|
|
1049
|
+
}), p = ut((e) => {
|
|
1050
|
+
let { a: t, d: n } = a;
|
|
1051
|
+
if (e.is0()) throw Error("bad point: ZERO");
|
|
1052
|
+
let { X: r, Y: i, Z: o, T: s } = e, l = c(r * r), u = c(i * i), d = c(o * o), f = c(d * d);
|
|
1053
|
+
if (c(d * c(c(l * t) + u)) !== c(f + c(n * c(l * u)))) throw Error("bad point: equation left != right (1)");
|
|
1054
|
+
if (c(r * i) !== c(o * s)) throw Error("bad point: equation left != right (2)");
|
|
1055
|
+
return !0;
|
|
1056
|
+
});
|
|
1057
|
+
class m {
|
|
1058
|
+
static BASE = new m(a.Gx, a.Gy, K, c(a.Gx * a.Gy));
|
|
1059
|
+
static ZERO = new m(G, K, K, G);
|
|
1060
|
+
static Fp = r;
|
|
1061
|
+
static Fn = i;
|
|
1062
|
+
X;
|
|
1063
|
+
Y;
|
|
1064
|
+
Z;
|
|
1065
|
+
T;
|
|
1066
|
+
constructor(e, t, n, r) {
|
|
1067
|
+
this.X = u("x", e), this.Y = u("y", t), this.Z = u("z", n, !0), this.T = u("t", r), Object.freeze(this);
|
|
1068
|
+
}
|
|
1069
|
+
static CURVE() {
|
|
1070
|
+
return a;
|
|
1071
|
+
}
|
|
1072
|
+
static fromAffine(e) {
|
|
1073
|
+
if (e instanceof m) throw Error("extended point not allowed");
|
|
1074
|
+
let { x: t, y: n } = e || {};
|
|
1075
|
+
return u("x", t), u("y", n), new m(t, n, K, c(t * n));
|
|
1076
|
+
}
|
|
1077
|
+
static fromBytes(e, t = !1) {
|
|
1078
|
+
let n = r.BYTES, { a: i, d: o } = a;
|
|
1079
|
+
e = nt(E(e, n, "point")), Ye(t, "zip215");
|
|
1080
|
+
let u = nt(e), d = e[n - 1];
|
|
1081
|
+
u[n - 1] = d & -129;
|
|
1082
|
+
let f = L(u);
|
|
1083
|
+
at("point.y", f, G, t ? s : r.ORDER);
|
|
1084
|
+
let p = c(f * f), { isValid: h, value: g } = l(c(p - K), c(o * p - i));
|
|
1085
|
+
if (!h) throw Error("bad point: invalid y coordinate");
|
|
1086
|
+
let _ = (g & K) === K, v = (d & 128) != 0;
|
|
1087
|
+
if (!t && g === G && v) throw Error("bad point: x=0 and x_0=1");
|
|
1088
|
+
return v !== _ && (g = c(-g)), m.fromAffine({
|
|
1089
|
+
x: g,
|
|
1090
|
+
y: f
|
|
1091
|
+
});
|
|
1092
|
+
}
|
|
1093
|
+
static fromHex(e, t = !1) {
|
|
1094
|
+
return m.fromBytes(Ce(e), t);
|
|
1095
|
+
}
|
|
1096
|
+
get x() {
|
|
1097
|
+
return this.toAffine().x;
|
|
1098
|
+
}
|
|
1099
|
+
get y() {
|
|
1100
|
+
return this.toAffine().y;
|
|
1101
|
+
}
|
|
1102
|
+
precompute(e = 8, t = !0) {
|
|
1103
|
+
return h.createCache(this, e), t || this.multiply(tn), this;
|
|
1104
|
+
}
|
|
1105
|
+
assertValidity() {
|
|
1106
|
+
p(this);
|
|
1107
|
+
}
|
|
1108
|
+
equals(e) {
|
|
1109
|
+
d(e);
|
|
1110
|
+
let { X: t, Y: n, Z: r } = this, { X: i, Y: a, Z: o } = e, s = c(t * o), l = c(i * r), u = c(n * o), f = c(a * r);
|
|
1111
|
+
return s === l && u === f;
|
|
1112
|
+
}
|
|
1113
|
+
is0() {
|
|
1114
|
+
return this.equals(m.ZERO);
|
|
1115
|
+
}
|
|
1116
|
+
negate() {
|
|
1117
|
+
return new m(c(-this.X), this.Y, this.Z, c(-this.T));
|
|
1118
|
+
}
|
|
1119
|
+
double() {
|
|
1120
|
+
let { a: e } = a, { X: t, Y: n, Z: r } = this, i = c(t * t), o = c(n * n), s = c(tn * c(r * r)), l = c(e * i), u = t + n, d = c(c(u * u) - i - o), f = l + o, p = f - s, h = l - o, g = c(d * p), _ = c(f * h), v = c(d * h);
|
|
1121
|
+
return new m(g, _, c(p * f), v);
|
|
1122
|
+
}
|
|
1123
|
+
add(e) {
|
|
1124
|
+
d(e);
|
|
1125
|
+
let { a: t, d: n } = a, { X: r, Y: i, Z: o, T: s } = this, { X: l, Y: u, Z: f, T: p } = e, h = c(r * l), g = c(i * u), _ = c(s * n * p), v = c(o * f), y = c((r + i) * (l + u) - h - g), b = v - _, x = v + _, S = c(g - t * h), C = c(y * b), w = c(x * S), ee = c(y * S);
|
|
1126
|
+
return new m(C, w, c(b * x), ee);
|
|
1127
|
+
}
|
|
1128
|
+
subtract(e) {
|
|
1129
|
+
return this.add(e.negate());
|
|
1130
|
+
}
|
|
1131
|
+
multiply(e) {
|
|
1132
|
+
if (!i.isValidNot0(e)) throw Error("invalid scalar: expected 1 <= sc < curve.n");
|
|
1133
|
+
let { p: t, f: n } = h.cached(this, e, (e) => Bt(m, e));
|
|
1134
|
+
return Bt(m, [t, n])[0];
|
|
1135
|
+
}
|
|
1136
|
+
multiplyUnsafe(e, t = m.ZERO) {
|
|
1137
|
+
if (!i.isValid(e)) throw Error("invalid scalar: expected 0 <= sc < curve.n");
|
|
1138
|
+
return e === G ? m.ZERO : this.is0() || e === K ? this : h.unsafe(this, e, (e) => Bt(m, e), t);
|
|
1139
|
+
}
|
|
1140
|
+
isSmallOrder() {
|
|
1141
|
+
return this.multiplyUnsafe(o).is0();
|
|
1142
|
+
}
|
|
1143
|
+
isTorsionFree() {
|
|
1144
|
+
return h.unsafe(this, a.n).is0();
|
|
1145
|
+
}
|
|
1146
|
+
toAffine(e) {
|
|
1147
|
+
return f(this, e);
|
|
1148
|
+
}
|
|
1149
|
+
clearCofactor() {
|
|
1150
|
+
return o === K ? this : this.multiplyUnsafe(o);
|
|
1151
|
+
}
|
|
1152
|
+
toBytes() {
|
|
1153
|
+
let { x: e, y: t } = this.toAffine(), n = r.toBytes(t);
|
|
1154
|
+
return n[n.length - 1] |= e & K ? 128 : 0, n;
|
|
1155
|
+
}
|
|
1156
|
+
toHex() {
|
|
1157
|
+
return xe(this.toBytes());
|
|
1158
|
+
}
|
|
1159
|
+
toString() {
|
|
1160
|
+
return `<Point ${this.is0() ? "ZERO" : this.toHex()}>`;
|
|
1161
|
+
}
|
|
1162
|
+
}
|
|
1163
|
+
let h = new Xt(m, i.BITS);
|
|
1164
|
+
return m.BASE.precompute(8), m;
|
|
1165
|
+
}
|
|
1166
|
+
var on = class {
|
|
1167
|
+
static BASE;
|
|
1168
|
+
static ZERO;
|
|
1169
|
+
static Fp;
|
|
1170
|
+
static Fn;
|
|
1171
|
+
ep;
|
|
1172
|
+
constructor(e) {
|
|
1173
|
+
this.ep = e;
|
|
1174
|
+
}
|
|
1175
|
+
static fromBytes(e) {
|
|
1176
|
+
lt();
|
|
1177
|
+
}
|
|
1178
|
+
static fromHex(e) {
|
|
1179
|
+
lt();
|
|
1180
|
+
}
|
|
1181
|
+
get x() {
|
|
1182
|
+
return this.toAffine().x;
|
|
1183
|
+
}
|
|
1184
|
+
get y() {
|
|
1185
|
+
return this.toAffine().y;
|
|
1186
|
+
}
|
|
1187
|
+
clearCofactor() {
|
|
1188
|
+
return this;
|
|
1189
|
+
}
|
|
1190
|
+
assertValidity() {
|
|
1191
|
+
this.ep.assertValidity();
|
|
1192
|
+
}
|
|
1193
|
+
toAffine(e) {
|
|
1194
|
+
return this.ep.toAffine(e);
|
|
1195
|
+
}
|
|
1196
|
+
toHex() {
|
|
1197
|
+
return xe(this.toBytes());
|
|
1198
|
+
}
|
|
1199
|
+
toString() {
|
|
1200
|
+
return this.toHex();
|
|
1201
|
+
}
|
|
1202
|
+
isTorsionFree() {
|
|
1203
|
+
return !0;
|
|
1204
|
+
}
|
|
1205
|
+
isSmallOrder() {
|
|
1206
|
+
return !1;
|
|
1207
|
+
}
|
|
1208
|
+
add(e) {
|
|
1209
|
+
return this.assertSame(e), this.init(this.ep.add(e.ep));
|
|
1210
|
+
}
|
|
1211
|
+
subtract(e) {
|
|
1212
|
+
return this.assertSame(e), this.init(this.ep.subtract(e.ep));
|
|
1213
|
+
}
|
|
1214
|
+
multiply(e) {
|
|
1215
|
+
return this.init(this.ep.multiply(e));
|
|
1216
|
+
}
|
|
1217
|
+
multiplyUnsafe(e) {
|
|
1218
|
+
return this.init(this.ep.multiplyUnsafe(e));
|
|
1219
|
+
}
|
|
1220
|
+
double() {
|
|
1221
|
+
return this.init(this.ep.double());
|
|
1222
|
+
}
|
|
1223
|
+
negate() {
|
|
1224
|
+
return this.init(this.ep.negate());
|
|
1225
|
+
}
|
|
1226
|
+
precompute(e, t) {
|
|
1227
|
+
return this.init(this.ep.precompute(e, t));
|
|
1228
|
+
}
|
|
1229
|
+
};
|
|
1230
|
+
function sn(e, t, n = {}) {
|
|
1231
|
+
if (typeof t != "function") throw Error("\"hash\" function param is required");
|
|
1232
|
+
ct(n, {}, {
|
|
1233
|
+
adjustScalarBytes: "function",
|
|
1234
|
+
randomBytes: "function",
|
|
1235
|
+
domain: "function",
|
|
1236
|
+
prehash: "function",
|
|
1237
|
+
mapToCurve: "function"
|
|
1238
|
+
});
|
|
1239
|
+
let { prehash: r } = n, { BASE: i, Fp: a, Fn: o } = e, s = n.randomBytes || k, c = n.adjustScalarBytes || ((e) => e), l = n.domain || ((e, t, n) => {
|
|
1240
|
+
if (Ye(n, "phflag"), t.length || n) throw Error("Contexts/pre-hash are not supported");
|
|
1241
|
+
return e;
|
|
1242
|
+
});
|
|
1243
|
+
function u(e) {
|
|
1244
|
+
return o.create(L(e));
|
|
1245
|
+
}
|
|
1246
|
+
function d(e) {
|
|
1247
|
+
let n = y.secretKey;
|
|
1248
|
+
E(e, y.secretKey, "secretKey");
|
|
1249
|
+
let r = E(t(e), 2 * n, "hashedSecretKey"), i = c(r.slice(0, n));
|
|
1250
|
+
return {
|
|
1251
|
+
head: i,
|
|
1252
|
+
prefix: r.slice(n, 2 * n),
|
|
1253
|
+
scalar: u(i)
|
|
1254
|
+
};
|
|
1255
|
+
}
|
|
1256
|
+
function f(e) {
|
|
1257
|
+
let { head: t, prefix: n, scalar: r } = d(e), a = i.multiply(r);
|
|
1258
|
+
return {
|
|
1259
|
+
head: t,
|
|
1260
|
+
prefix: n,
|
|
1261
|
+
scalar: r,
|
|
1262
|
+
point: a,
|
|
1263
|
+
pointBytes: a.toBytes()
|
|
1264
|
+
};
|
|
1265
|
+
}
|
|
1266
|
+
function p(e) {
|
|
1267
|
+
return f(e).pointBytes;
|
|
1268
|
+
}
|
|
1269
|
+
function m(e = Uint8Array.of(), ...n) {
|
|
1270
|
+
return u(t(l(O(...n), E(e, void 0, "context"), !!r)));
|
|
1271
|
+
}
|
|
1272
|
+
function h(e, t, n = {}) {
|
|
1273
|
+
e = E(e, void 0, "message"), r && (e = r(e));
|
|
1274
|
+
let { prefix: a, scalar: s, pointBytes: c } = f(t), l = m(n.context, a, e), u = i.multiply(l).toBytes(), d = m(n.context, u, c, e), p = o.create(l + d * s);
|
|
1275
|
+
if (!o.isValid(p)) throw Error("sign failed: invalid s");
|
|
1276
|
+
return E(O(u, o.toBytes(p)), y.signature, "result");
|
|
1277
|
+
}
|
|
1278
|
+
let g = { zip215: !0 };
|
|
1279
|
+
function _(t, n, a, o = g) {
|
|
1280
|
+
let { context: s, zip215: c } = o, l = y.signature;
|
|
1281
|
+
t = E(t, l, "signature"), n = E(n, void 0, "message"), a = E(a, y.publicKey, "publicKey"), c !== void 0 && Ye(c, "zip215"), r && (n = r(n));
|
|
1282
|
+
let u = l / 2, d = t.subarray(0, u), f = L(t.subarray(u, l)), p, h, _;
|
|
1283
|
+
try {
|
|
1284
|
+
p = e.fromBytes(a, c), h = e.fromBytes(d, c), _ = i.multiplyUnsafe(f);
|
|
1285
|
+
} catch {
|
|
1286
|
+
return !1;
|
|
1287
|
+
}
|
|
1288
|
+
if (!c && p.isSmallOrder()) return !1;
|
|
1289
|
+
let v = m(s, h.toBytes(), p.toBytes(), n);
|
|
1290
|
+
return h.add(p.multiplyUnsafe(v)).subtract(_).clearCofactor().is0();
|
|
1291
|
+
}
|
|
1292
|
+
let v = a.BYTES, y = {
|
|
1293
|
+
secretKey: v,
|
|
1294
|
+
publicKey: v,
|
|
1295
|
+
signature: 2 * v,
|
|
1296
|
+
seed: v
|
|
1297
|
+
};
|
|
1298
|
+
function b(e = s(y.seed)) {
|
|
1299
|
+
return E(e, y.seed, "seed");
|
|
1300
|
+
}
|
|
1301
|
+
function x(e) {
|
|
1302
|
+
return pe(e) && e.length === o.BYTES;
|
|
1303
|
+
}
|
|
1304
|
+
function S(t, n) {
|
|
1305
|
+
try {
|
|
1306
|
+
return !!e.fromBytes(t, n);
|
|
1307
|
+
} catch {
|
|
1308
|
+
return !1;
|
|
1309
|
+
}
|
|
1310
|
+
}
|
|
1311
|
+
let C = {
|
|
1312
|
+
getExtendedPublicKey: f,
|
|
1313
|
+
randomSecretKey: b,
|
|
1314
|
+
isValidSecretKey: x,
|
|
1315
|
+
isValidPublicKey: S,
|
|
1316
|
+
toMontgomery(t) {
|
|
1317
|
+
let { y: n } = e.fromBytes(t), r = y.publicKey, i = r === 32;
|
|
1318
|
+
if (!i && r !== 57) throw Error("only defined for 25519 and 448");
|
|
1319
|
+
let o = i ? a.div(K + n, K - n) : a.div(n - K, n + K);
|
|
1320
|
+
return a.toBytes(o);
|
|
1321
|
+
},
|
|
1322
|
+
toMontgomerySecret(e) {
|
|
1323
|
+
let n = y.secretKey;
|
|
1324
|
+
return E(e, n), c(t(e.subarray(0, n))).subarray(0, n);
|
|
1325
|
+
}
|
|
1326
|
+
};
|
|
1327
|
+
return Object.freeze({
|
|
1328
|
+
keygen: en(b, p),
|
|
1329
|
+
getPublicKey: p,
|
|
1330
|
+
sign: h,
|
|
1331
|
+
verify: _,
|
|
1332
|
+
utils: C,
|
|
1333
|
+
Point: e,
|
|
1334
|
+
lengths: y
|
|
1335
|
+
});
|
|
1336
|
+
}
|
|
1337
|
+
//#endregion
|
|
1338
|
+
//#region node_modules/.pnpm/@noble+curves@2.0.1/node_modules/@noble/curves/abstract/hash-to-curve.js
|
|
1339
|
+
var cn = Qe;
|
|
1340
|
+
function q(e, t) {
|
|
1341
|
+
if (I(e), I(t), e < 0 || e >= 1 << 8 * t) throw Error("invalid I2OSP input: " + e);
|
|
1342
|
+
let n = Array.from({ length: t }).fill(0);
|
|
1343
|
+
for (let r = t - 1; r >= 0; r--) n[r] = e & 255, e >>>= 8;
|
|
1344
|
+
return new Uint8Array(n);
|
|
1345
|
+
}
|
|
1346
|
+
function ln(e, t) {
|
|
1347
|
+
let n = new Uint8Array(e.length);
|
|
1348
|
+
for (let r = 0; r < e.length; r++) n[r] = e[r] ^ t[r];
|
|
1349
|
+
return n;
|
|
1350
|
+
}
|
|
1351
|
+
function un(e) {
|
|
1352
|
+
if (!pe(e) && typeof e != "string") throw Error("DST must be Uint8Array or ascii string");
|
|
1353
|
+
return typeof e == "string" ? R(e) : e;
|
|
1354
|
+
}
|
|
1355
|
+
function dn(e, t, n, r) {
|
|
1356
|
+
E(e), I(n), t = un(t), t.length > 255 && (t = r(O(R("H2C-OVERSIZE-DST-"), t)));
|
|
1357
|
+
let { outputLen: i, blockLen: a } = r, o = Math.ceil(n / i);
|
|
1358
|
+
if (n > 65535 || o > 255) throw Error("expand_message_xmd: invalid lenInBytes");
|
|
1359
|
+
let s = O(t, q(t.length, 1)), c = q(0, a), l = q(n, 2), u = Array(o), d = r(O(c, e, l, q(0, 1), s));
|
|
1360
|
+
u[0] = r(O(d, q(1, 1), s));
|
|
1361
|
+
for (let e = 1; e <= o; e++) u[e] = r(O(ln(d, u[e - 1]), q(e + 1, 1), s));
|
|
1362
|
+
return O(...u).slice(0, n);
|
|
1363
|
+
}
|
|
1364
|
+
function fn(e, t, n, r, i) {
|
|
1365
|
+
if (E(e), I(n), t = un(t), t.length > 255) {
|
|
1366
|
+
let e = Math.ceil(2 * r / 8);
|
|
1367
|
+
t = i.create({ dkLen: e }).update(R("H2C-OVERSIZE-DST-")).update(t).digest();
|
|
1368
|
+
}
|
|
1369
|
+
if (n > 65535 || t.length > 255) throw Error("expand_message_xof: invalid lenInBytes");
|
|
1370
|
+
return i.create({ dkLen: n }).update(e).update(q(n, 2)).update(t).update(q(t.length, 1)).digest();
|
|
1371
|
+
}
|
|
1372
|
+
function pn(e, t, n) {
|
|
1373
|
+
ct(n, {
|
|
1374
|
+
p: "bigint",
|
|
1375
|
+
m: "number",
|
|
1376
|
+
k: "number",
|
|
1377
|
+
hash: "function"
|
|
1378
|
+
});
|
|
1379
|
+
let { p: r, k: i, m: a, hash: o, expand: s, DST: c } = n;
|
|
1380
|
+
I(o.outputLen, "valid hash"), E(e), I(t);
|
|
1381
|
+
let l = r.toString(2).length, u = Math.ceil((l + i) / 8), d = t * a * u, f;
|
|
1382
|
+
if (s === "xmd") f = dn(e, c, d, o);
|
|
1383
|
+
else if (s === "xof") f = fn(e, c, d, i, o);
|
|
1384
|
+
else if (s === "_internal_pass") f = e;
|
|
1385
|
+
else throw Error("expand must be \"xmd\" or \"xof\"");
|
|
1386
|
+
let p = Array(t);
|
|
1387
|
+
for (let e = 0; e < t; e++) {
|
|
1388
|
+
let t = Array(a);
|
|
1389
|
+
for (let n = 0; n < a; n++) {
|
|
1390
|
+
let i = u * (n + e * a);
|
|
1391
|
+
t[n] = H(cn(f.subarray(i, i + u)), r);
|
|
1392
|
+
}
|
|
1393
|
+
p[e] = t;
|
|
1394
|
+
}
|
|
1395
|
+
return p;
|
|
1396
|
+
}
|
|
1397
|
+
var mn = R("HashToScalar-");
|
|
1398
|
+
function hn(e, t, n) {
|
|
1399
|
+
if (typeof t != "function") throw Error("mapToCurve() must be defined");
|
|
1400
|
+
function r(n) {
|
|
1401
|
+
return e.fromAffine(t(n));
|
|
1402
|
+
}
|
|
1403
|
+
function i(t) {
|
|
1404
|
+
let n = t.clearCofactor();
|
|
1405
|
+
return n.equals(e.ZERO) ? e.ZERO : (n.assertValidity(), n);
|
|
1406
|
+
}
|
|
1407
|
+
return {
|
|
1408
|
+
defaults: Object.freeze(n),
|
|
1409
|
+
Point: e,
|
|
1410
|
+
hashToCurve(e, t) {
|
|
1411
|
+
let a = pn(e, 2, Object.assign({}, n, t)), o = r(a[0]), s = r(a[1]);
|
|
1412
|
+
return i(o.add(s));
|
|
1413
|
+
},
|
|
1414
|
+
encodeToCurve(e, t) {
|
|
1415
|
+
let a = n.encodeDST ? { DST: n.encodeDST } : {};
|
|
1416
|
+
return i(r(pn(e, 1, Object.assign({}, n, a, t))[0]));
|
|
1417
|
+
},
|
|
1418
|
+
mapToCurve(e) {
|
|
1419
|
+
if (n.m === 1) {
|
|
1420
|
+
if (typeof e != "bigint") throw Error("expected bigint (m=1)");
|
|
1421
|
+
return i(r([e]));
|
|
1422
|
+
}
|
|
1423
|
+
if (!Array.isArray(e)) throw Error("expected array of bigints");
|
|
1424
|
+
for (let t of e) if (typeof t != "bigint") throw Error("expected array of bigints");
|
|
1425
|
+
return i(r(e));
|
|
1426
|
+
},
|
|
1427
|
+
hashToScalar(t, r) {
|
|
1428
|
+
let i = e.Fn.ORDER;
|
|
1429
|
+
return pn(t, 1, Object.assign({}, n, {
|
|
1430
|
+
p: i,
|
|
1431
|
+
m: 1,
|
|
1432
|
+
DST: mn
|
|
1433
|
+
}, r))[0][0];
|
|
1434
|
+
}
|
|
1435
|
+
};
|
|
1436
|
+
}
|
|
1437
|
+
//#endregion
|
|
1438
|
+
//#region node_modules/.pnpm/@noble+curves@2.0.1/node_modules/@noble/curves/abstract/oprf.js
|
|
1439
|
+
function gn(e) {
|
|
1440
|
+
ct(e, {
|
|
1441
|
+
name: "string",
|
|
1442
|
+
hash: "function",
|
|
1443
|
+
hashToScalar: "function",
|
|
1444
|
+
hashToGroup: "function"
|
|
1445
|
+
});
|
|
1446
|
+
let { name: t, Point: n, hash: r } = e, { Fn: i } = n, a = (t, n) => e.hashToGroup(t, { DST: O(R("HashToGroup-"), n) }), o = (t, n) => e.hashToScalar(t, { DST: O(mn, n) }), s = (e = k) => {
|
|
1447
|
+
let t = It(e(Ft(i.ORDER)), i.ORDER, i.isLE);
|
|
1448
|
+
return i.isLE ? L(t) : Qe(t);
|
|
1449
|
+
}, c = (e, t) => Zt(n, e, t), l = (e) => O(R("OPRFV1-"), new Uint8Array([e]), R("-" + t)), u = l(0), d = l(1), f = l(2);
|
|
1450
|
+
function p(...e) {
|
|
1451
|
+
let t = [];
|
|
1452
|
+
for (let n of e) typeof n == "number" ? t.push($e(n, 2)) : typeof n == "string" ? t.push(R(n)) : (E(n), t.push($e(n.length, 2), n));
|
|
1453
|
+
return O(...t);
|
|
1454
|
+
}
|
|
1455
|
+
let m = (...e) => r(p(...e, "Finalize"));
|
|
1456
|
+
function h(e, t, n, i) {
|
|
1457
|
+
let a = r(p(e.toBytes(), O(R("Seed-"), i))), s = [];
|
|
1458
|
+
for (let e = 0; e < t.length; e++) {
|
|
1459
|
+
let r = t[e].toBytes(), c = n[e].toBytes(), l = o(p(a, e, r, c, "Composite"), i);
|
|
1460
|
+
s.push(l);
|
|
1461
|
+
}
|
|
1462
|
+
return s;
|
|
1463
|
+
}
|
|
1464
|
+
function g(e, t, n, r) {
|
|
1465
|
+
let i = h(e, t, n, r);
|
|
1466
|
+
return {
|
|
1467
|
+
M: c(t, i),
|
|
1468
|
+
Z: c(n, i)
|
|
1469
|
+
};
|
|
1470
|
+
}
|
|
1471
|
+
function _(e, t, n, r, i) {
|
|
1472
|
+
let a = c(n, h(t, n, r, i));
|
|
1473
|
+
return {
|
|
1474
|
+
M: a,
|
|
1475
|
+
Z: a.multiply(e)
|
|
1476
|
+
};
|
|
1477
|
+
}
|
|
1478
|
+
function v(e, t, n, r, i, a) {
|
|
1479
|
+
let [s, c, l, u, d] = [
|
|
1480
|
+
e,
|
|
1481
|
+
t,
|
|
1482
|
+
n,
|
|
1483
|
+
r,
|
|
1484
|
+
i
|
|
1485
|
+
].map((e) => e.toBytes());
|
|
1486
|
+
return o(p(s, c, l, u, d, "Challenge"), a);
|
|
1487
|
+
}
|
|
1488
|
+
function y(e, t, r, a, o, c) {
|
|
1489
|
+
let { M: l, Z: u } = _(t, r, a, o, e), d = s(c), f = v(r, l, u, n.BASE.multiply(d), l.multiply(d), e);
|
|
1490
|
+
return O(...[f, i.sub(d, i.mul(f, t))].map((e) => i.toBytes(e)));
|
|
1491
|
+
}
|
|
1492
|
+
function b(e, t, r, a, o) {
|
|
1493
|
+
E(o, 2 * i.BYTES);
|
|
1494
|
+
let { M: s, Z: c } = g(t, r, a, e), [l, u] = [o.subarray(0, i.BYTES), o.subarray(i.BYTES)].map((e) => i.fromBytes(e)), d = v(t, s, c, n.BASE.multiply(u).add(t.multiply(l)), s.multiply(u).add(c.multiply(l)), e);
|
|
1495
|
+
if (!i.eql(l, d)) throw Error("proof verification failed");
|
|
1496
|
+
}
|
|
1497
|
+
function x() {
|
|
1498
|
+
let e = s(), t = n.BASE.multiply(e);
|
|
1499
|
+
return {
|
|
1500
|
+
secretKey: i.toBytes(e),
|
|
1501
|
+
publicKey: t.toBytes()
|
|
1502
|
+
};
|
|
1503
|
+
}
|
|
1504
|
+
function S(t, r, a) {
|
|
1505
|
+
let o = O(R("DeriveKeyPair"), t), s = O(r, p(a), Uint8Array.of(0));
|
|
1506
|
+
for (let t = 0; t <= 255; t++) {
|
|
1507
|
+
s[s.length - 1] = t;
|
|
1508
|
+
let r = e.hashToScalar(s, { DST: o });
|
|
1509
|
+
if (!i.is0(r)) return {
|
|
1510
|
+
secretKey: i.toBytes(r),
|
|
1511
|
+
publicKey: n.BASE.multiply(r).toBytes()
|
|
1512
|
+
};
|
|
1513
|
+
}
|
|
1514
|
+
throw Error("Cannot derive key");
|
|
1515
|
+
}
|
|
1516
|
+
function C(e, t, r = k) {
|
|
1517
|
+
let o = s(r), c = a(t, e);
|
|
1518
|
+
if (c.equals(n.ZERO)) throw Error("Input point at infinity");
|
|
1519
|
+
let l = c.multiply(o);
|
|
1520
|
+
return {
|
|
1521
|
+
blind: i.toBytes(o),
|
|
1522
|
+
blinded: l.toBytes()
|
|
1523
|
+
};
|
|
1524
|
+
}
|
|
1525
|
+
function w(e, t, r) {
|
|
1526
|
+
let o = i.fromBytes(t), s = a(r, e);
|
|
1527
|
+
if (s.equals(n.ZERO)) throw Error("Input point at infinity");
|
|
1528
|
+
return m(r, s.multiply(o).toBytes());
|
|
1529
|
+
}
|
|
1530
|
+
let ee = {
|
|
1531
|
+
generateKeyPair: x,
|
|
1532
|
+
deriveKeyPair: (e, t) => S(u, e, t),
|
|
1533
|
+
blind: (e, t = k) => C(u, e, t),
|
|
1534
|
+
blindEvaluate(e, t) {
|
|
1535
|
+
let r = i.fromBytes(e);
|
|
1536
|
+
return n.fromBytes(t).multiply(r).toBytes();
|
|
1537
|
+
},
|
|
1538
|
+
finalize(e, t, r) {
|
|
1539
|
+
let a = i.fromBytes(t);
|
|
1540
|
+
return m(e, n.fromBytes(r).multiply(i.inv(a)).toBytes());
|
|
1541
|
+
},
|
|
1542
|
+
evaluate: (e, t) => w(u, e, t)
|
|
1543
|
+
};
|
|
1544
|
+
return Object.freeze({
|
|
1545
|
+
name: t,
|
|
1546
|
+
oprf: ee,
|
|
1547
|
+
voprf: {
|
|
1548
|
+
generateKeyPair: x,
|
|
1549
|
+
deriveKeyPair: (e, t) => S(d, e, t),
|
|
1550
|
+
blind: (e, t = k) => C(d, e, t),
|
|
1551
|
+
blindEvaluateBatch(e, t, r, a = k) {
|
|
1552
|
+
if (!Array.isArray(r)) throw Error("expected array");
|
|
1553
|
+
let o = i.fromBytes(e), s = n.fromBytes(t), c = r.map(n.fromBytes), l = c.map((e) => e.multiply(o)), u = y(d, o, s, c, l, a);
|
|
1554
|
+
return {
|
|
1555
|
+
evaluated: l.map((e) => e.toBytes()),
|
|
1556
|
+
proof: u
|
|
1557
|
+
};
|
|
1558
|
+
},
|
|
1559
|
+
blindEvaluate(e, t, n, r = k) {
|
|
1560
|
+
let i = this.blindEvaluateBatch(e, t, [n], r);
|
|
1561
|
+
return {
|
|
1562
|
+
evaluated: i.evaluated[0],
|
|
1563
|
+
proof: i.proof
|
|
1564
|
+
};
|
|
1565
|
+
},
|
|
1566
|
+
finalizeBatch(e, t, r) {
|
|
1567
|
+
if (!Array.isArray(e)) throw Error("expected array");
|
|
1568
|
+
return b(d, n.fromBytes(t), e.map((e) => e.blinded).map(n.fromBytes), e.map((e) => e.evaluated).map(n.fromBytes), r), e.map((e) => ee.finalize(e.input, e.blind, e.evaluated));
|
|
1569
|
+
},
|
|
1570
|
+
finalize(e, t, n, r, i, a) {
|
|
1571
|
+
return this.finalizeBatch([{
|
|
1572
|
+
input: e,
|
|
1573
|
+
blind: t,
|
|
1574
|
+
evaluated: n,
|
|
1575
|
+
blinded: r
|
|
1576
|
+
}], i, a)[0];
|
|
1577
|
+
},
|
|
1578
|
+
evaluate: (e, t) => w(d, e, t)
|
|
1579
|
+
},
|
|
1580
|
+
poprf: (e) => {
|
|
1581
|
+
let t = o(p("Info", e), f), r = n.BASE.multiply(t);
|
|
1582
|
+
return {
|
|
1583
|
+
generateKeyPair: x,
|
|
1584
|
+
deriveKeyPair: (e, t) => S(f, e, t),
|
|
1585
|
+
blind(e, t, o = k) {
|
|
1586
|
+
let c = n.fromBytes(t), l = r.add(c);
|
|
1587
|
+
if (l.equals(n.ZERO)) throw Error("tweakedKey point at infinity");
|
|
1588
|
+
let u = s(o), d = a(e, f);
|
|
1589
|
+
if (d.equals(n.ZERO)) throw Error("Input point at infinity");
|
|
1590
|
+
let p = d.multiply(u);
|
|
1591
|
+
return {
|
|
1592
|
+
blind: i.toBytes(u),
|
|
1593
|
+
blinded: p.toBytes(),
|
|
1594
|
+
tweakedKey: l.toBytes()
|
|
1595
|
+
};
|
|
1596
|
+
},
|
|
1597
|
+
blindEvaluateBatch(e, r, a = k) {
|
|
1598
|
+
if (!Array.isArray(r)) throw Error("expected array");
|
|
1599
|
+
let o = i.fromBytes(e), s = i.add(o, t), c = i.inv(s), l = r.map(n.fromBytes), u = l.map((e) => e.multiply(c)), d = y(f, s, n.BASE.multiply(s), u, l, a);
|
|
1600
|
+
return {
|
|
1601
|
+
evaluated: u.map((e) => e.toBytes()),
|
|
1602
|
+
proof: d
|
|
1603
|
+
};
|
|
1604
|
+
},
|
|
1605
|
+
blindEvaluate(e, t, n = k) {
|
|
1606
|
+
let r = this.blindEvaluateBatch(e, [t], n);
|
|
1607
|
+
return {
|
|
1608
|
+
evaluated: r.evaluated[0],
|
|
1609
|
+
proof: r.proof
|
|
1610
|
+
};
|
|
1611
|
+
},
|
|
1612
|
+
finalizeBatch(t, r, a) {
|
|
1613
|
+
if (!Array.isArray(t)) throw Error("expected array");
|
|
1614
|
+
let o = t.map((e) => e.evaluated).map(n.fromBytes);
|
|
1615
|
+
return b(f, n.fromBytes(a), o, t.map((e) => e.blinded).map(n.fromBytes), r), t.map((t, n) => {
|
|
1616
|
+
let r = i.fromBytes(t.blind), a = o[n].multiply(i.inv(r)).toBytes();
|
|
1617
|
+
return m(t.input, e, a);
|
|
1618
|
+
});
|
|
1619
|
+
},
|
|
1620
|
+
finalize(e, t, n, r, i, a) {
|
|
1621
|
+
return this.finalizeBatch([{
|
|
1622
|
+
input: e,
|
|
1623
|
+
blind: t,
|
|
1624
|
+
evaluated: n,
|
|
1625
|
+
blinded: r
|
|
1626
|
+
}], i, a)[0];
|
|
1627
|
+
},
|
|
1628
|
+
evaluate(r, o) {
|
|
1629
|
+
let s = i.fromBytes(r), c = a(o, f);
|
|
1630
|
+
if (c.equals(n.ZERO)) throw Error("Input point at infinity");
|
|
1631
|
+
let l = i.add(s, t), u = i.inv(l);
|
|
1632
|
+
return m(o, e, c.multiply(u).toBytes());
|
|
1633
|
+
}
|
|
1634
|
+
};
|
|
1635
|
+
},
|
|
1636
|
+
__tests: { Fn: i }
|
|
1637
|
+
});
|
|
1638
|
+
}
|
|
1639
|
+
//#endregion
|
|
1640
|
+
//#region node_modules/.pnpm/@noble+curves@2.0.1/node_modules/@noble/curves/ed25519.js
|
|
1641
|
+
var _n = /* @__PURE__ */ BigInt(0), J = BigInt(1), vn = BigInt(2), yn = /* @__PURE__ */ BigInt(3), bn = BigInt(5), xn = BigInt(8), Y = BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"), Sn = {
|
|
1642
|
+
p: Y,
|
|
1643
|
+
n: BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),
|
|
1644
|
+
h: xn,
|
|
1645
|
+
a: BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),
|
|
1646
|
+
d: BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),
|
|
1647
|
+
Gx: BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),
|
|
1648
|
+
Gy: BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")
|
|
1649
|
+
};
|
|
1650
|
+
function Cn(e) {
|
|
1651
|
+
let t = BigInt(10), n = BigInt(20), r = BigInt(40), i = BigInt(80), a = Y, o = e * e % a * e % a, s = U(U(o, vn, a) * o % a, J, a) * e % a, c = U(s, bn, a) * s % a, l = U(c, t, a) * c % a, u = U(l, n, a) * l % a, d = U(u, r, a) * u % a;
|
|
1652
|
+
return {
|
|
1653
|
+
pow_p_5_8: U(U(U(U(d, i, a) * d % a, i, a) * d % a, t, a) * c % a, vn, a) * e % a,
|
|
1654
|
+
b2: o
|
|
1655
|
+
};
|
|
1656
|
+
}
|
|
1657
|
+
function wn(e) {
|
|
1658
|
+
return e[0] &= 248, e[31] &= 127, e[31] |= 64, e;
|
|
1659
|
+
}
|
|
1660
|
+
var Tn = /* @__PURE__ */ BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");
|
|
1661
|
+
function En(e, t) {
|
|
1662
|
+
let n = Y, r = H(t * t * t, n), i = Cn(e * H(r * r * t, n)).pow_p_5_8, a = H(e * r * i, n), o = H(t * a * a, n), s = a, c = H(a * Tn, n), l = o === e, u = o === H(-e, n), d = o === H(-e * Tn, n);
|
|
1663
|
+
return l && (a = s), (u || d) && (a = c), W(a, n) && (a = H(-a, n)), {
|
|
1664
|
+
isValid: l || u,
|
|
1665
|
+
value: a
|
|
1666
|
+
};
|
|
1667
|
+
}
|
|
1668
|
+
var X = /* @__PURE__ */ an(Sn, { uvRatio: En }), Z = X.Fp, Dn = X.Fn;
|
|
1669
|
+
function On(e) {
|
|
1670
|
+
return sn(X, Ke, Object.assign({ adjustScalarBytes: wn }, e));
|
|
1671
|
+
}
|
|
1672
|
+
var Q = /* @__PURE__ */ On({}), kn = (Y + yn) / xn, An = Z.pow(vn, kn), jn = Z.sqrt(Z.neg(Z.ONE));
|
|
1673
|
+
function Mn(e) {
|
|
1674
|
+
let t = (Y - bn) / xn, n = BigInt(486662), r = Z.sqr(e);
|
|
1675
|
+
r = Z.mul(r, vn);
|
|
1676
|
+
let i = Z.add(r, Z.ONE), a = Z.neg(n), o = Z.sqr(i), s = Z.mul(o, i), c = Z.mul(r, n);
|
|
1677
|
+
c = Z.mul(c, a), c = Z.add(c, o), c = Z.mul(c, a);
|
|
1678
|
+
let l = Z.sqr(s);
|
|
1679
|
+
o = Z.sqr(l), l = Z.mul(l, s), l = Z.mul(l, c), o = Z.mul(o, l);
|
|
1680
|
+
let u = Z.pow(o, t);
|
|
1681
|
+
u = Z.mul(u, l);
|
|
1682
|
+
let d = Z.mul(u, jn);
|
|
1683
|
+
o = Z.sqr(u), o = Z.mul(o, s);
|
|
1684
|
+
let f = Z.eql(o, c), p = Z.cmov(d, u, f), m = Z.mul(a, r), h = Z.mul(u, e);
|
|
1685
|
+
h = Z.mul(h, An);
|
|
1686
|
+
let g = Z.mul(h, jn), _ = Z.mul(c, r);
|
|
1687
|
+
o = Z.sqr(h), o = Z.mul(o, s);
|
|
1688
|
+
let v = Z.eql(o, _), y = Z.cmov(g, h, v);
|
|
1689
|
+
o = Z.sqr(p), o = Z.mul(o, s);
|
|
1690
|
+
let b = Z.eql(o, c), x = Z.cmov(m, a, b), S = Z.cmov(y, p, b), C = Z.isOdd(S);
|
|
1691
|
+
return S = Z.cmov(S, Z.neg(S), b !== C), {
|
|
1692
|
+
xMn: x,
|
|
1693
|
+
xMd: i,
|
|
1694
|
+
yMn: S,
|
|
1695
|
+
yMd: J
|
|
1696
|
+
};
|
|
1697
|
+
}
|
|
1698
|
+
var Nn = Nt(Z, Z.neg(BigInt(486664)));
|
|
1699
|
+
function Pn(e) {
|
|
1700
|
+
let { xMn: t, xMd: n, yMn: r, yMd: i } = Mn(e), a = Z.mul(t, i);
|
|
1701
|
+
a = Z.mul(a, Nn);
|
|
1702
|
+
let o = Z.mul(n, r), s = Z.sub(t, n), c = Z.add(t, n), l = Z.mul(o, c), u = Z.eql(l, Z.ZERO);
|
|
1703
|
+
a = Z.cmov(a, Z.ZERO, u), o = Z.cmov(o, Z.ONE, u), s = Z.cmov(s, Z.ONE, u), c = Z.cmov(c, Z.ONE, u);
|
|
1704
|
+
let [d, f] = Ot(Z, [o, c], !0);
|
|
1705
|
+
return {
|
|
1706
|
+
x: Z.mul(a, d),
|
|
1707
|
+
y: Z.mul(s, f)
|
|
1708
|
+
};
|
|
1709
|
+
}
|
|
1710
|
+
hn(X, (e) => Pn(e[0]), {
|
|
1711
|
+
DST: "edwards25519_XMD:SHA-512_ELL2_RO_",
|
|
1712
|
+
encodeDST: "edwards25519_XMD:SHA-512_ELL2_NU_",
|
|
1713
|
+
p: Y,
|
|
1714
|
+
m: 1,
|
|
1715
|
+
k: 128,
|
|
1716
|
+
expand: "xmd",
|
|
1717
|
+
hash: Ke
|
|
1718
|
+
});
|
|
1719
|
+
var Fn = Tn, In = /* @__PURE__ */ BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"), Ln = /* @__PURE__ */ BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"), Rn = /* @__PURE__ */ BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"), zn = /* @__PURE__ */ BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952"), Bn = (e) => En(J, e), Vn = /* @__PURE__ */ BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"), Hn = (e) => Z.create(L(e) & Vn);
|
|
1720
|
+
function Un(e) {
|
|
1721
|
+
let { d: t } = Sn, n = Y, r = (e) => Z.create(e), i = r(Fn * e * e), a = r((i + J) * Rn), o = BigInt(-1), s = r((o - t * i) * r(i + t)), { isValid: c, value: l } = En(a, s), u = r(l * e);
|
|
1722
|
+
W(u, n) || (u = r(-u)), c || (l = u), c || (o = i);
|
|
1723
|
+
let d = r(o * (i - J) * zn - s), f = l * l, p = r((l + l) * s), m = r(d * In), h = r(J - f), g = r(J + f);
|
|
1724
|
+
return new X(r(p * g), r(h * m), r(m * g), r(p * h));
|
|
1725
|
+
}
|
|
1726
|
+
var Wn = class e extends on {
|
|
1727
|
+
static BASE = new e(X.BASE);
|
|
1728
|
+
static ZERO = new e(X.ZERO);
|
|
1729
|
+
static Fp = Z;
|
|
1730
|
+
static Fn = Dn;
|
|
1731
|
+
constructor(e) {
|
|
1732
|
+
super(e);
|
|
1733
|
+
}
|
|
1734
|
+
static fromAffine(t) {
|
|
1735
|
+
return new e(X.fromAffine(t));
|
|
1736
|
+
}
|
|
1737
|
+
assertSame(t) {
|
|
1738
|
+
if (!(t instanceof e)) throw Error("RistrettoPoint expected");
|
|
1739
|
+
}
|
|
1740
|
+
init(t) {
|
|
1741
|
+
return new e(t);
|
|
1742
|
+
}
|
|
1743
|
+
static fromBytes(t) {
|
|
1744
|
+
E(t, 32);
|
|
1745
|
+
let { a: n, d: r } = Sn, i = Y, a = (e) => Z.create(e), o = Hn(t);
|
|
1746
|
+
if (!tt(Z.toBytes(o), t) || W(o, i)) throw Error("invalid ristretto255 encoding 1");
|
|
1747
|
+
let s = a(o * o), c = a(J + n * s), l = a(J - n * s), u = a(c * c), d = a(l * l), f = a(n * r * u - d), { isValid: p, value: m } = Bn(a(f * d)), h = a(m * l), g = a(m * h * f), _ = a((o + o) * h);
|
|
1748
|
+
W(_, i) && (_ = a(-_));
|
|
1749
|
+
let v = a(c * g), y = a(_ * v);
|
|
1750
|
+
if (!p || W(y, i) || v === _n) throw Error("invalid ristretto255 encoding 2");
|
|
1751
|
+
return new e(new X(_, v, J, y));
|
|
1752
|
+
}
|
|
1753
|
+
static fromHex(t) {
|
|
1754
|
+
return e.fromBytes(Ce(t));
|
|
1755
|
+
}
|
|
1756
|
+
toBytes() {
|
|
1757
|
+
let { X: e, Y: t, Z: n, T: r } = this.ep, i = Y, a = (e) => Z.create(e), o = a(a(n + t) * a(n - t)), s = a(e * t), { value: c } = Bn(a(o * a(s * s))), l = a(c * o), u = a(c * s), d = a(l * u * r), f;
|
|
1758
|
+
if (W(r * d, i)) {
|
|
1759
|
+
let n = a(t * Fn), r = a(e * Fn);
|
|
1760
|
+
e = n, t = r, f = a(l * Ln);
|
|
1761
|
+
} else f = u;
|
|
1762
|
+
W(e * d, i) && (t = a(-t));
|
|
1763
|
+
let p = a((n - t) * f);
|
|
1764
|
+
return W(p, i) && (p = a(-p)), Z.toBytes(p);
|
|
1765
|
+
}
|
|
1766
|
+
equals(e) {
|
|
1767
|
+
this.assertSame(e);
|
|
1768
|
+
let { X: t, Y: n } = this.ep, { X: r, Y: i } = e.ep, a = (e) => Z.create(e), o = a(t * i) === a(n * r), s = a(n * i) === a(t * r);
|
|
1769
|
+
return o || s;
|
|
1770
|
+
}
|
|
1771
|
+
is0() {
|
|
1772
|
+
return this.equals(e.ZERO);
|
|
1773
|
+
}
|
|
1774
|
+
}, Gn = {
|
|
1775
|
+
Point: Wn,
|
|
1776
|
+
hashToCurve(e, t) {
|
|
1777
|
+
let n = dn(e, t?.DST || "ristretto255_XMD:SHA-512_R255MAP_RO_", 64, Ke);
|
|
1778
|
+
return Gn.deriveToCurve(n);
|
|
1779
|
+
},
|
|
1780
|
+
hashToScalar(e, t = { DST: mn }) {
|
|
1781
|
+
let n = dn(e, t.DST, 64, Ke);
|
|
1782
|
+
return Dn.create(L(n));
|
|
1783
|
+
},
|
|
1784
|
+
deriveToCurve(e) {
|
|
1785
|
+
E(e, 64);
|
|
1786
|
+
let t = Un(Hn(e.subarray(0, 32))), n = Un(Hn(e.subarray(32, 64)));
|
|
1787
|
+
return new Wn(t.add(n));
|
|
1788
|
+
}
|
|
1789
|
+
};
|
|
1790
|
+
gn({
|
|
1791
|
+
name: "ristretto255-SHA512",
|
|
1792
|
+
Point: Wn,
|
|
1793
|
+
hash: Ke,
|
|
1794
|
+
hashToGroup: Gn.hashToCurve,
|
|
1795
|
+
hashToScalar: Gn.hashToScalar
|
|
1796
|
+
});
|
|
1797
|
+
//#endregion
|
|
1798
|
+
//#region src/crypto/primitives.ts
|
|
1799
|
+
var $ = 32, Kn = 248, qn = 127, Jn = 64, Yn = 128, Xn = 127;
|
|
1800
|
+
function Zn(e) {
|
|
1801
|
+
e.length < $ || (e[0] = (e[0] ?? 0) & Kn, e[$ - 1] = (e[$ - 1] ?? 0) & qn | Jn);
|
|
1802
|
+
}
|
|
1803
|
+
function Qn() {
|
|
1804
|
+
let e = new Uint8Array(s($));
|
|
1805
|
+
Zn(e);
|
|
1806
|
+
let t = nr(e) % Q.Point.CURVE().n;
|
|
1807
|
+
return [Q.Point.BASE.multiply(t).toBytes(), Uint8Array.from(e)];
|
|
1808
|
+
}
|
|
1809
|
+
function $n(e, t) {
|
|
1810
|
+
let n = i("SHA256");
|
|
1811
|
+
return n.update(t), n.sign(e);
|
|
1812
|
+
}
|
|
1813
|
+
function er(e, t, n) {
|
|
1814
|
+
try {
|
|
1815
|
+
let r = a("SHA256");
|
|
1816
|
+
return r.update(t), r.verify(e, Buffer.from(n));
|
|
1817
|
+
} catch {
|
|
1818
|
+
return !1;
|
|
1819
|
+
}
|
|
1820
|
+
}
|
|
1821
|
+
function tr(e, n) {
|
|
1822
|
+
if (e.length !== $ || n.length !== $) throw Error("invalid key length");
|
|
1823
|
+
let r = Uint8Array.from(n);
|
|
1824
|
+
r[$ - 1] = (r[$ - 1] ?? 0) & Xn;
|
|
1825
|
+
let i = nr(r) % Q.Point.CURVE().n, a = Q.Point.fromBytes(e).negate().multiply(i).toBytes();
|
|
1826
|
+
return a[$ - 1] = (a[$ - 1] ?? 0) ^ Yn, t("sha512").update(a).digest();
|
|
1827
|
+
}
|
|
1828
|
+
function nr(e) {
|
|
1829
|
+
let t = 0n;
|
|
1830
|
+
for (let n = e.length - 1; n >= 0; n--) t = t << 8n | BigInt(e[n]);
|
|
1831
|
+
return t;
|
|
1832
|
+
}
|
|
1833
|
+
//#endregion
|
|
1834
|
+
export { c as S, p as _, er as a, _ as b, C as c, S as d, ne as f, f as g, g as h, $n as i, w as l, u as m, Qn as n, Q as o, d as p, tr as r, x as s, Zn as t, ee as u, m as v, l as x, h as y };
|
|
1835
|
+
|
|
1836
|
+
//# sourceMappingURL=primitives-CmIK1O7L.js.map
|