@bitgo-beta/sdk-coin-cspr 1.2.19-beta.898 → 1.2.19-beta.899
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/cspr.d.ts +3 -1
- package/dist/src/cspr.d.ts.map +1 -1
- package/dist/src/cspr.js +5 -1
- package/package.json +6 -6
package/dist/src/cspr.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { BaseCoin as StaticsBaseCoin, CoinFamily } from '@bitgo-beta/statics';
|
|
2
|
-
import { BaseCoin, BitGoBase, KeyPair, MultisigType, ParsedTransaction, ParseTransactionOptions, SignedTransaction, SignTransactionOptions as BaseSignTransactionOptions, TransactionExplanation, TransactionPrebuild as BaseTransactionPrebuild, VerifyAddressOptions, VerifyTransactionOptions } from '@bitgo-beta/sdk-core';
|
|
2
|
+
import { AuditDecryptedKeyParams, BaseCoin, BitGoBase, KeyPair, MultisigType, ParsedTransaction, ParseTransactionOptions, SignedTransaction, SignTransactionOptions as BaseSignTransactionOptions, TransactionExplanation, TransactionPrebuild as BaseTransactionPrebuild, VerifyAddressOptions, VerifyTransactionOptions } from '@bitgo-beta/sdk-core';
|
|
3
3
|
interface SignTransactionOptions extends BaseSignTransactionOptions {
|
|
4
4
|
txPrebuild: TransactionPrebuild;
|
|
5
5
|
prv: string;
|
|
@@ -100,6 +100,8 @@ export declare class Cspr extends BaseCoin {
|
|
|
100
100
|
*/
|
|
101
101
|
explainTransaction(params: ExplainTransactionOptions): Promise<TransactionExplanation>;
|
|
102
102
|
private getBuilder;
|
|
103
|
+
/** @inheritDoc */
|
|
104
|
+
auditDecryptedKey(params: AuditDecryptedKeyParams): void;
|
|
103
105
|
}
|
|
104
106
|
export {};
|
|
105
107
|
//# sourceMappingURL=cspr.d.ts.map
|
package/dist/src/cspr.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
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,YAAY,EAEZ,iBAAiB,EACjB,uBAAuB,EACvB,iBAAiB,EACjB,sBAAsB,IAAI,0BAA0B,EACpD,sBAAsB,EACtB,mBAAmB,IAAI,uBAAuB,EAG9C,oBAAoB,EACpB,wBAAwB,
|
|
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,uBAAuB,EACvB,QAAQ,EACR,SAAS,EAGT,OAAO,EACP,YAAY,EAEZ,iBAAiB,EACjB,uBAAuB,EACvB,iBAAiB,EACjB,sBAAsB,IAAI,0BAA0B,EACpD,sBAAsB,EACtB,mBAAmB,IAAI,uBAAuB,EAG9C,oBAAoB,EACpB,wBAAwB,EAEzB,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;IAIhC,oBAAoB;IACpB,sBAAsB,IAAI,YAAY;IAIhC,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;IAIlB,kBAAkB;IAClB,iBAAiB,CAAC,MAAM,EAAE,uBAAuB;CAGlD"}
|
package/dist/src/cspr.js
CHANGED
|
@@ -305,6 +305,10 @@ class Cspr extends sdk_core_1.BaseCoin {
|
|
|
305
305
|
getBuilder() {
|
|
306
306
|
return new CsprLib.TransactionBuilderFactory(statics_1.coins.get(this.getChain()));
|
|
307
307
|
}
|
|
308
|
+
/** @inheritDoc */
|
|
309
|
+
auditDecryptedKey(params) {
|
|
310
|
+
throw new sdk_core_1.MethodNotImplementedError();
|
|
311
|
+
}
|
|
308
312
|
}
|
|
309
313
|
exports.Cspr = Cspr;
|
|
310
|
-
//# 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  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} 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"]}
|
|
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/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@bitgo-beta/sdk-coin-cspr",
|
|
3
|
-
"version": "1.2.19-beta.
|
|
3
|
+
"version": "1.2.19-beta.899",
|
|
4
4
|
"description": "BitGo SDK coin library for Casper",
|
|
5
5
|
"main": "./dist/src/index.js",
|
|
6
6
|
"types": "./dist/src/index.d.ts",
|
|
@@ -40,9 +40,9 @@
|
|
|
40
40
|
]
|
|
41
41
|
},
|
|
42
42
|
"dependencies": {
|
|
43
|
-
"@bitgo-beta/sdk-core": "8.2.1-beta.
|
|
44
|
-
"@bitgo-beta/secp256k1": "1.0.2-beta.
|
|
45
|
-
"@bitgo-beta/statics": "15.1.1-beta.
|
|
43
|
+
"@bitgo-beta/sdk-core": "8.2.1-beta.902",
|
|
44
|
+
"@bitgo-beta/secp256k1": "1.0.2-beta.929",
|
|
45
|
+
"@bitgo-beta/statics": "15.1.1-beta.905",
|
|
46
46
|
"@ethersproject/bignumber": "^5.6.0",
|
|
47
47
|
"@stablelib/hex": "^1.0.0",
|
|
48
48
|
"bignumber.js": "^9.0.0",
|
|
@@ -51,9 +51,9 @@
|
|
|
51
51
|
"secp256k1": "5.0.1"
|
|
52
52
|
},
|
|
53
53
|
"devDependencies": {
|
|
54
|
-
"@bitgo-beta/sdk-api": "1.10.1-beta.
|
|
54
|
+
"@bitgo-beta/sdk-api": "1.10.1-beta.901",
|
|
55
55
|
"@bitgo-beta/sdk-test": "^8.0.86",
|
|
56
56
|
"tweetnacl": "^1.0.3"
|
|
57
57
|
},
|
|
58
|
-
"gitHead": "
|
|
58
|
+
"gitHead": "5b5a61ddf2b079ded0b4d3a7d701ee46749f5fbd"
|
|
59
59
|
}
|