@bitgo-beta/sdk-coin-tao 1.0.1-alpha.26 → 1.0.1-alpha.27
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.
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
|
|
2
|
+
import { UnsignedTransaction, DecodedSignedTx, DecodedSigningPayload } from '@substrate/txwrapper-core';
|
|
3
|
+
import { TransactionType, BaseAddress } from '@bitgo-beta/sdk-core';
|
|
4
|
+
import { Transaction, TransactionBuilder } from '@bitgo-beta/abstract-substrate';
|
|
5
|
+
export declare class StakingBuilder extends TransactionBuilder {
|
|
6
|
+
protected _amount: number;
|
|
7
|
+
protected _hotkey: string;
|
|
8
|
+
protected _netuid: number;
|
|
9
|
+
constructor(_coinConfig: Readonly<CoinConfig>);
|
|
10
|
+
/**
|
|
11
|
+
* Take the origin account as a stash and lock up value of its balance.
|
|
12
|
+
* Controller will be the account that controls it.
|
|
13
|
+
*
|
|
14
|
+
* @returns {UnsignedTransaction} an unsigned Dot transaction
|
|
15
|
+
*
|
|
16
|
+
* @see https://polkadot.js.org/docs/substrate/extrinsics/#staking
|
|
17
|
+
*/
|
|
18
|
+
protected buildTransaction(): UnsignedTransaction;
|
|
19
|
+
protected get transactionType(): TransactionType;
|
|
20
|
+
/**
|
|
21
|
+
* The amount to stake.
|
|
22
|
+
*
|
|
23
|
+
* @param {string} amount
|
|
24
|
+
* @returns {StakeBuilder} This staking builder.
|
|
25
|
+
*
|
|
26
|
+
* @see https://wiki.polkadot.network/docs/learn-nominator#required-minimum-stake
|
|
27
|
+
*/
|
|
28
|
+
amount(amount: number): this;
|
|
29
|
+
/**
|
|
30
|
+
* The controller of the staked amount.
|
|
31
|
+
*
|
|
32
|
+
* @param {string} hotkey
|
|
33
|
+
* @returns {StakeBuilder} This staking builder.
|
|
34
|
+
*
|
|
35
|
+
* @see https://wiki.polkadot.network/docs/learn-staking#accounts
|
|
36
|
+
*/
|
|
37
|
+
hotkey({ address }: BaseAddress): this;
|
|
38
|
+
netuid(netuid: number): this;
|
|
39
|
+
/** @inheritdoc */
|
|
40
|
+
protected fromImplementation(rawTransaction: string): Transaction;
|
|
41
|
+
/** @inheritdoc */
|
|
42
|
+
validateTransaction(_: Transaction): void;
|
|
43
|
+
private validateFields;
|
|
44
|
+
/** @inheritdoc */
|
|
45
|
+
validateDecodedTransaction(decodedTxn: DecodedSigningPayload | DecodedSignedTx, rawTransaction: string): void;
|
|
46
|
+
/**
|
|
47
|
+
* Construct a transaction to stake
|
|
48
|
+
*
|
|
49
|
+
* @param args - Arguments specific to this method.
|
|
50
|
+
* @param info - Information required to construct the transaction.
|
|
51
|
+
*/
|
|
52
|
+
private addStake;
|
|
53
|
+
}
|
|
54
|
+
//# sourceMappingURL=stakingBuilder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stakingBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/stakingBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAgB,mBAAmB,EAAE,eAAe,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AAEtH,OAAO,EAA2B,eAAe,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAC7F,OAAO,EAAE,WAAW,EAAE,kBAAkB,EAAqB,MAAM,gCAAgC,CAAC;AAEpG,qBAAa,cAAe,SAAQ,kBAAkB;IACpD,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC;IAC1B,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC;IAC1B,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC;gBAEd,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C;;;;;;;OAOG;IACH,SAAS,CAAC,gBAAgB,IAAI,mBAAmB;IAYjD,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED;;;;;;;OAOG;IACH,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAM5B;;;;;;;OAOG;IACH,MAAM,CAAC,EAAE,OAAO,EAAE,EAAE,WAAW,GAAG,IAAI;IAMtC,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAK5B,kBAAkB;IAClB,SAAS,CAAC,kBAAkB,CAAC,cAAc,EAAE,MAAM,GAAG,WAAW;IAajE,kBAAkB;IAClB,mBAAmB,CAAC,CAAC,EAAE,WAAW,GAAG,IAAI;IAKzC,OAAO,CAAC,cAAc;IActB,kBAAkB;IAClB,0BAA0B,CAAC,UAAU,EAAE,qBAAqB,GAAG,eAAe,EAAE,cAAc,EAAE,MAAM,GAAG,IAAI;IAa7G;;;;;OAKG;IACH,OAAO,CAAC,QAAQ;CAajB"}
|
|
@@ -0,0 +1,124 @@
|
|
|
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.StakingBuilder = void 0;
|
|
7
|
+
const txwrapper_core_1 = require("@substrate/txwrapper-core");
|
|
8
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
9
|
+
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
10
|
+
const abstract_substrate_1 = require("@bitgo-beta/abstract-substrate");
|
|
11
|
+
class StakingBuilder extends abstract_substrate_1.TransactionBuilder {
|
|
12
|
+
constructor(_coinConfig) {
|
|
13
|
+
super(_coinConfig);
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Take the origin account as a stash and lock up value of its balance.
|
|
17
|
+
* Controller will be the account that controls it.
|
|
18
|
+
*
|
|
19
|
+
* @returns {UnsignedTransaction} an unsigned Dot transaction
|
|
20
|
+
*
|
|
21
|
+
* @see https://polkadot.js.org/docs/substrate/extrinsics/#staking
|
|
22
|
+
*/
|
|
23
|
+
buildTransaction() {
|
|
24
|
+
const baseTxInfo = this.createBaseTxInfo();
|
|
25
|
+
return this.addStake({
|
|
26
|
+
amountStaked: this._amount,
|
|
27
|
+
hotkey: this._hotkey,
|
|
28
|
+
netuid: this._netuid,
|
|
29
|
+
}, baseTxInfo);
|
|
30
|
+
}
|
|
31
|
+
get transactionType() {
|
|
32
|
+
return sdk_core_1.TransactionType.StakingActivate;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* The amount to stake.
|
|
36
|
+
*
|
|
37
|
+
* @param {string} amount
|
|
38
|
+
* @returns {StakeBuilder} This staking builder.
|
|
39
|
+
*
|
|
40
|
+
* @see https://wiki.polkadot.network/docs/learn-nominator#required-minimum-stake
|
|
41
|
+
*/
|
|
42
|
+
amount(amount) {
|
|
43
|
+
this.validateValue(new bignumber_js_1.default(amount));
|
|
44
|
+
this._amount = amount;
|
|
45
|
+
return this;
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* The controller of the staked amount.
|
|
49
|
+
*
|
|
50
|
+
* @param {string} hotkey
|
|
51
|
+
* @returns {StakeBuilder} This staking builder.
|
|
52
|
+
*
|
|
53
|
+
* @see https://wiki.polkadot.network/docs/learn-staking#accounts
|
|
54
|
+
*/
|
|
55
|
+
hotkey({ address }) {
|
|
56
|
+
this.validateAddress({ address });
|
|
57
|
+
this._hotkey = address;
|
|
58
|
+
return this;
|
|
59
|
+
}
|
|
60
|
+
netuid(netuid) {
|
|
61
|
+
this._netuid = netuid;
|
|
62
|
+
return this;
|
|
63
|
+
}
|
|
64
|
+
/** @inheritdoc */
|
|
65
|
+
fromImplementation(rawTransaction) {
|
|
66
|
+
const tx = super.fromImplementation(rawTransaction);
|
|
67
|
+
if (this._method?.name === abstract_substrate_1.Interface.MethodNames.AddStake) {
|
|
68
|
+
const txMethod = this._method.args;
|
|
69
|
+
this.amount(txMethod.amountStaked);
|
|
70
|
+
this.hotkey({ address: txMethod.hotkey });
|
|
71
|
+
this.netuid(txMethod.netuid);
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
throw new sdk_core_1.InvalidTransactionError(`Invalid Transaction Type: ${this._method?.name}. Expected addStake`);
|
|
75
|
+
}
|
|
76
|
+
return tx;
|
|
77
|
+
}
|
|
78
|
+
/** @inheritdoc */
|
|
79
|
+
validateTransaction(_) {
|
|
80
|
+
super.validateTransaction(_);
|
|
81
|
+
this.validateFields(this._amount, this._hotkey, this._netuid);
|
|
82
|
+
}
|
|
83
|
+
validateFields(amountStaked, hotkey, netuid) {
|
|
84
|
+
const validationResult = abstract_substrate_1.Schema.StakeTransactionSchema.validate({
|
|
85
|
+
amountStaked,
|
|
86
|
+
hotkey,
|
|
87
|
+
netuid,
|
|
88
|
+
});
|
|
89
|
+
if (validationResult.error) {
|
|
90
|
+
throw new sdk_core_1.InvalidTransactionError(`Stake Builder Transaction validation failed: ${validationResult.error.message}`);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
/** @inheritdoc */
|
|
94
|
+
validateDecodedTransaction(decodedTxn, rawTransaction) {
|
|
95
|
+
if (decodedTxn.method?.name === abstract_substrate_1.Interface.MethodNames.AddStake) {
|
|
96
|
+
const txMethod = decodedTxn.method.args;
|
|
97
|
+
const amountStaked = txMethod.amountStaked;
|
|
98
|
+
const hotkey = txMethod.hotkey;
|
|
99
|
+
const netuid = txMethod.netuid;
|
|
100
|
+
const validationResult = abstract_substrate_1.Schema.StakeTransactionSchema.validate({ amountStaked, hotkey, netuid });
|
|
101
|
+
if (validationResult.error) {
|
|
102
|
+
throw new sdk_core_1.InvalidTransactionError(`Transfer Transaction validation failed: ${validationResult.error.message}`);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Construct a transaction to stake
|
|
108
|
+
*
|
|
109
|
+
* @param args - Arguments specific to this method.
|
|
110
|
+
* @param info - Information required to construct the transaction.
|
|
111
|
+
*/
|
|
112
|
+
addStake(args, info) {
|
|
113
|
+
return (0, txwrapper_core_1.defineMethod)({
|
|
114
|
+
method: {
|
|
115
|
+
args,
|
|
116
|
+
name: 'addStake',
|
|
117
|
+
pallet: 'subtensorModule',
|
|
118
|
+
},
|
|
119
|
+
...info.baseTxInfo,
|
|
120
|
+
}, info.options);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
exports.StakingBuilder = StakingBuilder;
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stakingBuilder.js","sourceRoot":"","sources":["../../../src/lib/stakingBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { defineMethod, UnsignedTransaction, DecodedSignedTx, DecodedSigningPayload } from '@substrate/txwrapper-core';\nimport BigNumber from 'bignumber.js';\nimport { InvalidTransactionError, TransactionType, BaseAddress } from '@bitgo-beta/sdk-core';\nimport { Transaction, TransactionBuilder, Interface, Schema } from '@bitgo-beta/abstract-substrate';\n\nexport class StakingBuilder extends TransactionBuilder {\n  protected _amount: number;\n  protected _hotkey: string;\n  protected _netuid: number;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /**\n   * Take the origin account as a stash and lock up value of its balance.\n   * Controller will be the account that controls it.\n   *\n   * @returns {UnsignedTransaction} an unsigned Dot transaction\n   *\n   * @see https://polkadot.js.org/docs/substrate/extrinsics/#staking\n   */\n  protected buildTransaction(): UnsignedTransaction {\n    const baseTxInfo = this.createBaseTxInfo();\n    return this.addStake(\n      {\n        amountStaked: this._amount,\n        hotkey: this._hotkey,\n        netuid: this._netuid,\n      },\n      baseTxInfo\n    );\n  }\n\n  protected get transactionType(): TransactionType {\n    return TransactionType.StakingActivate;\n  }\n\n  /**\n   * The amount to stake.\n   *\n   * @param {string} amount\n   * @returns {StakeBuilder} This staking builder.\n   *\n   * @see https://wiki.polkadot.network/docs/learn-nominator#required-minimum-stake\n   */\n  amount(amount: number): this {\n    this.validateValue(new BigNumber(amount));\n    this._amount = amount;\n    return this;\n  }\n\n  /**\n   * The controller of the staked amount.\n   *\n   * @param {string} hotkey\n   * @returns {StakeBuilder} This staking builder.\n   *\n   * @see https://wiki.polkadot.network/docs/learn-staking#accounts\n   */\n  hotkey({ address }: BaseAddress): this {\n    this.validateAddress({ address });\n    this._hotkey = address;\n    return this;\n  }\n\n  netuid(netuid: number): this {\n    this._netuid = netuid;\n    return this;\n  }\n\n  /** @inheritdoc */\n  protected fromImplementation(rawTransaction: string): Transaction {\n    const tx = super.fromImplementation(rawTransaction);\n    if (this._method?.name === Interface.MethodNames.AddStake) {\n      const txMethod = this._method.args as Interface.AddStakeArgs;\n      this.amount(txMethod.amountStaked);\n      this.hotkey({ address: txMethod.hotkey });\n      this.netuid(txMethod.netuid);\n    } else {\n      throw new InvalidTransactionError(`Invalid Transaction Type: ${this._method?.name}. Expected addStake`);\n    }\n    return tx;\n  }\n\n  /** @inheritdoc */\n  validateTransaction(_: Transaction): void {\n    super.validateTransaction(_);\n    this.validateFields(this._amount, this._hotkey, this._netuid);\n  }\n\n  private validateFields(amountStaked: number, hotkey: string, netuid: number): void {\n    const validationResult = Schema.StakeTransactionSchema.validate({\n      amountStaked,\n      hotkey,\n      netuid,\n    });\n\n    if (validationResult.error) {\n      throw new InvalidTransactionError(\n        `Stake Builder Transaction validation failed: ${validationResult.error.message}`\n      );\n    }\n  }\n\n  /** @inheritdoc */\n  validateDecodedTransaction(decodedTxn: DecodedSigningPayload | DecodedSignedTx, rawTransaction: string): void {\n    if (decodedTxn.method?.name === Interface.MethodNames.AddStake) {\n      const txMethod = decodedTxn.method.args as unknown as Interface.AddStakeArgs;\n      const amountStaked = txMethod.amountStaked;\n      const hotkey = txMethod.hotkey;\n      const netuid = txMethod.netuid;\n      const validationResult = Schema.StakeTransactionSchema.validate({ amountStaked, hotkey, netuid });\n      if (validationResult.error) {\n        throw new InvalidTransactionError(`Transfer Transaction validation failed: ${validationResult.error.message}`);\n      }\n    }\n  }\n\n  /**\n   * Construct a transaction to stake\n   *\n   * @param args - Arguments specific to this method.\n   * @param info - Information required to construct the transaction.\n   */\n  private addStake(args: Interface.AddStakeArgs, info: Interface.CreateBaseTxInfo): UnsignedTransaction {\n    return defineMethod(\n      {\n        method: {\n          args,\n          name: 'addStake',\n          pallet: 'subtensorModule',\n        },\n        ...info.baseTxInfo,\n      },\n      info.options\n    );\n  }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@bitgo-beta/sdk-coin-tao",
|
|
3
|
-
"version": "1.0.1-alpha.
|
|
3
|
+
"version": "1.0.1-alpha.27",
|
|
4
4
|
"description": "BitGo SDK coin library for TAO (Bittensor) coin",
|
|
5
5
|
"main": "./dist/src/index.js",
|
|
6
6
|
"types": "./dist/src/index.d.ts",
|
|
@@ -40,15 +40,16 @@
|
|
|
40
40
|
]
|
|
41
41
|
},
|
|
42
42
|
"dependencies": {
|
|
43
|
-
"@bitgo-beta/abstract-substrate": "1.0.0-alpha.
|
|
44
|
-
"@bitgo-beta/sdk-core": "2.4.1-alpha.
|
|
45
|
-
"@bitgo-beta/statics": "10.0.1-alpha.
|
|
43
|
+
"@bitgo-beta/abstract-substrate": "1.0.0-alpha.30",
|
|
44
|
+
"@bitgo-beta/sdk-core": "2.4.1-alpha.278",
|
|
45
|
+
"@bitgo-beta/statics": "10.0.1-alpha.278",
|
|
46
46
|
"@substrate/txwrapper-core": "7.5.2",
|
|
47
|
-
"@substrate/txwrapper-polkadot": "7.5.2"
|
|
47
|
+
"@substrate/txwrapper-polkadot": "7.5.2",
|
|
48
|
+
"bignumber.js": "^9.0.0"
|
|
48
49
|
},
|
|
49
50
|
"devDependencies": {
|
|
50
|
-
"@bitgo-beta/sdk-api": "1.6.1-alpha.
|
|
51
|
+
"@bitgo-beta/sdk-api": "1.6.1-alpha.278",
|
|
51
52
|
"@bitgo-beta/sdk-test": "^8.0.72"
|
|
52
53
|
},
|
|
53
|
-
"gitHead": "
|
|
54
|
+
"gitHead": "c95f1f3164a9b8b6a004ec1a73c0b87ee6b72894"
|
|
54
55
|
}
|