@layerzerolabs/lz-foundation 3.0.15 → 3.0.16

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/dist/index.mjs CHANGED
@@ -1,8 +1,11 @@
1
1
  import { blake2b as blake2b$1 } from '@noble/hashes/blake2b';
2
2
  import { sha256 } from '@noble/hashes/sha256';
3
- import { sha3_256 as sha3_256$1 } from '@noble/hashes/sha3';
3
+ import { keccak_256 as keccak_256$1, sha3_256 as sha3_256$1 } from '@noble/hashes/sha3';
4
4
  import * as ed25519 from '@noble/ed25519';
5
5
  import * as secp256k1 from '@noble/secp256k1';
6
+ import { base58, createBase58check, base64 } from '@scure/base';
7
+ import { arrayify, isHex, hexlify, padify } from '@layerzerolabs/lz-utilities';
8
+ import { chainToChainType, ChainType, Chain } from '@layerzerolabs/lz-definitions';
6
9
 
7
10
  var __defProp = Object.defineProperty;
8
11
  var __export = (target, all) => {
@@ -10,7 +13,7 @@ var __export = (target, all) => {
10
13
  __defProp(target, name, { get: all[name], enumerable: true });
11
14
  };
12
15
  function keccak_256(message) {
13
- return keccak_256();
16
+ return keccak_256$1(message);
14
17
  }
15
18
  function blake2b(message) {
16
19
  return blake2b$1(message);
@@ -121,12 +124,26 @@ var Secp256k1Signer = class _Secp256k1Signer {
121
124
  constructor(privateKey) {
122
125
  this.privateKey = privateKey;
123
126
  }
127
+ /**
128
+ * Creates an instance of Secp256k1Signer from a private key.
129
+ * @param {Uint8Array} privateKey - The private key.
130
+ * @returns {Secp256k1Signer} The created Secp256k1Signer instance.
131
+ */
124
132
  static from(privatekey) {
125
133
  return new _Secp256k1Signer(privatekey);
126
134
  }
135
+ /**
136
+ * Returns the public key of the signer.
137
+ * @returns {Promise<Uint8Array>} A promise that resolves to the public key.
138
+ */
127
139
  async getPublicKey() {
128
140
  return secp256k1_exports.getPublicKey(this.privateKey);
129
141
  }
142
+ /**
143
+ * Signs a hash.
144
+ * @param {Uint8Array} hash - The hash to sign, must be 32 bytes long.
145
+ * @returns {Promise<Uint8Array>} A promise that resolves to the signature.
146
+ */
130
147
  async signHash(hash) {
131
148
  return secp256k1_exports.signHash(hash, this.privateKey);
132
149
  }
@@ -135,17 +152,418 @@ var Ed25519Signer = class _Ed25519Signer {
135
152
  constructor(privateKey) {
136
153
  this.privateKey = privateKey;
137
154
  }
155
+ /**
156
+ * Creates an instance of Ed25519Signer from a private key.
157
+ * @param {Uint8Array} privateKey - The private key.
158
+ * @returns {Ed25519Signer} The created Ed25519Signer instance.
159
+ */
138
160
  static from(privateKey) {
139
161
  return new _Ed25519Signer(privateKey);
140
162
  }
163
+ /**
164
+ * Signs a hash.
165
+ * @param {Uint8Array} hash - The hash to sign, must be 32 bytes long.
166
+ * @returns {Promise<Uint8Array>} A promise that resolves to the signature.
167
+ */
141
168
  async signHash(hash) {
142
169
  return ed25519_exports.signHash(hash, this.privateKey);
143
170
  }
171
+ /**
172
+ * Returns the public key of the signer.
173
+ * @returns {Promise<Uint8Array>} A promise that resolves to the public key.
174
+ */
144
175
  async getPublicKey() {
145
176
  return ed25519_exports.getPublicKey(this.privateKey);
146
177
  }
147
178
  };
148
179
 
149
- export { Ed25519Signer, Secp256k1Signer, SignAlgorithm, blake2b, ed25519_exports as ed25519, keccak_256, secp256k1_exports as secp256k1, sha2_256, sha3_256, signHash3 as signHash };
180
+ // src/base/base58.ts
181
+ var base58_exports = {};
182
+ __export(base58_exports, {
183
+ decode: () => decode,
184
+ encode: () => encode
185
+ });
186
+ function encode(value) {
187
+ if (typeof value === "string") {
188
+ return base58.encode(arrayify(value));
189
+ } else {
190
+ return base58.encode(value);
191
+ }
192
+ }
193
+ function decode(value) {
194
+ return base58.decode(value);
195
+ }
196
+
197
+ // src/base/base58check.ts
198
+ var base58check_exports = {};
199
+ __export(base58check_exports, {
200
+ decode: () => decode2,
201
+ encode: () => encode2
202
+ });
203
+ function encode2(value) {
204
+ const base58check = createBase58check(sha256);
205
+ if (typeof value === "string") {
206
+ return base58check.encode(arrayify(value));
207
+ } else {
208
+ return base58check.encode(value);
209
+ }
210
+ }
211
+ function decode2(value) {
212
+ const base58check = createBase58check(sha256);
213
+ return base58check.decode(value);
214
+ }
215
+
216
+ // src/base/base64.ts
217
+ var base64_exports = {};
218
+ __export(base64_exports, {
219
+ decode: () => decode3,
220
+ encode: () => encode3
221
+ });
222
+ function encode3(value) {
223
+ if (typeof value === "string") {
224
+ return base64.encode(arrayify(value));
225
+ } else {
226
+ return base64.encode(value);
227
+ }
228
+ }
229
+ function decode3(value) {
230
+ return base64.decode(value);
231
+ }
232
+
233
+ // src/address/aptos.ts
234
+ var aptos_exports = {};
235
+ __export(aptos_exports, {
236
+ Address: () => Address
237
+ });
238
+ var Address = class _Address {
239
+ /**
240
+ * Creates an instance of Address.
241
+ * @param {Uint8Array | string} value - The address value.
242
+ * @throws {Error} If the address is invalid.
243
+ */
244
+ constructor(value) {
245
+ let data = void 0;
246
+ if (value instanceof Uint8Array) {
247
+ data = value;
248
+ } else if (typeof value === "string") {
249
+ if (isHex(value)) {
250
+ data = arrayify(value);
251
+ }
252
+ }
253
+ if (data === void 0) {
254
+ throw new Error("Invalid address");
255
+ }
256
+ if (data.length > 32) {
257
+ throw new Error("Invalid address length. Expected less or equal than 32 bytes.");
258
+ }
259
+ this.data = data;
260
+ }
261
+ /**
262
+ * Creates an Address instance from a value.
263
+ * @param {Uint8Array | string} value - The address value.
264
+ * @returns {Address} The Address instance.
265
+ */
266
+ static from(value) {
267
+ return new _Address(value);
268
+ }
269
+ /**
270
+ * Inspects the address.
271
+ * @returns {string} The address as a string.
272
+ */
273
+ inspect() {
274
+ return this.toString();
275
+ }
276
+ /**
277
+ * Converts the address to a string.
278
+ * @returns {string} The address as a string.
279
+ */
280
+ toString() {
281
+ return this.hr();
282
+ }
283
+ /**
284
+ * Gets the raw address data.
285
+ * @returns {Uint8Array} The raw address data.
286
+ */
287
+ raw() {
288
+ return this.data;
289
+ }
290
+ /**
291
+ * Gets the human-readable address.
292
+ * @returns {string} The human-readable address.
293
+ */
294
+ hr() {
295
+ return hexlify(this.data);
296
+ }
297
+ /**
298
+ * Gets the address as a hexadecimal string.
299
+ * @returns {Hex} The address as a hexadecimal string.
300
+ */
301
+ hex() {
302
+ return hexlify(this.data);
303
+ }
304
+ };
305
+
306
+ // src/address/evm.ts
307
+ var evm_exports = {};
308
+ __export(evm_exports, {
309
+ Address: () => Address2,
310
+ toChecksumAddress: () => toChecksumAddress
311
+ });
312
+ var Address2 = class _Address {
313
+ /**
314
+ * Creates an instance of Address.
315
+ * @param {Uint8Array | string} value - The address value.
316
+ * @throws {Error} If the address is invalid.
317
+ */
318
+ constructor(value) {
319
+ let data = void 0;
320
+ if (value instanceof Uint8Array) {
321
+ data = value;
322
+ } else if (typeof value === "string" && isHex(value)) {
323
+ data = arrayify(value);
324
+ }
325
+ if (data === void 0) {
326
+ throw new Error("Invalid address");
327
+ }
328
+ if (data.length > 20) {
329
+ const prefix = data.slice(0, data.length - 20);
330
+ const isAllZero = prefix.every((byte) => byte === 0);
331
+ if (!isAllZero) {
332
+ throw new Error("Invalid address length. Expected less or equal than 20 bytes.");
333
+ }
334
+ }
335
+ this.data = data;
336
+ }
337
+ /**
338
+ * Creates an Address instance from a value.
339
+ * @param {Uint8Array | string} value - The address value.
340
+ * @returns {Address} The Address instance.
341
+ */
342
+ static from(value) {
343
+ return new _Address(value);
344
+ }
345
+ /**
346
+ * Inspects the address.
347
+ * @returns {string} The address as a string.
348
+ */
349
+ inspect() {
350
+ return this.toString();
351
+ }
352
+ /**
353
+ * Converts the address to a string.
354
+ * @returns {string} The address as a string.
355
+ */
356
+ toString() {
357
+ return this.hr();
358
+ }
359
+ /**
360
+ * Gets the raw address data.
361
+ * @returns {Uint8Array} The raw address data.
362
+ */
363
+ raw() {
364
+ return this.data;
365
+ }
366
+ /**
367
+ * Gets the human-readable address.
368
+ * @returns {string} The human-readable address.
369
+ */
370
+ hr() {
371
+ const value = hexlify(padify(this.data, { size: 20 }));
372
+ return toChecksumAddress(value);
373
+ }
374
+ /**
375
+ * Gets the address as a hexadecimal string.
376
+ * @returns {Hex} The address as a hexadecimal string.
377
+ */
378
+ hex() {
379
+ return hexlify(padify(this.data, { size: 20 }));
380
+ }
381
+ };
382
+ function toChecksumAddress(address) {
383
+ const lowercasedAddress = address.toLowerCase().replace("0x", "");
384
+ const hash = Buffer.from(keccak_256(lowercasedAddress)).toString("hex");
385
+ let checksumAddress = "0x";
386
+ for (let i = 0; i < lowercasedAddress.length; i++) {
387
+ if (parseInt(hash[i], 16) > 7) {
388
+ checksumAddress += lowercasedAddress[i].toUpperCase();
389
+ } else {
390
+ checksumAddress += lowercasedAddress[i];
391
+ }
392
+ }
393
+ return checksumAddress;
394
+ }
395
+
396
+ // src/address/solana.ts
397
+ var solana_exports = {};
398
+ __export(solana_exports, {
399
+ Address: () => Address3
400
+ });
401
+ var Address3 = class _Address {
402
+ /**
403
+ * Creates an instance of Address.
404
+ * @param {Uint8Array | string} value - The address value.
405
+ * @throws {Error} If the address is invalid.
406
+ */
407
+ constructor(value) {
408
+ let data = void 0;
409
+ if (value instanceof Uint8Array) {
410
+ data = value;
411
+ } else if (typeof value === "string") {
412
+ if (isHex(value)) {
413
+ data = arrayify(value);
414
+ } else {
415
+ data = base58_exports.decode(value);
416
+ }
417
+ }
418
+ if (data === void 0) {
419
+ throw new Error("Invalid address");
420
+ }
421
+ if (data.length > 32) {
422
+ throw new Error("Invalid address length. Expected less or equal than 32 bytes.");
423
+ }
424
+ this.data = data;
425
+ }
426
+ /**
427
+ * Creates an Address instance from a value.
428
+ * @param {Uint8Array | string} value - The address value.
429
+ * @returns {Address} The Address instance.
430
+ */
431
+ static from(value) {
432
+ return new _Address(value);
433
+ }
434
+ /**
435
+ * Inspects the address.
436
+ * @returns {string} The address as a string.
437
+ */
438
+ inspect() {
439
+ return this.toString();
440
+ }
441
+ /**
442
+ * Converts the address to a string.
443
+ * @returns {string} The address as a string.
444
+ */
445
+ toString() {
446
+ return this.hr();
447
+ }
448
+ /**
449
+ * Gets the raw address data.
450
+ * @returns {Uint8Array} The raw address data.
451
+ */
452
+ raw() {
453
+ return this.data;
454
+ }
455
+ /**
456
+ * Gets the human-readable address.
457
+ * @returns {string} The human-readable address.
458
+ */
459
+ hr() {
460
+ return base58_exports.encode(this.data);
461
+ }
462
+ /**
463
+ * Gets the address as a hexadecimal string.
464
+ * @returns {Hex} The address as a hexadecimal string.
465
+ */
466
+ hex() {
467
+ return hexlify(this.data);
468
+ }
469
+ };
470
+
471
+ // src/address/tron.ts
472
+ var tron_exports = {};
473
+ __export(tron_exports, {
474
+ Address: () => Address4
475
+ });
476
+ var Address4 = class _Address {
477
+ /**
478
+ * Creates an instance of Address.
479
+ * @param {Uint8Array | string} value - The address value.
480
+ * @throws {Error} If the address is invalid.
481
+ */
482
+ constructor(value) {
483
+ let data = void 0;
484
+ if (value instanceof Uint8Array) {
485
+ data = value;
486
+ } else if (typeof value === "string") {
487
+ if (isHex(value)) {
488
+ data = arrayify(value);
489
+ } else {
490
+ data = base58check_exports.decode(value);
491
+ }
492
+ }
493
+ if (data === void 0) {
494
+ throw new Error("Invalid address");
495
+ }
496
+ if (data.length != 21) {
497
+ throw new Error("Invalid address length. Expected 21 bytes.");
498
+ }
499
+ this.data = data;
500
+ }
501
+ /**
502
+ * Creates an Address instance from a value.
503
+ * @param {Uint8Array | string} value - The address value.
504
+ * @returns {Address} The Address instance.
505
+ */
506
+ static from(value) {
507
+ return new _Address(value);
508
+ }
509
+ /**
510
+ * Inspects the address.
511
+ * @returns {string} The address as a string.
512
+ */
513
+ inspect() {
514
+ return this.toString();
515
+ }
516
+ /**
517
+ * Converts the address to a string.
518
+ * @returns {string} The address as a string.
519
+ */
520
+ toString() {
521
+ return this.hr();
522
+ }
523
+ /**
524
+ * Gets the raw address data.
525
+ * @returns {Uint8Array} The raw address data.
526
+ */
527
+ raw() {
528
+ return this.data;
529
+ }
530
+ /**
531
+ * Gets the human-readable address.
532
+ * @returns {string} The human-readable address.
533
+ */
534
+ hr() {
535
+ return base58check_exports.encode(this.data);
536
+ }
537
+ /**
538
+ * Gets the address as a hexadecimal string.
539
+ * @returns {Hex} The address as a hexadecimal string.
540
+ */
541
+ hex() {
542
+ return hexlify(this.data);
543
+ }
544
+ };
545
+ var Address5 = {
546
+ from: (address, chain) => {
547
+ const chainType = chainToChainType(chain);
548
+ switch (chainType) {
549
+ case ChainType.EVM:
550
+ if (chain === Chain.TRON) {
551
+ return Address4.from(address);
552
+ }
553
+ return Address2.from(address);
554
+ case ChainType.APTOS:
555
+ return Address.from(address);
556
+ case ChainType.SOLANA:
557
+ return Address3.from(address);
558
+ default:
559
+ throw new Error(`Unsupported chain type: ${chainType}`);
560
+ }
561
+ }
562
+ };
563
+
564
+ // src/address/address.ts
565
+ var Address6 = Address5;
566
+
567
+ export { Address6 as Address, Ed25519Signer, Secp256k1Signer, SignAlgorithm, aptos_exports as aptos, base58_exports as base58, base58check_exports as base58check, base64_exports as base64, blake2b, ed25519_exports as ed25519, evm_exports as evm, keccak_256, secp256k1_exports as secp256k1, sha2_256, sha3_256, signHash3 as signHash, solana_exports as solana, tron_exports as tron };
150
568
  //# sourceMappingURL=out.js.map
151
569
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/hash/index.ts","../src/sign/constant.ts","../src/sign/ed25519.ts","../src/sign/internal.ts","../src/sign/secp256k1.ts","../src/sign/index.ts","../src/signer.ts"],"names":["SignAlgorithm","getPublicKey","signHash"],"mappings":"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","sourcesContent":["import { blake2b as _blake2b } from '@noble/hashes/blake2b'\nimport { sha256 as _sha256 } from '@noble/hashes/sha256'\nimport { sha3_256 as _sha3_256 } from '@noble/hashes/sha3'\n\nexport function keccak_256(message: Uint8Array | string): Uint8Array {\n return keccak_256(message)\n}\n\nexport function blake2b(message: Uint8Array | string): Uint8Array {\n return _blake2b(message)\n}\n\nexport function sha3_256(message: Uint8Array | string): Uint8Array {\n return _sha3_256(message)\n}\n\nexport function sha2_256(message: Uint8Array | string): Uint8Array {\n return _sha256(message)\n}\n","export enum SignAlgorithm {\n NATIVE,\n SECP256K1,\n ED25519,\n}\n","import * as ed25519 from '@noble/ed25519'\n\nimport { normalizePrivateKey } from './internal'\n\n/**\n * Sign a hash using ed25519\n * @param hash - 32 bytes long\n * @param privateKey - private key in hex format\n * @returns\n */\nexport async function signHash(hash: Uint8Array, privateKey: string | Uint8Array | bigint): Promise<Uint8Array> {\n if (hash.length !== 32) {\n throw new Error('Hash must be 32 bytes long')\n }\n\n privateKey = normalizePrivateKey(privateKey)\n const pubKey = await ed25519.getPublicKey(privateKey)\n const signature = await ed25519.sign(hash, privateKey)\n const isValid = await ed25519.verify(signature, hash, pubKey)\n if (!isValid) {\n throw new Error('Invalid signature')\n }\n\n return signature\n}\n\nexport async function getPublicKey(privateKey: string | Uint8Array | bigint): Promise<Uint8Array> {\n privateKey = normalizePrivateKey(privateKey)\n return ed25519.getPublicKey(privateKey)\n}\n","/**\n * Normalize the private key to a string or Uint8Array\n * - getPublicKey accepts bigint but sign does not, in ed25519\n * - a string privateKey should not have a 0x prefix, in ed25519\n * @param privateKey\n */\nexport function normalizePrivateKey(privateKey: string | Uint8Array | bigint): string | Uint8Array {\n if (typeof privateKey === 'string') {\n return privateKey.replace(/^0x/, '')\n } else if (typeof privateKey === 'bigint') {\n return privateKey.toString(16).padStart(64, '0') // the private key is 32 bytes for ed25519 and secp256k1\n } else {\n return privateKey\n }\n}\n","import * as secp256k1 from '@noble/secp256k1'\n\nimport { normalizePrivateKey } from './internal'\n\n/**\n * Sign a hash using secp256k1\n * @param hash - 32 bytes long\n * @param privateKey - private key in hex format\n * @returns\n */\nexport async function signHash(hash: Uint8Array, privateKey: string | Uint8Array | bigint): Promise<Uint8Array> {\n if (hash.length !== 32) {\n throw new Error('Hash must be 32 bytes long')\n }\n\n privateKey = normalizePrivateKey(privateKey)\n const pubKey = secp256k1.getPublicKey(privateKey, false)\n\n // refer to: https://github.com/paulmillr/noble-secp256k1/tree/1.7.1#signmsghash-privatekey\n const [signature, recoveryId] = await secp256k1.sign(hash, privateKey, {\n // recovered - true indicates the recovered bit should be included in the result\n recovered: true,\n // canonical - true makes signatures compatible with libsecp256k1, false makes signatures compatible with openssl\n canonical: true,\n // der - whether the returned signature should be in DER format. If false, it would be in Compact format (32-byte r + 32-byte s)\n der: false,\n // extraEntropy - When true, it would automatically be filled with 32 bytes of cryptographically secure entropy. Strongly recommended to pass true to improve security:\n extraEntropy: undefined,\n })\n\n const isValid = secp256k1.verify(signature, hash, pubKey, { strict: true })\n if (!isValid) {\n throw new Error('Invalid signature')\n }\n\n return Uint8Array.from([...signature, recoveryId])\n}\n\nexport async function getPublicKey(privateKey: string | Uint8Array | bigint): Promise<Uint8Array> {\n privateKey = normalizePrivateKey(privateKey)\n return Promise.resolve(secp256k1.getPublicKey(privateKey, false))\n}\n","import { SignAlgorithm } from './constant'\nexport * from './keypair'\nexport * from './constant'\nimport * as ed25519 from './ed25519'\nimport * as secp256k1 from './secp256k1'\n\nexport async function signHash(\n hash: Uint8Array,\n privateKey: string | Uint8Array,\n algorithm: SignAlgorithm\n): Promise<Uint8Array> {\n if (hash.length !== 32) {\n throw new Error('Hash must be 32 bytes long')\n }\n\n // privKey should be a hex string without 0x prefix\n // refer to: https://github.com/paulmillr/noble-secp256k1/blob/5ed251242bf065aeb22a54bb42eee1f67e7c77ce/index.ts#L130\n const privKey =\n typeof privateKey === 'string' ? privateKey.replace(/^0x/, '') : Buffer.from(privateKey).toString('hex')\n switch (algorithm) {\n case SignAlgorithm.SECP256K1:\n return secp256k1.signHash(hash, privKey)\n break\n case SignAlgorithm.ED25519:\n return ed25519.signHash(hash, privKey)\n break\n default:\n throw new Error(`Unsupported algorithm: ${algorithm}`)\n }\n}\n\nexport { secp256k1, ed25519 }\n","import { ed25519, secp256k1 } from './sign'\n/**\n * Interface for signing a hash.\n */\nexport interface HashSigner {\n /**\n * signHash signs a hash\n * @param hash - 32 bytes long\n */\n signHash(hash: Uint8Array): Promise<Uint8Array>\n\n /**\n * publicKey returns the public key of the signer\n */\n getPublicKey(): Promise<Uint8Array>\n}\n\nexport class Secp256k1Signer implements HashSigner {\n private constructor(private readonly privateKey: Uint8Array) {}\n\n static from(privatekey: Uint8Array): Secp256k1Signer {\n return new Secp256k1Signer(privatekey)\n }\n\n async getPublicKey(): Promise<Uint8Array> {\n return secp256k1.getPublicKey(this.privateKey)\n }\n\n async signHash(hash: Uint8Array): Promise<Uint8Array> {\n return secp256k1.signHash(hash, this.privateKey)\n }\n}\n\nexport class Ed25519Signer implements HashSigner {\n private constructor(private readonly privateKey: Uint8Array) {}\n\n static from(privateKey: Uint8Array): Ed25519Signer {\n return new Ed25519Signer(privateKey)\n }\n\n async signHash(hash: Uint8Array): Promise<Uint8Array> {\n return ed25519.signHash(hash, this.privateKey)\n }\n\n async getPublicKey(): Promise<Uint8Array> {\n return ed25519.getPublicKey(this.privateKey)\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/hash/index.ts","../src/sign/constant.ts","../src/sign/ed25519.ts","../src/sign/internal.ts","../src/sign/secp256k1.ts","../src/sign/index.ts","../src/signer.ts","../src/base/base58.ts","../src/base/base58check.ts","../src/base/base64.ts","../src/address/aptos.ts","../src/address/evm.ts","../src/address/solana.ts","../src/address/tron.ts","../src/address/utils.ts","../src/address/address.ts"],"names":["SignAlgorithm","getPublicKey","signHash","decode","encode","arrayify","Address","hexlify","isHex"],"mappings":"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","sourcesContent":["import { blake2b as _blake2b } from '@noble/hashes/blake2b'\nimport { sha256 as _sha256 } from '@noble/hashes/sha256'\nimport { keccak_256 as _keccak_256, sha3_256 as _sha3_256 } from '@noble/hashes/sha3'\n\n/**\n * Computes the Keccak-256 hash of the given message.\n * introduction: https://wiki.rugdoc.io/docs/introduction-to-ethereums-keccak-256-algorithm/\n *\n * @param {Uint8Array | string} message - The input message to hash.\n * @returns {Uint8Array} The Keccak-256 hash of the input message.\n */\nexport function keccak_256(message: Uint8Array | string): Uint8Array {\n return _keccak_256(message)\n}\n\n/**\n * Computes the BLAKE2b hash of the given message.\n * introduction: https://en.wikipedia.org/wiki/BLAKE_(hash_function)\n *\n * @param {Uint8Array | string} message - The input message to hash.\n * @returns {Uint8Array} The BLAKE2b hash of the input message.\n */\nexport function blake2b(message: Uint8Array | string): Uint8Array {\n return _blake2b(message)\n}\n\n/**\n * Computes the SHA3-256 hash of the given message.\n *\n * @param {Uint8Array | string} message - The input message to hash.\n * @returns {Uint8Array} The SHA3-256 hash of the input message.\n */\nexport function sha3_256(message: Uint8Array | string): Uint8Array {\n return _sha3_256(message)\n}\n\n/**\n * Computes the SHA-256 hash of the given message.\n *\n * @param {Uint8Array | string} message - The input message to hash.\n * @returns {Uint8Array} The SHA-256 hash of the input message.\n */\nexport function sha2_256(message: Uint8Array | string): Uint8Array {\n return _sha256(message)\n}\n","/**\n * Enum representing different signing algorithms.\n */\nexport enum SignAlgorithm {\n /**\n * Native signing algorithm.\n */\n NATIVE,\n\n /**\n * SECP256K1 signing algorithm.\n * introduction: https://en.bitcoin.it/wiki/Secp256k1\n */\n SECP256K1,\n\n /**\n * ED25519 signing algorithm.\n * introduction: https://ed25519.cr.yp.to/\n */\n ED25519,\n}\n","import * as ed25519 from '@noble/ed25519'\n\nimport { normalizePrivateKey } from './internal'\n\n/**\n * Signs a hash using the ed25519 algorithm.\n *\n * @param {Uint8Array} hash - The hash to sign, must be 32 bytes long.\n * @param {string | Uint8Array | bigint} privateKey - The private key in hex format, Uint8Array, or bigint.\n * @returns {Promise<Uint8Array>} A promise that resolves to the signature.\n * @throws {Error} If the hash is not 32 bytes long or the signature is invalid.\n */\nexport async function signHash(hash: Uint8Array, privateKey: string | Uint8Array | bigint): Promise<Uint8Array> {\n if (hash.length !== 32) {\n throw new Error('Hash must be 32 bytes long')\n }\n\n privateKey = normalizePrivateKey(privateKey)\n const pubKey = await ed25519.getPublicKey(privateKey)\n const signature = await ed25519.sign(hash, privateKey)\n const isValid = await ed25519.verify(signature, hash, pubKey)\n if (!isValid) {\n throw new Error('Invalid signature')\n }\n\n return signature\n}\n\n/**\n * Gets the public key corresponding to the given private key using the ed25519 algorithm.\n *\n * @param {string | Uint8Array | bigint} privateKey - The private key in hex format, Uint8Array, or bigint.\n * @returns {Promise<Uint8Array>} A promise that resolves to the public key.\n */\nexport async function getPublicKey(privateKey: string | Uint8Array | bigint): Promise<Uint8Array> {\n privateKey = normalizePrivateKey(privateKey)\n return ed25519.getPublicKey(privateKey)\n}\n","/**\n * Normalizes the private key to a string or Uint8Array.\n * - `getPublicKey` accepts bigint but `sign` does not, in ed25519.\n * - A string privateKey should not have a 0x prefix, in ed25519.\n *\n * @param {string | Uint8Array | bigint} privateKey - The private key to normalize.\n * @returns {string | Uint8Array} The normalized private key.\n */\nexport function normalizePrivateKey(privateKey: string | Uint8Array | bigint): string | Uint8Array {\n if (typeof privateKey === 'string') {\n return privateKey.replace(/^0x/, '')\n } else if (typeof privateKey === 'bigint') {\n return privateKey.toString(16).padStart(64, '0') // the private key is 32 bytes for ed25519 and secp256k1\n } else {\n return privateKey\n }\n}\n","import * as secp256k1 from '@noble/secp256k1'\n\nimport { normalizePrivateKey } from './internal'\n\n/**\n * Signs a hash using the secp256k1 algorithm.\n *\n * @param {Uint8Array} hash - The hash to sign, must be 32 bytes long.\n * @param {string | Uint8Array | bigint} privateKey - The private key in hex format, Uint8Array, or bigint.\n * @returns {Promise<Uint8Array>} A promise that resolves to the signature.\n * @throws {Error} If the hash is not 32 bytes long or the signature is invalid.\n */\nexport async function signHash(hash: Uint8Array, privateKey: string | Uint8Array | bigint): Promise<Uint8Array> {\n if (hash.length !== 32) {\n throw new Error('Hash must be 32 bytes long')\n }\n\n privateKey = normalizePrivateKey(privateKey)\n const pubKey = secp256k1.getPublicKey(privateKey, false)\n\n // refer to: https://github.com/paulmillr/noble-secp256k1/tree/1.7.1#signmsghash-privatekey\n const [signature, recoveryId] = await secp256k1.sign(hash, privateKey, {\n // recovered - true indicates the recovered bit should be included in the result\n recovered: true,\n // canonical - true makes signatures compatible with libsecp256k1, false makes signatures compatible with openssl\n canonical: true,\n // der - whether the returned signature should be in DER format. If false, it would be in Compact format (32-byte r + 32-byte s)\n der: false,\n // extraEntropy - When true, it would automatically be filled with 32 bytes of cryptographically secure entropy. Strongly recommended to pass true to improve security:\n extraEntropy: undefined,\n })\n\n const isValid = secp256k1.verify(signature, hash, pubKey, { strict: true })\n if (!isValid) {\n throw new Error('Invalid signature')\n }\n\n return Uint8Array.from([...signature, recoveryId])\n}\n\n/**\n * Gets the public key corresponding to the given private key using the secp256k1 algorithm.\n *\n * @param {string | Uint8Array | bigint} privateKey - The private key in hex format, Uint8Array, or bigint.\n * @returns {Promise<Uint8Array>} A promise that resolves to the public key.\n */\nexport async function getPublicKey(privateKey: string | Uint8Array | bigint): Promise<Uint8Array> {\n privateKey = normalizePrivateKey(privateKey)\n return Promise.resolve(secp256k1.getPublicKey(privateKey, false))\n}\n","import { SignAlgorithm } from './constant'\nexport * from './keypair'\nexport * from './constant'\nimport * as ed25519 from './ed25519'\nimport * as secp256k1 from './secp256k1'\n\n/**\n * Signs a hash using the specified signing algorithm.\n *\n * @param {Uint8Array} hash - The hash to sign, must be 32 bytes long.\n * @param {string | Uint8Array} privateKey - The private key in hex format or Uint8Array.\n * @param {SignAlgorithm} algorithm - The signing algorithm to use.\n * @returns {Promise<Uint8Array>} A promise that resolves to the signature.\n * @throws {Error} If the hash is not 32 bytes long or the algorithm is unsupported.\n */\nexport async function signHash(\n hash: Uint8Array,\n privateKey: string | Uint8Array,\n algorithm: SignAlgorithm\n): Promise<Uint8Array> {\n if (hash.length !== 32) {\n throw new Error('Hash must be 32 bytes long')\n }\n\n // privKey should be a hex string without 0x prefix\n // refer to: https://github.com/paulmillr/noble-secp256k1/blob/5ed251242bf065aeb22a54bb42eee1f67e7c77ce/index.ts#L130\n const privKey =\n typeof privateKey === 'string' ? privateKey.replace(/^0x/, '') : Buffer.from(privateKey).toString('hex')\n switch (algorithm) {\n case SignAlgorithm.SECP256K1:\n return secp256k1.signHash(hash, privKey)\n break\n case SignAlgorithm.ED25519:\n return ed25519.signHash(hash, privKey)\n break\n default:\n throw new Error(`Unsupported algorithm: ${algorithm}`)\n }\n}\n\nexport { secp256k1, ed25519 }\n","import { ed25519, secp256k1 } from './sign'\n/**\n * Interface for signing a hash.\n */\nexport interface HashSigner {\n /**\n * Signs a hash.\n * @param {Uint8Array} hash - The hash to sign, must be 32 bytes long.\n * @returns {Promise<Uint8Array>} A promise that resolves to the signature.\n */\n signHash(hash: Uint8Array): Promise<Uint8Array>\n\n /**\n * Returns the public key of the signer.\n * @returns {Promise<Uint8Array>} A promise that resolves to the public key.\n */\n getPublicKey(): Promise<Uint8Array>\n}\n\n/**\n * Class for signing hashes using the secp256k1 algorithm.\n */\nexport class Secp256k1Signer implements HashSigner {\n private constructor(private readonly privateKey: Uint8Array) {}\n\n /**\n * Creates an instance of Secp256k1Signer from a private key.\n * @param {Uint8Array} privateKey - The private key.\n * @returns {Secp256k1Signer} The created Secp256k1Signer instance.\n */\n static from(privatekey: Uint8Array): Secp256k1Signer {\n return new Secp256k1Signer(privatekey)\n }\n\n /**\n * Returns the public key of the signer.\n * @returns {Promise<Uint8Array>} A promise that resolves to the public key.\n */\n async getPublicKey(): Promise<Uint8Array> {\n return secp256k1.getPublicKey(this.privateKey)\n }\n\n /**\n * Signs a hash.\n * @param {Uint8Array} hash - The hash to sign, must be 32 bytes long.\n * @returns {Promise<Uint8Array>} A promise that resolves to the signature.\n */\n async signHash(hash: Uint8Array): Promise<Uint8Array> {\n return secp256k1.signHash(hash, this.privateKey)\n }\n}\n\n/**\n * Class for signing hashes using the ed25519 algorithm.\n */\nexport class Ed25519Signer implements HashSigner {\n private constructor(private readonly privateKey: Uint8Array) {}\n\n /**\n * Creates an instance of Ed25519Signer from a private key.\n * @param {Uint8Array} privateKey - The private key.\n * @returns {Ed25519Signer} The created Ed25519Signer instance.\n */\n static from(privateKey: Uint8Array): Ed25519Signer {\n return new Ed25519Signer(privateKey)\n }\n\n /**\n * Signs a hash.\n * @param {Uint8Array} hash - The hash to sign, must be 32 bytes long.\n * @returns {Promise<Uint8Array>} A promise that resolves to the signature.\n */\n async signHash(hash: Uint8Array): Promise<Uint8Array> {\n return ed25519.signHash(hash, this.privateKey)\n }\n\n /**\n * Returns the public key of the signer.\n * @returns {Promise<Uint8Array>} A promise that resolves to the public key.\n */\n async getPublicKey(): Promise<Uint8Array> {\n return ed25519.getPublicKey(this.privateKey)\n }\n}\n","import { base58 } from '@scure/base'\n\nimport { arrayify } from '@layerzerolabs/lz-utilities'\n\n/**\n * Encodes a string or Uint8Array to a base58 string.\n *\n * @param {string | Uint8Array} value - The value to encode.\n * @returns {string} The base58 encoded string.\n */\nexport function encode(value: string | Uint8Array): string {\n if (typeof value === 'string') {\n return base58.encode(arrayify(value))\n } else {\n return base58.encode(value)\n }\n}\n\n/**\n * Decodes a base58 string to a Uint8Array.\n *\n * @param {string} value - The base58 string to decode.\n * @returns {Uint8Array} The decoded Uint8Array.\n */\nexport function decode(value: string): Uint8Array {\n return base58.decode(value)\n}\n","import { sha256 } from '@noble/hashes/sha256'\nimport { createBase58check } from '@scure/base'\n\nimport { arrayify } from '@layerzerolabs/lz-utilities'\n\n/**\n * Encodes a string or Uint8Array to a base58check string.\n *\n * @param {string | Uint8Array} value - The value to encode.\n * @returns {string} The base58check encoded string.\n */\nexport function encode(value: string | Uint8Array): string {\n const base58check = createBase58check(sha256)\n if (typeof value === 'string') {\n return base58check.encode(arrayify(value))\n } else {\n return base58check.encode(value)\n }\n}\n\n/**\n * Decodes a base58check string to a Uint8Array.\n *\n * @param {string} value - The base58check string to decode.\n * @returns {Uint8Array} The decoded Uint8Array.\n */\nexport function decode(value: string): Uint8Array {\n const base58check = createBase58check(sha256)\n return base58check.decode(value)\n}\n","import { base64 } from '@scure/base'\n\nimport { arrayify } from '@layerzerolabs/lz-utilities'\n\n/**\n * Encodes a string or Uint8Array to a base64 string.\n *\n * @param {string | Uint8Array} value - The value to encode.\n * @returns {string} The base64 encoded string.\n */\nexport function encode(value: string | Uint8Array): string {\n if (typeof value === 'string') {\n return base64.encode(arrayify(value))\n } else {\n return base64.encode(value)\n }\n}\n\n/**\n * Decodes a base64 string to a Uint8Array.\n *\n * @param {string} value - The base64 string to decode.\n * @returns {Uint8Array} The decoded Uint8Array.\n */\nexport function decode(value: string): Uint8Array {\n return base64.decode(value)\n}\n","import { Hex, arrayify, hexlify, isHex } from '@layerzerolabs/lz-utilities'\n\nimport { Address as AddressInterface } from './address'\n\n/**\n * Represents an Aptos address.\n * @see {@link AddressInterface}\n */\nexport class Address implements AddressInterface {\n /**\n * The raw address data.\n */\n private data: Uint8Array\n\n /**\n * Creates an instance of Address.\n * @param {Uint8Array | string} value - The address value.\n * @throws {Error} If the address is invalid.\n */\n constructor(value: Uint8Array | string) {\n let data: Uint8Array | undefined = undefined\n\n if (value instanceof Uint8Array) {\n data = value\n } else if (typeof value === 'string') {\n if (isHex(value)) {\n data = arrayify(value)\n }\n }\n if (data === undefined) {\n throw new Error('Invalid address')\n }\n\n if (data.length > 32) {\n throw new Error('Invalid address length. Expected less or equal than 32 bytes.')\n }\n\n this.data = data\n }\n\n /**\n * Creates an Address instance from a value.\n * @param {Uint8Array | string} value - The address value.\n * @returns {Address} The Address instance.\n */\n static from(value: Uint8Array | string): Address {\n return new Address(value)\n }\n\n /**\n * Inspects the address.\n * @returns {string} The address as a string.\n */\n inspect(): string {\n return this.toString()\n }\n\n /**\n * Converts the address to a string.\n * @returns {string} The address as a string.\n */\n toString(): string {\n return this.hr()\n }\n\n /**\n * Gets the raw address data.\n * @returns {Uint8Array} The raw address data.\n */\n raw(): Uint8Array {\n return this.data\n }\n\n /**\n * Gets the human-readable address.\n * @returns {string} The human-readable address.\n */\n hr(): string {\n return hexlify(this.data)\n }\n\n /**\n * Gets the address as a hexadecimal string.\n * @returns {Hex} The address as a hexadecimal string.\n */\n hex(): Hex {\n return hexlify(this.data)\n }\n}\n","import { Hex, arrayify, hexlify, isHex, padify } from '@layerzerolabs/lz-utilities'\n\nimport { Address as AddressInterface } from './address'\nimport { keccak_256 } from '../hash'\n\n/**\n * Represents an EVM address.\n * @see {@link AddressInterface}\n */\nexport class Address implements AddressInterface {\n /**\n * The raw address data.\n */\n private data: Uint8Array\n\n /**\n * Creates an instance of Address.\n * @param {Uint8Array | string} value - The address value.\n * @throws {Error} If the address is invalid.\n */\n constructor(value: Uint8Array | string) {\n let data: Uint8Array | undefined = undefined\n if (value instanceof Uint8Array) {\n data = value\n } else if (typeof value === 'string' && isHex(value)) {\n data = arrayify(value)\n }\n\n if (data === undefined) {\n throw new Error('Invalid address')\n }\n\n if (data.length > 20) {\n const prefix = data.slice(0, data.length - 20)\n const isAllZero = prefix.every((byte) => byte === 0)\n if (!isAllZero) {\n throw new Error('Invalid address length. Expected less or equal than 20 bytes.')\n }\n }\n\n this.data = data\n }\n\n /**\n * Creates an Address instance from a value.\n * @param {Uint8Array | string} value - The address value.\n * @returns {Address} The Address instance.\n */\n static from(value: Uint8Array | string): Address {\n return new Address(value)\n }\n\n /**\n * Inspects the address.\n * @returns {string} The address as a string.\n */\n inspect(): string {\n return this.toString()\n }\n\n /**\n * Converts the address to a string.\n * @returns {string} The address as a string.\n */\n toString(): string {\n return this.hr()\n }\n\n /**\n * Gets the raw address data.\n * @returns {Uint8Array} The raw address data.\n */\n raw(): Uint8Array {\n return this.data\n }\n\n /**\n * Gets the human-readable address.\n * @returns {string} The human-readable address.\n */\n hr(): string {\n const value = hexlify(padify(this.data, { size: 20 }))\n return toChecksumAddress(value)\n }\n\n /**\n * Gets the address as a hexadecimal string.\n * @returns {Hex} The address as a hexadecimal string.\n */\n hex(): Hex {\n return hexlify(padify(this.data, { size: 20 }))\n }\n}\n\n/**\n * Converts an address to its checksum format.\n * @param {string} address - The address to convert.\n * @returns {string} The checksummed address.\n */\nexport function toChecksumAddress(address: string): string {\n // https://eips.ethereum.org/EIPS/eip-55\n const lowercasedAddress = address.toLowerCase().replace('0x', '')\n\n const hash = Buffer.from(keccak_256(lowercasedAddress)).toString('hex')\n\n let checksumAddress = '0x'\n for (let i = 0; i < lowercasedAddress.length; i++) {\n if (parseInt(hash[i], 16) > 7) {\n checksumAddress += lowercasedAddress[i].toUpperCase()\n } else {\n checksumAddress += lowercasedAddress[i]\n }\n }\n\n return checksumAddress\n}\n","import { Hex, arrayify, hexlify, isHex } from '@layerzerolabs/lz-utilities'\n\nimport { Address as AddressInterface } from './address'\nimport { base58 } from '../base'\n\n/**\n * Represents a Solana address.\n * @see {@link AddressInterface}\n */\nexport class Address implements AddressInterface {\n /**\n * The raw address data.\n */\n private data: Uint8Array\n\n /**\n * Creates an instance of Address.\n * @param {Uint8Array | string} value - The address value.\n * @throws {Error} If the address is invalid.\n */\n constructor(value: Uint8Array | string) {\n let data: Uint8Array | undefined = undefined\n if (value instanceof Uint8Array) {\n data = value\n } else if (typeof value === 'string') {\n if (isHex(value)) {\n data = arrayify(value)\n } else {\n data = base58.decode(value)\n }\n }\n\n if (data === undefined) {\n throw new Error('Invalid address')\n }\n\n if (data.length > 32) {\n throw new Error('Invalid address length. Expected less or equal than 32 bytes.')\n }\n\n this.data = data\n }\n\n /**\n * Creates an Address instance from a value.\n * @param {Uint8Array | string} value - The address value.\n * @returns {Address} The Address instance.\n */\n static from(value: Uint8Array | string): Address {\n return new Address(value)\n }\n\n /**\n * Inspects the address.\n * @returns {string} The address as a string.\n */\n inspect(): string {\n return this.toString()\n }\n\n /**\n * Converts the address to a string.\n * @returns {string} The address as a string.\n */\n toString(): string {\n return this.hr()\n }\n\n /**\n * Gets the raw address data.\n * @returns {Uint8Array} The raw address data.\n */\n raw(): Uint8Array {\n return this.data\n }\n\n /**\n * Gets the human-readable address.\n * @returns {string} The human-readable address.\n */\n hr(): string {\n return base58.encode(this.data)\n }\n\n /**\n * Gets the address as a hexadecimal string.\n * @returns {Hex} The address as a hexadecimal string.\n */\n hex(): Hex {\n return hexlify(this.data)\n }\n}\n","import { Hex, arrayify, hexlify, isHex } from '@layerzerolabs/lz-utilities'\n\nimport { Address as AddressInterface } from './address'\nimport { base58check } from '../base'\n\n/**\n * Represents a Tron address.\n * @see {@link AddressInterface}\n */\nexport class Address implements AddressInterface {\n /**\n * The raw address data.\n */\n private data: Uint8Array\n\n /**\n * Creates an instance of Address.\n * @param {Uint8Array | string} value - The address value.\n * @throws {Error} If the address is invalid.\n */\n constructor(value: Uint8Array | string) {\n let data: Uint8Array | undefined = undefined\n if (value instanceof Uint8Array) {\n data = value\n } else if (typeof value === 'string') {\n if (isHex(value)) {\n data = arrayify(value)\n } else {\n data = base58check.decode(value)\n }\n }\n\n if (data === undefined) {\n throw new Error('Invalid address')\n }\n\n if (data.length != 21) {\n throw new Error('Invalid address length. Expected 21 bytes.')\n }\n\n this.data = data\n }\n\n /**\n * Creates an Address instance from a value.\n * @param {Uint8Array | string} value - The address value.\n * @returns {Address} The Address instance.\n */\n static from(value: Uint8Array | string): Address {\n return new Address(value)\n }\n\n /**\n * Inspects the address.\n * @returns {string} The address as a string.\n */\n inspect(): string {\n return this.toString()\n }\n\n /**\n * Converts the address to a string.\n * @returns {string} The address as a string.\n */\n toString(): string {\n return this.hr()\n }\n\n /**\n * Gets the raw address data.\n * @returns {Uint8Array} The raw address data.\n */\n raw(): Uint8Array {\n return this.data\n }\n\n /**\n * Gets the human-readable address.\n * @returns {string} The human-readable address.\n */\n hr(): string {\n return base58check.encode(this.data)\n }\n\n /**\n * Gets the address as a hexadecimal string.\n * @returns {Hex} The address as a hexadecimal string.\n */\n hex(): Hex {\n return hexlify(this.data)\n }\n}\n","import { Chain, ChainType, chainToChainType } from '@layerzerolabs/lz-definitions'\n\nimport { Address as AddressInterface } from './address'\nimport * as aptos from './aptos'\nimport * as evm from './evm'\nimport * as solana from './solana'\nimport * as tron from './tron'\n\nexport const Address = {\n from: (address: string | Uint8Array, chain: Chain): AddressInterface => {\n const chainType = chainToChainType(chain)\n switch (chainType) {\n case ChainType.EVM:\n if (chain === Chain.TRON) {\n return tron.Address.from(address)\n }\n return evm.Address.from(address)\n case ChainType.APTOS:\n return aptos.Address.from(address)\n case ChainType.SOLANA:\n return solana.Address.from(address)\n default:\n throw new Error(`Unsupported chain type: ${chainType}`)\n }\n },\n}\n","import { Address as AddressInterface } from './types'\nimport { Address as AddressObject } from './utils'\n\nconst Address = AddressObject\ntype Address = AddressInterface\n\nexport { Address }\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@layerzerolabs/lz-foundation",
3
- "version": "3.0.15",
3
+ "version": "3.0.16",
4
4
  "description": "LayerZero Core Library",
5
5
  "license": "BUSL-1.1",
6
6
  "exports": {
@@ -23,16 +23,17 @@
23
23
  "clean-prebuild": "rimraf dist"
24
24
  },
25
25
  "dependencies": {
26
- "@layerzerolabs/lz-definitions": "^3.0.15",
27
- "@layerzerolabs/lz-utilities": "^3.0.15",
26
+ "@layerzerolabs/lz-definitions": "^3.0.16",
27
+ "@layerzerolabs/lz-utilities": "^3.0.16",
28
28
  "@noble/ed25519": "^1.7.1",
29
29
  "@noble/hashes": "^1.3.2",
30
- "@noble/secp256k1": "^1.7.1"
30
+ "@noble/secp256k1": "^1.7.1",
31
+ "@scure/base": "^1.1.7"
31
32
  },
32
33
  "devDependencies": {
33
34
  "@jest/globals": "^29.7.0",
34
- "@layerzerolabs/tsup-config-next": "^3.0.15",
35
- "@layerzerolabs/typescript-config-next": "^3.0.15",
35
+ "@layerzerolabs/tsup-config-next": "^3.0.16",
36
+ "@layerzerolabs/typescript-config-next": "^3.0.16",
36
37
  "@types/jest": "^29.5.10",
37
38
  "jest": "^29.7.0",
38
39
  "rimraf": "^5.0.5",