@bitgo-beta/sdk-coin-stx 1.4.3-alpha.22 → 1.4.3-alpha.221

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.
@@ -1,7 +1,11 @@
1
1
  "use strict";
2
2
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
3
  if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
5
9
  }) : (function(o, m, k, k2) {
6
10
  if (k2 === undefined) k2 = k;
7
11
  o[k2] = m[k];
@@ -30,4 +34,4 @@ __exportStar(require("./keyPair"), exports);
30
34
  __exportStar(require("./transaction"), exports);
31
35
  __exportStar(require("./transactionBuilderFactory"), exports);
32
36
  exports.Utils = __importStar(require("./utils"));
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxxREFBdUU7QUFBOUQsOEdBQUEsY0FBYyxPQUFBO0FBQUUsK0dBQUEsZUFBZSxPQUFBO0FBQ3hDLDRDQUEwQjtBQUMxQixnREFBOEI7QUFDOUIsOERBQTRDO0FBQzVDLGlEQUFpQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IEFkZHJlc3NWZXJzaW9uLCBBZGRyZXNzSGFzaE1vZGUgfSBmcm9tICdAc3RhY2tzL3RyYW5zYWN0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL2tleVBhaXInO1xuZXhwb3J0ICogZnJvbSAnLi90cmFuc2FjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3RyYW5zYWN0aW9uQnVpbGRlckZhY3RvcnknO1xuZXhwb3J0ICogYXMgVXRpbHMgZnJvbSAnLi91dGlscyc7XG4iXX0=
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEscURBQXVFO0FBQTlELDhHQUFBLGNBQWMsT0FBQTtBQUFFLCtHQUFBLGVBQWUsT0FBQTtBQUN4Qyw0Q0FBMEI7QUFDMUIsZ0RBQThCO0FBQzlCLDhEQUE0QztBQUM1QyxpREFBaUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBBZGRyZXNzVmVyc2lvbiwgQWRkcmVzc0hhc2hNb2RlIH0gZnJvbSAnQHN0YWNrcy90cmFuc2FjdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9rZXlQYWlyJztcbmV4cG9ydCAqIGZyb20gJy4vdHJhbnNhY3Rpb24nO1xuZXhwb3J0ICogZnJvbSAnLi90cmFuc2FjdGlvbkJ1aWxkZXJGYWN0b3J5JztcbmV4cG9ydCAqIGFzIFV0aWxzIGZyb20gJy4vdXRpbHMnO1xuIl19
@@ -16,16 +16,16 @@ class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
16
16
  constructor(source) {
17
17
  super(source);
18
18
  if (!source) {
19
- const seed = crypto_1.randomBytes(constants_1.DEFAULT_SEED_SIZE_BYTES);
19
+ const seed = (0, crypto_1.randomBytes)(constants_1.DEFAULT_SEED_SIZE_BYTES);
20
20
  this.hdNode = utxo_lib_1.bip32.fromSeed(seed);
21
21
  }
22
- else if (sdk_core_1.isSeed(source)) {
22
+ else if ((0, sdk_core_1.isSeed)(source)) {
23
23
  this.hdNode = utxo_lib_1.bip32.fromSeed(source.seed);
24
24
  }
25
- else if (sdk_core_1.isPrivateKey(source)) {
25
+ else if ((0, sdk_core_1.isPrivateKey)(source)) {
26
26
  this.recordKeysFromPrivateKey(source.prv);
27
27
  }
28
- else if (sdk_core_1.isPublicKey(source)) {
28
+ else if ((0, sdk_core_1.isPublicKey)(source)) {
29
29
  this.recordKeysFromPublicKey(source.pub);
30
30
  }
31
31
  else {
@@ -46,10 +46,10 @@ class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
46
46
  * @param {string} prv A raw private key
47
47
  */
48
48
  recordKeysFromPrivateKey(prv) {
49
- if (!utils_1.isValidPrivateKey(prv)) {
49
+ if (!(0, utils_1.isValidPrivateKey)(prv)) {
50
50
  throw new Error('Unsupported private key');
51
51
  }
52
- if (sdk_core_1.isValidXprv(prv)) {
52
+ if ((0, sdk_core_1.isValidXprv)(prv)) {
53
53
  this.hdNode = utxo_lib_1.bip32.fromBase58(prv);
54
54
  }
55
55
  else {
@@ -67,10 +67,10 @@ class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
67
67
  * @param {string} pub A raw public key
68
68
  */
69
69
  recordKeysFromPublicKey(pub) {
70
- if (!utils_1.isValidPublicKey(pub)) {
70
+ if (!(0, utils_1.isValidPublicKey)(pub)) {
71
71
  throw new Error('Unsupported public key');
72
72
  }
73
- if (sdk_core_1.isValidXpub(pub)) {
73
+ if ((0, sdk_core_1.isValidXpub)(pub)) {
74
74
  this.hdNode = utxo_lib_1.bip32.fromBase58(pub);
75
75
  }
76
76
  else {
@@ -113,8 +113,8 @@ class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
113
113
  * @returns {string} The public address
114
114
  */
115
115
  getSTXAddress(compressed = false, network = transactions_1.TransactionVersion.Mainnet) {
116
- return transactions_1.getAddressFromPublicKey(this.getKeys(compressed).pub, network);
116
+ return (0, transactions_1.getAddressFromPublicKey)(this.getKeys(compressed).pub, network);
117
117
  }
118
118
  }
119
119
  exports.KeyPair = KeyPair;
120
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyPair.js","sourceRoot":"","sources":["../../../src/lib/keyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import { randomBytes } from 'crypto';\nimport { bip32, ECPair } from '@bitgo-beta/utxo-lib';\nimport { getAddressFromPublicKey, TransactionVersion } from '@stacks/transactions';\nimport {\n  DefaultKeys,\n  isPrivateKey,\n  isPublicKey,\n  isSeed,\n  isValidXprv,\n  isValidXpub,\n  KeyPairOptions,\n  Secp256k1ExtendedKeyPair,\n} from '@bitgo-beta/sdk-core';\nimport { isValidPrivateKey, isValidPublicKey } from './utils';\nimport { DEFAULT_SEED_SIZE_BYTES } from './constants';\n\nexport class KeyPair extends Secp256k1ExtendedKeyPair {\n  /**\n   * Public constructor. By default, creates a key pair with a random master seed.\n   *\n   * @param { KeyPairOptions } source Either a master seed, a private key, or a public key\n   */\n  constructor(source?: KeyPairOptions) {\n    super(source);\n    if (!source) {\n      const seed = randomBytes(DEFAULT_SEED_SIZE_BYTES);\n      this.hdNode = bip32.fromSeed(seed);\n    } else if (isSeed(source)) {\n      this.hdNode = bip32.fromSeed(source.seed);\n    } else if (isPrivateKey(source)) {\n      this.recordKeysFromPrivateKey(source.prv);\n    } else if (isPublicKey(source)) {\n      this.recordKeysFromPublicKey(source.pub);\n    } else {\n      throw new Error('Invalid key pair options');\n    }\n\n    if (this.hdNode) {\n      this.keyPair = Secp256k1ExtendedKeyPair.toKeyPair(this.hdNode);\n    }\n  }\n\n  /**\n   * Build a keypair from a protocol private key or extended private key.\n   *\n   * The protocol private key is either 32 or 33 bytes long (64 or 66\n   * characters hex).  If it is 32 bytes long, set the keypair's \"compressed\"\n   * field to false to later generate uncompressed public keys (the default).\n   * A 33 byte key has 0x01 as the last byte.\n   *\n   * @param {string} prv A raw private key\n   */\n  recordKeysFromPrivateKey(prv: string): void {\n    if (!isValidPrivateKey(prv)) {\n      throw new Error('Unsupported private key');\n    }\n\n    if (isValidXprv(prv)) {\n      this.hdNode = bip32.fromBase58(prv);\n    } else {\n      this.keyPair = ECPair.fromPrivateKey(Buffer.from(prv.slice(0, 64), 'hex'));\n    }\n  }\n\n  /**\n   * Build an ECPair from a protocol public key or extended public key.\n   *\n   * The protocol public key is either 32 bytes or 64 bytes long, with a\n   * one-byte prefix (a total of 66 or 130 characters in hex).  If the\n   * prefix is 0x02 or 0x03, it is a compressed public key.  A prefix of 0x04\n   * denotes an uncompressed public key.\n   *\n   * @param {string} pub A raw public key\n   */\n  recordKeysFromPublicKey(pub: string): void {\n    if (!isValidPublicKey(pub)) {\n      throw new Error('Unsupported public key');\n    }\n\n    if (isValidXpub(pub)) {\n      this.hdNode = bip32.fromBase58(pub);\n    } else {\n      this.keyPair = ECPair.fromPublicKey(Buffer.from(pub, 'hex'));\n    }\n  }\n\n  /**\n   * Stacks default keys format is raw private and uncompressed public key\n   *\n   * @param {boolean} compressed - Compress public key (defaults to false)\n   * @returns {DefaultKeys} The keys in the protocol default key format\n   */\n  getKeys(compressed = false): DefaultKeys {\n    let prv = this.getPrivateKey()?.toString('hex');\n    if (prv && compressed) {\n      prv += '01';\n    }\n\n    return {\n      pub: this.getPublicKey({ compressed }).toString('hex'),\n      prv,\n    };\n  }\n\n  getCompressed(): boolean {\n    return this.keyPair.compressed;\n  }\n\n  /**\n   * Get a public address of an uncompressed public key.\n   *\n   * @returns {string} The public address\n   */\n  getAddress(): string {\n    return this.getSTXAddress(false, TransactionVersion.Mainnet);\n  }\n\n  /**\n   * Get a public address of an uncompressed public key.\n   *\n   * @param {boolean} compressed - Compress public key (defaults to false)\n   * @param {TransactionVersion} network - select Mainnet or Testnet for the address\n   * @returns {string} The public address\n   */\n  getSTXAddress(compressed = false, network: TransactionVersion = TransactionVersion.Mainnet): string {\n    return getAddressFromPublicKey(this.getKeys(compressed).pub, network);\n  }\n}\n"]}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyPair.js","sourceRoot":"","sources":["../../../src/lib/keyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import { randomBytes } from 'crypto';\nimport { bip32, ECPair } from '@bitgo-beta/utxo-lib';\nimport { getAddressFromPublicKey, TransactionVersion } from '@stacks/transactions';\nimport {\n  DefaultKeys,\n  isPrivateKey,\n  isPublicKey,\n  isSeed,\n  isValidXprv,\n  isValidXpub,\n  KeyPairOptions,\n  Secp256k1ExtendedKeyPair,\n} from '@bitgo-beta/sdk-core';\nimport { isValidPrivateKey, isValidPublicKey } from './utils';\nimport { DEFAULT_SEED_SIZE_BYTES } from './constants';\n\nexport class KeyPair extends Secp256k1ExtendedKeyPair {\n  /**\n   * Public constructor. By default, creates a key pair with a random master seed.\n   *\n   * @param { KeyPairOptions } source Either a master seed, a private key, or a public key\n   */\n  constructor(source?: KeyPairOptions) {\n    super(source);\n    if (!source) {\n      const seed = randomBytes(DEFAULT_SEED_SIZE_BYTES);\n      this.hdNode = bip32.fromSeed(seed);\n    } else if (isSeed(source)) {\n      this.hdNode = bip32.fromSeed(source.seed);\n    } else if (isPrivateKey(source)) {\n      this.recordKeysFromPrivateKey(source.prv);\n    } else if (isPublicKey(source)) {\n      this.recordKeysFromPublicKey(source.pub);\n    } else {\n      throw new Error('Invalid key pair options');\n    }\n\n    if (this.hdNode) {\n      this.keyPair = Secp256k1ExtendedKeyPair.toKeyPair(this.hdNode);\n    }\n  }\n\n  /**\n   * Build a keypair from a protocol private key or extended private key.\n   *\n   * The protocol private key is either 32 or 33 bytes long (64 or 66\n   * characters hex).  If it is 32 bytes long, set the keypair's \"compressed\"\n   * field to false to later generate uncompressed public keys (the default).\n   * A 33 byte key has 0x01 as the last byte.\n   *\n   * @param {string} prv A raw private key\n   */\n  recordKeysFromPrivateKey(prv: string): void {\n    if (!isValidPrivateKey(prv)) {\n      throw new Error('Unsupported private key');\n    }\n\n    if (isValidXprv(prv)) {\n      this.hdNode = bip32.fromBase58(prv);\n    } else {\n      this.keyPair = ECPair.fromPrivateKey(Buffer.from(prv.slice(0, 64), 'hex'));\n    }\n  }\n\n  /**\n   * Build an ECPair from a protocol public key or extended public key.\n   *\n   * The protocol public key is either 32 bytes or 64 bytes long, with a\n   * one-byte prefix (a total of 66 or 130 characters in hex).  If the\n   * prefix is 0x02 or 0x03, it is a compressed public key.  A prefix of 0x04\n   * denotes an uncompressed public key.\n   *\n   * @param {string} pub A raw public key\n   */\n  recordKeysFromPublicKey(pub: string): void {\n    if (!isValidPublicKey(pub)) {\n      throw new Error('Unsupported public key');\n    }\n\n    if (isValidXpub(pub)) {\n      this.hdNode = bip32.fromBase58(pub);\n    } else {\n      this.keyPair = ECPair.fromPublicKey(Buffer.from(pub, 'hex'));\n    }\n  }\n\n  /**\n   * Stacks default keys format is raw private and uncompressed public key\n   *\n   * @param {boolean} compressed - Compress public key (defaults to false)\n   * @returns {DefaultKeys} The keys in the protocol default key format\n   */\n  getKeys(compressed = false): DefaultKeys {\n    let prv = this.getPrivateKey()?.toString('hex');\n    if (prv && compressed) {\n      prv += '01';\n    }\n\n    return {\n      pub: this.getPublicKey({ compressed }).toString('hex'),\n      prv,\n    };\n  }\n\n  getCompressed(): boolean {\n    return this.keyPair.compressed;\n  }\n\n  /**\n   * Get a public address of an uncompressed public key.\n   *\n   * @returns {string} The public address\n   */\n  getAddress(): string {\n    return this.getSTXAddress(false, TransactionVersion.Mainnet);\n  }\n\n  /**\n   * Get a public address of an uncompressed public key.\n   *\n   * @param {boolean} compressed - Compress public key (defaults to false)\n   * @param {TransactionVersion} network - select Mainnet or Testnet for the address\n   * @returns {string} The public address\n   */\n  getSTXAddress(compressed = false, network: TransactionVersion = TransactionVersion.Mainnet): string {\n    return getAddressFromPublicKey(this.getKeys(compressed).pub, network);\n  }\n}\n"]}
@@ -16,30 +16,30 @@ class SendmanyBuilder extends abstractContractBuilder_1.AbstractContractBuilder
16
16
  super(_coinConfig);
17
17
  this._sendParams = [];
18
18
  this.sendParamsToFunctionArgs = (sendParams) => [
19
- transactions_1.listCV(sendParams.map((recipient) => transactions_1.tupleCV({
20
- to: transactions_1.standardPrincipalCV(recipient.address),
21
- ustx: transactions_1.uintCV(recipient.amount),
22
- memo: transactions_1.bufferCVFromString(recipient.memo || ''),
19
+ (0, transactions_1.listCV)(sendParams.map((recipient) => (0, transactions_1.tupleCV)({
20
+ to: (0, transactions_1.standardPrincipalCV)(recipient.address),
21
+ ustx: (0, transactions_1.uintCV)(recipient.amount),
22
+ memo: (0, transactions_1.bufferCVFromString)(recipient.memo || ''),
23
23
  }))),
24
24
  ];
25
25
  }
26
26
  static isValidContractCall(coinConfig, payload) {
27
27
  return (coinConfig.network.sendmanymemoContractAddress ===
28
- transactions_1.addressToString(payload.contractAddress) &&
28
+ (0, transactions_1.addressToString)(payload.contractAddress) &&
29
29
  constants_1.CONTRACT_NAME_SENDMANY === payload.contractName.content &&
30
30
  constants_1.FUNCTION_NAME_SENDMANY === payload.functionName.content);
31
31
  }
32
32
  sendParamsToPostcondition(sendParams) {
33
33
  const sum = sendParams.reduce((current, next) => current.add(new bn_js_1.default(next.amount)), new bn_js_1.default(0));
34
34
  return [
35
- transactions_1.makeStandardSTXPostCondition(utils_1.getSTXAddressFromPubKeys(this._fromPubKeys, this._coinConfig.network.type === statics_1.NetworkType.MAINNET
35
+ (0, transactions_1.makeStandardSTXPostCondition)((0, utils_1.getSTXAddressFromPubKeys)(this._fromPubKeys, this._coinConfig.network.type === statics_1.NetworkType.MAINNET
36
36
  ? transactions_1.AddressVersion.MainnetMultiSig
37
37
  : transactions_1.AddressVersion.TestnetMultiSig, this._fromPubKeys.length > 1 ? transactions_1.AddressHashMode.SerializeP2SH : transactions_1.AddressHashMode.SerializeP2PKH, this._numberSignatures).address, transactions_1.FungibleConditionCode.Equal, sum),
38
38
  ];
39
39
  }
40
40
  initBuilder(tx) {
41
41
  super.initBuilder(tx);
42
- this._sendParams = utils_1.functionArgsToSendParams(tx.stxTransaction.payload.functionArgs);
42
+ this._sendParams = (0, utils_1.functionArgsToSendParams)(tx.stxTransaction.payload.functionArgs);
43
43
  }
44
44
  /**
45
45
  * Set a transfer
@@ -48,13 +48,13 @@ class SendmanyBuilder extends abstractContractBuilder_1.AbstractContractBuilder
48
48
  * @returns {TransactionBuilder} This transaction builder
49
49
  */
50
50
  send({ address, amount, memo }) {
51
- if (!address || !utils_1.isValidAddress(address)) {
51
+ if (!address || !(0, utils_1.isValidAddress)(address)) {
52
52
  throw new sdk_core_1.BuildTransactionError('Invalid or missing address, got: ' + address);
53
53
  }
54
- if (!amount || !utils_1.isValidAmount(amount)) {
54
+ if (!amount || !(0, utils_1.isValidAmount)(amount)) {
55
55
  throw new sdk_core_1.BuildTransactionError('Invalid or missing amount, got: ' + amount);
56
56
  }
57
- if (!!memo && !utils_1.isValidMemo(memo)) {
57
+ if (!!memo && !(0, utils_1.isValidMemo)(memo)) {
58
58
  throw new sdk_core_1.BuildTransactionError('Invalid memo, got: ' + memo);
59
59
  }
60
60
  this._sendParams.push({ address, amount, memo });
@@ -72,4 +72,4 @@ class SendmanyBuilder extends abstractContractBuilder_1.AbstractContractBuilder
72
72
  }
73
73
  }
74
74
  exports.SendmanyBuilder = SendmanyBuilder;
75
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sendmanyBuilder.js","sourceRoot":"","sources":["../../../src/lib/sendmanyBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig, NetworkType, StacksNetwork as BitgoStacksNetwork } from '@bitgo-beta/statics';\nimport BigNum from 'bn.js';\nimport {\n  AddressHashMode,\n  addressToString,\n  AddressVersion,\n  bufferCVFromString,\n  ClarityValue,\n  FungibleConditionCode,\n  listCV,\n  makeStandardSTXPostCondition,\n  PostCondition,\n  PostConditionMode,\n  standardPrincipalCV,\n  tupleCV,\n  uintCV,\n} from '@stacks/transactions';\nimport { BuildTransactionError } from '@bitgo-beta/sdk-core';\nimport { Transaction } from './transaction';\nimport {\n  functionArgsToSendParams,\n  getSTXAddressFromPubKeys,\n  isValidAddress,\n  isValidAmount,\n  isValidMemo,\n} from './utils';\nimport { SendParams } from './iface';\nimport { CONTRACT_NAME_SENDMANY, FUNCTION_NAME_SENDMANY } from './constants';\nimport { ContractCallPayload } from '@stacks/transactions/dist/payload';\nimport { AbstractContractBuilder } from './abstractContractBuilder';\n\nexport class SendmanyBuilder extends AbstractContractBuilder {\n  private _sendParams: SendParams[] = [];\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  public static isValidContractCall(coinConfig: Readonly<CoinConfig>, payload: ContractCallPayload): boolean {\n    return (\n      (coinConfig.network as BitgoStacksNetwork).sendmanymemoContractAddress ===\n        addressToString(payload.contractAddress) &&\n      CONTRACT_NAME_SENDMANY === payload.contractName.content &&\n      FUNCTION_NAME_SENDMANY === payload.functionName.content\n    );\n  }\n\n  private sendParamsToFunctionArgs = (sendParams: SendParams[]): ClarityValue[] => [\n    listCV(\n      sendParams.map((recipient) =>\n        tupleCV({\n          to: standardPrincipalCV(recipient.address),\n          ustx: uintCV(recipient.amount),\n          memo: bufferCVFromString(recipient.memo || ''),\n        })\n      )\n    ),\n  ];\n\n  private sendParamsToPostcondition(sendParams: SendParams[]): PostCondition[] {\n    const sum: BigNum = sendParams.reduce((current, next) => current.add(new BigNum(next.amount)), new BigNum(0));\n    return [\n      makeStandardSTXPostCondition(\n        getSTXAddressFromPubKeys(\n          this._fromPubKeys,\n          this._coinConfig.network.type === NetworkType.MAINNET\n            ? AddressVersion.MainnetMultiSig\n            : AddressVersion.TestnetMultiSig,\n          this._fromPubKeys.length > 1 ? AddressHashMode.SerializeP2SH : AddressHashMode.SerializeP2PKH,\n          this._numberSignatures\n        ).address,\n        FungibleConditionCode.Equal,\n        sum\n      ),\n    ];\n  }\n\n  initBuilder(tx: Transaction): void {\n    super.initBuilder(tx);\n    this._sendParams = functionArgsToSendParams((tx.stxTransaction.payload as ContractCallPayload).functionArgs);\n  }\n\n  /**\n   *  Set a transfer\n   *\n   * @param {SendParams} sendParams - the sender address\n   * @returns {TransactionBuilder} This transaction builder\n   */\n  send({ address, amount, memo }: SendParams): this {\n    if (!address || !isValidAddress(address)) {\n      throw new BuildTransactionError('Invalid or missing address, got: ' + address);\n    }\n    if (!amount || !isValidAmount(amount)) {\n      throw new BuildTransactionError('Invalid or missing amount, got: ' + amount);\n    }\n    if (!!memo && !isValidMemo(memo)) {\n      throw new BuildTransactionError('Invalid memo, got: ' + memo);\n    }\n\n    this._sendParams.push({ address, amount, memo });\n    return this;\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    this._contractAddress = (this._coinConfig.network as BitgoStacksNetwork).sendmanymemoContractAddress;\n    this._contractName = CONTRACT_NAME_SENDMANY;\n    this._functionName = FUNCTION_NAME_SENDMANY;\n    this._functionArgs = this.sendParamsToFunctionArgs(this._sendParams);\n    this._postConditionMode = PostConditionMode.Deny;\n    this._postConditions = this.sendParamsToPostcondition(this._sendParams);\n    return await super.buildImplementation();\n  }\n}\n"]}
75
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sendmanyBuilder.js","sourceRoot":"","sources":["../../../src/lib/sendmanyBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig, NetworkType, StacksNetwork as BitgoStacksNetwork } from '@bitgo-beta/statics';\nimport BigNum from 'bn.js';\nimport {\n  AddressHashMode,\n  addressToString,\n  AddressVersion,\n  bufferCVFromString,\n  ClarityValue,\n  FungibleConditionCode,\n  listCV,\n  makeStandardSTXPostCondition,\n  PostCondition,\n  PostConditionMode,\n  standardPrincipalCV,\n  tupleCV,\n  uintCV,\n} from '@stacks/transactions';\nimport { BuildTransactionError } from '@bitgo-beta/sdk-core';\nimport { Transaction } from './transaction';\nimport {\n  functionArgsToSendParams,\n  getSTXAddressFromPubKeys,\n  isValidAddress,\n  isValidAmount,\n  isValidMemo,\n} from './utils';\nimport { SendParams } from './iface';\nimport { CONTRACT_NAME_SENDMANY, FUNCTION_NAME_SENDMANY } from './constants';\nimport { ContractCallPayload } from '@stacks/transactions/dist/payload';\nimport { AbstractContractBuilder } from './abstractContractBuilder';\n\nexport class SendmanyBuilder extends AbstractContractBuilder {\n  private _sendParams: SendParams[] = [];\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  public static isValidContractCall(coinConfig: Readonly<CoinConfig>, payload: ContractCallPayload): boolean {\n    return (\n      (coinConfig.network as BitgoStacksNetwork).sendmanymemoContractAddress ===\n        addressToString(payload.contractAddress) &&\n      CONTRACT_NAME_SENDMANY === payload.contractName.content &&\n      FUNCTION_NAME_SENDMANY === payload.functionName.content\n    );\n  }\n\n  private sendParamsToFunctionArgs = (sendParams: SendParams[]): ClarityValue[] => [\n    listCV(\n      sendParams.map((recipient) =>\n        tupleCV({\n          to: standardPrincipalCV(recipient.address),\n          ustx: uintCV(recipient.amount),\n          memo: bufferCVFromString(recipient.memo || ''),\n        })\n      )\n    ),\n  ];\n\n  private sendParamsToPostcondition(sendParams: SendParams[]): PostCondition[] {\n    const sum: BigNum = sendParams.reduce((current, next) => current.add(new BigNum(next.amount)), new BigNum(0));\n    return [\n      makeStandardSTXPostCondition(\n        getSTXAddressFromPubKeys(\n          this._fromPubKeys,\n          this._coinConfig.network.type === NetworkType.MAINNET\n            ? AddressVersion.MainnetMultiSig\n            : AddressVersion.TestnetMultiSig,\n          this._fromPubKeys.length > 1 ? AddressHashMode.SerializeP2SH : AddressHashMode.SerializeP2PKH,\n          this._numberSignatures\n        ).address,\n        FungibleConditionCode.Equal,\n        sum\n      ),\n    ];\n  }\n\n  initBuilder(tx: Transaction): void {\n    super.initBuilder(tx);\n    this._sendParams = functionArgsToSendParams((tx.stxTransaction.payload as ContractCallPayload).functionArgs);\n  }\n\n  /**\n   *  Set a transfer\n   *\n   * @param {SendParams} sendParams - the sender address\n   * @returns {TransactionBuilder} This transaction builder\n   */\n  send({ address, amount, memo }: SendParams): this {\n    if (!address || !isValidAddress(address)) {\n      throw new BuildTransactionError('Invalid or missing address, got: ' + address);\n    }\n    if (!amount || !isValidAmount(amount)) {\n      throw new BuildTransactionError('Invalid or missing amount, got: ' + amount);\n    }\n    if (!!memo && !isValidMemo(memo)) {\n      throw new BuildTransactionError('Invalid memo, got: ' + memo);\n    }\n\n    this._sendParams.push({ address, amount, memo });\n    return this;\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    this._contractAddress = (this._coinConfig.network as BitgoStacksNetwork).sendmanymemoContractAddress;\n    this._contractName = CONTRACT_NAME_SENDMANY;\n    this._functionName = FUNCTION_NAME_SENDMANY;\n    this._functionArgs = this.sendParamsToFunctionArgs(this._sendParams);\n    this._postConditionMode = PostConditionMode.Deny;\n    this._postConditions = this.sendParamsToPostcondition(this._sendParams);\n    return await super.buildImplementation();\n  }\n}\n"]}
@@ -27,7 +27,7 @@ class Transaction extends sdk_core_1.BaseTransaction {
27
27
  if (!keys.prv) {
28
28
  throw new sdk_core_1.SigningError('Missing private key');
29
29
  }
30
- const privKey = transactions_1.createStacksPrivateKey(keys.prv);
30
+ const privKey = (0, transactions_1.createStacksPrivateKey)(keys.prv);
31
31
  signer.signOrigin(privKey);
32
32
  this._sigHash = signer.sigHash;
33
33
  }
@@ -36,7 +36,7 @@ class Transaction extends sdk_core_1.BaseTransaction {
36
36
  const pubKeyStrings = pubKeyString instanceof Array ? pubKeyString : [pubKeyString];
37
37
  const signer = new transactions_1.TransactionSigner(this._stxTransaction);
38
38
  pubKeyStrings.forEach((pubKey) => {
39
- signer.appendOrigin(transactions_1.createStacksPublicKey(pubKey));
39
+ signer.appendOrigin((0, transactions_1.createStacksPublicKey)(pubKey));
40
40
  });
41
41
  }
42
42
  async signWithSignatures(signature, isMultiSig) {
@@ -48,7 +48,7 @@ class Transaction extends sdk_core_1.BaseTransaction {
48
48
  this._stxTransaction = this._stxTransaction.createTxWithSignature(signatures[0].data);
49
49
  }
50
50
  else {
51
- const authFields = signatures.map((sig) => transactions_1.createTransactionAuthField(transactions_1.PubKeyEncoding.Compressed, sig));
51
+ const authFields = signatures.map((sig) => (0, transactions_1.createTransactionAuthField)(transactions_1.PubKeyEncoding.Compressed, sig));
52
52
  this._stxTransaction.auth.spendingCondition.fields = this._stxTransaction.auth.spendingCondition.fields.concat(authFields);
53
53
  }
54
54
  if (signatures.length > 0) {
@@ -57,7 +57,7 @@ class Transaction extends sdk_core_1.BaseTransaction {
57
57
  }
58
58
  get signature() {
59
59
  if (this._stxTransaction && this._stxTransaction.auth.spendingCondition) {
60
- if (transactions_1.isSingleSig(this._stxTransaction.auth.spendingCondition)) {
60
+ if ((0, transactions_1.isSingleSig)(this._stxTransaction.auth.spendingCondition)) {
61
61
  return [this._stxTransaction.auth.spendingCondition.signature.data];
62
62
  }
63
63
  else {
@@ -80,7 +80,7 @@ class Transaction extends sdk_core_1.BaseTransaction {
80
80
  const result = {
81
81
  id: this._stxTransaction.txid(),
82
82
  fee: this._stxTransaction.auth.getFee().toString(10),
83
- from: utils_1.getTxSenderAddress(this._stxTransaction),
83
+ from: (0, utils_1.getTxSenderAddress)(this._stxTransaction),
84
84
  nonce: this.getNonce(),
85
85
  payload: this.getPayloadData(),
86
86
  };
@@ -93,8 +93,8 @@ class Transaction extends sdk_core_1.BaseTransaction {
93
93
  payloadType: transactions_1.PayloadType.TokenTransfer,
94
94
  // result.payload.memo will be padded with \u0000 up to
95
95
  // MEMO_MAX_LENGTH_BYTES as defined in @stacks/transactions
96
- memo: utils_1.unpadMemo(payload.memo.content),
97
- to: transactions_1.addressToString({
96
+ memo: (0, utils_1.unpadMemo)(payload.memo.content),
97
+ to: (0, transactions_1.addressToString)({
98
98
  type: transactions_1.StacksMessageType.Address,
99
99
  version: payload.recipient.address.version,
100
100
  hash160: payload.recipient.address.hash160.toString(),
@@ -107,7 +107,7 @@ class Transaction extends sdk_core_1.BaseTransaction {
107
107
  const payload = this._stxTransaction.payload;
108
108
  const contractPayload = {
109
109
  payloadType: transactions_1.PayloadType.ContractCall,
110
- contractAddress: transactions_1.addressToString(payload.contractAddress),
110
+ contractAddress: (0, transactions_1.addressToString)(payload.contractAddress),
111
111
  contractName: payload.contractName.content,
112
112
  functionName: payload.functionName.content,
113
113
  functionArgs: payload.functionArgs.map(utils_1.stringifyCv),
@@ -153,9 +153,9 @@ class Transaction extends sdk_core_1.BaseTransaction {
153
153
  * @param rawTransaction
154
154
  */
155
155
  fromRawTransaction(rawTransaction) {
156
- const raw = utils_1.removeHexPrefix(rawTransaction);
156
+ const raw = (0, utils_1.removeHexPrefix)(rawTransaction);
157
157
  try {
158
- this._stxTransaction = transactions_1.deserializeTransaction(transactions_1.BufferReader.fromBuffer(Buffer.from(raw, 'hex')));
158
+ this._stxTransaction = (0, transactions_1.deserializeTransaction)(transactions_1.BufferReader.fromBuffer(Buffer.from(raw, 'hex')));
159
159
  }
160
160
  catch (e) {
161
161
  throw new sdk_core_1.ParseTransactionError('Error parsing the raw transaction');
@@ -196,7 +196,7 @@ class Transaction extends sdk_core_1.BaseTransaction {
196
196
  }
197
197
  else if (txJson.payload.payloadType === transactions_1.PayloadType.ContractCall) {
198
198
  if (txJson.payload.contractAddress === this._coinConfig.network.sendmanymemoContractAddress) {
199
- const sendParams = utils_1.functionArgsToSendParams(this.stxTransaction.payload.functionArgs);
199
+ const sendParams = (0, utils_1.functionArgsToSendParams)(this.stxTransaction.payload.functionArgs);
200
200
  const coin = this._coinConfig.name;
201
201
  const sum = sendParams.reduce((current, next) => current.add(new bn_js_1.default(next.amount)), new bn_js_1.default(0));
202
202
  this._outputs = sendParams.map((sendParam) => ({ address: sendParam.address, value: sendParam.amount, coin }));
@@ -222,4 +222,4 @@ class Transaction extends sdk_core_1.BaseTransaction {
222
222
  }
223
223
  }
224
224
  exports.Transaction = Transaction;
225
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  addressToString,\n  BufferReader,\n  createStacksPrivateKey,\n  createStacksPublicKey,\n  createTransactionAuthField,\n  deserializeTransaction,\n  isSingleSig,\n  MultiSigSpendingCondition,\n  PayloadType,\n  PubKeyEncoding,\n  StacksMessageType,\n  StacksTransaction,\n  TransactionSigner,\n} from '@stacks/transactions';\nimport { BaseCoin as CoinConfig, StacksNetwork } from '@bitgo-beta/statics';\nimport {\n  BaseKey,\n  BaseTransaction,\n  InvalidTransactionError,\n  NotSupported,\n  ParseTransactionError,\n  SigningError,\n  TransactionType,\n} from '@bitgo-beta/sdk-core';\nimport { SignatureData, StacksContractPayload, StacksTransactionPayload, TxData } from './iface';\nimport { functionArgsToSendParams, getTxSenderAddress, removeHexPrefix, stringifyCv, unpadMemo } from './utils';\nimport { KeyPair } from './keyPair';\nimport { ContractCallPayload } from '@stacks/transactions/dist/payload';\nimport BigNum from 'bn.js';\n\nexport class Transaction extends BaseTransaction {\n  private _stxTransaction: StacksTransaction;\n  protected _type: TransactionType;\n  private _sigHash: string;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /** @inheritdoc */\n  canSign(key: BaseKey): boolean {\n    return true;\n  }\n\n  async sign(keyPair: KeyPair[] | KeyPair, sigHash?: string): Promise<void> {\n    const keyPairs = keyPair instanceof Array ? keyPair : [keyPair];\n    const signer = new TransactionSigner(this._stxTransaction);\n    signer.checkOversign = false;\n    signer.sigHash = sigHash ?? this._sigHash ?? this._stxTransaction.verifyBegin();\n    for (const kp of keyPairs) {\n      const keys = kp.getKeys(kp.getCompressed());\n      if (!keys.prv) {\n        throw new SigningError('Missing private key');\n      }\n      const privKey = createStacksPrivateKey(keys.prv);\n      signer.signOrigin(privKey);\n      this._sigHash = signer.sigHash;\n    }\n  }\n\n  async appendOrigin(pubKeyString: string[] | string): Promise<void> {\n    const pubKeyStrings = pubKeyString instanceof Array ? pubKeyString : [pubKeyString];\n    const signer: TransactionSigner = new TransactionSigner(this._stxTransaction);\n    pubKeyStrings.forEach((pubKey) => {\n      signer.appendOrigin(createStacksPublicKey(pubKey));\n    });\n  }\n\n  async signWithSignatures(signature: SignatureData[] | SignatureData, isMultiSig: boolean): Promise<void> {\n    if (!signature) {\n      throw new SigningError('Missing signatures');\n    }\n    const signatures = signature instanceof Array ? signature : [signature];\n\n    if (!isMultiSig) {\n      this._stxTransaction = this._stxTransaction.createTxWithSignature(signatures[0].data);\n    } else {\n      const authFields = signatures.map((sig) => createTransactionAuthField(PubKeyEncoding.Compressed, sig));\n      (this._stxTransaction.auth.spendingCondition as MultiSigSpendingCondition).fields = (\n        this._stxTransaction.auth.spendingCondition as MultiSigSpendingCondition\n      ).fields.concat(authFields);\n    }\n    if (signatures.length > 0) {\n      this._sigHash = signatures[signatures.length - 1].sigHash;\n    }\n  }\n\n  get signature(): string[] {\n    if (this._stxTransaction && this._stxTransaction.auth.spendingCondition) {\n      if (isSingleSig(this._stxTransaction.auth.spendingCondition)) {\n        return [this._stxTransaction.auth.spendingCondition.signature.data];\n      } else {\n        const signatures: string[] = [];\n        this._stxTransaction.auth.spendingCondition.fields.forEach((field) => {\n          if (field.contents.type === StacksMessageType.MessageSignature) {\n            signatures.push(field.contents.data);\n          }\n        });\n        return signatures;\n      }\n    }\n    return [];\n  }\n\n  /** @inheritdoc */\n  toJson(): TxData {\n    if (!this._stxTransaction) {\n      throw new ParseTransactionError('Empty transaction');\n    }\n    const result: TxData = {\n      id: this._stxTransaction.txid(),\n      fee: this._stxTransaction.auth.getFee().toString(10),\n      from: getTxSenderAddress(this._stxTransaction),\n      nonce: this.getNonce(),\n      payload: this.getPayloadData(),\n    };\n    return result;\n  }\n\n  private getPayloadData(): StacksTransactionPayload | StacksContractPayload {\n    if (this._stxTransaction.payload.payloadType === PayloadType.TokenTransfer) {\n      const payload = this._stxTransaction.payload;\n      const txPayload: StacksTransactionPayload = {\n        payloadType: PayloadType.TokenTransfer,\n        // result.payload.memo will be padded with \\u0000 up to\n        // MEMO_MAX_LENGTH_BYTES as defined in @stacks/transactions\n        memo: unpadMemo(payload.memo.content),\n        to: addressToString({\n          type: StacksMessageType.Address,\n          version: payload.recipient.address.version,\n          hash160: payload.recipient.address.hash160.toString(),\n        }),\n        amount: payload.amount.toString(),\n      };\n      return txPayload;\n    } else if (this._stxTransaction.payload.payloadType === PayloadType.ContractCall) {\n      const payload = this._stxTransaction.payload;\n      const contractPayload: StacksContractPayload = {\n        payloadType: PayloadType.ContractCall,\n        contractAddress: addressToString(payload.contractAddress),\n        contractName: payload.contractName.content,\n        functionName: payload.functionName.content,\n        functionArgs: payload.functionArgs.map(stringifyCv),\n      };\n      return contractPayload;\n    } else {\n      throw new NotSupported('payload type not supported');\n    }\n  }\n\n  /**\n   * Return the length of a transaction.  This is needed to calculate\n   * the transaction fee.\n   *\n   * @returns {number} size in bytes of the serialized transaction\n   */\n  transactionSize(): number {\n    return this._stxTransaction.serialize().length;\n  }\n\n  toBroadcastFormat(): string {\n    if (!this._stxTransaction) {\n      throw new ParseTransactionError('Empty transaction');\n    }\n    return this._stxTransaction.serialize().toString('hex');\n  }\n\n  get stxTransaction(): StacksTransaction {\n    return this._stxTransaction;\n  }\n\n  set stxTransaction(t: StacksTransaction) {\n    this._stxTransaction = t;\n  }\n\n  private getNonce(): number {\n    if (this._stxTransaction.auth.spendingCondition) {\n      return Number(this._stxTransaction.auth.spendingCondition.nonce);\n    } else {\n      throw new InvalidTransactionError('spending condition is null');\n    }\n  }\n\n  /**\n   * Sets this transaction payload\n   *\n   * @param rawTransaction\n   */\n  fromRawTransaction(rawTransaction: string): void {\n    const raw = removeHexPrefix(rawTransaction);\n    try {\n      this._stxTransaction = deserializeTransaction(BufferReader.fromBuffer(Buffer.from(raw, 'hex')));\n    } catch (e) {\n      throw new ParseTransactionError('Error parsing the raw transaction');\n    }\n    this.loadInputsAndOutputs();\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   * Load the input and output data on this transaction using the transaction json\n   * if there are outputs.\n   */\n  loadInputsAndOutputs(): void {\n    const txJson = this.toJson();\n    if (txJson.payload.payloadType === PayloadType.TokenTransfer) {\n      if (txJson.payload.to && txJson.payload.amount) {\n        this._outputs = [\n          {\n            address: txJson.payload.to,\n            value: txJson.payload.amount,\n            coin: this._coinConfig.name,\n          },\n        ];\n\n        this._inputs = [\n          {\n            address: txJson.from,\n            value: txJson.payload.amount,\n            coin: this._coinConfig.name,\n          },\n        ];\n      }\n    } else if (txJson.payload.payloadType === PayloadType.ContractCall) {\n      if (txJson.payload.contractAddress === (this._coinConfig.network as StacksNetwork).sendmanymemoContractAddress) {\n        const sendParams = functionArgsToSendParams((this.stxTransaction.payload as ContractCallPayload).functionArgs);\n        const coin = this._coinConfig.name;\n        const sum: BigNum = sendParams.reduce((current, next) => current.add(new BigNum(next.amount)), new BigNum(0));\n        this._outputs = sendParams.map((sendParam) => ({ address: sendParam.address, value: sendParam.amount, coin }));\n        this._inputs = [{ address: txJson.from, value: sum.toString(), coin }];\n      } else {\n        this._outputs = [\n          {\n            address: txJson.payload.contractAddress,\n            value: '0',\n            coin: this._coinConfig.name,\n          },\n        ];\n\n        this._inputs = [\n          {\n            address: txJson.from,\n            value: '0',\n            coin: this._coinConfig.name,\n          },\n        ];\n      }\n    }\n  }\n}\n"]}
225
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  addressToString,\n  BufferReader,\n  createStacksPrivateKey,\n  createStacksPublicKey,\n  createTransactionAuthField,\n  deserializeTransaction,\n  isSingleSig,\n  MultiSigSpendingCondition,\n  PayloadType,\n  PubKeyEncoding,\n  StacksMessageType,\n  StacksTransaction,\n  TransactionSigner,\n} from '@stacks/transactions';\nimport { BaseCoin as CoinConfig, StacksNetwork } from '@bitgo-beta/statics';\nimport {\n  BaseKey,\n  BaseTransaction,\n  InvalidTransactionError,\n  NotSupported,\n  ParseTransactionError,\n  SigningError,\n  TransactionType,\n} from '@bitgo-beta/sdk-core';\nimport { SignatureData, StacksContractPayload, StacksTransactionPayload, TxData } from './iface';\nimport { functionArgsToSendParams, getTxSenderAddress, removeHexPrefix, stringifyCv, unpadMemo } from './utils';\nimport { KeyPair } from './keyPair';\nimport { ContractCallPayload } from '@stacks/transactions/dist/payload';\nimport BigNum from 'bn.js';\n\nexport class Transaction extends BaseTransaction {\n  private _stxTransaction: StacksTransaction;\n  protected _type: TransactionType;\n  private _sigHash: string;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /** @inheritdoc */\n  canSign(key: BaseKey): boolean {\n    return true;\n  }\n\n  async sign(keyPair: KeyPair[] | KeyPair, sigHash?: string): Promise<void> {\n    const keyPairs = keyPair instanceof Array ? keyPair : [keyPair];\n    const signer = new TransactionSigner(this._stxTransaction);\n    signer.checkOversign = false;\n    signer.sigHash = sigHash ?? this._sigHash ?? this._stxTransaction.verifyBegin();\n    for (const kp of keyPairs) {\n      const keys = kp.getKeys(kp.getCompressed());\n      if (!keys.prv) {\n        throw new SigningError('Missing private key');\n      }\n      const privKey = createStacksPrivateKey(keys.prv);\n      signer.signOrigin(privKey);\n      this._sigHash = signer.sigHash;\n    }\n  }\n\n  async appendOrigin(pubKeyString: string[] | string): Promise<void> {\n    const pubKeyStrings = pubKeyString instanceof Array ? pubKeyString : [pubKeyString];\n    const signer: TransactionSigner = new TransactionSigner(this._stxTransaction);\n    pubKeyStrings.forEach((pubKey) => {\n      signer.appendOrigin(createStacksPublicKey(pubKey));\n    });\n  }\n\n  async signWithSignatures(signature: SignatureData[] | SignatureData, isMultiSig: boolean): Promise<void> {\n    if (!signature) {\n      throw new SigningError('Missing signatures');\n    }\n    const signatures = signature instanceof Array ? signature : [signature];\n\n    if (!isMultiSig) {\n      this._stxTransaction = this._stxTransaction.createTxWithSignature(signatures[0].data);\n    } else {\n      const authFields = signatures.map((sig) => createTransactionAuthField(PubKeyEncoding.Compressed, sig));\n      (this._stxTransaction.auth.spendingCondition as MultiSigSpendingCondition).fields = (\n        this._stxTransaction.auth.spendingCondition as MultiSigSpendingCondition\n      ).fields.concat(authFields);\n    }\n    if (signatures.length > 0) {\n      this._sigHash = signatures[signatures.length - 1].sigHash;\n    }\n  }\n\n  get signature(): string[] {\n    if (this._stxTransaction && this._stxTransaction.auth.spendingCondition) {\n      if (isSingleSig(this._stxTransaction.auth.spendingCondition)) {\n        return [this._stxTransaction.auth.spendingCondition.signature.data];\n      } else {\n        const signatures: string[] = [];\n        this._stxTransaction.auth.spendingCondition.fields.forEach((field) => {\n          if (field.contents.type === StacksMessageType.MessageSignature) {\n            signatures.push(field.contents.data);\n          }\n        });\n        return signatures;\n      }\n    }\n    return [];\n  }\n\n  /** @inheritdoc */\n  toJson(): TxData {\n    if (!this._stxTransaction) {\n      throw new ParseTransactionError('Empty transaction');\n    }\n    const result: TxData = {\n      id: this._stxTransaction.txid(),\n      fee: this._stxTransaction.auth.getFee().toString(10),\n      from: getTxSenderAddress(this._stxTransaction),\n      nonce: this.getNonce(),\n      payload: this.getPayloadData(),\n    };\n    return result;\n  }\n\n  private getPayloadData(): StacksTransactionPayload | StacksContractPayload {\n    if (this._stxTransaction.payload.payloadType === PayloadType.TokenTransfer) {\n      const payload = this._stxTransaction.payload;\n      const txPayload: StacksTransactionPayload = {\n        payloadType: PayloadType.TokenTransfer,\n        // result.payload.memo will be padded with \\u0000 up to\n        // MEMO_MAX_LENGTH_BYTES as defined in @stacks/transactions\n        memo: unpadMemo(payload.memo.content),\n        to: addressToString({\n          type: StacksMessageType.Address,\n          version: payload.recipient.address.version,\n          hash160: payload.recipient.address.hash160.toString(),\n        }),\n        amount: payload.amount.toString(),\n      };\n      return txPayload;\n    } else if (this._stxTransaction.payload.payloadType === PayloadType.ContractCall) {\n      const payload = this._stxTransaction.payload;\n      const contractPayload: StacksContractPayload = {\n        payloadType: PayloadType.ContractCall,\n        contractAddress: addressToString(payload.contractAddress),\n        contractName: payload.contractName.content,\n        functionName: payload.functionName.content,\n        functionArgs: payload.functionArgs.map(stringifyCv),\n      };\n      return contractPayload;\n    } else {\n      throw new NotSupported('payload type not supported');\n    }\n  }\n\n  /**\n   * Return the length of a transaction.  This is needed to calculate\n   * the transaction fee.\n   *\n   * @returns {number} size in bytes of the serialized transaction\n   */\n  transactionSize(): number {\n    return this._stxTransaction.serialize().length;\n  }\n\n  toBroadcastFormat(): string {\n    if (!this._stxTransaction) {\n      throw new ParseTransactionError('Empty transaction');\n    }\n    return this._stxTransaction.serialize().toString('hex');\n  }\n\n  get stxTransaction(): StacksTransaction {\n    return this._stxTransaction;\n  }\n\n  set stxTransaction(t: StacksTransaction) {\n    this._stxTransaction = t;\n  }\n\n  private getNonce(): number {\n    if (this._stxTransaction.auth.spendingCondition) {\n      return Number(this._stxTransaction.auth.spendingCondition.nonce);\n    } else {\n      throw new InvalidTransactionError('spending condition is null');\n    }\n  }\n\n  /**\n   * Sets this transaction payload\n   *\n   * @param rawTransaction\n   */\n  fromRawTransaction(rawTransaction: string): void {\n    const raw = removeHexPrefix(rawTransaction);\n    try {\n      this._stxTransaction = deserializeTransaction(BufferReader.fromBuffer(Buffer.from(raw, 'hex')));\n    } catch (e) {\n      throw new ParseTransactionError('Error parsing the raw transaction');\n    }\n    this.loadInputsAndOutputs();\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   * Load the input and output data on this transaction using the transaction json\n   * if there are outputs.\n   */\n  loadInputsAndOutputs(): void {\n    const txJson = this.toJson();\n    if (txJson.payload.payloadType === PayloadType.TokenTransfer) {\n      if (txJson.payload.to && txJson.payload.amount) {\n        this._outputs = [\n          {\n            address: txJson.payload.to,\n            value: txJson.payload.amount,\n            coin: this._coinConfig.name,\n          },\n        ];\n\n        this._inputs = [\n          {\n            address: txJson.from,\n            value: txJson.payload.amount,\n            coin: this._coinConfig.name,\n          },\n        ];\n      }\n    } else if (txJson.payload.payloadType === PayloadType.ContractCall) {\n      if (txJson.payload.contractAddress === (this._coinConfig.network as StacksNetwork).sendmanymemoContractAddress) {\n        const sendParams = functionArgsToSendParams((this.stxTransaction.payload as ContractCallPayload).functionArgs);\n        const coin = this._coinConfig.name;\n        const sum: BigNum = sendParams.reduce((current, next) => current.add(new BigNum(next.amount)), new BigNum(0));\n        this._outputs = sendParams.map((sendParam) => ({ address: sendParam.address, value: sendParam.amount, coin }));\n        this._inputs = [{ address: txJson.from, value: sum.toString(), coin }];\n      } else {\n        this._outputs = [\n          {\n            address: txJson.payload.contractAddress,\n            value: '0',\n            coin: this._coinConfig.name,\n          },\n        ];\n\n        this._inputs = [\n          {\n            address: txJson.from,\n            value: '0',\n            coin: this._coinConfig.name,\n          },\n        ];\n      }\n    }\n  }\n}\n"]}
@@ -43,13 +43,13 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
43
43
  this.nonce(txData.nonce);
44
44
  let sigHash = tx.stxTransaction.verifyBegin();
45
45
  const authType = tx.stxTransaction.auth.authType ? tx.stxTransaction.auth.authType : transactions_1.AuthType.Standard;
46
- if (transactions_1.isSingleSig(tx.stxTransaction.auth.spendingCondition)) {
46
+ if ((0, transactions_1.isSingleSig)(tx.stxTransaction.auth.spendingCondition)) {
47
47
  this._numberSignatures = 1;
48
- if (tx.stxTransaction.auth.spendingCondition.signature.data !== transactions_1.emptyMessageSignature().data) {
48
+ if (tx.stxTransaction.auth.spendingCondition.signature.data !== (0, transactions_1.emptyMessageSignature)().data) {
49
49
  const signature = tx.stxTransaction.auth.spendingCondition.signature;
50
- sigHash = transactions_1.makeSigHashPreSign(sigHash, authType, new bn_js_1.default(this._fee.fee), new bn_js_1.default(this._nonce));
50
+ sigHash = (0, transactions_1.makeSigHashPreSign)(sigHash, authType, new bn_js_1.default(this._fee.fee), new bn_js_1.default(this._nonce));
51
51
  this._signatures.push({ ...signature, index: 0, sigHash });
52
- this._fromPubKeys = [transactions_1.publicKeyFromSignature(sigHash, signature)];
52
+ this._fromPubKeys = [(0, transactions_1.publicKeyFromSignature)(sigHash, signature)];
53
53
  }
54
54
  }
55
55
  else {
@@ -57,7 +57,7 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
57
57
  tx.stxTransaction.auth.spendingCondition.fields.forEach((field, index) => {
58
58
  if (field.contents.type === transactions_1.StacksMessageType.MessageSignature) {
59
59
  const signature = field.contents;
60
- const nextVerify = transactions_1.nextVerification(sigHash, authType, new bn_js_1.default(this._fee.fee), new bn_js_1.default(this._nonce), transactions_1.PubKeyEncoding.Compressed, // useless param as Compressed is hardcoded in stacks lib
60
+ const nextVerify = (0, transactions_1.nextVerification)(sigHash, authType, new bn_js_1.default(this._fee.fee), new bn_js_1.default(this._nonce), transactions_1.PubKeyEncoding.Compressed, // useless param as Compressed is hardcoded in stacks lib
61
61
  signature);
62
62
  sigHash = nextVerify.nextSigHash;
63
63
  this._signatures.push({ ...signature, index, sigHash });
@@ -73,7 +73,7 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
73
73
  fromImplementation(rawTransaction) {
74
74
  const tx = new transaction_1.Transaction(this._coinConfig);
75
75
  this.validateRawTransaction(rawTransaction);
76
- const stackstransaction = transactions_1.deserializeTransaction(transactions_1.BufferReader.fromBuffer(Buffer.from(utils_1.removeHexPrefix(rawTransaction), 'hex')));
76
+ const stackstransaction = (0, transactions_1.deserializeTransaction)(transactions_1.BufferReader.fromBuffer(Buffer.from((0, utils_1.removeHexPrefix)(rawTransaction), 'hex')));
77
77
  tx.stxTransaction = stackstransaction;
78
78
  this.initBuilder(tx);
79
79
  return this.transaction;
@@ -108,7 +108,7 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
108
108
  this.checkDuplicatedKeys(key);
109
109
  let prv = key.key;
110
110
  if (prv.startsWith('xprv')) {
111
- const rawPrv = sdk_core_1.xprvToRawPrv(prv);
111
+ const rawPrv = (0, sdk_core_1.xprvToRawPrv)(prv);
112
112
  prv = new keyPair_1.KeyPair({ prv: rawPrv }).getKeys(true).prv;
113
113
  }
114
114
  const signer = new keyPair_1.KeyPair({ prv: prv });
@@ -160,7 +160,7 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
160
160
  const pubKeys = senderPubKey instanceof Array ? senderPubKey : [senderPubKey];
161
161
  this._fromPubKeys = [];
162
162
  pubKeys.forEach((key) => {
163
- if (utils_1.isValidPublicKey(key)) {
163
+ if ((0, utils_1.isValidPublicKey)(key)) {
164
164
  this._fromPubKeys.push(key);
165
165
  }
166
166
  else {
@@ -176,7 +176,7 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
176
176
  * @returns {TransactionBuilder} This transaction builder
177
177
  */
178
178
  memo(memo) {
179
- if (!utils_1.isValidMemo(memo)) {
179
+ if (!(0, utils_1.isValidMemo)(memo)) {
180
180
  throw new sdk_core_1.BuildTransactionError('Memo is too long');
181
181
  }
182
182
  this._memo = memo;
@@ -196,7 +196,7 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
196
196
  // region Validators
197
197
  /** @inheritdoc */
198
198
  validateAddress(address, addressFormat) {
199
- if (!utils_1.isValidAddress(address.address)) {
199
+ if (!(0, utils_1.isValidAddress)(address.address)) {
200
200
  throw new sdk_core_1.BuildTransactionError('Invalid address ' + address.address);
201
201
  }
202
202
  }
@@ -213,7 +213,7 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
213
213
  throw new sdk_core_1.InvalidTransactionError('Raw transaction is empty');
214
214
  }
215
215
  try {
216
- transactions_1.deserializeTransaction(transactions_1.BufferReader.fromBuffer(Buffer.from(utils_1.removeHexPrefix(rawTransaction), 'hex')));
216
+ (0, transactions_1.deserializeTransaction)(transactions_1.BufferReader.fromBuffer(Buffer.from((0, utils_1.removeHexPrefix)(rawTransaction), 'hex')));
217
217
  }
218
218
  catch (e) {
219
219
  throw new sdk_core_1.ParseTransactionError('There was an error parsing the raw transaction');
@@ -260,4 +260,4 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
260
260
  }
261
261
  }
262
262
  exports.TransactionBuilder = TransactionBuilder;
263
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transactionBuilder.js","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import BigNumber from 'bignumber.js';\nimport BigNum from 'bn.js';\nimport { BaseCoin as CoinConfig, NetworkType } from '@bitgo-beta/statics';\nimport {\n  AuthType,\n  BufferReader,\n  deserializeTransaction,\n  emptyMessageSignature,\n  isSingleSig,\n  makeSigHashPreSign,\n  nextVerification,\n  publicKeyFromSignature,\n  StacksMessageType,\n  PubKeyEncoding,\n} from '@stacks/transactions';\nimport { StacksNetwork, StacksTestnet, StacksMainnet } from '@stacks/network';\nimport {\n  BaseAddress,\n  BaseFee,\n  BaseKey,\n  BaseTransactionBuilder,\n  BuildTransactionError,\n  InvalidParameterValueError,\n  InvalidTransactionError,\n  ParseTransactionError,\n  SigningError,\n  xprvToRawPrv,\n} from '@bitgo-beta/sdk-core';\nimport { Transaction } from './transaction';\nimport { KeyPair } from './keyPair';\nimport { SignatureData } from './iface';\nimport { isValidAddress, removeHexPrefix, isValidMemo, isValidPublicKey } from './utils';\nimport { ANCHOR_MODE, DEFAULT_MULTISIG_SIG_NUMBER } from './constants';\n\nexport abstract class TransactionBuilder extends BaseTransactionBuilder {\n  private _transaction: Transaction;\n  protected _anchorMode: number;\n  protected _fee: BaseFee;\n  protected _nonce: number;\n  protected _memo: string;\n  protected _numberSignatures: number;\n  protected _multiSignerKeyPairs: KeyPair[];\n  protected _signatures: SignatureData[];\n  protected _network: StacksNetwork;\n  protected _fromPubKeys: string[];\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._anchorMode = ANCHOR_MODE;\n    this._multiSignerKeyPairs = [];\n    this._fromPubKeys = [];\n    this._signatures = [];\n    this._numberSignatures = DEFAULT_MULTISIG_SIG_NUMBER;\n    this._network = _coinConfig.network.type === NetworkType.MAINNET ? new StacksMainnet() : new StacksTestnet();\n    this._transaction = new Transaction(_coinConfig);\n  }\n\n  /**\n   * Initialize the transaction builder fields using the decoded transaction data\n   *\n   * @param {Transaction} tx the transaction data\n   */\n  initBuilder(tx: Transaction): void {\n    this.transaction = tx;\n    // check if it is signed or unsigned tx\n    if (tx.stxTransaction.auth.spendingCondition === undefined) {\n      throw new InvalidTransactionError('spending condition cannot be undefined');\n    }\n    const txData = tx.toJson();\n    this.fee({ fee: txData.fee.toString() });\n    this.nonce(txData.nonce);\n    let sigHash = tx.stxTransaction.verifyBegin();\n\n    const authType = tx.stxTransaction.auth.authType ? tx.stxTransaction.auth.authType : AuthType.Standard;\n    if (isSingleSig(tx.stxTransaction.auth.spendingCondition)) {\n      this._numberSignatures = 1;\n      if (tx.stxTransaction.auth.spendingCondition.signature.data !== emptyMessageSignature().data) {\n        const signature = tx.stxTransaction.auth.spendingCondition.signature;\n        sigHash = makeSigHashPreSign(sigHash, authType, new BigNum(this._fee.fee), new BigNum(this._nonce));\n        this._signatures.push({ ...signature, index: 0, sigHash });\n        this._fromPubKeys = [publicKeyFromSignature(sigHash, signature)];\n      }\n    } else {\n      this._numberSignatures = tx.stxTransaction.auth.spendingCondition.signaturesRequired;\n      tx.stxTransaction.auth.spendingCondition.fields.forEach((field, index) => {\n        if (field.contents.type === StacksMessageType.MessageSignature) {\n          const signature = field.contents;\n          const nextVerify = nextVerification(\n            sigHash,\n            authType,\n            new BigNum(this._fee.fee),\n            new BigNum(this._nonce),\n            PubKeyEncoding.Compressed, // useless param as Compressed is hardcoded in stacks lib\n            signature\n          );\n          sigHash = nextVerify.nextSigHash;\n          this._signatures.push({ ...signature, index, sigHash });\n          this._fromPubKeys.push(nextVerify.pubKey.data.toString('hex'));\n        } else {\n          this._fromPubKeys.push(field.contents.data.toString('hex'));\n        }\n      });\n    }\n  }\n\n  /** @inheritdoc */\n  protected fromImplementation(rawTransaction: string): Transaction {\n    const tx = new Transaction(this._coinConfig);\n    this.validateRawTransaction(rawTransaction);\n    const stackstransaction = deserializeTransaction(\n      BufferReader.fromBuffer(Buffer.from(removeHexPrefix(rawTransaction), 'hex'))\n    );\n    tx.stxTransaction = stackstransaction;\n    this.initBuilder(tx);\n    return this.transaction;\n  }\n\n  // region Base Builder\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    const isMultiSig: boolean = this._fromPubKeys.length > 1;\n    this._transaction.stxTransaction.setFee(new BigNum(this._fee.fee));\n    this._transaction.stxTransaction.setNonce(new BigNum(this._nonce));\n\n    for (let index = 0; index < this._fromPubKeys.length; index++) {\n      const pubKey = this._fromPubKeys[index];\n      const signature = this.getSignature(pubKey, index);\n      if (signature) {\n        await this.transaction.signWithSignatures(signature, isMultiSig);\n      } else {\n        const prvKey = this.getPrivateKey(pubKey, index);\n        if (prvKey) {\n          await this.transaction.sign(prvKey);\n        } else if (isMultiSig) {\n          await this.transaction.appendOrigin(pubKey);\n        }\n      }\n    }\n\n    this._transaction.loadInputsAndOutputs();\n    return this._transaction;\n  }\n\n  private getSignature = (_: string, index: number): SignatureData | undefined =>\n    this._signatures.find((s) => s.index === index);\n  private getPrivateKey = (pubKey: string, _: number): KeyPair | undefined =>\n    this._multiSignerKeyPairs.find((kp) => kp.getKeys(true).pub === pubKey || kp.getKeys().pub === pubKey);\n\n  /** @inheritdoc */\n  protected signImplementation(key: BaseKey): Transaction {\n    this.checkDuplicatedKeys(key);\n    let prv = key.key;\n    if (prv.startsWith('xprv')) {\n      const rawPrv = xprvToRawPrv(prv);\n      prv = new KeyPair({ prv: rawPrv }).getKeys(true).prv;\n    }\n    const signer = new KeyPair({ prv: prv });\n\n    // Signing the transaction is an operation that relies on all the data being set,\n    // so we set the source here and leave the actual signing for the build step\n    this._multiSignerKeyPairs.push(signer);\n    const publicKey = signer.getKeys(signer.getCompressed()).pub;\n    if (!this._fromPubKeys.includes(publicKey)) {\n      this._fromPubKeys.push(publicKey);\n    }\n    return this.transaction;\n  }\n\n  /** @inheritdoc */\n  protected get transaction(): Transaction {\n    return this._transaction;\n  }\n\n  /** @inheritdoc */\n  protected set transaction(transaction: Transaction) {\n    this._transaction = transaction;\n  }\n\n  /**\n   * Validates that the given key is not already in this._multiSignerKeyPairs\n   *\n   * @param {BaseKey} key - The key to check\n   */\n  private checkDuplicatedKeys(key: BaseKey) {\n    this._multiSignerKeyPairs.forEach((_sourceKeyPair) => {\n      if (_sourceKeyPair.getKeys().prv === key.key) {\n        throw new SigningError('Repeated sign: ' + key.key);\n      }\n    });\n  }\n\n  /**\n   * Set the transaction fees\n   *\n   * @param {BaseFee} fee The maximum gas to pay\n   * @returns {TransactionBuilder} This transaction builder\n   */\n  fee(fee: BaseFee): this {\n    this.validateValue(new BigNumber(fee.fee));\n    this._fee = fee;\n    return this;\n  }\n\n  nonce(n: number): this {\n    this._nonce = n;\n    return this;\n  }\n\n  fromPubKey(senderPubKey: string | string[]): this {\n    const pubKeys = senderPubKey instanceof Array ? senderPubKey : [senderPubKey];\n    this._fromPubKeys = [];\n    pubKeys.forEach((key) => {\n      if (isValidPublicKey(key)) {\n        this._fromPubKeys.push(key);\n      } else {\n        throw new InvalidParameterValueError('Invalid public key');\n      }\n    });\n    return this;\n  }\n\n  /**\n   *  Set the memo\n   *\n   * @param {string} memo\n   * @returns {TransactionBuilder} This transaction builder\n   */\n  memo(memo: string): this {\n    if (!isValidMemo(memo)) {\n      throw new BuildTransactionError('Memo is too long');\n    }\n    this._memo = memo;\n    return this;\n  }\n\n  /**\n   *  Set the number of signatures for multi-sig\n   *\n   * @param {number} numSigns\n   * @returns {TransactionBuilder} This transaction builder\n   */\n  numberSignatures(numSigns: number): this {\n    this.validateValue(new BigNumber(numSigns));\n    this._numberSignatures = numSigns;\n    return this;\n  }\n\n  // region Validators\n  /** @inheritdoc */\n  validateAddress(address: BaseAddress, addressFormat?: string): void {\n    if (!isValidAddress(address.address)) {\n      throw new BuildTransactionError('Invalid address ' + address.address);\n    }\n  }\n\n  /** @inheritdoc */\n  validateKey(key: BaseKey): void {\n    const keyPair = new KeyPair({ prv: key.key });\n    if (!keyPair.getKeys().prv) {\n      throw new BuildTransactionError('Invalid key');\n    }\n  }\n\n  /** @inheritdoc */\n  validateRawTransaction(rawTransaction: string): void {\n    if (!rawTransaction) {\n      throw new InvalidTransactionError('Raw transaction is empty');\n    }\n    try {\n      deserializeTransaction(BufferReader.fromBuffer(Buffer.from(removeHexPrefix(rawTransaction), 'hex')));\n    } catch (e) {\n      throw new ParseTransactionError('There was an error parsing the raw transaction');\n    }\n  }\n\n  /** @inheritdoc */\n  validateTransaction(transaction?: Transaction): void {\n    this.validateFee();\n    this.validateNonce();\n  }\n\n  /** @inheritdoc */\n  validateValue(value: BigNumber): void {\n    if (value.isLessThan(0)) {\n      throw new BuildTransactionError('Value cannot be less than zero');\n    }\n  }\n\n  /**\n   * Validates that the fee field is defined\n   */\n  private validateFee(): void {\n    if (this._fee === undefined) {\n      throw new BuildTransactionError('Invalid transaction: missing fee');\n    }\n    try {\n      this.validateValue(new BigNumber(this._fee.fee));\n    } catch (e) {\n      throw new BuildTransactionError('Invalid fee');\n    }\n  }\n\n  /**\n   * Validates that nonce is defined\n   */\n  private validateNonce(): void {\n    if (this._nonce === undefined) {\n      throw new BuildTransactionError('Invalid transaction: missing nonce');\n    }\n    try {\n      this.validateValue(new BigNumber(this._nonce));\n    } catch (e) {\n      throw new BuildTransactionError(`Invalid nonce ${this._nonce}`);\n    }\n  }\n}\n"]}
263
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transactionBuilder.js","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import BigNumber from 'bignumber.js';\nimport BigNum from 'bn.js';\nimport { BaseCoin as CoinConfig, NetworkType } from '@bitgo-beta/statics';\nimport {\n  AuthType,\n  BufferReader,\n  deserializeTransaction,\n  emptyMessageSignature,\n  isSingleSig,\n  makeSigHashPreSign,\n  nextVerification,\n  publicKeyFromSignature,\n  StacksMessageType,\n  PubKeyEncoding,\n} from '@stacks/transactions';\nimport { StacksNetwork, StacksTestnet, StacksMainnet } from '@stacks/network';\nimport {\n  BaseAddress,\n  BaseFee,\n  BaseKey,\n  BaseTransactionBuilder,\n  BuildTransactionError,\n  InvalidParameterValueError,\n  InvalidTransactionError,\n  ParseTransactionError,\n  SigningError,\n  xprvToRawPrv,\n} from '@bitgo-beta/sdk-core';\nimport { Transaction } from './transaction';\nimport { KeyPair } from './keyPair';\nimport { SignatureData } from './iface';\nimport { isValidAddress, removeHexPrefix, isValidMemo, isValidPublicKey } from './utils';\nimport { ANCHOR_MODE, DEFAULT_MULTISIG_SIG_NUMBER } from './constants';\n\nexport abstract class TransactionBuilder extends BaseTransactionBuilder {\n  private _transaction: Transaction;\n  protected _anchorMode: number;\n  protected _fee: BaseFee;\n  protected _nonce: number;\n  protected _memo: string;\n  protected _numberSignatures: number;\n  protected _multiSignerKeyPairs: KeyPair[];\n  protected _signatures: SignatureData[];\n  protected _network: StacksNetwork;\n  protected _fromPubKeys: string[];\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._anchorMode = ANCHOR_MODE;\n    this._multiSignerKeyPairs = [];\n    this._fromPubKeys = [];\n    this._signatures = [];\n    this._numberSignatures = DEFAULT_MULTISIG_SIG_NUMBER;\n    this._network = _coinConfig.network.type === NetworkType.MAINNET ? new StacksMainnet() : new StacksTestnet();\n    this._transaction = new Transaction(_coinConfig);\n  }\n\n  /**\n   * Initialize the transaction builder fields using the decoded transaction data\n   *\n   * @param {Transaction} tx the transaction data\n   */\n  initBuilder(tx: Transaction): void {\n    this.transaction = tx;\n    // check if it is signed or unsigned tx\n    if (tx.stxTransaction.auth.spendingCondition === undefined) {\n      throw new InvalidTransactionError('spending condition cannot be undefined');\n    }\n    const txData = tx.toJson();\n    this.fee({ fee: txData.fee.toString() });\n    this.nonce(txData.nonce);\n    let sigHash = tx.stxTransaction.verifyBegin();\n\n    const authType = tx.stxTransaction.auth.authType ? tx.stxTransaction.auth.authType : AuthType.Standard;\n    if (isSingleSig(tx.stxTransaction.auth.spendingCondition)) {\n      this._numberSignatures = 1;\n      if (tx.stxTransaction.auth.spendingCondition.signature.data !== emptyMessageSignature().data) {\n        const signature = tx.stxTransaction.auth.spendingCondition.signature;\n        sigHash = makeSigHashPreSign(sigHash, authType, new BigNum(this._fee.fee), new BigNum(this._nonce));\n        this._signatures.push({ ...signature, index: 0, sigHash });\n        this._fromPubKeys = [publicKeyFromSignature(sigHash, signature)];\n      }\n    } else {\n      this._numberSignatures = tx.stxTransaction.auth.spendingCondition.signaturesRequired;\n      tx.stxTransaction.auth.spendingCondition.fields.forEach((field, index) => {\n        if (field.contents.type === StacksMessageType.MessageSignature) {\n          const signature = field.contents;\n          const nextVerify = nextVerification(\n            sigHash,\n            authType,\n            new BigNum(this._fee.fee),\n            new BigNum(this._nonce),\n            PubKeyEncoding.Compressed, // useless param as Compressed is hardcoded in stacks lib\n            signature\n          );\n          sigHash = nextVerify.nextSigHash;\n          this._signatures.push({ ...signature, index, sigHash });\n          this._fromPubKeys.push(nextVerify.pubKey.data.toString('hex'));\n        } else {\n          this._fromPubKeys.push(field.contents.data.toString('hex'));\n        }\n      });\n    }\n  }\n\n  /** @inheritdoc */\n  protected fromImplementation(rawTransaction: string): Transaction {\n    const tx = new Transaction(this._coinConfig);\n    this.validateRawTransaction(rawTransaction);\n    const stackstransaction = deserializeTransaction(\n      BufferReader.fromBuffer(Buffer.from(removeHexPrefix(rawTransaction), 'hex'))\n    );\n    tx.stxTransaction = stackstransaction;\n    this.initBuilder(tx);\n    return this.transaction;\n  }\n\n  // region Base Builder\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    const isMultiSig: boolean = this._fromPubKeys.length > 1;\n    this._transaction.stxTransaction.setFee(new BigNum(this._fee.fee));\n    this._transaction.stxTransaction.setNonce(new BigNum(this._nonce));\n\n    for (let index = 0; index < this._fromPubKeys.length; index++) {\n      const pubKey = this._fromPubKeys[index];\n      const signature = this.getSignature(pubKey, index);\n      if (signature) {\n        await this.transaction.signWithSignatures(signature, isMultiSig);\n      } else {\n        const prvKey = this.getPrivateKey(pubKey, index);\n        if (prvKey) {\n          await this.transaction.sign(prvKey);\n        } else if (isMultiSig) {\n          await this.transaction.appendOrigin(pubKey);\n        }\n      }\n    }\n\n    this._transaction.loadInputsAndOutputs();\n    return this._transaction;\n  }\n\n  private getSignature = (_: string, index: number): SignatureData | undefined =>\n    this._signatures.find((s) => s.index === index);\n  private getPrivateKey = (pubKey: string, _: number): KeyPair | undefined =>\n    this._multiSignerKeyPairs.find((kp) => kp.getKeys(true).pub === pubKey || kp.getKeys().pub === pubKey);\n\n  /** @inheritdoc */\n  protected signImplementation(key: BaseKey): Transaction {\n    this.checkDuplicatedKeys(key);\n    let prv = key.key;\n    if (prv.startsWith('xprv')) {\n      const rawPrv = xprvToRawPrv(prv);\n      prv = new KeyPair({ prv: rawPrv }).getKeys(true).prv;\n    }\n    const signer = new KeyPair({ prv: prv });\n\n    // Signing the transaction is an operation that relies on all the data being set,\n    // so we set the source here and leave the actual signing for the build step\n    this._multiSignerKeyPairs.push(signer);\n    const publicKey = signer.getKeys(signer.getCompressed()).pub;\n    if (!this._fromPubKeys.includes(publicKey)) {\n      this._fromPubKeys.push(publicKey);\n    }\n    return this.transaction;\n  }\n\n  /** @inheritdoc */\n  protected get transaction(): Transaction {\n    return this._transaction;\n  }\n\n  /** @inheritdoc */\n  protected set transaction(transaction: Transaction) {\n    this._transaction = transaction;\n  }\n\n  /**\n   * Validates that the given key is not already in this._multiSignerKeyPairs\n   *\n   * @param {BaseKey} key - The key to check\n   */\n  private checkDuplicatedKeys(key: BaseKey) {\n    this._multiSignerKeyPairs.forEach((_sourceKeyPair) => {\n      if (_sourceKeyPair.getKeys().prv === key.key) {\n        throw new SigningError('Repeated sign: ' + key.key);\n      }\n    });\n  }\n\n  /**\n   * Set the transaction fees\n   *\n   * @param {BaseFee} fee The maximum gas to pay\n   * @returns {TransactionBuilder} This transaction builder\n   */\n  fee(fee: BaseFee): this {\n    this.validateValue(new BigNumber(fee.fee));\n    this._fee = fee;\n    return this;\n  }\n\n  nonce(n: number): this {\n    this._nonce = n;\n    return this;\n  }\n\n  fromPubKey(senderPubKey: string | string[]): this {\n    const pubKeys = senderPubKey instanceof Array ? senderPubKey : [senderPubKey];\n    this._fromPubKeys = [];\n    pubKeys.forEach((key) => {\n      if (isValidPublicKey(key)) {\n        this._fromPubKeys.push(key);\n      } else {\n        throw new InvalidParameterValueError('Invalid public key');\n      }\n    });\n    return this;\n  }\n\n  /**\n   *  Set the memo\n   *\n   * @param {string} memo\n   * @returns {TransactionBuilder} This transaction builder\n   */\n  memo(memo: string): this {\n    if (!isValidMemo(memo)) {\n      throw new BuildTransactionError('Memo is too long');\n    }\n    this._memo = memo;\n    return this;\n  }\n\n  /**\n   *  Set the number of signatures for multi-sig\n   *\n   * @param {number} numSigns\n   * @returns {TransactionBuilder} This transaction builder\n   */\n  numberSignatures(numSigns: number): this {\n    this.validateValue(new BigNumber(numSigns));\n    this._numberSignatures = numSigns;\n    return this;\n  }\n\n  // region Validators\n  /** @inheritdoc */\n  validateAddress(address: BaseAddress, addressFormat?: string): void {\n    if (!isValidAddress(address.address)) {\n      throw new BuildTransactionError('Invalid address ' + address.address);\n    }\n  }\n\n  /** @inheritdoc */\n  validateKey(key: BaseKey): void {\n    const keyPair = new KeyPair({ prv: key.key });\n    if (!keyPair.getKeys().prv) {\n      throw new BuildTransactionError('Invalid key');\n    }\n  }\n\n  /** @inheritdoc */\n  validateRawTransaction(rawTransaction: string): void {\n    if (!rawTransaction) {\n      throw new InvalidTransactionError('Raw transaction is empty');\n    }\n    try {\n      deserializeTransaction(BufferReader.fromBuffer(Buffer.from(removeHexPrefix(rawTransaction), 'hex')));\n    } catch (e) {\n      throw new ParseTransactionError('There was an error parsing the raw transaction');\n    }\n  }\n\n  /** @inheritdoc */\n  validateTransaction(transaction?: Transaction): void {\n    this.validateFee();\n    this.validateNonce();\n  }\n\n  /** @inheritdoc */\n  validateValue(value: BigNumber): void {\n    if (value.isLessThan(0)) {\n      throw new BuildTransactionError('Value cannot be less than zero');\n    }\n  }\n\n  /**\n   * Validates that the fee field is defined\n   */\n  private validateFee(): void {\n    if (this._fee === undefined) {\n      throw new BuildTransactionError('Invalid transaction: missing fee');\n    }\n    try {\n      this.validateValue(new BigNumber(this._fee.fee));\n    } catch (e) {\n      throw new BuildTransactionError('Invalid fee');\n    }\n  }\n\n  /**\n   * Validates that nonce is defined\n   */\n  private validateNonce(): void {\n    if (this._nonce === undefined) {\n      throw new BuildTransactionError('Invalid transaction: missing nonce');\n    }\n    try {\n      this.validateValue(new BigNumber(this._nonce));\n    } catch (e) {\n      throw new BuildTransactionError(`Invalid nonce ${this._nonce}`);\n    }\n  }\n}\n"]}