@cardano-sdk/crypto 0.1.18 → 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 +2 -4
|
@@ -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,5 +1,5 @@
|
|
|
1
|
-
import { BN } from 'bn.js';
|
|
2
1
|
import { InvalidArgumentError } from '@cardano-sdk/util';
|
|
2
|
+
import { add256bits, add28Mul8 } from './arithmetic';
|
|
3
3
|
import { crypto_auth_hmacsha512, crypto_core_ed25519_add, crypto_scalarmult_ed25519_base_noclamp } from 'libsodium-wrappers-sumo';
|
|
4
4
|
const isHardenedDerivation = (index) => index >= 2147483648;
|
|
5
5
|
const deriveHardened = (index, scalar, iv, chainCode) => {
|
|
@@ -24,17 +24,9 @@ const deriveSoft = (index, scalar, chainCode) => {
|
|
|
24
24
|
const ccMac = crypto_auth_hmacsha512(data, chainCode);
|
|
25
25
|
return { ccMac, zMac };
|
|
26
26
|
};
|
|
27
|
-
const truc28Mul8 = (lhs, rhs) => new BN(lhs, 16, 'le').add(new BN(rhs.slice(0, 28), 16, 'le').mul(new BN(8))).toArrayLike(Buffer, 'le', 32);
|
|
28
27
|
const pointOfTrunc28Mul8 = (sk) => {
|
|
29
|
-
const
|
|
30
|
-
return crypto_scalarmult_ed25519_base_noclamp(
|
|
31
|
-
};
|
|
32
|
-
const add = (lhs, rhs) => {
|
|
33
|
-
let r = new BN(lhs, 16, 'le').add(new BN(rhs, 16, 'le')).toArrayLike(Buffer, 'le').subarray(0, 32);
|
|
34
|
-
if (r.length !== 32) {
|
|
35
|
-
r = Buffer.from(r.toString('hex').padEnd(32, '0'), 'hex');
|
|
36
|
-
}
|
|
37
|
-
return r;
|
|
28
|
+
const scalar = add28Mul8(new Uint8Array(32).fill(0), sk);
|
|
29
|
+
return crypto_scalarmult_ed25519_base_noclamp(scalar);
|
|
38
30
|
};
|
|
39
31
|
export const derivePrivate = (key, index) => {
|
|
40
32
|
const kl = key.subarray(0, 32);
|
|
@@ -44,8 +36,8 @@ export const derivePrivate = (key, index) => {
|
|
|
44
36
|
const chainCode = ccMac.slice(32, 64);
|
|
45
37
|
const zl = zMac.slice(0, 32);
|
|
46
38
|
const zr = zMac.slice(32, 64);
|
|
47
|
-
const left =
|
|
48
|
-
const right =
|
|
39
|
+
const left = add28Mul8(kl, zl);
|
|
40
|
+
const right = add256bits(kr, zr);
|
|
49
41
|
return Buffer.concat([left, right, chainCode]);
|
|
50
42
|
};
|
|
51
43
|
export const derivePublic = (key, index) => {
|
|
@@ -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,27 @@
|
|
|
1
|
+
export const add28Mul8 = (x, y) => {
|
|
2
|
+
let carry = 0;
|
|
3
|
+
const out = new Uint8Array(32);
|
|
4
|
+
for (let i = 0; i < 28; i++) {
|
|
5
|
+
const r = x[i] + (y[i] << 3) + carry;
|
|
6
|
+
out[i] = r & 0xff;
|
|
7
|
+
carry = r >> 8;
|
|
8
|
+
}
|
|
9
|
+
for (let i = 28; i < 32; i++) {
|
|
10
|
+
const r = x[i] + carry;
|
|
11
|
+
out[i] = r & 0xff;
|
|
12
|
+
carry = r >> 8;
|
|
13
|
+
}
|
|
14
|
+
return out;
|
|
15
|
+
};
|
|
16
|
+
export const add256bits = (x, y) => {
|
|
17
|
+
let carry = 0;
|
|
18
|
+
const out = new Uint8Array(32);
|
|
19
|
+
for (let i = 0; i < 32; i++) {
|
|
20
|
+
const r = x[i] + y[i] + carry;
|
|
21
|
+
out[i] = r;
|
|
22
|
+
carry = r >> 8;
|
|
23
|
+
}
|
|
24
|
+
return out;
|
|
25
|
+
};
|
|
26
|
+
export const le32 = (i) => new Uint8Array([i & 0xff, (i >> 8) & 0xff, (i >> 16) & 0xff, (i >> 24) & 0xff]);
|
|
27
|
+
//# sourceMappingURL=arithmetic.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"arithmetic.js","sourceRoot":"","sources":["../../../src/Bip32/arithmetic.ts"],"names":[],"mappings":"AAUA,MAAM,CAAC,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;AASF,MAAM,CAAC,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;AAQF,MAAM,CAAC,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"}
|
|
@@ -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/esm/Bip32/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/Bip32/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,kBAAkB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/Bip32/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,kBAAkB,CAAC;AACjC,cAAc,cAAc,CAAC"}
|