@bitgo-beta/sdk-coin-cspr 1.2.19-beta.99 → 1.2.19-beta.991
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 +553 -0
- package/dist/src/cspr.d.ts +5 -2
- package/dist/src/cspr.d.ts.map +1 -1
- package/dist/src/cspr.js +36 -14
- package/dist/src/index.js +23 -9
- package/dist/src/lib/constants.d.ts +1 -1
- package/dist/src/lib/constants.d.ts.map +1 -1
- package/dist/src/lib/constants.js +2 -2
- package/dist/src/lib/delegateBuilder.js +6 -6
- package/dist/src/lib/ifaces.d.ts +2 -2
- package/dist/src/lib/ifaces.d.ts.map +1 -1
- package/dist/src/lib/index.js +23 -9
- package/dist/src/lib/keyPair.js +9 -10
- package/dist/src/lib/transaction.js +47 -34
- package/dist/src/lib/transactionBuilder.js +3 -3
- package/dist/src/lib/transactionBuilderFactory.js +2 -2
- package/dist/src/lib/transferBuilder.js +9 -9
- package/dist/src/lib/undelegateBuilder.js +6 -6
- package/dist/src/lib/utils.js +58 -45
- package/dist/src/lib/walletInitializationBuilder.js +1 -1
- package/dist/src/tcspr.js +1 -1
- package/package.json +9 -9
package/dist/src/cspr.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
|
};
|
|
@@ -27,7 +41,7 @@ exports.Cspr = void 0;
|
|
|
27
41
|
* @prettier
|
|
28
42
|
*/
|
|
29
43
|
const CsprLib = __importStar(require("./lib"));
|
|
30
|
-
const
|
|
44
|
+
const secp256k1_1 = require("@bitgo-beta/secp256k1");
|
|
31
45
|
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
32
46
|
const statics_1 = require("@bitgo-beta/statics");
|
|
33
47
|
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
@@ -54,6 +68,10 @@ class Cspr extends sdk_core_1.BaseCoin {
|
|
|
54
68
|
getBaseFactor() {
|
|
55
69
|
return Math.pow(10, this._staticsCoin.decimalPlaces);
|
|
56
70
|
}
|
|
71
|
+
/** inherited doc */
|
|
72
|
+
getDefaultMultisigType() {
|
|
73
|
+
return sdk_core_1.multisigTypes.onchain;
|
|
74
|
+
}
|
|
57
75
|
async verifyTransaction(params) {
|
|
58
76
|
// TODO: Implement when available on the SDK.
|
|
59
77
|
return true;
|
|
@@ -177,7 +195,7 @@ class Cspr extends sdk_core_1.BaseCoin {
|
|
|
177
195
|
}
|
|
178
196
|
}
|
|
179
197
|
else {
|
|
180
|
-
const keyPair =
|
|
198
|
+
const keyPair = secp256k1_1.ECPair.makeRandom();
|
|
181
199
|
if (!keyPair.privateKey) {
|
|
182
200
|
throw new Error('no privateKey');
|
|
183
201
|
}
|
|
@@ -193,7 +211,7 @@ class Cspr extends sdk_core_1.BaseCoin {
|
|
|
193
211
|
*/
|
|
194
212
|
async signMessage(key, message) {
|
|
195
213
|
const keyPair = new CsprLib.KeyPair({ prv: key.prv });
|
|
196
|
-
const messageHex = message
|
|
214
|
+
const messageHex = typeof message === 'string' ? message : message.toString('hex');
|
|
197
215
|
const signatureData = CsprLib.Utils.signMessage(keyPair, messageHex);
|
|
198
216
|
return Buffer.from(signatureData.signature);
|
|
199
217
|
}
|
|
@@ -277,8 +295,8 @@ class Cspr extends sdk_core_1.BaseCoin {
|
|
|
277
295
|
id,
|
|
278
296
|
outputs,
|
|
279
297
|
outputAmount,
|
|
280
|
-
changeOutputs: [],
|
|
281
|
-
changeAmount: '0',
|
|
298
|
+
changeOutputs: [], // account based does not use change outputs
|
|
299
|
+
changeAmount: '0', // account base does not make change
|
|
282
300
|
transferId,
|
|
283
301
|
fee: params.feeInfo,
|
|
284
302
|
operations,
|
|
@@ -287,6 +305,10 @@ class Cspr extends sdk_core_1.BaseCoin {
|
|
|
287
305
|
getBuilder() {
|
|
288
306
|
return new CsprLib.TransactionBuilderFactory(statics_1.coins.get(this.getChain()));
|
|
289
307
|
}
|
|
308
|
+
/** @inheritDoc */
|
|
309
|
+
auditDecryptedKey(params) {
|
|
310
|
+
throw new sdk_core_1.MethodNotImplementedError();
|
|
311
|
+
}
|
|
290
312
|
}
|
|
291
313
|
exports.Cspr = Cspr;
|
|
292
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cspr.js","sourceRoot":"","sources":["../../src/cspr.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport * as CsprLib from './lib';\nimport { ECPair } from '@bitgo-beta/utxo-lib';\nimport BigNumber from 'bignumber.js';\n\nimport { BaseCoin as StaticsBaseCoin, CoinFamily, coins } from '@bitgo-beta/statics';\nimport {\n  BaseCoin,\n  BitGoBase,\n  InvalidAddressError,\n  InvalidTransactionError,\n  KeyPair,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  SignedTransaction,\n  SignTransactionOptions as BaseSignTransactionOptions,\n  TransactionExplanation,\n  TransactionPrebuild as BaseTransactionPrebuild,\n  TransactionType,\n  UnexpectedAddressError,\n  VerifyAddressOptions,\n  VerifyTransactionOptions,\n} from '@bitgo-beta/sdk-core';\n\ninterface SignTransactionOptions extends BaseSignTransactionOptions {\n  txPrebuild: TransactionPrebuild;\n  prv: string;\n}\n\nexport interface TransactionPrebuild extends BaseTransactionPrebuild {\n  txHex: string;\n}\n\nexport interface TransactionFee {\n  gasLimit: string;\n  gasPrice: string;\n}\n\nexport interface ExplainTransactionOptions {\n  txHex?: string;\n  halfSigned?: {\n    txHex: string;\n  };\n  feeInfo: TransactionFee;\n}\n\ninterface SupplementGenerateWalletOptions {\n  rootPrivateKey?: string;\n}\n\ninterface TransactionOutput {\n  address: string;\n  amount: string;\n  coin: string;\n}\n\ninterface TransactionOperation {\n  type: number;\n  amount: string;\n  coin: string;\n  validator: string;\n}\n\ninterface CsprVerifyAddressOptions extends VerifyAddressOptions {\n  rootAddress: string;\n}\n\nexport class Cspr extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n\n  constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Cspr(bitgo, staticsCoin);\n  }\n\n  getChain(): string {\n    return this._staticsCoin.name;\n  }\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n  getFullName(): string {\n    return this._staticsCoin.fullName;\n  }\n  getBaseFactor(): string | number {\n    return Math.pow(10, this._staticsCoin.decimalPlaces);\n  }\n\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    // TODO: Implement when available on the SDK.\n    return true;\n  }\n\n  /**\n   * Check if address is valid, then make sure it matches the root address.\n   *\n   * @param {VerifyAddressOptions} params address and rootAddress to verify\n   */\n  async isWalletAddress(params: CsprVerifyAddressOptions): Promise<boolean> {\n    const { address, rootAddress } = params;\n    if (!this.isValidAddress(address)) {\n      throw new InvalidAddressError(`invalid address: ${address}`);\n    }\n    if (!this.isValidAddress(rootAddress)) {\n      throw new InvalidAddressError('wallet root address is not valid');\n    }\n\n    const newAddressDetails = CsprLib.Utils.getAddressDetails(address);\n    const rootAddressDetails = CsprLib.Utils.getAddressDetails(rootAddress);\n    if (newAddressDetails.address.toLowerCase() !== rootAddressDetails.address.toLowerCase()) {\n      throw new UnexpectedAddressError(`address validation failure: ${newAddressDetails.address} vs ${rootAddress}`);\n    }\n    return true;\n  }\n\n  /**\n   * Generate Casper key pair - BitGo xpub format\n   *\n   * @param {Buffer} seed - Seed from which the new keypair should be generated, otherwise a random seed is used\n   * @returns {Object} object with generated xpub and xprv\n   */\n  generateKeyPair(seed?: Buffer): KeyPair {\n    const keyPair = seed ? new CsprLib.KeyPair({ seed }) : new CsprLib.KeyPair();\n    const keys = keyPair.getExtendedKeys();\n\n    if (!keys.xprv) {\n      throw new Error('Missing xprv in key generation.');\n    }\n\n    return {\n      pub: keys.xpub,\n      prv: keys.xprv,\n    };\n  }\n\n  isValidPub(pub: string): boolean {\n    // TODO(STLX-1344): Validate using account-lib when available\n    //  return accountLib.Cspr.Utils.isValidPublicKey(pub);\n    try {\n      new CsprLib.KeyPair({ pub });\n      return true;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  /**\n   * Return boolean indicating whether input is valid private key for the coin\n   *\n   * @param prv the prv to be checked\n   * @returns is it valid?\n   */\n  isValidPrv(prv: string): boolean {\n    // TODO(STLX-1345): Validate using account-lib when available\n    //  return accountLib.Cspr.Utils.isValidPrivateKey(prv);\n    try {\n      new CsprLib.KeyPair({ prv });\n      return true;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  /**\n   * Return boolean indicating whether input is valid CSPR address\n   *\n   * @param address the pub to be checked\n   * @returns true if the address is valid\n   */\n  isValidAddress(address: string): boolean {\n    try {\n      const addressDetails = CsprLib.Utils.getAddressDetails(address);\n      return address === CsprLib.Utils.normalizeAddress(addressDetails);\n    } catch (e) {\n      return false;\n    }\n  }\n\n  /**\n   * Assemble keychain and half-sign prebuilt transaction\n   *\n   * @param {SignTransactionOptions} params data required to rebuild and sign the transaction\n   * @param {TransactionPrebuild} params.txPrebuild prebuild object returned by platform\n   * @param {String} params.prv user prv used to sign the transaction\n   * @returns Bluebird<SignedTransaction>\n   */\n  async signTransaction(params: SignTransactionOptions): Promise<SignedTransaction> {\n    const txBuilder = this.getBuilder().from(params.txPrebuild.txHex);\n    const key = params.prv;\n    txBuilder.sign({ key });\n\n    const transaction: any = await txBuilder.build();\n    if (!transaction) {\n      throw new InvalidTransactionError('Error while trying to build transaction');\n    }\n    const response = {\n      txHex: transaction.toBroadcastFormat(),\n    };\n    return transaction.signature.length >= 2 ? response : { halfSigned: response };\n  }\n\n  async parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction> {\n    return {};\n  }\n\n  /**\n   * Extend walletParams with extra params required for generating a Casper wallet\n   *\n   * Casper wallets have three three keys, user, backup and bitgo.\n   * Initially, we need a root prv to generate the account, which must be distinct from all three keychains on the wallet.\n   * If a root private key is not provided, a random one is generated.\n   * The root public key is the basis for the wallet root address.\n   */\n  async supplementGenerateWallet(\n    walletParams: SupplementGenerateWalletOptions\n  ): Promise<SupplementGenerateWalletOptions> {\n    if (walletParams.rootPrivateKey) {\n      if (!this.isValidPrv(walletParams.rootPrivateKey) || walletParams.rootPrivateKey.length !== 64) {\n        throw new Error('rootPrivateKey needs to be a hexadecimal private key string');\n      }\n    } else {\n      const keyPair = ECPair.makeRandom();\n      if (!keyPair.privateKey) {\n        throw new Error('no privateKey');\n      }\n      walletParams.rootPrivateKey = keyPair.privateKey.toString('hex');\n    }\n    return walletParams;\n  }\n\n  /**\n   * Sign message with private key\n   *\n   * @param key\n   * @param message\n   */\n  async signMessage(key: KeyPair, message: string | Buffer): Promise<Buffer> {\n    const keyPair = new CsprLib.KeyPair({ prv: key.prv });\n    const messageHex = message instanceof Buffer ? message.toString('hex') : message;\n    const signatureData = CsprLib.Utils.signMessage(keyPair, messageHex);\n    return Buffer.from(signatureData.signature);\n  }\n\n  /**\n   * Explain a Casper transaction from Raw Tx\n   *\n   * @param {ExplainTransactionOptions} params given explain transaction params\n   * @param {String} params.txHex raw transaction\n   * @param {String} params.halfSigned.txHex raw half signed transaction\n   * @param {TransactionFee} fee fee information\n   * @returns Bluebird<TransactionExplanation>\n   */\n  async explainTransaction(params: ExplainTransactionOptions): Promise<TransactionExplanation> {\n    const txHex = params.txHex || (params.halfSigned && params.halfSigned.txHex);\n    if (!txHex || !params.feeInfo) {\n      throw new Error('missing explain tx parameters');\n    }\n    const txBuilder = this.getBuilder().from(txHex);\n\n    const tx: any = await txBuilder.build();\n    if (!tx) {\n      throw new InvalidTransactionError('Error while trying to build transaction');\n    }\n    const id = Buffer.from(tx.casperTx.hash).toString('hex');\n    const amount = CsprLib.Utils.getTransferAmount(tx.casperTx.session);\n    let transferId;\n    const outputs: TransactionOutput[] = [];\n    const operations: TransactionOperation[] = [];\n\n    switch (tx.type) {\n      case TransactionType.Send: {\n        transferId = CsprLib.Utils.getTransferId(tx.casperTx.session);\n        const toAddress = CsprLib.Utils.getTransferDestinationAddress(tx._deploy.session);\n        outputs.push({\n          address: toAddress,\n          amount,\n          coin: this.getChain(),\n        });\n        break;\n      }\n      case TransactionType.StakingLock: {\n        const validator = CsprLib.Utils.getValidatorAddress(tx._deploy.session);\n        operations.push({\n          type: TransactionType.StakingLock,\n          amount,\n          coin: this.getChain(),\n          validator: validator,\n        });\n        break;\n      }\n      case TransactionType.StakingUnlock: {\n        const validator = CsprLib.Utils.getValidatorAddress(tx._deploy.session);\n        operations.push({\n          type: TransactionType.StakingUnlock,\n          amount,\n          coin: this.getChain(),\n          validator: validator,\n        });\n        break;\n      }\n      default: {\n        throw new InvalidTransactionError('Error while trying to get transaction type');\n      }\n    }\n\n    const outputAmount = outputs\n      .reduce((acumulator, output) => {\n        const currentValue = new BigNumber(output.amount);\n        return acumulator.plus(currentValue);\n      }, new BigNumber(0))\n      .toFixed(0);\n\n    const displayOrder = [\n      'id',\n      'outputAmount',\n      'changeAmount',\n      'outputs',\n      'changeOutputs',\n      'transferId',\n      'fee',\n      'operations',\n    ];\n\n    return {\n      displayOrder,\n      id,\n      outputs,\n      outputAmount,\n      changeOutputs: [], // account based does not use change outputs\n      changeAmount: '0', // account base does not make change\n      transferId,\n      fee: params.feeInfo,\n      operations,\n    } as any;\n  }\n\n  private getBuilder(): CsprLib.TransactionBuilderFactory {\n    return new CsprLib.TransactionBuilderFactory(coins.get(this.getChain()));\n  }\n}\n"]}
|
|
314
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cspr.js","sourceRoot":"","sources":["../../src/cspr.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport * as CsprLib from './lib';\nimport { ECPair } from '@bitgo-beta/secp256k1';\nimport BigNumber from 'bignumber.js';\n\nimport { BaseCoin as StaticsBaseCoin, CoinFamily, coins } from '@bitgo-beta/statics';\nimport {\n  AuditDecryptedKeyParams,\n  BaseCoin,\n  BitGoBase,\n  InvalidAddressError,\n  InvalidTransactionError,\n  KeyPair,\n  MultisigType,\n  multisigTypes,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  SignedTransaction,\n  SignTransactionOptions as BaseSignTransactionOptions,\n  TransactionExplanation,\n  TransactionPrebuild as BaseTransactionPrebuild,\n  TransactionType,\n  UnexpectedAddressError,\n  VerifyAddressOptions,\n  VerifyTransactionOptions,\n  MethodNotImplementedError,\n} from '@bitgo-beta/sdk-core';\n\ninterface SignTransactionOptions extends BaseSignTransactionOptions {\n  txPrebuild: TransactionPrebuild;\n  prv: string;\n}\n\nexport interface TransactionPrebuild extends BaseTransactionPrebuild {\n  txHex: string;\n}\n\nexport interface TransactionFee {\n  gasLimit: string;\n  gasPrice: string;\n}\n\nexport interface ExplainTransactionOptions {\n  txHex?: string;\n  halfSigned?: {\n    txHex: string;\n  };\n  feeInfo: TransactionFee;\n}\n\ninterface SupplementGenerateWalletOptions {\n  rootPrivateKey?: string;\n}\n\ninterface TransactionOutput {\n  address: string;\n  amount: string;\n  coin: string;\n}\n\ninterface TransactionOperation {\n  type: number;\n  amount: string;\n  coin: string;\n  validator: string;\n}\n\ninterface CsprVerifyAddressOptions extends VerifyAddressOptions {\n  rootAddress: string;\n}\n\nexport class Cspr extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n\n  constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Cspr(bitgo, staticsCoin);\n  }\n\n  getChain(): string {\n    return this._staticsCoin.name;\n  }\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n  getFullName(): string {\n    return this._staticsCoin.fullName;\n  }\n  getBaseFactor(): string | number {\n    return Math.pow(10, this._staticsCoin.decimalPlaces);\n  }\n\n  /** inherited doc */\n  getDefaultMultisigType(): MultisigType {\n    return multisigTypes.onchain;\n  }\n\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    // TODO: Implement when available on the SDK.\n    return true;\n  }\n\n  /**\n   * Check if address is valid, then make sure it matches the root address.\n   *\n   * @param {VerifyAddressOptions} params address and rootAddress to verify\n   */\n  async isWalletAddress(params: CsprVerifyAddressOptions): Promise<boolean> {\n    const { address, rootAddress } = params;\n    if (!this.isValidAddress(address)) {\n      throw new InvalidAddressError(`invalid address: ${address}`);\n    }\n    if (!this.isValidAddress(rootAddress)) {\n      throw new InvalidAddressError('wallet root address is not valid');\n    }\n\n    const newAddressDetails = CsprLib.Utils.getAddressDetails(address);\n    const rootAddressDetails = CsprLib.Utils.getAddressDetails(rootAddress);\n    if (newAddressDetails.address.toLowerCase() !== rootAddressDetails.address.toLowerCase()) {\n      throw new UnexpectedAddressError(`address validation failure: ${newAddressDetails.address} vs ${rootAddress}`);\n    }\n    return true;\n  }\n\n  /**\n   * Generate Casper key pair - BitGo xpub format\n   *\n   * @param {Buffer} seed - Seed from which the new keypair should be generated, otherwise a random seed is used\n   * @returns {Object} object with generated xpub and xprv\n   */\n  generateKeyPair(seed?: Buffer): KeyPair {\n    const keyPair = seed ? new CsprLib.KeyPair({ seed }) : new CsprLib.KeyPair();\n    const keys = keyPair.getExtendedKeys();\n\n    if (!keys.xprv) {\n      throw new Error('Missing xprv in key generation.');\n    }\n\n    return {\n      pub: keys.xpub,\n      prv: keys.xprv,\n    };\n  }\n\n  isValidPub(pub: string): boolean {\n    // TODO(STLX-1344): Validate using account-lib when available\n    //  return accountLib.Cspr.Utils.isValidPublicKey(pub);\n    try {\n      new CsprLib.KeyPair({ pub });\n      return true;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  /**\n   * Return boolean indicating whether input is valid private key for the coin\n   *\n   * @param prv the prv to be checked\n   * @returns is it valid?\n   */\n  isValidPrv(prv: string): boolean {\n    // TODO(STLX-1345): Validate using account-lib when available\n    //  return accountLib.Cspr.Utils.isValidPrivateKey(prv);\n    try {\n      new CsprLib.KeyPair({ prv });\n      return true;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  /**\n   * Return boolean indicating whether input is valid CSPR address\n   *\n   * @param address the pub to be checked\n   * @returns true if the address is valid\n   */\n  isValidAddress(address: string): boolean {\n    try {\n      const addressDetails = CsprLib.Utils.getAddressDetails(address);\n      return address === CsprLib.Utils.normalizeAddress(addressDetails);\n    } catch (e) {\n      return false;\n    }\n  }\n\n  /**\n   * Assemble keychain and half-sign prebuilt transaction\n   *\n   * @param {SignTransactionOptions} params data required to rebuild and sign the transaction\n   * @param {TransactionPrebuild} params.txPrebuild prebuild object returned by platform\n   * @param {String} params.prv user prv used to sign the transaction\n   * @returns Bluebird<SignedTransaction>\n   */\n  async signTransaction(params: SignTransactionOptions): Promise<SignedTransaction> {\n    const txBuilder = this.getBuilder().from(params.txPrebuild.txHex);\n    const key = params.prv;\n    txBuilder.sign({ key });\n\n    const transaction: any = await txBuilder.build();\n    if (!transaction) {\n      throw new InvalidTransactionError('Error while trying to build transaction');\n    }\n    const response = {\n      txHex: transaction.toBroadcastFormat(),\n    };\n    return transaction.signature.length >= 2 ? response : { halfSigned: response };\n  }\n\n  async parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction> {\n    return {};\n  }\n\n  /**\n   * Extend walletParams with extra params required for generating a Casper wallet\n   *\n   * Casper wallets have three three keys, user, backup and bitgo.\n   * Initially, we need a root prv to generate the account, which must be distinct from all three keychains on the wallet.\n   * If a root private key is not provided, a random one is generated.\n   * The root public key is the basis for the wallet root address.\n   */\n  async supplementGenerateWallet(\n    walletParams: SupplementGenerateWalletOptions\n  ): Promise<SupplementGenerateWalletOptions> {\n    if (walletParams.rootPrivateKey) {\n      if (!this.isValidPrv(walletParams.rootPrivateKey) || walletParams.rootPrivateKey.length !== 64) {\n        throw new Error('rootPrivateKey needs to be a hexadecimal private key string');\n      }\n    } else {\n      const keyPair = ECPair.makeRandom();\n      if (!keyPair.privateKey) {\n        throw new Error('no privateKey');\n      }\n      walletParams.rootPrivateKey = keyPair.privateKey.toString('hex');\n    }\n    return walletParams;\n  }\n\n  /**\n   * Sign message with private key\n   *\n   * @param key\n   * @param message\n   */\n  async signMessage(key: KeyPair, message: string | Buffer): Promise<Buffer> {\n    const keyPair = new CsprLib.KeyPair({ prv: key.prv });\n    const messageHex = typeof message === 'string' ? message : message.toString('hex');\n    const signatureData = CsprLib.Utils.signMessage(keyPair, messageHex);\n    return Buffer.from(signatureData.signature);\n  }\n\n  /**\n   * Explain a Casper transaction from Raw Tx\n   *\n   * @param {ExplainTransactionOptions} params given explain transaction params\n   * @param {String} params.txHex raw transaction\n   * @param {String} params.halfSigned.txHex raw half signed transaction\n   * @param {TransactionFee} fee fee information\n   * @returns Bluebird<TransactionExplanation>\n   */\n  async explainTransaction(params: ExplainTransactionOptions): Promise<TransactionExplanation> {\n    const txHex = params.txHex || (params.halfSigned && params.halfSigned.txHex);\n    if (!txHex || !params.feeInfo) {\n      throw new Error('missing explain tx parameters');\n    }\n    const txBuilder = this.getBuilder().from(txHex);\n\n    const tx: any = await txBuilder.build();\n    if (!tx) {\n      throw new InvalidTransactionError('Error while trying to build transaction');\n    }\n    const id = Buffer.from(tx.casperTx.hash).toString('hex');\n    const amount = CsprLib.Utils.getTransferAmount(tx.casperTx.session);\n    let transferId;\n    const outputs: TransactionOutput[] = [];\n    const operations: TransactionOperation[] = [];\n\n    switch (tx.type) {\n      case TransactionType.Send: {\n        transferId = CsprLib.Utils.getTransferId(tx.casperTx.session);\n        const toAddress = CsprLib.Utils.getTransferDestinationAddress(tx._deploy.session);\n        outputs.push({\n          address: toAddress,\n          amount,\n          coin: this.getChain(),\n        });\n        break;\n      }\n      case TransactionType.StakingLock: {\n        const validator = CsprLib.Utils.getValidatorAddress(tx._deploy.session);\n        operations.push({\n          type: TransactionType.StakingLock,\n          amount,\n          coin: this.getChain(),\n          validator: validator,\n        });\n        break;\n      }\n      case TransactionType.StakingUnlock: {\n        const validator = CsprLib.Utils.getValidatorAddress(tx._deploy.session);\n        operations.push({\n          type: TransactionType.StakingUnlock,\n          amount,\n          coin: this.getChain(),\n          validator: validator,\n        });\n        break;\n      }\n      default: {\n        throw new InvalidTransactionError('Error while trying to get transaction type');\n      }\n    }\n\n    const outputAmount = outputs\n      .reduce((acumulator, output) => {\n        const currentValue = new BigNumber(output.amount);\n        return acumulator.plus(currentValue);\n      }, new BigNumber(0))\n      .toFixed(0);\n\n    const displayOrder = [\n      'id',\n      'outputAmount',\n      'changeAmount',\n      'outputs',\n      'changeOutputs',\n      'transferId',\n      'fee',\n      'operations',\n    ];\n\n    return {\n      displayOrder,\n      id,\n      outputs,\n      outputAmount,\n      changeOutputs: [], // account based does not use change outputs\n      changeAmount: '0', // account base does not make change\n      transferId,\n      fee: params.feeInfo,\n      operations,\n    } as any;\n  }\n\n  private getBuilder(): CsprLib.TransactionBuilderFactory {\n    return new CsprLib.TransactionBuilderFactory(coins.get(this.getChain()));\n  }\n\n  /** @inheritDoc */\n  auditDecryptedKey(params: AuditDecryptedKeyParams) {\n    throw new MethodNotImplementedError();\n  }\n}\n"]}
|
package/dist/src/index.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];
|
|
@@ -14,17 +18,27 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
|
|
|
14
18
|
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
15
19
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
16
20
|
};
|
|
17
|
-
var __importStar = (this && this.__importStar) || function (
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
};
|
|
21
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
22
|
+
var ownKeys = function(o) {
|
|
23
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
24
|
+
var ar = [];
|
|
25
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
26
|
+
return ar;
|
|
27
|
+
};
|
|
28
|
+
return ownKeys(o);
|
|
29
|
+
};
|
|
30
|
+
return function (mod) {
|
|
31
|
+
if (mod && mod.__esModule) return mod;
|
|
32
|
+
var result = {};
|
|
33
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
34
|
+
__setModuleDefault(result, mod);
|
|
35
|
+
return result;
|
|
36
|
+
};
|
|
37
|
+
})();
|
|
24
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
39
|
exports.CsprLib = void 0;
|
|
26
40
|
__exportStar(require("./cspr"), exports);
|
|
27
41
|
__exportStar(require("./tcspr"), exports);
|
|
28
42
|
exports.CsprLib = __importStar(require("./lib"));
|
|
29
43
|
__exportStar(require("./register"), exports);
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEseUNBQXVCO0FBQ3ZCLDBDQUF3QjtBQUN4QixpREFBaUM7QUFDakMsNkNBQTJCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jc3ByJztcbmV4cG9ydCAqIGZyb20gJy4vdGNzcHInO1xuZXhwb3J0ICogYXMgQ3NwckxpYiBmcm9tICcuL2xpYic7XG5leHBvcnQgKiBmcm9tICcuL3JlZ2lzdGVyJztcbiJdfQ==
|
|
@@ -4,7 +4,7 @@ export declare const DEFAULT_CHAIN_NAMES: {
|
|
|
4
4
|
testnet: string;
|
|
5
5
|
mainnet: string;
|
|
6
6
|
};
|
|
7
|
-
export declare const TRANSACTION_EXPIRATION =
|
|
7
|
+
export declare const TRANSACTION_EXPIRATION = 7200000;
|
|
8
8
|
export declare const DELEGATE_VALIDATOR_ACCOUNT = "0100cd28cec3dd6d29b959ae7b36a8201c92fe6af75fa44d5fa84b7d2e417ca940";
|
|
9
9
|
export declare const MODULE_BYTES_ACTION = "action";
|
|
10
10
|
export declare const WALLET_INITIALIZATION_CONTRACT_ACTION = "set_all";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/lib/constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,gBAAgB,OAAO,CAAC;AACrC,eAAO,MAAM,cAAc,OAAO,CAAC;AACnC,eAAO,MAAM,mBAAmB;;;CAG/B,CAAC;AACF,eAAO,MAAM,sBAAsB,
|
|
1
|
+
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/lib/constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,gBAAgB,OAAO,CAAC;AACrC,eAAO,MAAM,cAAc,OAAO,CAAC;AACnC,eAAO,MAAM,mBAAmB;;;CAG/B,CAAC;AACF,eAAO,MAAM,sBAAsB,UAAU,CAAC;AAC9C,eAAO,MAAM,0BAA0B,uEAAuE,CAAC;AAG/G,eAAO,MAAM,mBAAmB,WAAW,CAAC;AAI5C,eAAO,MAAM,qCAAqC,YAAY,CAAC;AAC/D,eAAO,MAAM,wBAAwB,aAAa,CAAC;AACnD,eAAO,MAAM,0BAA0B,eAAe,CAAC;AAIvD,eAAO,MAAM,YAAY,WAAW,CAAC;AACrC,eAAO,MAAM,mBAAmB,eAAe,CAAC;AAChD,eAAO,MAAM,qBAAqB,iBAAiB,CAAC;AACpD,eAAO,MAAM,gBAAgB,gBAAgB,CAAC;AAC9C,eAAO,MAAM,kBAAkB,cAAc,CAAC;AAC9C,eAAO,MAAM,YAAY,iBAAiB,CAAC"}
|
|
@@ -7,7 +7,7 @@ exports.DEFAULT_CHAIN_NAMES = {
|
|
|
7
7
|
testnet: 'integration-test',
|
|
8
8
|
mainnet: 'casper',
|
|
9
9
|
};
|
|
10
|
-
exports.TRANSACTION_EXPIRATION =
|
|
10
|
+
exports.TRANSACTION_EXPIRATION = 7200000; // 2 hours in milliseconds (max TTL)
|
|
11
11
|
exports.DELEGATE_VALIDATOR_ACCOUNT = '0100cd28cec3dd6d29b959ae7b36a8201c92fe6af75fa44d5fa84b7d2e417ca940';
|
|
12
12
|
// #region contract arguments
|
|
13
13
|
exports.MODULE_BYTES_ACTION = 'action';
|
|
@@ -25,4 +25,4 @@ exports.TRANSACTION_TYPE = 'deploy_type';
|
|
|
25
25
|
exports.DELEGATE_VALIDATOR = 'validator';
|
|
26
26
|
exports.STAKING_TYPE = 'staking_type';
|
|
27
27
|
// #endregion
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi9jb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQWEsUUFBQSxnQkFBZ0IsR0FBRyxJQUFJLENBQUM7QUFDeEIsUUFBQSxjQUFjLEdBQUcsSUFBSSxDQUFDO0FBQ3RCLFFBQUEsbUJBQW1CLEdBQUc7SUFDakMsT0FBTyxFQUFFLGtCQUFrQjtJQUMzQixPQUFPLEVBQUUsUUFBUTtDQUNsQixDQUFDO0FBQ1csUUFBQSxzQkFBc0IsR0FBRyxPQUFPLENBQUMsQ0FBQyxvQ0FBb0M7QUFDdEUsUUFBQSwwQkFBMEIsR0FBRyxvRUFBb0UsQ0FBQztBQUUvRyw2QkFBNkI7QUFDaEIsUUFBQSxtQkFBbUIsR0FBRyxRQUFRLENBQUM7QUFDNUMsYUFBYTtBQUViLDJCQUEyQjtBQUNkLFFBQUEscUNBQXFDLEdBQUcsU0FBUyxDQUFDO0FBQ2xELFFBQUEsd0JBQXdCLEdBQUcsVUFBVSxDQUFDO0FBQ3RDLFFBQUEsMEJBQTBCLEdBQUcsWUFBWSxDQUFDO0FBQ3ZELGFBQWE7QUFFYixpQ0FBaUM7QUFDcEIsUUFBQSxZQUFZLEdBQUcsUUFBUSxDQUFDO0FBQ3hCLFFBQUEsbUJBQW1CLEdBQUcsWUFBWSxDQUFDO0FBQ25DLFFBQUEscUJBQXFCLEdBQUcsY0FBYyxDQUFDO0FBQ3ZDLFFBQUEsZ0JBQWdCLEdBQUcsYUFBYSxDQUFDO0FBQ2pDLFFBQUEsa0JBQWtCLEdBQUcsV0FBVyxDQUFDO0FBQ2pDLFFBQUEsWUFBWSxHQUFHLGNBQWMsQ0FBQztBQUMzQyxhQUFhIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IFNFQ1AyNTZLMV9QUkVGSVggPSAnMDInO1xuZXhwb3J0IGNvbnN0IEVEMjU1MTlfUFJFRklYID0gJzAxJztcbmV4cG9ydCBjb25zdCBERUZBVUxUX0NIQUlOX05BTUVTID0ge1xuICB0ZXN0bmV0OiAnaW50ZWdyYXRpb24tdGVzdCcsXG4gIG1haW5uZXQ6ICdjYXNwZXInLFxufTtcbmV4cG9ydCBjb25zdCBUUkFOU0FDVElPTl9FWFBJUkFUSU9OID0gNzIwMDAwMDsgLy8gMiBob3VycyBpbiBtaWxsaXNlY29uZHMgKG1heCBUVEwpXG5leHBvcnQgY29uc3QgREVMRUdBVEVfVkFMSURBVE9SX0FDQ09VTlQgPSAnMDEwMGNkMjhjZWMzZGQ2ZDI5Yjk1OWFlN2IzNmE4MjAxYzkyZmU2YWY3NWZhNDRkNWZhODRiN2QyZTQxN2NhOTQwJztcblxuLy8gI3JlZ2lvbiBjb250cmFjdCBhcmd1bWVudHNcbmV4cG9ydCBjb25zdCBNT0RVTEVfQllURVNfQUNUSU9OID0gJ2FjdGlvbic7XG4vLyAjZW5kcmVnaW9uXG5cbi8vICNyZWdpb24gY29udHJhY3QgYWN0aW9uc1xuZXhwb3J0IGNvbnN0IFdBTExFVF9JTklUSUFMSVpBVElPTl9DT05UUkFDVF9BQ1RJT04gPSAnc2V0X2FsbCc7XG5leHBvcnQgY29uc3QgREVMRUdBVEVfQ09OVFJBQ1RfQUNUSU9OID0gJ2RlbGVnYXRlJztcbmV4cG9ydCBjb25zdCBVTkRFTEVHQVRFX0NPTlRSQUNUX0FDVElPTiA9ICd1bmRlbGVnYXRlJztcbi8vICNlbmRyZWdpb25cblxuLy8gI3JlZ2lvbiBleHRyYSBkZXBsb3kgYXJndW1lbnRzXG5leHBvcnQgY29uc3QgT1dORVJfUFJFRklYID0gJ293bmVyXyc7XG5leHBvcnQgY29uc3QgVFJBTlNGRVJfVE9fQUREUkVTUyA9ICd0b19hZGRyZXNzJztcbmV4cG9ydCBjb25zdCBERUxFR0FURV9GUk9NX0FERFJFU1MgPSAnZnJvbV9hZGRyZXNzJztcbmV4cG9ydCBjb25zdCBUUkFOU0FDVElPTl9UWVBFID0gJ2RlcGxveV90eXBlJztcbmV4cG9ydCBjb25zdCBERUxFR0FURV9WQUxJREFUT1IgPSAndmFsaWRhdG9yJztcbmV4cG9ydCBjb25zdCBTVEFLSU5HX1RZUEUgPSAnc3Rha2luZ190eXBlJztcbi8vICNlbmRyZWdpb25cbiJdfQ==
|
|
@@ -38,8 +38,8 @@ class DelegateBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
|
38
38
|
initBuilder(tx) {
|
|
39
39
|
super.initBuilder(tx);
|
|
40
40
|
this.transaction.setTransactionType(sdk_core_1.TransactionType.StakingLock);
|
|
41
|
-
this.validator(utils_1.getValidatorAddress(tx.casperTx.session));
|
|
42
|
-
this.amount(utils_1.getTransferAmount(tx.casperTx.session));
|
|
41
|
+
this.validator((0, utils_1.getValidatorAddress)(tx.casperTx.session));
|
|
42
|
+
this.amount((0, utils_1.getTransferAmount)(tx.casperTx.session));
|
|
43
43
|
}
|
|
44
44
|
/** @inheritdoc */
|
|
45
45
|
signImplementation(key) {
|
|
@@ -71,7 +71,7 @@ class DelegateBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
|
71
71
|
* @returns {DelegateBuilder} the builder with the new parameter set
|
|
72
72
|
*/
|
|
73
73
|
validator(address) {
|
|
74
|
-
if (!utils_1.isValidAddress(address)) {
|
|
74
|
+
if (!(0, utils_1.isValidAddress)(address)) {
|
|
75
75
|
throw new sdk_core_1.InvalidParameterValueError('Invalid address');
|
|
76
76
|
}
|
|
77
77
|
this._validator = address;
|
|
@@ -84,7 +84,7 @@ class DelegateBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
|
84
84
|
* @returns {DelegateBuilder} the builder with the new parameter set
|
|
85
85
|
*/
|
|
86
86
|
amount(amount) {
|
|
87
|
-
if (!utils_1.isValidDelegateAmount(amount)) {
|
|
87
|
+
if (!(0, utils_1.isValidDelegateAmount)(amount)) {
|
|
88
88
|
throw new sdk_core_1.InvalidParameterValueError('Invalid amount');
|
|
89
89
|
}
|
|
90
90
|
this._amount = amount;
|
|
@@ -101,11 +101,11 @@ class DelegateBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
|
101
101
|
if (!this._amount) {
|
|
102
102
|
throw new sdk_core_1.BuildTransactionError('Invalid transaction: missing amount');
|
|
103
103
|
}
|
|
104
|
-
if (!utils_1.isValidDelegateAmount(this._amount)) {
|
|
104
|
+
if (!(0, utils_1.isValidDelegateAmount)(this._amount)) {
|
|
105
105
|
throw new sdk_core_1.InvalidParameterValueError('Invalid amount');
|
|
106
106
|
}
|
|
107
107
|
super.validateMandatoryFields();
|
|
108
108
|
}
|
|
109
109
|
}
|
|
110
110
|
exports.DelegateBuilder = DelegateBuilder;
|
|
111
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"delegateBuilder.js","sourceRoot":"","sources":["../../../src/lib/delegateBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { CLValue, CLPublicKey as PublicKey, RuntimeArgs, CLValueBuilder } from 'casper-js-sdk';\n\nimport {\n  BaseKey,\n  BuildTransactionError,\n  InvalidParameterValueError,\n  SigningError,\n  TransactionType,\n  StakingOperationTypes,\n} from '@bitgo-beta/sdk-core';\nimport { TransactionBuilder, DEFAULT_M } from './transactionBuilder';\nimport { Transaction } from './transaction';\nimport {\n  TRANSACTION_TYPE,\n  DELEGATE_VALIDATOR,\n  DELEGATE_FROM_ADDRESS,\n  STAKING_TYPE,\n  DELEGATE_CONTRACT_ACTION,\n  DELEGATE_VALIDATOR_ACCOUNT,\n} from './constants';\nimport {\n  isValidDelegateAmount,\n  isValidAddress,\n  getTransferAmount,\n  getValidatorAddress,\n  casperContractHexCode,\n} from './utils';\nimport { DelegateUndelegateContractArgs } from './ifaces';\n\nexport class DelegateBuilder extends TransactionBuilder {\n  private _validator: string;\n  private readonly _action: string;\n  private _amount: string;\n  private readonly _contract: Uint8Array;\n\n  /**\n   * Public constructor.\n   *\n   * @param {CoinConfig} _coinConfig Coin configuration object\n   */\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._action = DELEGATE_CONTRACT_ACTION;\n    this._contract = Uint8Array.from(Buffer.from(casperContractHexCode, 'hex'));\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    this._validator = this._validator || DELEGATE_VALIDATOR_ACCOUNT;\n    const args = this.buildDelegateParameters();\n    const extraArguments = new Map<string, CLValue>();\n\n    extraArguments.set(TRANSACTION_TYPE, CLValueBuilder.string(TransactionType[TransactionType.StakingLock]));\n    extraArguments.set(STAKING_TYPE, CLValueBuilder.string(StakingOperationTypes[StakingOperationTypes.LOCK]));\n    extraArguments.set(DELEGATE_FROM_ADDRESS, CLValueBuilder.string(this._source.address));\n    extraArguments.set(DELEGATE_VALIDATOR, CLValueBuilder.string(this._validator));\n\n    this._session = {\n      moduleBytes: this._contract,\n      args: RuntimeArgs.fromMap(args),\n      extraArguments: extraArguments,\n    };\n    this.transaction.setTransactionType(TransactionType.StakingLock);\n    return await super.buildImplementation();\n  }\n\n  /** @inheritdoc */\n  initBuilder(tx: Transaction): void {\n    super.initBuilder(tx);\n    this.transaction.setTransactionType(TransactionType.StakingLock);\n    this.validator(getValidatorAddress(tx.casperTx.session));\n    this.amount(getTransferAmount(tx.casperTx.session));\n  }\n\n  /** @inheritdoc */\n  protected signImplementation(key: BaseKey): Transaction {\n    if (this._multiSignerKeyPairs.length >= DEFAULT_M) {\n      throw new SigningError('A maximum of ' + DEFAULT_M + ' can sign the transaction.');\n    }\n    return super.signImplementation(key);\n  }\n\n  /**\n   * Build args needed to create a session, then we can send this session with the contract\n   *\n   * @returns {DelegateUndelegateContractArgs} contracts args to create a session\n   */\n  private buildDelegateParameters(): DelegateUndelegateContractArgs {\n    const delegator = PublicKey.fromHex(this._source.address);\n    const validator = PublicKey.fromHex(this._validator);\n\n    return {\n      action: CLValueBuilder.string(this._action),\n      delegator: CLValueBuilder.publicKey(delegator.value(), delegator.tag),\n      validator: CLValueBuilder.publicKey(validator.value(), validator.tag),\n      amount: CLValueBuilder.u512(this._amount),\n    };\n  }\n\n  // region Transfer fields\n  /**\n   * Set the destination address where the funds will be sent,\n   *\n   * @param {string} address the 68 bits address to transfer funds to\n   * @returns {DelegateBuilder} the builder with the new parameter set\n   */\n  validator(address: string): this {\n    if (!isValidAddress(address)) {\n      throw new InvalidParameterValueError('Invalid address');\n    }\n    this._validator = address;\n    return this;\n  }\n\n  /**\n   * Set the amount to be transferred\n   *\n   * @param {string} amount amount to transfer\n   * @returns {DelegateBuilder} the builder with the new parameter set\n   */\n  amount(amount: string): this {\n    if (!isValidDelegateAmount(amount)) {\n      throw new InvalidParameterValueError('Invalid amount');\n    }\n    this._amount = amount;\n    return this;\n  }\n\n  // endregion\n\n  // region Validators\n\n  /**\n   * Validate mandatory fields in the class\n   *\n   * @throws {Error} In case of missing or invalid fields\n   */\n  validateMandatoryFields(): void {\n    if (!this._amount) {\n      throw new BuildTransactionError('Invalid transaction: missing amount');\n    }\n    if (!isValidDelegateAmount(this._amount)) {\n      throw new InvalidParameterValueError('Invalid amount');\n    }\n    super.validateMandatoryFields();\n  }\n  // endregion\n}\n"]}
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"delegateBuilder.js","sourceRoot":"","sources":["../../../src/lib/delegateBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { CLValue, CLPublicKey as PublicKey, RuntimeArgs, CLValueBuilder } from 'casper-js-sdk';\n\nimport {\n  BaseKey,\n  BuildTransactionError,\n  InvalidParameterValueError,\n  SigningError,\n  TransactionType,\n  StakingOperationTypes,\n} from '@bitgo-beta/sdk-core';\nimport { TransactionBuilder, DEFAULT_M } from './transactionBuilder';\nimport { Transaction } from './transaction';\nimport {\n  TRANSACTION_TYPE,\n  DELEGATE_VALIDATOR,\n  DELEGATE_FROM_ADDRESS,\n  STAKING_TYPE,\n  DELEGATE_CONTRACT_ACTION,\n  DELEGATE_VALIDATOR_ACCOUNT,\n} from './constants';\nimport {\n  isValidDelegateAmount,\n  isValidAddress,\n  getTransferAmount,\n  getValidatorAddress,\n  casperContractHexCode,\n} from './utils';\nimport { DelegateUndelegateContractArgs } from './ifaces';\n\nexport class DelegateBuilder extends TransactionBuilder {\n  private _validator: string;\n  private readonly _action: string;\n  private _amount: string;\n  private readonly _contract: Uint8Array;\n\n  /**\n   * Public constructor.\n   *\n   * @param {CoinConfig} _coinConfig Coin configuration object\n   */\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._action = DELEGATE_CONTRACT_ACTION;\n    this._contract = Uint8Array.from(Buffer.from(casperContractHexCode, 'hex'));\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    this._validator = this._validator || DELEGATE_VALIDATOR_ACCOUNT;\n    const args = this.buildDelegateParameters();\n    const extraArguments = new Map<string, CLValue>();\n\n    extraArguments.set(TRANSACTION_TYPE, CLValueBuilder.string(TransactionType[TransactionType.StakingLock]));\n    extraArguments.set(STAKING_TYPE, CLValueBuilder.string(StakingOperationTypes[StakingOperationTypes.LOCK]));\n    extraArguments.set(DELEGATE_FROM_ADDRESS, CLValueBuilder.string(this._source.address));\n    extraArguments.set(DELEGATE_VALIDATOR, CLValueBuilder.string(this._validator));\n\n    this._session = {\n      moduleBytes: this._contract,\n      args: RuntimeArgs.fromMap(args),\n      extraArguments: extraArguments,\n    };\n    this.transaction.setTransactionType(TransactionType.StakingLock);\n    return await super.buildImplementation();\n  }\n\n  /** @inheritdoc */\n  initBuilder(tx: Transaction): void {\n    super.initBuilder(tx);\n    this.transaction.setTransactionType(TransactionType.StakingLock);\n    this.validator(getValidatorAddress(tx.casperTx.session));\n    this.amount(getTransferAmount(tx.casperTx.session));\n  }\n\n  /** @inheritdoc */\n  protected signImplementation(key: BaseKey): Transaction {\n    if (this._multiSignerKeyPairs.length >= DEFAULT_M) {\n      throw new SigningError('A maximum of ' + DEFAULT_M + ' can sign the transaction.');\n    }\n    return super.signImplementation(key);\n  }\n\n  /**\n   * Build args needed to create a session, then we can send this session with the contract\n   *\n   * @returns {DelegateUndelegateContractArgs} contracts args to create a session\n   */\n  private buildDelegateParameters(): DelegateUndelegateContractArgs {\n    const delegator = PublicKey.fromHex(this._source.address);\n    const validator = PublicKey.fromHex(this._validator);\n\n    return {\n      action: CLValueBuilder.string(this._action),\n      delegator: CLValueBuilder.publicKey(delegator.value(), delegator.tag),\n      validator: CLValueBuilder.publicKey(validator.value(), validator.tag),\n      amount: CLValueBuilder.u512(this._amount),\n    };\n  }\n\n  // region Transfer fields\n  /**\n   * Set the destination address where the funds will be sent,\n   *\n   * @param {string} address the 68 bits address to transfer funds to\n   * @returns {DelegateBuilder} the builder with the new parameter set\n   */\n  validator(address: string): this {\n    if (!isValidAddress(address)) {\n      throw new InvalidParameterValueError('Invalid address');\n    }\n    this._validator = address;\n    return this;\n  }\n\n  /**\n   * Set the amount to be transferred\n   *\n   * @param {string} amount amount to transfer\n   * @returns {DelegateBuilder} the builder with the new parameter set\n   */\n  amount(amount: string): this {\n    if (!isValidDelegateAmount(amount)) {\n      throw new InvalidParameterValueError('Invalid amount');\n    }\n    this._amount = amount;\n    return this;\n  }\n\n  // endregion\n\n  // region Validators\n\n  /**\n   * Validate mandatory fields in the class\n   *\n   * @throws {Error} In case of missing or invalid fields\n   */\n  validateMandatoryFields(): void {\n    if (!this._amount) {\n      throw new BuildTransactionError('Invalid transaction: missing amount');\n    }\n    if (!isValidDelegateAmount(this._amount)) {\n      throw new InvalidParameterValueError('Invalid amount');\n    }\n    super.validateMandatoryFields();\n  }\n  // endregion\n}\n"]}
|
package/dist/src/lib/ifaces.d.ts
CHANGED
|
@@ -53,8 +53,8 @@ export interface Owner {
|
|
|
53
53
|
address: CLPublicKey;
|
|
54
54
|
weight: number;
|
|
55
55
|
}
|
|
56
|
-
export
|
|
57
|
-
export
|
|
56
|
+
export type WalletInitContractArgs = Record<'action' | 'deployment_thereshold' | 'key_management_threshold' | 'accounts' | 'weights', CLValue>;
|
|
57
|
+
export type DelegateUndelegateContractArgs = Record<'action' | 'delegator' | 'validator' | 'amount', CLValue>;
|
|
58
58
|
/**
|
|
59
59
|
* Secp256k1 return type for sign operations
|
|
60
60
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ifaces.d.ts","sourceRoot":"","sources":["../../../src/lib/ifaces.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,OAAO,EAAE,MAAM,GAAG,CAAC;AAE5B,MAAM,WAAW,iBAAiB;IAEhC,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,GAAG,CAAC;IACT,UAAU,EAAE,MAAM,CAAC;IAEnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IAEpB,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAE7B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,UAAU;IACzB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,aAAa;IAC5B,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,OAAO,CAAC;CAClB;AAED,MAAM,WAAW,GAAG;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,yBAAyB;IACxC,MAAM,EAAE,YAAY,CAAC;IACrB,MAAM,EAAE,WAAW,CAAC;IACpB,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACrB,cAAc,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACtC;AAED;;GAEG;AACH,MAAM,WAAW,yBAAyB;IACxC,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,WAAW,CAAC;IACvB,SAAS,EAAE,WAAW,CAAC;IACvB,MAAM,EAAE,YAAY,CAAC;IACrB,cAAc,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACtC;AAED,MAAM,WAAW,4BAA4B;IAC3C,WAAW,EAAE,UAAU,CAAC;IACxB,IAAI,EAAE,WAAW,CAAC;IAClB,cAAc,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACtC;AAED,MAAM,WAAW,KAAK;IACpB,OAAO,EAAE,WAAW,CAAC;IACrB,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,
|
|
1
|
+
{"version":3,"file":"ifaces.d.ts","sourceRoot":"","sources":["../../../src/lib/ifaces.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,OAAO,EAAE,MAAM,GAAG,CAAC;AAE5B,MAAM,WAAW,iBAAiB;IAEhC,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,GAAG,CAAC;IACT,UAAU,EAAE,MAAM,CAAC;IAEnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IAEpB,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAE7B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,UAAU;IACzB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,aAAa;IAC5B,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,OAAO,CAAC;CAClB;AAED,MAAM,WAAW,GAAG;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,yBAAyB;IACxC,MAAM,EAAE,YAAY,CAAC;IACrB,MAAM,EAAE,WAAW,CAAC;IACpB,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACrB,cAAc,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACtC;AAED;;GAEG;AACH,MAAM,WAAW,yBAAyB;IACxC,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,WAAW,CAAC;IACvB,SAAS,EAAE,WAAW,CAAC;IACvB,MAAM,EAAE,YAAY,CAAC;IACrB,cAAc,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACtC;AAED,MAAM,WAAW,4BAA4B;IAC3C,WAAW,EAAE,UAAU,CAAC;IACxB,IAAI,EAAE,WAAW,CAAC;IAClB,cAAc,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACtC;AAED,MAAM,WAAW,KAAK;IACpB,OAAO,EAAE,WAAW,CAAC;IACrB,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,MAAM,sBAAsB,GAAG,MAAM,CAEzC,QAAQ,GAAG,uBAAuB,GAAG,0BAA0B,GAAG,UAAU,GAAG,SAAS,EACxF,OAAO,CACR,CAAC;AAEF,MAAM,MAAM,8BAA8B,GAAG,MAAM,CAAC,QAAQ,GAAG,WAAW,GAAG,WAAW,GAAG,QAAQ,EAAE,OAAO,CAAC,CAAC;AAE9G;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,SAAS,EAAE,UAAU,CAAC;IACtB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,cAAc;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB"}
|
package/dist/src/lib/index.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
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
22
36
|
exports.Utils = exports.KeyPair = exports.TransactionBuilderFactory = exports.Transaction = void 0;
|
|
23
37
|
const Utils = __importStar(require("./utils"));
|
|
@@ -28,4 +42,4 @@ var transactionBuilderFactory_1 = require("./transactionBuilderFactory");
|
|
|
28
42
|
Object.defineProperty(exports, "TransactionBuilderFactory", { enumerable: true, get: function () { return transactionBuilderFactory_1.TransactionBuilderFactory; } });
|
|
29
43
|
var keyPair_1 = require("./keyPair");
|
|
30
44
|
Object.defineProperty(exports, "KeyPair", { enumerable: true, get: function () { return keyPair_1.KeyPair; } });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLCtDQUFpQztBQU14QixzQkFBSztBQUpkLDZDQUE0QztBQUFuQywwR0FBQSxXQUFXLE9BQUE7QUFDcEIseUVBQXdFO0FBQS9ELHNJQUFBLHlCQUF5QixPQUFBO0FBQ2xDLHFDQUFvQztBQUEzQixrR0FBQSxPQUFPLE9BQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBVdGlscyBmcm9tICcuL3V0aWxzJztcblxuZXhwb3J0IHsgVHJhbnNhY3Rpb24gfSBmcm9tICcuL3RyYW5zYWN0aW9uJztcbmV4cG9ydCB7IFRyYW5zYWN0aW9uQnVpbGRlckZhY3RvcnkgfSBmcm9tICcuL3RyYW5zYWN0aW9uQnVpbGRlckZhY3RvcnknO1xuZXhwb3J0IHsgS2V5UGFpciB9IGZyb20gJy4va2V5UGFpcic7XG5cbmV4cG9ydCB7IFV0aWxzIH07XG4iXX0=
|
package/dist/src/lib/keyPair.js
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.KeyPair = void 0;
|
|
4
4
|
const crypto_1 = require("crypto");
|
|
5
|
-
const
|
|
5
|
+
const secp256k1_1 = require("@bitgo-beta/secp256k1");
|
|
6
6
|
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
7
7
|
const constants_1 = require("./constants");
|
|
8
8
|
const DEFAULT_SEED_SIZE_BYTES = 16;
|
|
@@ -15,16 +15,16 @@ class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
|
|
|
15
15
|
constructor(source) {
|
|
16
16
|
super(source);
|
|
17
17
|
if (!source) {
|
|
18
|
-
const seed = crypto_1.randomBytes(DEFAULT_SEED_SIZE_BYTES);
|
|
19
|
-
this.hdNode =
|
|
18
|
+
const seed = (0, crypto_1.randomBytes)(DEFAULT_SEED_SIZE_BYTES);
|
|
19
|
+
this.hdNode = secp256k1_1.bip32.fromSeed(seed);
|
|
20
20
|
}
|
|
21
|
-
else if (sdk_core_1.isSeed(source)) {
|
|
22
|
-
this.hdNode =
|
|
21
|
+
else if ((0, sdk_core_1.isSeed)(source)) {
|
|
22
|
+
this.hdNode = secp256k1_1.bip32.fromSeed(source.seed);
|
|
23
23
|
}
|
|
24
|
-
else if (sdk_core_1.isPrivateKey(source)) {
|
|
24
|
+
else if ((0, sdk_core_1.isPrivateKey)(source)) {
|
|
25
25
|
this.recordKeysFromPrivateKey(source.prv);
|
|
26
26
|
}
|
|
27
|
-
else if (sdk_core_1.isPublicKey(source)) {
|
|
27
|
+
else if ((0, sdk_core_1.isPublicKey)(source)) {
|
|
28
28
|
this.recordKeysFromPublicKey(source.pub);
|
|
29
29
|
}
|
|
30
30
|
else {
|
|
@@ -40,10 +40,9 @@ class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
|
|
|
40
40
|
* @returns { DefaultKeys } The keys in the defined format
|
|
41
41
|
*/
|
|
42
42
|
getKeys() {
|
|
43
|
-
var _a;
|
|
44
43
|
return {
|
|
45
44
|
pub: this.getPublicKey({ compressed: true }).toString('hex'),
|
|
46
|
-
prv:
|
|
45
|
+
prv: this.getPrivateKey()?.toString('hex'),
|
|
47
46
|
};
|
|
48
47
|
}
|
|
49
48
|
/** @inheritdoc */
|
|
@@ -53,4 +52,4 @@ class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
|
|
|
53
52
|
}
|
|
54
53
|
}
|
|
55
54
|
exports.KeyPair = KeyPair;
|
|
56
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5UGFpci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIva2V5UGFpci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtQ0FBcUM7QUFDckMscURBQThDO0FBQzlDLG1EQU84QjtBQUM5QiwyQ0FBK0M7QUFDL0MsTUFBTSx1QkFBdUIsR0FBRyxFQUFFLENBQUM7QUFFbkMsTUFBYSxPQUFRLFNBQVEsbUNBQXdCO0lBQ25EOzs7O09BSUc7SUFDSCxZQUFZLE1BQXVCO1FBQ2pDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNkLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNaLE1BQU0sSUFBSSxHQUFHLElBQUEsb0JBQVcsRUFBQyx1QkFBdUIsQ0FBQyxDQUFDO1lBQ2xELElBQUksQ0FBQyxNQUFNLEdBQUcsaUJBQUssQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDckMsQ0FBQzthQUFNLElBQUksSUFBQSxpQkFBTSxFQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7WUFDMUIsSUFBSSxDQUFDLE1BQU0sR0FBRyxpQkFBSyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDNUMsQ0FBQzthQUFNLElBQUksSUFBQSx1QkFBWSxFQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7WUFDaEMsSUFBSSxDQUFDLHdCQUF3QixDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUM1QyxDQUFDO2FBQU0sSUFBSSxJQUFBLHNCQUFXLEVBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztZQUMvQixJQUFJLENBQUMsdUJBQXVCLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzNDLENBQUM7YUFBTSxDQUFDO1lBQ04sTUFBTSxJQUFJLEtBQUssQ0FBQywwQkFBMEIsQ0FBQyxDQUFDO1FBQzlDLENBQUM7UUFFRCxJQUFJLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNoQixJQUFJLENBQUMsT0FBTyxHQUFHLG1DQUF3QixDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDakUsQ0FBQztJQUNILENBQUM7SUFFRDs7OztPQUlHO0lBQ0gsT0FBTztRQUNMLE9BQU87WUFDTCxHQUFHLEVBQUUsSUFBSSxDQUFDLFlBQVksQ0FBQyxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUM7WUFDNUQsR0FBRyxFQUFFLElBQUksQ0FBQyxhQUFhLEVBQUUsRUFBRSxRQUFRLENBQUMsS0FBSyxDQUFDO1NBQzNDLENBQUM7SUFDSixDQUFDO0lBRUQsa0JBQWtCO0lBQ2xCLFVBQVU7UUFDUixNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDNUIsT0FBTyw0QkFBZ0IsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDO0lBQ3JDLENBQUM7Q0FDRjtBQTNDRCwwQkEyQ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyByYW5kb21CeXRlcyB9IGZyb20gJ2NyeXB0byc7XG5pbXBvcnQgeyBiaXAzMiB9IGZyb20gJ0BiaXRnby1iZXRhL3NlY3AyNTZrMSc7XG5pbXBvcnQge1xuICBLZXlQYWlyT3B0aW9ucyxcbiAgaXNQcml2YXRlS2V5LFxuICBpc1B1YmxpY0tleSxcbiAgaXNTZWVkLFxuICBEZWZhdWx0S2V5cyxcbiAgU2VjcDI1NmsxRXh0ZW5kZWRLZXlQYWlyLFxufSBmcm9tICdAYml0Z28tYmV0YS9zZGstY29yZSc7XG5pbXBvcnQgeyBTRUNQMjU2SzFfUFJFRklYIH0gZnJvbSAnLi9jb25zdGFudHMnO1xuY29uc3QgREVGQVVMVF9TRUVEX1NJWkVfQllURVMgPSAxNjtcblxuZXhwb3J0IGNsYXNzIEtleVBhaXIgZXh0ZW5kcyBTZWNwMjU2azFFeHRlbmRlZEtleVBhaXIge1xuICAvKipcbiAgICogUHVibGljIGNvbnN0cnVjdG9yLiBCeSBkZWZhdWx0LCBjcmVhdGVzIGEga2V5IHBhaXIgd2l0aCBhIHJhbmRvbSBtYXN0ZXIgc2VlZC5cbiAgICpcbiAgICogQHBhcmFtIHsgS2V5UGFpck9wdGlvbnMgfSBzb3VyY2UgRWl0aGVyIGEgbWFzdGVyIHNlZWQsIGEgcHJpdmF0ZSBrZXksIG9yIGEgcHVibGljIGtleVxuICAgKi9cbiAgY29uc3RydWN0b3Ioc291cmNlPzogS2V5UGFpck9wdGlvbnMpIHtcbiAgICBzdXBlcihzb3VyY2UpO1xuICAgIGlmICghc291cmNlKSB7XG4gICAgICBjb25zdCBzZWVkID0gcmFuZG9tQnl0ZXMoREVGQVVMVF9TRUVEX1NJWkVfQllURVMpO1xuICAgICAgdGhpcy5oZE5vZGUgPSBiaXAzMi5mcm9tU2VlZChzZWVkKTtcbiAgICB9IGVsc2UgaWYgKGlzU2VlZChzb3VyY2UpKSB7XG4gICAgICB0aGlzLmhkTm9kZSA9IGJpcDMyLmZyb21TZWVkKHNvdXJjZS5zZWVkKTtcbiAgICB9IGVsc2UgaWYgKGlzUHJpdmF0ZUtleShzb3VyY2UpKSB7XG4gICAgICB0aGlzLnJlY29yZEtleXNGcm9tUHJpdmF0ZUtleShzb3VyY2UucHJ2KTtcbiAgICB9IGVsc2UgaWYgKGlzUHVibGljS2V5KHNvdXJjZSkpIHtcbiAgICAgIHRoaXMucmVjb3JkS2V5c0Zyb21QdWJsaWNLZXkoc291cmNlLnB1Yik7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignSW52YWxpZCBrZXkgcGFpciBvcHRpb25zJyk7XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuaGROb2RlKSB7XG4gICAgICB0aGlzLmtleVBhaXIgPSBTZWNwMjU2azFFeHRlbmRlZEtleVBhaXIudG9LZXlQYWlyKHRoaXMuaGROb2RlKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogRGVmYXVsdCBrZXlzIGZvcm1hdCBpcyBhIHBhaXIgb2YgVWludDhBcnJheSBrZXlzXG4gICAqXG4gICAqIEByZXR1cm5zIHsgRGVmYXVsdEtleXMgfSBUaGUga2V5cyBpbiB0aGUgZGVmaW5lZCBmb3JtYXRcbiAgICovXG4gIGdldEtleXMoKTogRGVmYXVsdEtleXMge1xuICAgIHJldHVybiB7XG4gICAgICBwdWI6IHRoaXMuZ2V0UHVibGljS2V5KHsgY29tcHJlc3NlZDogdHJ1ZSB9KS50b1N0cmluZygnaGV4JyksXG4gICAgICBwcnY6IHRoaXMuZ2V0UHJpdmF0ZUtleSgpPy50b1N0cmluZygnaGV4JyksXG4gICAgfTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICBnZXRBZGRyZXNzKCk6IHN0cmluZyB7XG4gICAgY29uc3Qga2V5cyA9IHRoaXMuZ2V0S2V5cygpO1xuICAgIHJldHVybiBTRUNQMjU2SzFfUFJFRklYICsga2V5cy5wdWI7XG4gIH1cbn1cbiJdfQ==
|