@bitgo-beta/sdk-coin-stx 1.4.3-alpha.24 → 1.4.3-alpha.240
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +487 -0
- package/dist/src/index.js +23 -9
- package/dist/src/lib/abstractContractBuilder.js +2 -2
- package/dist/src/lib/constants.d.ts +1 -1
- package/dist/src/lib/constants.d.ts.map +1 -1
- package/dist/src/lib/constants.js +2 -2
- package/dist/src/lib/contractBuilder.js +10 -10
- package/dist/src/lib/index.js +23 -9
- package/dist/src/lib/keyPair.js +11 -12
- package/dist/src/lib/sendmanyBuilder.js +11 -11
- package/dist/src/lib/transaction.js +13 -14
- package/dist/src/lib/transactionBuilder.js +12 -12
- package/dist/src/lib/transactionBuilderFactory.js +2 -2
- package/dist/src/lib/transferBuilder.js +4 -4
- package/dist/src/lib/utils.d.ts +0 -1
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +69 -57
- package/dist/src/stx.d.ts +0 -1
- package/dist/src/stx.d.ts.map +1 -1
- package/dist/src/stx.js +7 -3
- package/dist/src/tstx.js +1 -1
- package/package.json +8 -8
|
@@ -27,7 +27,7 @@ class ContractBuilder extends abstractContractBuilder_1.AbstractContractBuilder
|
|
|
27
27
|
* @returns {ContractBuilder} the builder with the new parameter set
|
|
28
28
|
*/
|
|
29
29
|
contractAddress(address) {
|
|
30
|
-
if (!utils_1.isValidAddress(address)) {
|
|
30
|
+
if (!(0, utils_1.isValidAddress)(address)) {
|
|
31
31
|
throw new sdk_core_1.InvalidParameterValueError('Invalid address');
|
|
32
32
|
}
|
|
33
33
|
if (!_1.Utils.isValidContractAddress(address, this._coinConfig.network)) {
|
|
@@ -47,7 +47,7 @@ class ContractBuilder extends abstractContractBuilder_1.AbstractContractBuilder
|
|
|
47
47
|
throw new sdk_core_1.InvalidParameterValueError('Invalid name');
|
|
48
48
|
}
|
|
49
49
|
if (name !== constants_1.CONTRACT_NAME_STAKING && name !== constants_1.CONTRACT_NAME_SENDMANY) {
|
|
50
|
-
throw new sdk_core_1.InvalidParameterValueError('Only pox and send-many-memo contracts supported');
|
|
50
|
+
throw new sdk_core_1.InvalidParameterValueError('Only pox-4 and send-many-memo contracts supported');
|
|
51
51
|
}
|
|
52
52
|
this._contractName = name;
|
|
53
53
|
return this;
|
|
@@ -84,10 +84,10 @@ class ContractBuilder extends abstractContractBuilder_1.AbstractContractBuilder
|
|
|
84
84
|
switch (arg.type) {
|
|
85
85
|
case 'optional':
|
|
86
86
|
if (arg.val === undefined) {
|
|
87
|
-
return transactions_1.noneCV();
|
|
87
|
+
return (0, transactions_1.noneCV)();
|
|
88
88
|
}
|
|
89
89
|
else {
|
|
90
|
-
return transactions_1.someCV(this.parseCv(arg.val));
|
|
90
|
+
return (0, transactions_1.someCV)(this.parseCv(arg.val));
|
|
91
91
|
}
|
|
92
92
|
case 'tuple':
|
|
93
93
|
if (arg.val instanceof Array) {
|
|
@@ -95,22 +95,22 @@ class ContractBuilder extends abstractContractBuilder_1.AbstractContractBuilder
|
|
|
95
95
|
arg.val.forEach((a) => {
|
|
96
96
|
data[a.key] = this.parseCv({ type: a.type, val: a.val });
|
|
97
97
|
});
|
|
98
|
-
return transactions_1.tupleCV(data);
|
|
98
|
+
return (0, transactions_1.tupleCV)(data);
|
|
99
99
|
}
|
|
100
100
|
throw new sdk_core_1.InvalidParameterValueError('tuple require Array val');
|
|
101
101
|
case 'buffer':
|
|
102
102
|
if (arg.val instanceof Buffer) {
|
|
103
|
-
return transactions_1.bufferCV(arg.val);
|
|
103
|
+
return (0, transactions_1.bufferCV)(arg.val);
|
|
104
104
|
}
|
|
105
105
|
const nval = Number(arg.val);
|
|
106
106
|
if (nval) {
|
|
107
|
-
return transactions_1.bufferCV(Buffer.of(nval));
|
|
107
|
+
return (0, transactions_1.bufferCV)(Buffer.of(nval));
|
|
108
108
|
}
|
|
109
|
-
return transactions_1.bufferCVFromString(arg.val);
|
|
109
|
+
return (0, transactions_1.bufferCVFromString)(arg.val);
|
|
110
110
|
default:
|
|
111
|
-
return transactions_1.encodeClarityValue(arg.type, arg.val);
|
|
111
|
+
return (0, transactions_1.encodeClarityValue)(arg.type, arg.val);
|
|
112
112
|
}
|
|
113
113
|
}
|
|
114
114
|
}
|
|
115
115
|
exports.ContractBuilder = ContractBuilder;
|
|
116
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contractBuilder.js","sourceRoot":"","sources":["../../../src/lib/contractBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig, StacksNetwork as BitgoStacksNetwork } from '@bitgo-beta/statics';\nimport {\n  bufferCV,\n  bufferCVFromString,\n  ClarityAbiType,\n  ClarityType,\n  ClarityValue,\n  encodeClarityValue,\n  noneCV,\n  someCV,\n  tupleCV,\n} from '@stacks/transactions';\nimport { InvalidParameterValueError } from '@bitgo-beta/sdk-core';\nimport { Transaction } from './transaction';\nimport { isValidAddress } from './utils';\nimport { ClarityValueJson } from './iface';\nimport { Utils } from '.';\nimport { CONTRACT_NAME_SENDMANY, CONTRACT_NAME_STAKING } from './constants';\nimport { AbstractContractBuilder } from './abstractContractBuilder';\n\nexport class ContractBuilder extends AbstractContractBuilder {\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  initBuilder(tx: Transaction): void {\n    super.initBuilder(tx);\n    // Retro compatibility, checks parameters.\n    this.contractAddress(this._contractAddress);\n    this.contractName(this._contractName);\n    this.functionName(this._functionName);\n    this.functionArgs(this._functionArgs);\n  }\n\n  // region Contract fields\n  /**\n   * Set the contract address\n   *\n   * @param {string} address the address deployed the contract\n   * @returns {ContractBuilder} the builder with the new parameter set\n   */\n  contractAddress(address: string): this {\n    if (!isValidAddress(address)) {\n      throw new InvalidParameterValueError('Invalid address');\n    }\n    if (!Utils.isValidContractAddress(address, this._coinConfig.network as BitgoStacksNetwork)) {\n      throw new InvalidParameterValueError('Invalid contract address');\n    }\n    this._contractAddress = address;\n    return this;\n  }\n\n  /**\n   * Set the contract name\n   *\n   * @param {string} name name of contract\n   * @returns {ContractBuilder} the builder with the new parameter set\n   */\n  contractName(name: string): this {\n    if (name.length === 0) {\n      throw new InvalidParameterValueError('Invalid name');\n    }\n    if (name !== CONTRACT_NAME_STAKING && name !== CONTRACT_NAME_SENDMANY) {\n      throw new InvalidParameterValueError('Only pox-4 and send-many-memo contracts supported');\n    }\n    this._contractName = name;\n    return this;\n  }\n\n  /**\n   * Set the function name in contract\n   *\n   * @param {string} name name of function\n   * @returns {ContractBuilder} the builder with the new parameter set\n   */\n  functionName(name: string): this {\n    if (name.length === 0) {\n      throw new InvalidParameterValueError('Invalid name');\n    }\n    if (!Utils.isValidContractFunctionName(name)) {\n      throw new InvalidParameterValueError(`${name} is not supported contract function name`);\n    }\n    this._functionName = name;\n    return this;\n  }\n\n  functionArgs(args: ClarityValueJson[] | ClarityValue[]): this {\n    this._functionArgs = args.map((arg) => {\n      if (!ClarityType[arg.type]) {\n        return this.parseCv(arg);\n      } else {\n        // got direct clarity value after deserialization in fromImplementation\n        return arg;\n      }\n    });\n    return this;\n  }\n\n  private parseCv(arg: ClarityValueJson): ClarityValue {\n    switch (arg.type) {\n      case 'optional':\n        if (arg.val === undefined) {\n          return noneCV();\n        } else {\n          return someCV(this.parseCv(arg.val));\n        }\n      case 'tuple':\n        if (arg.val instanceof Array) {\n          const data = {};\n          arg.val.forEach((a) => {\n            data[a.key] = this.parseCv({ type: a.type, val: a.val });\n          });\n          return tupleCV(data);\n        }\n        throw new InvalidParameterValueError('tuple require Array val');\n      case 'buffer':\n        if (arg.val instanceof Buffer) {\n          return bufferCV(arg.val);\n        }\n        const nval = Number(arg.val);\n        if (nval) {\n          return bufferCV(Buffer.of(nval));\n        }\n        return bufferCVFromString(arg.val);\n      default:\n        return encodeClarityValue(arg.type as ClarityAbiType, arg.val);\n    }\n  }\n}\n"]}
|
package/dist/src/lib/index.js
CHANGED
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -14,13 +18,23 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
|
|
|
14
18
|
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
15
19
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
16
20
|
};
|
|
17
|
-
var __importStar = (this && this.__importStar) || function (
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
};
|
|
21
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
22
|
+
var ownKeys = function(o) {
|
|
23
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
24
|
+
var ar = [];
|
|
25
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
26
|
+
return ar;
|
|
27
|
+
};
|
|
28
|
+
return ownKeys(o);
|
|
29
|
+
};
|
|
30
|
+
return function (mod) {
|
|
31
|
+
if (mod && mod.__esModule) return mod;
|
|
32
|
+
var result = {};
|
|
33
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
34
|
+
__setModuleDefault(result, mod);
|
|
35
|
+
return result;
|
|
36
|
+
};
|
|
37
|
+
})();
|
|
24
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
39
|
exports.Utils = exports.AddressHashMode = exports.AddressVersion = void 0;
|
|
26
40
|
var transactions_1 = require("@stacks/transactions");
|
|
@@ -30,4 +44,4 @@ __exportStar(require("./keyPair"), exports);
|
|
|
30
44
|
__exportStar(require("./transaction"), exports);
|
|
31
45
|
__exportStar(require("./transactionBuilderFactory"), exports);
|
|
32
46
|
exports.Utils = __importStar(require("./utils"));
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHFEQUF1RTtBQUE5RCw4R0FBQSxjQUFjLE9BQUE7QUFBRSwrR0FBQSxlQUFlLE9BQUE7QUFDeEMsNENBQTBCO0FBQzFCLGdEQUE4QjtBQUM5Qiw4REFBNEM7QUFDNUMsaURBQWlDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgQWRkcmVzc1ZlcnNpb24sIEFkZHJlc3NIYXNoTW9kZSB9IGZyb20gJ0BzdGFja3MvdHJhbnNhY3Rpb25zJztcbmV4cG9ydCAqIGZyb20gJy4va2V5UGFpcic7XG5leHBvcnQgKiBmcm9tICcuL3RyYW5zYWN0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vdHJhbnNhY3Rpb25CdWlsZGVyRmFjdG9yeSc7XG5leHBvcnQgKiBhcyBVdGlscyBmcm9tICcuL3V0aWxzJztcbiJdfQ==
|
package/dist/src/lib/keyPair.js
CHANGED
|
@@ -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 {
|
|
@@ -84,8 +84,7 @@ class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
|
|
|
84
84
|
* @returns {DefaultKeys} The keys in the protocol default key format
|
|
85
85
|
*/
|
|
86
86
|
getKeys(compressed = false) {
|
|
87
|
-
|
|
88
|
-
let prv = (_a = this.getPrivateKey()) === null || _a === void 0 ? void 0 : _a.toString('hex');
|
|
87
|
+
let prv = this.getPrivateKey()?.toString('hex');
|
|
89
88
|
if (prv && compressed) {
|
|
90
89
|
prv += '01';
|
|
91
90
|
}
|
|
@@ -113,8 +112,8 @@ class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
|
|
|
113
112
|
* @returns {string} The public address
|
|
114
113
|
*/
|
|
115
114
|
getSTXAddress(compressed = false, network = transactions_1.TransactionVersion.Mainnet) {
|
|
116
|
-
return transactions_1.getAddressFromPublicKey(this.getKeys(compressed).pub, network);
|
|
115
|
+
return (0, transactions_1.getAddressFromPublicKey)(this.getKeys(compressed).pub, network);
|
|
117
116
|
}
|
|
118
117
|
}
|
|
119
118
|
exports.KeyPair = KeyPair;
|
|
120
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
119
|
+
//# 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,
|
|
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"]}
|
|
@@ -17,17 +17,16 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
17
17
|
return true;
|
|
18
18
|
}
|
|
19
19
|
async sign(keyPair, sigHash) {
|
|
20
|
-
var _a;
|
|
21
20
|
const keyPairs = keyPair instanceof Array ? keyPair : [keyPair];
|
|
22
21
|
const signer = new transactions_1.TransactionSigner(this._stxTransaction);
|
|
23
22
|
signer.checkOversign = false;
|
|
24
|
-
signer.sigHash =
|
|
23
|
+
signer.sigHash = sigHash ?? this._sigHash ?? this._stxTransaction.verifyBegin();
|
|
25
24
|
for (const kp of keyPairs) {
|
|
26
25
|
const keys = kp.getKeys(kp.getCompressed());
|
|
27
26
|
if (!keys.prv) {
|
|
28
27
|
throw new sdk_core_1.SigningError('Missing private key');
|
|
29
28
|
}
|
|
30
|
-
const privKey = transactions_1.createStacksPrivateKey(keys.prv);
|
|
29
|
+
const privKey = (0, transactions_1.createStacksPrivateKey)(keys.prv);
|
|
31
30
|
signer.signOrigin(privKey);
|
|
32
31
|
this._sigHash = signer.sigHash;
|
|
33
32
|
}
|
|
@@ -36,7 +35,7 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
36
35
|
const pubKeyStrings = pubKeyString instanceof Array ? pubKeyString : [pubKeyString];
|
|
37
36
|
const signer = new transactions_1.TransactionSigner(this._stxTransaction);
|
|
38
37
|
pubKeyStrings.forEach((pubKey) => {
|
|
39
|
-
signer.appendOrigin(transactions_1.createStacksPublicKey(pubKey));
|
|
38
|
+
signer.appendOrigin((0, transactions_1.createStacksPublicKey)(pubKey));
|
|
40
39
|
});
|
|
41
40
|
}
|
|
42
41
|
async signWithSignatures(signature, isMultiSig) {
|
|
@@ -48,7 +47,7 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
48
47
|
this._stxTransaction = this._stxTransaction.createTxWithSignature(signatures[0].data);
|
|
49
48
|
}
|
|
50
49
|
else {
|
|
51
|
-
const authFields = signatures.map((sig) => transactions_1.createTransactionAuthField(transactions_1.PubKeyEncoding.Compressed, sig));
|
|
50
|
+
const authFields = signatures.map((sig) => (0, transactions_1.createTransactionAuthField)(transactions_1.PubKeyEncoding.Compressed, sig));
|
|
52
51
|
this._stxTransaction.auth.spendingCondition.fields = this._stxTransaction.auth.spendingCondition.fields.concat(authFields);
|
|
53
52
|
}
|
|
54
53
|
if (signatures.length > 0) {
|
|
@@ -57,7 +56,7 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
57
56
|
}
|
|
58
57
|
get signature() {
|
|
59
58
|
if (this._stxTransaction && this._stxTransaction.auth.spendingCondition) {
|
|
60
|
-
if (transactions_1.isSingleSig(this._stxTransaction.auth.spendingCondition)) {
|
|
59
|
+
if ((0, transactions_1.isSingleSig)(this._stxTransaction.auth.spendingCondition)) {
|
|
61
60
|
return [this._stxTransaction.auth.spendingCondition.signature.data];
|
|
62
61
|
}
|
|
63
62
|
else {
|
|
@@ -80,7 +79,7 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
80
79
|
const result = {
|
|
81
80
|
id: this._stxTransaction.txid(),
|
|
82
81
|
fee: this._stxTransaction.auth.getFee().toString(10),
|
|
83
|
-
from: utils_1.getTxSenderAddress(this._stxTransaction),
|
|
82
|
+
from: (0, utils_1.getTxSenderAddress)(this._stxTransaction),
|
|
84
83
|
nonce: this.getNonce(),
|
|
85
84
|
payload: this.getPayloadData(),
|
|
86
85
|
};
|
|
@@ -93,8 +92,8 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
93
92
|
payloadType: transactions_1.PayloadType.TokenTransfer,
|
|
94
93
|
// result.payload.memo will be padded with \u0000 up to
|
|
95
94
|
// MEMO_MAX_LENGTH_BYTES as defined in @stacks/transactions
|
|
96
|
-
memo: utils_1.unpadMemo(payload.memo.content),
|
|
97
|
-
to: transactions_1.addressToString({
|
|
95
|
+
memo: (0, utils_1.unpadMemo)(payload.memo.content),
|
|
96
|
+
to: (0, transactions_1.addressToString)({
|
|
98
97
|
type: transactions_1.StacksMessageType.Address,
|
|
99
98
|
version: payload.recipient.address.version,
|
|
100
99
|
hash160: payload.recipient.address.hash160.toString(),
|
|
@@ -107,7 +106,7 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
107
106
|
const payload = this._stxTransaction.payload;
|
|
108
107
|
const contractPayload = {
|
|
109
108
|
payloadType: transactions_1.PayloadType.ContractCall,
|
|
110
|
-
contractAddress: transactions_1.addressToString(payload.contractAddress),
|
|
109
|
+
contractAddress: (0, transactions_1.addressToString)(payload.contractAddress),
|
|
111
110
|
contractName: payload.contractName.content,
|
|
112
111
|
functionName: payload.functionName.content,
|
|
113
112
|
functionArgs: payload.functionArgs.map(utils_1.stringifyCv),
|
|
@@ -153,9 +152,9 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
153
152
|
* @param rawTransaction
|
|
154
153
|
*/
|
|
155
154
|
fromRawTransaction(rawTransaction) {
|
|
156
|
-
const raw = utils_1.removeHexPrefix(rawTransaction);
|
|
155
|
+
const raw = (0, utils_1.removeHexPrefix)(rawTransaction);
|
|
157
156
|
try {
|
|
158
|
-
this._stxTransaction = transactions_1.deserializeTransaction(transactions_1.BufferReader.fromBuffer(Buffer.from(raw, 'hex')));
|
|
157
|
+
this._stxTransaction = (0, transactions_1.deserializeTransaction)(transactions_1.BufferReader.fromBuffer(Buffer.from(raw, 'hex')));
|
|
159
158
|
}
|
|
160
159
|
catch (e) {
|
|
161
160
|
throw new sdk_core_1.ParseTransactionError('Error parsing the raw transaction');
|
|
@@ -196,7 +195,7 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
196
195
|
}
|
|
197
196
|
else if (txJson.payload.payloadType === transactions_1.PayloadType.ContractCall) {
|
|
198
197
|
if (txJson.payload.contractAddress === this._coinConfig.network.sendmanymemoContractAddress) {
|
|
199
|
-
const sendParams = utils_1.functionArgsToSendParams(this.stxTransaction.payload.functionArgs);
|
|
198
|
+
const sendParams = (0, utils_1.functionArgsToSendParams)(this.stxTransaction.payload.functionArgs);
|
|
200
199
|
const coin = this._coinConfig.name;
|
|
201
200
|
const sum = sendParams.reduce((current, next) => current.add(new bn_js_1.default(next.amount)), new bn_js_1.default(0));
|
|
202
201
|
this._outputs = sendParams.map((sendParam) => ({ address: sendParam.address, value: sendParam.amount, coin }));
|
|
@@ -222,4 +221,4 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
222
221
|
}
|
|
223
222
|
}
|
|
224
223
|
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"]}
|
|
224
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":";;;;;;AAAA,uDAc8B;AAE9B,mDAQ8B;AAE9B,mCAAgH;AAGhH,kDAA2B;AAE3B,MAAa,WAAY,SAAQ,0BAAe;IAK9C,YAAY,WAAiC;QAC3C,KAAK,CAAC,WAAW,CAAC,CAAC;IACrB,CAAC;IAED,kBAAkB;IAClB,OAAO,CAAC,GAAY;QAClB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,OAA4B,EAAE,OAAgB;QACvD,MAAM,QAAQ,GAAG,OAAO,YAAY,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;QAChE,MAAM,MAAM,GAAG,IAAI,gCAAiB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAC3D,MAAM,CAAC,aAAa,GAAG,KAAK,CAAC;QAC7B,MAAM,CAAC,OAAO,GAAG,OAAO,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE,CAAC;QAChF,KAAK,MAAM,EAAE,IAAI,QAAQ,EAAE,CAAC;YAC1B,MAAM,IAAI,GAAG,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC,CAAC;YAC5C,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;gBACd,MAAM,IAAI,uBAAY,CAAC,qBAAqB,CAAC,CAAC;YAChD,CAAC;YACD,MAAM,OAAO,GAAG,IAAA,qCAAsB,EAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACjD,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;YAC3B,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC;QACjC,CAAC;IACH,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,YAA+B;QAChD,MAAM,aAAa,GAAG,YAAY,YAAY,KAAK,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC;QACpF,MAAM,MAAM,GAAsB,IAAI,gCAAiB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAC9E,aAAa,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;YAC/B,MAAM,CAAC,YAAY,CAAC,IAAA,oCAAqB,EAAC,MAAM,CAAC,CAAC,CAAC;QACrD,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,kBAAkB,CAAC,SAA0C,EAAE,UAAmB;QACtF,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,MAAM,IAAI,uBAAY,CAAC,oBAAoB,CAAC,CAAC;QAC/C,CAAC;QACD,MAAM,UAAU,GAAG,SAAS,YAAY,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;QAExE,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,qBAAqB,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QACxF,CAAC;aAAM,CAAC;YACN,MAAM,UAAU,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAA,yCAA0B,EAAC,6BAAc,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC,CAAC;YACtG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,iBAA+C,CAAC,MAAM,GAC/E,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,iBAC3B,CAAC,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QAC9B,CAAC;QACD,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC1B,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC;QAC5D,CAAC;IACH,CAAC;IAED,IAAI,SAAS;QACX,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACxE,IAAI,IAAA,0BAAW,EAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,iBAAiB,CAAC,EAAE,CAAC;gBAC7D,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YACtE,CAAC;iBAAM,CAAC;gBACN,MAAM,UAAU,GAAa,EAAE,CAAC;gBAChC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;oBACnE,IAAI,KAAK,CAAC,QAAQ,CAAC,IAAI,KAAK,gCAAiB,CAAC,gBAAgB,EAAE,CAAC;wBAC/D,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;oBACvC,CAAC;gBACH,CAAC,CAAC,CAAC;gBACH,OAAO,UAAU,CAAC;YACpB,CAAC;QACH,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,kBAAkB;IAClB,MAAM;QACJ,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;YAC1B,MAAM,IAAI,gCAAqB,CAAC,mBAAmB,CAAC,CAAC;QACvD,CAAC;QACD,MAAM,MAAM,GAAW;YACrB,EAAE,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE;YAC/B,GAAG,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC;YACpD,IAAI,EAAE,IAAA,0BAAkB,EAAC,IAAI,CAAC,eAAe,CAAC;YAC9C,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE;YACtB,OAAO,EAAE,IAAI,CAAC,cAAc,EAAE;SAC/B,CAAC;QACF,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,cAAc;QACpB,IAAI,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,WAAW,KAAK,0BAAW,CAAC,aAAa,EAAE,CAAC;YAC3E,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC;YAC7C,MAAM,SAAS,GAA6B;gBAC1C,WAAW,EAAE,0BAAW,CAAC,aAAa;gBACtC,uDAAuD;gBACvD,2DAA2D;gBAC3D,IAAI,EAAE,IAAA,iBAAS,EAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC;gBACrC,EAAE,EAAE,IAAA,8BAAe,EAAC;oBAClB,IAAI,EAAE,gCAAiB,CAAC,OAAO;oBAC/B,OAAO,EAAE,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO;oBAC1C,OAAO,EAAE,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,EAAE;iBACtD,CAAC;gBACF,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE;aAClC,CAAC;YACF,OAAO,SAAS,CAAC;QACnB,CAAC;aAAM,IAAI,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,WAAW,KAAK,0BAAW,CAAC,YAAY,EAAE,CAAC;YACjF,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC;YAC7C,MAAM,eAAe,GAA0B;gBAC7C,WAAW,EAAE,0BAAW,CAAC,YAAY;gBACrC,eAAe,EAAE,IAAA,8BAAe,EAAC,OAAO,CAAC,eAAe,CAAC;gBACzD,YAAY,EAAE,OAAO,CAAC,YAAY,CAAC,OAAO;gBAC1C,YAAY,EAAE,OAAO,CAAC,YAAY,CAAC,OAAO;gBAC1C,YAAY,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,CAAC,mBAAW,CAAC;aACpD,CAAC;YACF,OAAO,eAAe,CAAC;QACzB,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,uBAAY,CAAC,4BAA4B,CAAC,CAAC;QACvD,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,eAAe;QACb,OAAO,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC;IACjD,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;YAC1B,MAAM,IAAI,gCAAqB,CAAC,mBAAmB,CAAC,CAAC;QACvD,CAAC;QACD,OAAO,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC1D,CAAC;IAED,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAED,IAAI,cAAc,CAAC,CAAoB;QACrC,IAAI,CAAC,eAAe,GAAG,CAAC,CAAC;IAC3B,CAAC;IAEO,QAAQ;QACd,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAChD,OAAO,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;QACnE,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,kCAAuB,CAAC,4BAA4B,CAAC,CAAC;QAClE,CAAC;IACH,CAAC;IAED;;;;OAIG;IACH,kBAAkB,CAAC,cAAsB;QACvC,MAAM,GAAG,GAAG,IAAA,uBAAe,EAAC,cAAc,CAAC,CAAC;QAC5C,IAAI,CAAC;YACH,IAAI,CAAC,eAAe,GAAG,IAAA,qCAAsB,EAAC,2BAAY,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;QAClG,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,MAAM,IAAI,gCAAqB,CAAC,mCAAmC,CAAC,CAAC;QACvE,CAAC;QACD,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAED;;;;OAIG;IACH,kBAAkB,CAAC,eAAgC;QACjD,IAAI,CAAC,KAAK,GAAG,eAAe,CAAC;IAC/B,CAAC;IAED;;;OAGG;IACH,oBAAoB;QAClB,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QAC7B,IAAI,MAAM,CAAC,OAAO,CAAC,WAAW,KAAK,0BAAW,CAAC,aAAa,EAAE,CAAC;YAC7D,IAAI,MAAM,CAAC,OAAO,CAAC,EAAE,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;gBAC/C,IAAI,CAAC,QAAQ,GAAG;oBACd;wBACE,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,EAAE;wBAC1B,KAAK,EAAE,MAAM,CAAC,OAAO,CAAC,MAAM;wBAC5B,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI;qBAC5B;iBACF,CAAC;gBAEF,IAAI,CAAC,OAAO,GAAG;oBACb;wBACE,OAAO,EAAE,MAAM,CAAC,IAAI;wBACpB,KAAK,EAAE,MAAM,CAAC,OAAO,CAAC,MAAM;wBAC5B,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI;qBAC5B;iBACF,CAAC;YACJ,CAAC;QACH,CAAC;aAAM,IAAI,MAAM,CAAC,OAAO,CAAC,WAAW,KAAK,0BAAW,CAAC,YAAY,EAAE,CAAC;YACnE,IAAI,MAAM,CAAC,OAAO,CAAC,eAAe,KAAM,IAAI,CAAC,WAAW,CAAC,OAAyB,CAAC,2BAA2B,EAAE,CAAC;gBAC/G,MAAM,UAAU,GAAG,IAAA,gCAAwB,EAAE,IAAI,CAAC,cAAc,CAAC,OAA+B,CAAC,YAAY,CAAC,CAAC;gBAC/G,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;gBACnC,MAAM,GAAG,GAAW,UAAU,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,eAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,eAAM,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC9G,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,SAAS,CAAC,OAAO,EAAE,KAAK,EAAE,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;gBAC/G,IAAI,CAAC,OAAO,GAAG,CAAC,EAAE,OAAO,EAAE,MAAM,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,CAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC;YACzE,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,QAAQ,GAAG;oBACd;wBACE,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,eAAe;wBACvC,KAAK,EAAE,GAAG;wBACV,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI;qBAC5B;iBACF,CAAC;gBAEF,IAAI,CAAC,OAAO,GAAG;oBACb;wBACE,OAAO,EAAE,MAAM,CAAC,IAAI;wBACpB,KAAK,EAAE,GAAG;wBACV,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI;qBAC5B;iBACF,CAAC;YACJ,CAAC;QACH,CAAC;IACH,CAAC;CACF;AAnOD,kCAmOC","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"]}
|