@bitgo-beta/sdk-coin-sol 2.4.3-beta.98 → 2.4.3-beta.981
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 +968 -0
- package/dist/src/index.js +6 -2
- package/dist/src/lib/ataInitializationBuilder.d.ts.map +1 -1
- package/dist/src/lib/ataInitializationBuilder.js +60 -22
- package/dist/src/lib/closeAtaBuilder.d.ts +19 -0
- package/dist/src/lib/closeAtaBuilder.d.ts.map +1 -0
- package/dist/src/lib/closeAtaBuilder.js +69 -0
- package/dist/src/lib/constants.d.ts +35 -8
- package/dist/src/lib/constants.d.ts.map +1 -1
- package/dist/src/lib/constants.js +39 -10
- package/dist/src/lib/iface.d.ts +45 -4
- package/dist/src/lib/iface.d.ts.map +1 -1
- package/dist/src/lib/iface.js +1 -1
- package/dist/src/lib/index.d.ts +12 -9
- package/dist/src/lib/index.d.ts.map +1 -1
- package/dist/src/lib/index.js +46 -26
- package/dist/src/lib/instructionParamsFactory.d.ts +1 -1
- package/dist/src/lib/instructionParamsFactory.d.ts.map +1 -1
- package/dist/src/lib/instructionParamsFactory.js +287 -60
- package/dist/src/lib/keyPair.js +5 -5
- package/dist/src/lib/messages/index.d.ts +2 -0
- package/dist/src/lib/messages/index.d.ts.map +1 -0
- package/dist/src/lib/messages/index.js +18 -0
- package/dist/src/lib/messages/messageBuilderFactory.d.ts +7 -0
- package/dist/src/lib/messages/messageBuilderFactory.d.ts.map +1 -0
- package/dist/src/lib/messages/messageBuilderFactory.js +19 -0
- package/dist/src/lib/solInstructionFactory.d.ts.map +1 -1
- package/dist/src/lib/solInstructionFactory.js +146 -53
- package/dist/src/lib/stakingActivateBuilder.d.ts +9 -2
- package/dist/src/lib/stakingActivateBuilder.d.ts.map +1 -1
- package/dist/src/lib/stakingActivateBuilder.js +23 -10
- package/dist/src/lib/stakingAuthorizeBuilder.js +7 -7
- package/dist/src/lib/stakingDeactivateBuilder.d.ts +26 -1
- package/dist/src/lib/stakingDeactivateBuilder.d.ts.map +1 -1
- package/dist/src/lib/stakingDeactivateBuilder.js +106 -25
- package/dist/src/lib/stakingDelegateBuilder.d.ts +42 -0
- package/dist/src/lib/stakingDelegateBuilder.d.ts.map +1 -0
- package/dist/src/lib/stakingDelegateBuilder.js +120 -0
- package/dist/src/lib/stakingRawMsgAuthorizeBuilder.d.ts.map +1 -1
- package/dist/src/lib/stakingRawMsgAuthorizeBuilder.js +9 -5
- package/dist/src/lib/stakingWithdrawBuilder.js +6 -6
- package/dist/src/lib/tokenTransferBuilder.d.ts +4 -1
- package/dist/src/lib/tokenTransferBuilder.d.ts.map +1 -1
- package/dist/src/lib/tokenTransferBuilder.js +87 -23
- package/dist/src/lib/transaction.d.ts +12 -3
- package/dist/src/lib/transaction.d.ts.map +1 -1
- package/dist/src/lib/transaction.js +61 -26
- package/dist/src/lib/transactionBuilder.d.ts +2 -1
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilder.js +30 -19
- package/dist/src/lib/transactionBuilderFactory.d.ts +22 -9
- package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilderFactory.js +32 -10
- package/dist/src/lib/transferBuilder.js +4 -4
- package/dist/src/lib/transferBuilderV2.d.ts +14 -1
- package/dist/src/lib/transferBuilderV2.d.ts.map +1 -1
- package/dist/src/lib/transferBuilderV2.js +114 -11
- package/dist/src/lib/utils.d.ts +16 -6
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +145 -53
- package/dist/src/lib/walletInitializationBuilder.js +6 -6
- package/dist/src/sol.d.ts +71 -25
- package/dist/src/sol.d.ts.map +1 -1
- package/dist/src/sol.js +615 -81
- package/dist/src/solToken.d.ts +2 -1
- package/dist/src/solToken.d.ts.map +1 -1
- package/dist/src/solToken.js +6 -3
- package/dist/src/tsol.js +1 -1
- package/package.json +10 -9
|
@@ -7,14 +7,15 @@ exports.TransferBuilderV2 = void 0;
|
|
|
7
7
|
const transactionBuilder_1 = require("./transactionBuilder");
|
|
8
8
|
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
9
9
|
const utils_1 = require("./utils");
|
|
10
|
-
const statics_1 = require("@bitgo-beta/statics");
|
|
11
10
|
const assert_1 = __importDefault(require("assert"));
|
|
12
11
|
const constants_1 = require("./constants");
|
|
12
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
13
13
|
const UNSIGNED_BIGINT_MAX = BigInt('18446744073709551615');
|
|
14
14
|
class TransferBuilderV2 extends transactionBuilder_1.TransactionBuilder {
|
|
15
15
|
constructor(_coinConfig) {
|
|
16
16
|
super(_coinConfig);
|
|
17
17
|
this._sendParams = [];
|
|
18
|
+
this._createAtaParams = [];
|
|
18
19
|
}
|
|
19
20
|
get transactionType() {
|
|
20
21
|
return sdk_core_1.TransactionType.Send;
|
|
@@ -39,6 +40,14 @@ class TransferBuilderV2 extends transactionBuilder_1.TransactionBuilder {
|
|
|
39
40
|
tokenName: transferInstruction.params.tokenName,
|
|
40
41
|
});
|
|
41
42
|
}
|
|
43
|
+
else if (instruction.type === constants_1.InstructionBuilderTypes.CreateAssociatedTokenAccount) {
|
|
44
|
+
const ataInitInstruction = instruction;
|
|
45
|
+
this._createAtaParams.push({
|
|
46
|
+
ownerAddress: ataInitInstruction.params.ownerAddress,
|
|
47
|
+
tokenName: ataInitInstruction.params.tokenName,
|
|
48
|
+
ataAddress: ataInitInstruction.params.ataAddress,
|
|
49
|
+
});
|
|
50
|
+
}
|
|
42
51
|
}
|
|
43
52
|
}
|
|
44
53
|
/**
|
|
@@ -46,7 +55,7 @@ class TransferBuilderV2 extends transactionBuilder_1.TransactionBuilder {
|
|
|
46
55
|
* @param payerAddress
|
|
47
56
|
*/
|
|
48
57
|
feePayer(payerAddress) {
|
|
49
|
-
utils_1.validateAddress(payerAddress, 'address');
|
|
58
|
+
(0, utils_1.validateAddress)(payerAddress, 'address');
|
|
50
59
|
this._feePayer = payerAddress;
|
|
51
60
|
return this;
|
|
52
61
|
}
|
|
@@ -57,8 +66,8 @@ class TransferBuilderV2 extends transactionBuilder_1.TransactionBuilder {
|
|
|
57
66
|
* @returns {TransactionBuilder} This transaction builder
|
|
58
67
|
*/
|
|
59
68
|
send(sendParams) {
|
|
60
|
-
utils_1.validateAddress(sendParams.address, 'address');
|
|
61
|
-
if (!sendParams.amount || !utils_1.isValidAmount(sendParams.amount)) {
|
|
69
|
+
(0, utils_1.validateAddress)(sendParams.address, 'address');
|
|
70
|
+
if (!sendParams.amount || !(0, utils_1.isValidAmount)(sendParams.amount)) {
|
|
62
71
|
throw new sdk_core_1.BuildTransactionError('Invalid or missing amount, got: ' + sendParams.amount);
|
|
63
72
|
}
|
|
64
73
|
if (sendParams.tokenName && BigInt(sendParams.amount) > UNSIGNED_BIGINT_MAX) {
|
|
@@ -70,22 +79,67 @@ class TransferBuilderV2 extends transactionBuilder_1.TransactionBuilder {
|
|
|
70
79
|
this._sendParams.push(sendParams);
|
|
71
80
|
return this;
|
|
72
81
|
}
|
|
82
|
+
/**
|
|
83
|
+
*
|
|
84
|
+
* @param {TokenAssociateRecipient} recipient - recipient of the associated token account creation
|
|
85
|
+
* @param {string} recipient.ownerAddress - owner of the associated token account
|
|
86
|
+
* @param {string} recipient.tokenName - name of the token that is intended to associate
|
|
87
|
+
* @returns {TransactionBuilder} This transaction builder
|
|
88
|
+
*/
|
|
89
|
+
createAssociatedTokenAccount(recipient) {
|
|
90
|
+
(0, utils_1.validateOwnerAddress)(recipient.ownerAddress);
|
|
91
|
+
const token = (0, utils_1.getSolTokenFromTokenName)(recipient.tokenName);
|
|
92
|
+
let tokenAddress;
|
|
93
|
+
if (recipient.tokenAddress) {
|
|
94
|
+
tokenAddress = recipient.tokenAddress;
|
|
95
|
+
}
|
|
96
|
+
else if (token) {
|
|
97
|
+
tokenAddress = token.tokenAddress;
|
|
98
|
+
}
|
|
99
|
+
if (!tokenAddress) {
|
|
100
|
+
throw new sdk_core_1.BuildTransactionError('Invalid token name, got: ' + recipient.tokenName);
|
|
101
|
+
}
|
|
102
|
+
(0, utils_1.validateMintAddress)(tokenAddress);
|
|
103
|
+
this._createAtaParams.push(recipient);
|
|
104
|
+
return this;
|
|
105
|
+
}
|
|
73
106
|
/** @inheritdoc */
|
|
74
107
|
async buildImplementation() {
|
|
75
|
-
assert_1.default(this._sender, 'Sender must be set before building the transaction');
|
|
76
|
-
|
|
108
|
+
(0, assert_1.default)(this._sender, 'Sender must be set before building the transaction');
|
|
109
|
+
const sendInstructions = await Promise.all(this._sendParams.map(async (sendParams) => {
|
|
77
110
|
if (sendParams.tokenName) {
|
|
78
|
-
const coin = utils_1.getSolTokenFromTokenName(sendParams.tokenName);
|
|
79
|
-
|
|
80
|
-
|
|
111
|
+
const coin = (0, utils_1.getSolTokenFromTokenName)(sendParams.tokenName);
|
|
112
|
+
let tokenAddress;
|
|
113
|
+
let tokenName;
|
|
114
|
+
let programId;
|
|
115
|
+
let decimals;
|
|
116
|
+
if (sendParams.tokenAddress && sendParams.programId && sendParams.decimalPlaces) {
|
|
117
|
+
tokenName = sendParams.tokenName;
|
|
118
|
+
tokenAddress = sendParams.tokenAddress;
|
|
119
|
+
decimals = sendParams.decimalPlaces;
|
|
120
|
+
programId = sendParams.programId;
|
|
121
|
+
}
|
|
122
|
+
else if (coin) {
|
|
123
|
+
tokenName = coin.name;
|
|
124
|
+
tokenAddress = coin.tokenAddress;
|
|
125
|
+
decimals = coin.decimalPlaces;
|
|
126
|
+
programId = coin.programId;
|
|
127
|
+
}
|
|
128
|
+
else {
|
|
129
|
+
throw new Error(`Could not determine token information for ${sendParams.tokenName}`);
|
|
130
|
+
}
|
|
131
|
+
const sourceAddress = await (0, utils_1.getAssociatedTokenAccountAddress)(tokenAddress, this._sender, false, programId);
|
|
81
132
|
return {
|
|
82
133
|
type: constants_1.InstructionBuilderTypes.TokenTransfer,
|
|
83
134
|
params: {
|
|
84
135
|
fromAddress: this._sender,
|
|
85
136
|
toAddress: sendParams.address,
|
|
86
137
|
amount: sendParams.amount,
|
|
87
|
-
tokenName:
|
|
138
|
+
tokenName: tokenName,
|
|
88
139
|
sourceAddress: sourceAddress,
|
|
140
|
+
tokenAddress: tokenAddress,
|
|
141
|
+
programId: programId,
|
|
142
|
+
decimalPlaces: decimals,
|
|
89
143
|
},
|
|
90
144
|
};
|
|
91
145
|
}
|
|
@@ -100,8 +154,57 @@ class TransferBuilderV2 extends transactionBuilder_1.TransactionBuilder {
|
|
|
100
154
|
};
|
|
101
155
|
}
|
|
102
156
|
}));
|
|
157
|
+
const uniqueCreateAtaParams = lodash_1.default.uniqBy(this._createAtaParams, (recipient) => {
|
|
158
|
+
return recipient.ownerAddress + recipient.tokenName;
|
|
159
|
+
});
|
|
160
|
+
const createAtaInstructions = await Promise.all(uniqueCreateAtaParams.map(async (recipient) => {
|
|
161
|
+
const coin = (0, utils_1.getSolTokenFromTokenName)(recipient.tokenName);
|
|
162
|
+
let tokenAddress;
|
|
163
|
+
let tokenName;
|
|
164
|
+
let programId;
|
|
165
|
+
if (recipient.tokenAddress && recipient.programId) {
|
|
166
|
+
tokenName = recipient.tokenName;
|
|
167
|
+
tokenAddress = recipient.tokenAddress;
|
|
168
|
+
programId = recipient.programId;
|
|
169
|
+
}
|
|
170
|
+
else if (coin) {
|
|
171
|
+
tokenName = coin.name;
|
|
172
|
+
tokenAddress = coin.tokenAddress;
|
|
173
|
+
programId = coin.programId;
|
|
174
|
+
}
|
|
175
|
+
else {
|
|
176
|
+
throw new Error(`Could not determine token information for ${recipient.tokenName}`);
|
|
177
|
+
}
|
|
178
|
+
const recipientTokenAddress = await (0, utils_1.getAssociatedTokenAccountAddress)(tokenAddress, recipient.ownerAddress, false, programId);
|
|
179
|
+
return {
|
|
180
|
+
type: constants_1.InstructionBuilderTypes.CreateAssociatedTokenAccount,
|
|
181
|
+
params: {
|
|
182
|
+
ownerAddress: recipient.ownerAddress,
|
|
183
|
+
tokenName: tokenName,
|
|
184
|
+
mintAddress: tokenAddress,
|
|
185
|
+
ataAddress: recipientTokenAddress,
|
|
186
|
+
payerAddress: this._sender,
|
|
187
|
+
programId: programId,
|
|
188
|
+
},
|
|
189
|
+
};
|
|
190
|
+
}));
|
|
191
|
+
let addPriorityFeeInstruction;
|
|
192
|
+
// If there are createAtaInstructions, then token is involved and we need to add a priority fee instruction
|
|
193
|
+
if (!this._priorityFee || this._priorityFee === Number(0)) {
|
|
194
|
+
this._instructionsData = [...createAtaInstructions, ...sendInstructions];
|
|
195
|
+
}
|
|
196
|
+
else if (createAtaInstructions.length !== 0 ||
|
|
197
|
+
sendInstructions.some((instruction) => instruction.type === constants_1.InstructionBuilderTypes.TokenTransfer)) {
|
|
198
|
+
addPriorityFeeInstruction = {
|
|
199
|
+
type: constants_1.InstructionBuilderTypes.SetPriorityFee,
|
|
200
|
+
params: {
|
|
201
|
+
fee: this._priorityFee,
|
|
202
|
+
},
|
|
203
|
+
};
|
|
204
|
+
this._instructionsData = [addPriorityFeeInstruction, ...createAtaInstructions, ...sendInstructions];
|
|
205
|
+
}
|
|
103
206
|
return await super.buildImplementation();
|
|
104
207
|
}
|
|
105
208
|
}
|
|
106
209
|
exports.TransferBuilderV2 = TransferBuilderV2;
|
|
107
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transferBuilderV2.js","sourceRoot":"","sources":["../../../src/lib/transferBuilderV2.ts"],"names":[],"mappings":"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","sourcesContent":["import { TransactionBuilder } from './transactionBuilder';\nimport { BuildTransactionError, TransactionType } from '@bitgo-beta/sdk-core';\nimport { getAssociatedTokenAccountAddress, getSolTokenFromTokenName, isValidAmount, validateAddress } from './utils';\nimport { BaseCoin as CoinConfig, SolCoin } from '@bitgo-beta/statics';\nimport { Transaction } from './transaction';\nimport assert from 'assert';\nimport { TokenTransfer, Transfer } from './iface';\nimport { InstructionBuilderTypes } from './constants';\n\nexport interface SendParams {\n  address: string;\n  amount: string;\n  tokenName?: string;\n}\n\nconst UNSIGNED_BIGINT_MAX = BigInt('18446744073709551615');\n\nexport class TransferBuilderV2 extends TransactionBuilder {\n  private _sendParams: SendParams[] = [];\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\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.Transfer) {\n        const transferInstruction: Transfer = instruction;\n        this.sender(transferInstruction.params.fromAddress);\n        this.send({\n          address: transferInstruction.params.toAddress,\n          amount: transferInstruction.params.amount,\n        });\n      } else 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    }\n  }\n\n  /**\n   * Set a feePayer\n   * @param payerAddress\n   */\n  feePayer(payerAddress: string): this {\n    validateAddress(payerAddress, 'address');\n    this._feePayer = payerAddress;\n    return this;\n  }\n\n  /**\n   *  Set a transfer\n   *\n   * @param {SendParams} sendParams - sendParams\n   * @returns {TransactionBuilder} This transaction builder\n   */\n  send(sendParams: SendParams): this {\n    validateAddress(sendParams.address, 'address');\n    if (!sendParams.amount || !isValidAmount(sendParams.amount)) {\n      throw new BuildTransactionError('Invalid or missing amount, got: ' + sendParams.amount);\n    }\n    if (sendParams.tokenName && BigInt(sendParams.amount) > UNSIGNED_BIGINT_MAX) {\n      throw new BuildTransactionError(`input amount ${sendParams.amount} exceeds big int limit ${UNSIGNED_BIGINT_MAX}`);\n    } else if (!sendParams.tokenName && BigInt(sendParams.amount) > BigInt(Number.MAX_SAFE_INTEGER)) {\n      throw new BuildTransactionError(\n        `input amount ${sendParams.amount} exceeds max safe int ${Number.MAX_SAFE_INTEGER}`\n      );\n    }\n\n    this._sendParams.push(sendParams);\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\n    this._instructionsData = await Promise.all(\n      this._sendParams.map(async (sendParams: SendParams): Promise<Transfer | TokenTransfer> => {\n        if (sendParams.tokenName) {\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: sendParams.tokenName,\n              sourceAddress: sourceAddress,\n            },\n          };\n        } else {\n          return {\n            type: InstructionBuilderTypes.Transfer,\n            params: {\n              fromAddress: this._sender,\n              toAddress: sendParams.address,\n              amount: sendParams.amount,\n            },\n          };\n        }\n      })\n    );\n\n    return await super.buildImplementation();\n  }\n}\n"]}
|
|
210
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transferBuilderV2.js","sourceRoot":"","sources":["../../../src/lib/transferBuilderV2.ts"],"names":[],"mappings":"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","sourcesContent":["import { TransactionBuilder } from './transactionBuilder';\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 { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport assert from 'assert';\nimport { AtaInit, TokenAssociateRecipient, TokenTransfer, Transfer, SetPriorityFee } from './iface';\nimport { InstructionBuilderTypes } from './constants';\nimport _ from 'lodash';\n\nexport interface SendParams {\n  address: string;\n  amount: string;\n  tokenName?: string;\n  tokenAddress?: string;\n  programId?: string;\n  decimalPlaces?: number;\n}\n\nconst UNSIGNED_BIGINT_MAX = BigInt('18446744073709551615');\n\nexport class TransferBuilderV2 extends TransactionBuilder {\n  private _sendParams: SendParams[] = [];\n  private _createAtaParams: TokenAssociateRecipient[];\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.Transfer) {\n        const transferInstruction: Transfer = instruction;\n        this.sender(transferInstruction.params.fromAddress);\n        this.send({\n          address: transferInstruction.params.toAddress,\n          amount: transferInstruction.params.amount,\n        });\n      } else 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      } else 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          ataAddress: ataInitInstruction.params.ataAddress,\n        });\n      }\n    }\n  }\n\n  /**\n   * Set a feePayer\n   * @param payerAddress\n   */\n  feePayer(payerAddress: string): this {\n    validateAddress(payerAddress, 'address');\n    this._feePayer = payerAddress;\n    return this;\n  }\n\n  /**\n   *  Set a transfer\n   *\n   * @param {SendParams} sendParams - sendParams\n   * @returns {TransactionBuilder} This transaction builder\n   */\n  send(sendParams: SendParams): this {\n    validateAddress(sendParams.address, 'address');\n    if (!sendParams.amount || !isValidAmount(sendParams.amount)) {\n      throw new BuildTransactionError('Invalid or missing amount, got: ' + sendParams.amount);\n    }\n    if (sendParams.tokenName && BigInt(sendParams.amount) > UNSIGNED_BIGINT_MAX) {\n      throw new BuildTransactionError(`input amount ${sendParams.amount} exceeds big int limit ${UNSIGNED_BIGINT_MAX}`);\n    } else if (!sendParams.tokenName && BigInt(sendParams.amount) > BigInt(Number.MAX_SAFE_INTEGER)) {\n      throw new BuildTransactionError(\n        `input amount ${sendParams.amount} exceeds max safe int ${Number.MAX_SAFE_INTEGER}`\n      );\n    }\n\n    this._sendParams.push(sendParams);\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    let tokenAddress;\n    if (recipient.tokenAddress) {\n      tokenAddress = recipient.tokenAddress;\n    } else if (token) {\n      tokenAddress = token.tokenAddress;\n    }\n\n    if (!tokenAddress) {\n      throw new BuildTransactionError('Invalid token name, got: ' + recipient.tokenName);\n    }\n    validateMintAddress(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<Transfer | TokenTransfer> => {\n        if (sendParams.tokenName) {\n          const coin = getSolTokenFromTokenName(sendParams.tokenName);\n          let tokenAddress: string;\n          let tokenName: string;\n          let programId: string | undefined;\n          let decimals: number | undefined;\n          if (sendParams.tokenAddress && sendParams.programId && sendParams.decimalPlaces) {\n            tokenName = sendParams.tokenName;\n            tokenAddress = sendParams.tokenAddress;\n            decimals = sendParams.decimalPlaces;\n            programId = sendParams.programId;\n          } else if (coin) {\n            tokenName = coin.name;\n            tokenAddress = coin.tokenAddress;\n            decimals = coin.decimalPlaces;\n            programId = coin.programId;\n          } else {\n            throw new Error(`Could not determine token information for ${sendParams.tokenName}`);\n          }\n\n          const sourceAddress = await getAssociatedTokenAccountAddress(tokenAddress, this._sender, false, programId);\n          return {\n            type: InstructionBuilderTypes.TokenTransfer,\n            params: {\n              fromAddress: this._sender,\n              toAddress: sendParams.address,\n              amount: sendParams.amount,\n              tokenName: tokenName,\n              sourceAddress: sourceAddress,\n              tokenAddress: tokenAddress,\n              programId: programId,\n              decimalPlaces: decimals,\n            },\n          };\n        } else {\n          return {\n            type: InstructionBuilderTypes.Transfer,\n            params: {\n              fromAddress: this._sender,\n              toAddress: sendParams.address,\n              amount: sendParams.amount,\n            },\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        let tokenAddress: string;\n        let tokenName: string;\n        let programId: string | undefined;\n        if (recipient.tokenAddress && recipient.programId) {\n          tokenName = recipient.tokenName;\n          tokenAddress = recipient.tokenAddress;\n          programId = recipient.programId;\n        } else if (coin) {\n          tokenName = coin.name;\n          tokenAddress = coin.tokenAddress;\n          programId = coin.programId;\n        } else {\n          throw new Error(`Could not determine token information for ${recipient.tokenName}`);\n        }\n        const recipientTokenAddress = await getAssociatedTokenAccountAddress(\n          tokenAddress,\n          recipient.ownerAddress,\n          false,\n          programId\n        );\n        return {\n          type: InstructionBuilderTypes.CreateAssociatedTokenAccount,\n          params: {\n            ownerAddress: recipient.ownerAddress,\n            tokenName: tokenName,\n            mintAddress: tokenAddress,\n            ataAddress: recipientTokenAddress,\n            payerAddress: this._sender,\n            programId: programId,\n          },\n        };\n      })\n    );\n\n    let addPriorityFeeInstruction: SetPriorityFee;\n    // If there are createAtaInstructions, then token is involved and we need to add a priority fee instruction\n    if (!this._priorityFee || this._priorityFee === Number(0)) {\n      this._instructionsData = [...createAtaInstructions, ...sendInstructions];\n    } else if (\n      createAtaInstructions.length !== 0 ||\n      sendInstructions.some((instruction) => instruction.type === InstructionBuilderTypes.TokenTransfer)\n    ) {\n      addPriorityFeeInstruction = {\n        type: InstructionBuilderTypes.SetPriorityFee,\n        params: {\n          fee: this._priorityFee,\n        },\n      };\n      this._instructionsData = [addPriorityFeeInstruction, ...createAtaInstructions, ...sendInstructions];\n    }\n\n    return await super.buildImplementation();\n  }\n}\n"]}
|
package/dist/src/lib/utils.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { SignaturePubkeyPair, Transaction as SolTransaction, TransactionInstruction } from '@solana/web3.js';
|
|
2
1
|
import { TransactionType } from '@bitgo-beta/sdk-core';
|
|
3
|
-
import { ValidInstructionTypes } from './iface';
|
|
4
2
|
import { BaseCoin, BaseNetwork, SolCoin } from '@bitgo-beta/statics';
|
|
3
|
+
import { SignaturePubkeyPair, Transaction as SolTransaction, TransactionInstruction } from '@solana/web3.js';
|
|
4
|
+
import { ValidInstructionTypes } from './iface';
|
|
5
5
|
/** @inheritdoc */
|
|
6
6
|
export declare function isValidAddress(address: string): boolean;
|
|
7
7
|
/** @inheritdoc */
|
|
@@ -39,9 +39,11 @@ export declare function isValidMemo(memo: string): boolean;
|
|
|
39
39
|
* Checks if raw transaction can be deserialized
|
|
40
40
|
*
|
|
41
41
|
* @param {string} rawTransaction - transaction in base64 string format
|
|
42
|
+
* @param {boolean} requireAllSignatures - require all signatures to be present
|
|
43
|
+
* @param {boolean} verifySignatures - verify signatures
|
|
42
44
|
* @returns {boolean} - the validation result
|
|
43
45
|
*/
|
|
44
|
-
export declare function isValidRawTransaction(rawTransaction: string): boolean;
|
|
46
|
+
export declare function isValidRawTransaction(rawTransaction: string, requireAllSignatures?: boolean, verifySignatures?: boolean): boolean;
|
|
45
47
|
/**
|
|
46
48
|
* Verifies if signature for message is valid.
|
|
47
49
|
*
|
|
@@ -124,7 +126,7 @@ export declare function validateRawMsgInstruction(instructions: TransactionInstr
|
|
|
124
126
|
*
|
|
125
127
|
* @param {string} rawTransaction - Transaction in base64 string format
|
|
126
128
|
*/
|
|
127
|
-
export declare function validateRawTransaction(rawTransaction: string): void;
|
|
129
|
+
export declare function validateRawTransaction(rawTransaction: string, requireAllSignatures?: boolean, verifySignatures?: boolean): void;
|
|
128
130
|
/**
|
|
129
131
|
* Validates address to check if it exists and is a valid Solana public key
|
|
130
132
|
*
|
|
@@ -140,6 +142,14 @@ export declare function validateAddress(address: string, fieldName: string): voi
|
|
|
140
142
|
* @returns statics BaseCoin object for the matching token
|
|
141
143
|
*/
|
|
142
144
|
export declare function getSolTokenFromAddress(tokenAddress: string, network: BaseNetwork): Readonly<BaseCoin> | undefined;
|
|
145
|
+
/**
|
|
146
|
+
* Get the statics coin object matching a given Solana token address if it exists
|
|
147
|
+
*
|
|
148
|
+
* @param tokenAddress The token address to match against
|
|
149
|
+
* @param network Solana Mainnet or Testnet
|
|
150
|
+
* @returns statics BaseCoin object for the matching token
|
|
151
|
+
*/
|
|
152
|
+
export declare function getSolTokenFromAddressOnly(tokenAddress: string): Readonly<BaseCoin> | undefined;
|
|
143
153
|
/**
|
|
144
154
|
* Get the solana token object from token name
|
|
145
155
|
* @param tokenName The token name to match against
|
|
@@ -147,11 +157,11 @@ export declare function getSolTokenFromAddress(tokenAddress: string, network: Ba
|
|
|
147
157
|
export declare function getSolTokenFromTokenName(tokenName: string): Readonly<SolCoin> | undefined;
|
|
148
158
|
/**
|
|
149
159
|
* Get the solana associated token account address
|
|
150
|
-
* @param tokenAddress
|
|
160
|
+
* @param tokenAddress token mint address
|
|
151
161
|
* @param ownerAddress The owner of the associated token account
|
|
152
162
|
* @returns The associated token account address
|
|
153
163
|
* */
|
|
154
|
-
export declare function getAssociatedTokenAccountAddress(
|
|
164
|
+
export declare function getAssociatedTokenAccountAddress(tokenMintAddress: string, ownerAddress: string, allowOwnerOffCurve?: boolean, programId?: string): Promise<string>;
|
|
155
165
|
export declare function validateMintAddress(mintAddress: string): void;
|
|
156
166
|
export declare function validateOwnerAddress(ownerAddress: string): void;
|
|
157
167
|
//# sourceMappingURL=utils.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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"}
|