@bitgo-beta/sdk-coin-xtz 1.4.3-alpha.27 → 1.4.3-alpha.270
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/CHANGELOG.md +489 -0
- package/dist/src/index.js +23 -9
- package/dist/src/lib/iface.d.ts +0 -1
- package/dist/src/lib/iface.d.ts.map +1 -1
- package/dist/src/lib/index.js +23 -9
- package/dist/src/lib/keyPair.js +32 -18
- package/dist/src/lib/multisigUtils.js +36 -23
- package/dist/src/lib/transaction.js +28 -14
- package/dist/src/lib/transactionBuilder.js +12 -12
- package/dist/src/lib/transferBuilder.js +1 -1
- package/dist/src/lib/utils.d.ts +26 -27
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +47 -33
- package/dist/src/xtz.d.ts +0 -2
- package/dist/src/xtz.d.ts.map +1 -1
- package/dist/src/xtz.js +7 -4
- package/package.json +10 -10
package/dist/src/lib/keyPair.js
CHANGED
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
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);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -11,13 +15,23 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
|
|
|
11
15
|
}) : function(o, v) {
|
|
12
16
|
o["default"] = v;
|
|
13
17
|
});
|
|
14
|
-
var __importStar = (this && this.__importStar) || function (
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
};
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
21
35
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
22
36
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
23
37
|
};
|
|
@@ -42,16 +56,16 @@ class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
|
|
|
42
56
|
constructor(source) {
|
|
43
57
|
super(source);
|
|
44
58
|
if (!source) {
|
|
45
|
-
const seed = crypto_1.randomBytes(DEFAULT_SEED_SIZE_BYTES);
|
|
59
|
+
const seed = (0, crypto_1.randomBytes)(DEFAULT_SEED_SIZE_BYTES);
|
|
46
60
|
this.hdNode = utxo_lib_1.bip32.fromSeed(seed);
|
|
47
61
|
}
|
|
48
|
-
else if (sdk_core_1.isSeed(source)) {
|
|
62
|
+
else if ((0, sdk_core_1.isSeed)(source)) {
|
|
49
63
|
this.hdNode = utxo_lib_1.bip32.fromSeed(source.seed);
|
|
50
64
|
}
|
|
51
|
-
else if (sdk_core_1.isPrivateKey(source)) {
|
|
65
|
+
else if ((0, sdk_core_1.isPrivateKey)(source)) {
|
|
52
66
|
this.recordKeysFromPrivateKey(source.prv);
|
|
53
67
|
}
|
|
54
|
-
else if (sdk_core_1.isPublicKey(source)) {
|
|
68
|
+
else if ((0, sdk_core_1.isPublicKey)(source)) {
|
|
55
69
|
this.recordKeysFromPublicKey(source.pub);
|
|
56
70
|
}
|
|
57
71
|
else {
|
|
@@ -68,10 +82,10 @@ class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
|
|
|
68
82
|
* @param {string} prv An extended or raw private key
|
|
69
83
|
*/
|
|
70
84
|
recordKeysFromPrivateKey(prv) {
|
|
71
|
-
if (sdk_core_1.isValidXprv(prv)) {
|
|
85
|
+
if ((0, sdk_core_1.isValidXprv)(prv)) {
|
|
72
86
|
this.hdNode = utxo_lib_1.bip32.fromBase58(prv);
|
|
73
87
|
}
|
|
74
|
-
else if (sdk_core_1.isValidPrv(prv)) {
|
|
88
|
+
else if ((0, sdk_core_1.isValidPrv)(prv)) {
|
|
75
89
|
// Cannot create the HD node without the chain code, so create a regular Key Chain
|
|
76
90
|
this.keyPair = utxo_lib_1.ECPair.fromPrivateKey(Buffer.from(prv, 'hex'));
|
|
77
91
|
}
|
|
@@ -89,10 +103,10 @@ class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
|
|
|
89
103
|
* @param {string} pub - An extended, compressed, or uncompressed public key
|
|
90
104
|
*/
|
|
91
105
|
recordKeysFromPublicKey(pub) {
|
|
92
|
-
if (sdk_core_1.isValidXpub(pub)) {
|
|
106
|
+
if ((0, sdk_core_1.isValidXpub)(pub)) {
|
|
93
107
|
this.hdNode = utxo_lib_1.bip32.fromBase58(pub);
|
|
94
108
|
}
|
|
95
|
-
else if (sdk_core_1.isValidPub(pub)) {
|
|
109
|
+
else if ((0, sdk_core_1.isValidPub)(pub)) {
|
|
96
110
|
// Cannot create an HD node without the chain code, so create a regular Key Chain
|
|
97
111
|
this.keyPair = utxo_lib_1.ECPair.fromPublicKey(Buffer.from(pub, 'hex'));
|
|
98
112
|
}
|
|
@@ -127,9 +141,9 @@ class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
|
|
|
127
141
|
getAddress() {
|
|
128
142
|
const pub = this.getPublicKey({ compressed: true });
|
|
129
143
|
const out = Buffer.alloc(20);
|
|
130
|
-
const b2b = blake2b_1.default(out.length).update(pub).digest(out);
|
|
144
|
+
const b2b = (0, blake2b_1.default)(out.length).update(pub).digest(out);
|
|
131
145
|
return Utils.base58encode(Utils.hashTypes.tz2.prefix, b2b);
|
|
132
146
|
}
|
|
133
147
|
}
|
|
134
148
|
exports.KeyPair = KeyPair;
|
|
135
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
149
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyPair.js","sourceRoot":"","sources":["../../../src/lib/keyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import { randomBytes } from 'crypto';\nimport blake2b from '@bitgo-beta/blake2b';\nimport { bip32, ECPair } from '@bitgo-beta/utxo-lib';\nimport {\n  DefaultKeys,\n  isPrivateKey,\n  isPublicKey,\n  isSeed,\n  isValidPrv,\n  isValidPub,\n  isValidXprv,\n  isValidXpub,\n  KeyPairOptions,\n  Secp256k1ExtendedKeyPair,\n} from '@bitgo-beta/sdk-core';\nimport * as Utils from './utils';\n\nconst DEFAULT_SEED_SIZE_BYTES = 16;\n\n/**\n * Tezos keys and address management.\n */\nexport class KeyPair extends Secp256k1ExtendedKeyPair {\n  /**\n   * Public constructor. By default, creates a key pair with a random master seed.\n   *\n   * @param {KeyPairOptions} source Either a master seed, a private key (extended or raw), or a public key\n   *     (extended, compressed, or uncompressed)\n   */\n  constructor(source?: KeyPairOptions) {\n    super(source);\n    if (!source) {\n      const seed = randomBytes(DEFAULT_SEED_SIZE_BYTES);\n      this.hdNode = bip32.fromSeed(seed);\n    } else if (isSeed(source)) {\n      this.hdNode = bip32.fromSeed(source.seed);\n    } else if (isPrivateKey(source)) {\n      this.recordKeysFromPrivateKey(source.prv);\n    } else if (isPublicKey(source)) {\n      this.recordKeysFromPublicKey(source.pub);\n    } else {\n      throw new Error('Invalid key pair options');\n    }\n\n    if (this.hdNode) {\n      this.keyPair = Secp256k1ExtendedKeyPair.toKeyPair(this.hdNode);\n    }\n  }\n\n  /**\n   * Build a Hierarchical Deterministic node or an ECPair from a private key.\n   * Specific Tezos implementation\n   *\n   * @param {string} prv An extended or raw private key\n   */\n  recordKeysFromPrivateKey(prv: string): void {\n    if (isValidXprv(prv)) {\n      this.hdNode = bip32.fromBase58(prv);\n    } else if (isValidPrv(prv)) {\n      // Cannot create the HD node without the chain code, so create a regular Key Chain\n      this.keyPair = ECPair.fromPrivateKey(Buffer.from(prv, 'hex'));\n    } else if (Utils.isValidKey(prv, Utils.hashTypes.spsk)) {\n      this.keyPair = ECPair.fromPrivateKey(Utils.decodeKey(prv, Utils.hashTypes.spsk));\n    } else {\n      throw new Error('Unsupported private key');\n    }\n  }\n\n  /**\n   * Build a Hierarchical Deterministic node or an ECPair from a public key.\n   * Specific Tezos implementation\n   *\n   * @param {string} pub - An extended, compressed, or uncompressed public key\n   */\n  recordKeysFromPublicKey(pub: string): void {\n    if (isValidXpub(pub)) {\n      this.hdNode = bip32.fromBase58(pub);\n    } else if (isValidPub(pub)) {\n      // Cannot create an HD node without the chain code, so create a regular Key Chain\n      this.keyPair = ECPair.fromPublicKey(Buffer.from(pub, 'hex'));\n    } else if (Utils.isValidKey(pub, Utils.hashTypes.sppk)) {\n      this.keyPair = ECPair.fromPublicKey(Utils.decodeKey(pub, Utils.hashTypes.sppk));\n    } else {\n      throw new Error('Unsupported public key: ' + pub);\n    }\n  }\n\n  /**\n   * Return Tezos default keys with the respective prefixes\n   *\n   * @returns {DefaultKeys} The keys in the protocol default key format\n   */\n  getKeys(): DefaultKeys {\n    // Always use the compressed version to be consistent\n    const result: DefaultKeys = {\n      pub: Utils.base58encode(Utils.hashTypes.sppk.prefix, this.getPublicKey({ compressed: true })),\n    };\n    const prvBuffer: Buffer | undefined = this.getPrivateKey();\n    if (prvBuffer) {\n      result.prv = Utils.base58encode(Utils.hashTypes.spsk.prefix, prvBuffer);\n    }\n    return result;\n  }\n\n  /**\n   * Get a public address.\n   *\n   * @returns {string} The public address\n   */\n  getAddress(): string {\n    const pub = this.getPublicKey({ compressed: true });\n    const out = Buffer.alloc(20);\n    const b2b = blake2b(out.length).update(pub).digest(out);\n    return Utils.base58encode(Utils.hashTypes.tz2.prefix, b2b);\n  }\n}\n"]}
|