@bitgo-beta/sdk-coin-cspr 1.2.19-beta.583 → 1.2.19-beta.585
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 +6 -0
- package/dist/src/cspr.d.ts +0 -2
- package/dist/src/cspr.d.ts.map +1 -1
- package/dist/src/cspr.js +21 -11
- package/dist/src/index.js +18 -8
- package/dist/src/lib/delegateBuilder.js +1 -1
- package/dist/src/lib/index.js +18 -8
- package/dist/src/lib/keyPair.js +1 -1
- package/dist/src/lib/transaction.js +18 -8
- package/dist/src/lib/transactionBuilder.js +1 -1
- package/dist/src/lib/transactionBuilderFactory.js +1 -1
- package/dist/src/lib/transferBuilder.js +1 -1
- package/dist/src/lib/undelegateBuilder.js +1 -1
- package/dist/src/lib/utils.js +44 -34
- package/dist/src/lib/walletInitializationBuilder.js +1 -1
- package/dist/src/tcspr.js +1 -1
- package/package.json +7 -7
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,12 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
## [2.0.50](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-cspr@2.0.49...@bitgo/sdk-coin-cspr@2.0.50) (2024-12-03)
|
|
7
|
+
|
|
8
|
+
### Bug Fixes
|
|
9
|
+
|
|
10
|
+
- use better string conversion for message signing ([c81d0b1](https://github.com/BitGo/BitGoJS/commit/c81d0b19c379109df69f8bdd7ff92c582492ab45))
|
|
11
|
+
|
|
6
12
|
## [2.0.49](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-cspr@2.0.48...@bitgo/sdk-coin-cspr@2.0.49) (2024-11-26)
|
|
7
13
|
|
|
8
14
|
**Note:** Version bump only for package @bitgo/sdk-coin-cspr
|
package/dist/src/cspr.d.ts
CHANGED
|
@@ -1,5 +1,3 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
|
-
/// <reference types="node" />
|
|
3
1
|
import { BaseCoin as StaticsBaseCoin, CoinFamily } from '@bitgo-beta/statics';
|
|
4
2
|
import { BaseCoin, BitGoBase, KeyPair, ParsedTransaction, ParseTransactionOptions, SignedTransaction, SignTransactionOptions as BaseSignTransactionOptions, TransactionExplanation, TransactionPrebuild as BaseTransactionPrebuild, VerifyAddressOptions, VerifyTransactionOptions } from '@bitgo-beta/sdk-core';
|
|
5
3
|
interface SignTransactionOptions extends BaseSignTransactionOptions {
|
package/dist/src/cspr.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cspr.d.ts","sourceRoot":"","sources":["../../src/cspr.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"cspr.d.ts","sourceRoot":"","sources":["../../src/cspr.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,QAAQ,IAAI,eAAe,EAAE,UAAU,EAAS,MAAM,qBAAqB,CAAC;AACrF,OAAO,EACL,QAAQ,EACR,SAAS,EAGT,OAAO,EACP,iBAAiB,EACjB,uBAAuB,EACvB,iBAAiB,EACjB,sBAAsB,IAAI,0BAA0B,EACpD,sBAAsB,EACtB,mBAAmB,IAAI,uBAAuB,EAG9C,oBAAoB,EACpB,wBAAwB,EACzB,MAAM,sBAAsB,CAAC;AAE9B,UAAU,sBAAuB,SAAQ,0BAA0B;IACjE,UAAU,EAAE,mBAAmB,CAAC;IAChC,GAAG,EAAE,MAAM,CAAC;CACb;AAED,MAAM,WAAW,mBAAoB,SAAQ,uBAAuB;IAClE,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,cAAc;IAC7B,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,yBAAyB;IACxC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE;QACX,KAAK,EAAE,MAAM,CAAC;KACf,CAAC;IACF,OAAO,EAAE,cAAc,CAAC;CACzB;AAED,UAAU,+BAA+B;IACvC,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAeD,UAAU,wBAAyB,SAAQ,oBAAoB;IAC7D,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,qBAAa,IAAK,SAAQ,QAAQ;IAChC,SAAS,CAAC,QAAQ,CAAC,YAAY,EAAE,QAAQ,CAAC,eAAe,CAAC,CAAC;gBAE/C,KAAK,EAAE,SAAS,EAAE,WAAW,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC;IAUrE,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,SAAS,EAAE,WAAW,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC,GAAG,QAAQ;IAI1F,QAAQ,IAAI,MAAM;IAGlB,SAAS,IAAI,UAAU;IAGvB,WAAW,IAAI,MAAM;IAGrB,aAAa,IAAI,MAAM,GAAG,MAAM;IAI1B,iBAAiB,CAAC,MAAM,EAAE,wBAAwB,GAAG,OAAO,CAAC,OAAO,CAAC;IAK3E;;;;OAIG;IACG,eAAe,CAAC,MAAM,EAAE,wBAAwB,GAAG,OAAO,CAAC,OAAO,CAAC;IAiBzE;;;;;OAKG;IACH,eAAe,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO;IAcvC,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAWhC;;;;;OAKG;IACH,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAWhC;;;;;OAKG;IACH,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IASxC;;;;;;;OAOG;IACG,eAAe,CAAC,MAAM,EAAE,sBAAsB,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAe3E,gBAAgB,CAAC,MAAM,EAAE,uBAAuB,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAInF;;;;;;;OAOG;IACG,wBAAwB,CAC5B,YAAY,EAAE,+BAA+B,GAC5C,OAAO,CAAC,+BAA+B,CAAC;IAe3C;;;;;OAKG;IACG,WAAW,CAAC,GAAG,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAO1E;;;;;;;;OAQG;IACG,kBAAkB,CAAC,MAAM,EAAE,yBAAyB,GAAG,OAAO,CAAC,sBAAsB,CAAC;IAoF5F,OAAO,CAAC,UAAU;CAGnB"}
|
package/dist/src/cspr.js
CHANGED
|
@@ -15,13 +15,23 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
|
|
|
15
15
|
}) : function(o, v) {
|
|
16
16
|
o["default"] = v;
|
|
17
17
|
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
};
|
|
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
|
+
})();
|
|
25
35
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
36
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
37
|
};
|
|
@@ -197,7 +207,7 @@ class Cspr extends sdk_core_1.BaseCoin {
|
|
|
197
207
|
*/
|
|
198
208
|
async signMessage(key, message) {
|
|
199
209
|
const keyPair = new CsprLib.KeyPair({ prv: key.prv });
|
|
200
|
-
const messageHex = message
|
|
210
|
+
const messageHex = typeof message === 'string' ? message : message.toString('hex');
|
|
201
211
|
const signatureData = CsprLib.Utils.signMessage(keyPair, messageHex);
|
|
202
212
|
return Buffer.from(signatureData.signature);
|
|
203
213
|
}
|
|
@@ -281,8 +291,8 @@ class Cspr extends sdk_core_1.BaseCoin {
|
|
|
281
291
|
id,
|
|
282
292
|
outputs,
|
|
283
293
|
outputAmount,
|
|
284
|
-
changeOutputs: [],
|
|
285
|
-
changeAmount: '0',
|
|
294
|
+
changeOutputs: [], // account based does not use change outputs
|
|
295
|
+
changeAmount: '0', // account base does not make change
|
|
286
296
|
transferId,
|
|
287
297
|
fee: params.feeInfo,
|
|
288
298
|
operations,
|
|
@@ -293,4 +303,4 @@ class Cspr extends sdk_core_1.BaseCoin {
|
|
|
293
303
|
}
|
|
294
304
|
}
|
|
295
305
|
exports.Cspr = Cspr;
|
|
296
|
-
//# 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"]}
|
|
306
|
+
//# 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 = 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"]}
|
package/dist/src/index.js
CHANGED
|
@@ -18,17 +18,27 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
|
|
|
18
18
|
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
19
19
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
20
20
|
};
|
|
21
|
-
var __importStar = (this && this.__importStar) || function (
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
};
|
|
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
|
+
})();
|
|
28
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
39
|
exports.CsprLib = void 0;
|
|
30
40
|
__exportStar(require("./cspr"), exports);
|
|
31
41
|
__exportStar(require("./tcspr"), exports);
|
|
32
42
|
exports.CsprLib = __importStar(require("./lib"));
|
|
33
43
|
__exportStar(require("./register"), exports);
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEseUNBQXVCO0FBQ3ZCLDBDQUF3QjtBQUN4QixpREFBaUM7QUFDakMsNkNBQTJCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jc3ByJztcbmV4cG9ydCAqIGZyb20gJy4vdGNzcHInO1xuZXhwb3J0ICogYXMgQ3NwckxpYiBmcm9tICcuL2xpYic7XG5leHBvcnQgKiBmcm9tICcuL3JlZ2lzdGVyJztcbiJdfQ==
|
|
@@ -108,4 +108,4 @@ class DelegateBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
|
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/index.js
CHANGED
|
@@ -15,13 +15,23 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
|
|
|
15
15
|
}) : function(o, v) {
|
|
16
16
|
o["default"] = v;
|
|
17
17
|
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
};
|
|
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
|
+
})();
|
|
25
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
36
|
exports.Utils = exports.KeyPair = exports.TransactionBuilderFactory = exports.Transaction = void 0;
|
|
27
37
|
const Utils = __importStar(require("./utils"));
|
|
@@ -32,4 +42,4 @@ var transactionBuilderFactory_1 = require("./transactionBuilderFactory");
|
|
|
32
42
|
Object.defineProperty(exports, "TransactionBuilderFactory", { enumerable: true, get: function () { return transactionBuilderFactory_1.TransactionBuilderFactory; } });
|
|
33
43
|
var keyPair_1 = require("./keyPair");
|
|
34
44
|
Object.defineProperty(exports, "KeyPair", { enumerable: true, get: function () { return keyPair_1.KeyPair; } });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLCtDQUFpQztBQU14QixzQkFBSztBQUpkLDZDQUE0QztBQUFuQywwR0FBQSxXQUFXLE9BQUE7QUFDcEIseUVBQXdFO0FBQS9ELHNJQUFBLHlCQUF5QixPQUFBO0FBQ2xDLHFDQUFvQztBQUEzQixrR0FBQSxPQUFPLE9BQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBVdGlscyBmcm9tICcuL3V0aWxzJztcblxuZXhwb3J0IHsgVHJhbnNhY3Rpb24gfSBmcm9tICcuL3RyYW5zYWN0aW9uJztcbmV4cG9ydCB7IFRyYW5zYWN0aW9uQnVpbGRlckZhY3RvcnkgfSBmcm9tICcuL3RyYW5zYWN0aW9uQnVpbGRlckZhY3RvcnknO1xuZXhwb3J0IHsgS2V5UGFpciB9IGZyb20gJy4va2V5UGFpcic7XG5cbmV4cG9ydCB7IFV0aWxzIH07XG4iXX0=
|
package/dist/src/lib/keyPair.js
CHANGED
|
@@ -53,4 +53,4 @@ class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
|
|
|
53
53
|
}
|
|
54
54
|
}
|
|
55
55
|
exports.KeyPair = KeyPair;
|
|
56
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5UGFpci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIva2V5UGFpci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtQ0FBcUM7QUFDckMsbURBQTZDO0FBQzdDLG1EQU84QjtBQUM5QiwyQ0FBK0M7QUFDL0MsTUFBTSx1QkFBdUIsR0FBRyxFQUFFLENBQUM7QUFFbkMsTUFBYSxPQUFRLFNBQVEsbUNBQXdCO0lBQ25EOzs7O09BSUc7SUFDSCxZQUFZLE1BQXVCO1FBQ2pDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNkLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNaLE1BQU0sSUFBSSxHQUFHLElBQUEsb0JBQVcsRUFBQyx1QkFBdUIsQ0FBQyxDQUFDO1lBQ2xELElBQUksQ0FBQyxNQUFNLEdBQUcsZ0JBQUssQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDckMsQ0FBQzthQUFNLElBQUksSUFBQSxpQkFBTSxFQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7WUFDMUIsSUFBSSxDQUFDLE1BQU0sR0FBRyxnQkFBSyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDNUMsQ0FBQzthQUFNLElBQUksSUFBQSx1QkFBWSxFQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7WUFDaEMsSUFBSSxDQUFDLHdCQUF3QixDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUM1QyxDQUFDO2FBQU0sSUFBSSxJQUFBLHNCQUFXLEVBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztZQUMvQixJQUFJLENBQUMsdUJBQXVCLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzNDLENBQUM7YUFBTSxDQUFDO1lBQ04sTUFBTSxJQUFJLEtBQUssQ0FBQywwQkFBMEIsQ0FBQyxDQUFDO1FBQzlDLENBQUM7UUFFRCxJQUFJLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNoQixJQUFJLENBQUMsT0FBTyxHQUFHLG1DQUF3QixDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDakUsQ0FBQztJQUNILENBQUM7SUFFRDs7OztPQUlHO0lBQ0gsT0FBTzs7UUFDTCxPQUFPO1lBQ0wsR0FBRyxFQUFFLElBQUksQ0FBQyxZQUFZLENBQUMsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDO1lBQzVELEdBQUcsRUFBRSxNQUFBLElBQUksQ0FBQyxhQUFhLEVBQUUsMENBQUUsUUFBUSxDQUFDLEtBQUssQ0FBQztTQUMzQyxDQUFDO0lBQ0osQ0FBQztJQUVELGtCQUFrQjtJQUNsQixVQUFVO1FBQ1IsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQzVCLE9BQU8sNEJBQWdCLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQztJQUNyQyxDQUFDO0NBQ0Y7QUEzQ0QsMEJBMkNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgcmFuZG9tQnl0ZXMgfSBmcm9tICdjcnlwdG8nO1xuaW1wb3J0IHsgYmlwMzIgfSBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5pbXBvcnQge1xuICBLZXlQYWlyT3B0aW9ucyxcbiAgaXNQcml2YXRlS2V5LFxuICBpc1B1YmxpY0tleSxcbiAgaXNTZWVkLFxuICBEZWZhdWx0S2V5cyxcbiAgU2VjcDI1NmsxRXh0ZW5kZWRLZXlQYWlyLFxufSBmcm9tICdAYml0Z28tYmV0YS9zZGstY29yZSc7XG5pbXBvcnQgeyBTRUNQMjU2SzFfUFJFRklYIH0gZnJvbSAnLi9jb25zdGFudHMnO1xuY29uc3QgREVGQVVMVF9TRUVEX1NJWkVfQllURVMgPSAxNjtcblxuZXhwb3J0IGNsYXNzIEtleVBhaXIgZXh0ZW5kcyBTZWNwMjU2azFFeHRlbmRlZEtleVBhaXIge1xuICAvKipcbiAgICogUHVibGljIGNvbnN0cnVjdG9yLiBCeSBkZWZhdWx0LCBjcmVhdGVzIGEga2V5IHBhaXIgd2l0aCBhIHJhbmRvbSBtYXN0ZXIgc2VlZC5cbiAgICpcbiAgICogQHBhcmFtIHsgS2V5UGFpck9wdGlvbnMgfSBzb3VyY2UgRWl0aGVyIGEgbWFzdGVyIHNlZWQsIGEgcHJpdmF0ZSBrZXksIG9yIGEgcHVibGljIGtleVxuICAgKi9cbiAgY29uc3RydWN0b3Ioc291cmNlPzogS2V5UGFpck9wdGlvbnMpIHtcbiAgICBzdXBlcihzb3VyY2UpO1xuICAgIGlmICghc291cmNlKSB7XG4gICAgICBjb25zdCBzZWVkID0gcmFuZG9tQnl0ZXMoREVGQVVMVF9TRUVEX1NJWkVfQllURVMpO1xuICAgICAgdGhpcy5oZE5vZGUgPSBiaXAzMi5mcm9tU2VlZChzZWVkKTtcbiAgICB9IGVsc2UgaWYgKGlzU2VlZChzb3VyY2UpKSB7XG4gICAgICB0aGlzLmhkTm9kZSA9IGJpcDMyLmZyb21TZWVkKHNvdXJjZS5zZWVkKTtcbiAgICB9IGVsc2UgaWYgKGlzUHJpdmF0ZUtleShzb3VyY2UpKSB7XG4gICAgICB0aGlzLnJlY29yZEtleXNGcm9tUHJpdmF0ZUtleShzb3VyY2UucHJ2KTtcbiAgICB9IGVsc2UgaWYgKGlzUHVibGljS2V5KHNvdXJjZSkpIHtcbiAgICAgIHRoaXMucmVjb3JkS2V5c0Zyb21QdWJsaWNLZXkoc291cmNlLnB1Yik7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignSW52YWxpZCBrZXkgcGFpciBvcHRpb25zJyk7XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuaGROb2RlKSB7XG4gICAgICB0aGlzLmtleVBhaXIgPSBTZWNwMjU2azFFeHRlbmRlZEtleVBhaXIudG9LZXlQYWlyKHRoaXMuaGROb2RlKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogRGVmYXVsdCBrZXlzIGZvcm1hdCBpcyBhIHBhaXIgb2YgVWludDhBcnJheSBrZXlzXG4gICAqXG4gICAqIEByZXR1cm5zIHsgRGVmYXVsdEtleXMgfSBUaGUga2V5cyBpbiB0aGUgZGVmaW5lZCBmb3JtYXRcbiAgICovXG4gIGdldEtleXMoKTogRGVmYXVsdEtleXMge1xuICAgIHJldHVybiB7XG4gICAgICBwdWI6IHRoaXMuZ2V0UHVibGljS2V5KHsgY29tcHJlc3NlZDogdHJ1ZSB9KS50b1N0cmluZygnaGV4JyksXG4gICAgICBwcnY6IHRoaXMuZ2V0UHJpdmF0ZUtleSgpPy50b1N0cmluZygnaGV4JyksXG4gICAgfTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICBnZXRBZGRyZXNzKCk6IHN0cmluZyB7XG4gICAgY29uc3Qga2V5cyA9IHRoaXMuZ2V0S2V5cygpO1xuICAgIHJldHVybiBTRUNQMjU2SzFfUFJFRklYICsga2V5cy5wdWI7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -15,13 +15,23 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
|
|
|
15
15
|
}) : function(o, v) {
|
|
16
16
|
o["default"] = v;
|
|
17
17
|
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
};
|
|
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
|
+
})();
|
|
25
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
36
|
exports.Transaction = void 0;
|
|
27
37
|
const _ = __importStar(require("lodash"));
|
|
@@ -228,4 +238,4 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
228
238
|
}
|
|
229
239
|
}
|
|
230
240
|
exports.Transaction = Transaction;
|
|
231
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import * as _ from 'lodash';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { CLPublicKey as PublicKey, DeployUtil, Keys, CLString, CLU512 } from 'casper-js-sdk';\nimport { BaseKey, BaseTransaction, TransactionType, InvalidTransactionError, SigningError } from '@bitgo-beta/sdk-core';\nimport { KeyPair } from './keyPair';\nimport { CasperTransaction } from './ifaces';\nimport {\n  DELEGATE_FROM_ADDRESS,\n  DELEGATE_VALIDATOR,\n  OWNER_PREFIX,\n  SECP256K1_PREFIX,\n  TRANSACTION_TYPE,\n} from './constants';\nimport {\n  getTransferAmount,\n  getTransferDestinationAddress,\n  getTransferId,\n  isValidPublicKey,\n  removeAlgoPrefixFromHexValue,\n  getDeployType,\n  getDelegatorAddress,\n  getValidatorAddress,\n  getDelegateAmount,\n} from './utils';\n\nexport class Transaction extends BaseTransaction {\n  protected _type: TransactionType;\n  protected _deploy: DeployUtil.Deploy;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /** @inheritdoc */\n  canSign(key: BaseKey): boolean {\n    return true;\n  }\n\n  sign(keyPair: KeyPair): void {\n    const keys = keyPair.getKeys();\n    if (!keys.prv) {\n      throw new SigningError('Missing private key');\n    }\n    if (\n      this._deploy.approvals.some(\n        (ap) => !ap.signer.startsWith(SECP256K1_PREFIX) || !isValidPublicKey(removeAlgoPrefixFromHexValue(ap.signer))\n      )\n    ) {\n      throw new SigningError('Invalid deploy. Already signed with an invalid key');\n    }\n    const secpKeys = new Keys.Secp256K1(\n      Uint8Array.from(Buffer.from(keys.pub, 'hex')),\n      Uint8Array.from(Buffer.from(keys.prv, 'hex'))\n    );\n    const signedDeploy = DeployUtil.signDeploy(this._deploy, secpKeys);\n    this._signatures.push(signedDeploy.approvals[signedDeploy.approvals.length - 1].signature);\n  }\n\n  /**\n   * Add a signature to this transaction and to and its deploy\n   *\n   * @param {string} signature The signature to add, in string hex format\n   * @param {KeyPair} keyPair The key pair that created the signature\n   */\n  addSignature(signature: string, keyPair: KeyPair): void {\n    const pub = keyPair.getKeys().pub;\n    const signatureBuffer = Uint8Array.from(Buffer.from(signature, 'hex'));\n    const pubKeyBuffer = Uint8Array.from(Buffer.from(pub, 'hex'));\n    const parsedPublicKey = Keys.Secp256K1.parsePublicKey(pubKeyBuffer, 'raw');\n    const pubKeyHex = Keys.Secp256K1.accountHex(parsedPublicKey);\n    if (removeAlgoPrefixFromHexValue(pubKeyHex) !== pub) {\n      throw new SigningError('Signer does not match signature');\n    }\n    const signedDeploy = DeployUtil.setSignature(\n      this._deploy,\n      signatureBuffer,\n      PublicKey.fromSecp256K1(parsedPublicKey)\n    );\n    const approval = _.last(signedDeploy.approvals) as DeployUtil.Approval;\n    if (removeAlgoPrefixFromHexValue(approval.signature) !== signature) {\n      throw new SigningError('Invalid signature');\n    }\n    this._signatures.push(signature);\n  }\n\n  /** @inheritdoc */\n  toBroadcastFormat(): string {\n    if (!this.casperTx) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    const txJson: any = DeployUtil.deployToJson(this.casperTx);\n    // The new casper lib is converting the TTL from miliseconds to another date format, in this case 1 day\n    // we need to leave it as ms for the HSM to be able to parse it\n    txJson.deploy.header.ttl = `${this.casperTx.header.ttl}ms`;\n    this.setOwnersInJson(txJson);\n    this.setTransfersFieldsInJson(txJson);\n    this.setDelegateFieldsInJson(txJson);\n    return JSON.stringify(txJson);\n  }\n\n  /** @inheritdoc */\n  toJson(): CasperTransaction {\n    const deployPayment = this._deploy.payment.asModuleBytes()?.getArgByName('amount') as CLU512;\n    if (!deployPayment) {\n      throw new InvalidTransactionError('Undefined fee');\n    }\n\n    const owner1Index = 0;\n    const owner2Index = 1;\n    const owner3Index = 2;\n    const sourcePublicKey = Buffer.from(this._deploy.header.account.value()).toString('hex');\n    const sourceAddress = new KeyPair({ pub: sourcePublicKey }).getAddress();\n\n    const result: CasperTransaction = {\n      hash: Buffer.from(this._deploy.hash).toString('hex'),\n      fee: { gasLimit: deployPayment.value().toString(), gasPrice: this._deploy.header.gasPrice.toString() },\n      from: sourceAddress,\n      startTime: new Date(this._deploy.header.timestamp).toISOString(),\n      expiration: this._deploy.header.ttl,\n      deployType: (this._deploy.session.getArgByName(TRANSACTION_TYPE) as CLString).value(),\n    };\n\n    const transactionType = getDeployType(this._deploy.session);\n\n    switch (transactionType) {\n      case TransactionType.Send:\n        result.to = getTransferDestinationAddress(this._deploy.session);\n        result.amount = getTransferAmount(this._deploy.session);\n        result.transferId = getTransferId(this._deploy.session);\n        break;\n      case TransactionType.WalletInitialization:\n        result.owner1 = (this.casperTx.session.getArgByName(OWNER_PREFIX + owner1Index) as CLString).value();\n        result.owner2 = (this.casperTx.session.getArgByName(OWNER_PREFIX + owner2Index) as CLString).value();\n        result.owner3 = (this.casperTx.session.getArgByName(OWNER_PREFIX + owner3Index) as CLString).value();\n        break;\n      case TransactionType.StakingLock:\n        result.fromDelegate = getDelegatorAddress(this.casperTx.session);\n        result.validator = getValidatorAddress(this.casperTx.session);\n        result.amount = getDelegateAmount(this.casperTx.session);\n        break;\n      case TransactionType.StakingUnlock:\n        result.fromDelegate = getDelegatorAddress(this.casperTx.session);\n        result.validator = getValidatorAddress(this.casperTx.session);\n        result.amount = getDelegateAmount(this.casperTx.session);\n        break;\n    }\n    return result;\n  }\n\n  /**\n   * Set the transaction type\n   *\n   * @param {TransactionType} transactionType The transaction type to be set\n   */\n  setTransactionType(transactionType: TransactionType): void {\n    this._type = transactionType;\n  }\n\n  /**\n   * Retrieve signatures from the deploy instance and load them into the signatures list\n   */\n  loadPreviousSignatures(): void {\n    if (this._deploy.approvals && this._deploy.approvals.length > 0) {\n      this._deploy.approvals.forEach((approval) => {\n        this._signatures.push(approval.signature);\n      });\n    }\n  }\n\n  /**\n   * Set owners inside a json representing a wallet initialization tx.\n   *\n   * @param {Record<string, any>} txJson json to modify\n   */\n  setOwnersInJson(txJson: Record<string, any>): void {\n    if (getDeployType(this.casperTx.session) === TransactionType.WalletInitialization) {\n      const argName = 0;\n      const argValue = 1;\n      const owner0 = 0;\n      const owner1 = 1;\n      const owner2 = 2;\n\n      const ownersValues = new Map();\n\n      ownersValues.set(TRANSACTION_TYPE, (this.casperTx.session.getArgByName(TRANSACTION_TYPE) as CLString).value());\n\n      [owner0, owner1, owner2].forEach((index) => {\n        ownersValues.set(\n          OWNER_PREFIX + index,\n          (this.casperTx.session.getArgByName(OWNER_PREFIX + index) as CLString).value()\n        );\n      });\n\n      txJson['deploy']['session']['ModuleBytes']['args'].forEach((arg) => {\n        if (ownersValues.has(arg[argName])) {\n          arg[argValue]['parsed'] = ownersValues.get(arg[argName]);\n        }\n      });\n    }\n  }\n\n  /**\n   * Set transfer fields inside a json representing a transfer tx.\n   *\n   * @param {Record<string, any>} txJson json to modify\n   */\n  setTransfersFieldsInJson(txJson: Record<string, any>): void {\n    if (getDeployType(this.casperTx.session) === TransactionType.Send) {\n      const argName = 0;\n      const argValue = 1;\n\n      const transferValues = new Map();\n      transferValues.set(TRANSACTION_TYPE, (this.casperTx.session.getArgByName(TRANSACTION_TYPE) as CLString).value());\n      transferValues.set('amount', getTransferAmount(this.casperTx.session));\n      transferValues.set('to_address', getTransferDestinationAddress(this.casperTx.session));\n      const transferId = getTransferId(this.casperTx.session);\n      if (transferId !== undefined) {\n        transferValues.set('id', transferId.toString());\n      }\n\n      txJson['deploy']['session']['Transfer']['args'].forEach((arg) => {\n        if (transferValues.has(arg[argName])) {\n          arg[argValue]['parsed'] = transferValues.get(arg[argName]);\n        }\n      });\n    }\n  }\n\n  /**\n   * Set delegate / undelegate fields inside a json representing the tx.\n   *\n   * @param {Record<string, any>} txJson json to modify\n   */\n  setDelegateFieldsInJson(txJson: Record<string, any>): void {\n    if (\n      getDeployType(this.casperTx.session) === TransactionType.StakingLock ||\n      getDeployType(this.casperTx.session) === TransactionType.StakingUnlock\n    ) {\n      const argName = 0;\n      const argValue = 1;\n\n      const delegateValues = new Map();\n      delegateValues.set(TRANSACTION_TYPE, (this.casperTx.session.getArgByName(TRANSACTION_TYPE) as CLString).value());\n      delegateValues.set('amount', getDelegateAmount(this.casperTx.session));\n      delegateValues.set(DELEGATE_FROM_ADDRESS, getDelegatorAddress(this.casperTx.session));\n      delegateValues.set(DELEGATE_VALIDATOR, getValidatorAddress(this.casperTx.session));\n\n      txJson.deploy.session.ModuleBytes.args.forEach((arg) => {\n        if (delegateValues.has(arg[argName])) {\n          arg[argValue]['parsed'] = delegateValues.get(arg[argName]);\n        }\n      });\n    }\n  }\n\n  get casperTx(): DeployUtil.Deploy {\n    return this._deploy;\n  }\n\n  set casperTx(deploy: DeployUtil.Deploy) {\n    this._deploy = deploy;\n  }\n\n  // endregion\n}\n"]}
|
|
241
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import * as _ from 'lodash';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { CLPublicKey as PublicKey, DeployUtil, Keys, CLString, CLU512 } from 'casper-js-sdk';\nimport { BaseKey, BaseTransaction, TransactionType, InvalidTransactionError, SigningError } from '@bitgo-beta/sdk-core';\nimport { KeyPair } from './keyPair';\nimport { CasperTransaction } from './ifaces';\nimport {\n  DELEGATE_FROM_ADDRESS,\n  DELEGATE_VALIDATOR,\n  OWNER_PREFIX,\n  SECP256K1_PREFIX,\n  TRANSACTION_TYPE,\n} from './constants';\nimport {\n  getTransferAmount,\n  getTransferDestinationAddress,\n  getTransferId,\n  isValidPublicKey,\n  removeAlgoPrefixFromHexValue,\n  getDeployType,\n  getDelegatorAddress,\n  getValidatorAddress,\n  getDelegateAmount,\n} from './utils';\n\nexport class Transaction extends BaseTransaction {\n  protected _type: TransactionType;\n  protected _deploy: DeployUtil.Deploy;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /** @inheritdoc */\n  canSign(key: BaseKey): boolean {\n    return true;\n  }\n\n  sign(keyPair: KeyPair): void {\n    const keys = keyPair.getKeys();\n    if (!keys.prv) {\n      throw new SigningError('Missing private key');\n    }\n    if (\n      this._deploy.approvals.some(\n        (ap) => !ap.signer.startsWith(SECP256K1_PREFIX) || !isValidPublicKey(removeAlgoPrefixFromHexValue(ap.signer))\n      )\n    ) {\n      throw new SigningError('Invalid deploy. Already signed with an invalid key');\n    }\n    const secpKeys = new Keys.Secp256K1(\n      Uint8Array.from(Buffer.from(keys.pub, 'hex')),\n      Uint8Array.from(Buffer.from(keys.prv, 'hex'))\n    );\n    const signedDeploy = DeployUtil.signDeploy(this._deploy, secpKeys);\n    this._signatures.push(signedDeploy.approvals[signedDeploy.approvals.length - 1].signature);\n  }\n\n  /**\n   * Add a signature to this transaction and to and its deploy\n   *\n   * @param {string} signature The signature to add, in string hex format\n   * @param {KeyPair} keyPair The key pair that created the signature\n   */\n  addSignature(signature: string, keyPair: KeyPair): void {\n    const pub = keyPair.getKeys().pub;\n    const signatureBuffer = Uint8Array.from(Buffer.from(signature, 'hex'));\n    const pubKeyBuffer = Uint8Array.from(Buffer.from(pub, 'hex'));\n    const parsedPublicKey = Keys.Secp256K1.parsePublicKey(pubKeyBuffer, 'raw');\n    const pubKeyHex = Keys.Secp256K1.accountHex(parsedPublicKey);\n    if (removeAlgoPrefixFromHexValue(pubKeyHex) !== pub) {\n      throw new SigningError('Signer does not match signature');\n    }\n    const signedDeploy = DeployUtil.setSignature(\n      this._deploy,\n      signatureBuffer,\n      PublicKey.fromSecp256K1(parsedPublicKey)\n    );\n    const approval = _.last(signedDeploy.approvals) as DeployUtil.Approval;\n    if (removeAlgoPrefixFromHexValue(approval.signature) !== signature) {\n      throw new SigningError('Invalid signature');\n    }\n    this._signatures.push(signature);\n  }\n\n  /** @inheritdoc */\n  toBroadcastFormat(): string {\n    if (!this.casperTx) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    const txJson: any = DeployUtil.deployToJson(this.casperTx);\n    // The new casper lib is converting the TTL from miliseconds to another date format, in this case 1 day\n    // we need to leave it as ms for the HSM to be able to parse it\n    txJson.deploy.header.ttl = `${this.casperTx.header.ttl}ms`;\n    this.setOwnersInJson(txJson);\n    this.setTransfersFieldsInJson(txJson);\n    this.setDelegateFieldsInJson(txJson);\n    return JSON.stringify(txJson);\n  }\n\n  /** @inheritdoc */\n  toJson(): CasperTransaction {\n    const deployPayment = this._deploy.payment.asModuleBytes()?.getArgByName('amount') as CLU512;\n    if (!deployPayment) {\n      throw new InvalidTransactionError('Undefined fee');\n    }\n\n    const owner1Index = 0;\n    const owner2Index = 1;\n    const owner3Index = 2;\n    const sourcePublicKey = Buffer.from(this._deploy.header.account.value()).toString('hex');\n    const sourceAddress = new KeyPair({ pub: sourcePublicKey }).getAddress();\n\n    const result: CasperTransaction = {\n      hash: Buffer.from(this._deploy.hash).toString('hex'),\n      fee: { gasLimit: deployPayment.value().toString(), gasPrice: this._deploy.header.gasPrice.toString() },\n      from: sourceAddress,\n      startTime: new Date(this._deploy.header.timestamp).toISOString(),\n      expiration: this._deploy.header.ttl,\n      deployType: (this._deploy.session.getArgByName(TRANSACTION_TYPE) as CLString).value(),\n    };\n\n    const transactionType = getDeployType(this._deploy.session);\n\n    switch (transactionType) {\n      case TransactionType.Send:\n        result.to = getTransferDestinationAddress(this._deploy.session);\n        result.amount = getTransferAmount(this._deploy.session);\n        result.transferId = getTransferId(this._deploy.session);\n        break;\n      case TransactionType.WalletInitialization:\n        result.owner1 = (this.casperTx.session.getArgByName(OWNER_PREFIX + owner1Index) as CLString).value();\n        result.owner2 = (this.casperTx.session.getArgByName(OWNER_PREFIX + owner2Index) as CLString).value();\n        result.owner3 = (this.casperTx.session.getArgByName(OWNER_PREFIX + owner3Index) as CLString).value();\n        break;\n      case TransactionType.StakingLock:\n        result.fromDelegate = getDelegatorAddress(this.casperTx.session);\n        result.validator = getValidatorAddress(this.casperTx.session);\n        result.amount = getDelegateAmount(this.casperTx.session);\n        break;\n      case TransactionType.StakingUnlock:\n        result.fromDelegate = getDelegatorAddress(this.casperTx.session);\n        result.validator = getValidatorAddress(this.casperTx.session);\n        result.amount = getDelegateAmount(this.casperTx.session);\n        break;\n    }\n    return result;\n  }\n\n  /**\n   * Set the transaction type\n   *\n   * @param {TransactionType} transactionType The transaction type to be set\n   */\n  setTransactionType(transactionType: TransactionType): void {\n    this._type = transactionType;\n  }\n\n  /**\n   * Retrieve signatures from the deploy instance and load them into the signatures list\n   */\n  loadPreviousSignatures(): void {\n    if (this._deploy.approvals && this._deploy.approvals.length > 0) {\n      this._deploy.approvals.forEach((approval) => {\n        this._signatures.push(approval.signature);\n      });\n    }\n  }\n\n  /**\n   * Set owners inside a json representing a wallet initialization tx.\n   *\n   * @param {Record<string, any>} txJson json to modify\n   */\n  setOwnersInJson(txJson: Record<string, any>): void {\n    if (getDeployType(this.casperTx.session) === TransactionType.WalletInitialization) {\n      const argName = 0;\n      const argValue = 1;\n      const owner0 = 0;\n      const owner1 = 1;\n      const owner2 = 2;\n\n      const ownersValues = new Map();\n\n      ownersValues.set(TRANSACTION_TYPE, (this.casperTx.session.getArgByName(TRANSACTION_TYPE) as CLString).value());\n\n      [owner0, owner1, owner2].forEach((index) => {\n        ownersValues.set(\n          OWNER_PREFIX + index,\n          (this.casperTx.session.getArgByName(OWNER_PREFIX + index) as CLString).value()\n        );\n      });\n\n      txJson['deploy']['session']['ModuleBytes']['args'].forEach((arg) => {\n        if (ownersValues.has(arg[argName])) {\n          arg[argValue]['parsed'] = ownersValues.get(arg[argName]);\n        }\n      });\n    }\n  }\n\n  /**\n   * Set transfer fields inside a json representing a transfer tx.\n   *\n   * @param {Record<string, any>} txJson json to modify\n   */\n  setTransfersFieldsInJson(txJson: Record<string, any>): void {\n    if (getDeployType(this.casperTx.session) === TransactionType.Send) {\n      const argName = 0;\n      const argValue = 1;\n\n      const transferValues = new Map();\n      transferValues.set(TRANSACTION_TYPE, (this.casperTx.session.getArgByName(TRANSACTION_TYPE) as CLString).value());\n      transferValues.set('amount', getTransferAmount(this.casperTx.session));\n      transferValues.set('to_address', getTransferDestinationAddress(this.casperTx.session));\n      const transferId = getTransferId(this.casperTx.session);\n      if (transferId !== undefined) {\n        transferValues.set('id', transferId.toString());\n      }\n\n      txJson['deploy']['session']['Transfer']['args'].forEach((arg) => {\n        if (transferValues.has(arg[argName])) {\n          arg[argValue]['parsed'] = transferValues.get(arg[argName]);\n        }\n      });\n    }\n  }\n\n  /**\n   * Set delegate / undelegate fields inside a json representing the tx.\n   *\n   * @param {Record<string, any>} txJson json to modify\n   */\n  setDelegateFieldsInJson(txJson: Record<string, any>): void {\n    if (\n      getDeployType(this.casperTx.session) === TransactionType.StakingLock ||\n      getDeployType(this.casperTx.session) === TransactionType.StakingUnlock\n    ) {\n      const argName = 0;\n      const argValue = 1;\n\n      const delegateValues = new Map();\n      delegateValues.set(TRANSACTION_TYPE, (this.casperTx.session.getArgByName(TRANSACTION_TYPE) as CLString).value());\n      delegateValues.set('amount', getDelegateAmount(this.casperTx.session));\n      delegateValues.set(DELEGATE_FROM_ADDRESS, getDelegatorAddress(this.casperTx.session));\n      delegateValues.set(DELEGATE_VALIDATOR, getValidatorAddress(this.casperTx.session));\n\n      txJson.deploy.session.ModuleBytes.args.forEach((arg) => {\n        if (delegateValues.has(arg[argName])) {\n          arg[argValue]['parsed'] = delegateValues.get(arg[argName]);\n        }\n      });\n    }\n  }\n\n  get casperTx(): DeployUtil.Deploy {\n    return this._deploy;\n  }\n\n  set casperTx(deploy: DeployUtil.Deploy) {\n    this._deploy = deploy;\n  }\n\n  // endregion\n}\n"]}
|