@bitgo-beta/sdk-coin-sol 2.2.3-alpha.9 → 2.4.2

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.
Files changed (41) hide show
  1. package/CHANGELOG.md +68 -0
  2. package/dist/src/index.d.ts +1 -0
  3. package/dist/src/index.d.ts.map +1 -1
  4. package/dist/src/index.js +2 -1
  5. package/dist/src/lib/ataInitializationBuilder.d.ts +2 -12
  6. package/dist/src/lib/ataInitializationBuilder.d.ts.map +1 -1
  7. package/dist/src/lib/ataInitializationBuilder.js +11 -37
  8. package/dist/src/lib/constants.d.ts +13 -1
  9. package/dist/src/lib/constants.d.ts.map +1 -1
  10. package/dist/src/lib/constants.js +17 -2
  11. package/dist/src/lib/iface.d.ts +6 -0
  12. package/dist/src/lib/iface.d.ts.map +1 -1
  13. package/dist/src/lib/iface.js +5 -1
  14. package/dist/src/lib/instructionParamsFactory.d.ts.map +1 -1
  15. package/dist/src/lib/instructionParamsFactory.js +82 -12
  16. package/dist/src/lib/solInstructionFactory.js +35 -6
  17. package/dist/src/lib/stakingDeactivateBuilder.d.ts +22 -0
  18. package/dist/src/lib/stakingDeactivateBuilder.d.ts.map +1 -1
  19. package/dist/src/lib/stakingDeactivateBuilder.js +43 -1
  20. package/dist/src/lib/tokenTransferBuilder.d.ts +14 -3
  21. package/dist/src/lib/tokenTransferBuilder.d.ts.map +1 -1
  22. package/dist/src/lib/tokenTransferBuilder.js +53 -6
  23. package/dist/src/lib/transaction.d.ts +5 -0
  24. package/dist/src/lib/transaction.d.ts.map +1 -1
  25. package/dist/src/lib/transaction.js +38 -8
  26. package/dist/src/lib/transactionBuilder.d.ts +8 -0
  27. package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
  28. package/dist/src/lib/transactionBuilder.js +19 -1
  29. package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
  30. package/dist/src/lib/transactionBuilderFactory.js +2 -5
  31. package/dist/src/lib/utils.d.ts +3 -0
  32. package/dist/src/lib/utils.d.ts.map +1 -1
  33. package/dist/src/lib/utils.js +35 -6
  34. package/dist/src/register.d.ts +3 -0
  35. package/dist/src/register.d.ts.map +1 -0
  36. package/dist/src/register.js +15 -0
  37. package/dist/src/sol.js +3 -3
  38. package/package.json +6 -6
  39. package/dist/src/lib/ataInitializationTransaction.d.ts +0 -14
  40. package/dist/src/lib/ataInitializationTransaction.d.ts.map +0 -1
  41. package/dist/src/lib/ataInitializationTransaction.js +0 -81
@@ -1,6 +1,7 @@
1
1
  import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
2
2
  import { TransactionType } from '@bitgo-beta/sdk-core';
3
3
  import { Transaction } from './transaction';
4
+ import { TokenAssociateRecipient } from './iface';
4
5
  import { TransactionBuilder } from './transactionBuilder';
5
6
  export interface SendParams {
6
7
  address: string;
@@ -9,18 +10,28 @@ export interface SendParams {
9
10
  }
10
11
  export declare class TokenTransferBuilder extends TransactionBuilder {
11
12
  private _sendParams;
13
+ private _createAtaParams;
12
14
  constructor(_coinConfig: Readonly<CoinConfig>);
13
15
  protected get transactionType(): TransactionType;
14
16
  initBuilder(tx: Transaction): void;
15
17
  /**
16
18
  * Set a transfer
17
19
  *
18
- * @param {string} fromAddress - the sender address
19
- * @param {string} amount - the amount sent
20
- * @param {string} tokenName - name of token that is intended to send
20
+ * @param {SendParams} params - params for the transfer
21
+ * @param {string} params.address - the receiver token address
22
+ * @param {string} params.amount - the amount sent
23
+ * @param {string} params.tokenName - name of token that is intended to send
21
24
  * @returns {TransactionBuilder} This transaction builder
22
25
  */
23
26
  send({ address, amount, tokenName }: SendParams): this;
27
+ /**
28
+ *
29
+ * @param {TokenAssociateRecipient} recipient - recipient of the associated token account creation
30
+ * @param {string} recipient.ownerAddress - owner of the associated token account
31
+ * @param {string} recipient.tokenName - name of the token that is intended to associate
32
+ * @returns {TransactionBuilder} This transaction builder
33
+ */
34
+ createAssociatedTokenAccount(recipient: TokenAssociateRecipient): this;
24
35
  /** @inheritdoc */
25
36
  protected buildImplementation(): Promise<Transaction>;
26
37
  }
@@ -1 +1 @@
1
- {"version":3,"file":"tokenTransferBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/tokenTransferBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAW,MAAM,qBAAqB,CAAC;AACtE,OAAO,EAAyB,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAC9E,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAM5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAE1D,MAAM,WAAW,UAAU;IACzB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;CACnB;AAID,qBAAa,oBAAqB,SAAQ,kBAAkB;IAC1D,OAAO,CAAC,WAAW,CAAoB;gBAE3B,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED,WAAW,CAAC,EAAE,EAAE,WAAW,GAAG,IAAI;IAgBlC;;;;;;;OAOG;IACH,IAAI,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,UAAU,GAAG,IAAI;IAatD,kBAAkB;cACF,mBAAmB,IAAI,OAAO,CAAC,WAAW,CAAC;CAsB5D"}
1
+ {"version":3,"file":"tokenTransferBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/tokenTransferBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAW,MAAM,qBAAqB,CAAC;AACtE,OAAO,EAAyB,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAC9E,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAU5C,OAAO,EAAW,uBAAuB,EAAiB,MAAM,SAAS,CAAC;AAE1E,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAG1D,MAAM,WAAW,UAAU;IACzB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;CACnB;AAID,qBAAa,oBAAqB,SAAQ,kBAAkB;IAC1D,OAAO,CAAC,WAAW,CAAoB;IACvC,OAAO,CAAC,gBAAgB,CAA4B;gBAExC,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAK7C,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED,WAAW,CAAC,EAAE,EAAE,WAAW,GAAG,IAAI;IAuBlC;;;;;;;;OAQG;IACH,IAAI,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,UAAU,GAAG,IAAI;IAatD;;;;;;OAMG;IACH,4BAA4B,CAAC,SAAS,EAAE,uBAAuB,GAAG,IAAI;IAYtE,kBAAkB;cACF,mBAAmB,IAAI,OAAO,CAAC,WAAW,CAAC;CA2C5D"}
@@ -10,11 +10,13 @@ const utils_1 = require("./utils");
10
10
  const constants_1 = require("./constants");
11
11
  const assert_1 = __importDefault(require("assert"));
12
12
  const transactionBuilder_1 = require("./transactionBuilder");
13
+ const lodash_1 = __importDefault(require("lodash"));
13
14
  const UNSIGNED_BIGINT_MAX = BigInt('18446744073709551615');
14
15
  class TokenTransferBuilder extends transactionBuilder_1.TransactionBuilder {
15
16
  constructor(_coinConfig) {
16
17
  super(_coinConfig);
17
18
  this._sendParams = [];
19
+ this._createAtaParams = [];
18
20
  }
19
21
  get transactionType() {
20
22
  return sdk_core_1.TransactionType.Send;
@@ -31,14 +33,22 @@ class TokenTransferBuilder extends transactionBuilder_1.TransactionBuilder {
31
33
  tokenName: transferInstruction.params.tokenName,
32
34
  });
33
35
  }
36
+ if (instruction.type === constants_1.InstructionBuilderTypes.CreateAssociatedTokenAccount) {
37
+ const ataInitInstruction = instruction;
38
+ this._createAtaParams.push({
39
+ ownerAddress: ataInitInstruction.params.ownerAddress,
40
+ tokenName: ataInitInstruction.params.tokenName,
41
+ });
42
+ }
34
43
  }
35
44
  }
36
45
  /**
37
46
  * Set a transfer
38
47
  *
39
- * @param {string} fromAddress - the sender address
40
- * @param {string} amount - the amount sent
41
- * @param {string} tokenName - name of token that is intended to send
48
+ * @param {SendParams} params - params for the transfer
49
+ * @param {string} params.address - the receiver token address
50
+ * @param {string} params.amount - the amount sent
51
+ * @param {string} params.tokenName - name of token that is intended to send
42
52
  * @returns {TransactionBuilder} This transaction builder
43
53
  */
44
54
  send({ address, amount, tokenName }) {
@@ -52,10 +62,27 @@ class TokenTransferBuilder extends transactionBuilder_1.TransactionBuilder {
52
62
  this._sendParams.push({ address, amount, tokenName: tokenName });
53
63
  return this;
54
64
  }
65
+ /**
66
+ *
67
+ * @param {TokenAssociateRecipient} recipient - recipient of the associated token account creation
68
+ * @param {string} recipient.ownerAddress - owner of the associated token account
69
+ * @param {string} recipient.tokenName - name of the token that is intended to associate
70
+ * @returns {TransactionBuilder} This transaction builder
71
+ */
72
+ createAssociatedTokenAccount(recipient) {
73
+ utils_1.validateOwnerAddress(recipient.ownerAddress);
74
+ const token = utils_1.getSolTokenFromTokenName(recipient.tokenName);
75
+ if (!token) {
76
+ throw new sdk_core_1.BuildTransactionError('Invalid token name, got: ' + recipient.tokenName);
77
+ }
78
+ utils_1.validateMintAddress(token.tokenAddress);
79
+ this._createAtaParams.push(recipient);
80
+ return this;
81
+ }
55
82
  /** @inheritdoc */
56
83
  async buildImplementation() {
57
84
  assert_1.default(this._sender, 'Sender must be set before building the transaction');
58
- this._instructionsData = await Promise.all(this._sendParams.map(async (sendParams) => {
85
+ const sendInstructions = await Promise.all(this._sendParams.map(async (sendParams) => {
59
86
  const coin = utils_1.getSolTokenFromTokenName(sendParams.tokenName);
60
87
  assert_1.default(coin instanceof statics_1.SolCoin);
61
88
  const sourceAddress = await utils_1.getAssociatedTokenAccountAddress(coin.tokenAddress, this._sender);
@@ -65,13 +92,33 @@ class TokenTransferBuilder extends transactionBuilder_1.TransactionBuilder {
65
92
  fromAddress: this._sender,
66
93
  toAddress: sendParams.address,
67
94
  amount: sendParams.amount,
68
- tokenName: coin === null || coin === void 0 ? void 0 : coin.name,
95
+ tokenName: coin.name,
69
96
  sourceAddress: sourceAddress,
70
97
  },
71
98
  };
72
99
  }));
100
+ const uniqueCreateAtaParams = lodash_1.default.uniqBy(this._createAtaParams, (recipient) => {
101
+ return recipient.ownerAddress + recipient.tokenName;
102
+ });
103
+ const createAtaInstructions = await Promise.all(uniqueCreateAtaParams.map(async (recipient) => {
104
+ const coin = utils_1.getSolTokenFromTokenName(recipient.tokenName);
105
+ assert_1.default(coin instanceof statics_1.SolCoin);
106
+ const recipientTokenAddress = await utils_1.getAssociatedTokenAccountAddress(coin.tokenAddress, recipient.ownerAddress);
107
+ return {
108
+ type: constants_1.InstructionBuilderTypes.CreateAssociatedTokenAccount,
109
+ params: {
110
+ ownerAddress: recipient.ownerAddress,
111
+ tokenName: coin.name,
112
+ mintAddress: coin.tokenAddress,
113
+ ataAddress: recipientTokenAddress,
114
+ payerAddress: this._sender,
115
+ },
116
+ };
117
+ }));
118
+ // order is important, createAtaInstructions must be before sendInstructions
119
+ this._instructionsData = [...createAtaInstructions, ...sendInstructions];
73
120
  return await super.buildImplementation();
74
121
  }
75
122
  }
76
123
  exports.TokenTransferBuilder = TokenTransferBuilder;
77
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9rZW5UcmFuc2ZlckJ1aWxkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL3Rva2VuVHJhbnNmZXJCdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLGlEQUFzRTtBQUN0RSxtREFBOEU7QUFFOUUsbUNBQXFIO0FBQ3JILDJDQUFzRDtBQUd0RCxvREFBNEI7QUFDNUIsNkRBQTBEO0FBUTFELE1BQU0sbUJBQW1CLEdBQUcsTUFBTSxDQUFDLHNCQUFzQixDQUFDLENBQUM7QUFFM0QsTUFBYSxvQkFBcUIsU0FBUSx1Q0FBa0I7SUFHMUQsWUFBWSxXQUFpQztRQUMzQyxLQUFLLENBQUMsV0FBVyxDQUFDLENBQUM7UUFIYixnQkFBVyxHQUFpQixFQUFFLENBQUM7SUFJdkMsQ0FBQztJQUVELElBQWMsZUFBZTtRQUMzQixPQUFPLDBCQUFlLENBQUMsSUFBSSxDQUFDO0lBQzlCLENBQUM7SUFFRCxXQUFXLENBQUMsRUFBZTtRQUN6QixLQUFLLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBRXRCLEtBQUssTUFBTSxXQUFXLElBQUksSUFBSSxDQUFDLGlCQUFpQixFQUFFO1lBQ2hELElBQUksV0FBVyxDQUFDLElBQUksS0FBSyxtQ0FBdUIsQ0FBQyxhQUFhLEVBQUU7Z0JBQzlELE1BQU0sbUJBQW1CLEdBQWtCLFdBQVcsQ0FBQztnQkFDdkQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUM7Z0JBQ3BELElBQUksQ0FBQyxJQUFJLENBQUM7b0JBQ1IsT0FBTyxFQUFFLG1CQUFtQixDQUFDLE1BQU0sQ0FBQyxTQUFTO29CQUM3QyxNQUFNLEVBQUUsbUJBQW1CLENBQUMsTUFBTSxDQUFDLE1BQU07b0JBQ3pDLFNBQVMsRUFBRSxtQkFBbUIsQ0FBQyxNQUFNLENBQUMsU0FBUztpQkFDaEQsQ0FBQyxDQUFDO2FBQ0o7U0FDRjtJQUNILENBQUM7SUFFRDs7Ozs7OztPQU9HO0lBQ0gsSUFBSSxDQUFDLEVBQUUsT0FBTyxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQWM7UUFDN0MsdUJBQWUsQ0FBQyxPQUFPLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDcEMsSUFBSSxDQUFDLE1BQU0sSUFBSSxDQUFDLHFCQUFhLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDckMsTUFBTSxJQUFJLGdDQUFxQixDQUFDLGtDQUFrQyxHQUFHLE1BQU0sQ0FBQyxDQUFDO1NBQzlFO1FBQ0QsSUFBSSxNQUFNLENBQUMsTUFBTSxDQUFDLEdBQUcsbUJBQW1CLEVBQUU7WUFDeEMsTUFBTSxJQUFJLGdDQUFxQixDQUFDLGdCQUFnQixNQUFNLDBCQUEwQixtQkFBbUIsRUFBRSxDQUFDLENBQUM7U0FDeEc7UUFFRCxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxDQUFDLENBQUM7UUFDakUsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsa0JBQWtCO0lBQ1IsS0FBSyxDQUFDLG1CQUFtQjtRQUNqQyxnQkFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsb0RBQW9ELENBQUMsQ0FBQztRQUMzRSxJQUFJLENBQUMsaUJBQWlCLEdBQUcsTUFBTSxPQUFPLENBQUMsR0FBRyxDQUN4QyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsVUFBc0IsRUFBMEIsRUFBRTtZQUM1RSxNQUFNLElBQUksR0FBRyxnQ0FBd0IsQ0FBQyxVQUFVLENBQUMsU0FBVSxDQUFDLENBQUM7WUFDN0QsZ0JBQU0sQ0FBQyxJQUFJLFlBQVksaUJBQU8sQ0FBQyxDQUFDO1lBQ2hDLE1BQU0sYUFBYSxHQUFHLE1BQU0sd0NBQWdDLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDOUYsT0FBTztnQkFDTCxJQUFJLEVBQUUsbUNBQXVCLENBQUMsYUFBYTtnQkFDM0MsTUFBTSxFQUFFO29CQUNOLFdBQVcsRUFBRSxJQUFJLENBQUMsT0FBTztvQkFDekIsU0FBUyxFQUFFLFVBQVUsQ0FBQyxPQUFPO29CQUM3QixNQUFNLEVBQUUsVUFBVSxDQUFDLE1BQU07b0JBQ3pCLFNBQVMsRUFBRSxJQUFJLGFBQUosSUFBSSx1QkFBSixJQUFJLENBQUUsSUFBSTtvQkFDckIsYUFBYSxFQUFFLGFBQWE7aUJBQzdCO2FBQ0YsQ0FBQztRQUNKLENBQUMsQ0FBQyxDQUNILENBQUM7UUFFRixPQUFPLE1BQU0sS0FBSyxDQUFDLG1CQUFtQixFQUFFLENBQUM7SUFDM0MsQ0FBQztDQUNGO0FBdkVELG9EQXVFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJhc2VDb2luIGFzIENvaW5Db25maWcsIFNvbENvaW4gfSBmcm9tICdAYml0Z28tYmV0YS9zdGF0aWNzJztcbmltcG9ydCB7IEJ1aWxkVHJhbnNhY3Rpb25FcnJvciwgVHJhbnNhY3Rpb25UeXBlIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IHsgVHJhbnNhY3Rpb24gfSBmcm9tICcuL3RyYW5zYWN0aW9uJztcbmltcG9ydCB7IGdldEFzc29jaWF0ZWRUb2tlbkFjY291bnRBZGRyZXNzLCBnZXRTb2xUb2tlbkZyb21Ub2tlbk5hbWUsIGlzVmFsaWRBbW91bnQsIHZhbGlkYXRlQWRkcmVzcyB9IGZyb20gJy4vdXRpbHMnO1xuaW1wb3J0IHsgSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMgfSBmcm9tICcuL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBUb2tlblRyYW5zZmVyIH0gZnJvbSAnLi9pZmFjZSc7XG5cbmltcG9ydCBhc3NlcnQgZnJvbSAnYXNzZXJ0JztcbmltcG9ydCB7IFRyYW5zYWN0aW9uQnVpbGRlciB9IGZyb20gJy4vdHJhbnNhY3Rpb25CdWlsZGVyJztcblxuZXhwb3J0IGludGVyZmFjZSBTZW5kUGFyYW1zIHtcbiAgYWRkcmVzczogc3RyaW5nO1xuICBhbW91bnQ6IHN0cmluZztcbiAgdG9rZW5OYW1lOiBzdHJpbmc7XG59XG5cbmNvbnN0IFVOU0lHTkVEX0JJR0lOVF9NQVggPSBCaWdJbnQoJzE4NDQ2NzQ0MDczNzA5NTUxNjE1Jyk7XG5cbmV4cG9ydCBjbGFzcyBUb2tlblRyYW5zZmVyQnVpbGRlciBleHRlbmRzIFRyYW5zYWN0aW9uQnVpbGRlciB7XG4gIHByaXZhdGUgX3NlbmRQYXJhbXM6IFNlbmRQYXJhbXNbXSA9IFtdO1xuXG4gIGNvbnN0cnVjdG9yKF9jb2luQ29uZmlnOiBSZWFkb25seTxDb2luQ29uZmlnPikge1xuICAgIHN1cGVyKF9jb2luQ29uZmlnKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBnZXQgdHJhbnNhY3Rpb25UeXBlKCk6IFRyYW5zYWN0aW9uVHlwZSB7XG4gICAgcmV0dXJuIFRyYW5zYWN0aW9uVHlwZS5TZW5kO1xuICB9XG5cbiAgaW5pdEJ1aWxkZXIodHg6IFRyYW5zYWN0aW9uKTogdm9pZCB7XG4gICAgc3VwZXIuaW5pdEJ1aWxkZXIodHgpO1xuXG4gICAgZm9yIChjb25zdCBpbnN0cnVjdGlvbiBvZiB0aGlzLl9pbnN0cnVjdGlvbnNEYXRhKSB7XG4gICAgICBpZiAoaW5zdHJ1Y3Rpb24udHlwZSA9PT0gSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMuVG9rZW5UcmFuc2Zlcikge1xuICAgICAgICBjb25zdCB0cmFuc2Zlckluc3RydWN0aW9uOiBUb2tlblRyYW5zZmVyID0gaW5zdHJ1Y3Rpb247XG4gICAgICAgIHRoaXMuc2VuZGVyKHRyYW5zZmVySW5zdHJ1Y3Rpb24ucGFyYW1zLmZyb21BZGRyZXNzKTtcbiAgICAgICAgdGhpcy5zZW5kKHtcbiAgICAgICAgICBhZGRyZXNzOiB0cmFuc2Zlckluc3RydWN0aW9uLnBhcmFtcy50b0FkZHJlc3MsXG4gICAgICAgICAgYW1vdW50OiB0cmFuc2Zlckluc3RydWN0aW9uLnBhcmFtcy5hbW91bnQsXG4gICAgICAgICAgdG9rZW5OYW1lOiB0cmFuc2Zlckluc3RydWN0aW9uLnBhcmFtcy50b2tlbk5hbWUsXG4gICAgICAgIH0pO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiAgU2V0IGEgdHJhbnNmZXJcbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IGZyb21BZGRyZXNzIC0gdGhlIHNlbmRlciBhZGRyZXNzXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBhbW91bnQgLSB0aGUgYW1vdW50IHNlbnRcbiAgICogQHBhcmFtIHtzdHJpbmd9IHRva2VuTmFtZSAtIG5hbWUgb2YgdG9rZW4gdGhhdCBpcyBpbnRlbmRlZCB0byBzZW5kXG4gICAqIEByZXR1cm5zIHtUcmFuc2FjdGlvbkJ1aWxkZXJ9IFRoaXMgdHJhbnNhY3Rpb24gYnVpbGRlclxuICAgKi9cbiAgc2VuZCh7IGFkZHJlc3MsIGFtb3VudCwgdG9rZW5OYW1lIH06IFNlbmRQYXJhbXMpOiB0aGlzIHtcbiAgICB2YWxpZGF0ZUFkZHJlc3MoYWRkcmVzcywgJ2FkZHJlc3MnKTtcbiAgICBpZiAoIWFtb3VudCB8fCAhaXNWYWxpZEFtb3VudChhbW91bnQpKSB7XG4gICAgICB0aHJvdyBuZXcgQnVpbGRUcmFuc2FjdGlvbkVycm9yKCdJbnZhbGlkIG9yIG1pc3NpbmcgYW1vdW50LCBnb3Q6ICcgKyBhbW91bnQpO1xuICAgIH1cbiAgICBpZiAoQmlnSW50KGFtb3VudCkgPiBVTlNJR05FRF9CSUdJTlRfTUFYKSB7XG4gICAgICB0aHJvdyBuZXcgQnVpbGRUcmFuc2FjdGlvbkVycm9yKGBpbnB1dCBhbW91bnQgJHthbW91bnR9IGV4Y2VlZHMgYmlnIGludCBsaW1pdCAke1VOU0lHTkVEX0JJR0lOVF9NQVh9YCk7XG4gICAgfVxuXG4gICAgdGhpcy5fc2VuZFBhcmFtcy5wdXNoKHsgYWRkcmVzcywgYW1vdW50LCB0b2tlbk5hbWU6IHRva2VuTmFtZSB9KTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICBwcm90ZWN0ZWQgYXN5bmMgYnVpbGRJbXBsZW1lbnRhdGlvbigpOiBQcm9taXNlPFRyYW5zYWN0aW9uPiB7XG4gICAgYXNzZXJ0KHRoaXMuX3NlbmRlciwgJ1NlbmRlciBtdXN0IGJlIHNldCBiZWZvcmUgYnVpbGRpbmcgdGhlIHRyYW5zYWN0aW9uJyk7XG4gICAgdGhpcy5faW5zdHJ1Y3Rpb25zRGF0YSA9IGF3YWl0IFByb21pc2UuYWxsKFxuICAgICAgdGhpcy5fc2VuZFBhcmFtcy5tYXAoYXN5bmMgKHNlbmRQYXJhbXM6IFNlbmRQYXJhbXMpOiBQcm9taXNlPFRva2VuVHJhbnNmZXI+ID0+IHtcbiAgICAgICAgY29uc3QgY29pbiA9IGdldFNvbFRva2VuRnJvbVRva2VuTmFtZShzZW5kUGFyYW1zLnRva2VuTmFtZSEpO1xuICAgICAgICBhc3NlcnQoY29pbiBpbnN0YW5jZW9mIFNvbENvaW4pO1xuICAgICAgICBjb25zdCBzb3VyY2VBZGRyZXNzID0gYXdhaXQgZ2V0QXNzb2NpYXRlZFRva2VuQWNjb3VudEFkZHJlc3MoY29pbi50b2tlbkFkZHJlc3MsIHRoaXMuX3NlbmRlcik7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgdHlwZTogSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMuVG9rZW5UcmFuc2ZlcixcbiAgICAgICAgICBwYXJhbXM6IHtcbiAgICAgICAgICAgIGZyb21BZGRyZXNzOiB0aGlzLl9zZW5kZXIsXG4gICAgICAgICAgICB0b0FkZHJlc3M6IHNlbmRQYXJhbXMuYWRkcmVzcyxcbiAgICAgICAgICAgIGFtb3VudDogc2VuZFBhcmFtcy5hbW91bnQsXG4gICAgICAgICAgICB0b2tlbk5hbWU6IGNvaW4/Lm5hbWUsXG4gICAgICAgICAgICBzb3VyY2VBZGRyZXNzOiBzb3VyY2VBZGRyZXNzLFxuICAgICAgICAgIH0sXG4gICAgICAgIH07XG4gICAgICB9KVxuICAgICk7XG5cbiAgICByZXR1cm4gYXdhaXQgc3VwZXIuYnVpbGRJbXBsZW1lbnRhdGlvbigpO1xuICB9XG59XG4iXX0=
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tokenTransferBuilder.js","sourceRoot":"","sources":["../../../src/lib/tokenTransferBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig, SolCoin } from '@bitgo-beta/statics';\nimport { BuildTransactionError, TransactionType } from '@bitgo-beta/sdk-core';\nimport { Transaction } from './transaction';\nimport {\n  getAssociatedTokenAccountAddress,\n  getSolTokenFromTokenName,\n  isValidAmount,\n  validateAddress,\n  validateMintAddress,\n  validateOwnerAddress,\n} from './utils';\nimport { InstructionBuilderTypes } from './constants';\nimport { AtaInit, TokenAssociateRecipient, TokenTransfer } from './iface';\nimport assert from 'assert';\nimport { TransactionBuilder } from './transactionBuilder';\nimport _ from 'lodash';\n\nexport interface SendParams {\n  address: string;\n  amount: string;\n  tokenName: string;\n}\n\nconst UNSIGNED_BIGINT_MAX = BigInt('18446744073709551615');\n\nexport class TokenTransferBuilder extends TransactionBuilder {\n  private _sendParams: SendParams[] = [];\n  private _createAtaParams: TokenAssociateRecipient[];\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._createAtaParams = [];\n  }\n\n  protected get transactionType(): TransactionType {\n    return TransactionType.Send;\n  }\n\n  initBuilder(tx: Transaction): void {\n    super.initBuilder(tx);\n\n    for (const instruction of this._instructionsData) {\n      if (instruction.type === InstructionBuilderTypes.TokenTransfer) {\n        const transferInstruction: TokenTransfer = instruction;\n        this.sender(transferInstruction.params.fromAddress);\n        this.send({\n          address: transferInstruction.params.toAddress,\n          amount: transferInstruction.params.amount,\n          tokenName: transferInstruction.params.tokenName,\n        });\n      }\n      if (instruction.type === InstructionBuilderTypes.CreateAssociatedTokenAccount) {\n        const ataInitInstruction: AtaInit = instruction;\n        this._createAtaParams.push({\n          ownerAddress: ataInitInstruction.params.ownerAddress,\n          tokenName: ataInitInstruction.params.tokenName,\n        });\n      }\n    }\n  }\n\n  /**\n   *  Set a transfer\n   *\n   * @param {SendParams} params - params for the transfer\n   * @param {string} params.address - the receiver token address\n   * @param {string} params.amount - the amount sent\n   * @param {string} params.tokenName - name of token that is intended to send\n   * @returns {TransactionBuilder} This transaction builder\n   */\n  send({ address, amount, tokenName }: SendParams): this {\n    validateAddress(address, 'address');\n    if (!amount || !isValidAmount(amount)) {\n      throw new BuildTransactionError('Invalid or missing amount, got: ' + amount);\n    }\n    if (BigInt(amount) > UNSIGNED_BIGINT_MAX) {\n      throw new BuildTransactionError(`input amount ${amount} exceeds big int limit ${UNSIGNED_BIGINT_MAX}`);\n    }\n\n    this._sendParams.push({ address, amount, tokenName: tokenName });\n    return this;\n  }\n\n  /**\n   *\n   * @param {TokenAssociateRecipient} recipient - recipient of the associated token account creation\n   * @param {string} recipient.ownerAddress - owner of the associated token account\n   * @param {string} recipient.tokenName - name of the token that is intended to associate\n   * @returns {TransactionBuilder} This transaction builder\n   */\n  createAssociatedTokenAccount(recipient: TokenAssociateRecipient): this {\n    validateOwnerAddress(recipient.ownerAddress);\n    const token = getSolTokenFromTokenName(recipient.tokenName);\n    if (!token) {\n      throw new BuildTransactionError('Invalid token name, got: ' + recipient.tokenName);\n    }\n    validateMintAddress(token.tokenAddress);\n\n    this._createAtaParams.push(recipient);\n    return this;\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    assert(this._sender, 'Sender must be set before building the transaction');\n    const sendInstructions = await Promise.all(\n      this._sendParams.map(async (sendParams: SendParams): Promise<TokenTransfer> => {\n        const coin = getSolTokenFromTokenName(sendParams.tokenName);\n        assert(coin instanceof SolCoin);\n        const sourceAddress = await getAssociatedTokenAccountAddress(coin.tokenAddress, this._sender);\n        return {\n          type: InstructionBuilderTypes.TokenTransfer,\n          params: {\n            fromAddress: this._sender,\n            toAddress: sendParams.address,\n            amount: sendParams.amount,\n            tokenName: coin.name,\n            sourceAddress: sourceAddress,\n          },\n        };\n      })\n    );\n    const uniqueCreateAtaParams = _.uniqBy(this._createAtaParams, (recipient: TokenAssociateRecipient) => {\n      return recipient.ownerAddress + recipient.tokenName;\n    });\n    const createAtaInstructions = await Promise.all(\n      uniqueCreateAtaParams.map(async (recipient: TokenAssociateRecipient): Promise<AtaInit> => {\n        const coin = getSolTokenFromTokenName(recipient.tokenName);\n        assert(coin instanceof SolCoin);\n        const recipientTokenAddress = await getAssociatedTokenAccountAddress(coin.tokenAddress, recipient.ownerAddress);\n        return {\n          type: InstructionBuilderTypes.CreateAssociatedTokenAccount,\n          params: {\n            ownerAddress: recipient.ownerAddress,\n            tokenName: coin.name,\n            mintAddress: coin.tokenAddress,\n            ataAddress: recipientTokenAddress,\n            payerAddress: this._sender,\n          },\n        };\n      })\n    );\n    // order is important, createAtaInstructions must be before sendInstructions\n    this._instructionsData = [...createAtaInstructions, ...sendInstructions];\n    return await super.buildImplementation();\n  }\n}\n"]}
@@ -8,17 +8,21 @@ import { KeyPair } from '.';
8
8
  export declare class Transaction extends BaseTransaction {
9
9
  protected _solTransaction: SolTransaction;
10
10
  private _lamportsPerSignature;
11
+ private _tokenAccountRentExemptAmount;
11
12
  protected _type: TransactionType;
12
13
  constructor(_coinConfig: Readonly<CoinConfig>);
13
14
  get solTransaction(): SolTransaction;
14
15
  set solTransaction(tx: SolTransaction);
15
16
  private get numberOfRequiredSignatures();
17
+ private get numberOfATACreationInstructions();
16
18
  /** @inheritDoc */
17
19
  get signablePayload(): Buffer;
18
20
  /** @inheritDoc **/
19
21
  get id(): string;
20
22
  get lamportsPerSignature(): number | undefined;
21
23
  set lamportsPerSignature(lamportsPerSignature: number | undefined);
24
+ get tokenAccountRentExemptAmount(): string | undefined;
25
+ set tokenAccountRentExemptAmount(tokenAccountRentExemptAmount: string | undefined);
22
26
  /** @inheritDoc */
23
27
  get signature(): string[];
24
28
  /**
@@ -56,6 +60,7 @@ export declare class Transaction extends BaseTransaction {
56
60
  loadInputsAndOutputs(): void;
57
61
  /** @inheritDoc */
58
62
  explainTransaction(): TransactionExplanation;
63
+ private calculateFee;
59
64
  protected getExplainedTransaction(outputAmount: BigNumber, outputs: TransactionRecipient[], memo?: undefined | string, durableNonce?: undefined | DurableNonceParams): TransactionExplanation;
60
65
  }
61
66
  //# sourceMappingURL=transaction.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":";AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EACL,eAAe,EAKf,oBAAoB,EACpB,eAAe,EAChB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAmD,WAAW,IAAI,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjH,OAAO,EACL,kBAAkB,EAMlB,sBAAsB,EAEtB,MAAM,EAEP,MAAM,SAAS,CAAC;AAGjB,OAAO,EAAE,OAAO,EAAE,MAAM,GAAG,CAAC;AAK5B,qBAAa,WAAY,SAAQ,eAAe;IAC9C,SAAS,CAAC,eAAe,EAAE,cAAc,CAAC;IAC1C,OAAO,CAAC,qBAAqB,CAAqB;IAClD,SAAS,CAAC,KAAK,EAAE,eAAe,CAAC;gBAErB,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C,IAAI,cAAc,IAAI,cAAc,CAEnC;IAED,IAAI,cAAc,CAAC,EAAE,EAAE,cAAc,EAEpC;IAED,OAAO,KAAK,0BAA0B,GAErC;IAED,kBAAkB;IAClB,IAAI,eAAe,IAAI,MAAM,CAE5B;IAED,mBAAmB;IACnB,IAAI,EAAE,IAAI,MAAM,CAOf;IAED,IAAI,oBAAoB,IAAI,MAAM,GAAG,SAAS,CAE7C;IAED,IAAI,oBAAoB,CAAC,oBAAoB,EAAE,MAAM,GAAG,SAAS,EAEhE;IAED,kBAAkB;IAClB,IAAI,SAAS,IAAI,MAAM,EAAE,CAUxB;IAED;;;;OAIG;IACH,kBAAkB,CAAC,eAAe,EAAE,eAAe,GAAG,IAAI;IAI1D,kBAAkB;IAClB,OAAO,IAAI,OAAO;IAIlB;;;;OAIG;IACG,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAuBvD,kBAAkB;IAClB,iBAAiB,IAAI,MAAM;IAiB3B;;;;OAIG;IACH,kBAAkB,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IAkChD,kBAAkB;IAClB,MAAM,IAAI,MAAM;IA0BhB;;;OAGG;IACH,OAAO,CAAC,QAAQ;IAUhB;;OAEG;IACH,oBAAoB,IAAI,IAAI;IA0E5B,kBAAkB;IAClB,kBAAkB,IAAI,sBAAsB;IA+E5C,SAAS,CAAC,uBAAuB,CAC/B,YAAY,EAAE,SAAS,EACvB,OAAO,EAAE,oBAAoB,EAAE,EAC/B,IAAI,GAAE,SAAS,GAAG,MAAkB,EACpC,YAAY,GAAE,SAAS,GAAG,kBAA8B,GACvD,sBAAsB;CAgC1B"}
1
+ {"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":";AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EACL,eAAe,EAKf,oBAAoB,EACpB,eAAe,EAChB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAmD,WAAW,IAAI,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjH,OAAO,EACL,kBAAkB,EAMlB,sBAAsB,EAEtB,MAAM,EAEP,MAAM,SAAS,CAAC;AAGjB,OAAO,EAAE,OAAO,EAAE,MAAM,GAAG,CAAC;AAG5B,qBAAa,WAAY,SAAQ,eAAe;IAC9C,SAAS,CAAC,eAAe,EAAE,cAAc,CAAC;IAC1C,OAAO,CAAC,qBAAqB,CAAqB;IAClD,OAAO,CAAC,6BAA6B,CAAqB;IAC1D,SAAS,CAAC,KAAK,EAAE,eAAe,CAAC;gBAErB,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C,IAAI,cAAc,IAAI,cAAc,CAEnC;IAED,IAAI,cAAc,CAAC,EAAE,EAAE,cAAc,EAEpC;IAED,OAAO,KAAK,0BAA0B,GAErC;IAED,OAAO,KAAK,+BAA+B,GAI1C;IAED,kBAAkB;IAClB,IAAI,eAAe,IAAI,MAAM,CAE5B;IAED,mBAAmB;IACnB,IAAI,EAAE,IAAI,MAAM,CAOf;IAED,IAAI,oBAAoB,IAAI,MAAM,GAAG,SAAS,CAE7C;IAED,IAAI,oBAAoB,CAAC,oBAAoB,EAAE,MAAM,GAAG,SAAS,EAEhE;IAED,IAAI,4BAA4B,IAAI,MAAM,GAAG,SAAS,CAErD;IAED,IAAI,4BAA4B,CAAC,4BAA4B,EAAE,MAAM,GAAG,SAAS,EAEhF;IAED,kBAAkB;IAClB,IAAI,SAAS,IAAI,MAAM,EAAE,CAUxB;IAED;;;;OAIG;IACH,kBAAkB,CAAC,eAAe,EAAE,eAAe,GAAG,IAAI;IAI1D,kBAAkB;IAClB,OAAO,IAAI,OAAO;IAIlB;;;;OAIG;IACG,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAuBvD,kBAAkB;IAClB,iBAAiB,IAAI,MAAM;IAiB3B;;;;OAIG;IACH,kBAAkB,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IAkChD,kBAAkB;IAClB,MAAM,IAAI,MAAM;IA0BhB;;;OAGG;IACH,OAAO,CAAC,QAAQ;IAUhB;;OAEG;IACH,oBAAoB,IAAI,IAAI;IAuF5B,kBAAkB;IAClB,kBAAkB,IAAI,sBAAsB;IA8E5C,OAAO,CAAC,YAAY;IAapB,SAAS,CAAC,uBAAuB,CAC/B,YAAY,EAAE,SAAS,EACvB,OAAO,EAAE,oBAAoB,EAAE,EAC/B,IAAI,GAAE,SAAS,GAAG,MAAkB,EACpC,YAAY,GAAE,SAAS,GAAG,kBAA8B,GACvD,sBAAsB;CA8B1B"}
@@ -11,7 +11,6 @@ const bs58_1 = __importDefault(require("bs58"));
11
11
  const utils_1 = require("./utils");
12
12
  const instructionParamsFactory_1 = require("./instructionParamsFactory");
13
13
  const constants_1 = require("./constants");
14
- const UNAVAILABLE_TEXT = 'UNAVAILABLE';
15
14
  class Transaction extends sdk_core_1.BaseTransaction {
16
15
  constructor(_coinConfig) {
17
16
  super(_coinConfig);
@@ -25,6 +24,9 @@ class Transaction extends sdk_core_1.BaseTransaction {
25
24
  get numberOfRequiredSignatures() {
26
25
  return this._solTransaction.compileMessage().header.numRequiredSignatures;
27
26
  }
27
+ get numberOfATACreationInstructions() {
28
+ return this._solTransaction.instructions.filter((instruction) => utils_1.getInstructionType(instruction) === constants_1.ValidInstructionTypesEnum.InitializeAssociatedTokenAccount).length;
29
+ }
28
30
  /** @inheritDoc */
29
31
  get signablePayload() {
30
32
  return this._solTransaction.serializeMessage();
@@ -36,7 +38,7 @@ class Transaction extends sdk_core_1.BaseTransaction {
36
38
  return bs58_1.default.encode(this._solTransaction.signature);
37
39
  }
38
40
  else {
39
- return UNAVAILABLE_TEXT;
41
+ return constants_1.UNAVAILABLE_TEXT;
40
42
  }
41
43
  }
42
44
  get lamportsPerSignature() {
@@ -45,6 +47,12 @@ class Transaction extends sdk_core_1.BaseTransaction {
45
47
  set lamportsPerSignature(lamportsPerSignature) {
46
48
  this._lamportsPerSignature = lamportsPerSignature;
47
49
  }
50
+ get tokenAccountRentExemptAmount() {
51
+ return this._tokenAccountRentExemptAmount;
52
+ }
53
+ set tokenAccountRentExemptAmount(tokenAccountRentExemptAmount) {
54
+ this._tokenAccountRentExemptAmount = tokenAccountRentExemptAmount;
55
+ }
48
56
  /** @inheritDoc */
49
57
  get signature() {
50
58
  const signatures = [];
@@ -248,6 +256,20 @@ class Transaction extends sdk_core_1.BaseTransaction {
248
256
  coin: this._coinConfig.name,
249
257
  });
250
258
  break;
259
+ case constants_1.InstructionBuilderTypes.StakingDeactivate:
260
+ if (instruction.params.amount && instruction.params.unstakingAddress) {
261
+ inputs.push({
262
+ address: instruction.params.stakingAddress,
263
+ value: instruction.params.amount,
264
+ coin: this._coinConfig.name,
265
+ });
266
+ outputs.push({
267
+ address: instruction.params.unstakingAddress,
268
+ value: instruction.params.amount,
269
+ coin: this._coinConfig.name,
270
+ });
271
+ }
272
+ break;
251
273
  case constants_1.InstructionBuilderTypes.StakingWithdraw:
252
274
  inputs.push({
253
275
  address: instruction.params.stakingAddress,
@@ -261,7 +283,6 @@ class Transaction extends sdk_core_1.BaseTransaction {
261
283
  });
262
284
  break;
263
285
  case constants_1.InstructionBuilderTypes.CreateAssociatedTokenAccount:
264
- // taken care of in subclass
265
286
  break;
266
287
  }
267
288
  }
@@ -324,7 +345,6 @@ class Transaction extends sdk_core_1.BaseTransaction {
324
345
  outputAmount = outputAmount.plus(stakingWithdrawInstruction.params.amount);
325
346
  break;
326
347
  case constants_1.InstructionBuilderTypes.CreateAssociatedTokenAccount:
327
- // taken care of in subclass
328
348
  break;
329
349
  default:
330
350
  continue;
@@ -340,10 +360,20 @@ class Transaction extends sdk_core_1.BaseTransaction {
340
360
  }
341
361
  return this.getExplainedTransaction(outputAmount, outputs, memo, durableNonce);
342
362
  }
363
+ calculateFee() {
364
+ if (this.lamportsPerSignature || this.tokenAccountRentExemptAmount) {
365
+ const signatureFees = this.lamportsPerSignature
366
+ ? new bignumber_js_1.default(this.lamportsPerSignature).multipliedBy(this.numberOfRequiredSignatures).toFixed(0)
367
+ : 0;
368
+ const rentFees = this.tokenAccountRentExemptAmount
369
+ ? new bignumber_js_1.default(this.tokenAccountRentExemptAmount).multipliedBy(this.numberOfATACreationInstructions).toFixed(0)
370
+ : 0;
371
+ return new bignumber_js_1.default(signatureFees).plus(rentFees).toFixed(0);
372
+ }
373
+ return constants_1.UNAVAILABLE_TEXT;
374
+ }
343
375
  getExplainedTransaction(outputAmount, outputs, memo = undefined, durableNonce = undefined) {
344
- const feeString = this.lamportsPerSignature
345
- ? new bignumber_js_1.default(this.lamportsPerSignature).multipliedBy(this.numberOfRequiredSignatures).toFixed(0)
346
- : UNAVAILABLE_TEXT;
376
+ const feeString = this.calculateFee();
347
377
  return {
348
378
  displayOrder: [
349
379
  'id',
@@ -374,4 +404,4 @@ class Transaction extends sdk_core_1.BaseTransaction {
374
404
  }
375
405
  }
376
406
  exports.Transaction = Transaction;
377
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import BigNumber from 'bignumber.js';\nimport {\n  BaseTransaction,\n  Entry,\n  InvalidTransactionError,\n  ParseTransactionError,\n  SigningError,\n  TransactionRecipient,\n  TransactionType,\n} from '@bitgo-beta/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { Blockhash, PublicKey, Signer, SystemInstruction, Transaction as SolTransaction } from '@solana/web3.js';\nimport {\n  DurableNonceParams,\n  Memo,\n  Nonce,\n  StakingActivate,\n  StakingWithdraw,\n  TokenTransfer,\n  TransactionExplanation,\n  Transfer,\n  TxData,\n  WalletInit,\n} from './iface';\nimport base58 from 'bs58';\nimport { getTransactionType, isValidRawTransaction, requiresAllSignatures } from './utils';\nimport { KeyPair } from '.';\nimport { instructionParamsFactory } from './instructionParamsFactory';\nimport { InstructionBuilderTypes } from './constants';\n\nconst UNAVAILABLE_TEXT = 'UNAVAILABLE';\nexport class Transaction extends BaseTransaction {\n  protected _solTransaction: SolTransaction;\n  private _lamportsPerSignature: number | undefined;\n  protected _type: TransactionType;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  get solTransaction(): SolTransaction {\n    return this._solTransaction;\n  }\n\n  set solTransaction(tx: SolTransaction) {\n    this._solTransaction = tx;\n  }\n\n  private get numberOfRequiredSignatures(): number {\n    return this._solTransaction.compileMessage().header.numRequiredSignatures;\n  }\n\n  /** @inheritDoc */\n  get signablePayload(): Buffer {\n    return this._solTransaction.serializeMessage();\n  }\n\n  /** @inheritDoc **/\n  get id(): string {\n    // Solana transaction ID === first signature: https://docs.solana.com/terminology#transaction-id\n    if (this._solTransaction.signature) {\n      return base58.encode(this._solTransaction.signature);\n    } else {\n      return UNAVAILABLE_TEXT;\n    }\n  }\n\n  get lamportsPerSignature(): number | undefined {\n    return this._lamportsPerSignature;\n  }\n\n  set lamportsPerSignature(lamportsPerSignature: number | undefined) {\n    this._lamportsPerSignature = lamportsPerSignature;\n  }\n\n  /** @inheritDoc */\n  get signature(): string[] {\n    const signatures: string[] = [];\n\n    for (const solSignature of this._solTransaction.signatures) {\n      if (solSignature.signature) {\n        signatures.push(base58.encode(solSignature.signature));\n      }\n    }\n\n    return signatures;\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  /** @inheritdoc */\n  canSign(): boolean {\n    return true;\n  }\n\n  /**\n   * Signs transaction.\n   *\n   * @param {KeyPair} keyPair Signer keys.\n   */\n  async sign(keyPair: KeyPair[] | KeyPair): Promise<void> {\n    if (!this._solTransaction || !this._solTransaction.recentBlockhash) {\n      throw new SigningError('Nonce is required before signing');\n    }\n    if (!this._solTransaction || !this._solTransaction.feePayer) {\n      throw new SigningError('feePayer is required before signing');\n    }\n    const keyPairs = keyPair instanceof Array ? keyPair : [keyPair];\n    const signers: Signer[] = [];\n    for (const kp of keyPairs) {\n      const keys = kp.getKeys(true);\n      if (!keys.prv) {\n        throw new SigningError('Missing private key');\n      }\n      signers.push({ publicKey: new PublicKey(keys.pub), secretKey: keys.prv as Uint8Array });\n    }\n    try {\n      this._solTransaction.partialSign(...signers);\n    } catch (e) {\n      throw e;\n    }\n  }\n\n  /** @inheritdoc */\n  toBroadcastFormat(): string {\n    if (!this._solTransaction) {\n      throw new ParseTransactionError('Empty transaction');\n    }\n    // The signatures can have null signatures (which means they are required but yet unsigned)\n    // In order to be able to serializer the txs, we have to change the requireAllSignatures based\n    // on if the TX is fully signed or not\n    const requireAllSignatures = requiresAllSignatures(this._solTransaction.signatures);\n    try {\n      // Based on the recomendation encoding found here https://docs.solana.com/developing/clients/jsonrpc-api#sendtransaction\n      // We use base64 encoding\n      return this._solTransaction.serialize({ requireAllSignatures }).toString('base64');\n    } catch (e) {\n      throw e;\n    }\n  }\n\n  /**\n   * Sets this transaction payload\n   *\n   * @param rawTransaction\n   */\n  fromRawTransaction(rawTransaction: string): void {\n    try {\n      isValidRawTransaction(rawTransaction);\n      this._solTransaction = SolTransaction.from(Buffer.from(rawTransaction, 'base64'));\n      if (this._solTransaction.signature && this._solTransaction.signature !== null) {\n        this._id = base58.encode(this._solTransaction.signature);\n      }\n      const transactionType = getTransactionType(this._solTransaction);\n      switch (transactionType) {\n        case TransactionType.WalletInitialization:\n          this.setTransactionType(TransactionType.WalletInitialization);\n          break;\n        case TransactionType.Send:\n          this.setTransactionType(TransactionType.Send);\n          break;\n        case TransactionType.StakingActivate:\n          this.setTransactionType(TransactionType.StakingActivate);\n          break;\n        case TransactionType.StakingDeactivate:\n          this.setTransactionType(TransactionType.StakingDeactivate);\n          break;\n        case TransactionType.StakingWithdraw:\n          this.setTransactionType(TransactionType.StakingWithdraw);\n          break;\n        case TransactionType.AssociatedTokenAccountInitialization:\n          this.setTransactionType(TransactionType.AssociatedTokenAccountInitialization);\n          break;\n      }\n      this.loadInputsAndOutputs();\n    } catch (e) {\n      throw e;\n    }\n  }\n\n  /** @inheritdoc */\n  toJson(): TxData {\n    if (!this._solTransaction) {\n      throw new ParseTransactionError('Empty transaction');\n    }\n\n    let durableNonce: DurableNonceParams | undefined;\n    if (this._solTransaction.nonceInfo) {\n      const nonceInstruction = SystemInstruction.decodeNonceAdvance(this._solTransaction.nonceInfo.nonceInstruction);\n      durableNonce = {\n        walletNonceAddress: nonceInstruction.noncePubkey.toString(),\n        authWalletAddress: nonceInstruction.authorizedPubkey.toString(),\n      };\n    }\n\n    const result: TxData = {\n      id: this._solTransaction.signature ? this.id : undefined,\n      feePayer: this._solTransaction.feePayer?.toString(),\n      lamportsPerSignature: this.lamportsPerSignature,\n      nonce: this.getNonce(),\n      durableNonce: durableNonce,\n      numSignatures: this.signature.length,\n      instructionsData: instructionParamsFactory(this._type, this._solTransaction.instructions),\n    };\n    return result;\n  }\n\n  /**\n   * Get the nonce from the Solana Transaction\n   * Throws if not set\n   */\n  private getNonce(): Blockhash {\n    if (this._solTransaction.recentBlockhash) {\n      return this._solTransaction.recentBlockhash;\n    } else if (this._solTransaction.nonceInfo) {\n      return this._solTransaction.nonceInfo.nonce;\n    } else {\n      throw new InvalidTransactionError('Nonce is not set');\n    }\n  }\n\n  /**\n   * Load the input and output data on this transaction.\n   */\n  loadInputsAndOutputs(): void {\n    if (!this._solTransaction || this._solTransaction.instructions?.length === 0) {\n      return;\n    }\n    const outputs: Entry[] = [];\n    const inputs: Entry[] = [];\n    const instructionParams = instructionParamsFactory(this.type, this._solTransaction.instructions);\n\n    for (const instruction of instructionParams) {\n      switch (instruction.type) {\n        case InstructionBuilderTypes.CreateNonceAccount:\n          inputs.push({\n            address: instruction.params.fromAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          break;\n        case InstructionBuilderTypes.Transfer:\n          inputs.push({\n            address: instruction.params.fromAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          outputs.push({\n            address: instruction.params.toAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          break;\n        case InstructionBuilderTypes.TokenTransfer:\n          inputs.push({\n            address: instruction.params.fromAddress,\n            value: instruction.params.amount,\n            coin: instruction.params.tokenName,\n          });\n          outputs.push({\n            address: instruction.params.toAddress,\n            value: instruction.params.amount,\n            coin: instruction.params.tokenName,\n          });\n          break;\n        case InstructionBuilderTypes.StakingActivate:\n          inputs.push({\n            address: instruction.params.fromAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          outputs.push({\n            address: instruction.params.stakingAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          break;\n        case InstructionBuilderTypes.StakingWithdraw:\n          inputs.push({\n            address: instruction.params.stakingAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          outputs.push({\n            address: instruction.params.fromAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          break;\n        case InstructionBuilderTypes.CreateAssociatedTokenAccount:\n          // taken care of in subclass\n          break;\n      }\n    }\n    this._outputs = outputs;\n    this._inputs = inputs;\n  }\n\n  /** @inheritDoc */\n  explainTransaction(): TransactionExplanation {\n    const decodedInstructions = instructionParamsFactory(this._type, this._solTransaction.instructions);\n\n    let memo: string | undefined = undefined;\n    let durableNonce: DurableNonceParams | undefined = undefined;\n\n    let outputAmount = new BigNumber(0);\n    const outputs: TransactionRecipient[] = [];\n\n    for (const instruction of decodedInstructions) {\n      switch (instruction.type) {\n        case InstructionBuilderTypes.NonceAdvance:\n          durableNonce = (instruction as Nonce).params;\n          break;\n        case InstructionBuilderTypes.Memo:\n          memo = (instruction as Memo).params.memo;\n          break;\n        case InstructionBuilderTypes.Transfer:\n          const transferInstruction = instruction as Transfer;\n          outputs.push({\n            address: transferInstruction.params.toAddress,\n            amount: transferInstruction.params.amount,\n          });\n          outputAmount = outputAmount.plus(transferInstruction.params.amount);\n          break;\n        case InstructionBuilderTypes.TokenTransfer:\n          const tokenTransferInstruction = instruction as TokenTransfer;\n          outputs.push({\n            address: tokenTransferInstruction.params.toAddress,\n            amount: tokenTransferInstruction.params.amount,\n            tokenName: tokenTransferInstruction.params.tokenName,\n          });\n          break;\n        case InstructionBuilderTypes.CreateNonceAccount:\n          const createInstruction = instruction as WalletInit;\n          outputs.push({\n            address: createInstruction.params.nonceAddress,\n            amount: createInstruction.params.amount,\n          });\n          outputAmount = outputAmount.plus(createInstruction.params.amount);\n          break;\n        case InstructionBuilderTypes.StakingActivate:\n          const stakingActivateInstruction = instruction as StakingActivate;\n          outputs.push({\n            address: stakingActivateInstruction.params.stakingAddress,\n            amount: stakingActivateInstruction.params.amount,\n          });\n          outputAmount = outputAmount.plus(stakingActivateInstruction.params.amount);\n          break;\n        case InstructionBuilderTypes.StakingWithdraw:\n          const stakingWithdrawInstruction = instruction as StakingWithdraw;\n          outputs.push({\n            address: stakingWithdrawInstruction.params.fromAddress,\n            amount: stakingWithdrawInstruction.params.amount,\n          });\n          outputAmount = outputAmount.plus(stakingWithdrawInstruction.params.amount);\n          break;\n        case InstructionBuilderTypes.CreateAssociatedTokenAccount:\n          // taken care of in subclass\n          break;\n        default:\n          continue;\n      }\n\n      // After deserializing a transaction, durable nonce details are populated in the nonceInfo field\n      if (!durableNonce && this._solTransaction.nonceInfo) {\n        const nonceAdvanceInstruction = SystemInstruction.decodeNonceAdvance(\n          this._solTransaction.nonceInfo.nonceInstruction\n        );\n        durableNonce = {\n          authWalletAddress: nonceAdvanceInstruction.authorizedPubkey.toString(),\n          walletNonceAddress: nonceAdvanceInstruction.noncePubkey.toString(),\n        };\n      }\n    }\n\n    return this.getExplainedTransaction(outputAmount, outputs, memo, durableNonce);\n  }\n\n  protected getExplainedTransaction(\n    outputAmount: BigNumber,\n    outputs: TransactionRecipient[],\n    memo: undefined | string = undefined,\n    durableNonce: undefined | DurableNonceParams = undefined\n  ): TransactionExplanation {\n    const feeString = this.lamportsPerSignature\n      ? new BigNumber(this.lamportsPerSignature).multipliedBy(this.numberOfRequiredSignatures).toFixed(0)\n      : UNAVAILABLE_TEXT;\n    return {\n      displayOrder: [\n        'id',\n        'type',\n        'blockhash',\n        'durableNonce',\n        'outputAmount',\n        'changeAmount',\n        'outputs',\n        'changeOutputs',\n        'fee',\n        'memo',\n      ],\n      id: this.id,\n      type: TransactionType[this.type].toString(),\n      changeOutputs: [],\n      changeAmount: '0',\n      outputAmount: outputAmount.toFixed(0),\n      outputs: outputs,\n      fee: {\n        fee: feeString,\n        feeRate: this.lamportsPerSignature,\n      },\n      memo: memo,\n      blockhash: this.getNonce(),\n      durableNonce: durableNonce,\n    };\n  }\n}\n"]}
407
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import BigNumber from 'bignumber.js';\nimport {\n  BaseTransaction,\n  Entry,\n  InvalidTransactionError,\n  ParseTransactionError,\n  SigningError,\n  TransactionRecipient,\n  TransactionType,\n} from '@bitgo-beta/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { Blockhash, PublicKey, Signer, SystemInstruction, Transaction as SolTransaction } from '@solana/web3.js';\nimport {\n  DurableNonceParams,\n  Memo,\n  Nonce,\n  StakingActivate,\n  StakingWithdraw,\n  TokenTransfer,\n  TransactionExplanation,\n  Transfer,\n  TxData,\n  WalletInit,\n} from './iface';\nimport base58 from 'bs58';\nimport { getInstructionType, getTransactionType, isValidRawTransaction, requiresAllSignatures } from './utils';\nimport { KeyPair } from '.';\nimport { instructionParamsFactory } from './instructionParamsFactory';\nimport { InstructionBuilderTypes, ValidInstructionTypesEnum, UNAVAILABLE_TEXT } from './constants';\nexport class Transaction extends BaseTransaction {\n  protected _solTransaction: SolTransaction;\n  private _lamportsPerSignature: number | undefined;\n  private _tokenAccountRentExemptAmount: string | undefined;\n  protected _type: TransactionType;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  get solTransaction(): SolTransaction {\n    return this._solTransaction;\n  }\n\n  set solTransaction(tx: SolTransaction) {\n    this._solTransaction = tx;\n  }\n\n  private get numberOfRequiredSignatures(): number {\n    return this._solTransaction.compileMessage().header.numRequiredSignatures;\n  }\n\n  private get numberOfATACreationInstructions(): number {\n    return this._solTransaction.instructions.filter(\n      (instruction) => getInstructionType(instruction) === ValidInstructionTypesEnum.InitializeAssociatedTokenAccount\n    ).length;\n  }\n\n  /** @inheritDoc */\n  get signablePayload(): Buffer {\n    return this._solTransaction.serializeMessage();\n  }\n\n  /** @inheritDoc **/\n  get id(): string {\n    // Solana transaction ID === first signature: https://docs.solana.com/terminology#transaction-id\n    if (this._solTransaction.signature) {\n      return base58.encode(this._solTransaction.signature);\n    } else {\n      return UNAVAILABLE_TEXT;\n    }\n  }\n\n  get lamportsPerSignature(): number | undefined {\n    return this._lamportsPerSignature;\n  }\n\n  set lamportsPerSignature(lamportsPerSignature: number | undefined) {\n    this._lamportsPerSignature = lamportsPerSignature;\n  }\n\n  get tokenAccountRentExemptAmount(): string | undefined {\n    return this._tokenAccountRentExemptAmount;\n  }\n\n  set tokenAccountRentExemptAmount(tokenAccountRentExemptAmount: string | undefined) {\n    this._tokenAccountRentExemptAmount = tokenAccountRentExemptAmount;\n  }\n\n  /** @inheritDoc */\n  get signature(): string[] {\n    const signatures: string[] = [];\n\n    for (const solSignature of this._solTransaction.signatures) {\n      if (solSignature.signature) {\n        signatures.push(base58.encode(solSignature.signature));\n      }\n    }\n\n    return signatures;\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  /** @inheritdoc */\n  canSign(): boolean {\n    return true;\n  }\n\n  /**\n   * Signs transaction.\n   *\n   * @param {KeyPair} keyPair Signer keys.\n   */\n  async sign(keyPair: KeyPair[] | KeyPair): Promise<void> {\n    if (!this._solTransaction || !this._solTransaction.recentBlockhash) {\n      throw new SigningError('Nonce is required before signing');\n    }\n    if (!this._solTransaction || !this._solTransaction.feePayer) {\n      throw new SigningError('feePayer is required before signing');\n    }\n    const keyPairs = keyPair instanceof Array ? keyPair : [keyPair];\n    const signers: Signer[] = [];\n    for (const kp of keyPairs) {\n      const keys = kp.getKeys(true);\n      if (!keys.prv) {\n        throw new SigningError('Missing private key');\n      }\n      signers.push({ publicKey: new PublicKey(keys.pub), secretKey: keys.prv as Uint8Array });\n    }\n    try {\n      this._solTransaction.partialSign(...signers);\n    } catch (e) {\n      throw e;\n    }\n  }\n\n  /** @inheritdoc */\n  toBroadcastFormat(): string {\n    if (!this._solTransaction) {\n      throw new ParseTransactionError('Empty transaction');\n    }\n    // The signatures can have null signatures (which means they are required but yet unsigned)\n    // In order to be able to serializer the txs, we have to change the requireAllSignatures based\n    // on if the TX is fully signed or not\n    const requireAllSignatures = requiresAllSignatures(this._solTransaction.signatures);\n    try {\n      // Based on the recomendation encoding found here https://docs.solana.com/developing/clients/jsonrpc-api#sendtransaction\n      // We use base64 encoding\n      return this._solTransaction.serialize({ requireAllSignatures }).toString('base64');\n    } catch (e) {\n      throw e;\n    }\n  }\n\n  /**\n   * Sets this transaction payload\n   *\n   * @param rawTransaction\n   */\n  fromRawTransaction(rawTransaction: string): void {\n    try {\n      isValidRawTransaction(rawTransaction);\n      this._solTransaction = SolTransaction.from(Buffer.from(rawTransaction, 'base64'));\n      if (this._solTransaction.signature && this._solTransaction.signature !== null) {\n        this._id = base58.encode(this._solTransaction.signature);\n      }\n      const transactionType = getTransactionType(this._solTransaction);\n      switch (transactionType) {\n        case TransactionType.WalletInitialization:\n          this.setTransactionType(TransactionType.WalletInitialization);\n          break;\n        case TransactionType.Send:\n          this.setTransactionType(TransactionType.Send);\n          break;\n        case TransactionType.StakingActivate:\n          this.setTransactionType(TransactionType.StakingActivate);\n          break;\n        case TransactionType.StakingDeactivate:\n          this.setTransactionType(TransactionType.StakingDeactivate);\n          break;\n        case TransactionType.StakingWithdraw:\n          this.setTransactionType(TransactionType.StakingWithdraw);\n          break;\n        case TransactionType.AssociatedTokenAccountInitialization:\n          this.setTransactionType(TransactionType.AssociatedTokenAccountInitialization);\n          break;\n      }\n      this.loadInputsAndOutputs();\n    } catch (e) {\n      throw e;\n    }\n  }\n\n  /** @inheritdoc */\n  toJson(): TxData {\n    if (!this._solTransaction) {\n      throw new ParseTransactionError('Empty transaction');\n    }\n\n    let durableNonce: DurableNonceParams | undefined;\n    if (this._solTransaction.nonceInfo) {\n      const nonceInstruction = SystemInstruction.decodeNonceAdvance(this._solTransaction.nonceInfo.nonceInstruction);\n      durableNonce = {\n        walletNonceAddress: nonceInstruction.noncePubkey.toString(),\n        authWalletAddress: nonceInstruction.authorizedPubkey.toString(),\n      };\n    }\n\n    const result: TxData = {\n      id: this._solTransaction.signature ? this.id : undefined,\n      feePayer: this._solTransaction.feePayer?.toString(),\n      lamportsPerSignature: this.lamportsPerSignature,\n      nonce: this.getNonce(),\n      durableNonce: durableNonce,\n      numSignatures: this.signature.length,\n      instructionsData: instructionParamsFactory(this._type, this._solTransaction.instructions),\n    };\n    return result;\n  }\n\n  /**\n   * Get the nonce from the Solana Transaction\n   * Throws if not set\n   */\n  private getNonce(): Blockhash {\n    if (this._solTransaction.recentBlockhash) {\n      return this._solTransaction.recentBlockhash;\n    } else if (this._solTransaction.nonceInfo) {\n      return this._solTransaction.nonceInfo.nonce;\n    } else {\n      throw new InvalidTransactionError('Nonce is not set');\n    }\n  }\n\n  /**\n   * Load the input and output data on this transaction.\n   */\n  loadInputsAndOutputs(): void {\n    if (!this._solTransaction || this._solTransaction.instructions?.length === 0) {\n      return;\n    }\n    const outputs: Entry[] = [];\n    const inputs: Entry[] = [];\n    const instructionParams = instructionParamsFactory(this.type, this._solTransaction.instructions);\n\n    for (const instruction of instructionParams) {\n      switch (instruction.type) {\n        case InstructionBuilderTypes.CreateNonceAccount:\n          inputs.push({\n            address: instruction.params.fromAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          break;\n        case InstructionBuilderTypes.Transfer:\n          inputs.push({\n            address: instruction.params.fromAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          outputs.push({\n            address: instruction.params.toAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          break;\n        case InstructionBuilderTypes.TokenTransfer:\n          inputs.push({\n            address: instruction.params.fromAddress,\n            value: instruction.params.amount,\n            coin: instruction.params.tokenName,\n          });\n          outputs.push({\n            address: instruction.params.toAddress,\n            value: instruction.params.amount,\n            coin: instruction.params.tokenName,\n          });\n          break;\n        case InstructionBuilderTypes.StakingActivate:\n          inputs.push({\n            address: instruction.params.fromAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          outputs.push({\n            address: instruction.params.stakingAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          break;\n        case InstructionBuilderTypes.StakingDeactivate:\n          if (instruction.params.amount && instruction.params.unstakingAddress) {\n            inputs.push({\n              address: instruction.params.stakingAddress,\n              value: instruction.params.amount,\n              coin: this._coinConfig.name,\n            });\n            outputs.push({\n              address: instruction.params.unstakingAddress,\n              value: instruction.params.amount,\n              coin: this._coinConfig.name,\n            });\n          }\n          break;\n        case InstructionBuilderTypes.StakingWithdraw:\n          inputs.push({\n            address: instruction.params.stakingAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          outputs.push({\n            address: instruction.params.fromAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          break;\n        case InstructionBuilderTypes.CreateAssociatedTokenAccount:\n          break;\n      }\n    }\n    this._outputs = outputs;\n    this._inputs = inputs;\n  }\n\n  /** @inheritDoc */\n  explainTransaction(): TransactionExplanation {\n    const decodedInstructions = instructionParamsFactory(this._type, this._solTransaction.instructions);\n\n    let memo: string | undefined = undefined;\n    let durableNonce: DurableNonceParams | undefined = undefined;\n\n    let outputAmount = new BigNumber(0);\n    const outputs: TransactionRecipient[] = [];\n\n    for (const instruction of decodedInstructions) {\n      switch (instruction.type) {\n        case InstructionBuilderTypes.NonceAdvance:\n          durableNonce = (instruction as Nonce).params;\n          break;\n        case InstructionBuilderTypes.Memo:\n          memo = (instruction as Memo).params.memo;\n          break;\n        case InstructionBuilderTypes.Transfer:\n          const transferInstruction = instruction as Transfer;\n          outputs.push({\n            address: transferInstruction.params.toAddress,\n            amount: transferInstruction.params.amount,\n          });\n          outputAmount = outputAmount.plus(transferInstruction.params.amount);\n          break;\n        case InstructionBuilderTypes.TokenTransfer:\n          const tokenTransferInstruction = instruction as TokenTransfer;\n          outputs.push({\n            address: tokenTransferInstruction.params.toAddress,\n            amount: tokenTransferInstruction.params.amount,\n            tokenName: tokenTransferInstruction.params.tokenName,\n          });\n          break;\n        case InstructionBuilderTypes.CreateNonceAccount:\n          const createInstruction = instruction as WalletInit;\n          outputs.push({\n            address: createInstruction.params.nonceAddress,\n            amount: createInstruction.params.amount,\n          });\n          outputAmount = outputAmount.plus(createInstruction.params.amount);\n          break;\n        case InstructionBuilderTypes.StakingActivate:\n          const stakingActivateInstruction = instruction as StakingActivate;\n          outputs.push({\n            address: stakingActivateInstruction.params.stakingAddress,\n            amount: stakingActivateInstruction.params.amount,\n          });\n          outputAmount = outputAmount.plus(stakingActivateInstruction.params.amount);\n          break;\n        case InstructionBuilderTypes.StakingWithdraw:\n          const stakingWithdrawInstruction = instruction as StakingWithdraw;\n          outputs.push({\n            address: stakingWithdrawInstruction.params.fromAddress,\n            amount: stakingWithdrawInstruction.params.amount,\n          });\n          outputAmount = outputAmount.plus(stakingWithdrawInstruction.params.amount);\n          break;\n        case InstructionBuilderTypes.CreateAssociatedTokenAccount:\n          break;\n        default:\n          continue;\n      }\n\n      // After deserializing a transaction, durable nonce details are populated in the nonceInfo field\n      if (!durableNonce && this._solTransaction.nonceInfo) {\n        const nonceAdvanceInstruction = SystemInstruction.decodeNonceAdvance(\n          this._solTransaction.nonceInfo.nonceInstruction\n        );\n        durableNonce = {\n          authWalletAddress: nonceAdvanceInstruction.authorizedPubkey.toString(),\n          walletNonceAddress: nonceAdvanceInstruction.noncePubkey.toString(),\n        };\n      }\n    }\n\n    return this.getExplainedTransaction(outputAmount, outputs, memo, durableNonce);\n  }\n\n  private calculateFee(): string {\n    if (this.lamportsPerSignature || this.tokenAccountRentExemptAmount) {\n      const signatureFees = this.lamportsPerSignature\n        ? new BigNumber(this.lamportsPerSignature).multipliedBy(this.numberOfRequiredSignatures).toFixed(0)\n        : 0;\n      const rentFees = this.tokenAccountRentExemptAmount\n        ? new BigNumber(this.tokenAccountRentExemptAmount).multipliedBy(this.numberOfATACreationInstructions).toFixed(0)\n        : 0;\n      return new BigNumber(signatureFees).plus(rentFees).toFixed(0);\n    }\n    return UNAVAILABLE_TEXT;\n  }\n\n  protected getExplainedTransaction(\n    outputAmount: BigNumber,\n    outputs: TransactionRecipient[],\n    memo: undefined | string = undefined,\n    durableNonce: undefined | DurableNonceParams = undefined\n  ): TransactionExplanation {\n    const feeString = this.calculateFee();\n    return {\n      displayOrder: [\n        'id',\n        'type',\n        'blockhash',\n        'durableNonce',\n        'outputAmount',\n        'changeAmount',\n        'outputs',\n        'changeOutputs',\n        'fee',\n        'memo',\n      ],\n      id: this.id,\n      type: TransactionType[this.type].toString(),\n      changeOutputs: [],\n      changeAmount: '0',\n      outputAmount: outputAmount.toFixed(0),\n      outputs: outputs,\n      fee: {\n        fee: feeString,\n        feeRate: this.lamportsPerSignature,\n      },\n      memo: memo,\n      blockhash: this.getNonce(),\n      durableNonce: durableNonce,\n    };\n  }\n}\n"]}
@@ -10,6 +10,7 @@ export declare abstract class TransactionBuilder extends BaseTransactionBuilder
10
10
  protected _transaction: Transaction;
11
11
  private _signatures;
12
12
  private _lamportsPerSignature;
13
+ private _tokenAccountRentExemptAmount;
13
14
  protected _sender: string;
14
15
  protected _recentBlockhash: Blockhash;
15
16
  protected _nonceInfo: Nonce;
@@ -70,6 +71,13 @@ export declare abstract class TransactionBuilder extends BaseTransactionBuilder
70
71
  memo(memo: string): this;
71
72
  fee(feeOptions: FeeOptions): this;
72
73
  feePayer(feePayer: string): this;
74
+ /**
75
+ * Used to set the minimum rent exempt amount for an ATA
76
+ *
77
+ * @param tokenAccountRentExemptAmount minimum rent exempt amount in lamports
78
+ */
79
+ associatedTokenAccountRent(tokenAccountRentExemptAmount: string): this;
80
+ private validateRentExemptAmount;
73
81
  /** @inheritdoc */
74
82
  validateAddress(address: BaseAddress, addressFormat?: string): void;
75
83
  /** @inheritdoc */
@@ -1 +1 @@
1
- {"version":3,"file":"transactionBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":";AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EACL,WAAW,EACX,OAAO,EACP,sBAAsB,EAEtB,UAAU,EACV,SAAS,IAAI,aAAa,EAG1B,eAAe,EAChB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,SAAS,EAAa,WAAW,IAAI,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAEtF,OAAO,EAAE,OAAO,EAAE,MAAM,GAAG,CAAC;AAI5B,OAAO,EAAE,kBAAkB,EAAE,iBAAiB,EAAQ,KAAK,EAAY,MAAM,SAAS,CAAC;AAGvF,8BAAsB,kBAAmB,SAAQ,sBAAsB;IACrE,SAAS,CAAC,YAAY,EAAE,WAAW,CAAC;IACpC,OAAO,CAAC,WAAW,CAAmB;IACtC,OAAO,CAAC,qBAAqB,CAAS;IAEtC,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC;IAC1B,SAAS,CAAC,gBAAgB,EAAE,SAAS,CAAC;IACtC,SAAS,CAAC,UAAU,EAAE,KAAK,CAAC;IAC5B,SAAS,CAAC,iBAAiB,EAAE,iBAAiB,EAAE,CAAM;IACtD,SAAS,CAAC,QAAQ,EAAE,OAAO,EAAE,CAAM;IACnC,SAAS,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IACzB,SAAS,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC;gBAEjB,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAK7C;;OAEG;IACH,SAAS,CAAC,QAAQ,KAAK,eAAe,IAAI,eAAe,CAAC;IAE1D;;;;OAIG;IACH,WAAW,CAAC,EAAE,EAAE,WAAW,GAAG,IAAI;IAgClC,kBAAkB;IAClB,SAAS,CAAC,kBAAkB,CAAC,cAAc,EAAE,MAAM,GAAG,WAAW;IAQjE,kBAAkB;cACF,mBAAmB,IAAI,OAAO,CAAC,WAAW,CAAC;IAO3D;;OAEG;IACH,SAAS,CAAC,mBAAmB,IAAI,cAAc;IAoD/C,kBAAkB;IAClB,SAAS,KAAK,WAAW,IAAI,WAAW,CAEvC;IAED,kBAAkB;IAClB,SAAS,KAAK,WAAW,CAAC,WAAW,EAAE,WAAW,EAEjD;IAED,kBAAkB;IAClB,SAAS,CAAC,kBAAkB,CAAC,GAAG,EAAE,OAAO,GAAG,WAAW;IAUvD,kBAAkB;IAClB,YAAY,CAAC,SAAS,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAI/D;;;;;;OAMG;IACH,MAAM,CAAC,aAAa,EAAE,MAAM,GAAG,IAAI;IAMnC;;;;;;;OAOG;IACH,KAAK,CAAC,SAAS,EAAE,SAAS,EAAE,kBAAkB,CAAC,EAAE,kBAAkB,GAAG,IAAI;IAmB1E;;;;;OAKG;IACH,IAAI,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAMxB,GAAG,CAAC,UAAU,EAAE,UAAU,GAAG,IAAI;IAKjC,QAAQ,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAQhC,kBAAkB;IAClB,eAAe,CAAC,OAAO,EAAE,WAAW,EAAE,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI;IAMnE,kBAAkB;IAClB,WAAW,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI;IAa/B,kBAAkB;IAClB,sBAAsB,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IAIpD,kBAAkB;IAClB,mBAAmB,CAAC,WAAW,CAAC,EAAE,WAAW,GAAG,IAAI;IAKpD,kBAAkB;IAClB,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI;IAKrC;;;OAGG;IACH,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAShC;;;;OAIG;IACH,OAAO,CAAC,qBAAqB;IAQ7B;;OAEG;IACH,OAAO,CAAC,cAAc;IAMtB;;OAEG;IACH,OAAO,CAAC,aAAa;CAMtB"}
1
+ {"version":3,"file":"transactionBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"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"}