@taquito/utils 10.2.1 → 11.0.1

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.
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InvalidMessageError = exports.InvalidSignatureError = exports.InvalidPublicKeyError = void 0;
4
+ var InvalidPublicKeyError = /** @class */ (function () {
5
+ function InvalidPublicKeyError(message) {
6
+ this.message = message;
7
+ this.name = 'InvalidPublicKeyError';
8
+ }
9
+ return InvalidPublicKeyError;
10
+ }());
11
+ exports.InvalidPublicKeyError = InvalidPublicKeyError;
12
+ var InvalidSignatureError = /** @class */ (function () {
13
+ function InvalidSignatureError(message) {
14
+ this.message = message;
15
+ this.name = 'InvalidSignatureError';
16
+ }
17
+ return InvalidSignatureError;
18
+ }());
19
+ exports.InvalidSignatureError = InvalidSignatureError;
20
+ var InvalidMessageError = /** @class */ (function () {
21
+ function InvalidMessageError(message) {
22
+ this.message = message;
23
+ this.name = 'InvalidMessageError';
24
+ }
25
+ return InvalidMessageError;
26
+ }());
27
+ exports.InvalidMessageError = InvalidMessageError;
28
+ //# sourceMappingURL=errors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.js","sourceRoot":"","sources":["../../src/errors.ts"],"names":[],"mappings":";;;AAAA;IAEI,+BAAmB,OAAe;QAAf,YAAO,GAAP,OAAO,CAAQ;QAD3B,SAAI,GAAW,uBAAuB,CAAC;IACT,CAAC;IACxC,4BAAC;AAAD,CAAC,AAHH,IAGG;AAHU,sDAAqB;AAKhC;IAEE,+BAAmB,OAAe;QAAf,YAAO,GAAP,OAAO,CAAQ;QAD3B,SAAI,GAAW,uBAAuB,CAAC;IACT,CAAC;IACxC,4BAAC;AAAD,CAAC,AAHD,IAGC;AAHY,sDAAqB;AAKlC;IAEE,6BAAmB,OAAe;QAAf,YAAO,GAAP,OAAO,CAAQ;QAD3B,SAAI,GAAW,qBAAqB,CAAC;IACP,CAAC;IACxC,0BAAC;AAAD,CAAC,AAHD,IAGC;AAHY,kDAAmB"}
@@ -14,7 +14,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
14
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
- exports.bytes2Char = exports.char2Bytes = exports.buf2hex = exports.mic2arr = exports.mergebuf = exports.hex2buf = exports.encodeKeyHash = exports.encodeKey = exports.encodePubKey = exports.b58decode = exports.b58cdecode = exports.b58cencode = exports.encodeOpHash = exports.encodeExpr = exports.prefixLength = exports.Prefix = exports.prefix = exports.VERSION = void 0;
17
+ exports.bytes2Char = exports.char2Bytes = exports.buf2hex = exports.mic2arr = exports.mergebuf = exports.hex2buf = exports.encodeKeyHash = exports.encodeKey = exports.encodePubKey = exports.b58decode = exports.b58cdecode = exports.b58cencode = exports.encodeOpHash = exports.encodeExpr = exports.verifySignature = exports.prefixLength = exports.Prefix = exports.prefix = exports.VERSION = void 0;
18
18
  /*
19
19
  * Some code in this file is originally from sotez and eztz
20
20
  * Copyright (c) 2018 Andrew Kishino
@@ -31,6 +31,8 @@ var constants_2 = require("./constants");
31
31
  Object.defineProperty(exports, "prefix", { enumerable: true, get: function () { return constants_2.prefix; } });
32
32
  Object.defineProperty(exports, "Prefix", { enumerable: true, get: function () { return constants_2.Prefix; } });
33
33
  Object.defineProperty(exports, "prefixLength", { enumerable: true, get: function () { return constants_2.prefixLength; } });
34
+ var verify_signature_1 = require("./verify-signature");
35
+ Object.defineProperty(exports, "verifySignature", { enumerable: true, get: function () { return verify_signature_1.verifySignature; } });
34
36
  /**
35
37
  *
36
38
  * @description Hash a string using the BLAKE2b algorithm, base58 encode the hash obtained and appends the prefix 'expr' to it
@@ -1 +1 @@
1
- {"version":3,"file":"taquito-utils.js","sourceRoot":"","sources":["../../src/taquito-utils.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"taquito-utils.js","sourceRoot":"","sources":["../../src/taquito-utils.ts"],"names":[],"mappings":"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"}
@@ -15,10 +15,9 @@ var __read = (this && this.__read) || function (o, n) {
15
15
  }
16
16
  return ar;
17
17
  };
18
- var __spreadArray = (this && this.__spreadArray) || function (to, from) {
19
- for (var i = 0, il = from.length, j = to.length; i < il; i++, j++)
20
- to[j] = from[i];
21
- return to;
18
+ var __spread = (this && this.__spread) || function () {
19
+ for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));
20
+ return ar;
22
21
  };
23
22
  Object.defineProperty(exports, "__esModule", { value: true });
24
23
  exports.validatePublicKey = exports.validateSignature = exports.validateKeyHash = exports.validateContractAddress = exports.validateChain = exports.validateAddress = exports.isValidPrefix = exports.ValidationResult = void 0;
@@ -93,7 +92,7 @@ var pkPrefix = [constants_1.Prefix.EDPK, constants_1.Prefix.SPPK, constants_1.Pr
93
92
  * ```
94
93
  */
95
94
  function validateAddress(value) {
96
- return validatePrefixedValue(value, __spreadArray(__spreadArray([], __read(implicitPrefix)), __read(contractPrefix)));
95
+ return validatePrefixedValue(value, __spread(implicitPrefix, contractPrefix));
97
96
  }
98
97
  exports.validateAddress = validateAddress;
99
98
  /**
@@ -181,7 +180,7 @@ exports.validateSignature = validateSignature;
181
180
  * @example
182
181
  * ```
183
182
  * import { validatePublicKey } from '@taquito/utils';
184
- * const publicKey = 'edsigtkpiSSschcaCt9pUVrpNPf7TTcgvgDEDD6NCEHMy8NNQJCGnMfLZzYoQj74yLjo9wx6MPVV29CvVzgi7qEcEUok3k7AuMg'
183
+ * const publicKey = 'edpkvS5QFv7KRGfa3b87gg9DBpxSm3NpSwnjhUjNBQrRUUR66F7C9g'
185
184
  * const validation = validatePublicKey(publicKey)
186
185
  * console.log(validation)
187
186
  * // This example return 3 which correspond to VALID
@@ -1 +1 @@
1
- {"version":3,"file":"validators.js","sourceRoot":"","sources":["../../src/validators.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"validators.js","sourceRoot":"","sources":["../../src/validators.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,135 @@
1
+ "use strict";
2
+ var __read = (this && this.__read) || function (o, n) {
3
+ var m = typeof Symbol === "function" && o[Symbol.iterator];
4
+ if (!m) return o;
5
+ var i = m.call(o), r, ar = [], e;
6
+ try {
7
+ while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
8
+ }
9
+ catch (error) { e = { error: error }; }
10
+ finally {
11
+ try {
12
+ if (r && !r.done && (m = i["return"])) m.call(i);
13
+ }
14
+ finally { if (e) throw e.error; }
15
+ }
16
+ return ar;
17
+ };
18
+ Object.defineProperty(exports, "__esModule", { value: true });
19
+ exports.verifySignature = void 0;
20
+ var ed25519_1 = require("@stablelib/ed25519");
21
+ var blake2b_1 = require("@stablelib/blake2b");
22
+ var taquito_utils_1 = require("./taquito-utils");
23
+ var elliptic_1 = require("elliptic");
24
+ var typedarray_to_buffer_1 = require("typedarray-to-buffer");
25
+ var errors_1 = require("./errors");
26
+ /**
27
+ * @description Verify signature of a payload
28
+ *
29
+ * @param messageBytes The forged message including the magic byte (1 for block, 2 for endorsement, 3 for generic, 5 for the PACK format of michelson)
30
+ * @param publicKey The public key to verify the signature against
31
+ * @param signature The signature to verify
32
+ * @returns A boolean indicating if the signature matches
33
+ *
34
+ * @example
35
+ * ```
36
+ * const message = '03d0c10e3ed11d7c6e3357f6ef335bab9e8f2bd54d0ce20c482e241191a6e4b8ce6c01be917311d9ac46959750e405d57e268e2ed9e174a80794fbd504e12a4a000141eb3781afed2f69679ff2bbe1c5375950b0e40d00ff000000005e05050505050507070100000024747a32526773486e74516b72794670707352466261313652546656503539684b72654a4d07070100000024747a315a6672455263414c42776d4171776f6e525859565142445439426a4e6a42484a750001';
37
+ * const pk = 'sppk7c7hkPj47yjYFEHX85q46sFJGw6RBrqoVSHwAJAT4e14KJwzoey';
38
+ * const sig = 'spsig1cdLkp1RLgUHAp13aRFkZ6MQDPp7xCnjAExGL3MBSdMDmT6JgQSX8cufyDgJRM3sinFtiCzLbsyP6d365EHoNevxhT47nx'
39
+ *
40
+ * const response = verifySignature(message, pk, sig);
41
+ * ```
42
+ *
43
+ */
44
+ function verifySignature(messageBytes, publicKey, signature) {
45
+ var pkPrefix = validatePkAndExtractPrefix(publicKey);
46
+ var sigPrefix = validateSigAndExtractPrefix(signature);
47
+ var decodedPublicKey = taquito_utils_1.b58cdecode(publicKey, taquito_utils_1.prefix[pkPrefix]);
48
+ var decodedSig = taquito_utils_1.b58cdecode(signature, taquito_utils_1.prefix[sigPrefix]);
49
+ var bytesHash = blake2b_1.hash(taquito_utils_1.hex2buf(validateMessageNotEmpty(messageBytes)), 32);
50
+ if (pkPrefix === taquito_utils_1.Prefix.EDPK) {
51
+ return verifyEdSignature(decodedSig, bytesHash, decodedPublicKey);
52
+ }
53
+ else if (pkPrefix === taquito_utils_1.Prefix.SPPK) {
54
+ return verifySpSignature(decodedSig, bytesHash, decodedPublicKey);
55
+ }
56
+ else if (pkPrefix === taquito_utils_1.Prefix.P2PK) {
57
+ return verifyP2Signature(decodedSig, bytesHash, decodedPublicKey);
58
+ }
59
+ else {
60
+ return false;
61
+ }
62
+ }
63
+ exports.verifySignature = verifySignature;
64
+ function validateMessageNotEmpty(message) {
65
+ if (message === '') {
66
+ throw new errors_1.InvalidMessageError("The message provided for verifying signature cannot be empty.");
67
+ }
68
+ return message;
69
+ }
70
+ function validatePkAndExtractPrefix(publicKey) {
71
+ if (publicKey === '') {
72
+ throw new errors_1.InvalidPublicKeyError("The public key provided for verifying signature cannot be empty.");
73
+ }
74
+ var pkPrefix = publicKey.substring(0, 4);
75
+ var validation = taquito_utils_1.validatePublicKey(publicKey);
76
+ if (validation !== taquito_utils_1.ValidationResult.VALID) {
77
+ if (validation === taquito_utils_1.ValidationResult.INVALID_CHECKSUM) {
78
+ throw new errors_1.InvalidPublicKeyError("The public key provided has an invalid checksum: " + publicKey);
79
+ }
80
+ else if (validation === taquito_utils_1.ValidationResult.INVALID_LENGTH) {
81
+ throw new errors_1.InvalidPublicKeyError("The public key provided has an invalid length: " + publicKey);
82
+ }
83
+ else if (validation === taquito_utils_1.ValidationResult.NO_PREFIX_MATCHED) {
84
+ throw new errors_1.InvalidPublicKeyError("The public key provided has an unsupported prefix: " + pkPrefix);
85
+ }
86
+ }
87
+ return pkPrefix;
88
+ }
89
+ function validateSigAndExtractPrefix(signature) {
90
+ var signaturePrefix = signature.startsWith('sig') ? signature.substr(0, 3) : signature.substr(0, 5);
91
+ var validation = taquito_utils_1.validateSignature(signature);
92
+ if (validation !== taquito_utils_1.ValidationResult.VALID) {
93
+ if (validation === taquito_utils_1.ValidationResult.INVALID_CHECKSUM) {
94
+ throw new errors_1.InvalidSignatureError("The signature provided has an invalid checksum: " + signature);
95
+ }
96
+ else if (validation === taquito_utils_1.ValidationResult.INVALID_LENGTH) {
97
+ throw new errors_1.InvalidSignatureError("The signature provided has an invalid length: " + signature);
98
+ }
99
+ else if (validation === taquito_utils_1.ValidationResult.NO_PREFIX_MATCHED) {
100
+ throw new errors_1.InvalidSignatureError("The signature provided has an unsupported prefix: " + signaturePrefix);
101
+ }
102
+ }
103
+ return signaturePrefix;
104
+ }
105
+ function verifyEdSignature(decodedSig, bytesHash, decodedPublicKey) {
106
+ try {
107
+ return ed25519_1.verify(decodedPublicKey, bytesHash, decodedSig);
108
+ }
109
+ catch (e) {
110
+ return false;
111
+ }
112
+ }
113
+ function verifySpSignature(decodedSig, bytesHash, decodedPublicKey) {
114
+ var key = new elliptic_1.default.ec('secp256k1').keyFromPublic(decodedPublicKey);
115
+ return verifySpOrP2Sig(decodedSig, bytesHash, key);
116
+ }
117
+ function verifyP2Signature(decodedSig, bytesHash, decodedPublicKey) {
118
+ var key = new elliptic_1.default.ec('p256').keyFromPublic(decodedPublicKey);
119
+ return verifySpOrP2Sig(decodedSig, bytesHash, key);
120
+ }
121
+ function verifySpOrP2Sig(decodedSig, bytesHash, key) {
122
+ var hexSig = taquito_utils_1.buf2hex(typedarray_to_buffer_1.default(decodedSig));
123
+ var match = hexSig.match(/([a-f\d]{64})/gi);
124
+ if (match) {
125
+ try {
126
+ var _a = __read(match, 2), r = _a[0], s = _a[1];
127
+ return key.verify(bytesHash, { r: r, s: s });
128
+ }
129
+ catch (e) {
130
+ return false;
131
+ }
132
+ }
133
+ return false;
134
+ }
135
+ //# sourceMappingURL=verify-signature.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"verify-signature.js","sourceRoot":"","sources":["../../src/verify-signature.ts"],"names":[],"mappings":"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"}
@@ -4,8 +4,8 @@ exports.VERSION = void 0;
4
4
  // IMPORTANT: THIS FILE IS AUTO GENERATED! DO NOT MANUALLY EDIT OR CHECKIN!
5
5
  /* tslint:disable */
6
6
  exports.VERSION = {
7
- "commitHash": "5711569ffaf481d88ba3251343a1788090b35dd4",
8
- "version": "10.2.1"
7
+ "commitHash": "8d7ecc86ce608bff9ee8c6cf0cd7d795263b8bda",
8
+ "version": "11.0.1"
9
9
  };
10
10
  /* tslint:enable */
11
11
  //# sourceMappingURL=version.js.map
@@ -1,4 +1,8 @@
1
1
  import { Buffer } from 'buffer';
2
+ import { verify } from '@stablelib/ed25519';
3
+ import { hash } from '@stablelib/blake2b';
4
+ import elliptic from 'elliptic';
5
+ import toBuffer from 'typedarray-to-buffer';
2
6
 
3
7
  var _a, _b;
4
8
  var Prefix;
@@ -118,10 +122,11 @@ function __read(o, n) {
118
122
  return ar;
119
123
  }
120
124
 
121
- function __spreadArray(to, from) {
122
- for (var i = 0, il = from.length, j = to.length; i < il; i++, j++)
123
- to[j] = from[i];
124
- return to;
125
+ /** @deprecated */
126
+ function __spread() {
127
+ for (var ar = [], i = 0; i < arguments.length; i++)
128
+ ar = ar.concat(__read(arguments[i]));
129
+ return ar;
125
130
  }
126
131
 
127
132
  var bs58check$1 = require('bs58check');
@@ -193,7 +198,7 @@ var pkPrefix = [Prefix.EDPK, Prefix.SPPK, Prefix.P2PK];
193
198
  * ```
194
199
  */
195
200
  function validateAddress(value) {
196
- return validatePrefixedValue(value, __spreadArray(__spreadArray([], __read(implicitPrefix)), __read(contractPrefix)));
201
+ return validatePrefixedValue(value, __spread(implicitPrefix, contractPrefix));
197
202
  }
198
203
  /**
199
204
  * @description Used to check if a chain id is valid.
@@ -276,7 +281,7 @@ function validateSignature(value) {
276
281
  * @example
277
282
  * ```
278
283
  * import { validatePublicKey } from '@taquito/utils';
279
- * const publicKey = 'edsigtkpiSSschcaCt9pUVrpNPf7TTcgvgDEDD6NCEHMy8NNQJCGnMfLZzYoQj74yLjo9wx6MPVV29CvVzgi7qEcEUok3k7AuMg'
284
+ * const publicKey = 'edpkvS5QFv7KRGfa3b87gg9DBpxSm3NpSwnjhUjNBQrRUUR66F7C9g'
280
285
  * const validation = validatePublicKey(publicKey)
281
286
  * console.log(validation)
282
287
  * // This example return 3 which correspond to VALID
@@ -289,11 +294,142 @@ function validatePublicKey(value) {
289
294
  // IMPORTANT: THIS FILE IS AUTO GENERATED! DO NOT MANUALLY EDIT OR CHECKIN!
290
295
  /* tslint:disable */
291
296
  var VERSION = {
292
- "commitHash": "5711569ffaf481d88ba3251343a1788090b35dd4",
293
- "version": "10.2.1"
297
+ "commitHash": "8d7ecc86ce608bff9ee8c6cf0cd7d795263b8bda",
298
+ "version": "11.0.1"
294
299
  };
295
300
  /* tslint:enable */
296
301
 
302
+ var InvalidPublicKeyError = /** @class */ (function () {
303
+ function InvalidPublicKeyError(message) {
304
+ this.message = message;
305
+ this.name = 'InvalidPublicKeyError';
306
+ }
307
+ return InvalidPublicKeyError;
308
+ }());
309
+ var InvalidSignatureError = /** @class */ (function () {
310
+ function InvalidSignatureError(message) {
311
+ this.message = message;
312
+ this.name = 'InvalidSignatureError';
313
+ }
314
+ return InvalidSignatureError;
315
+ }());
316
+ var InvalidMessageError = /** @class */ (function () {
317
+ function InvalidMessageError(message) {
318
+ this.message = message;
319
+ this.name = 'InvalidMessageError';
320
+ }
321
+ return InvalidMessageError;
322
+ }());
323
+
324
+ /**
325
+ * @description Verify signature of a payload
326
+ *
327
+ * @param messageBytes The forged message including the magic byte (1 for block, 2 for endorsement, 3 for generic, 5 for the PACK format of michelson)
328
+ * @param publicKey The public key to verify the signature against
329
+ * @param signature The signature to verify
330
+ * @returns A boolean indicating if the signature matches
331
+ *
332
+ * @example
333
+ * ```
334
+ * const message = '03d0c10e3ed11d7c6e3357f6ef335bab9e8f2bd54d0ce20c482e241191a6e4b8ce6c01be917311d9ac46959750e405d57e268e2ed9e174a80794fbd504e12a4a000141eb3781afed2f69679ff2bbe1c5375950b0e40d00ff000000005e05050505050507070100000024747a32526773486e74516b72794670707352466261313652546656503539684b72654a4d07070100000024747a315a6672455263414c42776d4171776f6e525859565142445439426a4e6a42484a750001';
335
+ * const pk = 'sppk7c7hkPj47yjYFEHX85q46sFJGw6RBrqoVSHwAJAT4e14KJwzoey';
336
+ * const sig = 'spsig1cdLkp1RLgUHAp13aRFkZ6MQDPp7xCnjAExGL3MBSdMDmT6JgQSX8cufyDgJRM3sinFtiCzLbsyP6d365EHoNevxhT47nx'
337
+ *
338
+ * const response = verifySignature(message, pk, sig);
339
+ * ```
340
+ *
341
+ */
342
+ function verifySignature(messageBytes, publicKey, signature) {
343
+ var pkPrefix = validatePkAndExtractPrefix(publicKey);
344
+ var sigPrefix = validateSigAndExtractPrefix(signature);
345
+ var decodedPublicKey = b58cdecode(publicKey, prefix[pkPrefix]);
346
+ var decodedSig = b58cdecode(signature, prefix[sigPrefix]);
347
+ var bytesHash = hash(hex2buf(validateMessageNotEmpty(messageBytes)), 32);
348
+ if (pkPrefix === Prefix.EDPK) {
349
+ return verifyEdSignature(decodedSig, bytesHash, decodedPublicKey);
350
+ }
351
+ else if (pkPrefix === Prefix.SPPK) {
352
+ return verifySpSignature(decodedSig, bytesHash, decodedPublicKey);
353
+ }
354
+ else if (pkPrefix === Prefix.P2PK) {
355
+ return verifyP2Signature(decodedSig, bytesHash, decodedPublicKey);
356
+ }
357
+ else {
358
+ return false;
359
+ }
360
+ }
361
+ function validateMessageNotEmpty(message) {
362
+ if (message === '') {
363
+ throw new InvalidMessageError("The message provided for verifying signature cannot be empty.");
364
+ }
365
+ return message;
366
+ }
367
+ function validatePkAndExtractPrefix(publicKey) {
368
+ if (publicKey === '') {
369
+ throw new InvalidPublicKeyError("The public key provided for verifying signature cannot be empty.");
370
+ }
371
+ var pkPrefix = publicKey.substring(0, 4);
372
+ var validation = validatePublicKey(publicKey);
373
+ if (validation !== ValidationResult.VALID) {
374
+ if (validation === ValidationResult.INVALID_CHECKSUM) {
375
+ throw new InvalidPublicKeyError("The public key provided has an invalid checksum: " + publicKey);
376
+ }
377
+ else if (validation === ValidationResult.INVALID_LENGTH) {
378
+ throw new InvalidPublicKeyError("The public key provided has an invalid length: " + publicKey);
379
+ }
380
+ else if (validation === ValidationResult.NO_PREFIX_MATCHED) {
381
+ throw new InvalidPublicKeyError("The public key provided has an unsupported prefix: " + pkPrefix);
382
+ }
383
+ }
384
+ return pkPrefix;
385
+ }
386
+ function validateSigAndExtractPrefix(signature) {
387
+ var signaturePrefix = signature.startsWith('sig') ? signature.substr(0, 3) : signature.substr(0, 5);
388
+ var validation = validateSignature(signature);
389
+ if (validation !== ValidationResult.VALID) {
390
+ if (validation === ValidationResult.INVALID_CHECKSUM) {
391
+ throw new InvalidSignatureError("The signature provided has an invalid checksum: " + signature);
392
+ }
393
+ else if (validation === ValidationResult.INVALID_LENGTH) {
394
+ throw new InvalidSignatureError("The signature provided has an invalid length: " + signature);
395
+ }
396
+ else if (validation === ValidationResult.NO_PREFIX_MATCHED) {
397
+ throw new InvalidSignatureError("The signature provided has an unsupported prefix: " + signaturePrefix);
398
+ }
399
+ }
400
+ return signaturePrefix;
401
+ }
402
+ function verifyEdSignature(decodedSig, bytesHash, decodedPublicKey) {
403
+ try {
404
+ return verify(decodedPublicKey, bytesHash, decodedSig);
405
+ }
406
+ catch (e) {
407
+ return false;
408
+ }
409
+ }
410
+ function verifySpSignature(decodedSig, bytesHash, decodedPublicKey) {
411
+ var key = new elliptic.ec('secp256k1').keyFromPublic(decodedPublicKey);
412
+ return verifySpOrP2Sig(decodedSig, bytesHash, key);
413
+ }
414
+ function verifyP2Signature(decodedSig, bytesHash, decodedPublicKey) {
415
+ var key = new elliptic.ec('p256').keyFromPublic(decodedPublicKey);
416
+ return verifySpOrP2Sig(decodedSig, bytesHash, key);
417
+ }
418
+ function verifySpOrP2Sig(decodedSig, bytesHash, key) {
419
+ var hexSig = buf2hex(toBuffer(decodedSig));
420
+ var match = hexSig.match(/([a-f\d]{64})/gi);
421
+ if (match) {
422
+ try {
423
+ var _a = __read(match, 2), r = _a[0], s = _a[1];
424
+ return key.verify(bytesHash, { r: r, s: s });
425
+ }
426
+ catch (e) {
427
+ return false;
428
+ }
429
+ }
430
+ return false;
431
+ }
432
+
297
433
  /**
298
434
  * @packageDocumentation
299
435
  * @module @taquito/utils
@@ -530,5 +666,5 @@ function bytes2Char(hex) {
530
666
  return Buffer.from(hex2buf(hex)).toString('utf8');
531
667
  }
532
668
 
533
- export { Prefix, VERSION, ValidationResult, b58cdecode, b58cencode, b58decode, buf2hex, bytes2Char, char2Bytes, encodeExpr, encodeKey, encodeKeyHash, encodeOpHash, encodePubKey, hex2buf, isValidPrefix, mergebuf, mic2arr, prefix, prefixLength, validateAddress, validateChain, validateContractAddress, validateKeyHash, validatePublicKey, validateSignature };
669
+ export { Prefix, VERSION, ValidationResult, b58cdecode, b58cencode, b58decode, buf2hex, bytes2Char, char2Bytes, encodeExpr, encodeKey, encodeKeyHash, encodeOpHash, encodePubKey, hex2buf, isValidPrefix, mergebuf, mic2arr, prefix, prefixLength, validateAddress, validateChain, validateContractAddress, validateKeyHash, validatePublicKey, validateSignature, verifySignature };
534
670
  //# sourceMappingURL=taquito-utils.es5.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"taquito-utils.es5.js","sources":["../src/constants.ts","../src/validators.ts","../src/version.ts","../src/taquito-utils.ts"],"sourcesContent":["export enum Prefix {\n TZ1 = 'tz1',\n TZ2 = 'tz2',\n TZ3 = 'tz3',\n KT = 'KT',\n KT1 = 'KT1',\n\n EDSK2 = 'edsk2',\n SPSK = 'spsk',\n P2SK = 'p2sk',\n\n EDPK = 'edpk',\n SPPK = 'sppk',\n P2PK = 'p2pk',\n\n EDESK = 'edesk',\n SPESK = 'spesk',\n P2ESK = 'p2esk',\n\n EDSK = 'edsk',\n EDSIG = 'edsig',\n SPSIG = 'spsig',\n P2SIG = 'p2sig',\n SIG = 'sig',\n\n NET = 'Net',\n NCE = 'nce',\n B = 'b',\n O = 'o',\n LO = 'Lo',\n LLO = 'LLo',\n P = 'P',\n CO = 'Co',\n ID = 'id',\n\n EXPR = 'expr',\n TZ = 'TZ',\n}\n\nexport const prefix = {\n [Prefix.TZ1]: new Uint8Array([6, 161, 159]),\n [Prefix.TZ2]: new Uint8Array([6, 161, 161]),\n [Prefix.TZ3]: new Uint8Array([6, 161, 164]),\n [Prefix.KT]: new Uint8Array([2, 90, 121]),\n [Prefix.KT1]: new Uint8Array([2, 90, 121]),\n\n [Prefix.EDSK]: new Uint8Array([43, 246, 78, 7]),\n [Prefix.EDSK2]: new Uint8Array([13, 15, 58, 7]),\n [Prefix.SPSK]: new Uint8Array([17, 162, 224, 201]),\n [Prefix.P2SK]: new Uint8Array([16, 81, 238, 189]),\n\n [Prefix.EDPK]: new Uint8Array([13, 15, 37, 217]),\n [Prefix.SPPK]: new Uint8Array([3, 254, 226, 86]),\n [Prefix.P2PK]: new Uint8Array([3, 178, 139, 127]),\n\n [Prefix.EDESK]: new Uint8Array([7, 90, 60, 179, 41]),\n [Prefix.SPESK]: new Uint8Array([0x09, 0xed, 0xf1, 0xae, 0x96]),\n [Prefix.P2ESK]: new Uint8Array([0x09, 0x30, 0x39, 0x73, 0xab]),\n\n [Prefix.EDSIG]: new Uint8Array([9, 245, 205, 134, 18]),\n [Prefix.SPSIG]: new Uint8Array([13, 115, 101, 19, 63]),\n [Prefix.P2SIG]: new Uint8Array([54, 240, 44, 52]),\n [Prefix.SIG]: new Uint8Array([4, 130, 43]),\n\n [Prefix.NET]: new Uint8Array([87, 82, 0]),\n [Prefix.NCE]: new Uint8Array([69, 220, 169]),\n [Prefix.B]: new Uint8Array([1, 52]),\n [Prefix.O]: new Uint8Array([5, 116]),\n [Prefix.LO]: new Uint8Array([133, 233]),\n [Prefix.LLO]: new Uint8Array([29, 159, 109]),\n [Prefix.P]: new Uint8Array([2, 170]),\n [Prefix.CO]: new Uint8Array([79, 179]),\n [Prefix.ID]: new Uint8Array([153, 103]),\n\n [Prefix.EXPR]: new Uint8Array([13, 44, 64, 27]),\n // Legacy prefix\n [Prefix.TZ]: new Uint8Array([2, 90, 121]),\n};\n\nexport const prefixLength: { [key: string]: number } = {\n [Prefix.TZ1]: 20,\n [Prefix.TZ2]: 20,\n [Prefix.TZ3]: 20,\n [Prefix.KT]: 20,\n [Prefix.KT1]: 20,\n [Prefix.EDPK]: 32,\n [Prefix.SPPK]: 33,\n [Prefix.P2PK]: 33,\n [Prefix.EDSIG]: 64,\n [Prefix.SPSIG]: 64,\n [Prefix.P2SIG]: 64,\n [Prefix.SIG]: 64,\n [Prefix.NET]: 4,\n [Prefix.B]: 32,\n [Prefix.P]: 32,\n [Prefix.O]: 32\n};\n","import { prefix, prefixLength, Prefix } from './constants';\n\nconst bs58check = require('bs58check');\n\nexport enum ValidationResult {\n NO_PREFIX_MATCHED,\n INVALID_CHECKSUM,\n INVALID_LENGTH,\n VALID,\n}\n\nexport function isValidPrefix(value: any): value is Prefix {\n if (typeof value !== 'string') {\n return false;\n }\n\n return value in prefix;\n}\n /**\n * @description This function is called by the validation functions ([[validateAddress]], [[validateChain]], [[validateContractAddress]], [[validateKeyHash]], [[validateSignature]], [[validatePublicKey]]).\n * Verify if the value has the right prefix or return `NO_PREFIX_MATCHED`,\n * decode the value using base58 and return `INVALID_CHECKSUM` if it fails,\n * check if the length of the value matches the prefix type or return `INVALID_LENGTH`.\n * If all checks pass, return `VALID`.\n *\n * @param value Value to validate\n * @param prefixes prefix the value should have\n */\nfunction validatePrefixedValue(value: any, prefixes: Prefix[]) {\n const match = new RegExp(`^(${prefixes.join('|')})`).exec(value);\n if (!match || match.length === 0) {\n return ValidationResult.NO_PREFIX_MATCHED;\n }\n\n const prefixKey = match[0];\n\n if (!isValidPrefix(prefixKey)) {\n return ValidationResult.NO_PREFIX_MATCHED;\n }\n\n // Remove annotation from contract address before doing the validation\n const contractAddress = /^(KT1\\w{33})(\\%(.*))?/.exec(value);\n if (contractAddress) {\n value = contractAddress[1];\n }\n\n // decodeUnsafe return undefined if decoding fail\n let decoded = bs58check.decodeUnsafe(value);\n if (!decoded) {\n return ValidationResult.INVALID_CHECKSUM;\n }\n\n decoded = decoded.slice(prefix[prefixKey].length);\n if (decoded.length !== prefixLength[prefixKey]) {\n return ValidationResult.INVALID_LENGTH;\n }\n\n return ValidationResult.VALID;\n}\n\nconst implicitPrefix = [Prefix.TZ1, Prefix.TZ2, Prefix.TZ3];\nconst contractPrefix = [Prefix.KT1];\nconst signaturePrefix = [Prefix.EDSIG, Prefix.P2SIG, Prefix.SPSIG, Prefix.SIG];\nconst pkPrefix = [Prefix.EDPK, Prefix.SPPK, Prefix.P2PK];\n\n /**\n * @description Used to check if an address or a contract address is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateAddress } from '@taquito/utils';\n * const pkh = 'tz1L9r8mWmRPndRhuvMCWESLGSVeFzQ9NAWx'\n * const validation = validateAddress(pkh)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validateAddress(value: any): ValidationResult {\n return validatePrefixedValue(value, [...implicitPrefix, ...contractPrefix]);\n}\n /**\n * @description Used to check if a chain id is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateChain } from '@taquito/utils';\n * const chainId = 'NetXdQprcVkpaWU'\n * const validation = validateChain(chainId)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validateChain(value: any): ValidationResult {\n return validatePrefixedValue(value, [Prefix.NET]);\n}\n /**\n * @description Used to check if a contract address is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateContractAddress } from '@taquito/utils';\n * const contractAddress = 'KT1JVErLYTgtY8uGGZ4mso2npTSxqVLDRVbC'\n * const validation = validateContractAddress(contractAddress)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validateContractAddress(value: any): ValidationResult {\n return validatePrefixedValue(value, contractPrefix);\n}\n /**\n * @description Used to check if a key hash is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateKeyHash } from '@taquito/utils';\n * const keyHashWithoutPrefix = '1L9r8mWmRPndRhuvMCWESLGSVeFzQ9NAWx'\n * const validation = validateKeyHash(keyHashWithoutPrefix)\n * console.log(validation)\n * // This example return 0 which correspond to NO_PREFIX_MATCHED\n * ```\n */\nexport function validateKeyHash(value: any): ValidationResult {\n return validatePrefixedValue(value, implicitPrefix);\n}\n /**\n * @description Used to check if a signature is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateSignature } from '@taquito/utils';\n * const signature = 'edsigtkpiSSschcaCt9pUVrpNPf7TTcgvgDEDD6NCEHMy8NNQJCGnMfLZzYoQj74yLjo9wx6MPVV29CvVzgi7qEcEUok3k7AuMg'\n * const validation = validateSignature(signature)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validateSignature(value: any): ValidationResult {\n return validatePrefixedValue(value, signaturePrefix);\n}\n /**\n * @description Used to check if a signature is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validatePublicKey } from '@taquito/utils';\n * const publicKey = 'edsigtkpiSSschcaCt9pUVrpNPf7TTcgvgDEDD6NCEHMy8NNQJCGnMfLZzYoQj74yLjo9wx6MPVV29CvVzgi7qEcEUok3k7AuMg'\n * const validation = validatePublicKey(publicKey)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validatePublicKey(value: any): ValidationResult {\n return validatePrefixedValue(value, pkPrefix);\n}\n","\n// IMPORTANT: THIS FILE IS AUTO GENERATED! DO NOT MANUALLY EDIT OR CHECKIN!\n/* tslint:disable */\nexport const VERSION = {\n \"commitHash\": \"5711569ffaf481d88ba3251343a1788090b35dd4\",\n \"version\": \"10.2.1\"\n};\n/* tslint:enable */\n","/**\n * @packageDocumentation\n * @module @taquito/utils\n */\n\n/*\n * Some code in this file is originally from sotez and eztz\n * Copyright (c) 2018 Andrew Kishino\n * Copyright (c) 2017 Stephen Andrews\n */\n\nimport { Buffer } from 'buffer';\nimport { prefix } from './constants';\nconst blake = require('blakejs');\nconst bs58check = require('bs58check');\n\nexport * from './validators';\nexport { VERSION } from './version';\n\nexport { prefix, Prefix, prefixLength } from './constants';\n\n/**\n *\n * @description Hash a string using the BLAKE2b algorithm, base58 encode the hash obtained and appends the prefix 'expr' to it\n *\n * @param value Value in hex\n */\nexport function encodeExpr(value: string) {\n const blakeHash = blake.blake2b(hex2buf(value), null, 32);\n return b58cencode(blakeHash, prefix['expr']);\n}\n\n/**\n *\n * @description Return the operation hash of a signed operation \n * @param value Value in hex of a signed operation\n */\n export function encodeOpHash(value: string) {\n const blakeHash = blake.blake2b(hex2buf(value), null, 32);\n return b58cencode(blakeHash, prefix.o);\n}\n\n/**\n *\n * @description Base58 encode a string or a Uint8Array and append a prefix to it\n *\n * @param value Value to base58 encode\n * @param prefix prefix to append to the encoded string\n */\nexport function b58cencode(value: string | Uint8Array, prefix: Uint8Array) {\n const payloadAr = typeof value === 'string' ? Uint8Array.from(Buffer.from(value, 'hex')) : value;\n\n const n = new Uint8Array(prefix.length + payloadAr.length);\n n.set(prefix);\n n.set(payloadAr, prefix.length);\n\n return bs58check.encode(Buffer.from(n.buffer));\n}\n\n/**\n *\n * @description Base58 decode a string and remove the prefix from it\n *\n * @param value Value to base58 decode\n * @param prefix prefix to remove from the decoded string\n */\nexport const b58cdecode = (enc: string, prefixArg: Uint8Array): Uint8Array =>\n bs58check.decode(enc).slice(prefixArg.length);\n\n/**\n *\n * @description Base58 decode a string with predefined prefix\n *\n * @param value Value to base58 decode\n */\nexport function b58decode(payload: string) {\n const buf: Buffer = bs58check.decode(payload);\n\n const prefixMap = {\n [prefix.tz1.toString()]: '0000',\n [prefix.tz2.toString()]: '0001',\n [prefix.tz3.toString()]: '0002',\n };\n\n let pref = prefixMap[new Uint8Array(buf.slice(0, 3)).toString()];\n if (pref) {\n // tz addresses\n const hex = buf2hex(buf.slice(3));\n return pref + hex;\n } else {\n // other (kt addresses)\n return '01' + buf2hex(buf.slice(3, 42)) + '00';\n }\n}\n\n/**\n *\n * @description Base58 encode a public key using predefined prefix\n *\n * @param value Public Key to base58 encode\n */\nexport function encodePubKey(value: string) {\n if (value.substring(0, 2) === '00') {\n const pref: { [key: string]: Uint8Array } = {\n '0000': prefix.tz1,\n '0001': prefix.tz2,\n '0002': prefix.tz3,\n };\n\n return b58cencode(value.substring(4), pref[value.substring(0, 4)]);\n }\n\n return b58cencode(value.substring(2, 42), prefix.KT);\n}\n\n/**\n *\n * @description Base58 encode a key according to its prefix\n *\n * @param value Key to base58 encode\n */\nexport function encodeKey(value: string) {\n if (value[0] === '0') {\n const pref: { [key: string]: Uint8Array } = {\n '00': new Uint8Array([13, 15, 37, 217]),\n '01': new Uint8Array([3, 254, 226, 86]),\n '02': new Uint8Array([3, 178, 139, 127]),\n };\n\n return b58cencode(value.substring(2), pref[value.substring(0, 2)]);\n }\n}\n\n/**\n *\n * @description Base58 encode a key hash according to its prefix\n *\n * @param value Key to base58 encode\n */\nexport function encodeKeyHash(value: string) {\n if (value[0] === '0') {\n const pref: { [key: string]: Uint8Array } = {\n '00': new Uint8Array([6, 161, 159]),\n '01': new Uint8Array([6, 161, 161]),\n '02': new Uint8Array([6, 161, 164]),\n };\n\n return b58cencode(value.substring(2), pref[value.substring(0, 2)]);\n }\n}\n\n/**\n *\n * @description Convert an hex string to a Uint8Array\n *\n * @param hex Hex string to convert\n */\nexport const hex2buf = (hex: string): Uint8Array => {\n return new Uint8Array(hex.match(/[\\da-f]{2}/gi)!.map((h) => parseInt(h, 16)));\n};\n\n/**\n *\n * @description Merge 2 buffers together\n *\n * @param b1 First buffer\n * @param b2 Second buffer\n */\nexport const mergebuf = (b1: Uint8Array, b2: Uint8Array): Uint8Array => {\n const r = new Uint8Array(b1.length + b2.length);\n r.set(b1);\n r.set(b2, b1.length);\n return r;\n};\n\n/**\n *\n * @description Flatten a michelson json representation to an array\n *\n * @param s michelson json\n */\nexport const mic2arr = function me2(s: any): any {\n let ret: any = [];\n if (Object.prototype.hasOwnProperty.call(s, 'prim')) {\n if (s.prim === 'Pair') {\n ret.push(me2(s.args[0]));\n ret = ret.concat(me2(s.args[1]));\n } else if (s.prim === 'Elt') {\n ret = {\n key: me2(s.args[0]),\n val: me2(s.args[1]),\n };\n } else if (s.prim === 'True') {\n ret = true;\n } else if (s.prim === 'False') {\n ret = false;\n }\n } else if (Array.isArray(s)) {\n const sc = s.length;\n for (let i = 0; i < sc; i++) {\n const n = me2(s[i]);\n if (typeof n.key !== 'undefined') {\n if (Array.isArray(ret)) {\n ret = {\n keys: [],\n vals: [],\n };\n }\n ret.keys.push(n.key);\n ret.vals.push(n.val);\n } else {\n ret.push(n);\n }\n }\n } else if (Object.prototype.hasOwnProperty.call(s, 'string')) {\n ret = s.string;\n } else if (Object.prototype.hasOwnProperty.call(s, 'int')) {\n ret = parseInt(s.int, 10);\n } else {\n ret = s;\n }\n return ret;\n};\n\n/**\n *\n * @description Convert a buffer to an hex string\n *\n * @param buffer Buffer to convert\n */\nexport const buf2hex = (buffer: Buffer): string => {\n const byteArray = new Uint8Array(buffer);\n const hexParts: string[] = [];\n byteArray.forEach((byte: any) => {\n const hex = byte.toString(16);\n const paddedHex = `00${hex}`.slice(-2);\n hexParts.push(paddedHex);\n });\n return hexParts.join('');\n};\n\n/**\n *\n * @description Convert a string to bytes\n *\n * @param str String to convert\n */\nexport function char2Bytes(str: string) {\n return Buffer.from(str, 'utf8').toString('hex');\n}\n\n/**\n *\n * @description Convert bytes to a string\n *\n * @param str Bytes to convert\n */\nexport function bytes2Char(hex: string): string {\n return Buffer.from(hex2buf(hex)).toString('utf8');\n}\n"],"names":["bs58check"],"mappings":"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"}
1
+ {"version":3,"file":"taquito-utils.es5.js","sources":["../src/constants.ts","../src/validators.ts","../src/version.ts","../src/errors.ts","../src/verify-signature.ts","../src/taquito-utils.ts"],"sourcesContent":["export enum Prefix {\n TZ1 = 'tz1',\n TZ2 = 'tz2',\n TZ3 = 'tz3',\n KT = 'KT',\n KT1 = 'KT1',\n\n EDSK2 = 'edsk2',\n SPSK = 'spsk',\n P2SK = 'p2sk',\n\n EDPK = 'edpk',\n SPPK = 'sppk',\n P2PK = 'p2pk',\n\n EDESK = 'edesk',\n SPESK = 'spesk',\n P2ESK = 'p2esk',\n\n EDSK = 'edsk',\n EDSIG = 'edsig',\n SPSIG = 'spsig',\n P2SIG = 'p2sig',\n SIG = 'sig',\n\n NET = 'Net',\n NCE = 'nce',\n B = 'b',\n O = 'o',\n LO = 'Lo',\n LLO = 'LLo',\n P = 'P',\n CO = 'Co',\n ID = 'id',\n\n EXPR = 'expr',\n TZ = 'TZ',\n}\n\nexport const prefix = {\n [Prefix.TZ1]: new Uint8Array([6, 161, 159]),\n [Prefix.TZ2]: new Uint8Array([6, 161, 161]),\n [Prefix.TZ3]: new Uint8Array([6, 161, 164]),\n [Prefix.KT]: new Uint8Array([2, 90, 121]),\n [Prefix.KT1]: new Uint8Array([2, 90, 121]),\n\n [Prefix.EDSK]: new Uint8Array([43, 246, 78, 7]),\n [Prefix.EDSK2]: new Uint8Array([13, 15, 58, 7]),\n [Prefix.SPSK]: new Uint8Array([17, 162, 224, 201]),\n [Prefix.P2SK]: new Uint8Array([16, 81, 238, 189]),\n\n [Prefix.EDPK]: new Uint8Array([13, 15, 37, 217]),\n [Prefix.SPPK]: new Uint8Array([3, 254, 226, 86]),\n [Prefix.P2PK]: new Uint8Array([3, 178, 139, 127]),\n\n [Prefix.EDESK]: new Uint8Array([7, 90, 60, 179, 41]),\n [Prefix.SPESK]: new Uint8Array([0x09, 0xed, 0xf1, 0xae, 0x96]),\n [Prefix.P2ESK]: new Uint8Array([0x09, 0x30, 0x39, 0x73, 0xab]),\n\n [Prefix.EDSIG]: new Uint8Array([9, 245, 205, 134, 18]),\n [Prefix.SPSIG]: new Uint8Array([13, 115, 101, 19, 63]),\n [Prefix.P2SIG]: new Uint8Array([54, 240, 44, 52]),\n [Prefix.SIG]: new Uint8Array([4, 130, 43]),\n\n [Prefix.NET]: new Uint8Array([87, 82, 0]),\n [Prefix.NCE]: new Uint8Array([69, 220, 169]),\n [Prefix.B]: new Uint8Array([1, 52]),\n [Prefix.O]: new Uint8Array([5, 116]),\n [Prefix.LO]: new Uint8Array([133, 233]),\n [Prefix.LLO]: new Uint8Array([29, 159, 109]),\n [Prefix.P]: new Uint8Array([2, 170]),\n [Prefix.CO]: new Uint8Array([79, 179]),\n [Prefix.ID]: new Uint8Array([153, 103]),\n\n [Prefix.EXPR]: new Uint8Array([13, 44, 64, 27]),\n // Legacy prefix\n [Prefix.TZ]: new Uint8Array([2, 90, 121]),\n};\n\nexport const prefixLength: { [key: string]: number } = {\n [Prefix.TZ1]: 20,\n [Prefix.TZ2]: 20,\n [Prefix.TZ3]: 20,\n [Prefix.KT]: 20,\n [Prefix.KT1]: 20,\n [Prefix.EDPK]: 32,\n [Prefix.SPPK]: 33,\n [Prefix.P2PK]: 33,\n [Prefix.EDSIG]: 64,\n [Prefix.SPSIG]: 64,\n [Prefix.P2SIG]: 64,\n [Prefix.SIG]: 64,\n [Prefix.NET]: 4,\n [Prefix.B]: 32,\n [Prefix.P]: 32,\n [Prefix.O]: 32\n};\n","import { prefix, prefixLength, Prefix } from './constants';\n\nconst bs58check = require('bs58check');\n\nexport enum ValidationResult {\n NO_PREFIX_MATCHED,\n INVALID_CHECKSUM,\n INVALID_LENGTH,\n VALID,\n}\n\nexport function isValidPrefix(value: any): value is Prefix {\n if (typeof value !== 'string') {\n return false;\n }\n\n return value in prefix;\n}\n /**\n * @description This function is called by the validation functions ([[validateAddress]], [[validateChain]], [[validateContractAddress]], [[validateKeyHash]], [[validateSignature]], [[validatePublicKey]]).\n * Verify if the value has the right prefix or return `NO_PREFIX_MATCHED`,\n * decode the value using base58 and return `INVALID_CHECKSUM` if it fails,\n * check if the length of the value matches the prefix type or return `INVALID_LENGTH`.\n * If all checks pass, return `VALID`.\n *\n * @param value Value to validate\n * @param prefixes prefix the value should have\n */\nfunction validatePrefixedValue(value: any, prefixes: Prefix[]) {\n const match = new RegExp(`^(${prefixes.join('|')})`).exec(value);\n if (!match || match.length === 0) {\n return ValidationResult.NO_PREFIX_MATCHED;\n }\n\n const prefixKey = match[0];\n\n if (!isValidPrefix(prefixKey)) {\n return ValidationResult.NO_PREFIX_MATCHED;\n }\n\n // Remove annotation from contract address before doing the validation\n const contractAddress = /^(KT1\\w{33})(\\%(.*))?/.exec(value);\n if (contractAddress) {\n value = contractAddress[1];\n }\n\n // decodeUnsafe return undefined if decoding fail\n let decoded = bs58check.decodeUnsafe(value);\n if (!decoded) {\n return ValidationResult.INVALID_CHECKSUM;\n }\n\n decoded = decoded.slice(prefix[prefixKey].length);\n if (decoded.length !== prefixLength[prefixKey]) {\n return ValidationResult.INVALID_LENGTH;\n }\n\n return ValidationResult.VALID;\n}\n\nconst implicitPrefix = [Prefix.TZ1, Prefix.TZ2, Prefix.TZ3];\nconst contractPrefix = [Prefix.KT1];\nconst signaturePrefix = [Prefix.EDSIG, Prefix.P2SIG, Prefix.SPSIG, Prefix.SIG];\nconst pkPrefix = [Prefix.EDPK, Prefix.SPPK, Prefix.P2PK];\n\n /**\n * @description Used to check if an address or a contract address is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateAddress } from '@taquito/utils';\n * const pkh = 'tz1L9r8mWmRPndRhuvMCWESLGSVeFzQ9NAWx'\n * const validation = validateAddress(pkh)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validateAddress(value: any): ValidationResult {\n return validatePrefixedValue(value, [...implicitPrefix, ...contractPrefix]);\n}\n /**\n * @description Used to check if a chain id is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateChain } from '@taquito/utils';\n * const chainId = 'NetXdQprcVkpaWU'\n * const validation = validateChain(chainId)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validateChain(value: any): ValidationResult {\n return validatePrefixedValue(value, [Prefix.NET]);\n}\n /**\n * @description Used to check if a contract address is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateContractAddress } from '@taquito/utils';\n * const contractAddress = 'KT1JVErLYTgtY8uGGZ4mso2npTSxqVLDRVbC'\n * const validation = validateContractAddress(contractAddress)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validateContractAddress(value: any): ValidationResult {\n return validatePrefixedValue(value, contractPrefix);\n}\n /**\n * @description Used to check if a key hash is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateKeyHash } from '@taquito/utils';\n * const keyHashWithoutPrefix = '1L9r8mWmRPndRhuvMCWESLGSVeFzQ9NAWx'\n * const validation = validateKeyHash(keyHashWithoutPrefix)\n * console.log(validation)\n * // This example return 0 which correspond to NO_PREFIX_MATCHED\n * ```\n */\nexport function validateKeyHash(value: any): ValidationResult {\n return validatePrefixedValue(value, implicitPrefix);\n}\n /**\n * @description Used to check if a signature is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateSignature } from '@taquito/utils';\n * const signature = 'edsigtkpiSSschcaCt9pUVrpNPf7TTcgvgDEDD6NCEHMy8NNQJCGnMfLZzYoQj74yLjo9wx6MPVV29CvVzgi7qEcEUok3k7AuMg'\n * const validation = validateSignature(signature)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validateSignature(value: any): ValidationResult {\n return validatePrefixedValue(value, signaturePrefix);\n}\n /**\n * @description Used to check if a signature is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validatePublicKey } from '@taquito/utils';\n * const publicKey = 'edpkvS5QFv7KRGfa3b87gg9DBpxSm3NpSwnjhUjNBQrRUUR66F7C9g'\n * const validation = validatePublicKey(publicKey)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validatePublicKey(value: any): ValidationResult {\n return validatePrefixedValue(value, pkPrefix);\n}\n","\n// IMPORTANT: THIS FILE IS AUTO GENERATED! DO NOT MANUALLY EDIT OR CHECKIN!\n/* tslint:disable */\nexport const VERSION = {\n \"commitHash\": \"8d7ecc86ce608bff9ee8c6cf0cd7d795263b8bda\",\n \"version\": \"11.0.1\"\n};\n/* tslint:enable */\n","export class InvalidPublicKeyError implements Error {\n public name: string = 'InvalidPublicKeyError';\n constructor(public message: string) {}\n }\n \n export class InvalidSignatureError implements Error {\n public name: string = 'InvalidSignatureError';\n constructor(public message: string) {}\n }\n \n export class InvalidMessageError implements Error {\n public name: string = 'InvalidMessageError';\n constructor(public message: string) {}\n }\n ","import { verify } from '@stablelib/ed25519';\nimport { hash } from '@stablelib/blake2b';\nimport {\n b58cdecode,\n buf2hex,\n hex2buf,\n Prefix,\n prefix,\n validatePublicKey,\n validateSignature,\n ValidationResult\n} from './taquito-utils';\nimport elliptic from 'elliptic';\nimport toBuffer from 'typedarray-to-buffer';\nimport { InvalidMessageError, InvalidPublicKeyError, InvalidSignatureError } from './errors';\n\ntype PkPrefix = Prefix.EDPK | Prefix.SPPK | Prefix.P2PK;\ntype SigPrefix = Prefix.EDSIG | Prefix.SPSIG | Prefix.P2SIG | Prefix.SIG;\n\n/**\n * @description Verify signature of a payload\n *\n * @param messageBytes The forged message including the magic byte (1 for block, 2 for endorsement, 3 for generic, 5 for the PACK format of michelson)\n * @param publicKey The public key to verify the signature against\n * @param signature The signature to verify\n * @returns A boolean indicating if the signature matches\n *\n * @example \n * ```\n * const message = '03d0c10e3ed11d7c6e3357f6ef335bab9e8f2bd54d0ce20c482e241191a6e4b8ce6c01be917311d9ac46959750e405d57e268e2ed9e174a80794fbd504e12a4a000141eb3781afed2f69679ff2bbe1c5375950b0e40d00ff000000005e05050505050507070100000024747a32526773486e74516b72794670707352466261313652546656503539684b72654a4d07070100000024747a315a6672455263414c42776d4171776f6e525859565142445439426a4e6a42484a750001';\n * const pk = 'sppk7c7hkPj47yjYFEHX85q46sFJGw6RBrqoVSHwAJAT4e14KJwzoey';\n * const sig = 'spsig1cdLkp1RLgUHAp13aRFkZ6MQDPp7xCnjAExGL3MBSdMDmT6JgQSX8cufyDgJRM3sinFtiCzLbsyP6d365EHoNevxhT47nx'\n * \n * const response = verifySignature(message, pk, sig);\n * ```\n *\n */\nexport function verifySignature(messageBytes: string, publicKey: string, signature: string): boolean {\n const pkPrefix = validatePkAndExtractPrefix(publicKey);\n const sigPrefix = validateSigAndExtractPrefix(signature);\n\n const decodedPublicKey = b58cdecode(publicKey, prefix[pkPrefix]);\n const decodedSig = b58cdecode(signature, prefix[sigPrefix]);\n const bytesHash = hash(hex2buf(validateMessageNotEmpty(messageBytes)), 32);\n\n if (pkPrefix === Prefix.EDPK) {\n return verifyEdSignature(decodedSig, bytesHash, decodedPublicKey);\n } else if (pkPrefix === Prefix.SPPK) {\n return verifySpSignature(decodedSig, bytesHash, decodedPublicKey);\n } else if (pkPrefix === Prefix.P2PK) {\n return verifyP2Signature(decodedSig, bytesHash, decodedPublicKey);\n } else {\n return false;\n }\n}\n\nfunction validateMessageNotEmpty(message: string) {\n if (message === '') {\n throw new InvalidMessageError(`The message provided for verifying signature cannot be empty.`);\n }\n return message;\n}\n\nfunction validatePkAndExtractPrefix(publicKey: string): PkPrefix {\n if (publicKey === '') {\n throw new InvalidPublicKeyError(`The public key provided for verifying signature cannot be empty.`);\n }\n const pkPrefix = publicKey.substring(0, 4);\n const validation = validatePublicKey(publicKey);\n if (validation !== ValidationResult.VALID) {\n if (validation === ValidationResult.INVALID_CHECKSUM) {\n throw new InvalidPublicKeyError(`The public key provided has an invalid checksum: ${publicKey}`);\n } else if (validation === ValidationResult.INVALID_LENGTH) {\n throw new InvalidPublicKeyError(`The public key provided has an invalid length: ${publicKey}`);\n } else if (validation === ValidationResult.NO_PREFIX_MATCHED) {\n throw new InvalidPublicKeyError(`The public key provided has an unsupported prefix: ${pkPrefix}`);\n }\n }\n return pkPrefix as PkPrefix;\n}\n\nfunction validateSigAndExtractPrefix(signature: string): SigPrefix {\n const signaturePrefix = signature.startsWith('sig') ? signature.substr(0, 3) : signature.substr(0, 5);\n const validation = validateSignature(signature);\n if (validation !== ValidationResult.VALID) {\n if (validation === ValidationResult.INVALID_CHECKSUM) {\n throw new InvalidSignatureError(`The signature provided has an invalid checksum: ${signature}`);\n } else if (validation === ValidationResult.INVALID_LENGTH) {\n throw new InvalidSignatureError(`The signature provided has an invalid length: ${signature}`);\n } else if (validation === ValidationResult.NO_PREFIX_MATCHED) {\n throw new InvalidSignatureError(`The signature provided has an unsupported prefix: ${signaturePrefix}`);\n }\n }\n return signaturePrefix as SigPrefix;\n}\n\nfunction verifyEdSignature(decodedSig: Uint8Array, bytesHash: Uint8Array, decodedPublicKey: Uint8Array) {\n try {\n return verify(decodedPublicKey, bytesHash, decodedSig);\n } catch (e) {\n return false;\n }\n}\n\nfunction verifySpSignature(decodedSig: Uint8Array, bytesHash: Uint8Array, decodedPublicKey: Uint8Array) {\n const key = new elliptic.ec('secp256k1').keyFromPublic(decodedPublicKey);\n return verifySpOrP2Sig(decodedSig, bytesHash, key)\n}\n\nfunction verifyP2Signature(decodedSig: Uint8Array, bytesHash: Uint8Array, decodedPublicKey: Uint8Array) {\n const key = new elliptic.ec('p256').keyFromPublic(decodedPublicKey);\n return verifySpOrP2Sig(decodedSig, bytesHash, key)\n}\n\nfunction verifySpOrP2Sig(decodedSig: Uint8Array, bytesHash: Uint8Array, key: elliptic.ec.KeyPair) {\n const hexSig = buf2hex(toBuffer(decodedSig));\n const match = hexSig.match(/([a-f\\d]{64})/gi);\n if (match) {\n try {\n const [r, s] = match;\n return key.verify(bytesHash, { r, s });\n } catch (e) {\n return false;\n }\n }\n return false;\n}\n","/**\n * @packageDocumentation\n * @module @taquito/utils\n */\n\n/*\n * Some code in this file is originally from sotez and eztz\n * Copyright (c) 2018 Andrew Kishino\n * Copyright (c) 2017 Stephen Andrews\n */\n\nimport { Buffer } from 'buffer';\nimport { prefix } from './constants';\nconst blake = require('blakejs');\nconst bs58check = require('bs58check');\n\nexport * from './validators';\nexport { VERSION } from './version';\n\nexport { prefix, Prefix, prefixLength } from './constants';\n\nexport { verifySignature } from './verify-signature';\n\n/**\n *\n * @description Hash a string using the BLAKE2b algorithm, base58 encode the hash obtained and appends the prefix 'expr' to it\n *\n * @param value Value in hex\n */\nexport function encodeExpr(value: string) {\n const blakeHash = blake.blake2b(hex2buf(value), null, 32);\n return b58cencode(blakeHash, prefix['expr']);\n}\n\n/**\n *\n * @description Return the operation hash of a signed operation \n * @param value Value in hex of a signed operation\n */\n export function encodeOpHash(value: string) {\n const blakeHash = blake.blake2b(hex2buf(value), null, 32);\n return b58cencode(blakeHash, prefix.o);\n}\n\n/**\n *\n * @description Base58 encode a string or a Uint8Array and append a prefix to it\n *\n * @param value Value to base58 encode\n * @param prefix prefix to append to the encoded string\n */\nexport function b58cencode(value: string | Uint8Array, prefix: Uint8Array) {\n const payloadAr = typeof value === 'string' ? Uint8Array.from(Buffer.from(value, 'hex')) : value;\n\n const n = new Uint8Array(prefix.length + payloadAr.length);\n n.set(prefix);\n n.set(payloadAr, prefix.length);\n\n return bs58check.encode(Buffer.from(n.buffer));\n}\n\n/**\n *\n * @description Base58 decode a string and remove the prefix from it\n *\n * @param value Value to base58 decode\n * @param prefix prefix to remove from the decoded string\n */\nexport const b58cdecode = (enc: string, prefixArg: Uint8Array): Uint8Array =>\n bs58check.decode(enc).slice(prefixArg.length);\n\n/**\n *\n * @description Base58 decode a string with predefined prefix\n *\n * @param value Value to base58 decode\n */\nexport function b58decode(payload: string) {\n const buf: Buffer = bs58check.decode(payload);\n\n const prefixMap = {\n [prefix.tz1.toString()]: '0000',\n [prefix.tz2.toString()]: '0001',\n [prefix.tz3.toString()]: '0002',\n };\n\n let pref = prefixMap[new Uint8Array(buf.slice(0, 3)).toString()];\n if (pref) {\n // tz addresses\n const hex = buf2hex(buf.slice(3));\n return pref + hex;\n } else {\n // other (kt addresses)\n return '01' + buf2hex(buf.slice(3, 42)) + '00';\n }\n}\n\n/**\n *\n * @description Base58 encode a public key using predefined prefix\n *\n * @param value Public Key to base58 encode\n */\nexport function encodePubKey(value: string) {\n if (value.substring(0, 2) === '00') {\n const pref: { [key: string]: Uint8Array } = {\n '0000': prefix.tz1,\n '0001': prefix.tz2,\n '0002': prefix.tz3,\n };\n\n return b58cencode(value.substring(4), pref[value.substring(0, 4)]);\n }\n\n return b58cencode(value.substring(2, 42), prefix.KT);\n}\n\n/**\n *\n * @description Base58 encode a key according to its prefix\n *\n * @param value Key to base58 encode\n */\nexport function encodeKey(value: string) {\n if (value[0] === '0') {\n const pref: { [key: string]: Uint8Array } = {\n '00': new Uint8Array([13, 15, 37, 217]),\n '01': new Uint8Array([3, 254, 226, 86]),\n '02': new Uint8Array([3, 178, 139, 127]),\n };\n\n return b58cencode(value.substring(2), pref[value.substring(0, 2)]);\n }\n}\n\n/**\n *\n * @description Base58 encode a key hash according to its prefix\n *\n * @param value Key to base58 encode\n */\nexport function encodeKeyHash(value: string) {\n if (value[0] === '0') {\n const pref: { [key: string]: Uint8Array } = {\n '00': new Uint8Array([6, 161, 159]),\n '01': new Uint8Array([6, 161, 161]),\n '02': new Uint8Array([6, 161, 164]),\n };\n\n return b58cencode(value.substring(2), pref[value.substring(0, 2)]);\n }\n}\n\n/**\n *\n * @description Convert an hex string to a Uint8Array\n *\n * @param hex Hex string to convert\n */\nexport const hex2buf = (hex: string): Uint8Array => {\n return new Uint8Array(hex.match(/[\\da-f]{2}/gi)!.map((h) => parseInt(h, 16)));\n};\n\n/**\n *\n * @description Merge 2 buffers together\n *\n * @param b1 First buffer\n * @param b2 Second buffer\n */\nexport const mergebuf = (b1: Uint8Array, b2: Uint8Array): Uint8Array => {\n const r = new Uint8Array(b1.length + b2.length);\n r.set(b1);\n r.set(b2, b1.length);\n return r;\n};\n\n/**\n *\n * @description Flatten a michelson json representation to an array\n *\n * @param s michelson json\n */\nexport const mic2arr = function me2(s: any): any {\n let ret: any = [];\n if (Object.prototype.hasOwnProperty.call(s, 'prim')) {\n if (s.prim === 'Pair') {\n ret.push(me2(s.args[0]));\n ret = ret.concat(me2(s.args[1]));\n } else if (s.prim === 'Elt') {\n ret = {\n key: me2(s.args[0]),\n val: me2(s.args[1]),\n };\n } else if (s.prim === 'True') {\n ret = true;\n } else if (s.prim === 'False') {\n ret = false;\n }\n } else if (Array.isArray(s)) {\n const sc = s.length;\n for (let i = 0; i < sc; i++) {\n const n = me2(s[i]);\n if (typeof n.key !== 'undefined') {\n if (Array.isArray(ret)) {\n ret = {\n keys: [],\n vals: [],\n };\n }\n ret.keys.push(n.key);\n ret.vals.push(n.val);\n } else {\n ret.push(n);\n }\n }\n } else if (Object.prototype.hasOwnProperty.call(s, 'string')) {\n ret = s.string;\n } else if (Object.prototype.hasOwnProperty.call(s, 'int')) {\n ret = parseInt(s.int, 10);\n } else {\n ret = s;\n }\n return ret;\n};\n\n/**\n *\n * @description Convert a buffer to an hex string\n *\n * @param buffer Buffer to convert\n */\nexport const buf2hex = (buffer: Buffer): string => {\n const byteArray = new Uint8Array(buffer);\n const hexParts: string[] = [];\n byteArray.forEach((byte: any) => {\n const hex = byte.toString(16);\n const paddedHex = `00${hex}`.slice(-2);\n hexParts.push(paddedHex);\n });\n return hexParts.join('');\n};\n\n/**\n *\n * @description Convert a string to bytes\n *\n * @param str String to convert\n */\nexport function char2Bytes(str: string) {\n return Buffer.from(str, 'utf8').toString('hex');\n}\n\n/**\n *\n * @description Convert bytes to a string\n *\n * @param str Bytes to convert\n */\nexport function bytes2Char(hex: string): string {\n return Buffer.from(hex2buf(hex)).toString('utf8');\n}\n"],"names":["bs58check"],"mappings":"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"}
@@ -1,8 +1,13 @@
1
1
  (function (global, factory) {
2
- typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('buffer')) :
3
- typeof define === 'function' && define.amd ? define(['exports', 'buffer'], factory) :
4
- (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.taquitoUtils = {}, global.buffer));
5
- }(this, (function (exports, buffer) { 'use strict';
2
+ typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('buffer'), require('@stablelib/ed25519'), require('@stablelib/blake2b'), require('elliptic'), require('typedarray-to-buffer')) :
3
+ typeof define === 'function' && define.amd ? define(['exports', 'buffer', '@stablelib/ed25519', '@stablelib/blake2b', 'elliptic', 'typedarray-to-buffer'], factory) :
4
+ (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.taquitoUtils = {}, global.buffer, global.ed25519, global.blake2b, global.elliptic, global.toBuffer));
5
+ }(this, (function (exports, buffer, ed25519, blake2b, elliptic, toBuffer) { 'use strict';
6
+
7
+ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
8
+
9
+ var elliptic__default = /*#__PURE__*/_interopDefaultLegacy(elliptic);
10
+ var toBuffer__default = /*#__PURE__*/_interopDefaultLegacy(toBuffer);
6
11
 
7
12
  var _a, _b;
8
13
  exports.Prefix = void 0;
@@ -122,10 +127,11 @@
122
127
  return ar;
123
128
  }
124
129
 
125
- function __spreadArray(to, from) {
126
- for (var i = 0, il = from.length, j = to.length; i < il; i++, j++)
127
- to[j] = from[i];
128
- return to;
130
+ /** @deprecated */
131
+ function __spread() {
132
+ for (var ar = [], i = 0; i < arguments.length; i++)
133
+ ar = ar.concat(__read(arguments[i]));
134
+ return ar;
129
135
  }
130
136
 
131
137
  var bs58check$1 = require('bs58check');
@@ -197,7 +203,7 @@
197
203
  * ```
198
204
  */
199
205
  function validateAddress(value) {
200
- return validatePrefixedValue(value, __spreadArray(__spreadArray([], __read(implicitPrefix)), __read(contractPrefix)));
206
+ return validatePrefixedValue(value, __spread(implicitPrefix, contractPrefix));
201
207
  }
202
208
  /**
203
209
  * @description Used to check if a chain id is valid.
@@ -280,7 +286,7 @@
280
286
  * @example
281
287
  * ```
282
288
  * import { validatePublicKey } from '@taquito/utils';
283
- * const publicKey = 'edsigtkpiSSschcaCt9pUVrpNPf7TTcgvgDEDD6NCEHMy8NNQJCGnMfLZzYoQj74yLjo9wx6MPVV29CvVzgi7qEcEUok3k7AuMg'
289
+ * const publicKey = 'edpkvS5QFv7KRGfa3b87gg9DBpxSm3NpSwnjhUjNBQrRUUR66F7C9g'
284
290
  * const validation = validatePublicKey(publicKey)
285
291
  * console.log(validation)
286
292
  * // This example return 3 which correspond to VALID
@@ -293,11 +299,142 @@
293
299
  // IMPORTANT: THIS FILE IS AUTO GENERATED! DO NOT MANUALLY EDIT OR CHECKIN!
294
300
  /* tslint:disable */
295
301
  var VERSION = {
296
- "commitHash": "5711569ffaf481d88ba3251343a1788090b35dd4",
297
- "version": "10.2.1"
302
+ "commitHash": "8d7ecc86ce608bff9ee8c6cf0cd7d795263b8bda",
303
+ "version": "11.0.1"
298
304
  };
299
305
  /* tslint:enable */
300
306
 
307
+ var InvalidPublicKeyError = /** @class */ (function () {
308
+ function InvalidPublicKeyError(message) {
309
+ this.message = message;
310
+ this.name = 'InvalidPublicKeyError';
311
+ }
312
+ return InvalidPublicKeyError;
313
+ }());
314
+ var InvalidSignatureError = /** @class */ (function () {
315
+ function InvalidSignatureError(message) {
316
+ this.message = message;
317
+ this.name = 'InvalidSignatureError';
318
+ }
319
+ return InvalidSignatureError;
320
+ }());
321
+ var InvalidMessageError = /** @class */ (function () {
322
+ function InvalidMessageError(message) {
323
+ this.message = message;
324
+ this.name = 'InvalidMessageError';
325
+ }
326
+ return InvalidMessageError;
327
+ }());
328
+
329
+ /**
330
+ * @description Verify signature of a payload
331
+ *
332
+ * @param messageBytes The forged message including the magic byte (1 for block, 2 for endorsement, 3 for generic, 5 for the PACK format of michelson)
333
+ * @param publicKey The public key to verify the signature against
334
+ * @param signature The signature to verify
335
+ * @returns A boolean indicating if the signature matches
336
+ *
337
+ * @example
338
+ * ```
339
+ * const message = '03d0c10e3ed11d7c6e3357f6ef335bab9e8f2bd54d0ce20c482e241191a6e4b8ce6c01be917311d9ac46959750e405d57e268e2ed9e174a80794fbd504e12a4a000141eb3781afed2f69679ff2bbe1c5375950b0e40d00ff000000005e05050505050507070100000024747a32526773486e74516b72794670707352466261313652546656503539684b72654a4d07070100000024747a315a6672455263414c42776d4171776f6e525859565142445439426a4e6a42484a750001';
340
+ * const pk = 'sppk7c7hkPj47yjYFEHX85q46sFJGw6RBrqoVSHwAJAT4e14KJwzoey';
341
+ * const sig = 'spsig1cdLkp1RLgUHAp13aRFkZ6MQDPp7xCnjAExGL3MBSdMDmT6JgQSX8cufyDgJRM3sinFtiCzLbsyP6d365EHoNevxhT47nx'
342
+ *
343
+ * const response = verifySignature(message, pk, sig);
344
+ * ```
345
+ *
346
+ */
347
+ function verifySignature(messageBytes, publicKey, signature) {
348
+ var pkPrefix = validatePkAndExtractPrefix(publicKey);
349
+ var sigPrefix = validateSigAndExtractPrefix(signature);
350
+ var decodedPublicKey = b58cdecode(publicKey, prefix[pkPrefix]);
351
+ var decodedSig = b58cdecode(signature, prefix[sigPrefix]);
352
+ var bytesHash = blake2b.hash(hex2buf(validateMessageNotEmpty(messageBytes)), 32);
353
+ if (pkPrefix === exports.Prefix.EDPK) {
354
+ return verifyEdSignature(decodedSig, bytesHash, decodedPublicKey);
355
+ }
356
+ else if (pkPrefix === exports.Prefix.SPPK) {
357
+ return verifySpSignature(decodedSig, bytesHash, decodedPublicKey);
358
+ }
359
+ else if (pkPrefix === exports.Prefix.P2PK) {
360
+ return verifyP2Signature(decodedSig, bytesHash, decodedPublicKey);
361
+ }
362
+ else {
363
+ return false;
364
+ }
365
+ }
366
+ function validateMessageNotEmpty(message) {
367
+ if (message === '') {
368
+ throw new InvalidMessageError("The message provided for verifying signature cannot be empty.");
369
+ }
370
+ return message;
371
+ }
372
+ function validatePkAndExtractPrefix(publicKey) {
373
+ if (publicKey === '') {
374
+ throw new InvalidPublicKeyError("The public key provided for verifying signature cannot be empty.");
375
+ }
376
+ var pkPrefix = publicKey.substring(0, 4);
377
+ var validation = validatePublicKey(publicKey);
378
+ if (validation !== exports.ValidationResult.VALID) {
379
+ if (validation === exports.ValidationResult.INVALID_CHECKSUM) {
380
+ throw new InvalidPublicKeyError("The public key provided has an invalid checksum: " + publicKey);
381
+ }
382
+ else if (validation === exports.ValidationResult.INVALID_LENGTH) {
383
+ throw new InvalidPublicKeyError("The public key provided has an invalid length: " + publicKey);
384
+ }
385
+ else if (validation === exports.ValidationResult.NO_PREFIX_MATCHED) {
386
+ throw new InvalidPublicKeyError("The public key provided has an unsupported prefix: " + pkPrefix);
387
+ }
388
+ }
389
+ return pkPrefix;
390
+ }
391
+ function validateSigAndExtractPrefix(signature) {
392
+ var signaturePrefix = signature.startsWith('sig') ? signature.substr(0, 3) : signature.substr(0, 5);
393
+ var validation = validateSignature(signature);
394
+ if (validation !== exports.ValidationResult.VALID) {
395
+ if (validation === exports.ValidationResult.INVALID_CHECKSUM) {
396
+ throw new InvalidSignatureError("The signature provided has an invalid checksum: " + signature);
397
+ }
398
+ else if (validation === exports.ValidationResult.INVALID_LENGTH) {
399
+ throw new InvalidSignatureError("The signature provided has an invalid length: " + signature);
400
+ }
401
+ else if (validation === exports.ValidationResult.NO_PREFIX_MATCHED) {
402
+ throw new InvalidSignatureError("The signature provided has an unsupported prefix: " + signaturePrefix);
403
+ }
404
+ }
405
+ return signaturePrefix;
406
+ }
407
+ function verifyEdSignature(decodedSig, bytesHash, decodedPublicKey) {
408
+ try {
409
+ return ed25519.verify(decodedPublicKey, bytesHash, decodedSig);
410
+ }
411
+ catch (e) {
412
+ return false;
413
+ }
414
+ }
415
+ function verifySpSignature(decodedSig, bytesHash, decodedPublicKey) {
416
+ var key = new elliptic__default['default'].ec('secp256k1').keyFromPublic(decodedPublicKey);
417
+ return verifySpOrP2Sig(decodedSig, bytesHash, key);
418
+ }
419
+ function verifyP2Signature(decodedSig, bytesHash, decodedPublicKey) {
420
+ var key = new elliptic__default['default'].ec('p256').keyFromPublic(decodedPublicKey);
421
+ return verifySpOrP2Sig(decodedSig, bytesHash, key);
422
+ }
423
+ function verifySpOrP2Sig(decodedSig, bytesHash, key) {
424
+ var hexSig = buf2hex(toBuffer__default['default'](decodedSig));
425
+ var match = hexSig.match(/([a-f\d]{64})/gi);
426
+ if (match) {
427
+ try {
428
+ var _a = __read(match, 2), r = _a[0], s = _a[1];
429
+ return key.verify(bytesHash, { r: r, s: s });
430
+ }
431
+ catch (e) {
432
+ return false;
433
+ }
434
+ }
435
+ return false;
436
+ }
437
+
301
438
  /**
302
439
  * @packageDocumentation
303
440
  * @module @taquito/utils
@@ -558,6 +695,7 @@
558
695
  exports.validateKeyHash = validateKeyHash;
559
696
  exports.validatePublicKey = validatePublicKey;
560
697
  exports.validateSignature = validateSignature;
698
+ exports.verifySignature = verifySignature;
561
699
 
562
700
  Object.defineProperty(exports, '__esModule', { value: true });
563
701
 
@@ -1 +1 @@
1
- {"version":3,"file":"taquito-utils.umd.js","sources":["../src/constants.ts","../src/validators.ts","../src/version.ts","../src/taquito-utils.ts"],"sourcesContent":["export enum Prefix {\n TZ1 = 'tz1',\n TZ2 = 'tz2',\n TZ3 = 'tz3',\n KT = 'KT',\n KT1 = 'KT1',\n\n EDSK2 = 'edsk2',\n SPSK = 'spsk',\n P2SK = 'p2sk',\n\n EDPK = 'edpk',\n SPPK = 'sppk',\n P2PK = 'p2pk',\n\n EDESK = 'edesk',\n SPESK = 'spesk',\n P2ESK = 'p2esk',\n\n EDSK = 'edsk',\n EDSIG = 'edsig',\n SPSIG = 'spsig',\n P2SIG = 'p2sig',\n SIG = 'sig',\n\n NET = 'Net',\n NCE = 'nce',\n B = 'b',\n O = 'o',\n LO = 'Lo',\n LLO = 'LLo',\n P = 'P',\n CO = 'Co',\n ID = 'id',\n\n EXPR = 'expr',\n TZ = 'TZ',\n}\n\nexport const prefix = {\n [Prefix.TZ1]: new Uint8Array([6, 161, 159]),\n [Prefix.TZ2]: new Uint8Array([6, 161, 161]),\n [Prefix.TZ3]: new Uint8Array([6, 161, 164]),\n [Prefix.KT]: new Uint8Array([2, 90, 121]),\n [Prefix.KT1]: new Uint8Array([2, 90, 121]),\n\n [Prefix.EDSK]: new Uint8Array([43, 246, 78, 7]),\n [Prefix.EDSK2]: new Uint8Array([13, 15, 58, 7]),\n [Prefix.SPSK]: new Uint8Array([17, 162, 224, 201]),\n [Prefix.P2SK]: new Uint8Array([16, 81, 238, 189]),\n\n [Prefix.EDPK]: new Uint8Array([13, 15, 37, 217]),\n [Prefix.SPPK]: new Uint8Array([3, 254, 226, 86]),\n [Prefix.P2PK]: new Uint8Array([3, 178, 139, 127]),\n\n [Prefix.EDESK]: new Uint8Array([7, 90, 60, 179, 41]),\n [Prefix.SPESK]: new Uint8Array([0x09, 0xed, 0xf1, 0xae, 0x96]),\n [Prefix.P2ESK]: new Uint8Array([0x09, 0x30, 0x39, 0x73, 0xab]),\n\n [Prefix.EDSIG]: new Uint8Array([9, 245, 205, 134, 18]),\n [Prefix.SPSIG]: new Uint8Array([13, 115, 101, 19, 63]),\n [Prefix.P2SIG]: new Uint8Array([54, 240, 44, 52]),\n [Prefix.SIG]: new Uint8Array([4, 130, 43]),\n\n [Prefix.NET]: new Uint8Array([87, 82, 0]),\n [Prefix.NCE]: new Uint8Array([69, 220, 169]),\n [Prefix.B]: new Uint8Array([1, 52]),\n [Prefix.O]: new Uint8Array([5, 116]),\n [Prefix.LO]: new Uint8Array([133, 233]),\n [Prefix.LLO]: new Uint8Array([29, 159, 109]),\n [Prefix.P]: new Uint8Array([2, 170]),\n [Prefix.CO]: new Uint8Array([79, 179]),\n [Prefix.ID]: new Uint8Array([153, 103]),\n\n [Prefix.EXPR]: new Uint8Array([13, 44, 64, 27]),\n // Legacy prefix\n [Prefix.TZ]: new Uint8Array([2, 90, 121]),\n};\n\nexport const prefixLength: { [key: string]: number } = {\n [Prefix.TZ1]: 20,\n [Prefix.TZ2]: 20,\n [Prefix.TZ3]: 20,\n [Prefix.KT]: 20,\n [Prefix.KT1]: 20,\n [Prefix.EDPK]: 32,\n [Prefix.SPPK]: 33,\n [Prefix.P2PK]: 33,\n [Prefix.EDSIG]: 64,\n [Prefix.SPSIG]: 64,\n [Prefix.P2SIG]: 64,\n [Prefix.SIG]: 64,\n [Prefix.NET]: 4,\n [Prefix.B]: 32,\n [Prefix.P]: 32,\n [Prefix.O]: 32\n};\n","import { prefix, prefixLength, Prefix } from './constants';\n\nconst bs58check = require('bs58check');\n\nexport enum ValidationResult {\n NO_PREFIX_MATCHED,\n INVALID_CHECKSUM,\n INVALID_LENGTH,\n VALID,\n}\n\nexport function isValidPrefix(value: any): value is Prefix {\n if (typeof value !== 'string') {\n return false;\n }\n\n return value in prefix;\n}\n /**\n * @description This function is called by the validation functions ([[validateAddress]], [[validateChain]], [[validateContractAddress]], [[validateKeyHash]], [[validateSignature]], [[validatePublicKey]]).\n * Verify if the value has the right prefix or return `NO_PREFIX_MATCHED`,\n * decode the value using base58 and return `INVALID_CHECKSUM` if it fails,\n * check if the length of the value matches the prefix type or return `INVALID_LENGTH`.\n * If all checks pass, return `VALID`.\n *\n * @param value Value to validate\n * @param prefixes prefix the value should have\n */\nfunction validatePrefixedValue(value: any, prefixes: Prefix[]) {\n const match = new RegExp(`^(${prefixes.join('|')})`).exec(value);\n if (!match || match.length === 0) {\n return ValidationResult.NO_PREFIX_MATCHED;\n }\n\n const prefixKey = match[0];\n\n if (!isValidPrefix(prefixKey)) {\n return ValidationResult.NO_PREFIX_MATCHED;\n }\n\n // Remove annotation from contract address before doing the validation\n const contractAddress = /^(KT1\\w{33})(\\%(.*))?/.exec(value);\n if (contractAddress) {\n value = contractAddress[1];\n }\n\n // decodeUnsafe return undefined if decoding fail\n let decoded = bs58check.decodeUnsafe(value);\n if (!decoded) {\n return ValidationResult.INVALID_CHECKSUM;\n }\n\n decoded = decoded.slice(prefix[prefixKey].length);\n if (decoded.length !== prefixLength[prefixKey]) {\n return ValidationResult.INVALID_LENGTH;\n }\n\n return ValidationResult.VALID;\n}\n\nconst implicitPrefix = [Prefix.TZ1, Prefix.TZ2, Prefix.TZ3];\nconst contractPrefix = [Prefix.KT1];\nconst signaturePrefix = [Prefix.EDSIG, Prefix.P2SIG, Prefix.SPSIG, Prefix.SIG];\nconst pkPrefix = [Prefix.EDPK, Prefix.SPPK, Prefix.P2PK];\n\n /**\n * @description Used to check if an address or a contract address is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateAddress } from '@taquito/utils';\n * const pkh = 'tz1L9r8mWmRPndRhuvMCWESLGSVeFzQ9NAWx'\n * const validation = validateAddress(pkh)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validateAddress(value: any): ValidationResult {\n return validatePrefixedValue(value, [...implicitPrefix, ...contractPrefix]);\n}\n /**\n * @description Used to check if a chain id is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateChain } from '@taquito/utils';\n * const chainId = 'NetXdQprcVkpaWU'\n * const validation = validateChain(chainId)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validateChain(value: any): ValidationResult {\n return validatePrefixedValue(value, [Prefix.NET]);\n}\n /**\n * @description Used to check if a contract address is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateContractAddress } from '@taquito/utils';\n * const contractAddress = 'KT1JVErLYTgtY8uGGZ4mso2npTSxqVLDRVbC'\n * const validation = validateContractAddress(contractAddress)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validateContractAddress(value: any): ValidationResult {\n return validatePrefixedValue(value, contractPrefix);\n}\n /**\n * @description Used to check if a key hash is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateKeyHash } from '@taquito/utils';\n * const keyHashWithoutPrefix = '1L9r8mWmRPndRhuvMCWESLGSVeFzQ9NAWx'\n * const validation = validateKeyHash(keyHashWithoutPrefix)\n * console.log(validation)\n * // This example return 0 which correspond to NO_PREFIX_MATCHED\n * ```\n */\nexport function validateKeyHash(value: any): ValidationResult {\n return validatePrefixedValue(value, implicitPrefix);\n}\n /**\n * @description Used to check if a signature is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateSignature } from '@taquito/utils';\n * const signature = 'edsigtkpiSSschcaCt9pUVrpNPf7TTcgvgDEDD6NCEHMy8NNQJCGnMfLZzYoQj74yLjo9wx6MPVV29CvVzgi7qEcEUok3k7AuMg'\n * const validation = validateSignature(signature)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validateSignature(value: any): ValidationResult {\n return validatePrefixedValue(value, signaturePrefix);\n}\n /**\n * @description Used to check if a signature is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validatePublicKey } from '@taquito/utils';\n * const publicKey = 'edsigtkpiSSschcaCt9pUVrpNPf7TTcgvgDEDD6NCEHMy8NNQJCGnMfLZzYoQj74yLjo9wx6MPVV29CvVzgi7qEcEUok3k7AuMg'\n * const validation = validatePublicKey(publicKey)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validatePublicKey(value: any): ValidationResult {\n return validatePrefixedValue(value, pkPrefix);\n}\n","\n// IMPORTANT: THIS FILE IS AUTO GENERATED! DO NOT MANUALLY EDIT OR CHECKIN!\n/* tslint:disable */\nexport const VERSION = {\n \"commitHash\": \"5711569ffaf481d88ba3251343a1788090b35dd4\",\n \"version\": \"10.2.1\"\n};\n/* tslint:enable */\n","/**\n * @packageDocumentation\n * @module @taquito/utils\n */\n\n/*\n * Some code in this file is originally from sotez and eztz\n * Copyright (c) 2018 Andrew Kishino\n * Copyright (c) 2017 Stephen Andrews\n */\n\nimport { Buffer } from 'buffer';\nimport { prefix } from './constants';\nconst blake = require('blakejs');\nconst bs58check = require('bs58check');\n\nexport * from './validators';\nexport { VERSION } from './version';\n\nexport { prefix, Prefix, prefixLength } from './constants';\n\n/**\n *\n * @description Hash a string using the BLAKE2b algorithm, base58 encode the hash obtained and appends the prefix 'expr' to it\n *\n * @param value Value in hex\n */\nexport function encodeExpr(value: string) {\n const blakeHash = blake.blake2b(hex2buf(value), null, 32);\n return b58cencode(blakeHash, prefix['expr']);\n}\n\n/**\n *\n * @description Return the operation hash of a signed operation \n * @param value Value in hex of a signed operation\n */\n export function encodeOpHash(value: string) {\n const blakeHash = blake.blake2b(hex2buf(value), null, 32);\n return b58cencode(blakeHash, prefix.o);\n}\n\n/**\n *\n * @description Base58 encode a string or a Uint8Array and append a prefix to it\n *\n * @param value Value to base58 encode\n * @param prefix prefix to append to the encoded string\n */\nexport function b58cencode(value: string | Uint8Array, prefix: Uint8Array) {\n const payloadAr = typeof value === 'string' ? Uint8Array.from(Buffer.from(value, 'hex')) : value;\n\n const n = new Uint8Array(prefix.length + payloadAr.length);\n n.set(prefix);\n n.set(payloadAr, prefix.length);\n\n return bs58check.encode(Buffer.from(n.buffer));\n}\n\n/**\n *\n * @description Base58 decode a string and remove the prefix from it\n *\n * @param value Value to base58 decode\n * @param prefix prefix to remove from the decoded string\n */\nexport const b58cdecode = (enc: string, prefixArg: Uint8Array): Uint8Array =>\n bs58check.decode(enc).slice(prefixArg.length);\n\n/**\n *\n * @description Base58 decode a string with predefined prefix\n *\n * @param value Value to base58 decode\n */\nexport function b58decode(payload: string) {\n const buf: Buffer = bs58check.decode(payload);\n\n const prefixMap = {\n [prefix.tz1.toString()]: '0000',\n [prefix.tz2.toString()]: '0001',\n [prefix.tz3.toString()]: '0002',\n };\n\n let pref = prefixMap[new Uint8Array(buf.slice(0, 3)).toString()];\n if (pref) {\n // tz addresses\n const hex = buf2hex(buf.slice(3));\n return pref + hex;\n } else {\n // other (kt addresses)\n return '01' + buf2hex(buf.slice(3, 42)) + '00';\n }\n}\n\n/**\n *\n * @description Base58 encode a public key using predefined prefix\n *\n * @param value Public Key to base58 encode\n */\nexport function encodePubKey(value: string) {\n if (value.substring(0, 2) === '00') {\n const pref: { [key: string]: Uint8Array } = {\n '0000': prefix.tz1,\n '0001': prefix.tz2,\n '0002': prefix.tz3,\n };\n\n return b58cencode(value.substring(4), pref[value.substring(0, 4)]);\n }\n\n return b58cencode(value.substring(2, 42), prefix.KT);\n}\n\n/**\n *\n * @description Base58 encode a key according to its prefix\n *\n * @param value Key to base58 encode\n */\nexport function encodeKey(value: string) {\n if (value[0] === '0') {\n const pref: { [key: string]: Uint8Array } = {\n '00': new Uint8Array([13, 15, 37, 217]),\n '01': new Uint8Array([3, 254, 226, 86]),\n '02': new Uint8Array([3, 178, 139, 127]),\n };\n\n return b58cencode(value.substring(2), pref[value.substring(0, 2)]);\n }\n}\n\n/**\n *\n * @description Base58 encode a key hash according to its prefix\n *\n * @param value Key to base58 encode\n */\nexport function encodeKeyHash(value: string) {\n if (value[0] === '0') {\n const pref: { [key: string]: Uint8Array } = {\n '00': new Uint8Array([6, 161, 159]),\n '01': new Uint8Array([6, 161, 161]),\n '02': new Uint8Array([6, 161, 164]),\n };\n\n return b58cencode(value.substring(2), pref[value.substring(0, 2)]);\n }\n}\n\n/**\n *\n * @description Convert an hex string to a Uint8Array\n *\n * @param hex Hex string to convert\n */\nexport const hex2buf = (hex: string): Uint8Array => {\n return new Uint8Array(hex.match(/[\\da-f]{2}/gi)!.map((h) => parseInt(h, 16)));\n};\n\n/**\n *\n * @description Merge 2 buffers together\n *\n * @param b1 First buffer\n * @param b2 Second buffer\n */\nexport const mergebuf = (b1: Uint8Array, b2: Uint8Array): Uint8Array => {\n const r = new Uint8Array(b1.length + b2.length);\n r.set(b1);\n r.set(b2, b1.length);\n return r;\n};\n\n/**\n *\n * @description Flatten a michelson json representation to an array\n *\n * @param s michelson json\n */\nexport const mic2arr = function me2(s: any): any {\n let ret: any = [];\n if (Object.prototype.hasOwnProperty.call(s, 'prim')) {\n if (s.prim === 'Pair') {\n ret.push(me2(s.args[0]));\n ret = ret.concat(me2(s.args[1]));\n } else if (s.prim === 'Elt') {\n ret = {\n key: me2(s.args[0]),\n val: me2(s.args[1]),\n };\n } else if (s.prim === 'True') {\n ret = true;\n } else if (s.prim === 'False') {\n ret = false;\n }\n } else if (Array.isArray(s)) {\n const sc = s.length;\n for (let i = 0; i < sc; i++) {\n const n = me2(s[i]);\n if (typeof n.key !== 'undefined') {\n if (Array.isArray(ret)) {\n ret = {\n keys: [],\n vals: [],\n };\n }\n ret.keys.push(n.key);\n ret.vals.push(n.val);\n } else {\n ret.push(n);\n }\n }\n } else if (Object.prototype.hasOwnProperty.call(s, 'string')) {\n ret = s.string;\n } else if (Object.prototype.hasOwnProperty.call(s, 'int')) {\n ret = parseInt(s.int, 10);\n } else {\n ret = s;\n }\n return ret;\n};\n\n/**\n *\n * @description Convert a buffer to an hex string\n *\n * @param buffer Buffer to convert\n */\nexport const buf2hex = (buffer: Buffer): string => {\n const byteArray = new Uint8Array(buffer);\n const hexParts: string[] = [];\n byteArray.forEach((byte: any) => {\n const hex = byte.toString(16);\n const paddedHex = `00${hex}`.slice(-2);\n hexParts.push(paddedHex);\n });\n return hexParts.join('');\n};\n\n/**\n *\n * @description Convert a string to bytes\n *\n * @param str String to convert\n */\nexport function char2Bytes(str: string) {\n return Buffer.from(str, 'utf8').toString('hex');\n}\n\n/**\n *\n * @description Convert bytes to a string\n *\n * @param str Bytes to convert\n */\nexport function bytes2Char(hex: string): string {\n return Buffer.from(hex2buf(hex)).toString('utf8');\n}\n"],"names":["Prefix","bs58check","ValidationResult","Buffer"],"mappings":"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"}
1
+ {"version":3,"file":"taquito-utils.umd.js","sources":["../src/constants.ts","../src/validators.ts","../src/version.ts","../src/errors.ts","../src/verify-signature.ts","../src/taquito-utils.ts"],"sourcesContent":["export enum Prefix {\n TZ1 = 'tz1',\n TZ2 = 'tz2',\n TZ3 = 'tz3',\n KT = 'KT',\n KT1 = 'KT1',\n\n EDSK2 = 'edsk2',\n SPSK = 'spsk',\n P2SK = 'p2sk',\n\n EDPK = 'edpk',\n SPPK = 'sppk',\n P2PK = 'p2pk',\n\n EDESK = 'edesk',\n SPESK = 'spesk',\n P2ESK = 'p2esk',\n\n EDSK = 'edsk',\n EDSIG = 'edsig',\n SPSIG = 'spsig',\n P2SIG = 'p2sig',\n SIG = 'sig',\n\n NET = 'Net',\n NCE = 'nce',\n B = 'b',\n O = 'o',\n LO = 'Lo',\n LLO = 'LLo',\n P = 'P',\n CO = 'Co',\n ID = 'id',\n\n EXPR = 'expr',\n TZ = 'TZ',\n}\n\nexport const prefix = {\n [Prefix.TZ1]: new Uint8Array([6, 161, 159]),\n [Prefix.TZ2]: new Uint8Array([6, 161, 161]),\n [Prefix.TZ3]: new Uint8Array([6, 161, 164]),\n [Prefix.KT]: new Uint8Array([2, 90, 121]),\n [Prefix.KT1]: new Uint8Array([2, 90, 121]),\n\n [Prefix.EDSK]: new Uint8Array([43, 246, 78, 7]),\n [Prefix.EDSK2]: new Uint8Array([13, 15, 58, 7]),\n [Prefix.SPSK]: new Uint8Array([17, 162, 224, 201]),\n [Prefix.P2SK]: new Uint8Array([16, 81, 238, 189]),\n\n [Prefix.EDPK]: new Uint8Array([13, 15, 37, 217]),\n [Prefix.SPPK]: new Uint8Array([3, 254, 226, 86]),\n [Prefix.P2PK]: new Uint8Array([3, 178, 139, 127]),\n\n [Prefix.EDESK]: new Uint8Array([7, 90, 60, 179, 41]),\n [Prefix.SPESK]: new Uint8Array([0x09, 0xed, 0xf1, 0xae, 0x96]),\n [Prefix.P2ESK]: new Uint8Array([0x09, 0x30, 0x39, 0x73, 0xab]),\n\n [Prefix.EDSIG]: new Uint8Array([9, 245, 205, 134, 18]),\n [Prefix.SPSIG]: new Uint8Array([13, 115, 101, 19, 63]),\n [Prefix.P2SIG]: new Uint8Array([54, 240, 44, 52]),\n [Prefix.SIG]: new Uint8Array([4, 130, 43]),\n\n [Prefix.NET]: new Uint8Array([87, 82, 0]),\n [Prefix.NCE]: new Uint8Array([69, 220, 169]),\n [Prefix.B]: new Uint8Array([1, 52]),\n [Prefix.O]: new Uint8Array([5, 116]),\n [Prefix.LO]: new Uint8Array([133, 233]),\n [Prefix.LLO]: new Uint8Array([29, 159, 109]),\n [Prefix.P]: new Uint8Array([2, 170]),\n [Prefix.CO]: new Uint8Array([79, 179]),\n [Prefix.ID]: new Uint8Array([153, 103]),\n\n [Prefix.EXPR]: new Uint8Array([13, 44, 64, 27]),\n // Legacy prefix\n [Prefix.TZ]: new Uint8Array([2, 90, 121]),\n};\n\nexport const prefixLength: { [key: string]: number } = {\n [Prefix.TZ1]: 20,\n [Prefix.TZ2]: 20,\n [Prefix.TZ3]: 20,\n [Prefix.KT]: 20,\n [Prefix.KT1]: 20,\n [Prefix.EDPK]: 32,\n [Prefix.SPPK]: 33,\n [Prefix.P2PK]: 33,\n [Prefix.EDSIG]: 64,\n [Prefix.SPSIG]: 64,\n [Prefix.P2SIG]: 64,\n [Prefix.SIG]: 64,\n [Prefix.NET]: 4,\n [Prefix.B]: 32,\n [Prefix.P]: 32,\n [Prefix.O]: 32\n};\n","import { prefix, prefixLength, Prefix } from './constants';\n\nconst bs58check = require('bs58check');\n\nexport enum ValidationResult {\n NO_PREFIX_MATCHED,\n INVALID_CHECKSUM,\n INVALID_LENGTH,\n VALID,\n}\n\nexport function isValidPrefix(value: any): value is Prefix {\n if (typeof value !== 'string') {\n return false;\n }\n\n return value in prefix;\n}\n /**\n * @description This function is called by the validation functions ([[validateAddress]], [[validateChain]], [[validateContractAddress]], [[validateKeyHash]], [[validateSignature]], [[validatePublicKey]]).\n * Verify if the value has the right prefix or return `NO_PREFIX_MATCHED`,\n * decode the value using base58 and return `INVALID_CHECKSUM` if it fails,\n * check if the length of the value matches the prefix type or return `INVALID_LENGTH`.\n * If all checks pass, return `VALID`.\n *\n * @param value Value to validate\n * @param prefixes prefix the value should have\n */\nfunction validatePrefixedValue(value: any, prefixes: Prefix[]) {\n const match = new RegExp(`^(${prefixes.join('|')})`).exec(value);\n if (!match || match.length === 0) {\n return ValidationResult.NO_PREFIX_MATCHED;\n }\n\n const prefixKey = match[0];\n\n if (!isValidPrefix(prefixKey)) {\n return ValidationResult.NO_PREFIX_MATCHED;\n }\n\n // Remove annotation from contract address before doing the validation\n const contractAddress = /^(KT1\\w{33})(\\%(.*))?/.exec(value);\n if (contractAddress) {\n value = contractAddress[1];\n }\n\n // decodeUnsafe return undefined if decoding fail\n let decoded = bs58check.decodeUnsafe(value);\n if (!decoded) {\n return ValidationResult.INVALID_CHECKSUM;\n }\n\n decoded = decoded.slice(prefix[prefixKey].length);\n if (decoded.length !== prefixLength[prefixKey]) {\n return ValidationResult.INVALID_LENGTH;\n }\n\n return ValidationResult.VALID;\n}\n\nconst implicitPrefix = [Prefix.TZ1, Prefix.TZ2, Prefix.TZ3];\nconst contractPrefix = [Prefix.KT1];\nconst signaturePrefix = [Prefix.EDSIG, Prefix.P2SIG, Prefix.SPSIG, Prefix.SIG];\nconst pkPrefix = [Prefix.EDPK, Prefix.SPPK, Prefix.P2PK];\n\n /**\n * @description Used to check if an address or a contract address is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateAddress } from '@taquito/utils';\n * const pkh = 'tz1L9r8mWmRPndRhuvMCWESLGSVeFzQ9NAWx'\n * const validation = validateAddress(pkh)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validateAddress(value: any): ValidationResult {\n return validatePrefixedValue(value, [...implicitPrefix, ...contractPrefix]);\n}\n /**\n * @description Used to check if a chain id is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateChain } from '@taquito/utils';\n * const chainId = 'NetXdQprcVkpaWU'\n * const validation = validateChain(chainId)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validateChain(value: any): ValidationResult {\n return validatePrefixedValue(value, [Prefix.NET]);\n}\n /**\n * @description Used to check if a contract address is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateContractAddress } from '@taquito/utils';\n * const contractAddress = 'KT1JVErLYTgtY8uGGZ4mso2npTSxqVLDRVbC'\n * const validation = validateContractAddress(contractAddress)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validateContractAddress(value: any): ValidationResult {\n return validatePrefixedValue(value, contractPrefix);\n}\n /**\n * @description Used to check if a key hash is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateKeyHash } from '@taquito/utils';\n * const keyHashWithoutPrefix = '1L9r8mWmRPndRhuvMCWESLGSVeFzQ9NAWx'\n * const validation = validateKeyHash(keyHashWithoutPrefix)\n * console.log(validation)\n * // This example return 0 which correspond to NO_PREFIX_MATCHED\n * ```\n */\nexport function validateKeyHash(value: any): ValidationResult {\n return validatePrefixedValue(value, implicitPrefix);\n}\n /**\n * @description Used to check if a signature is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validateSignature } from '@taquito/utils';\n * const signature = 'edsigtkpiSSschcaCt9pUVrpNPf7TTcgvgDEDD6NCEHMy8NNQJCGnMfLZzYoQj74yLjo9wx6MPVV29CvVzgi7qEcEUok3k7AuMg'\n * const validation = validateSignature(signature)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validateSignature(value: any): ValidationResult {\n return validatePrefixedValue(value, signaturePrefix);\n}\n /**\n * @description Used to check if a signature is valid.\n *\n * @returns\n * 0 (NO_PREFIX_MATCHED), 1 (INVALID_CHECKSUM), 2 (INVALID_LENGTH) or 3 (VALID).\n *\n * @example\n * ```\n * import { validatePublicKey } from '@taquito/utils';\n * const publicKey = 'edpkvS5QFv7KRGfa3b87gg9DBpxSm3NpSwnjhUjNBQrRUUR66F7C9g'\n * const validation = validatePublicKey(publicKey)\n * console.log(validation)\n * // This example return 3 which correspond to VALID\n * ```\n */\nexport function validatePublicKey(value: any): ValidationResult {\n return validatePrefixedValue(value, pkPrefix);\n}\n","\n// IMPORTANT: THIS FILE IS AUTO GENERATED! DO NOT MANUALLY EDIT OR CHECKIN!\n/* tslint:disable */\nexport const VERSION = {\n \"commitHash\": \"8d7ecc86ce608bff9ee8c6cf0cd7d795263b8bda\",\n \"version\": \"11.0.1\"\n};\n/* tslint:enable */\n","export class InvalidPublicKeyError implements Error {\n public name: string = 'InvalidPublicKeyError';\n constructor(public message: string) {}\n }\n \n export class InvalidSignatureError implements Error {\n public name: string = 'InvalidSignatureError';\n constructor(public message: string) {}\n }\n \n export class InvalidMessageError implements Error {\n public name: string = 'InvalidMessageError';\n constructor(public message: string) {}\n }\n ","import { verify } from '@stablelib/ed25519';\nimport { hash } from '@stablelib/blake2b';\nimport {\n b58cdecode,\n buf2hex,\n hex2buf,\n Prefix,\n prefix,\n validatePublicKey,\n validateSignature,\n ValidationResult\n} from './taquito-utils';\nimport elliptic from 'elliptic';\nimport toBuffer from 'typedarray-to-buffer';\nimport { InvalidMessageError, InvalidPublicKeyError, InvalidSignatureError } from './errors';\n\ntype PkPrefix = Prefix.EDPK | Prefix.SPPK | Prefix.P2PK;\ntype SigPrefix = Prefix.EDSIG | Prefix.SPSIG | Prefix.P2SIG | Prefix.SIG;\n\n/**\n * @description Verify signature of a payload\n *\n * @param messageBytes The forged message including the magic byte (1 for block, 2 for endorsement, 3 for generic, 5 for the PACK format of michelson)\n * @param publicKey The public key to verify the signature against\n * @param signature The signature to verify\n * @returns A boolean indicating if the signature matches\n *\n * @example \n * ```\n * const message = '03d0c10e3ed11d7c6e3357f6ef335bab9e8f2bd54d0ce20c482e241191a6e4b8ce6c01be917311d9ac46959750e405d57e268e2ed9e174a80794fbd504e12a4a000141eb3781afed2f69679ff2bbe1c5375950b0e40d00ff000000005e05050505050507070100000024747a32526773486e74516b72794670707352466261313652546656503539684b72654a4d07070100000024747a315a6672455263414c42776d4171776f6e525859565142445439426a4e6a42484a750001';\n * const pk = 'sppk7c7hkPj47yjYFEHX85q46sFJGw6RBrqoVSHwAJAT4e14KJwzoey';\n * const sig = 'spsig1cdLkp1RLgUHAp13aRFkZ6MQDPp7xCnjAExGL3MBSdMDmT6JgQSX8cufyDgJRM3sinFtiCzLbsyP6d365EHoNevxhT47nx'\n * \n * const response = verifySignature(message, pk, sig);\n * ```\n *\n */\nexport function verifySignature(messageBytes: string, publicKey: string, signature: string): boolean {\n const pkPrefix = validatePkAndExtractPrefix(publicKey);\n const sigPrefix = validateSigAndExtractPrefix(signature);\n\n const decodedPublicKey = b58cdecode(publicKey, prefix[pkPrefix]);\n const decodedSig = b58cdecode(signature, prefix[sigPrefix]);\n const bytesHash = hash(hex2buf(validateMessageNotEmpty(messageBytes)), 32);\n\n if (pkPrefix === Prefix.EDPK) {\n return verifyEdSignature(decodedSig, bytesHash, decodedPublicKey);\n } else if (pkPrefix === Prefix.SPPK) {\n return verifySpSignature(decodedSig, bytesHash, decodedPublicKey);\n } else if (pkPrefix === Prefix.P2PK) {\n return verifyP2Signature(decodedSig, bytesHash, decodedPublicKey);\n } else {\n return false;\n }\n}\n\nfunction validateMessageNotEmpty(message: string) {\n if (message === '') {\n throw new InvalidMessageError(`The message provided for verifying signature cannot be empty.`);\n }\n return message;\n}\n\nfunction validatePkAndExtractPrefix(publicKey: string): PkPrefix {\n if (publicKey === '') {\n throw new InvalidPublicKeyError(`The public key provided for verifying signature cannot be empty.`);\n }\n const pkPrefix = publicKey.substring(0, 4);\n const validation = validatePublicKey(publicKey);\n if (validation !== ValidationResult.VALID) {\n if (validation === ValidationResult.INVALID_CHECKSUM) {\n throw new InvalidPublicKeyError(`The public key provided has an invalid checksum: ${publicKey}`);\n } else if (validation === ValidationResult.INVALID_LENGTH) {\n throw new InvalidPublicKeyError(`The public key provided has an invalid length: ${publicKey}`);\n } else if (validation === ValidationResult.NO_PREFIX_MATCHED) {\n throw new InvalidPublicKeyError(`The public key provided has an unsupported prefix: ${pkPrefix}`);\n }\n }\n return pkPrefix as PkPrefix;\n}\n\nfunction validateSigAndExtractPrefix(signature: string): SigPrefix {\n const signaturePrefix = signature.startsWith('sig') ? signature.substr(0, 3) : signature.substr(0, 5);\n const validation = validateSignature(signature);\n if (validation !== ValidationResult.VALID) {\n if (validation === ValidationResult.INVALID_CHECKSUM) {\n throw new InvalidSignatureError(`The signature provided has an invalid checksum: ${signature}`);\n } else if (validation === ValidationResult.INVALID_LENGTH) {\n throw new InvalidSignatureError(`The signature provided has an invalid length: ${signature}`);\n } else if (validation === ValidationResult.NO_PREFIX_MATCHED) {\n throw new InvalidSignatureError(`The signature provided has an unsupported prefix: ${signaturePrefix}`);\n }\n }\n return signaturePrefix as SigPrefix;\n}\n\nfunction verifyEdSignature(decodedSig: Uint8Array, bytesHash: Uint8Array, decodedPublicKey: Uint8Array) {\n try {\n return verify(decodedPublicKey, bytesHash, decodedSig);\n } catch (e) {\n return false;\n }\n}\n\nfunction verifySpSignature(decodedSig: Uint8Array, bytesHash: Uint8Array, decodedPublicKey: Uint8Array) {\n const key = new elliptic.ec('secp256k1').keyFromPublic(decodedPublicKey);\n return verifySpOrP2Sig(decodedSig, bytesHash, key)\n}\n\nfunction verifyP2Signature(decodedSig: Uint8Array, bytesHash: Uint8Array, decodedPublicKey: Uint8Array) {\n const key = new elliptic.ec('p256').keyFromPublic(decodedPublicKey);\n return verifySpOrP2Sig(decodedSig, bytesHash, key)\n}\n\nfunction verifySpOrP2Sig(decodedSig: Uint8Array, bytesHash: Uint8Array, key: elliptic.ec.KeyPair) {\n const hexSig = buf2hex(toBuffer(decodedSig));\n const match = hexSig.match(/([a-f\\d]{64})/gi);\n if (match) {\n try {\n const [r, s] = match;\n return key.verify(bytesHash, { r, s });\n } catch (e) {\n return false;\n }\n }\n return false;\n}\n","/**\n * @packageDocumentation\n * @module @taquito/utils\n */\n\n/*\n * Some code in this file is originally from sotez and eztz\n * Copyright (c) 2018 Andrew Kishino\n * Copyright (c) 2017 Stephen Andrews\n */\n\nimport { Buffer } from 'buffer';\nimport { prefix } from './constants';\nconst blake = require('blakejs');\nconst bs58check = require('bs58check');\n\nexport * from './validators';\nexport { VERSION } from './version';\n\nexport { prefix, Prefix, prefixLength } from './constants';\n\nexport { verifySignature } from './verify-signature';\n\n/**\n *\n * @description Hash a string using the BLAKE2b algorithm, base58 encode the hash obtained and appends the prefix 'expr' to it\n *\n * @param value Value in hex\n */\nexport function encodeExpr(value: string) {\n const blakeHash = blake.blake2b(hex2buf(value), null, 32);\n return b58cencode(blakeHash, prefix['expr']);\n}\n\n/**\n *\n * @description Return the operation hash of a signed operation \n * @param value Value in hex of a signed operation\n */\n export function encodeOpHash(value: string) {\n const blakeHash = blake.blake2b(hex2buf(value), null, 32);\n return b58cencode(blakeHash, prefix.o);\n}\n\n/**\n *\n * @description Base58 encode a string or a Uint8Array and append a prefix to it\n *\n * @param value Value to base58 encode\n * @param prefix prefix to append to the encoded string\n */\nexport function b58cencode(value: string | Uint8Array, prefix: Uint8Array) {\n const payloadAr = typeof value === 'string' ? Uint8Array.from(Buffer.from(value, 'hex')) : value;\n\n const n = new Uint8Array(prefix.length + payloadAr.length);\n n.set(prefix);\n n.set(payloadAr, prefix.length);\n\n return bs58check.encode(Buffer.from(n.buffer));\n}\n\n/**\n *\n * @description Base58 decode a string and remove the prefix from it\n *\n * @param value Value to base58 decode\n * @param prefix prefix to remove from the decoded string\n */\nexport const b58cdecode = (enc: string, prefixArg: Uint8Array): Uint8Array =>\n bs58check.decode(enc).slice(prefixArg.length);\n\n/**\n *\n * @description Base58 decode a string with predefined prefix\n *\n * @param value Value to base58 decode\n */\nexport function b58decode(payload: string) {\n const buf: Buffer = bs58check.decode(payload);\n\n const prefixMap = {\n [prefix.tz1.toString()]: '0000',\n [prefix.tz2.toString()]: '0001',\n [prefix.tz3.toString()]: '0002',\n };\n\n let pref = prefixMap[new Uint8Array(buf.slice(0, 3)).toString()];\n if (pref) {\n // tz addresses\n const hex = buf2hex(buf.slice(3));\n return pref + hex;\n } else {\n // other (kt addresses)\n return '01' + buf2hex(buf.slice(3, 42)) + '00';\n }\n}\n\n/**\n *\n * @description Base58 encode a public key using predefined prefix\n *\n * @param value Public Key to base58 encode\n */\nexport function encodePubKey(value: string) {\n if (value.substring(0, 2) === '00') {\n const pref: { [key: string]: Uint8Array } = {\n '0000': prefix.tz1,\n '0001': prefix.tz2,\n '0002': prefix.tz3,\n };\n\n return b58cencode(value.substring(4), pref[value.substring(0, 4)]);\n }\n\n return b58cencode(value.substring(2, 42), prefix.KT);\n}\n\n/**\n *\n * @description Base58 encode a key according to its prefix\n *\n * @param value Key to base58 encode\n */\nexport function encodeKey(value: string) {\n if (value[0] === '0') {\n const pref: { [key: string]: Uint8Array } = {\n '00': new Uint8Array([13, 15, 37, 217]),\n '01': new Uint8Array([3, 254, 226, 86]),\n '02': new Uint8Array([3, 178, 139, 127]),\n };\n\n return b58cencode(value.substring(2), pref[value.substring(0, 2)]);\n }\n}\n\n/**\n *\n * @description Base58 encode a key hash according to its prefix\n *\n * @param value Key to base58 encode\n */\nexport function encodeKeyHash(value: string) {\n if (value[0] === '0') {\n const pref: { [key: string]: Uint8Array } = {\n '00': new Uint8Array([6, 161, 159]),\n '01': new Uint8Array([6, 161, 161]),\n '02': new Uint8Array([6, 161, 164]),\n };\n\n return b58cencode(value.substring(2), pref[value.substring(0, 2)]);\n }\n}\n\n/**\n *\n * @description Convert an hex string to a Uint8Array\n *\n * @param hex Hex string to convert\n */\nexport const hex2buf = (hex: string): Uint8Array => {\n return new Uint8Array(hex.match(/[\\da-f]{2}/gi)!.map((h) => parseInt(h, 16)));\n};\n\n/**\n *\n * @description Merge 2 buffers together\n *\n * @param b1 First buffer\n * @param b2 Second buffer\n */\nexport const mergebuf = (b1: Uint8Array, b2: Uint8Array): Uint8Array => {\n const r = new Uint8Array(b1.length + b2.length);\n r.set(b1);\n r.set(b2, b1.length);\n return r;\n};\n\n/**\n *\n * @description Flatten a michelson json representation to an array\n *\n * @param s michelson json\n */\nexport const mic2arr = function me2(s: any): any {\n let ret: any = [];\n if (Object.prototype.hasOwnProperty.call(s, 'prim')) {\n if (s.prim === 'Pair') {\n ret.push(me2(s.args[0]));\n ret = ret.concat(me2(s.args[1]));\n } else if (s.prim === 'Elt') {\n ret = {\n key: me2(s.args[0]),\n val: me2(s.args[1]),\n };\n } else if (s.prim === 'True') {\n ret = true;\n } else if (s.prim === 'False') {\n ret = false;\n }\n } else if (Array.isArray(s)) {\n const sc = s.length;\n for (let i = 0; i < sc; i++) {\n const n = me2(s[i]);\n if (typeof n.key !== 'undefined') {\n if (Array.isArray(ret)) {\n ret = {\n keys: [],\n vals: [],\n };\n }\n ret.keys.push(n.key);\n ret.vals.push(n.val);\n } else {\n ret.push(n);\n }\n }\n } else if (Object.prototype.hasOwnProperty.call(s, 'string')) {\n ret = s.string;\n } else if (Object.prototype.hasOwnProperty.call(s, 'int')) {\n ret = parseInt(s.int, 10);\n } else {\n ret = s;\n }\n return ret;\n};\n\n/**\n *\n * @description Convert a buffer to an hex string\n *\n * @param buffer Buffer to convert\n */\nexport const buf2hex = (buffer: Buffer): string => {\n const byteArray = new Uint8Array(buffer);\n const hexParts: string[] = [];\n byteArray.forEach((byte: any) => {\n const hex = byte.toString(16);\n const paddedHex = `00${hex}`.slice(-2);\n hexParts.push(paddedHex);\n });\n return hexParts.join('');\n};\n\n/**\n *\n * @description Convert a string to bytes\n *\n * @param str String to convert\n */\nexport function char2Bytes(str: string) {\n return Buffer.from(str, 'utf8').toString('hex');\n}\n\n/**\n *\n * @description Convert bytes to a string\n *\n * @param str Bytes to convert\n */\nexport function bytes2Char(hex: string): string {\n return Buffer.from(hex2buf(hex)).toString('utf8');\n}\n"],"names":["Prefix","bs58check","ValidationResult","hash","verify","elliptic","toBuffer","Buffer"],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ export declare class InvalidPublicKeyError implements Error {
2
+ message: string;
3
+ name: string;
4
+ constructor(message: string);
5
+ }
6
+ export declare class InvalidSignatureError implements Error {
7
+ message: string;
8
+ name: string;
9
+ constructor(message: string);
10
+ }
11
+ export declare class InvalidMessageError implements Error {
12
+ message: string;
13
+ name: string;
14
+ constructor(message: string);
15
+ }
@@ -6,6 +6,7 @@ import { Buffer } from 'buffer';
6
6
  export * from './validators';
7
7
  export { VERSION } from './version';
8
8
  export { prefix, Prefix, prefixLength } from './constants';
9
+ export { verifySignature } from './verify-signature';
9
10
  /**
10
11
  *
11
12
  * @description Hash a string using the BLAKE2b algorithm, base58 encode the hash obtained and appends the prefix 'expr' to it
@@ -95,7 +95,7 @@ export declare function validateSignature(value: any): ValidationResult;
95
95
  * @example
96
96
  * ```
97
97
  * import { validatePublicKey } from '@taquito/utils';
98
- * const publicKey = 'edsigtkpiSSschcaCt9pUVrpNPf7TTcgvgDEDD6NCEHMy8NNQJCGnMfLZzYoQj74yLjo9wx6MPVV29CvVzgi7qEcEUok3k7AuMg'
98
+ * const publicKey = 'edpkvS5QFv7KRGfa3b87gg9DBpxSm3NpSwnjhUjNBQrRUUR66F7C9g'
99
99
  * const validation = validatePublicKey(publicKey)
100
100
  * console.log(validation)
101
101
  * // This example return 3 which correspond to VALID
@@ -0,0 +1,19 @@
1
+ /**
2
+ * @description Verify signature of a payload
3
+ *
4
+ * @param messageBytes The forged message including the magic byte (1 for block, 2 for endorsement, 3 for generic, 5 for the PACK format of michelson)
5
+ * @param publicKey The public key to verify the signature against
6
+ * @param signature The signature to verify
7
+ * @returns A boolean indicating if the signature matches
8
+ *
9
+ * @example
10
+ * ```
11
+ * const message = '03d0c10e3ed11d7c6e3357f6ef335bab9e8f2bd54d0ce20c482e241191a6e4b8ce6c01be917311d9ac46959750e405d57e268e2ed9e174a80794fbd504e12a4a000141eb3781afed2f69679ff2bbe1c5375950b0e40d00ff000000005e05050505050507070100000024747a32526773486e74516b72794670707352466261313652546656503539684b72654a4d07070100000024747a315a6672455263414c42776d4171776f6e525859565142445439426a4e6a42484a750001';
12
+ * const pk = 'sppk7c7hkPj47yjYFEHX85q46sFJGw6RBrqoVSHwAJAT4e14KJwzoey';
13
+ * const sig = 'spsig1cdLkp1RLgUHAp13aRFkZ6MQDPp7xCnjAExGL3MBSdMDmT6JgQSX8cufyDgJRM3sinFtiCzLbsyP6d365EHoNevxhT47nx'
14
+ *
15
+ * const response = verifySignature(message, pk, sig);
16
+ * ```
17
+ *
18
+ */
19
+ export declare function verifySignature(messageBytes: string, publicKey: string, signature: string): boolean;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@taquito/utils",
3
- "version": "10.2.1",
3
+ "version": "11.0.1",
4
4
  "description": "converts michelson data and types into convenient JS/TS objects",
5
5
  "keywords": [
6
6
  "tezos",
@@ -39,7 +39,7 @@
39
39
  "lint-staged": {
40
40
  "{src,test}/**/*.ts": [
41
41
  "prettier --write",
42
- "tslint --fix",
42
+ "eslint --fix",
43
43
  "git add"
44
44
  ]
45
45
  },
@@ -63,11 +63,16 @@
63
63
  ]
64
64
  },
65
65
  "dependencies": {
66
+ "@stablelib/blake2b": "^1.0.1",
67
+ "@stablelib/ed25519": "^1.0.2",
66
68
  "blakejs": "^1.1.0",
67
69
  "bs58check": "^2.1.2",
68
- "buffer": "^6.0.3"
70
+ "buffer": "^6.0.3",
71
+ "elliptic": "^6.5.4",
72
+ "typedarray-to-buffer": "^4.0.0"
69
73
  },
70
74
  "devDependencies": {
75
+ "@types/elliptic": "^6.4.14",
71
76
  "@types/jest": "^26.0.23",
72
77
  "@types/node": "^15.12.2",
73
78
  "@typescript-eslint/eslint-plugin": "^4.28.1",
@@ -94,7 +99,7 @@
94
99
  "tslint-config-prettier": "^1.18.0",
95
100
  "tslint-config-standard": "^9.0.0",
96
101
  "typedoc": "^0.20.36",
97
- "typescript": "^4.1.5"
102
+ "typescript": "~4.1.5"
98
103
  },
99
- "gitHead": "c3d65aa8a91c161ca2560e10d48f85b6b63255b0"
104
+ "gitHead": "d09ecc8f28d454067553c9e94c85142409f90722"
100
105
  }
package/signature.json CHANGED
@@ -193,7 +193,7 @@
193
193
  "tslint-config-prettier": "^1.18.0",
194
194
  "tslint-config-standard": "^9.0.0",
195
195
  "typedoc": "^0.20.23",
196
- "typescript": "^4.1.5"
196
+ "typescript": "~4.1.5"
197
197
  },
198
198
  "gitHead": "551e35aeff7d6dcde1c72284238c0ed3c3aae77e"
199
199
  }