@cardano-sdk/crypto 0.1.17 → 0.1.19
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/cjs/Bip32/Bip32KeyDerivation.d.ts.map +1 -1
- package/dist/cjs/Bip32/Bip32KeyDerivation.js +5 -13
- package/dist/cjs/Bip32/Bip32KeyDerivation.js.map +1 -1
- package/dist/cjs/Bip32/arithmetic.d.ts +4 -0
- package/dist/cjs/Bip32/arithmetic.d.ts.map +1 -0
- package/dist/cjs/Bip32/arithmetic.js +33 -0
- package/dist/cjs/Bip32/arithmetic.js.map +1 -0
- package/dist/cjs/Bip32/index.d.ts +1 -0
- package/dist/cjs/Bip32/index.d.ts.map +1 -1
- package/dist/cjs/Bip32/index.js +1 -0
- package/dist/cjs/Bip32/index.js.map +1 -1
- package/dist/cjs/tsconfig.tsbuildinfo +1 -1
- package/dist/esm/Bip32/Bip32KeyDerivation.d.ts.map +1 -1
- package/dist/esm/Bip32/Bip32KeyDerivation.js +5 -13
- package/dist/esm/Bip32/Bip32KeyDerivation.js.map +1 -1
- package/dist/esm/Bip32/arithmetic.d.ts +4 -0
- package/dist/esm/Bip32/arithmetic.d.ts.map +1 -0
- package/dist/esm/Bip32/arithmetic.js +27 -0
- package/dist/esm/Bip32/arithmetic.js.map +1 -0
- package/dist/esm/Bip32/index.d.ts +1 -0
- package/dist/esm/Bip32/index.d.ts.map +1 -1
- package/dist/esm/Bip32/index.js +1 -0
- package/dist/esm/Bip32/index.js.map +1 -1
- package/dist/esm/tsconfig.tsbuildinfo +1 -1
- package/package.json +4 -6
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Bip32KeyDerivation.d.ts","sourceRoot":"","sources":["../../../src/Bip32/Bip32KeyDerivation.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Bip32KeyDerivation.d.ts","sourceRoot":"","sources":["../../../src/Bip32/Bip32KeyDerivation.ts"],"names":[],"mappings":"AAuGA,eAAO,MAAM,aAAa,QAAS,MAAM,SAAS,MAAM,KAAG,MAe1D,CAAC;AAWF,eAAO,MAAM,YAAY,QAAS,MAAM,SAAS,MAAM,KAAG,MAuBzD,CAAC"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.derivePublic = exports.derivePrivate = void 0;
|
|
4
|
-
const bn_js_1 = require("bn.js");
|
|
5
4
|
const util_1 = require("@cardano-sdk/util");
|
|
5
|
+
const arithmetic_1 = require("./arithmetic");
|
|
6
6
|
const libsodium_wrappers_sumo_1 = require("libsodium-wrappers-sumo");
|
|
7
7
|
const isHardenedDerivation = (index) => index >= 2147483648;
|
|
8
8
|
const deriveHardened = (index, scalar, iv, chainCode) => {
|
|
@@ -27,17 +27,9 @@ const deriveSoft = (index, scalar, chainCode) => {
|
|
|
27
27
|
const ccMac = (0, libsodium_wrappers_sumo_1.crypto_auth_hmacsha512)(data, chainCode);
|
|
28
28
|
return { ccMac, zMac };
|
|
29
29
|
};
|
|
30
|
-
const truc28Mul8 = (lhs, rhs) => new bn_js_1.BN(lhs, 16, 'le').add(new bn_js_1.BN(rhs.slice(0, 28), 16, 'le').mul(new bn_js_1.BN(8))).toArrayLike(Buffer, 'le', 32);
|
|
31
30
|
const pointOfTrunc28Mul8 = (sk) => {
|
|
32
|
-
const
|
|
33
|
-
return (0, libsodium_wrappers_sumo_1.crypto_scalarmult_ed25519_base_noclamp)(
|
|
34
|
-
};
|
|
35
|
-
const add = (lhs, rhs) => {
|
|
36
|
-
let r = new bn_js_1.BN(lhs, 16, 'le').add(new bn_js_1.BN(rhs, 16, 'le')).toArrayLike(Buffer, 'le').subarray(0, 32);
|
|
37
|
-
if (r.length !== 32) {
|
|
38
|
-
r = Buffer.from(r.toString('hex').padEnd(32, '0'), 'hex');
|
|
39
|
-
}
|
|
40
|
-
return r;
|
|
31
|
+
const scalar = (0, arithmetic_1.add28Mul8)(new Uint8Array(32).fill(0), sk);
|
|
32
|
+
return (0, libsodium_wrappers_sumo_1.crypto_scalarmult_ed25519_base_noclamp)(scalar);
|
|
41
33
|
};
|
|
42
34
|
const derivePrivate = (key, index) => {
|
|
43
35
|
const kl = key.subarray(0, 32);
|
|
@@ -47,8 +39,8 @@ const derivePrivate = (key, index) => {
|
|
|
47
39
|
const chainCode = ccMac.slice(32, 64);
|
|
48
40
|
const zl = zMac.slice(0, 32);
|
|
49
41
|
const zr = zMac.slice(32, 64);
|
|
50
|
-
const left =
|
|
51
|
-
const right =
|
|
42
|
+
const left = (0, arithmetic_1.add28Mul8)(kl, zl);
|
|
43
|
+
const right = (0, arithmetic_1.add256bits)(kr, zr);
|
|
52
44
|
return Buffer.concat([left, right, chainCode]);
|
|
53
45
|
};
|
|
54
46
|
exports.derivePrivate = derivePrivate;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Bip32KeyDerivation.js","sourceRoot":"","sources":["../../../src/Bip32/Bip32KeyDerivation.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"Bip32KeyDerivation.js","sourceRoot":"","sources":["../../../src/Bip32/Bip32KeyDerivation.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"arithmetic.d.ts","sourceRoot":"","sources":["../../../src/Bip32/arithmetic.ts"],"names":[],"mappings":"AAUA,eAAO,MAAM,SAAS,MAAO,UAAU,KAAK,UAAU,KAAG,UAexD,CAAC;AASF,eAAO,MAAM,UAAU,MAAO,UAAU,KAAK,UAAU,KAAG,UAWzD,CAAC;AAQF,eAAO,MAAM,IAAI,MAAO,MAAM,KAAG,UACgD,CAAC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.le32 = exports.add256bits = exports.add28Mul8 = void 0;
|
|
4
|
+
const add28Mul8 = (x, y) => {
|
|
5
|
+
let carry = 0;
|
|
6
|
+
const out = new Uint8Array(32);
|
|
7
|
+
for (let i = 0; i < 28; i++) {
|
|
8
|
+
const r = x[i] + (y[i] << 3) + carry;
|
|
9
|
+
out[i] = r & 0xff;
|
|
10
|
+
carry = r >> 8;
|
|
11
|
+
}
|
|
12
|
+
for (let i = 28; i < 32; i++) {
|
|
13
|
+
const r = x[i] + carry;
|
|
14
|
+
out[i] = r & 0xff;
|
|
15
|
+
carry = r >> 8;
|
|
16
|
+
}
|
|
17
|
+
return out;
|
|
18
|
+
};
|
|
19
|
+
exports.add28Mul8 = add28Mul8;
|
|
20
|
+
const add256bits = (x, y) => {
|
|
21
|
+
let carry = 0;
|
|
22
|
+
const out = new Uint8Array(32);
|
|
23
|
+
for (let i = 0; i < 32; i++) {
|
|
24
|
+
const r = x[i] + y[i] + carry;
|
|
25
|
+
out[i] = r;
|
|
26
|
+
carry = r >> 8;
|
|
27
|
+
}
|
|
28
|
+
return out;
|
|
29
|
+
};
|
|
30
|
+
exports.add256bits = add256bits;
|
|
31
|
+
const le32 = (i) => new Uint8Array([i & 0xff, (i >> 8) & 0xff, (i >> 16) & 0xff, (i >> 24) & 0xff]);
|
|
32
|
+
exports.le32 = le32;
|
|
33
|
+
//# sourceMappingURL=arithmetic.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"arithmetic.js","sourceRoot":"","sources":["../../../src/Bip32/arithmetic.ts"],"names":[],"mappings":";;;AAUO,MAAM,SAAS,GAAG,CAAC,CAAa,EAAE,CAAa,EAAc,EAAE;IACpE,IAAI,KAAK,GAAG,CAAC,CAAC;IACd,MAAM,GAAG,GAAe,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC;IAE3C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE;QAC3B,MAAM,CAAC,GAAW,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC;QAC7C,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;QAClB,KAAK,GAAG,CAAC,IAAI,CAAC,CAAC;KAChB;IACD,KAAK,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE;QAC5B,MAAM,CAAC,GAAW,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;QAC/B,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;QAClB,KAAK,GAAG,CAAC,IAAI,CAAC,CAAC;KAChB;IACD,OAAO,GAAG,CAAC;AACb,CAAC,CAAC;AAfW,QAAA,SAAS,aAepB;AASK,MAAM,UAAU,GAAG,CAAC,CAAa,EAAE,CAAa,EAAc,EAAE;IACrE,IAAI,KAAK,GAAG,CAAC,CAAC;IACd,MAAM,GAAG,GAAe,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC;IAE3C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE;QAC3B,MAAM,CAAC,GAAW,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;QACtC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACX,KAAK,GAAG,CAAC,IAAI,CAAC,CAAC;KAChB;IAED,OAAO,GAAG,CAAC;AACb,CAAC,CAAC;AAXW,QAAA,UAAU,cAWrB;AAQK,MAAM,IAAI,GAAG,CAAC,CAAS,EAAc,EAAE,CAC5C,IAAI,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;AADrE,QAAA,IAAI,QACiE"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/Bip32/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,kBAAkB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/Bip32/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,kBAAkB,CAAC;AACjC,cAAc,cAAc,CAAC"}
|
package/dist/cjs/Bip32/index.js
CHANGED
|
@@ -16,4 +16,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./Bip32PrivateKey"), exports);
|
|
18
18
|
__exportStar(require("./Bip32PublicKey"), exports);
|
|
19
|
+
__exportStar(require("./arithmetic"), exports);
|
|
19
20
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/Bip32/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAkC;AAClC,mDAAiC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/Bip32/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAkC;AAClC,mDAAiC;AACjC,+CAA6B"}
|