@shapeshiftoss/hdwallet-native 1.55.4-alpha.1 → 1.55.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/adapter.js +61 -22
- package/dist/adapter.js.map +1 -1
- package/dist/arkeo.js +123 -54
- package/dist/arkeo.js.map +1 -1
- package/dist/binance.js +194 -123
- package/dist/binance.js.map +1 -1
- package/dist/bitcoin.js +284 -219
- package/dist/bitcoin.js.map +1 -1
- package/dist/cosmos.js +123 -54
- package/dist/cosmos.js.map +1 -1
- package/dist/crypto/CryptoHelper.js +172 -106
- package/dist/crypto/CryptoHelper.js.map +1 -1
- package/dist/crypto/EncryptedWallet.js +123 -64
- package/dist/crypto/EncryptedWallet.js.map +1 -1
- package/dist/crypto/classes/cipherString.js +19 -18
- package/dist/crypto/classes/cipherString.js.map +1 -1
- package/dist/crypto/classes/encryptedObject.js +7 -7
- package/dist/crypto/classes/encryptedObject.js.map +1 -1
- package/dist/crypto/classes/encryptionType.js +5 -2
- package/dist/crypto/classes/encryptionType.js.map +1 -1
- package/dist/crypto/classes/index.js +11 -4
- package/dist/crypto/classes/index.js.map +1 -1
- package/dist/crypto/classes/symmetricCryptoKey.js +11 -13
- package/dist/crypto/classes/symmetricCryptoKey.js.map +1 -1
- package/dist/crypto/engines/index.js +18 -2
- package/dist/crypto/engines/index.js.map +1 -1
- package/dist/crypto/engines/types.js +5 -2
- package/dist/crypto/engines/types.js.map +1 -1
- package/dist/crypto/engines/web-crypto.js +84 -39
- package/dist/crypto/engines/web-crypto.js.map +1 -1
- package/dist/crypto/index.js +32 -3
- package/dist/crypto/index.js.map +1 -1
- package/dist/crypto/isolation/adapters/binance.js +51 -12
- package/dist/crypto/isolation/adapters/binance.js.map +1 -1
- package/dist/crypto/isolation/adapters/bip32.js +108 -65
- package/dist/crypto/isolation/adapters/bip32.js.map +1 -1
- package/dist/crypto/isolation/adapters/bitcoin.js +84 -41
- package/dist/crypto/isolation/adapters/bitcoin.js.map +1 -1
- package/dist/crypto/isolation/adapters/cosmos.js +24 -9
- package/dist/crypto/isolation/adapters/cosmos.js.map +1 -1
- package/dist/crypto/isolation/adapters/cosmosDirect.js +77 -35
- package/dist/crypto/isolation/adapters/cosmosDirect.js.map +1 -1
- package/dist/crypto/isolation/adapters/ethereum.js +90 -49
- package/dist/crypto/isolation/adapters/ethereum.js.map +1 -1
- package/dist/crypto/isolation/adapters/fio.js +67 -24
- package/dist/crypto/isolation/adapters/fio.js.map +1 -1
- package/dist/crypto/isolation/adapters/index.js +20 -7
- package/dist/crypto/isolation/adapters/index.js.map +1 -1
- package/dist/crypto/isolation/core/bip32/index.js +50 -22
- package/dist/crypto/isolation/core/bip32/index.js.map +1 -1
- package/dist/crypto/isolation/core/bip32/interfaces.js +28 -2
- package/dist/crypto/isolation/core/bip32/interfaces.js.map +1 -1
- package/dist/crypto/isolation/core/bip32/types.js +8 -5
- package/dist/crypto/isolation/core/bip32/types.js.map +1 -1
- package/dist/crypto/isolation/core/bip39/index.js +17 -1
- package/dist/crypto/isolation/core/bip39/index.js.map +1 -1
- package/dist/crypto/isolation/core/bip39/interfaces.js +2 -1
- package/dist/crypto/isolation/core/digest/algorithms.js +32 -23
- package/dist/crypto/isolation/core/digest/algorithms.js.map +1 -1
- package/dist/crypto/isolation/core/digest/index.js +18 -2
- package/dist/crypto/isolation/core/digest/index.js.map +1 -1
- package/dist/crypto/isolation/core/digest/types.js +26 -23
- package/dist/crypto/isolation/core/digest/types.js.map +1 -1
- package/dist/crypto/isolation/core/index.js +32 -5
- package/dist/crypto/isolation/core/index.js.map +1 -1
- package/dist/crypto/isolation/core/secp256k1/index.js +18 -2
- package/dist/crypto/isolation/core/secp256k1/index.js.map +1 -1
- package/dist/crypto/isolation/core/secp256k1/interfaces.js +2 -1
- package/dist/crypto/isolation/core/secp256k1/types.js +157 -119
- package/dist/crypto/isolation/core/secp256k1/types.js.map +1 -1
- package/dist/crypto/isolation/engines/default/bip32.js +176 -102
- package/dist/crypto/isolation/engines/default/bip32.js.map +1 -1
- package/dist/crypto/isolation/engines/default/bip39.js +68 -24
- package/dist/crypto/isolation/engines/default/bip39.js.map +1 -1
- package/dist/crypto/isolation/engines/default/index.js +32 -3
- package/dist/crypto/isolation/engines/default/index.js.map +1 -1
- package/dist/crypto/isolation/engines/default/revocable.js +51 -30
- package/dist/crypto/isolation/engines/default/revocable.js.map +1 -1
- package/dist/crypto/isolation/engines/dummy/bip32.js +121 -63
- package/dist/crypto/isolation/engines/dummy/bip32.js.map +1 -1
- package/dist/crypto/isolation/engines/dummy/bip39.js +97 -55
- package/dist/crypto/isolation/engines/dummy/bip39.js.map +1 -1
- package/dist/crypto/isolation/engines/dummy/index.js +30 -3
- package/dist/crypto/isolation/engines/dummy/index.js.map +1 -1
- package/dist/crypto/isolation/engines/dummy/types.js +5 -1
- package/dist/crypto/isolation/engines/dummy/types.js.map +1 -1
- package/dist/crypto/isolation/engines/index.js +28 -2
- package/dist/crypto/isolation/engines/index.js.map +1 -1
- package/dist/crypto/isolation/index.js +29 -3
- package/dist/crypto/isolation/index.js.map +1 -1
- package/dist/crypto/isolation/types.js +49 -43
- package/dist/crypto/isolation/types.js.map +1 -1
- package/dist/crypto/utils.js +13 -7
- package/dist/crypto/utils.js.map +1 -1
- package/dist/ethereum.js +160 -92
- package/dist/ethereum.js.map +1 -1
- package/dist/fio.js +282 -204
- package/dist/fio.js.map +1 -1
- package/dist/index.js +32 -3
- package/dist/index.js.map +1 -1
- package/dist/kava.js +119 -50
- package/dist/kava.js.map +1 -1
- package/dist/native.js +304 -176
- package/dist/native.js.map +1 -1
- package/dist/networks.js +33 -16
- package/dist/networks.js.map +1 -1
- package/dist/osmosis.js +123 -54
- package/dist/osmosis.js.map +1 -1
- package/dist/secret.js +119 -50
- package/dist/secret.js.map +1 -1
- package/dist/terra.js +119 -50
- package/dist/terra.js.map +1 -1
- package/dist/thorchain.js +123 -54
- package/dist/thorchain.js.map +1 -1
- package/dist/util.js +54 -16
- package/dist/util.js.map +1 -1
- package/package.json +3 -3
|
@@ -1,10 +1,37 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.IsolationError = exports.SecP256K1 = exports.Digest = exports.BIP39 = exports.BIP32 = void 0;
|
|
27
|
+
exports.BIP32 = __importStar(require("./bip32"));
|
|
28
|
+
exports.BIP39 = __importStar(require("./bip39"));
|
|
29
|
+
exports.Digest = __importStar(require("./digest"));
|
|
30
|
+
exports.SecP256K1 = __importStar(require("./secp256k1"));
|
|
31
|
+
class IsolationError extends Error {
|
|
6
32
|
constructor(name) {
|
|
7
33
|
super(`this key is isolated -- no ${name} for you!`);
|
|
8
34
|
}
|
|
9
35
|
}
|
|
36
|
+
exports.IsolationError = IsolationError;
|
|
10
37
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/crypto/isolation/core/index.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/crypto/isolation/core/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,iDAAiC;AACjC,iDAAiC;AACjC,mDAAmC;AACnC,yDAAyC;AAEzC,MAAa,cAAe,SAAQ,KAAK;IACvC,YAAY,IAAY;QACtB,KAAK,CAAC,8BAA8B,IAAI,WAAW,CAAC,CAAC;IACvD,CAAC;CACF;AAJD,wCAIC"}
|
|
@@ -1,3 +1,19 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./interfaces"), exports);
|
|
18
|
+
__exportStar(require("./types"), exports);
|
|
3
19
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/crypto/isolation/core/secp256k1/index.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/crypto/isolation/core/secp256k1/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+CAA6B;AAC7B,0CAAwB"}
|
|
@@ -1,242 +1,280 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
26
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
27
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
28
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
29
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
30
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
31
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
32
|
+
});
|
|
33
|
+
};
|
|
34
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
35
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
36
|
+
};
|
|
37
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
38
|
+
exports.RecoverableSignature = exports.Signature = exports.Message = exports.MessageWithPreimage = exports.RecoveryParam = exports.CurvePoint = exports.CompressedPoint = exports.UncompressedPoint = exports.FieldElement = void 0;
|
|
39
|
+
const core = __importStar(require("@shapeshiftoss/hdwallet-core"));
|
|
40
|
+
const funtypes_1 = require("funtypes");
|
|
41
|
+
const p_lazy_1 = __importDefault(require("p-lazy"));
|
|
42
|
+
const tinyecc = __importStar(require("tiny-secp256k1"));
|
|
43
|
+
const types_1 = require("../../types");
|
|
44
|
+
const Digest = __importStar(require("../digest"));
|
|
45
|
+
const ethers = p_lazy_1.default.from(() => Promise.resolve().then(() => __importStar(require("ethers"))));
|
|
46
|
+
const _fieldElementBase = (0, types_1.BigEndianInteger)(32).withConstraint((x) => tinyecc.isPrivate((0, types_1.safeBufferFrom)(x)) || `expected ${x} to be within the order of the curve`, { name: "FieldElement" });
|
|
9
47
|
const _fieldElementStatic = {};
|
|
10
|
-
const _fieldElement = Object.assign(_fieldElementBase, BigEndianInteger, _fieldElementStatic);
|
|
11
|
-
|
|
12
|
-
const _uncompressedPointBase = ByteArray(65)
|
|
13
|
-
.And(
|
|
14
|
-
0: Literal(0x04),
|
|
48
|
+
const _fieldElement = Object.assign(_fieldElementBase, types_1.BigEndianInteger, _fieldElementStatic);
|
|
49
|
+
exports.FieldElement = _fieldElement;
|
|
50
|
+
const _uncompressedPointBase = (0, types_1.ByteArray)(65)
|
|
51
|
+
.And((0, funtypes_1.Object)({
|
|
52
|
+
0: (0, funtypes_1.Literal)(0x04),
|
|
15
53
|
}))
|
|
16
|
-
.withConstraint((p) => FieldElement.test(p.slice(1, 33)) || `expected ${p}.x to be within the order of the curve`, {
|
|
54
|
+
.withConstraint((p) => exports.FieldElement.test(p.slice(1, 33)) || `expected ${p}.x to be within the order of the curve`, {
|
|
17
55
|
name: "UncompressedPoint.x",
|
|
18
56
|
})
|
|
19
57
|
.withConstraint((p) => {
|
|
20
|
-
if (!FieldElement.test(p.slice(33, 65)))
|
|
58
|
+
if (!exports.FieldElement.test(p.slice(33, 65)))
|
|
21
59
|
return `expected ${p}.y to be within the order of the curve`;
|
|
22
60
|
const pBuf = Buffer.from(p);
|
|
23
|
-
if (!ByteArray.equal(tinyecc.pointCompress(tinyecc.pointCompress(pBuf, true), false), pBuf))
|
|
61
|
+
if (!types_1.ByteArray.equal(tinyecc.pointCompress(tinyecc.pointCompress(pBuf, true), false), pBuf))
|
|
24
62
|
return `expected ${p} to be on the curve`;
|
|
25
63
|
return true;
|
|
26
64
|
}, { name: "UncompressedPoint.y" });
|
|
27
|
-
const _compressedPointBase = ByteArray(33)
|
|
28
|
-
.And(
|
|
29
|
-
0: Literal(0x02).Or(Literal(0x03)),
|
|
65
|
+
const _compressedPointBase = (0, types_1.ByteArray)(33)
|
|
66
|
+
.And((0, funtypes_1.Object)({
|
|
67
|
+
0: (0, funtypes_1.Literal)(0x02).Or((0, funtypes_1.Literal)(0x03)),
|
|
30
68
|
}))
|
|
31
|
-
.withConstraint((p) => FieldElement.test(p.slice(1)) || `expected ${p}.x to be within the order of the curve`, {
|
|
69
|
+
.withConstraint((p) => exports.FieldElement.test(p.slice(1)) || `expected ${p}.x to be within the order of the curve`, {
|
|
32
70
|
name: "CompressedPoint.x",
|
|
33
71
|
});
|
|
34
72
|
const _uncompressedPointStatic = {
|
|
35
73
|
from: (p) => {
|
|
36
|
-
return p.length === 65 ? p : UncompressedPoint.fromCompressed(checkType(CompressedPoint, p));
|
|
74
|
+
return p.length === 65 ? p : exports.UncompressedPoint.fromCompressed((0, types_1.checkType)(exports.CompressedPoint, p));
|
|
37
75
|
},
|
|
38
76
|
fromCompressed: (p) => {
|
|
39
|
-
return checkType(UncompressedPoint, tinyecc.pointCompress(Buffer.from(p), false));
|
|
77
|
+
return (0, types_1.checkType)(exports.UncompressedPoint, tinyecc.pointCompress(Buffer.from(p), false));
|
|
40
78
|
},
|
|
41
79
|
x: (p) => {
|
|
42
|
-
return checkType(FieldElement, p.slice(1, 33));
|
|
80
|
+
return (0, types_1.checkType)(exports.FieldElement, p.slice(1, 33));
|
|
43
81
|
},
|
|
44
82
|
y: (p) => {
|
|
45
|
-
return checkType(FieldElement, p.slice(33, 65));
|
|
83
|
+
return (0, types_1.checkType)(exports.FieldElement, p.slice(33, 65));
|
|
46
84
|
},
|
|
47
85
|
yIsOdd: (p) => {
|
|
48
|
-
return FieldElement.isOdd(UncompressedPoint.y(p));
|
|
86
|
+
return exports.FieldElement.isOdd(exports.UncompressedPoint.y(p));
|
|
49
87
|
},
|
|
50
88
|
};
|
|
51
|
-
const _uncompressedPoint = Object.assign(_uncompressedPointBase, ByteArray, _uncompressedPointStatic);
|
|
52
|
-
|
|
89
|
+
const _uncompressedPoint = Object.assign(_uncompressedPointBase, types_1.ByteArray, _uncompressedPointStatic);
|
|
90
|
+
exports.UncompressedPoint = _uncompressedPoint;
|
|
53
91
|
const _compressedPointStatic = {
|
|
54
92
|
from: (p) => {
|
|
55
|
-
return p.length === 33 ? p : CompressedPoint.fromUncompressed(checkType(UncompressedPoint, p));
|
|
93
|
+
return p.length === 33 ? p : exports.CompressedPoint.fromUncompressed((0, types_1.checkType)(exports.UncompressedPoint, p));
|
|
56
94
|
},
|
|
57
95
|
fromUncompressed: (p) => {
|
|
58
96
|
const out = new Uint8Array(33);
|
|
59
|
-
out[0] = UncompressedPoint.yIsOdd(p) ? 0x03 : 0x02;
|
|
60
|
-
out.set(UncompressedPoint.x(p), 1);
|
|
61
|
-
CompressedPoint.assert(out);
|
|
97
|
+
out[0] = exports.UncompressedPoint.yIsOdd(p) ? 0x03 : 0x02;
|
|
98
|
+
out.set(exports.UncompressedPoint.x(p), 1);
|
|
99
|
+
exports.CompressedPoint.assert(out);
|
|
62
100
|
return out;
|
|
63
101
|
},
|
|
64
102
|
x: (p) => {
|
|
65
|
-
return checkType(FieldElement, p.slice(1));
|
|
103
|
+
return (0, types_1.checkType)(exports.FieldElement, p.slice(1));
|
|
66
104
|
},
|
|
67
105
|
yIsOdd: (p) => {
|
|
68
106
|
return p[0] === 0x03;
|
|
69
107
|
},
|
|
70
108
|
};
|
|
71
|
-
const _compressedPoint = Object.assign(_compressedPointBase, ByteArray, _compressedPointStatic);
|
|
72
|
-
|
|
73
|
-
const _curvePointBase = CompressedPoint.Or(UncompressedPoint);
|
|
109
|
+
const _compressedPoint = Object.assign(_compressedPointBase, types_1.ByteArray, _compressedPointStatic);
|
|
110
|
+
exports.CompressedPoint = _compressedPoint;
|
|
111
|
+
const _curvePointBase = exports.CompressedPoint.Or(exports.UncompressedPoint);
|
|
74
112
|
const _curvePointStatic = {
|
|
75
|
-
x: (p) => (p[0] === 0x04 ? UncompressedPoint.x(p) : CompressedPoint.x(p)),
|
|
76
|
-
yIsOdd: (p) => (p[0] === 0x04 ? UncompressedPoint.yIsOdd(p) : CompressedPoint.yIsOdd(p)),
|
|
113
|
+
x: (p) => (p[0] === 0x04 ? exports.UncompressedPoint.x(p) : exports.CompressedPoint.x(p)),
|
|
114
|
+
yIsOdd: (p) => (p[0] === 0x04 ? exports.UncompressedPoint.yIsOdd(p) : exports.CompressedPoint.yIsOdd(p)),
|
|
77
115
|
// Equivalent to CompressedPoint.equal(CompressedPoint.from(lhs), CompressedPoint.from(rhs)), but avoids allocations
|
|
78
|
-
equal: (lhs, rhs) => CurvePoint.yIsOdd(lhs) === CurvePoint.yIsOdd(rhs) && FieldElement.equal(CurvePoint.x(lhs), CurvePoint.x(rhs)),
|
|
116
|
+
equal: (lhs, rhs) => exports.CurvePoint.yIsOdd(lhs) === exports.CurvePoint.yIsOdd(rhs) && exports.FieldElement.equal(exports.CurvePoint.x(lhs), exports.CurvePoint.x(rhs)),
|
|
79
117
|
};
|
|
80
118
|
const _curvePoint = Object.assign(_curvePointBase, _curvePointStatic);
|
|
81
|
-
|
|
82
|
-
const _recoveryParamBase = Union(Literal(0), Literal(1), Literal(2), Literal(3));
|
|
119
|
+
exports.CurvePoint = _curvePoint;
|
|
120
|
+
const _recoveryParamBase = (0, funtypes_1.Union)((0, funtypes_1.Literal)(0), (0, funtypes_1.Literal)(1), (0, funtypes_1.Literal)(2), (0, funtypes_1.Literal)(3));
|
|
83
121
|
const _recoveryParamStatic = {};
|
|
84
122
|
const _recoveryParam = Object.assign(_recoveryParamBase, _recoveryParamStatic);
|
|
85
|
-
|
|
86
|
-
const _messageWithPreimageBase = ByteArray(32).And(Digest.Digest());
|
|
123
|
+
exports.RecoveryParam = _recoveryParam;
|
|
124
|
+
const _messageWithPreimageBase = (0, types_1.ByteArray)(32).And(Digest.Digest());
|
|
87
125
|
const _messageWithPreimageStatic = {};
|
|
88
|
-
const _messageWithPreimage = Object.assign(_messageWithPreimageBase, ByteArray, _messageWithPreimageStatic);
|
|
89
|
-
|
|
90
|
-
const _messageBase = MessageWithPreimage.Or(ByteArray());
|
|
126
|
+
const _messageWithPreimage = Object.assign(_messageWithPreimageBase, types_1.ByteArray, _messageWithPreimageStatic);
|
|
127
|
+
exports.MessageWithPreimage = _messageWithPreimage;
|
|
128
|
+
const _messageBase = exports.MessageWithPreimage.Or((0, types_1.ByteArray)());
|
|
91
129
|
const _messageStatic = {};
|
|
92
|
-
const _message = Object.assign(_messageBase, ByteArray, _messageWithPreimageStatic, _messageStatic);
|
|
93
|
-
|
|
94
|
-
const _signatureBase = ByteArray(64)
|
|
95
|
-
.withConstraint((x) => FieldElement.test(x.slice(0, 32)) || `expected ${x}.r to be within the order of the curve`, {
|
|
130
|
+
const _message = Object.assign(_messageBase, types_1.ByteArray, _messageWithPreimageStatic, _messageStatic);
|
|
131
|
+
exports.Message = _message;
|
|
132
|
+
const _signatureBase = (0, types_1.ByteArray)(64)
|
|
133
|
+
.withConstraint((x) => exports.FieldElement.test(x.slice(0, 32)) || `expected ${x}.r to be within the order of the curve`, {
|
|
96
134
|
name: "Signature.r",
|
|
97
135
|
})
|
|
98
|
-
.withConstraint((x) => FieldElement.test(x.slice(32, 64)) || `expected ${x}.s to be within the order of the curve`, {
|
|
136
|
+
.withConstraint((x) => exports.FieldElement.test(x.slice(32, 64)) || `expected ${x}.s to be within the order of the curve`, {
|
|
99
137
|
name: "Signature.s",
|
|
100
138
|
});
|
|
101
139
|
const _signatureStatic = {
|
|
102
140
|
r: (x) => {
|
|
103
|
-
return checkType(FieldElement, x.slice(0, 32));
|
|
141
|
+
return (0, types_1.checkType)(exports.FieldElement, x.slice(0, 32));
|
|
104
142
|
},
|
|
105
143
|
s: (x) => {
|
|
106
|
-
return checkType(FieldElement, x.slice(32, 64));
|
|
144
|
+
return (0, types_1.checkType)(exports.FieldElement, x.slice(32, 64));
|
|
107
145
|
},
|
|
108
146
|
isLowR: (x) => {
|
|
109
|
-
return !FieldElement.isHigh(Signature.r(x));
|
|
147
|
+
return !exports.FieldElement.isHigh(exports.Signature.r(x));
|
|
110
148
|
},
|
|
111
149
|
isLowS: (x) => {
|
|
112
|
-
return !FieldElement.isHigh(Signature.s(x));
|
|
150
|
+
return !exports.FieldElement.isHigh(exports.Signature.s(x));
|
|
113
151
|
},
|
|
114
152
|
isCanonical: (x) => {
|
|
115
|
-
return Signature.isLowR(x) && Signature.isLowS(x);
|
|
153
|
+
return exports.Signature.isLowR(x) && exports.Signature.isLowS(x);
|
|
116
154
|
},
|
|
117
|
-
signCanonically:
|
|
118
|
-
assertType(ByteArray(), message);
|
|
119
|
-
counter === undefined || Uint32.assert(counter);
|
|
120
|
-
for (let i = counter; i === undefined || i < (counter
|
|
121
|
-
const sig =
|
|
155
|
+
signCanonically: (x, digestAlgorithm, message, counter) => __awaiter(void 0, void 0, void 0, function* () {
|
|
156
|
+
(0, types_1.assertType)((0, types_1.ByteArray)(), message);
|
|
157
|
+
counter === undefined || types_1.Uint32.assert(counter);
|
|
158
|
+
for (let i = counter; i === undefined || i < (counter !== null && counter !== void 0 ? counter : 0) + 128; i = (i !== null && i !== void 0 ? i : -1) + 1) {
|
|
159
|
+
const sig = yield (() => __awaiter(void 0, void 0, void 0, function* () {
|
|
122
160
|
if (digestAlgorithm === null) {
|
|
123
|
-
assertType(ByteArray(32), message);
|
|
161
|
+
(0, types_1.assertType)((0, types_1.ByteArray)(32), message);
|
|
124
162
|
return i === undefined
|
|
125
|
-
?
|
|
126
|
-
:
|
|
163
|
+
? yield x.ecdsaSign(digestAlgorithm, message)
|
|
164
|
+
: yield x.ecdsaSign(digestAlgorithm, message, i);
|
|
127
165
|
}
|
|
128
166
|
else {
|
|
129
167
|
return i === undefined
|
|
130
|
-
?
|
|
131
|
-
:
|
|
168
|
+
? yield x.ecdsaSign(digestAlgorithm, message)
|
|
169
|
+
: yield x.ecdsaSign(digestAlgorithm, message, i);
|
|
132
170
|
}
|
|
133
|
-
})();
|
|
171
|
+
}))();
|
|
134
172
|
if (sig === undefined)
|
|
135
173
|
break;
|
|
136
174
|
//TODO: do integrated lowS correction
|
|
137
|
-
if (Signature.isCanonical(sig))
|
|
175
|
+
if (exports.Signature.isCanonical(sig))
|
|
138
176
|
return sig;
|
|
139
177
|
}
|
|
140
178
|
// This is cryptographically impossible (2^-128 chance) if the key is implemented correctly.
|
|
141
179
|
throw new Error(`Unable to generate canonical signature with public key ${x} over message ${message}; is your key implementation broken?`);
|
|
142
|
-
},
|
|
180
|
+
}),
|
|
143
181
|
verify: (x, digestAlgorithm, message, publicKey) => {
|
|
144
182
|
const msgOrDigest = digestAlgorithm === null
|
|
145
|
-
? checkType(ByteArray(32), message)
|
|
146
|
-
: Digest.Algorithms[digestAlgorithm](checkType(ByteArray(), message));
|
|
183
|
+
? (0, types_1.checkType)((0, types_1.ByteArray)(32), message)
|
|
184
|
+
: Digest.Algorithms[digestAlgorithm]((0, types_1.checkType)((0, types_1.ByteArray)(), message));
|
|
147
185
|
return tinyecc.verify(Buffer.from(msgOrDigest), Buffer.from(publicKey), Buffer.from(x));
|
|
148
186
|
},
|
|
149
187
|
};
|
|
150
|
-
const _signature = Object.assign(_signatureBase, ByteArray, _signatureStatic);
|
|
151
|
-
|
|
152
|
-
const _recoverableSignatureBase = ByteArray(65)
|
|
153
|
-
.And(
|
|
154
|
-
64: RecoveryParam,
|
|
188
|
+
const _signature = Object.assign(_signatureBase, types_1.ByteArray, _signatureStatic);
|
|
189
|
+
exports.Signature = _signature;
|
|
190
|
+
const _recoverableSignatureBase = (0, types_1.ByteArray)(65)
|
|
191
|
+
.And((0, funtypes_1.Object)({
|
|
192
|
+
64: exports.RecoveryParam,
|
|
155
193
|
}))
|
|
156
|
-
.withConstraint((x) => Signature.test(x.slice(0, 64)) || `expected ${x}.sig to be a valid signature`, {
|
|
194
|
+
.withConstraint((x) => exports.Signature.test(x.slice(0, 64)) || `expected ${x}.sig to be a valid signature`, {
|
|
157
195
|
name: "Signature",
|
|
158
196
|
});
|
|
159
197
|
const _recoverableSignatureStatic = {
|
|
160
198
|
from: (x, recoveryParam) => {
|
|
161
|
-
return checkType(RecoverableSignature, core.compatibleBufferConcat([x, new Uint8Array([recoveryParam])]));
|
|
199
|
+
return (0, types_1.checkType)(exports.RecoverableSignature, core.compatibleBufferConcat([x, new Uint8Array([recoveryParam])]));
|
|
162
200
|
},
|
|
163
|
-
fromSignature:
|
|
201
|
+
fromSignature: (x, digestAlgorithm, message, publicKey) => __awaiter(void 0, void 0, void 0, function* () {
|
|
164
202
|
for (let recoveryParam = 0; recoveryParam < 4; recoveryParam++) {
|
|
165
|
-
const out = RecoverableSignature.from(x, recoveryParam);
|
|
166
|
-
if (!CurvePoint.equal(publicKey,
|
|
203
|
+
const out = exports.RecoverableSignature.from(x, recoveryParam);
|
|
204
|
+
if (!exports.CurvePoint.equal(publicKey, yield exports.RecoverableSignature.recoverPublicKey(out, digestAlgorithm, message)))
|
|
167
205
|
continue;
|
|
168
206
|
return out;
|
|
169
207
|
}
|
|
170
208
|
throw new Error(`couldn't find recovery parameter producing public key ${publicKey} for signature ${x} over message ${message}`);
|
|
171
|
-
},
|
|
172
|
-
sig: (x) => checkType(Signature, x.slice(0, 64)),
|
|
173
|
-
recoveryParam: (x) => checkType(RecoveryParam, x[64]),
|
|
174
|
-
isLowRecoveryParam: (x) => [0, 1].includes(RecoverableSignature.recoveryParam(x)),
|
|
175
|
-
isCanonical: (x) => Signature.isCanonical(checkType(Signature, RecoverableSignature.sig(x))) &&
|
|
176
|
-
RecoverableSignature.isLowRecoveryParam(x),
|
|
177
|
-
signCanonically:
|
|
178
|
-
const publicKey =
|
|
179
|
-
assertType(ByteArray(), message);
|
|
180
|
-
counter === undefined || Uint32.assert(counter);
|
|
209
|
+
}),
|
|
210
|
+
sig: (x) => (0, types_1.checkType)(exports.Signature, x.slice(0, 64)),
|
|
211
|
+
recoveryParam: (x) => (0, types_1.checkType)(exports.RecoveryParam, x[64]),
|
|
212
|
+
isLowRecoveryParam: (x) => [0, 1].includes(exports.RecoverableSignature.recoveryParam(x)),
|
|
213
|
+
isCanonical: (x) => exports.Signature.isCanonical((0, types_1.checkType)(exports.Signature, exports.RecoverableSignature.sig(x))) &&
|
|
214
|
+
exports.RecoverableSignature.isLowRecoveryParam(x),
|
|
215
|
+
signCanonically: (x, digestAlgorithm, message, counter) => __awaiter(void 0, void 0, void 0, function* () {
|
|
216
|
+
const publicKey = yield x.getPublicKey();
|
|
217
|
+
(0, types_1.assertType)((0, types_1.ByteArray)(), message);
|
|
218
|
+
counter === undefined || types_1.Uint32.assert(counter);
|
|
181
219
|
// eslint-disable-next-line @typescript-eslint/no-shadow
|
|
182
220
|
const isIndexable = (x) => x !== null && ["object", "function"].includes(typeof x);
|
|
183
221
|
// eslint-disable-next-line @typescript-eslint/no-shadow
|
|
184
222
|
const isECDSARecoverableKey = (x) => isIndexable(x) && "ecdsaSignRecoverable" in x && typeof x.ecdsaSignRecoverable === "function";
|
|
185
223
|
const ecdsaSignRecoverable = isECDSARecoverableKey(x)
|
|
186
224
|
? // eslint-disable-next-line @typescript-eslint/no-shadow
|
|
187
|
-
|
|
225
|
+
(digestAlgorithm, message, counter) => __awaiter(void 0, void 0, void 0, function* () {
|
|
188
226
|
if (digestAlgorithm === null) {
|
|
189
|
-
assertType(ByteArray(32), message);
|
|
227
|
+
(0, types_1.assertType)((0, types_1.ByteArray)(32), message);
|
|
190
228
|
return counter === undefined
|
|
191
|
-
?
|
|
192
|
-
:
|
|
229
|
+
? yield x.ecdsaSignRecoverable(digestAlgorithm, message)
|
|
230
|
+
: yield x.ecdsaSignRecoverable(digestAlgorithm, message, counter);
|
|
193
231
|
}
|
|
194
232
|
else {
|
|
195
233
|
return counter === undefined
|
|
196
|
-
?
|
|
197
|
-
:
|
|
234
|
+
? yield x.ecdsaSignRecoverable(digestAlgorithm, message)
|
|
235
|
+
: yield x.ecdsaSignRecoverable(digestAlgorithm, message, counter);
|
|
198
236
|
}
|
|
199
|
-
}
|
|
237
|
+
})
|
|
200
238
|
: // eslint-disable-next-line @typescript-eslint/no-shadow
|
|
201
|
-
|
|
202
|
-
const sig =
|
|
239
|
+
(digestAlgorithm, message, counter) => __awaiter(void 0, void 0, void 0, function* () {
|
|
240
|
+
const sig = yield exports.Signature.signCanonically(x, digestAlgorithm, message, counter);
|
|
203
241
|
if (sig === undefined)
|
|
204
242
|
return undefined;
|
|
205
|
-
return
|
|
206
|
-
};
|
|
243
|
+
return yield exports.RecoverableSignature.fromSignature(sig, digestAlgorithm, message, publicKey);
|
|
244
|
+
});
|
|
207
245
|
// Technically, this may waste cycles; if Signature.signCanonically grinds the counter to find a canonical signature which then
|
|
208
246
|
// ends up to have a non-canonical recovery parameter, those values will all be re-ground. However, signatures can have
|
|
209
247
|
// non-canonical recovery parameters only with negligible probability, so optimization for that case would be silly.
|
|
210
|
-
for (let i = counter; i === undefined || i < (counter
|
|
211
|
-
const recoverableSig =
|
|
248
|
+
for (let i = counter; i === undefined || i < (counter !== null && counter !== void 0 ? counter : 0) + 128; i = (i !== null && i !== void 0 ? i : -1) + 1) {
|
|
249
|
+
const recoverableSig = yield ecdsaSignRecoverable(digestAlgorithm, message, i);
|
|
212
250
|
if (recoverableSig === undefined)
|
|
213
251
|
break;
|
|
214
252
|
//TODO: do integrated lowS correction
|
|
215
|
-
if (RecoverableSignature.isCanonical(recoverableSig))
|
|
253
|
+
if (exports.RecoverableSignature.isCanonical(recoverableSig))
|
|
216
254
|
return recoverableSig;
|
|
217
255
|
}
|
|
218
256
|
// This is cryptographically impossible (2^-128 chance) if the key is implemented correctly.
|
|
219
257
|
throw new Error(`Unable to generate canonical recoverable signature with public key ${Buffer.from(publicKey).toString("hex")} over message ${Buffer.from(message).toString("hex")}; is your key implementation broken?`);
|
|
220
|
-
},
|
|
221
|
-
recoverPublicKey:
|
|
258
|
+
}),
|
|
259
|
+
recoverPublicKey: (x, digestAlgorithm, message) => __awaiter(void 0, void 0, void 0, function* () {
|
|
222
260
|
// TODO: do this better
|
|
223
261
|
const msgOrDigest = digestAlgorithm === null
|
|
224
|
-
? checkType(ByteArray(32), message)
|
|
225
|
-
: Digest.Algorithms[digestAlgorithm](checkType(ByteArray(), message));
|
|
226
|
-
const sig = RecoverableSignature.sig(x);
|
|
227
|
-
const recoveryParam = RecoverableSignature.recoveryParam(x);
|
|
262
|
+
? (0, types_1.checkType)((0, types_1.ByteArray)(32), message)
|
|
263
|
+
: Digest.Algorithms[digestAlgorithm]((0, types_1.checkType)((0, types_1.ByteArray)(), message));
|
|
264
|
+
const sig = exports.RecoverableSignature.sig(x);
|
|
265
|
+
const recoveryParam = exports.RecoverableSignature.recoveryParam(x);
|
|
228
266
|
const ethSig = core.compatibleBufferConcat([sig, Buffer.from([recoveryParam])]);
|
|
229
|
-
const ethRecovered = (
|
|
230
|
-
return checkType(UncompressedPoint, Buffer.from(ethRecovered.slice(2), "hex"));
|
|
231
|
-
},
|
|
232
|
-
r: (x) => Signature.r(RecoverableSignature.sig(x)),
|
|
233
|
-
s: (x) => Signature.s(RecoverableSignature.sig(x)),
|
|
234
|
-
isLowR: (x) => Signature.isLowR(RecoverableSignature.sig(x)),
|
|
235
|
-
isLowS: (x) => Signature.isLowS(RecoverableSignature.sig(x)),
|
|
267
|
+
const ethRecovered = (yield ethers).utils.recoverPublicKey(msgOrDigest, (yield ethers).utils.splitSignature(ethSig));
|
|
268
|
+
return (0, types_1.checkType)(exports.UncompressedPoint, Buffer.from(ethRecovered.slice(2), "hex"));
|
|
269
|
+
}),
|
|
270
|
+
r: (x) => exports.Signature.r(exports.RecoverableSignature.sig(x)),
|
|
271
|
+
s: (x) => exports.Signature.s(exports.RecoverableSignature.sig(x)),
|
|
272
|
+
isLowR: (x) => exports.Signature.isLowR(exports.RecoverableSignature.sig(x)),
|
|
273
|
+
isLowS: (x) => exports.Signature.isLowS(exports.RecoverableSignature.sig(x)),
|
|
236
274
|
verify: (x, digestAlgorithm, message, publicKey) => {
|
|
237
|
-
return Signature.verify(RecoverableSignature.sig(x), digestAlgorithm, message, publicKey);
|
|
275
|
+
return exports.Signature.verify(exports.RecoverableSignature.sig(x), digestAlgorithm, message, publicKey);
|
|
238
276
|
},
|
|
239
277
|
};
|
|
240
278
|
const _recoverableSignature = Object.assign(_recoverableSignatureBase, _recoverableSignatureStatic);
|
|
241
|
-
|
|
279
|
+
exports.RecoverableSignature = _recoverableSignature;
|
|
242
280
|
//# sourceMappingURL=types.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../src/crypto/isolation/core/secp256k1/types.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../src/crypto/isolation/core/secp256k1/types.ts"],"names":[],"mappings":"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"}
|