@bitgo-beta/sdk-coin-polyx 1.0.0-alpha.7 → 1.0.0-alpha.71

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (82) hide show
  1. package/CHANGELOG.md +109 -0
  2. package/dist/src/index.d.ts +1 -0
  3. package/dist/src/index.d.ts.map +1 -1
  4. package/dist/src/index.js +2 -1
  5. package/dist/src/lib/baseBuilder.d.ts +24 -0
  6. package/dist/src/lib/baseBuilder.d.ts.map +1 -0
  7. package/dist/src/lib/baseBuilder.js +31 -0
  8. package/dist/src/lib/batchStakingBuilder.d.ts +79 -0
  9. package/dist/src/lib/batchStakingBuilder.d.ts.map +1 -0
  10. package/dist/src/lib/batchStakingBuilder.js +299 -0
  11. package/dist/src/lib/batchUnstakingBuilder.d.ts +39 -0
  12. package/dist/src/lib/batchUnstakingBuilder.d.ts.map +1 -0
  13. package/dist/src/lib/batchUnstakingBuilder.js +127 -0
  14. package/dist/src/lib/bondExtraBuilder.d.ts +37 -0
  15. package/dist/src/lib/bondExtraBuilder.d.ts.map +1 -0
  16. package/dist/src/lib/bondExtraBuilder.js +101 -0
  17. package/dist/src/lib/constants.d.ts +12 -0
  18. package/dist/src/lib/constants.d.ts.map +1 -0
  19. package/dist/src/lib/constants.js +15 -0
  20. package/dist/src/lib/iface.d.ts +124 -3
  21. package/dist/src/lib/iface.d.ts.map +1 -1
  22. package/dist/src/lib/iface.js +36 -1
  23. package/dist/src/lib/index.d.ts +15 -7
  24. package/dist/src/lib/index.d.ts.map +1 -1
  25. package/dist/src/lib/index.js +42 -36
  26. package/dist/src/lib/preApproveAssetBuilder.d.ts +33 -0
  27. package/dist/src/lib/preApproveAssetBuilder.d.ts.map +1 -0
  28. package/dist/src/lib/preApproveAssetBuilder.js +77 -0
  29. package/dist/src/lib/registerDidWithCDDBuilder.d.ts +34 -0
  30. package/dist/src/lib/registerDidWithCDDBuilder.d.ts.map +1 -0
  31. package/dist/src/lib/registerDidWithCDDBuilder.js +83 -0
  32. package/dist/src/lib/tokenTransferBuilder.d.ts +58 -0
  33. package/dist/src/lib/tokenTransferBuilder.d.ts.map +1 -0
  34. package/dist/src/lib/tokenTransferBuilder.js +152 -0
  35. package/dist/src/lib/transaction.d.ts +18 -4
  36. package/dist/src/lib/transaction.d.ts.map +1 -1
  37. package/dist/src/lib/transaction.js +136 -8
  38. package/dist/src/lib/transactionBuilderFactory.d.ts +27 -5
  39. package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
  40. package/dist/src/lib/transactionBuilderFactory.js +112 -8
  41. package/dist/src/lib/transferBuilder.d.ts +51 -3
  42. package/dist/src/lib/transferBuilder.d.ts.map +1 -1
  43. package/dist/src/lib/transferBuilder.js +109 -3
  44. package/dist/src/lib/txnSchema.d.ts +49 -0
  45. package/dist/src/lib/txnSchema.d.ts.map +1 -0
  46. package/dist/src/lib/txnSchema.js +129 -0
  47. package/dist/src/lib/unbondBuilder.d.ts +37 -0
  48. package/dist/src/lib/unbondBuilder.d.ts.map +1 -0
  49. package/dist/src/lib/unbondBuilder.js +98 -0
  50. package/dist/src/lib/utils.d.ts +15 -14
  51. package/dist/src/lib/utils.d.ts.map +1 -1
  52. package/dist/src/lib/utils.js +40 -23
  53. package/dist/src/lib/withdrawUnbondedBuilder.d.ts +35 -0
  54. package/dist/src/lib/withdrawUnbondedBuilder.d.ts.map +1 -0
  55. package/dist/src/lib/withdrawUnbondedBuilder.js +89 -0
  56. package/dist/src/polyx.d.ts +42 -9
  57. package/dist/src/polyx.d.ts.map +1 -1
  58. package/dist/src/polyx.js +252 -16
  59. package/dist/src/polyxToken.d.ts +20 -0
  60. package/dist/src/polyxToken.d.ts.map +1 -0
  61. package/dist/src/polyxToken.js +55 -0
  62. package/dist/src/register.d.ts.map +1 -1
  63. package/dist/src/register.js +5 -1
  64. package/dist/src/resources/index.d.ts +3 -0
  65. package/dist/src/resources/index.d.ts.map +1 -0
  66. package/dist/src/resources/index.js +19 -0
  67. package/dist/src/resources/mainnet.d.ts +13 -0
  68. package/dist/src/resources/mainnet.d.ts.map +1 -0
  69. package/dist/src/resources/mainnet.js +16 -0
  70. package/dist/src/resources/testnet.d.ts +13 -0
  71. package/dist/src/resources/testnet.d.ts.map +1 -0
  72. package/dist/src/resources/testnet.js +16 -0
  73. package/dist/src/tpolyx.d.ts +7 -0
  74. package/dist/src/tpolyx.d.ts.map +1 -1
  75. package/dist/src/tpolyx.js +11 -1
  76. package/package.json +15 -9
  77. package/dist/src/lib/keyPair.d.ts +0 -12
  78. package/dist/src/lib/keyPair.d.ts.map +0 -1
  79. package/dist/src/lib/keyPair.js +0 -24
  80. package/dist/src/lib/transactionBuilder.d.ts +0 -43
  81. package/dist/src/lib/transactionBuilder.d.ts.map +0 -1
  82. package/dist/src/lib/transactionBuilder.js +0 -78
@@ -0,0 +1,39 @@
1
+ import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
2
+ import { UnsignedTransaction, DecodedSigningPayload, DecodedSignedTx } from '@substrate/txwrapper-core';
3
+ import { TransactionType } from '@bitgo-beta/sdk-core';
4
+ import { Transaction } from './transaction';
5
+ import { PolyxBaseBuilder } from './baseBuilder';
6
+ export declare class BatchUnstakingBuilder extends PolyxBaseBuilder {
7
+ protected _amount: string;
8
+ constructor(_coinConfig: Readonly<CoinConfig>);
9
+ /**
10
+ * Unbond tokens and chill (stop nominating validators)
11
+ *
12
+ * @returns {UnsignedTransaction} an unsigned Polyx transaction
13
+ */
14
+ protected buildTransaction(): UnsignedTransaction;
15
+ protected get transactionType(): TransactionType;
16
+ /**
17
+ * The amount to unstake.
18
+ *
19
+ * @param {string} amount
20
+ * @returns {BatchUnstakingBuilder} This unstake builder.
21
+ */
22
+ amount(amount: string): this;
23
+ /**
24
+ * Get the amount to unstake
25
+ */
26
+ getAmount(): string;
27
+ /** @inheritdoc */
28
+ validateDecodedTransaction(decodedTxn: DecodedSigningPayload | DecodedSignedTx): void;
29
+ /** @inheritdoc */
30
+ protected fromImplementation(rawTransaction: string): Transaction;
31
+ /** @inheritdoc */
32
+ validateTransaction(_: Transaction): void;
33
+ private validateFields;
34
+ /**
35
+ * Validates fields for testing
36
+ */
37
+ testValidateFields(): void;
38
+ }
39
+ //# sourceMappingURL=batchUnstakingBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"batchUnstakingBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/batchUnstakingBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAE7D,OAAO,EAAE,mBAAmB,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AACxG,OAAO,EAA2B,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAEhF,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAKjD,qBAAa,qBAAsB,SAAQ,gBAAgB;IACzD,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC;gBAEd,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C;;;;OAIG;IACH,SAAS,CAAC,gBAAgB,IAAI,mBAAmB;IAuBjD,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED;;;;;OAKG;IACH,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAM5B;;OAEG;IACH,SAAS,IAAI,MAAM;IAInB,kBAAkB;IAClB,0BAA0B,CAAC,UAAU,EAAE,qBAAqB,GAAG,eAAe,GAAG,IAAI;IA4CrF,kBAAkB;IAClB,SAAS,CAAC,kBAAkB,CAAC,cAAc,EAAE,MAAM,GAAG,WAAW;IAsBjE,kBAAkB;IAClB,mBAAmB,CAAC,CAAC,EAAE,WAAW,GAAG,IAAI;IAKzC,OAAO,CAAC,cAAc;IAYtB;;OAEG;IACH,kBAAkB,IAAI,IAAI;CAG3B"}
@@ -0,0 +1,127 @@
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.BatchUnstakingBuilder = void 0;
7
+ const txwrapper_polkadot_1 = require("@substrate/txwrapper-polkadot");
8
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
9
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
10
+ const baseBuilder_1 = require("./baseBuilder");
11
+ const txnSchema_1 = require("./txnSchema");
12
+ const utils_1 = __importDefault(require("./utils"));
13
+ class BatchUnstakingBuilder extends baseBuilder_1.PolyxBaseBuilder {
14
+ constructor(_coinConfig) {
15
+ super(_coinConfig);
16
+ }
17
+ /**
18
+ * Unbond tokens and chill (stop nominating validators)
19
+ *
20
+ * @returns {UnsignedTransaction} an unsigned Polyx transaction
21
+ */
22
+ buildTransaction() {
23
+ const baseTxInfo = this.createBaseTxInfo();
24
+ const chillCall = txwrapper_polkadot_1.methods.staking.chill({}, baseTxInfo.baseTxInfo, baseTxInfo.options);
25
+ const unbondCall = txwrapper_polkadot_1.methods.staking.unbond({
26
+ value: this._amount,
27
+ }, baseTxInfo.baseTxInfo, baseTxInfo.options);
28
+ // Create batch all transaction (atomic execution)
29
+ return txwrapper_polkadot_1.methods.utility.batchAll({
30
+ calls: [chillCall.method, unbondCall.method],
31
+ }, baseTxInfo.baseTxInfo, baseTxInfo.options);
32
+ }
33
+ get transactionType() {
34
+ return sdk_core_1.TransactionType.Batch;
35
+ }
36
+ /**
37
+ * The amount to unstake.
38
+ *
39
+ * @param {string} amount
40
+ * @returns {BatchUnstakingBuilder} This unstake builder.
41
+ */
42
+ amount(amount) {
43
+ this.validateValue(new bignumber_js_1.default(amount));
44
+ this._amount = amount;
45
+ return this;
46
+ }
47
+ /**
48
+ * Get the amount to unstake
49
+ */
50
+ getAmount() {
51
+ return this._amount;
52
+ }
53
+ /** @inheritdoc */
54
+ validateDecodedTransaction(decodedTxn) {
55
+ const methodName = decodedTxn.method?.name;
56
+ if (methodName === 'batchAll') {
57
+ const txMethod = decodedTxn.method.args;
58
+ const calls = txMethod.calls;
59
+ if (calls.length !== 2) {
60
+ throw new sdk_core_1.InvalidTransactionError(`Invalid batch unstaking transaction: expected 2 calls but got ${calls.length}`);
61
+ }
62
+ // Check that first call is chill
63
+ const firstCallMethod = utils_1.default.decodeMethodName(calls[0], this._registry);
64
+ if (firstCallMethod !== 'chill') {
65
+ throw new sdk_core_1.InvalidTransactionError(`Invalid batch unstaking transaction: first call should be chill but got ${firstCallMethod}`);
66
+ }
67
+ // Check that second call is unbond
68
+ const secondCallMethod = utils_1.default.decodeMethodName(calls[1], this._registry);
69
+ if (secondCallMethod !== 'unbond') {
70
+ throw new sdk_core_1.InvalidTransactionError(`Invalid batch unstaking transaction: second call should be unbond but got ${secondCallMethod}`);
71
+ }
72
+ // Validate unbond amount - handle both string and number formats
73
+ const unbondArgs = calls[1].args;
74
+ const valueString = typeof unbondArgs.value === 'string' ? unbondArgs.value : unbondArgs.value.toString();
75
+ const validationResult = txnSchema_1.BatchUnstakingTransactionSchema.validate({
76
+ value: valueString,
77
+ });
78
+ if (validationResult.error) {
79
+ throw new sdk_core_1.InvalidTransactionError(`Invalid batch unstaking transaction: ${validationResult.error.message}`);
80
+ }
81
+ }
82
+ else {
83
+ throw new sdk_core_1.InvalidTransactionError(`Invalid transaction type: ${methodName}. Expected batchAll`);
84
+ }
85
+ }
86
+ /** @inheritdoc */
87
+ fromImplementation(rawTransaction) {
88
+ const tx = super.fromImplementation(rawTransaction);
89
+ if (this._method && this._method.name === 'batchAll') {
90
+ const txMethod = this._method.args;
91
+ const calls = txMethod.calls;
92
+ if (calls && calls.length === 2) {
93
+ const secondCallMethod = utils_1.default.decodeMethodName(calls[1], this._registry);
94
+ if (secondCallMethod === 'unbond') {
95
+ const unbondArgs = calls[1].args;
96
+ const valueString = typeof unbondArgs.value === 'string' ? unbondArgs.value : unbondArgs.value.toString();
97
+ this.amount(valueString);
98
+ }
99
+ }
100
+ }
101
+ else {
102
+ throw new sdk_core_1.InvalidTransactionError(`Invalid Transaction Type: ${this._method?.name}. Expected batchAll`);
103
+ }
104
+ return tx;
105
+ }
106
+ /** @inheritdoc */
107
+ validateTransaction(_) {
108
+ super.validateTransaction(_);
109
+ this.validateFields(this._amount);
110
+ }
111
+ validateFields(value) {
112
+ const validationResult = txnSchema_1.BatchUnstakingTransactionSchema.validate({
113
+ value,
114
+ });
115
+ if (validationResult.error) {
116
+ throw new sdk_core_1.InvalidTransactionError(`Batch Unstaking Builder Transaction validation failed: ${validationResult.error.message}`);
117
+ }
118
+ }
119
+ /**
120
+ * Validates fields for testing
121
+ */
122
+ testValidateFields() {
123
+ this.validateFields(this._amount);
124
+ }
125
+ }
126
+ exports.BatchUnstakingBuilder = BatchUnstakingBuilder;
127
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"batchUnstakingBuilder.js","sourceRoot":"","sources":["../../../src/lib/batchUnstakingBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { methods } from '@substrate/txwrapper-polkadot';\nimport { UnsignedTransaction, DecodedSigningPayload, DecodedSignedTx } from '@substrate/txwrapper-core';\nimport { InvalidTransactionError, TransactionType } from '@bitgo-beta/sdk-core';\nimport BigNumber from 'bignumber.js';\nimport { Transaction } from './transaction';\nimport { PolyxBaseBuilder } from './baseBuilder';\nimport { BatchArgs } from './iface';\nimport { BatchUnstakingTransactionSchema } from './txnSchema';\nimport utils from './utils';\n\nexport class BatchUnstakingBuilder extends PolyxBaseBuilder {\n  protected _amount: string;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /**\n   * Unbond tokens and chill (stop nominating validators)\n   *\n   * @returns {UnsignedTransaction} an unsigned Polyx transaction\n   */\n  protected buildTransaction(): UnsignedTransaction {\n    const baseTxInfo = this.createBaseTxInfo();\n\n    const chillCall = methods.staking.chill({}, baseTxInfo.baseTxInfo, baseTxInfo.options);\n\n    const unbondCall = methods.staking.unbond(\n      {\n        value: this._amount,\n      },\n      baseTxInfo.baseTxInfo,\n      baseTxInfo.options\n    );\n\n    // Create batch all transaction (atomic execution)\n    return methods.utility.batchAll(\n      {\n        calls: [chillCall.method, unbondCall.method],\n      },\n      baseTxInfo.baseTxInfo,\n      baseTxInfo.options\n    );\n  }\n\n  protected get transactionType(): TransactionType {\n    return TransactionType.Batch;\n  }\n\n  /**\n   * The amount to unstake.\n   *\n   * @param {string} amount\n   * @returns {BatchUnstakingBuilder} This unstake builder.\n   */\n  amount(amount: string): this {\n    this.validateValue(new BigNumber(amount));\n    this._amount = amount;\n    return this;\n  }\n\n  /**\n   * Get the amount to unstake\n   */\n  getAmount(): string {\n    return this._amount;\n  }\n\n  /** @inheritdoc */\n  validateDecodedTransaction(decodedTxn: DecodedSigningPayload | DecodedSignedTx): void {\n    const methodName = decodedTxn.method?.name as string;\n\n    if (methodName === 'batchAll') {\n      const txMethod = decodedTxn.method.args as unknown as BatchArgs;\n      const calls = txMethod.calls;\n\n      if (calls.length !== 2) {\n        throw new InvalidTransactionError(\n          `Invalid batch unstaking transaction: expected 2 calls but got ${calls.length}`\n        );\n      }\n\n      // Check that first call is chill\n      const firstCallMethod = utils.decodeMethodName(calls[0], this._registry);\n      if (firstCallMethod !== 'chill') {\n        throw new InvalidTransactionError(\n          `Invalid batch unstaking transaction: first call should be chill but got ${firstCallMethod}`\n        );\n      }\n\n      // Check that second call is unbond\n      const secondCallMethod = utils.decodeMethodName(calls[1], this._registry);\n      if (secondCallMethod !== 'unbond') {\n        throw new InvalidTransactionError(\n          `Invalid batch unstaking transaction: second call should be unbond but got ${secondCallMethod}`\n        );\n      }\n\n      // Validate unbond amount - handle both string and number formats\n      const unbondArgs = calls[1].args as { value: string | number };\n      const valueString = typeof unbondArgs.value === 'string' ? unbondArgs.value : unbondArgs.value.toString();\n      const validationResult = BatchUnstakingTransactionSchema.validate({\n        value: valueString,\n      });\n\n      if (validationResult.error) {\n        throw new InvalidTransactionError(`Invalid batch unstaking transaction: ${validationResult.error.message}`);\n      }\n    } else {\n      throw new InvalidTransactionError(`Invalid transaction type: ${methodName}. Expected batchAll`);\n    }\n  }\n\n  /** @inheritdoc */\n  protected fromImplementation(rawTransaction: string): Transaction {\n    const tx = super.fromImplementation(rawTransaction);\n\n    if (this._method && (this._method.name as string) === 'batchAll') {\n      const txMethod = this._method.args as unknown as BatchArgs;\n      const calls = txMethod.calls;\n\n      if (calls && calls.length === 2) {\n        const secondCallMethod = utils.decodeMethodName(calls[1], this._registry);\n        if (secondCallMethod === 'unbond') {\n          const unbondArgs = calls[1].args as { value: string | number };\n          const valueString = typeof unbondArgs.value === 'string' ? unbondArgs.value : unbondArgs.value.toString();\n          this.amount(valueString);\n        }\n      }\n    } else {\n      throw new InvalidTransactionError(`Invalid Transaction Type: ${this._method?.name}. Expected batchAll`);\n    }\n\n    return tx;\n  }\n\n  /** @inheritdoc */\n  validateTransaction(_: Transaction): void {\n    super.validateTransaction(_);\n    this.validateFields(this._amount);\n  }\n\n  private validateFields(value: string): void {\n    const validationResult = BatchUnstakingTransactionSchema.validate({\n      value,\n    });\n\n    if (validationResult.error) {\n      throw new InvalidTransactionError(\n        `Batch Unstaking Builder Transaction validation failed: ${validationResult.error.message}`\n      );\n    }\n  }\n\n  /**\n   * Validates fields for testing\n   */\n  testValidateFields(): void {\n    this.validateFields(this._amount);\n  }\n}\n"]}
@@ -0,0 +1,37 @@
1
+ import { Transaction } from './transaction';
2
+ import { PolyxBaseBuilder } from './baseBuilder';
3
+ import { DecodedSignedTx, DecodedSigningPayload, UnsignedTransaction } from '@substrate/txwrapper-core';
4
+ import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
5
+ import { TransactionType } from '@bitgo-beta/sdk-core';
6
+ export declare class BondExtraBuilder extends PolyxBaseBuilder {
7
+ protected _amount: string;
8
+ constructor(_coinConfig: Readonly<CoinConfig>);
9
+ protected get transactionType(): TransactionType;
10
+ /**
11
+ * Build the bondExtra transaction
12
+ */
13
+ protected buildTransaction(): UnsignedTransaction;
14
+ /**
15
+ * Set additional amount to stake
16
+ */
17
+ amount(amount: string): this;
18
+ /**
19
+ * Get the amount to stake
20
+ */
21
+ getAmount(): string;
22
+ /** @inheritdoc */
23
+ validateDecodedTransaction(decodedTxn: DecodedSigningPayload | DecodedSignedTx): void;
24
+ /** @inheritdoc */
25
+ protected fromImplementation(rawTransaction: string): Transaction;
26
+ /** @inheritdoc */
27
+ validateTransaction(tx: Transaction): void;
28
+ /**
29
+ * Validate the bondExtra fields
30
+ */
31
+ private validateFields;
32
+ /**
33
+ * Validate amount
34
+ */
35
+ validateAmount(amount: string): void;
36
+ }
37
+ //# sourceMappingURL=bondExtraBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bondExtraBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/bondExtraBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,qBAAqB,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAExG,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAA2B,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAMhF,qBAAa,gBAAiB,SAAQ,gBAAgB;IACpD,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC;gBAEd,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAK7C,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED;;OAEG;IACH,SAAS,CAAC,gBAAgB,IAAI,mBAAmB;IAYjD;;OAEG;IACH,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAM5B;;OAEG;IACH,SAAS,IAAI,MAAM;IAInB,kBAAkB;IAClB,0BAA0B,CAAC,UAAU,EAAE,qBAAqB,GAAG,eAAe,GAAG,IAAI;IAmBrF,kBAAkB;IAClB,SAAS,CAAC,kBAAkB,CAAC,cAAc,EAAE,MAAM,GAAG,WAAW;IAcjE,kBAAkB;IAClB,mBAAmB,CAAC,EAAE,EAAE,WAAW,GAAG,IAAI;IAK1C;;OAEG;IACH,OAAO,CAAC,cAAc;IAUtB;;OAEG;IACH,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;CAMrC"}
@@ -0,0 +1,101 @@
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.BondExtraBuilder = void 0;
7
+ const baseBuilder_1 = require("./baseBuilder");
8
+ const txwrapper_polkadot_1 = require("@substrate/txwrapper-polkadot");
9
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
10
+ const txnSchema_1 = require("./txnSchema");
11
+ const utils_1 = __importDefault(require("./utils"));
12
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
13
+ class BondExtraBuilder extends baseBuilder_1.PolyxBaseBuilder {
14
+ constructor(_coinConfig) {
15
+ super(_coinConfig);
16
+ this.material(utils_1.default.getMaterial(_coinConfig.network.type));
17
+ }
18
+ get transactionType() {
19
+ return sdk_core_1.TransactionType.StakingActivate;
20
+ }
21
+ /**
22
+ * Build the bondExtra transaction
23
+ */
24
+ buildTransaction() {
25
+ const baseTxInfo = this.createBaseTxInfo();
26
+ return txwrapper_polkadot_1.methods.staking.bondExtra({
27
+ maxAdditional: this._amount,
28
+ }, baseTxInfo.baseTxInfo, baseTxInfo.options);
29
+ }
30
+ /**
31
+ * Set additional amount to stake
32
+ */
33
+ amount(amount) {
34
+ this.validateValue(new bignumber_js_1.default(amount));
35
+ this._amount = amount;
36
+ return this;
37
+ }
38
+ /**
39
+ * Get the amount to stake
40
+ */
41
+ getAmount() {
42
+ return this._amount;
43
+ }
44
+ /** @inheritdoc */
45
+ validateDecodedTransaction(decodedTxn) {
46
+ const methodName = decodedTxn.method?.name;
47
+ if (methodName === 'bondExtra') {
48
+ const txMethod = decodedTxn.method.args;
49
+ const value = txMethod.maxAdditional;
50
+ const validationResult = txnSchema_1.BondExtraTransactionSchema.validate({
51
+ value,
52
+ });
53
+ if (validationResult.error) {
54
+ throw new sdk_core_1.InvalidTransactionError(`Invalid transaction: ${validationResult.error.message}`);
55
+ }
56
+ }
57
+ else {
58
+ throw new sdk_core_1.InvalidTransactionError(`Invalid transaction type: ${methodName}`);
59
+ }
60
+ }
61
+ /** @inheritdoc */
62
+ fromImplementation(rawTransaction) {
63
+ const tx = super.fromImplementation(rawTransaction);
64
+ const methodName = this._method?.name;
65
+ if (methodName === 'bondExtra' && this._method) {
66
+ const txMethod = this._method.args;
67
+ this.amount(txMethod.maxAdditional);
68
+ }
69
+ else {
70
+ throw new sdk_core_1.InvalidTransactionError(`Invalid Transaction Type: ${methodName}. Expected bondExtra`);
71
+ }
72
+ return tx;
73
+ }
74
+ /** @inheritdoc */
75
+ validateTransaction(tx) {
76
+ super.validateTransaction(tx);
77
+ this.validateFields();
78
+ }
79
+ /**
80
+ * Validate the bondExtra fields
81
+ */
82
+ validateFields() {
83
+ const validationResult = txnSchema_1.BondExtraTransactionSchema.validate({
84
+ value: this._amount,
85
+ });
86
+ if (validationResult.error) {
87
+ throw new sdk_core_1.InvalidTransactionError(`Invalid transaction: ${validationResult.error.message}`);
88
+ }
89
+ }
90
+ /**
91
+ * Validate amount
92
+ */
93
+ validateAmount(amount) {
94
+ const amountBN = new bignumber_js_1.default(amount);
95
+ if (amountBN.isNaN() || amountBN.isLessThanOrEqualTo(0)) {
96
+ throw new Error(`Bond amount ${amount} must be a positive number`);
97
+ }
98
+ }
99
+ }
100
+ exports.BondExtraBuilder = BondExtraBuilder;
101
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9uZEV4dHJhQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvYm9uZEV4dHJhQnVpbGRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFDQSwrQ0FBaUQ7QUFFakQsc0VBQXdEO0FBRXhELG1EQUFnRjtBQUNoRiwyQ0FBeUQ7QUFDekQsb0RBQTRCO0FBRTVCLGdFQUFxQztBQUVyQyxNQUFhLGdCQUFpQixTQUFRLDhCQUFnQjtJQUdwRCxZQUFZLFdBQWlDO1FBQzNDLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNuQixJQUFJLENBQUMsUUFBUSxDQUFDLGVBQUssQ0FBQyxXQUFXLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFFRCxJQUFjLGVBQWU7UUFDM0IsT0FBTywwQkFBZSxDQUFDLGVBQWUsQ0FBQztJQUN6QyxDQUFDO0lBRUQ7O09BRUc7SUFDTyxnQkFBZ0I7UUFDeEIsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7UUFFM0MsT0FBTyw0QkFBTyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQzlCO1lBQ0UsYUFBYSxFQUFFLElBQUksQ0FBQyxPQUFPO1NBQzVCLEVBQ0QsVUFBVSxDQUFDLFVBQVUsRUFDckIsVUFBVSxDQUFDLE9BQU8sQ0FDbkIsQ0FBQztJQUNKLENBQUM7SUFFRDs7T0FFRztJQUNILE1BQU0sQ0FBQyxNQUFjO1FBQ25CLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxzQkFBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7UUFDMUMsSUFBSSxDQUFDLE9BQU8sR0FBRyxNQUFNLENBQUM7UUFDdEIsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxTQUFTO1FBQ1AsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7SUFFRCxrQkFBa0I7SUFDbEIsMEJBQTBCLENBQUMsVUFBbUQ7UUFDNUUsTUFBTSxVQUFVLEdBQUcsVUFBVSxDQUFDLE1BQU0sRUFBRSxJQUFjLENBQUM7UUFFckQsSUFBSSxVQUFVLEtBQUssV0FBVyxFQUFFLENBQUM7WUFDL0IsTUFBTSxRQUFRLEdBQUcsVUFBVSxDQUFDLE1BQU0sQ0FBQyxJQUFnQyxDQUFDO1lBQ3BFLE1BQU0sS0FBSyxHQUFHLFFBQVEsQ0FBQyxhQUFhLENBQUM7WUFFckMsTUFBTSxnQkFBZ0IsR0FBRyxzQ0FBMEIsQ0FBQyxRQUFRLENBQUM7Z0JBQzNELEtBQUs7YUFDTixDQUFDLENBQUM7WUFFSCxJQUFJLGdCQUFnQixDQUFDLEtBQUssRUFBRSxDQUFDO2dCQUMzQixNQUFNLElBQUksa0NBQXVCLENBQUMsd0JBQXdCLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1lBQzlGLENBQUM7UUFDSCxDQUFDO2FBQU0sQ0FBQztZQUNOLE1BQU0sSUFBSSxrQ0FBdUIsQ0FBQyw2QkFBNkIsVUFBVSxFQUFFLENBQUMsQ0FBQztRQUMvRSxDQUFDO0lBQ0gsQ0FBQztJQUVELGtCQUFrQjtJQUNSLGtCQUFrQixDQUFDLGNBQXNCO1FBQ2pELE1BQU0sRUFBRSxHQUFHLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUNwRCxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsT0FBTyxFQUFFLElBQWMsQ0FBQztRQUVoRCxJQUFJLFVBQVUsS0FBSyxXQUFXLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQy9DLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBZ0MsQ0FBQztZQUMvRCxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUN0QyxDQUFDO2FBQU0sQ0FBQztZQUNOLE1BQU0sSUFBSSxrQ0FBdUIsQ0FBQyw2QkFBNkIsVUFBVSxzQkFBc0IsQ0FBQyxDQUFDO1FBQ25HLENBQUM7UUFFRCxPQUFPLEVBQUUsQ0FBQztJQUNaLENBQUM7SUFFRCxrQkFBa0I7SUFDbEIsbUJBQW1CLENBQUMsRUFBZTtRQUNqQyxLQUFLLENBQUMsbUJBQW1CLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDOUIsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO0lBQ3hCLENBQUM7SUFFRDs7T0FFRztJQUNLLGNBQWM7UUFDcEIsTUFBTSxnQkFBZ0IsR0FBRyxzQ0FBMEIsQ0FBQyxRQUFRLENBQUM7WUFDM0QsS0FBSyxFQUFFLElBQUksQ0FBQyxPQUFPO1NBQ3BCLENBQUMsQ0FBQztRQUVILElBQUksZ0JBQWdCLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDM0IsTUFBTSxJQUFJLGtDQUF1QixDQUFDLHdCQUF3QixnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztRQUM5RixDQUFDO0lBQ0gsQ0FBQztJQUVEOztPQUVHO0lBQ0gsY0FBYyxDQUFDLE1BQWM7UUFDM0IsTUFBTSxRQUFRLEdBQUcsSUFBSSxzQkFBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3ZDLElBQUksUUFBUSxDQUFDLEtBQUssRUFBRSxJQUFJLFFBQVEsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1lBQ3hELE1BQU0sSUFBSSxLQUFLLENBQUMsZUFBZSxNQUFNLDRCQUE0QixDQUFDLENBQUM7UUFDckUsQ0FBQztJQUNILENBQUM7Q0FDRjtBQTFHRCw0Q0EwR0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUcmFuc2FjdGlvbiB9IGZyb20gJy4vdHJhbnNhY3Rpb24nO1xuaW1wb3J0IHsgUG9seXhCYXNlQnVpbGRlciB9IGZyb20gJy4vYmFzZUJ1aWxkZXInO1xuaW1wb3J0IHsgRGVjb2RlZFNpZ25lZFR4LCBEZWNvZGVkU2lnbmluZ1BheWxvYWQsIFVuc2lnbmVkVHJhbnNhY3Rpb24gfSBmcm9tICdAc3Vic3RyYXRlL3R4d3JhcHBlci1jb3JlJztcbmltcG9ydCB7IG1ldGhvZHMgfSBmcm9tICdAc3Vic3RyYXRlL3R4d3JhcHBlci1wb2xrYWRvdCc7XG5pbXBvcnQgeyBCYXNlQ29pbiBhcyBDb2luQ29uZmlnIH0gZnJvbSAnQGJpdGdvLWJldGEvc3RhdGljcyc7XG5pbXBvcnQgeyBJbnZhbGlkVHJhbnNhY3Rpb25FcnJvciwgVHJhbnNhY3Rpb25UeXBlIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IHsgQm9uZEV4dHJhVHJhbnNhY3Rpb25TY2hlbWEgfSBmcm9tICcuL3R4blNjaGVtYSc7XG5pbXBvcnQgdXRpbHMgZnJvbSAnLi91dGlscyc7XG5pbXBvcnQgeyBCb25kRXh0cmFBcmdzIH0gZnJvbSAnLi9pZmFjZSc7XG5pbXBvcnQgQmlnTnVtYmVyIGZyb20gJ2JpZ251bWJlci5qcyc7XG5cbmV4cG9ydCBjbGFzcyBCb25kRXh0cmFCdWlsZGVyIGV4dGVuZHMgUG9seXhCYXNlQnVpbGRlciB7XG4gIHByb3RlY3RlZCBfYW1vdW50OiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3IoX2NvaW5Db25maWc6IFJlYWRvbmx5PENvaW5Db25maWc+KSB7XG4gICAgc3VwZXIoX2NvaW5Db25maWcpO1xuICAgIHRoaXMubWF0ZXJpYWwodXRpbHMuZ2V0TWF0ZXJpYWwoX2NvaW5Db25maWcubmV0d29yay50eXBlKSk7XG4gIH1cblxuICBwcm90ZWN0ZWQgZ2V0IHRyYW5zYWN0aW9uVHlwZSgpOiBUcmFuc2FjdGlvblR5cGUge1xuICAgIHJldHVybiBUcmFuc2FjdGlvblR5cGUuU3Rha2luZ0FjdGl2YXRlO1xuICB9XG5cbiAgLyoqXG4gICAqIEJ1aWxkIHRoZSBib25kRXh0cmEgdHJhbnNhY3Rpb25cbiAgICovXG4gIHByb3RlY3RlZCBidWlsZFRyYW5zYWN0aW9uKCk6IFVuc2lnbmVkVHJhbnNhY3Rpb24ge1xuICAgIGNvbnN0IGJhc2VUeEluZm8gPSB0aGlzLmNyZWF0ZUJhc2VUeEluZm8oKTtcblxuICAgIHJldHVybiBtZXRob2RzLnN0YWtpbmcuYm9uZEV4dHJhKFxuICAgICAge1xuICAgICAgICBtYXhBZGRpdGlvbmFsOiB0aGlzLl9hbW91bnQsXG4gICAgICB9LFxuICAgICAgYmFzZVR4SW5mby5iYXNlVHhJbmZvLFxuICAgICAgYmFzZVR4SW5mby5vcHRpb25zXG4gICAgKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXQgYWRkaXRpb25hbCBhbW91bnQgdG8gc3Rha2VcbiAgICovXG4gIGFtb3VudChhbW91bnQ6IHN0cmluZyk6IHRoaXMge1xuICAgIHRoaXMudmFsaWRhdGVWYWx1ZShuZXcgQmlnTnVtYmVyKGFtb3VudCkpO1xuICAgIHRoaXMuX2Ftb3VudCA9IGFtb3VudDtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgdGhlIGFtb3VudCB0byBzdGFrZVxuICAgKi9cbiAgZ2V0QW1vdW50KCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX2Ftb3VudDtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICB2YWxpZGF0ZURlY29kZWRUcmFuc2FjdGlvbihkZWNvZGVkVHhuOiBEZWNvZGVkU2lnbmluZ1BheWxvYWQgfCBEZWNvZGVkU2lnbmVkVHgpOiB2b2lkIHtcbiAgICBjb25zdCBtZXRob2ROYW1lID0gZGVjb2RlZFR4bi5tZXRob2Q/Lm5hbWUgYXMgc3RyaW5nO1xuXG4gICAgaWYgKG1ldGhvZE5hbWUgPT09ICdib25kRXh0cmEnKSB7XG4gICAgICBjb25zdCB0eE1ldGhvZCA9IGRlY29kZWRUeG4ubWV0aG9kLmFyZ3MgYXMgdW5rbm93biBhcyBCb25kRXh0cmFBcmdzO1xuICAgICAgY29uc3QgdmFsdWUgPSB0eE1ldGhvZC5tYXhBZGRpdGlvbmFsO1xuXG4gICAgICBjb25zdCB2YWxpZGF0aW9uUmVzdWx0ID0gQm9uZEV4dHJhVHJhbnNhY3Rpb25TY2hlbWEudmFsaWRhdGUoe1xuICAgICAgICB2YWx1ZSxcbiAgICAgIH0pO1xuXG4gICAgICBpZiAodmFsaWRhdGlvblJlc3VsdC5lcnJvcikge1xuICAgICAgICB0aHJvdyBuZXcgSW52YWxpZFRyYW5zYWN0aW9uRXJyb3IoYEludmFsaWQgdHJhbnNhY3Rpb246ICR7dmFsaWRhdGlvblJlc3VsdC5lcnJvci5tZXNzYWdlfWApO1xuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICB0aHJvdyBuZXcgSW52YWxpZFRyYW5zYWN0aW9uRXJyb3IoYEludmFsaWQgdHJhbnNhY3Rpb24gdHlwZTogJHttZXRob2ROYW1lfWApO1xuICAgIH1cbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICBwcm90ZWN0ZWQgZnJvbUltcGxlbWVudGF0aW9uKHJhd1RyYW5zYWN0aW9uOiBzdHJpbmcpOiBUcmFuc2FjdGlvbiB7XG4gICAgY29uc3QgdHggPSBzdXBlci5mcm9tSW1wbGVtZW50YXRpb24ocmF3VHJhbnNhY3Rpb24pO1xuICAgIGNvbnN0IG1ldGhvZE5hbWUgPSB0aGlzLl9tZXRob2Q/Lm5hbWUgYXMgc3RyaW5nO1xuXG4gICAgaWYgKG1ldGhvZE5hbWUgPT09ICdib25kRXh0cmEnICYmIHRoaXMuX21ldGhvZCkge1xuICAgICAgY29uc3QgdHhNZXRob2QgPSB0aGlzLl9tZXRob2QuYXJncyBhcyB1bmtub3duIGFzIEJvbmRFeHRyYUFyZ3M7XG4gICAgICB0aGlzLmFtb3VudCh0eE1ldGhvZC5tYXhBZGRpdGlvbmFsKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhyb3cgbmV3IEludmFsaWRUcmFuc2FjdGlvbkVycm9yKGBJbnZhbGlkIFRyYW5zYWN0aW9uIFR5cGU6ICR7bWV0aG9kTmFtZX0uIEV4cGVjdGVkIGJvbmRFeHRyYWApO1xuICAgIH1cblxuICAgIHJldHVybiB0eDtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICB2YWxpZGF0ZVRyYW5zYWN0aW9uKHR4OiBUcmFuc2FjdGlvbik6IHZvaWQge1xuICAgIHN1cGVyLnZhbGlkYXRlVHJhbnNhY3Rpb24odHgpO1xuICAgIHRoaXMudmFsaWRhdGVGaWVsZHMoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBWYWxpZGF0ZSB0aGUgYm9uZEV4dHJhIGZpZWxkc1xuICAgKi9cbiAgcHJpdmF0ZSB2YWxpZGF0ZUZpZWxkcygpOiB2b2lkIHtcbiAgICBjb25zdCB2YWxpZGF0aW9uUmVzdWx0ID0gQm9uZEV4dHJhVHJhbnNhY3Rpb25TY2hlbWEudmFsaWRhdGUoe1xuICAgICAgdmFsdWU6IHRoaXMuX2Ftb3VudCxcbiAgICB9KTtcblxuICAgIGlmICh2YWxpZGF0aW9uUmVzdWx0LmVycm9yKSB7XG4gICAgICB0aHJvdyBuZXcgSW52YWxpZFRyYW5zYWN0aW9uRXJyb3IoYEludmFsaWQgdHJhbnNhY3Rpb246ICR7dmFsaWRhdGlvblJlc3VsdC5lcnJvci5tZXNzYWdlfWApO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBWYWxpZGF0ZSBhbW91bnRcbiAgICovXG4gIHZhbGlkYXRlQW1vdW50KGFtb3VudDogc3RyaW5nKTogdm9pZCB7XG4gICAgY29uc3QgYW1vdW50Qk4gPSBuZXcgQmlnTnVtYmVyKGFtb3VudCk7XG4gICAgaWYgKGFtb3VudEJOLmlzTmFOKCkgfHwgYW1vdW50Qk4uaXNMZXNzVGhhbk9yRXF1YWxUbygwKSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBCb25kIGFtb3VudCAke2Ftb3VudH0gbXVzdCBiZSBhIHBvc2l0aXZlIG51bWJlcmApO1xuICAgIH1cbiAgfVxufVxuIl19
@@ -0,0 +1,12 @@
1
+ /**
2
+ * Address format constants for Polyx networks
3
+ */
4
+ /**
5
+ * Polyx mainnet address format
6
+ */
7
+ export declare const POLYX_ADDRESS_FORMAT = 12;
8
+ /**
9
+ * Tpolyx testnet address format
10
+ */
11
+ export declare const TPOLYX_ADDRESS_FORMAT = 42;
12
+ //# sourceMappingURL=constants.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/lib/constants.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH;;GAEG;AACH,eAAO,MAAM,oBAAoB,KAAK,CAAC;AAEvC;;GAEG;AACH,eAAO,MAAM,qBAAqB,KAAK,CAAC"}
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ /**
3
+ * Address format constants for Polyx networks
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.TPOLYX_ADDRESS_FORMAT = exports.POLYX_ADDRESS_FORMAT = void 0;
7
+ /**
8
+ * Polyx mainnet address format
9
+ */
10
+ exports.POLYX_ADDRESS_FORMAT = 12;
11
+ /**
12
+ * Tpolyx testnet address format
13
+ */
14
+ exports.TPOLYX_ADDRESS_FORMAT = 42;
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi9jb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOztHQUVHOzs7QUFFSDs7R0FFRztBQUNVLFFBQUEsb0JBQW9CLEdBQUcsRUFBRSxDQUFDO0FBRXZDOztHQUVHO0FBQ1UsUUFBQSxxQkFBcUIsR0FBRyxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEFkZHJlc3MgZm9ybWF0IGNvbnN0YW50cyBmb3IgUG9seXggbmV0d29ya3NcbiAqL1xuXG4vKipcbiAqIFBvbHl4IG1haW5uZXQgYWRkcmVzcyBmb3JtYXRcbiAqL1xuZXhwb3J0IGNvbnN0IFBPTFlYX0FERFJFU1NfRk9STUFUID0gMTI7XG5cbi8qKlxuICogVHBvbHl4IHRlc3RuZXQgYWRkcmVzcyBmb3JtYXRcbiAqL1xuZXhwb3J0IGNvbnN0IFRQT0xZWF9BRERSRVNTX0ZPUk1BVCA9IDQyO1xuIl19
@@ -1,7 +1,128 @@
1
+ import { Args } from '@substrate/txwrapper-core';
2
+ import { Interface } from '@bitgo-beta/abstract-substrate';
3
+ import { DecodedUnsignedTx } from '@substrate/txwrapper-core/lib/types';
4
+ export type AnyJson = string | number | boolean | null | {
5
+ [key: string]: AnyJson;
6
+ } | Array<AnyJson>;
1
7
  /**
2
- * The transaction data returned from the toJson() function of a transaction
8
+ * Extended TxData interface for Polyx transactions
9
+ * Adds assetId field to the base TxData interface from abstract-substrate
3
10
  */
4
- export interface TxData {
5
- id: string;
11
+ export interface TxData extends Interface.TxData {
12
+ assetId?: string;
13
+ fromDID?: string;
14
+ toDID?: string;
15
+ }
16
+ /**
17
+ * Settlement type for Polyx transactions
18
+ */
19
+ export declare enum SettlementType {
20
+ SettleOnAffirmation = "SettleOnAffirmation"
21
+ }
22
+ /**
23
+ * Portfolio kind for Polyx transactions
24
+ */
25
+ export declare enum PortfolioKind {
26
+ Default = "Default"
27
+ }
28
+ /**
29
+ * Method names for Polyx transactions.
30
+ * Extends the base MethodNames from Interface with additional Polyx-specific methods.
31
+ */
32
+ export declare const MethodNames: {
33
+ /**
34
+ * Registers a Decentralized Identifier (DID) along with Customer Due Diligence (CDD) information.
35
+ *
36
+ * @see https://developers.polymesh.network/sdk-docs/enums/Generated/Types/IdentityTx/#cddregisterdidwithcdd
37
+ */
38
+ readonly RegisterDidWithCDD: "cddRegisterDidWithCdd";
39
+ /**
40
+ * Pre-approves an asset.
41
+ */
42
+ readonly PreApproveAsset: "preApproveAsset";
43
+ readonly AddAndAffirmWithMediators: "addAndAffirmWithMediators";
44
+ readonly TransferAll: "transferAll";
45
+ readonly TransferKeepAlive: "transferKeepAlive";
46
+ readonly TransferWithMemo: "transferWithMemo";
47
+ readonly AddStake: "addStake";
48
+ readonly RemoveStake: "removeStake";
49
+ readonly Bond: "bond";
50
+ readonly BondExtra: "bondExtra";
51
+ readonly Nominate: "nominate";
52
+ readonly Chill: "chill";
53
+ readonly Unbond: "unbond";
54
+ readonly WithdrawUnbonded: "withdrawUnbonded";
55
+ readonly Batch: "batch";
56
+ readonly BatchAll: "batchAll";
57
+ };
58
+ export type MethodNamesType = keyof typeof MethodNames;
59
+ export type MethodNamesValues = (typeof MethodNames)[MethodNamesType];
60
+ export interface RegisterDidWithCDDArgs extends Args {
61
+ targetAccount: string;
62
+ secondaryKeys: [];
63
+ expiry: null;
64
+ }
65
+ export interface PreApproveAssetArgs extends Args {
66
+ assetId: string;
67
+ }
68
+ export interface AddAndAffirmWithMediatorsArgs extends Args {
69
+ venueId: null;
70
+ settlementType: SettlementType.SettleOnAffirmation;
71
+ tradeDate: null;
72
+ valueDate: null;
73
+ legs: Array<{
74
+ fungible: {
75
+ sender: {
76
+ did: string;
77
+ kind: PortfolioKind.Default;
78
+ };
79
+ receiver: {
80
+ did: string;
81
+ kind: PortfolioKind.Default;
82
+ };
83
+ assetId: string;
84
+ amount: string;
85
+ };
86
+ }>;
87
+ portfolios: Array<{
88
+ did: string;
89
+ kind: PortfolioKind.Default;
90
+ }>;
91
+ instructionMemo: string;
92
+ mediators: [];
93
+ }
94
+ export interface TxMethod extends Omit<Interface.TxMethod, 'args' | 'name'> {
95
+ args: Interface.TransferArgs | Interface.TransferAllArgs | Interface.AddStakeArgs | Interface.RemoveStakeArgs | Interface.BondArgs | Interface.BondExtraArgs | Interface.NominateArgs | Interface.ChillArgs | Interface.UnbondArgs | Interface.WithdrawUnbondedArgs | Interface.BatchArgs | RegisterDidWithCDDArgs | PreApproveAssetArgs | AddAndAffirmWithMediatorsArgs;
96
+ name: MethodNamesValues;
97
+ }
98
+ export interface DecodedTx extends Omit<DecodedUnsignedTx, 'method'> {
99
+ method: TxMethod;
100
+ }
101
+ export interface BondArgs extends Args {
102
+ value: string;
103
+ controller: string;
104
+ payee: string | {
105
+ Account: string;
106
+ };
107
+ }
108
+ export interface BondExtraArgs extends Args {
109
+ maxAdditional: string;
110
+ }
111
+ export interface NominateArgs extends Args {
112
+ targets: string[];
113
+ }
114
+ export interface BatchCallObject {
115
+ method?: string;
116
+ callIndex?: string;
117
+ args: Record<string, unknown>;
118
+ }
119
+ export interface BatchArgs {
120
+ calls: BatchCallObject[];
121
+ }
122
+ export interface UnbondArgs extends Args {
123
+ value: string;
124
+ }
125
+ export interface WithdrawUnbondedArgs extends Args {
126
+ numSlashingSpans: number;
6
127
  }
7
128
  //# sourceMappingURL=iface.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"iface.d.ts","sourceRoot":"","sources":["../../../src/lib/iface.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,WAAW,MAAM;IACrB,EAAE,EAAE,MAAM,CAAC;CACZ"}
1
+ {"version":3,"file":"iface.d.ts","sourceRoot":"","sources":["../../../src/lib/iface.ts"],"names":[],"mappings":"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"}
@@ -1,3 +1,38 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2lmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRoZSB0cmFuc2FjdGlvbiBkYXRhIHJldHVybmVkIGZyb20gdGhlIHRvSnNvbigpIGZ1bmN0aW9uIG9mIGEgdHJhbnNhY3Rpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUeERhdGEge1xuICBpZDogc3RyaW5nO1xufVxuIl19
3
+ exports.MethodNames = exports.PortfolioKind = exports.SettlementType = void 0;
4
+ const abstract_substrate_1 = require("@bitgo-beta/abstract-substrate");
5
+ /**
6
+ * Settlement type for Polyx transactions
7
+ */
8
+ var SettlementType;
9
+ (function (SettlementType) {
10
+ SettlementType["SettleOnAffirmation"] = "SettleOnAffirmation";
11
+ })(SettlementType || (exports.SettlementType = SettlementType = {}));
12
+ /**
13
+ * Portfolio kind for Polyx transactions
14
+ */
15
+ var PortfolioKind;
16
+ (function (PortfolioKind) {
17
+ PortfolioKind["Default"] = "Default";
18
+ })(PortfolioKind || (exports.PortfolioKind = PortfolioKind = {}));
19
+ /**
20
+ * Method names for Polyx transactions.
21
+ * Extends the base MethodNames from Interface with additional Polyx-specific methods.
22
+ */
23
+ exports.MethodNames = {
24
+ // Include all values from the base object
25
+ ...abstract_substrate_1.Interface.MethodNames,
26
+ /**
27
+ * Registers a Decentralized Identifier (DID) along with Customer Due Diligence (CDD) information.
28
+ *
29
+ * @see https://developers.polymesh.network/sdk-docs/enums/Generated/Types/IdentityTx/#cddregisterdidwithcdd
30
+ */
31
+ RegisterDidWithCDD: 'cddRegisterDidWithCdd',
32
+ /**
33
+ * Pre-approves an asset.
34
+ */
35
+ PreApproveAsset: 'preApproveAsset',
36
+ AddAndAffirmWithMediators: 'addAndAffirmWithMediators',
37
+ };
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2lmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLHVFQUEyRDtBQWUzRDs7R0FFRztBQUNILElBQVksY0FFWDtBQUZELFdBQVksY0FBYztJQUN4Qiw2REFBMkMsQ0FBQTtBQUM3QyxDQUFDLEVBRlcsY0FBYyw4QkFBZCxjQUFjLFFBRXpCO0FBRUQ7O0dBRUc7QUFDSCxJQUFZLGFBRVg7QUFGRCxXQUFZLGFBQWE7SUFDdkIsb0NBQW1CLENBQUE7QUFDckIsQ0FBQyxFQUZXLGFBQWEsNkJBQWIsYUFBYSxRQUV4QjtBQUVEOzs7R0FHRztBQUNVLFFBQUEsV0FBVyxHQUFHO0lBQ3pCLDBDQUEwQztJQUMxQyxHQUFHLDhCQUFTLENBQUMsV0FBVztJQUV4Qjs7OztPQUlHO0lBQ0gsa0JBQWtCLEVBQUUsdUJBQWdDO0lBRXBEOztPQUVHO0lBQ0gsZUFBZSxFQUFFLGlCQUEwQjtJQUUzQyx5QkFBeUIsRUFBRSwyQkFBb0M7Q0FDdkQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFyZ3MgfSBmcm9tICdAc3Vic3RyYXRlL3R4d3JhcHBlci1jb3JlJztcbmltcG9ydCB7IEludGVyZmFjZSB9IGZyb20gJ0BiaXRnby1iZXRhL2Fic3RyYWN0LXN1YnN0cmF0ZSc7XG5pbXBvcnQgeyBEZWNvZGVkVW5zaWduZWRUeCB9IGZyb20gJ0BzdWJzdHJhdGUvdHh3cmFwcGVyLWNvcmUvbGliL3R5cGVzJztcblxuZXhwb3J0IHR5cGUgQW55SnNvbiA9IHN0cmluZyB8IG51bWJlciB8IGJvb2xlYW4gfCBudWxsIHwgeyBba2V5OiBzdHJpbmddOiBBbnlKc29uIH0gfCBBcnJheTxBbnlKc29uPjtcblxuLyoqXG4gKiBFeHRlbmRlZCBUeERhdGEgaW50ZXJmYWNlIGZvciBQb2x5eCB0cmFuc2FjdGlvbnNcbiAqIEFkZHMgYXNzZXRJZCBmaWVsZCB0byB0aGUgYmFzZSBUeERhdGEgaW50ZXJmYWNlIGZyb20gYWJzdHJhY3Qtc3Vic3RyYXRlXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVHhEYXRhIGV4dGVuZHMgSW50ZXJmYWNlLlR4RGF0YSB7XG4gIGFzc2V0SWQ/OiBzdHJpbmc7XG4gIGZyb21ESUQ/OiBzdHJpbmc7XG4gIHRvRElEPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIFNldHRsZW1lbnQgdHlwZSBmb3IgUG9seXggdHJhbnNhY3Rpb25zXG4gKi9cbmV4cG9ydCBlbnVtIFNldHRsZW1lbnRUeXBlIHtcbiAgU2V0dGxlT25BZmZpcm1hdGlvbiA9ICdTZXR0bGVPbkFmZmlybWF0aW9uJyxcbn1cblxuLyoqXG4gKiBQb3J0Zm9saW8ga2luZCBmb3IgUG9seXggdHJhbnNhY3Rpb25zXG4gKi9cbmV4cG9ydCBlbnVtIFBvcnRmb2xpb0tpbmQge1xuICBEZWZhdWx0ID0gJ0RlZmF1bHQnLFxufVxuXG4vKipcbiAqIE1ldGhvZCBuYW1lcyBmb3IgUG9seXggdHJhbnNhY3Rpb25zLlxuICogRXh0ZW5kcyB0aGUgYmFzZSBNZXRob2ROYW1lcyBmcm9tIEludGVyZmFjZSB3aXRoIGFkZGl0aW9uYWwgUG9seXgtc3BlY2lmaWMgbWV0aG9kcy5cbiAqL1xuZXhwb3J0IGNvbnN0IE1ldGhvZE5hbWVzID0ge1xuICAvLyBJbmNsdWRlIGFsbCB2YWx1ZXMgZnJvbSB0aGUgYmFzZSBvYmplY3RcbiAgLi4uSW50ZXJmYWNlLk1ldGhvZE5hbWVzLFxuXG4gIC8qKlxuICAgKiBSZWdpc3RlcnMgYSBEZWNlbnRyYWxpemVkIElkZW50aWZpZXIgKERJRCkgYWxvbmcgd2l0aCBDdXN0b21lciBEdWUgRGlsaWdlbmNlIChDREQpIGluZm9ybWF0aW9uLlxuICAgKlxuICAgKiBAc2VlIGh0dHBzOi8vZGV2ZWxvcGVycy5wb2x5bWVzaC5uZXR3b3JrL3Nkay1kb2NzL2VudW1zL0dlbmVyYXRlZC9UeXBlcy9JZGVudGl0eVR4LyNjZGRyZWdpc3RlcmRpZHdpdGhjZGRcbiAgICovXG4gIFJlZ2lzdGVyRGlkV2l0aENERDogJ2NkZFJlZ2lzdGVyRGlkV2l0aENkZCcgYXMgY29uc3QsXG5cbiAgLyoqXG4gICAqIFByZS1hcHByb3ZlcyBhbiBhc3NldC5cbiAgICovXG4gIFByZUFwcHJvdmVBc3NldDogJ3ByZUFwcHJvdmVBc3NldCcgYXMgY29uc3QsXG5cbiAgQWRkQW5kQWZmaXJtV2l0aE1lZGlhdG9yczogJ2FkZEFuZEFmZmlybVdpdGhNZWRpYXRvcnMnIGFzIGNvbnN0LFxufSBhcyBjb25zdDtcblxuLy8gQ3JlYXRlIGEgdHlwZSB0aGF0IHJlcHJlc2VudHMgdGhlIGtleXMgb2YgdGhpcyBvYmplY3RcbmV4cG9ydCB0eXBlIE1ldGhvZE5hbWVzVHlwZSA9IGtleW9mIHR5cGVvZiBNZXRob2ROYW1lcztcblxuLy8gQ3JlYXRlIGEgdHlwZSB0aGF0IHJlcHJlc2VudHMgdGhlIHZhbHVlcyBvZiB0aGlzIG9iamVjdFxuZXhwb3J0IHR5cGUgTWV0aG9kTmFtZXNWYWx1ZXMgPSAodHlwZW9mIE1ldGhvZE5hbWVzKVtNZXRob2ROYW1lc1R5cGVdO1xuXG5leHBvcnQgaW50ZXJmYWNlIFJlZ2lzdGVyRGlkV2l0aENEREFyZ3MgZXh0ZW5kcyBBcmdzIHtcbiAgdGFyZ2V0QWNjb3VudDogc3RyaW5nO1xuICBzZWNvbmRhcnlLZXlzOiBbXTtcbiAgZXhwaXJ5OiBudWxsO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFByZUFwcHJvdmVBc3NldEFyZ3MgZXh0ZW5kcyBBcmdzIHtcbiAgYXNzZXRJZDogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFkZEFuZEFmZmlybVdpdGhNZWRpYXRvcnNBcmdzIGV4dGVuZHMgQXJncyB7XG4gIHZlbnVlSWQ6IG51bGw7XG4gIHNldHRsZW1lbnRUeXBlOiBTZXR0bGVtZW50VHlwZS5TZXR0bGVPbkFmZmlybWF0aW9uO1xuICB0cmFkZURhdGU6IG51bGw7XG4gIHZhbHVlRGF0ZTogbnVsbDtcbiAgbGVnczogQXJyYXk8e1xuICAgIGZ1bmdpYmxlOiB7XG4gICAgICBzZW5kZXI6IHsgZGlkOiBzdHJpbmc7IGtpbmQ6IFBvcnRmb2xpb0tpbmQuRGVmYXVsdCB9O1xuICAgICAgcmVjZWl2ZXI6IHsgZGlkOiBzdHJpbmc7IGtpbmQ6IFBvcnRmb2xpb0tpbmQuRGVmYXVsdCB9O1xuICAgICAgYXNzZXRJZDogc3RyaW5nO1xuICAgICAgYW1vdW50OiBzdHJpbmc7XG4gICAgfTtcbiAgfT47XG4gIHBvcnRmb2xpb3M6IEFycmF5PHsgZGlkOiBzdHJpbmc7IGtpbmQ6IFBvcnRmb2xpb0tpbmQuRGVmYXVsdCB9PjtcbiAgaW5zdHJ1Y3Rpb25NZW1vOiBzdHJpbmc7XG4gIG1lZGlhdG9yczogW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHhNZXRob2QgZXh0ZW5kcyBPbWl0PEludGVyZmFjZS5UeE1ldGhvZCwgJ2FyZ3MnIHwgJ25hbWUnPiB7XG4gIGFyZ3M6XG4gICAgfCBJbnRlcmZhY2UuVHJhbnNmZXJBcmdzXG4gICAgfCBJbnRlcmZhY2UuVHJhbnNmZXJBbGxBcmdzXG4gICAgfCBJbnRlcmZhY2UuQWRkU3Rha2VBcmdzXG4gICAgfCBJbnRlcmZhY2UuUmVtb3ZlU3Rha2VBcmdzXG4gICAgfCBJbnRlcmZhY2UuQm9uZEFyZ3NcbiAgICB8IEludGVyZmFjZS5Cb25kRXh0cmFBcmdzXG4gICAgfCBJbnRlcmZhY2UuTm9taW5hdGVBcmdzXG4gICAgfCBJbnRlcmZhY2UuQ2hpbGxBcmdzXG4gICAgfCBJbnRlcmZhY2UuVW5ib25kQXJnc1xuICAgIHwgSW50ZXJmYWNlLldpdGhkcmF3VW5ib25kZWRBcmdzXG4gICAgfCBJbnRlcmZhY2UuQmF0Y2hBcmdzXG4gICAgfCBSZWdpc3RlckRpZFdpdGhDRERBcmdzXG4gICAgfCBQcmVBcHByb3ZlQXNzZXRBcmdzXG4gICAgfCBBZGRBbmRBZmZpcm1XaXRoTWVkaWF0b3JzQXJncztcbiAgbmFtZTogTWV0aG9kTmFtZXNWYWx1ZXM7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGVjb2RlZFR4IGV4dGVuZHMgT21pdDxEZWNvZGVkVW5zaWduZWRUeCwgJ21ldGhvZCc+IHtcbiAgbWV0aG9kOiBUeE1ldGhvZDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBCb25kQXJncyBleHRlbmRzIEFyZ3Mge1xuICB2YWx1ZTogc3RyaW5nO1xuICBjb250cm9sbGVyOiBzdHJpbmc7XG4gIHBheWVlOiBzdHJpbmcgfCB7IEFjY291bnQ6IHN0cmluZyB9O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEJvbmRFeHRyYUFyZ3MgZXh0ZW5kcyBBcmdzIHtcbiAgbWF4QWRkaXRpb25hbDogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE5vbWluYXRlQXJncyBleHRlbmRzIEFyZ3Mge1xuICB0YXJnZXRzOiBzdHJpbmdbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBCYXRjaENhbGxPYmplY3Qge1xuICBtZXRob2Q/OiBzdHJpbmc7XG4gIGNhbGxJbmRleD86IHN0cmluZztcbiAgYXJnczogUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQmF0Y2hBcmdzIHtcbiAgY2FsbHM6IEJhdGNoQ2FsbE9iamVjdFtdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFVuYm9uZEFyZ3MgZXh0ZW5kcyBBcmdzIHtcbiAgdmFsdWU6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBXaXRoZHJhd1VuYm9uZGVkQXJncyBleHRlbmRzIEFyZ3Mge1xuICBudW1TbGFzaGluZ1NwYW5zOiBudW1iZXI7XG59XG4iXX0=
@@ -1,9 +1,17 @@
1
- import * as Utils from './utils';
2
- import * as Interface from './iface';
3
- export { KeyPair } from './keyPair';
4
- export { Transaction } from './transaction';
5
- export { TransactionBuilder } from './transactionBuilder';
6
- export { TransferBuilder } from './transferBuilder';
1
+ export { Constants, Errors, Interface, KeyPair, SingletonRegistry, Transaction, TransactionBuilder, } from '@bitgo-beta/abstract-substrate';
7
2
  export { TransactionBuilderFactory } from './transactionBuilderFactory';
8
- export { Interface, Utils };
3
+ export { PolyxBaseBuilder } from './baseBuilder';
4
+ export { TransferBuilder } from './transferBuilder';
5
+ export { RegisterDidWithCDDBuilder } from './registerDidWithCDDBuilder';
6
+ export { PreApproveAssetBuilder } from './preApproveAssetBuilder';
7
+ export { TokenTransferBuilder } from './tokenTransferBuilder';
8
+ export { Transaction as PolyxTransaction } from './transaction';
9
+ export { BondExtraBuilder } from './bondExtraBuilder';
10
+ export { BatchStakingBuilder as BatchBuilder } from './batchStakingBuilder';
11
+ export { BatchUnstakingBuilder } from './batchUnstakingBuilder';
12
+ export { UnbondBuilder } from './unbondBuilder';
13
+ export { WithdrawUnbondedBuilder } from './withdrawUnbondedBuilder';
14
+ export { Utils, default as utils } from './utils';
15
+ export * from './iface';
16
+ export { BondArgs, NominateArgs, BatchCallObject, BatchArgs } from './iface';
9
17
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,SAAS,CAAC;AACjC,OAAO,KAAK,SAAS,MAAM,SAAS,CAAC;AAErC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,6BAA6B,CAAC;AACxE,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,MAAM,EACN,SAAS,EACT,OAAO,EACP,iBAAiB,EACjB,WAAW,EACX,kBAAkB,GACnB,MAAM,gCAAgC,CAAC;AAExC,OAAO,EAAE,yBAAyB,EAAE,MAAM,6BAA6B,CAAC;AACxE,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,6BAA6B,CAAC;AACxE,OAAO,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAClE,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,WAAW,IAAI,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAChE,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,mBAAmB,IAAI,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAC5E,OAAO,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAC;AAChE,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,uBAAuB,EAAE,MAAM,2BAA2B,CAAC;AACpE,OAAO,EAAE,KAAK,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,SAAS,CAAC;AAClD,cAAc,SAAS,CAAC;AAExB,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC"}