@bitgo-beta/sdk-coin-sol 2.4.3-beta.83 → 2.4.3-beta.830
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 +910 -0
- package/dist/src/index.js +6 -2
- package/dist/src/lib/ataInitializationBuilder.js +33 -19
- 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 +25 -7
- package/dist/src/lib/constants.d.ts.map +1 -1
- package/dist/src/lib/constants.js +29 -9
- package/dist/src/lib/iface.d.ts +43 -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 +11 -8
- package/dist/src/lib/index.d.ts.map +1 -1
- package/dist/src/lib/index.js +44 -24
- package/dist/src/lib/instructionParamsFactory.d.ts.map +1 -1
- package/dist/src/lib/instructionParamsFactory.js +243 -43
- package/dist/src/lib/keyPair.js +5 -5
- package/dist/src/lib/solInstructionFactory.d.ts.map +1 -1
- package/dist/src/lib/solInstructionFactory.js +88 -43
- package/dist/src/lib/stakingActivateBuilder.d.ts +2 -2
- package/dist/src/lib/stakingActivateBuilder.js +10 -10
- package/dist/src/lib/stakingAuthorizeBuilder.js +7 -7
- package/dist/src/lib/stakingDeactivateBuilder.d.ts +10 -0
- package/dist/src/lib/stakingDeactivateBuilder.d.ts.map +1 -1
- package/dist/src/lib/stakingDeactivateBuilder.js +71 -24
- 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 +33 -0
- package/dist/src/lib/stakingRawMsgAuthorizeBuilder.d.ts.map +1 -0
- package/dist/src/lib/stakingRawMsgAuthorizeBuilder.js +110 -0
- package/dist/src/lib/stakingWithdrawBuilder.js +6 -6
- package/dist/src/lib/tokenTransferBuilder.d.ts.map +1 -1
- package/dist/src/lib/tokenTransferBuilder.js +26 -15
- package/dist/src/lib/transaction.d.ts +3 -3
- package/dist/src/lib/transaction.d.ts.map +1 -1
- package/dist/src/lib/transaction.js +93 -16
- 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 +29 -19
- package/dist/src/lib/transactionBuilderFactory.d.ts +30 -9
- package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilderFactory.js +46 -9
- package/dist/src/lib/transferBuilder.js +4 -4
- package/dist/src/lib/transferBuilderV2.d.ts +11 -1
- package/dist/src/lib/transferBuilderV2.d.ts.map +1 -1
- package/dist/src/lib/transferBuilderV2.js +69 -10
- package/dist/src/lib/utils.d.ts +15 -6
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +114 -48
- package/dist/src/lib/walletInitializationBuilder.js +6 -6
- package/dist/src/sol.d.ts +68 -25
- package/dist/src/sol.d.ts.map +1 -1
- package/dist/src/sol.js +609 -84
- 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
|
@@ -37,7 +37,7 @@ class StakingAuthorizeBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
|
37
37
|
* @see https://docs.solana.com/staking/stake-accounts#account-address
|
|
38
38
|
*/
|
|
39
39
|
stakingAddress(stakingAddress) {
|
|
40
|
-
utils_1.validateAddress(stakingAddress, 'stakingAddress');
|
|
40
|
+
(0, utils_1.validateAddress)(stakingAddress, 'stakingAddress');
|
|
41
41
|
this._stakingAddress = stakingAddress;
|
|
42
42
|
return this;
|
|
43
43
|
}
|
|
@@ -50,7 +50,7 @@ class StakingAuthorizeBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
|
50
50
|
* @see https://docs.solana.com/staking/stake-accounts#account-address
|
|
51
51
|
*/
|
|
52
52
|
newAuthorizedAddress(newAuthorizedAddress) {
|
|
53
|
-
utils_1.validateAddress(newAuthorizedAddress, 'newAuthorizedAddress');
|
|
53
|
+
(0, utils_1.validateAddress)(newAuthorizedAddress, 'newAuthorizedAddress');
|
|
54
54
|
this._newAuthorizedAddress = newAuthorizedAddress;
|
|
55
55
|
return this;
|
|
56
56
|
}
|
|
@@ -63,15 +63,15 @@ class StakingAuthorizeBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
|
63
63
|
* @see https://docs.solana.com/staking/stake-accounts#account-address
|
|
64
64
|
*/
|
|
65
65
|
oldAuthorizedAddress(oldAuthorizedAddress) {
|
|
66
|
-
utils_1.validateAddress(oldAuthorizedAddress, 'oldAuthorizedAddress');
|
|
66
|
+
(0, utils_1.validateAddress)(oldAuthorizedAddress, 'oldAuthorizedAddress');
|
|
67
67
|
this._oldAuthorizedAddress = oldAuthorizedAddress;
|
|
68
68
|
return this;
|
|
69
69
|
}
|
|
70
70
|
/** @inheritdoc */
|
|
71
71
|
async buildImplementation() {
|
|
72
|
-
assert_1.default(this._stakingAddress, 'Staking Address must be set before building the transaction');
|
|
73
|
-
assert_1.default(this._newAuthorizedAddress, 'new authorized Address must be set before building the transaction');
|
|
74
|
-
assert_1.default(this._oldAuthorizedAddress, 'old authorized Address must be set before building the transaction');
|
|
72
|
+
(0, assert_1.default)(this._stakingAddress, 'Staking Address must be set before building the transaction');
|
|
73
|
+
(0, assert_1.default)(this._newAuthorizedAddress, 'new authorized Address must be set before building the transaction');
|
|
74
|
+
(0, assert_1.default)(this._oldAuthorizedAddress, 'old authorized Address must be set before building the transaction');
|
|
75
75
|
const stakingAccountData = {
|
|
76
76
|
type: constants_1.InstructionBuilderTypes.StakingAuthorize,
|
|
77
77
|
params: {
|
|
@@ -86,4 +86,4 @@ class StakingAuthorizeBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
|
86
86
|
}
|
|
87
87
|
}
|
|
88
88
|
exports.StakingAuthorizeBuilder = StakingAuthorizeBuilder;
|
|
89
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Rha2luZ0F1dGhvcml6ZUJ1aWxkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL3N0YWtpbmdBdXRob3JpemVCdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUNBLG1EQUF1RDtBQUV2RCw2REFBMEQ7QUFDMUQsMkNBQXNEO0FBRXRELG9EQUE0QjtBQUU1QixtQ0FBMEM7QUFFMUMsTUFBYSx1QkFBd0IsU0FBUSx1Q0FBa0I7SUFLN0QsWUFBWSxXQUFpQztRQUMzQyxLQUFLLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDckIsQ0FBQztJQUVELElBQWMsZUFBZTtRQUMzQixPQUFPLDBCQUFlLENBQUMsZ0JBQWdCLENBQUM7SUFDMUMsQ0FBQztJQUVELGtCQUFrQjtJQUNsQixXQUFXLENBQUMsRUFBZTtRQUN6QixLQUFLLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQ3RCLEtBQUssTUFBTSxXQUFXLElBQUksSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7WUFDakQsSUFBSSxXQUFXLENBQUMsSUFBSSxLQUFLLG1DQUF1QixDQUFDLGdCQUFnQixFQUFFLENBQUM7Z0JBQ2xFLE1BQU0sb0JBQW9CLEdBQXFCLFdBQVcsQ0FBQztnQkFDM0QsSUFBSSxDQUFDLGNBQWMsQ0FBQyxvQkFBb0IsQ0FBQyxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUM7Z0JBQ2hFLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxvQkFBb0IsQ0FBQyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQztnQkFDM0UsSUFBSSxDQUFDLG9CQUFvQixDQUFDLG9CQUFvQixDQUFDLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO1lBQzdFLENBQUM7UUFDSCxDQUFDO0lBQ0gsQ0FBQztJQUVEOzs7Ozs7O09BT0c7SUFDSCxjQUFjLENBQUMsY0FBc0I7UUFDbkMsSUFBQSx1QkFBZSxFQUFDLGNBQWMsRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO1FBQ2xELElBQUksQ0FBQyxlQUFlLEdBQUcsY0FBYyxDQUFDO1FBQ3RDLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVEOzs7Ozs7O09BT0c7SUFDSCxvQkFBb0IsQ0FBQyxvQkFBNEI7UUFDL0MsSUFBQSx1QkFBZSxFQUFDLG9CQUFvQixFQUFFLHNCQUFzQixDQUFDLENBQUM7UUFDOUQsSUFBSSxDQUFDLHFCQUFxQixHQUFHLG9CQUFvQixDQUFDO1FBQ2xELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVEOzs7Ozs7O09BT0c7SUFDSCxvQkFBb0IsQ0FBQyxvQkFBNEI7UUFDL0MsSUFBQSx1QkFBZSxFQUFDLG9CQUFvQixFQUFFLHNCQUFzQixDQUFDLENBQUM7UUFDOUQsSUFBSSxDQUFDLHFCQUFxQixHQUFHLG9CQUFvQixDQUFDO1FBQ2xELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELGtCQUFrQjtJQUNSLEtBQUssQ0FBQyxtQkFBbUI7UUFDakMsSUFBQSxnQkFBTSxFQUFDLElBQUksQ0FBQyxlQUFlLEVBQUUsNkRBQTZELENBQUMsQ0FBQztRQUM1RixJQUFBLGdCQUFNLEVBQUMsSUFBSSxDQUFDLHFCQUFxQixFQUFFLG9FQUFvRSxDQUFDLENBQUM7UUFDekcsSUFBQSxnQkFBTSxFQUFDLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxvRUFBb0UsQ0FBQyxDQUFDO1FBRXpHLE1BQU0sa0JBQWtCLEdBQXFCO1lBQzNDLElBQUksRUFBRSxtQ0FBdUIsQ0FBQyxnQkFBZ0I7WUFDOUMsTUFBTSxFQUFFO2dCQUNOLGNBQWMsRUFBRSxJQUFJLENBQUMsZUFBZTtnQkFDcEMsa0JBQWtCLEVBQUUsSUFBSSxDQUFDLHFCQUFxQjtnQkFDOUMsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLHFCQUFxQjtnQkFDL0MsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLHFCQUFxQjthQUNoRDtTQUNGLENBQUM7UUFDRixJQUFJLENBQUMsaUJBQWlCLEdBQUcsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBRTlDLE9BQU8sTUFBTSxLQUFLLENBQUMsbUJBQW1CLEVBQUUsQ0FBQztJQUMzQyxDQUFDO0NBQ0Y7QUF2RkQsMERBdUZDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFzZUNvaW4gYXMgQ29pbkNvbmZpZyB9IGZyb20gJ0BiaXRnby1iZXRhL3N0YXRpY3MnO1xuaW1wb3J0IHsgVHJhbnNhY3Rpb25UeXBlIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IHsgVHJhbnNhY3Rpb24gfSBmcm9tICcuL3RyYW5zYWN0aW9uJztcbmltcG9ydCB7IFRyYW5zYWN0aW9uQnVpbGRlciB9IGZyb20gJy4vdHJhbnNhY3Rpb25CdWlsZGVyJztcbmltcG9ydCB7IEluc3RydWN0aW9uQnVpbGRlclR5cGVzIH0gZnJvbSAnLi9jb25zdGFudHMnO1xuXG5pbXBvcnQgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5pbXBvcnQgeyBTdGFraW5nQXV0aG9yaXplIH0gZnJvbSAnLi9pZmFjZSc7XG5pbXBvcnQgeyB2YWxpZGF0ZUFkZHJlc3MgfSBmcm9tICcuL3V0aWxzJztcblxuZXhwb3J0IGNsYXNzIFN0YWtpbmdBdXRob3JpemVCdWlsZGVyIGV4dGVuZHMgVHJhbnNhY3Rpb25CdWlsZGVyIHtcbiAgcHJvdGVjdGVkIF9zdGFraW5nQWRkcmVzczogc3RyaW5nO1xuICBwcm90ZWN0ZWQgX25ld0F1dGhvcml6ZWRBZGRyZXNzOiBzdHJpbmc7XG4gIHByb3RlY3RlZCBfb2xkQXV0aG9yaXplZEFkZHJlc3M6IHN0cmluZztcblxuICBjb25zdHJ1Y3RvcihfY29pbkNvbmZpZzogUmVhZG9ubHk8Q29pbkNvbmZpZz4pIHtcbiAgICBzdXBlcihfY29pbkNvbmZpZyk7XG4gIH1cblxuICBwcm90ZWN0ZWQgZ2V0IHRyYW5zYWN0aW9uVHlwZSgpOiBUcmFuc2FjdGlvblR5cGUge1xuICAgIHJldHVybiBUcmFuc2FjdGlvblR5cGUuU3Rha2luZ0F1dGhvcml6ZTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICBpbml0QnVpbGRlcih0eDogVHJhbnNhY3Rpb24pOiB2b2lkIHtcbiAgICBzdXBlci5pbml0QnVpbGRlcih0eCk7XG4gICAgZm9yIChjb25zdCBpbnN0cnVjdGlvbiBvZiB0aGlzLl9pbnN0cnVjdGlvbnNEYXRhKSB7XG4gICAgICBpZiAoaW5zdHJ1Y3Rpb24udHlwZSA9PT0gSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMuU3Rha2luZ0F1dGhvcml6ZSkge1xuICAgICAgICBjb25zdCBBdXRob3JpemVJbnN0cnVjdGlvbjogU3Rha2luZ0F1dGhvcml6ZSA9IGluc3RydWN0aW9uO1xuICAgICAgICB0aGlzLnN0YWtpbmdBZGRyZXNzKEF1dGhvcml6ZUluc3RydWN0aW9uLnBhcmFtcy5zdGFraW5nQWRkcmVzcyk7XG4gICAgICAgIHRoaXMubmV3QXV0aG9yaXplZEFkZHJlc3MoQXV0aG9yaXplSW5zdHJ1Y3Rpb24ucGFyYW1zLm5ld0F1dGhvcml6ZUFkZHJlc3MpO1xuICAgICAgICB0aGlzLm9sZEF1dGhvcml6ZWRBZGRyZXNzKEF1dGhvcml6ZUluc3RydWN0aW9uLnBhcmFtcy5vbGRBdXRob3JpemVBZGRyZXNzKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogVGhlIGFkZHJlc3Mgb2YgdGhlIHN0YWtpbmcgYWNjb3VudC5cbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IHN0YWtpbmdBZGRyZXNzIHB1YmxpYyBhZGRyZXNzIG9mIHRoZSBzdGFraW5nIGFjY291bnQuXG4gICAqIEByZXR1cm5zIHtTdGFrZUJ1aWxkZXJ9IFRoaXMgc3Rha2luZyBidWlsZGVyLlxuICAgKlxuICAgKiBAc2VlIGh0dHBzOi8vZG9jcy5zb2xhbmEuY29tL3N0YWtpbmcvc3Rha2UtYWNjb3VudHMjYWNjb3VudC1hZGRyZXNzXG4gICAqL1xuICBzdGFraW5nQWRkcmVzcyhzdGFraW5nQWRkcmVzczogc3RyaW5nKTogdGhpcyB7XG4gICAgdmFsaWRhdGVBZGRyZXNzKHN0YWtpbmdBZGRyZXNzLCAnc3Rha2luZ0FkZHJlc3MnKTtcbiAgICB0aGlzLl9zdGFraW5nQWRkcmVzcyA9IHN0YWtpbmdBZGRyZXNzO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFRoZSBhZGRyZXNzIG9mIHRoZSBuZXcgc3Rha2luZyBhY2NvdW50IGF1dGhvcml6YXRpb24uXG4gICAqXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBzdGFraW5nQWRkcmVzcyBwdWJsaWMgYWRkcmVzcyBvZiB0aGUgc3Rha2luZyBhY2NvdW50LlxuICAgKiBAcmV0dXJucyB7U3Rha2VCdWlsZGVyfSBUaGlzIHN0YWtpbmcgYnVpbGRlci5cbiAgICpcbiAgICogQHNlZSBodHRwczovL2RvY3Muc29sYW5hLmNvbS9zdGFraW5nL3N0YWtlLWFjY291bnRzI2FjY291bnQtYWRkcmVzc1xuICAgKi9cbiAgbmV3QXV0aG9yaXplZEFkZHJlc3MobmV3QXV0aG9yaXplZEFkZHJlc3M6IHN0cmluZyk6IHRoaXMge1xuICAgIHZhbGlkYXRlQWRkcmVzcyhuZXdBdXRob3JpemVkQWRkcmVzcywgJ25ld0F1dGhvcml6ZWRBZGRyZXNzJyk7XG4gICAgdGhpcy5fbmV3QXV0aG9yaXplZEFkZHJlc3MgPSBuZXdBdXRob3JpemVkQWRkcmVzcztcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBUaGUgYWRkcmVzcyBvZiB0aGUgbmV3IHN0YWtpbmcgYWNjb3VudCBhdXRob3JpemF0aW9uLlxuICAgKlxuICAgKiBAcGFyYW0ge3N0cmluZ30gc3Rha2luZ0FkZHJlc3MgcHVibGljIGFkZHJlc3Mgb2YgdGhlIHN0YWtpbmcgYWNjb3VudC5cbiAgICogQHJldHVybnMge1N0YWtlQnVpbGRlcn0gVGhpcyBzdGFraW5nIGJ1aWxkZXIuXG4gICAqXG4gICAqIEBzZWUgaHR0cHM6Ly9kb2NzLnNvbGFuYS5jb20vc3Rha2luZy9zdGFrZS1hY2NvdW50cyNhY2NvdW50LWFkZHJlc3NcbiAgICovXG4gIG9sZEF1dGhvcml6ZWRBZGRyZXNzKG9sZEF1dGhvcml6ZWRBZGRyZXNzOiBzdHJpbmcpOiB0aGlzIHtcbiAgICB2YWxpZGF0ZUFkZHJlc3Mob2xkQXV0aG9yaXplZEFkZHJlc3MsICdvbGRBdXRob3JpemVkQWRkcmVzcycpO1xuICAgIHRoaXMuX29sZEF1dGhvcml6ZWRBZGRyZXNzID0gb2xkQXV0aG9yaXplZEFkZHJlc3M7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgcHJvdGVjdGVkIGFzeW5jIGJ1aWxkSW1wbGVtZW50YXRpb24oKTogUHJvbWlzZTxUcmFuc2FjdGlvbj4ge1xuICAgIGFzc2VydCh0aGlzLl9zdGFraW5nQWRkcmVzcywgJ1N0YWtpbmcgQWRkcmVzcyBtdXN0IGJlIHNldCBiZWZvcmUgYnVpbGRpbmcgdGhlIHRyYW5zYWN0aW9uJyk7XG4gICAgYXNzZXJ0KHRoaXMuX25ld0F1dGhvcml6ZWRBZGRyZXNzLCAnbmV3IGF1dGhvcml6ZWQgQWRkcmVzcyBtdXN0IGJlIHNldCBiZWZvcmUgYnVpbGRpbmcgdGhlIHRyYW5zYWN0aW9uJyk7XG4gICAgYXNzZXJ0KHRoaXMuX29sZEF1dGhvcml6ZWRBZGRyZXNzLCAnb2xkIGF1dGhvcml6ZWQgQWRkcmVzcyBtdXN0IGJlIHNldCBiZWZvcmUgYnVpbGRpbmcgdGhlIHRyYW5zYWN0aW9uJyk7XG5cbiAgICBjb25zdCBzdGFraW5nQWNjb3VudERhdGE6IFN0YWtpbmdBdXRob3JpemUgPSB7XG4gICAgICB0eXBlOiBJbnN0cnVjdGlvbkJ1aWxkZXJUeXBlcy5TdGFraW5nQXV0aG9yaXplLFxuICAgICAgcGFyYW1zOiB7XG4gICAgICAgIHN0YWtpbmdBZGRyZXNzOiB0aGlzLl9zdGFraW5nQWRkcmVzcyxcbiAgICAgICAgbmV3V2l0aGRyYXdBZGRyZXNzOiB0aGlzLl9uZXdBdXRob3JpemVkQWRkcmVzcyxcbiAgICAgICAgbmV3QXV0aG9yaXplQWRkcmVzczogdGhpcy5fbmV3QXV0aG9yaXplZEFkZHJlc3MsXG4gICAgICAgIG9sZEF1dGhvcml6ZUFkZHJlc3M6IHRoaXMuX29sZEF1dGhvcml6ZWRBZGRyZXNzLFxuICAgICAgfSxcbiAgICB9O1xuICAgIHRoaXMuX2luc3RydWN0aW9uc0RhdGEgPSBbc3Rha2luZ0FjY291bnREYXRhXTtcblxuICAgIHJldHVybiBhd2FpdCBzdXBlci5idWlsZEltcGxlbWVudGF0aW9uKCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -4,6 +4,7 @@ import { Transaction } from './transaction';
|
|
|
4
4
|
import { TransactionBuilder } from './transactionBuilder';
|
|
5
5
|
export declare class StakingDeactivateBuilder extends TransactionBuilder {
|
|
6
6
|
protected _stakingAddress: string;
|
|
7
|
+
protected _stakingAddresses: string[];
|
|
7
8
|
protected _amount?: string;
|
|
8
9
|
protected _unstakingAddress: string;
|
|
9
10
|
constructor(_coinConfig: Readonly<CoinConfig>);
|
|
@@ -19,6 +20,15 @@ export declare class StakingDeactivateBuilder extends TransactionBuilder {
|
|
|
19
20
|
* @see https://docs.solana.com/staking/stake-accounts#account-address
|
|
20
21
|
*/
|
|
21
22
|
stakingAddress(stakingAddress: string): this;
|
|
23
|
+
/**
|
|
24
|
+
* The staking addresses of the staking account.
|
|
25
|
+
*
|
|
26
|
+
* @param {string[]} stakingAddresses public address of the staking accounts
|
|
27
|
+
* @returns {StakingDeactivateBuilder} This staking deactivate builder.
|
|
28
|
+
*
|
|
29
|
+
* @see https://docs.solana.com/staking/stake-accounts#account-address
|
|
30
|
+
*/
|
|
31
|
+
stakingAddresses(stakingAddresses: string[]): this;
|
|
22
32
|
/**
|
|
23
33
|
* Optional amount to unstake expressed in Lamports, 1 SOL = 1_000_000_000 lamports, to be used
|
|
24
34
|
* when partially unstaking. If not given then the entire staked amount will be unstaked.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stakingDeactivateBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/stakingDeactivateBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAG7D,OAAO,EAAyB,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAG9E,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAG1D,qBAAa,wBAAyB,SAAQ,kBAAkB;IAC9D,SAAS,CAAC,eAAe,EAAE,MAAM,CAAC;IAClC,SAAS,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC;IAC3B,SAAS,CAAC,iBAAiB,EAAE,MAAM,CAAC;gBAExB,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED,kBAAkB;IAClB,WAAW,CAAC,EAAE,EAAE,WAAW,GAAG,IAAI;
|
|
1
|
+
{"version":3,"file":"stakingDeactivateBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/stakingDeactivateBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAG7D,OAAO,EAAyB,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAG9E,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAG1D,qBAAa,wBAAyB,SAAQ,kBAAkB;IAC9D,SAAS,CAAC,eAAe,EAAE,MAAM,CAAC;IAClC,SAAS,CAAC,iBAAiB,EAAE,MAAM,EAAE,CAAC;IACtC,SAAS,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC;IAC3B,SAAS,CAAC,iBAAiB,EAAE,MAAM,CAAC;gBAExB,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED,kBAAkB;IAClB,WAAW,CAAC,EAAE,EAAE,WAAW,GAAG,IAAI;IAqBlC;;;;;;;OAOG;IACH,cAAc,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IAM5C;;;;;;;OAOG;IACH,gBAAgB,CAAC,gBAAgB,EAAE,MAAM,EAAE,GAAG,IAAI;IAQlD;;;;;;;;OAQG;IACH,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAQ5B;;;;;;;;OAQG;IACH,gBAAgB,CAAC,gBAAgB,EAAE,MAAM,GAAG,IAAI;IAMhD,kBAAkB;cACF,mBAAmB,IAAI,OAAO,CAAC,WAAW,CAAC;CA0D5D"}
|
|
@@ -19,17 +19,24 @@ class StakingDeactivateBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
|
19
19
|
/** @inheritdoc */
|
|
20
20
|
initBuilder(tx) {
|
|
21
21
|
super.initBuilder(tx);
|
|
22
|
+
const stakingAddresses = [];
|
|
22
23
|
for (const instruction of this._instructionsData) {
|
|
23
24
|
if (instruction.type === constants_1.InstructionBuilderTypes.StakingDeactivate) {
|
|
24
25
|
const deactivateInstruction = instruction;
|
|
25
26
|
this.sender(deactivateInstruction.params.fromAddress);
|
|
26
|
-
|
|
27
|
+
stakingAddresses.push(deactivateInstruction.params.stakingAddress);
|
|
27
28
|
if (deactivateInstruction.params.amount && deactivateInstruction.params.unstakingAddress) {
|
|
28
29
|
this.amount(deactivateInstruction.params.amount);
|
|
29
30
|
this.unstakingAddress(deactivateInstruction.params.unstakingAddress);
|
|
30
31
|
}
|
|
31
32
|
}
|
|
32
33
|
}
|
|
34
|
+
if (stakingAddresses.length > 1) {
|
|
35
|
+
this.stakingAddresses(stakingAddresses);
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
this.stakingAddress(stakingAddresses[0]);
|
|
39
|
+
}
|
|
33
40
|
}
|
|
34
41
|
/**
|
|
35
42
|
* The staking address of the staking account.
|
|
@@ -40,10 +47,25 @@ class StakingDeactivateBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
|
40
47
|
* @see https://docs.solana.com/staking/stake-accounts#account-address
|
|
41
48
|
*/
|
|
42
49
|
stakingAddress(stakingAddress) {
|
|
43
|
-
utils_1.validateAddress(stakingAddress, 'stakingAddress');
|
|
50
|
+
(0, utils_1.validateAddress)(stakingAddress, 'stakingAddress');
|
|
44
51
|
this._stakingAddress = stakingAddress;
|
|
45
52
|
return this;
|
|
46
53
|
}
|
|
54
|
+
/**
|
|
55
|
+
* The staking addresses of the staking account.
|
|
56
|
+
*
|
|
57
|
+
* @param {string[]} stakingAddresses public address of the staking accounts
|
|
58
|
+
* @returns {StakingDeactivateBuilder} This staking deactivate builder.
|
|
59
|
+
*
|
|
60
|
+
* @see https://docs.solana.com/staking/stake-accounts#account-address
|
|
61
|
+
*/
|
|
62
|
+
stakingAddresses(stakingAddresses) {
|
|
63
|
+
for (const stakingAddress of stakingAddresses) {
|
|
64
|
+
(0, utils_1.validateAddress)(stakingAddress, 'stakingAddress');
|
|
65
|
+
}
|
|
66
|
+
this._stakingAddresses = stakingAddresses;
|
|
67
|
+
return this;
|
|
68
|
+
}
|
|
47
69
|
/**
|
|
48
70
|
* Optional amount to unstake expressed in Lamports, 1 SOL = 1_000_000_000 lamports, to be used
|
|
49
71
|
* when partially unstaking. If not given then the entire staked amount will be unstaked.
|
|
@@ -54,7 +76,7 @@ class StakingDeactivateBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
|
54
76
|
* @see https://docs.solana.com/cli/delegate-stake#split-stake
|
|
55
77
|
*/
|
|
56
78
|
amount(amount) {
|
|
57
|
-
if (!utils_1.isValidStakingAmount(amount)) {
|
|
79
|
+
if (!(0, utils_1.isValidStakingAmount)(amount)) {
|
|
58
80
|
throw new sdk_core_1.BuildTransactionError('If given, amount cannot be zero or less');
|
|
59
81
|
}
|
|
60
82
|
this._amount = amount;
|
|
@@ -70,35 +92,60 @@ class StakingDeactivateBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
|
70
92
|
* @see https://docs.solana.com/cli/delegate-stake#split-stake
|
|
71
93
|
*/
|
|
72
94
|
unstakingAddress(unstakingAddress) {
|
|
73
|
-
utils_1.validateAddress(unstakingAddress, 'unstakingAddress');
|
|
95
|
+
(0, utils_1.validateAddress)(unstakingAddress, 'unstakingAddress');
|
|
74
96
|
this._unstakingAddress = unstakingAddress;
|
|
75
97
|
return this;
|
|
76
98
|
}
|
|
77
99
|
/** @inheritdoc */
|
|
78
100
|
async buildImplementation() {
|
|
79
|
-
assert_1.default(this._sender, 'Sender must be set before building the transaction');
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
101
|
+
(0, assert_1.default)(this._sender, 'Sender must be set before building the transaction');
|
|
102
|
+
if (this._stakingAddresses && this._stakingAddresses.length > 0) {
|
|
103
|
+
this._instructionsData = [];
|
|
104
|
+
for (const stakingAddress of this._stakingAddresses) {
|
|
105
|
+
const stakingDeactivateData = {
|
|
106
|
+
type: constants_1.InstructionBuilderTypes.StakingDeactivate,
|
|
107
|
+
params: {
|
|
108
|
+
fromAddress: this._sender,
|
|
109
|
+
stakingAddress: stakingAddress,
|
|
110
|
+
},
|
|
111
|
+
};
|
|
112
|
+
this._instructionsData.push(stakingDeactivateData);
|
|
113
|
+
}
|
|
86
114
|
}
|
|
87
|
-
|
|
88
|
-
assert_1.default(this.
|
|
115
|
+
else {
|
|
116
|
+
(0, assert_1.default)(this._stakingAddress, 'Staking address must be set before building the transaction');
|
|
117
|
+
if (this._sender === this._stakingAddress) {
|
|
118
|
+
throw new sdk_core_1.BuildTransactionError('Sender address cannot be the same as the Staking address');
|
|
119
|
+
}
|
|
120
|
+
if (this._amount) {
|
|
121
|
+
(0, assert_1.default)(this._unstakingAddress, 'When partially unstaking the unstaking address must be set before building the transaction');
|
|
122
|
+
}
|
|
123
|
+
this._instructionsData = [];
|
|
124
|
+
if (this._unstakingAddress) {
|
|
125
|
+
(0, assert_1.default)(this._amount, 'If an unstaking address is given then a partial amount to unstake must also be set before building the transaction');
|
|
126
|
+
const stakingFundUnstakeAddress = {
|
|
127
|
+
type: constants_1.InstructionBuilderTypes.Transfer,
|
|
128
|
+
params: {
|
|
129
|
+
fromAddress: this._sender,
|
|
130
|
+
amount: constants_1.STAKE_ACCOUNT_RENT_EXEMPT_AMOUNT.toString(),
|
|
131
|
+
toAddress: this._unstakingAddress,
|
|
132
|
+
},
|
|
133
|
+
};
|
|
134
|
+
this._instructionsData.push(stakingFundUnstakeAddress);
|
|
135
|
+
}
|
|
136
|
+
const stakingDeactivateData = {
|
|
137
|
+
type: constants_1.InstructionBuilderTypes.StakingDeactivate,
|
|
138
|
+
params: {
|
|
139
|
+
fromAddress: this._sender,
|
|
140
|
+
stakingAddress: this._stakingAddress,
|
|
141
|
+
amount: this._amount,
|
|
142
|
+
unstakingAddress: this._unstakingAddress,
|
|
143
|
+
},
|
|
144
|
+
};
|
|
145
|
+
this._instructionsData.push(stakingDeactivateData);
|
|
89
146
|
}
|
|
90
|
-
const stakingDeactivateData = {
|
|
91
|
-
type: constants_1.InstructionBuilderTypes.StakingDeactivate,
|
|
92
|
-
params: {
|
|
93
|
-
fromAddress: this._sender,
|
|
94
|
-
stakingAddress: this._stakingAddress,
|
|
95
|
-
amount: this._amount,
|
|
96
|
-
unstakingAddress: this._unstakingAddress,
|
|
97
|
-
},
|
|
98
|
-
};
|
|
99
|
-
this._instructionsData = [stakingDeactivateData];
|
|
100
147
|
return await super.buildImplementation();
|
|
101
148
|
}
|
|
102
149
|
}
|
|
103
150
|
exports.StakingDeactivateBuilder = StakingDeactivateBuilder;
|
|
104
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stakingDeactivateBuilder.js","sourceRoot":"","sources":["../../../src/lib/stakingDeactivateBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport assert from 'assert';\n\nimport { BuildTransactionError, TransactionType } from '@bitgo-beta/sdk-core';\nimport { InstructionBuilderTypes } from './constants';\nimport { StakingDeactivate } from './iface';\nimport { Transaction } from './transaction';\nimport { TransactionBuilder } from './transactionBuilder';\nimport { isValidStakingAmount, validateAddress } from './utils';\n\nexport class StakingDeactivateBuilder extends TransactionBuilder {\n  protected _stakingAddress: string;\n  protected _amount?: string;\n  protected _unstakingAddress: string;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  protected get transactionType(): TransactionType {\n    return TransactionType.StakingDeactivate;\n  }\n\n  /** @inheritdoc */\n  initBuilder(tx: Transaction): void {\n    super.initBuilder(tx);\n    for (const instruction of this._instructionsData) {\n      if (instruction.type === InstructionBuilderTypes.StakingDeactivate) {\n        const deactivateInstruction: StakingDeactivate = instruction;\n        this.sender(deactivateInstruction.params.fromAddress);\n        this.stakingAddress(deactivateInstruction.params.stakingAddress);\n        if (deactivateInstruction.params.amount && deactivateInstruction.params.unstakingAddress) {\n          this.amount(deactivateInstruction.params.amount);\n          this.unstakingAddress(deactivateInstruction.params.unstakingAddress);\n        }\n      }\n    }\n  }\n\n  /**\n   * The staking address of the staking account.\n   *\n   * @param {string} stakingAddress public address of the staking account\n   * @returns {StakingDeactivateBuilder} This staking deactivate builder.\n   *\n   * @see https://docs.solana.com/staking/stake-accounts#account-address\n   */\n  stakingAddress(stakingAddress: string): this {\n    validateAddress(stakingAddress, 'stakingAddress');\n    this._stakingAddress = stakingAddress;\n    return this;\n  }\n\n  /**\n   * Optional amount to unstake expressed in Lamports, 1 SOL = 1_000_000_000 lamports, to be used\n   * when partially unstaking. If not given then the entire staked amount will be unstaked.\n   *\n   * @param {string} amount The partial amount to unstake, expressed in Lamports.\n   * @returns {StakingDeactivateBuilder} This staking builder.\n   *\n   * @see https://docs.solana.com/cli/delegate-stake#split-stake\n   */\n  amount(amount: string): this {\n    if (!isValidStakingAmount(amount)) {\n      throw new BuildTransactionError('If given, amount cannot be zero or less');\n    }\n    this._amount = amount;\n    return this;\n  }\n\n  /**\n   * When partially unstaking move the amount to unstake to this account and initiate the\n   * unstake process. The original stake account will continue staking.\n   *\n   * @param {string} unstakingAddress An account used to unstake a partial amount.\n   * @returns {StakingDeactivateBuilder} This staking builder.\n   *\n   * @see https://docs.solana.com/cli/delegate-stake#split-stake\n   */\n  unstakingAddress(unstakingAddress: string): this {\n    validateAddress(unstakingAddress, 'unstakingAddress');\n    this._unstakingAddress = unstakingAddress;\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    assert(this._stakingAddress, 'Staking address must be set before building the transaction');\n\n    if (this._sender === this._stakingAddress) {\n      throw new BuildTransactionError('Sender address cannot be the same as the Staking address');\n    }\n\n    if (this._amount) {\n      assert(\n        this._unstakingAddress,\n        'When partially unstaking the unstaking address must be set before building the transaction'\n      );\n    }\n\n    if (this._unstakingAddress) {\n      assert(\n        this._amount,\n        'If an unstaking address is given then a partial amount to unstake must also be set before building the transaction'\n      );\n    }\n\n    const stakingDeactivateData: StakingDeactivate = {\n      type: InstructionBuilderTypes.StakingDeactivate,\n      params: {\n        fromAddress: this._sender,\n        stakingAddress: this._stakingAddress,\n        amount: this._amount,\n        unstakingAddress: this._unstakingAddress,\n      },\n    };\n    this._instructionsData = [stakingDeactivateData];\n\n    return await super.buildImplementation();\n  }\n}\n"]}
|
|
151
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stakingDeactivateBuilder.js","sourceRoot":"","sources":["../../../src/lib/stakingDeactivateBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport assert from 'assert';\n\nimport { BuildTransactionError, TransactionType } from '@bitgo-beta/sdk-core';\nimport { InstructionBuilderTypes, STAKE_ACCOUNT_RENT_EXEMPT_AMOUNT } from './constants';\nimport { StakingDeactivate, Transfer } from './iface';\nimport { Transaction } from './transaction';\nimport { TransactionBuilder } from './transactionBuilder';\nimport { isValidStakingAmount, validateAddress } from './utils';\n\nexport class StakingDeactivateBuilder extends TransactionBuilder {\n  protected _stakingAddress: string;\n  protected _stakingAddresses: string[];\n  protected _amount?: string;\n  protected _unstakingAddress: string;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  protected get transactionType(): TransactionType {\n    return TransactionType.StakingDeactivate;\n  }\n\n  /** @inheritdoc */\n  initBuilder(tx: Transaction): void {\n    super.initBuilder(tx);\n    const stakingAddresses: string[] = [];\n    for (const instruction of this._instructionsData) {\n      if (instruction.type === InstructionBuilderTypes.StakingDeactivate) {\n        const deactivateInstruction: StakingDeactivate = instruction;\n        this.sender(deactivateInstruction.params.fromAddress);\n        stakingAddresses.push(deactivateInstruction.params.stakingAddress);\n        if (deactivateInstruction.params.amount && deactivateInstruction.params.unstakingAddress) {\n          this.amount(deactivateInstruction.params.amount);\n          this.unstakingAddress(deactivateInstruction.params.unstakingAddress);\n        }\n      }\n    }\n    if (stakingAddresses.length > 1) {\n      this.stakingAddresses(stakingAddresses);\n    } else {\n      this.stakingAddress(stakingAddresses[0]);\n    }\n  }\n\n  /**\n   * The staking address of the staking account.\n   *\n   * @param {string} stakingAddress public address of the staking account\n   * @returns {StakingDeactivateBuilder} This staking deactivate builder.\n   *\n   * @see https://docs.solana.com/staking/stake-accounts#account-address\n   */\n  stakingAddress(stakingAddress: string): this {\n    validateAddress(stakingAddress, 'stakingAddress');\n    this._stakingAddress = stakingAddress;\n    return this;\n  }\n\n  /**\n   * The staking addresses of the staking account.\n   *\n   * @param {string[]} stakingAddresses public address of the staking accounts\n   * @returns {StakingDeactivateBuilder} This staking deactivate builder.\n   *\n   * @see https://docs.solana.com/staking/stake-accounts#account-address\n   */\n  stakingAddresses(stakingAddresses: string[]): this {\n    for (const stakingAddress of stakingAddresses) {\n      validateAddress(stakingAddress, 'stakingAddress');\n    }\n    this._stakingAddresses = stakingAddresses;\n    return this;\n  }\n\n  /**\n   * Optional amount to unstake expressed in Lamports, 1 SOL = 1_000_000_000 lamports, to be used\n   * when partially unstaking. If not given then the entire staked amount will be unstaked.\n   *\n   * @param {string} amount The partial amount to unstake, expressed in Lamports.\n   * @returns {StakingDeactivateBuilder} This staking builder.\n   *\n   * @see https://docs.solana.com/cli/delegate-stake#split-stake\n   */\n  amount(amount: string): this {\n    if (!isValidStakingAmount(amount)) {\n      throw new BuildTransactionError('If given, amount cannot be zero or less');\n    }\n    this._amount = amount;\n    return this;\n  }\n\n  /**\n   * When partially unstaking move the amount to unstake to this account and initiate the\n   * unstake process. The original stake account will continue staking.\n   *\n   * @param {string} unstakingAddress An account used to unstake a partial amount.\n   * @returns {StakingDeactivateBuilder} This staking builder.\n   *\n   * @see https://docs.solana.com/cli/delegate-stake#split-stake\n   */\n  unstakingAddress(unstakingAddress: string): this {\n    validateAddress(unstakingAddress, 'unstakingAddress');\n    this._unstakingAddress = unstakingAddress;\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    if (this._stakingAddresses && this._stakingAddresses.length > 0) {\n      this._instructionsData = [];\n      for (const stakingAddress of this._stakingAddresses) {\n        const stakingDeactivateData: StakingDeactivate = {\n          type: InstructionBuilderTypes.StakingDeactivate,\n          params: {\n            fromAddress: this._sender,\n            stakingAddress: stakingAddress,\n          },\n        };\n        this._instructionsData.push(stakingDeactivateData);\n      }\n    } else {\n      assert(this._stakingAddress, 'Staking address must be set before building the transaction');\n\n      if (this._sender === this._stakingAddress) {\n        throw new BuildTransactionError('Sender address cannot be the same as the Staking address');\n      }\n\n      if (this._amount) {\n        assert(\n          this._unstakingAddress,\n          'When partially unstaking the unstaking address must be set before building the transaction'\n        );\n      }\n      this._instructionsData = [];\n      if (this._unstakingAddress) {\n        assert(\n          this._amount,\n          'If an unstaking address is given then a partial amount to unstake must also be set before building the transaction'\n        );\n        const stakingFundUnstakeAddress: Transfer = {\n          type: InstructionBuilderTypes.Transfer,\n          params: {\n            fromAddress: this._sender,\n            amount: STAKE_ACCOUNT_RENT_EXEMPT_AMOUNT.toString(),\n            toAddress: this._unstakingAddress,\n          },\n        };\n        this._instructionsData.push(stakingFundUnstakeAddress);\n      }\n\n      const stakingDeactivateData: StakingDeactivate = {\n        type: InstructionBuilderTypes.StakingDeactivate,\n        params: {\n          fromAddress: this._sender,\n          stakingAddress: this._stakingAddress,\n          amount: this._amount,\n          unstakingAddress: this._unstakingAddress,\n        },\n      };\n      this._instructionsData.push(stakingDeactivateData);\n    }\n    return await super.buildImplementation();\n  }\n}\n"]}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
|
|
2
|
+
import { TransactionType } from '@bitgo-beta/sdk-core';
|
|
3
|
+
import { Transaction } from './transaction';
|
|
4
|
+
import { TransactionBuilder } from './transactionBuilder';
|
|
5
|
+
export declare class StakingDelegateBuilder extends TransactionBuilder {
|
|
6
|
+
protected _stakingAddress: string;
|
|
7
|
+
protected _stakingAddresses: string[];
|
|
8
|
+
protected _validator: string;
|
|
9
|
+
constructor(_coinConfig: Readonly<CoinConfig>);
|
|
10
|
+
protected get transactionType(): TransactionType;
|
|
11
|
+
/** @inheritdoc */
|
|
12
|
+
initBuilder(tx: Transaction): void;
|
|
13
|
+
/**
|
|
14
|
+
* The address of the staking account.
|
|
15
|
+
*
|
|
16
|
+
* @param {string} stakingAddress public address of the staking account.
|
|
17
|
+
* @returns {StakingDelegateBuilder} This staking delegate builder.
|
|
18
|
+
*
|
|
19
|
+
* @see https://docs.solana.com/staking/stake-accounts#account-address
|
|
20
|
+
*/
|
|
21
|
+
stakingAddress(stakingAddress: string): this;
|
|
22
|
+
/**
|
|
23
|
+
* The staking addresses of the staking account.
|
|
24
|
+
*
|
|
25
|
+
* @param {string[]} stakingAddresses public address of the staking accounts
|
|
26
|
+
* @returns {StakingDelegateBuilder} This staking delegate builder.
|
|
27
|
+
*
|
|
28
|
+
* @see https://docs.solana.com/staking/stake-accounts#account-address
|
|
29
|
+
*/
|
|
30
|
+
stakingAddresses(stakingAddresses: string[]): this;
|
|
31
|
+
/**
|
|
32
|
+
* Set validator address to delegate funds to.
|
|
33
|
+
*
|
|
34
|
+
* @param {string} validator Validator address to delegate funds to.
|
|
35
|
+
* @returns {StakingDelegateBuilder} This staking builder.
|
|
36
|
+
*
|
|
37
|
+
*/
|
|
38
|
+
validator(validator: string): this;
|
|
39
|
+
/** @inheritdoc */
|
|
40
|
+
protected buildImplementation(): Promise<Transaction>;
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=stakingDelegateBuilder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stakingDelegateBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/stakingDelegateBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAyB,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAC9E,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAO1D,qBAAa,sBAAuB,SAAQ,kBAAkB;IAC5D,SAAS,CAAC,eAAe,EAAE,MAAM,CAAC;IAClC,SAAS,CAAC,iBAAiB,EAAE,MAAM,EAAE,CAAC;IACtC,SAAS,CAAC,UAAU,EAAE,MAAM,CAAC;gBAEjB,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED,kBAAkB;IAClB,WAAW,CAAC,EAAE,EAAE,WAAW,GAAG,IAAI;IAkBlC;;;;;;;OAOG;IACH,cAAc,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IAM5C;;;;;;;OAOG;IACH,gBAAgB,CAAC,gBAAgB,EAAE,MAAM,EAAE,GAAG,IAAI;IASlD;;;;;;OAMG;IACH,SAAS,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAMlC,kBAAkB;cACF,mBAAmB,IAAI,OAAO,CAAC,WAAW,CAAC;CAuC5D"}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.StakingDelegateBuilder = void 0;
|
|
7
|
+
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
8
|
+
const transactionBuilder_1 = require("./transactionBuilder");
|
|
9
|
+
const constants_1 = require("./constants");
|
|
10
|
+
const assert_1 = __importDefault(require("assert"));
|
|
11
|
+
const utils_1 = require("./utils");
|
|
12
|
+
class StakingDelegateBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
13
|
+
constructor(_coinConfig) {
|
|
14
|
+
super(_coinConfig);
|
|
15
|
+
}
|
|
16
|
+
get transactionType() {
|
|
17
|
+
return sdk_core_1.TransactionType.StakingDelegate;
|
|
18
|
+
}
|
|
19
|
+
/** @inheritdoc */
|
|
20
|
+
initBuilder(tx) {
|
|
21
|
+
super.initBuilder(tx);
|
|
22
|
+
const stakingAddresses = [];
|
|
23
|
+
for (const instruction of this._instructionsData) {
|
|
24
|
+
if (instruction.type === constants_1.InstructionBuilderTypes.StakingDelegate) {
|
|
25
|
+
const activateInstruction = instruction;
|
|
26
|
+
this.sender(activateInstruction.params.fromAddress);
|
|
27
|
+
stakingAddresses.push(activateInstruction.params.stakingAddress);
|
|
28
|
+
this.validator(activateInstruction.params.validator);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
if (stakingAddresses.length > 1) {
|
|
32
|
+
this.stakingAddresses(stakingAddresses);
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
this.stakingAddress(stakingAddresses[0]);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* The address of the staking account.
|
|
40
|
+
*
|
|
41
|
+
* @param {string} stakingAddress public address of the staking account.
|
|
42
|
+
* @returns {StakingDelegateBuilder} This staking delegate builder.
|
|
43
|
+
*
|
|
44
|
+
* @see https://docs.solana.com/staking/stake-accounts#account-address
|
|
45
|
+
*/
|
|
46
|
+
stakingAddress(stakingAddress) {
|
|
47
|
+
(0, utils_1.validateAddress)(stakingAddress, 'stakingAddress');
|
|
48
|
+
this._stakingAddress = stakingAddress;
|
|
49
|
+
return this;
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* The staking addresses of the staking account.
|
|
53
|
+
*
|
|
54
|
+
* @param {string[]} stakingAddresses public address of the staking accounts
|
|
55
|
+
* @returns {StakingDelegateBuilder} This staking delegate builder.
|
|
56
|
+
*
|
|
57
|
+
* @see https://docs.solana.com/staking/stake-accounts#account-address
|
|
58
|
+
*/
|
|
59
|
+
stakingAddresses(stakingAddresses) {
|
|
60
|
+
(0, assert_1.default)(stakingAddresses.length > 0, 'stakingAddresses must not be empty');
|
|
61
|
+
for (const stakingAddress of stakingAddresses) {
|
|
62
|
+
(0, utils_1.validateAddress)(stakingAddress, 'stakingAddress');
|
|
63
|
+
}
|
|
64
|
+
this._stakingAddresses = stakingAddresses;
|
|
65
|
+
return this;
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Set validator address to delegate funds to.
|
|
69
|
+
*
|
|
70
|
+
* @param {string} validator Validator address to delegate funds to.
|
|
71
|
+
* @returns {StakingDelegateBuilder} This staking builder.
|
|
72
|
+
*
|
|
73
|
+
*/
|
|
74
|
+
validator(validator) {
|
|
75
|
+
(0, utils_1.validateAddress)(validator, 'validator');
|
|
76
|
+
this._validator = validator;
|
|
77
|
+
return this;
|
|
78
|
+
}
|
|
79
|
+
/** @inheritdoc */
|
|
80
|
+
async buildImplementation() {
|
|
81
|
+
(0, assert_1.default)(this._sender, 'Sender must be set before building the transaction');
|
|
82
|
+
(0, assert_1.default)(this._validator, 'Validator must be set before building the transaction');
|
|
83
|
+
if (this._stakingAddresses && this._stakingAddresses.length > 0) {
|
|
84
|
+
this._instructionsData = [];
|
|
85
|
+
for (const stakingAddress of this._stakingAddresses) {
|
|
86
|
+
(0, assert_1.default)(stakingAddress, 'Staking Address must be set before building the transaction');
|
|
87
|
+
if (this._sender === stakingAddress) {
|
|
88
|
+
throw new sdk_core_1.BuildTransactionError('Sender address cannot be the same as the Staking address');
|
|
89
|
+
}
|
|
90
|
+
const stakingAccountData = {
|
|
91
|
+
type: constants_1.InstructionBuilderTypes.StakingDelegate,
|
|
92
|
+
params: {
|
|
93
|
+
fromAddress: this._sender,
|
|
94
|
+
stakingAddress: stakingAddress,
|
|
95
|
+
validator: this._validator,
|
|
96
|
+
},
|
|
97
|
+
};
|
|
98
|
+
this._instructionsData.push(stakingAccountData);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
else {
|
|
102
|
+
(0, assert_1.default)(this._stakingAddress, 'Staking Address must be set before building the transaction');
|
|
103
|
+
if (this._sender === this._stakingAddress) {
|
|
104
|
+
throw new sdk_core_1.BuildTransactionError('Sender address cannot be the same as the Staking address');
|
|
105
|
+
}
|
|
106
|
+
const stakingAccountData = {
|
|
107
|
+
type: constants_1.InstructionBuilderTypes.StakingDelegate,
|
|
108
|
+
params: {
|
|
109
|
+
fromAddress: this._sender,
|
|
110
|
+
stakingAddress: this._stakingAddress,
|
|
111
|
+
validator: this._validator,
|
|
112
|
+
},
|
|
113
|
+
};
|
|
114
|
+
this._instructionsData = [stakingAccountData];
|
|
115
|
+
}
|
|
116
|
+
return await super.buildImplementation();
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
exports.StakingDelegateBuilder = StakingDelegateBuilder;
|
|
120
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stakingDelegateBuilder.js","sourceRoot":"","sources":["../../../src/lib/stakingDelegateBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { BuildTransactionError, TransactionType } from '@bitgo-beta/sdk-core';\nimport { Transaction } from './transaction';\nimport { TransactionBuilder } from './transactionBuilder';\nimport { InstructionBuilderTypes } from './constants';\n\nimport assert from 'assert';\nimport { StakingDelegate } from './iface';\nimport { validateAddress } from './utils';\n\nexport class StakingDelegateBuilder extends TransactionBuilder {\n  protected _stakingAddress: string;\n  protected _stakingAddresses: string[];\n  protected _validator: string;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  protected get transactionType(): TransactionType {\n    return TransactionType.StakingDelegate;\n  }\n\n  /** @inheritdoc */\n  initBuilder(tx: Transaction): void {\n    super.initBuilder(tx);\n    const stakingAddresses: string[] = [];\n    for (const instruction of this._instructionsData) {\n      if (instruction.type === InstructionBuilderTypes.StakingDelegate) {\n        const activateInstruction: StakingDelegate = instruction;\n        this.sender(activateInstruction.params.fromAddress);\n        stakingAddresses.push(activateInstruction.params.stakingAddress);\n        this.validator(activateInstruction.params.validator);\n      }\n    }\n    if (stakingAddresses.length > 1) {\n      this.stakingAddresses(stakingAddresses);\n    } else {\n      this.stakingAddress(stakingAddresses[0]);\n    }\n  }\n\n  /**\n   * The address of the staking account.\n   *\n   * @param {string} stakingAddress public address of the staking account.\n   * @returns {StakingDelegateBuilder} This staking delegate builder.\n   *\n   * @see https://docs.solana.com/staking/stake-accounts#account-address\n   */\n  stakingAddress(stakingAddress: string): this {\n    validateAddress(stakingAddress, 'stakingAddress');\n    this._stakingAddress = stakingAddress;\n    return this;\n  }\n\n  /**\n   * The staking addresses of the staking account.\n   *\n   * @param {string[]} stakingAddresses public address of the staking accounts\n   * @returns {StakingDelegateBuilder} This staking delegate builder.\n   *\n   * @see https://docs.solana.com/staking/stake-accounts#account-address\n   */\n  stakingAddresses(stakingAddresses: string[]): this {\n    assert(stakingAddresses.length > 0, 'stakingAddresses must not be empty');\n    for (const stakingAddress of stakingAddresses) {\n      validateAddress(stakingAddress, 'stakingAddress');\n    }\n    this._stakingAddresses = stakingAddresses;\n    return this;\n  }\n\n  /**\n   * Set validator address to delegate funds to.\n   *\n   * @param {string} validator Validator address to delegate funds to.\n   * @returns {StakingDelegateBuilder} This staking builder.\n   *\n   */\n  validator(validator: string): this {\n    validateAddress(validator, 'validator');\n    this._validator = validator;\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    assert(this._validator, 'Validator must be set before building the transaction');\n\n    if (this._stakingAddresses && this._stakingAddresses.length > 0) {\n      this._instructionsData = [];\n      for (const stakingAddress of this._stakingAddresses) {\n        assert(stakingAddress, 'Staking Address must be set before building the transaction');\n        if (this._sender === stakingAddress) {\n          throw new BuildTransactionError('Sender address cannot be the same as the Staking address');\n        }\n        const stakingAccountData: StakingDelegate = {\n          type: InstructionBuilderTypes.StakingDelegate,\n          params: {\n            fromAddress: this._sender,\n            stakingAddress: stakingAddress,\n            validator: this._validator,\n          },\n        };\n        this._instructionsData.push(stakingAccountData);\n      }\n    } else {\n      assert(this._stakingAddress, 'Staking Address must be set before building the transaction');\n      if (this._sender === this._stakingAddress) {\n        throw new BuildTransactionError('Sender address cannot be the same as the Staking address');\n      }\n\n      const stakingAccountData: StakingDelegate = {\n        type: InstructionBuilderTypes.StakingDelegate,\n        params: {\n          fromAddress: this._sender,\n          stakingAddress: this._stakingAddress,\n          validator: this._validator,\n        },\n      };\n      this._instructionsData = [stakingAccountData];\n    }\n    return await super.buildImplementation();\n  }\n}\n"]}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
|
|
2
|
+
import { BaseAddress, BaseKey, BaseTransaction, BaseTransactionBuilder, TransactionType } from '@bitgo-beta/sdk-core';
|
|
3
|
+
import { Transaction } from './transaction';
|
|
4
|
+
import BigNumber from 'bignumber.js';
|
|
5
|
+
export declare class StakingRawMsgAuthorizeBuilder extends BaseTransactionBuilder {
|
|
6
|
+
protected _transaction: Transaction;
|
|
7
|
+
protected _transactionMessage: string;
|
|
8
|
+
constructor(_coinConfig: Readonly<CoinConfig>);
|
|
9
|
+
protected get transactionType(): TransactionType;
|
|
10
|
+
/** @inheritdoc */
|
|
11
|
+
initBuilder(tx: Transaction): void;
|
|
12
|
+
/**
|
|
13
|
+
* The raw message generated by Solana CLI.
|
|
14
|
+
*
|
|
15
|
+
* @param {string} msg msg generated by 'solana stake-authorize-check.
|
|
16
|
+
* @returns {StakeBuilder} This staking builder.
|
|
17
|
+
*
|
|
18
|
+
*/
|
|
19
|
+
transactionMessage(msg: string): this;
|
|
20
|
+
/** @inheritdoc */
|
|
21
|
+
protected buildImplementation(): Promise<Transaction>;
|
|
22
|
+
validateTransaction(tx: Transaction): boolean;
|
|
23
|
+
build(): Promise<Transaction>;
|
|
24
|
+
protected validateMessage(msg: string): boolean;
|
|
25
|
+
protected fromImplementation(rawTransaction: string): Transaction;
|
|
26
|
+
protected signImplementation(key: BaseKey): BaseTransaction;
|
|
27
|
+
protected get transaction(): Transaction;
|
|
28
|
+
validateAddress(address: BaseAddress, addressFormat?: string): void;
|
|
29
|
+
validateKey(key: BaseKey): void;
|
|
30
|
+
validateRawTransaction(rawTransaction: string): void;
|
|
31
|
+
validateValue(value: BigNumber): void;
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=stakingRawMsgAuthorizeBuilder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stakingRawMsgAuthorizeBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/stakingRawMsgAuthorizeBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EACL,WAAW,EACX,OAAO,EACP,eAAe,EACf,sBAAsB,EAEtB,eAAe,EAChB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAU5C,OAAO,SAAS,MAAM,cAAc,CAAC;AAGrC,qBAAa,6BAA8B,SAAQ,sBAAsB;IACvE,SAAS,CAAC,YAAY,EAAE,WAAW,CAAC;IACpC,SAAS,CAAC,mBAAmB,EAAE,MAAM,CAAC;gBAC1B,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAK7C,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED,kBAAkB;IAClB,WAAW,CAAC,EAAE,EAAE,WAAW,GAAG,IAAI;IAMlC;;;;;;OAMG;IACH,kBAAkB,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAMrC,kBAAkB;cACF,mBAAmB,IAAI,OAAO,CAAC,WAAW,CAAC;IAgB3D,mBAAmB,CAAC,EAAE,EAAE,WAAW,GAAG,OAAO;IAIvC,KAAK,IAAI,OAAO,CAAC,WAAW,CAAC;IAInC,SAAS,CAAC,eAAe,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IA6B/C,SAAS,CAAC,kBAAkB,CAAC,cAAc,EAAE,MAAM,GAAG,WAAW;IAOjE,SAAS,CAAC,kBAAkB,CAAC,GAAG,EAAE,OAAO,GAAG,eAAe;IAI3D,SAAS,KAAK,WAAW,IAAI,WAAW,CAEvC;IAED,eAAe,CAAC,OAAO,EAAE,WAAW,EAAE,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI;IAInE,WAAW,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI;IAI/B,sBAAsB,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IAMpD,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI;CAGtC"}
|