@bitgo-beta/sdk-coin-vet 1.0.1-beta.5 → 1.0.1-beta.500

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 (156) hide show
  1. package/dist/src/index.d.ts +2 -0
  2. package/dist/src/index.d.ts.map +1 -1
  3. package/dist/src/index.js +3 -1
  4. package/dist/src/lib/constants.d.ts +29 -1
  5. package/dist/src/lib/constants.d.ts.map +1 -1
  6. package/dist/src/lib/constants.js +31 -3
  7. package/dist/src/lib/iface.d.ts +38 -0
  8. package/dist/src/lib/iface.d.ts.map +1 -0
  9. package/dist/src/lib/iface.js +3 -0
  10. package/dist/src/lib/index.d.ts +26 -1
  11. package/dist/src/lib/index.d.ts.map +1 -1
  12. package/dist/src/lib/index.js +52 -2
  13. package/dist/src/lib/keyPair.d.ts +26 -0
  14. package/dist/src/lib/keyPair.d.ts.map +1 -0
  15. package/dist/src/lib/keyPair.js +65 -0
  16. package/dist/src/lib/transaction/addressInitializationTransaction.d.ts +31 -0
  17. package/dist/src/lib/transaction/addressInitializationTransaction.d.ts.map +1 -0
  18. package/dist/src/lib/transaction/addressInitializationTransaction.js +170 -0
  19. package/dist/src/lib/transaction/burnNftTransaction.d.ts +29 -0
  20. package/dist/src/lib/transaction/burnNftTransaction.d.ts.map +1 -0
  21. package/dist/src/lib/transaction/burnNftTransaction.js +138 -0
  22. package/dist/src/lib/transaction/claimRewards.d.ts +41 -0
  23. package/dist/src/lib/transaction/claimRewards.d.ts.map +1 -0
  24. package/dist/src/lib/transaction/claimRewards.js +210 -0
  25. package/dist/src/lib/transaction/delegateClauseTransaction.d.ts +27 -0
  26. package/dist/src/lib/transaction/delegateClauseTransaction.d.ts.map +1 -0
  27. package/dist/src/lib/transaction/delegateClauseTransaction.js +158 -0
  28. package/dist/src/lib/transaction/exitDelegation.d.ts +29 -0
  29. package/dist/src/lib/transaction/exitDelegation.d.ts.map +1 -0
  30. package/dist/src/lib/transaction/exitDelegation.js +143 -0
  31. package/dist/src/lib/transaction/flushTokenTransaction.d.ts +20 -0
  32. package/dist/src/lib/transaction/flushTokenTransaction.d.ts.map +1 -0
  33. package/dist/src/lib/transaction/flushTokenTransaction.js +98 -0
  34. package/dist/src/lib/transaction/nftTransaction.d.ts +17 -0
  35. package/dist/src/lib/transaction/nftTransaction.d.ts.map +1 -0
  36. package/dist/src/lib/transaction/nftTransaction.js +108 -0
  37. package/dist/src/lib/transaction/stakeClauseTransaction.d.ts +27 -0
  38. package/dist/src/lib/transaction/stakeClauseTransaction.d.ts.map +1 -0
  39. package/dist/src/lib/transaction/stakeClauseTransaction.js +158 -0
  40. package/dist/src/lib/transaction/stakingTransaction.d.ts +31 -0
  41. package/dist/src/lib/transaction/stakingTransaction.d.ts.map +1 -0
  42. package/dist/src/lib/transaction/stakingTransaction.js +169 -0
  43. package/dist/src/lib/transaction/tokenTransaction.d.ts +14 -0
  44. package/dist/src/lib/transaction/tokenTransaction.d.ts.map +1 -0
  45. package/dist/src/lib/transaction/tokenTransaction.js +95 -0
  46. package/dist/src/lib/transaction/transaction.d.ts +109 -0
  47. package/dist/src/lib/transaction/transaction.d.ts.map +1 -0
  48. package/dist/src/lib/transaction/transaction.js +484 -0
  49. package/dist/src/lib/transactionBuilder/addressInitializationBuilder.d.ts +78 -0
  50. package/dist/src/lib/transactionBuilder/addressInitializationBuilder.d.ts.map +1 -0
  51. package/dist/src/lib/transactionBuilder/addressInitializationBuilder.js +158 -0
  52. package/dist/src/lib/transactionBuilder/burnNftBuilder.d.ts +59 -0
  53. package/dist/src/lib/transactionBuilder/burnNftBuilder.d.ts.map +1 -0
  54. package/dist/src/lib/transactionBuilder/burnNftBuilder.js +118 -0
  55. package/dist/src/lib/transactionBuilder/claimRewardsBuilder.d.ts +57 -0
  56. package/dist/src/lib/transactionBuilder/claimRewardsBuilder.d.ts.map +1 -0
  57. package/dist/src/lib/transactionBuilder/claimRewardsBuilder.js +142 -0
  58. package/dist/src/lib/transactionBuilder/delegateTxnBuilder.d.ts +72 -0
  59. package/dist/src/lib/transactionBuilder/delegateTxnBuilder.d.ts.map +1 -0
  60. package/dist/src/lib/transactionBuilder/delegateTxnBuilder.js +133 -0
  61. package/dist/src/lib/transactionBuilder/exitDelegationBuilder.d.ts +59 -0
  62. package/dist/src/lib/transactionBuilder/exitDelegationBuilder.d.ts.map +1 -0
  63. package/dist/src/lib/transactionBuilder/exitDelegationBuilder.js +118 -0
  64. package/dist/src/lib/transactionBuilder/flushTokenTransactionBuilder.d.ts +66 -0
  65. package/dist/src/lib/transactionBuilder/flushTokenTransactionBuilder.d.ts.map +1 -0
  66. package/dist/src/lib/transactionBuilder/flushTokenTransactionBuilder.js +129 -0
  67. package/dist/src/lib/transactionBuilder/nftTransactionBuilder.d.ts +23 -0
  68. package/dist/src/lib/transactionBuilder/nftTransactionBuilder.d.ts.map +1 -0
  69. package/dist/src/lib/transactionBuilder/nftTransactionBuilder.js +93 -0
  70. package/dist/src/lib/transactionBuilder/stakeClauseTxnBuilder.d.ts +73 -0
  71. package/dist/src/lib/transactionBuilder/stakeClauseTxnBuilder.d.ts.map +1 -0
  72. package/dist/src/lib/transactionBuilder/stakeClauseTxnBuilder.js +146 -0
  73. package/dist/src/lib/transactionBuilder/stakingBuilder.d.ts +73 -0
  74. package/dist/src/lib/transactionBuilder/stakingBuilder.d.ts.map +1 -0
  75. package/dist/src/lib/transactionBuilder/stakingBuilder.js +147 -0
  76. package/dist/src/lib/transactionBuilder/tokenTransactionBuilder.d.ts +21 -0
  77. package/dist/src/lib/transactionBuilder/tokenTransactionBuilder.d.ts.map +1 -0
  78. package/dist/src/lib/transactionBuilder/tokenTransactionBuilder.js +70 -0
  79. package/dist/src/lib/transactionBuilder/transactionBuilder.d.ts +55 -0
  80. package/dist/src/lib/transactionBuilder/transactionBuilder.d.ts.map +1 -0
  81. package/dist/src/lib/transactionBuilder/transactionBuilder.js +159 -0
  82. package/dist/src/lib/transactionBuilder/transferBuilder.d.ts +10 -0
  83. package/dist/src/lib/transactionBuilder/transferBuilder.d.ts.map +1 -0
  84. package/dist/src/lib/transactionBuilder/transferBuilder.js +45 -0
  85. package/dist/src/lib/transactionBuilderFactory.d.ts +77 -0
  86. package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -0
  87. package/dist/src/lib/transactionBuilderFactory.js +173 -0
  88. package/dist/src/lib/types.d.ts +32 -0
  89. package/dist/src/lib/types.d.ts.map +1 -0
  90. package/dist/src/lib/types.js +3 -0
  91. package/dist/src/lib/utils.d.ts +102 -1
  92. package/dist/src/lib/utils.d.ts.map +1 -1
  93. package/dist/src/lib/utils.js +301 -6
  94. package/dist/src/register.d.ts.map +1 -1
  95. package/dist/src/register.js +9 -1
  96. package/dist/src/vet.d.ts +87 -4
  97. package/dist/src/vet.d.ts.map +1 -1
  98. package/dist/src/vet.js +613 -13
  99. package/dist/src/vetNFTCollection.d.ts +18 -0
  100. package/dist/src/vetNFTCollection.d.ts.map +1 -0
  101. package/dist/src/vetNFTCollection.js +52 -0
  102. package/dist/src/vetToken.d.ts +19 -0
  103. package/dist/src/vetToken.d.ts.map +1 -0
  104. package/dist/src/vetToken.js +52 -0
  105. package/dist/test/resources/vet.d.ts +72 -0
  106. package/dist/test/resources/vet.d.ts.map +1 -0
  107. package/dist/test/resources/vet.js +127 -0
  108. package/dist/test/transactionBuilder/addressInitializationBuilder.d.ts +2 -0
  109. package/dist/test/transactionBuilder/addressInitializationBuilder.d.ts.map +1 -0
  110. package/dist/test/transactionBuilder/addressInitializationBuilder.js +141 -0
  111. package/dist/test/transactionBuilder/burnNftBuilder.d.ts +2 -0
  112. package/dist/test/transactionBuilder/burnNftBuilder.d.ts.map +1 -0
  113. package/dist/test/transactionBuilder/burnNftBuilder.js +150 -0
  114. package/dist/test/transactionBuilder/claimRewardsBuilder.d.ts +2 -0
  115. package/dist/test/transactionBuilder/claimRewardsBuilder.d.ts.map +1 -0
  116. package/dist/test/transactionBuilder/claimRewardsBuilder.js +246 -0
  117. package/dist/test/transactionBuilder/delegateClauseTxnBuilder.d.ts +2 -0
  118. package/dist/test/transactionBuilder/delegateClauseTxnBuilder.d.ts.map +1 -0
  119. package/dist/test/transactionBuilder/delegateClauseTxnBuilder.js +185 -0
  120. package/dist/test/transactionBuilder/exitDelegationBuilder.d.ts +2 -0
  121. package/dist/test/transactionBuilder/exitDelegationBuilder.d.ts.map +1 -0
  122. package/dist/test/transactionBuilder/exitDelegationBuilder.js +150 -0
  123. package/dist/test/transactionBuilder/flushTokenTransactionBuilder.d.ts +2 -0
  124. package/dist/test/transactionBuilder/flushTokenTransactionBuilder.d.ts.map +1 -0
  125. package/dist/test/transactionBuilder/flushTokenTransactionBuilder.js +132 -0
  126. package/dist/test/transactionBuilder/nftTransactionBuilder.d.ts +2 -0
  127. package/dist/test/transactionBuilder/nftTransactionBuilder.d.ts.map +1 -0
  128. package/dist/test/transactionBuilder/nftTransactionBuilder.js +242 -0
  129. package/dist/test/transactionBuilder/stakeClauseTransactionBuilder.d.ts +2 -0
  130. package/dist/test/transactionBuilder/stakeClauseTransactionBuilder.d.ts.map +1 -0
  131. package/dist/test/transactionBuilder/stakeClauseTransactionBuilder.js +247 -0
  132. package/dist/test/transactionBuilder/stakingTransaction.d.ts +2 -0
  133. package/dist/test/transactionBuilder/stakingTransaction.d.ts.map +1 -0
  134. package/dist/test/transactionBuilder/stakingTransaction.js +250 -0
  135. package/dist/test/transactionBuilder/tokenTransactionBuilder.d.ts +2 -0
  136. package/dist/test/transactionBuilder/tokenTransactionBuilder.d.ts.map +1 -0
  137. package/dist/test/transactionBuilder/tokenTransactionBuilder.js +249 -0
  138. package/dist/test/transactionBuilder/transferBuilder.d.ts +2 -0
  139. package/dist/test/transactionBuilder/transferBuilder.d.ts.map +1 -0
  140. package/dist/test/transactionBuilder/transferBuilder.js +214 -0
  141. package/dist/test/unit/keyPair.d.ts +2 -0
  142. package/dist/test/unit/keyPair.d.ts.map +1 -0
  143. package/dist/test/unit/keyPair.js +181 -0
  144. package/dist/test/unit/stakingFlowE2E.d.ts +2 -0
  145. package/dist/test/unit/stakingFlowE2E.d.ts.map +1 -0
  146. package/dist/test/unit/stakingFlowE2E.js +222 -0
  147. package/dist/test/unit/utils.d.ts +2 -0
  148. package/dist/test/unit/utils.d.ts.map +1 -0
  149. package/dist/test/unit/utils.js +106 -0
  150. package/dist/test/unit/vet.d.ts +2 -0
  151. package/dist/test/unit/vet.d.ts.map +1 -0
  152. package/dist/test/unit/vet.js +251 -0
  153. package/dist/tsconfig.tsbuildinfo +1 -0
  154. package/package.json +22 -8
  155. package/.eslintignore +0 -5
  156. package/.mocharc.yml +0 -8
@@ -0,0 +1,158 @@
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.AddressInitializationBuilder = void 0;
7
+ const assert_1 = __importDefault(require("assert"));
8
+ const abstract_eth_1 = require("@bitgo-beta/abstract-eth");
9
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
10
+ const ethereumjs_util_1 = require("ethereumjs-util");
11
+ const ethereumjs_abi_1 = __importDefault(require("ethereumjs-abi"));
12
+ const transactionBuilder_1 = require("./transactionBuilder");
13
+ const utils_1 = __importDefault(require("../utils"));
14
+ class AddressInitializationBuilder extends transactionBuilder_1.TransactionBuilder {
15
+ /**
16
+ * Creates a new AddressInitializationBuilder instance.
17
+ *
18
+ * @param {Readonly<CoinConfig>} _coinConfig - The coin configuration object
19
+ */
20
+ constructor(_coinConfig) {
21
+ super(_coinConfig);
22
+ }
23
+ /**
24
+ * Initializes the builder with an existing AddressInitializationTransaction.
25
+ *
26
+ * @param {AddressInitializationTransaction} tx - The transaction to initialize the builder with
27
+ */
28
+ initBuilder(tx) {
29
+ this._transaction = tx;
30
+ }
31
+ /**
32
+ * Gets the address initialization transaction instance.
33
+ *
34
+ * @returns {AddressInitializationTransaction} The address initialization transaction
35
+ */
36
+ get addressInitializationTransaction() {
37
+ return this._transaction;
38
+ }
39
+ /**
40
+ * Gets the transaction type for address initialization.
41
+ *
42
+ * @returns {TransactionType} The transaction type
43
+ */
44
+ get transactionType() {
45
+ return sdk_core_1.TransactionType.AddressInitialization;
46
+ }
47
+ /**
48
+ * Validates the transaction clauses for address initialization.
49
+ * @param {TransactionClause[]} clauses - The transaction clauses to validate.
50
+ * @returns {boolean} - Returns true if the clauses are valid, false otherwise.
51
+ */
52
+ isValidTransactionClauses(clauses) {
53
+ try {
54
+ if (!clauses || !Array.isArray(clauses) || clauses.length === 0) {
55
+ return false;
56
+ }
57
+ const clause = clauses[0];
58
+ if (!clause.to || !utils_1.default.isValidAddress(clause.to)) {
59
+ return false;
60
+ }
61
+ // For address init transactions, value must be exactly '0x0'
62
+ if (clause.value !== 0) {
63
+ return false;
64
+ }
65
+ const { baseAddress, addressCreationSalt, feeAddress } = (0, abstract_eth_1.decodeForwarderCreationData)(clause.data);
66
+ if (!utils_1.default.isValidAddress(baseAddress) || !utils_1.default.isValidAddress(feeAddress)) {
67
+ return false;
68
+ }
69
+ if (!addressCreationSalt) {
70
+ return false;
71
+ }
72
+ return true;
73
+ }
74
+ catch (e) {
75
+ return false;
76
+ }
77
+ }
78
+ /**
79
+ * Sets the base address for this forwarder init tx.
80
+ *
81
+ * @param {string} address - The base address to be set for the forwarder address
82
+ * @returns {AddressInitializationBuilder} This transaction builder
83
+ */
84
+ baseAddress(address) {
85
+ this.validateAddress({ address });
86
+ this.addressInitializationTransaction.baseAddress = address;
87
+ return this;
88
+ }
89
+ /**
90
+ * Sets the fee address for this forwarder init tx.
91
+ *
92
+ * @param {string} address - The fee address to be set for the forwarder address
93
+ * @returns {AddressInitializationBuilder} This transaction builder
94
+ */
95
+ feeAddress(address) {
96
+ this.validateAddress({ address });
97
+ this.addressInitializationTransaction.feeAddress = address;
98
+ return this;
99
+ }
100
+ /**
101
+ * Sets the salt value for the forwarder address creation.
102
+ *
103
+ * @param {string} salt - The salt value to use for address creation
104
+ * @returns {AddressInitializationBuilder} This transaction builder
105
+ */
106
+ salt(salt) {
107
+ this.addressInitializationTransaction.salt = salt;
108
+ return this;
109
+ }
110
+ /**
111
+ * Sets the initialization code for the forwarder contract.
112
+ *
113
+ * @param {string} address - The address to generate proxy init code for
114
+ * @returns {AddressInitializationBuilder} This transaction builder
115
+ */
116
+ initCode(address) {
117
+ this.validateAddress({ address });
118
+ this.addressInitializationTransaction.initCode = (0, abstract_eth_1.getProxyInitcode)(address);
119
+ return this;
120
+ }
121
+ /** @inheritdoc */
122
+ validateTransaction(transaction) {
123
+ if (!transaction) {
124
+ throw new Error('transaction not defined');
125
+ }
126
+ (0, assert_1.default)(transaction.contract, 'Contract address is required');
127
+ (0, assert_1.default)(transaction.baseAddress, 'Base address is required');
128
+ (0, assert_1.default)(transaction.feeAddress, 'Fee address is required');
129
+ (0, assert_1.default)(transaction.salt, 'Salt is required');
130
+ (0, assert_1.default)(transaction.initCode, 'Init code is required');
131
+ this.validateAddress({ address: transaction.contract });
132
+ this.validateAddress({ address: transaction.baseAddress });
133
+ this.validateAddress({ address: transaction.feeAddress });
134
+ }
135
+ /** @inheritdoc */
136
+ async buildImplementation() {
137
+ const transactionData = this.getAddressInitializationData();
138
+ this.transaction.type = this.transactionType;
139
+ this.addressInitializationTransaction.transactionData = transactionData;
140
+ await this.addressInitializationTransaction.build();
141
+ return this.transaction;
142
+ }
143
+ /**
144
+ * Generates the transaction data for address initialization by encoding the createForwarder method call.
145
+ *
146
+ * @private
147
+ * @returns {string} The encoded transaction data as a hex string
148
+ */
149
+ getAddressInitializationData() {
150
+ const saltBuffer = (0, ethereumjs_util_1.setLengthLeft)((0, ethereumjs_util_1.toBuffer)(this.addressInitializationTransaction.salt), 32);
151
+ const { createForwarderParams, createForwarderTypes } = (0, abstract_eth_1.getCreateForwarderParamsAndTypes)(this.addressInitializationTransaction.baseAddress, saltBuffer, this.addressInitializationTransaction.feeAddress);
152
+ const method = ethereumjs_abi_1.default.methodID('createForwarder', createForwarderTypes);
153
+ const args = ethereumjs_abi_1.default.rawEncode(createForwarderTypes, createForwarderParams);
154
+ return (0, ethereumjs_util_1.addHexPrefix)(Buffer.concat([method, args]).toString('hex'));
155
+ }
156
+ }
157
+ exports.AddressInitializationBuilder = AddressInitializationBuilder;
158
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"addressInitializationBuilder.js","sourceRoot":"","sources":["../../../../src/lib/transactionBuilder/addressInitializationBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport { TransactionClause } from '@vechain/sdk-core';\nimport { getProxyInitcode, getCreateForwarderParamsAndTypes, decodeForwarderCreationData } from '@bitgo-beta/abstract-eth';\nimport { TransactionType } from '@bitgo-beta/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { setLengthLeft, toBuffer, addHexPrefix } from 'ethereumjs-util';\nimport EthereumAbi from 'ethereumjs-abi';\n\nimport { TransactionBuilder } from './transactionBuilder';\nimport { AddressInitializationTransaction } from '../transaction/addressInitializationTransaction';\nimport { Transaction } from '../transaction/transaction';\nimport utils from '../utils';\n\nexport class AddressInitializationBuilder extends TransactionBuilder {\n  /**\n   * Creates a new AddressInitializationBuilder instance.\n   *\n   * @param {Readonly<CoinConfig>} _coinConfig - The coin configuration object\n   */\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /**\n   * Initializes the builder with an existing AddressInitializationTransaction.\n   *\n   * @param {AddressInitializationTransaction} tx - The transaction to initialize the builder with\n   */\n  initBuilder(tx: AddressInitializationTransaction): void {\n    this._transaction = tx;\n  }\n\n  /**\n   * Gets the address initialization transaction instance.\n   *\n   * @returns {AddressInitializationTransaction} The address initialization transaction\n   */\n  get addressInitializationTransaction(): AddressInitializationTransaction {\n    return this._transaction as AddressInitializationTransaction;\n  }\n\n  /**\n   * Gets the transaction type for address initialization.\n   *\n   * @returns {TransactionType} The transaction type\n   */\n  protected get transactionType(): TransactionType {\n    return TransactionType.AddressInitialization;\n  }\n\n  /**\n   * Validates the transaction clauses for address initialization.\n   * @param {TransactionClause[]} clauses - The transaction clauses to validate.\n   * @returns {boolean} - Returns true if the clauses are valid, false otherwise.\n   */\n  protected isValidTransactionClauses(clauses: TransactionClause[]): boolean {\n    try {\n      if (!clauses || !Array.isArray(clauses) || clauses.length === 0) {\n        return false;\n      }\n\n      const clause = clauses[0];\n\n      if (!clause.to || !utils.isValidAddress(clause.to)) {\n        return false;\n      }\n\n      // For address init transactions, value must be exactly '0x0'\n      if (clause.value !== 0) {\n        return false;\n      }\n\n      const { baseAddress, addressCreationSalt, feeAddress } = decodeForwarderCreationData(clause.data);\n\n      if (!utils.isValidAddress(baseAddress as string) || !utils.isValidAddress(feeAddress as string)) {\n        return false;\n      }\n\n      if (!addressCreationSalt) {\n        return false;\n      }\n\n      return true;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  /**\n   * Sets the base address for this forwarder init tx.\n   *\n   * @param {string} address - The base address to be set for the forwarder address\n   * @returns {AddressInitializationBuilder} This transaction builder\n   */\n  baseAddress(address: string): this {\n    this.validateAddress({ address });\n    this.addressInitializationTransaction.baseAddress = address;\n    return this;\n  }\n\n  /**\n   * Sets the fee address for this forwarder init tx.\n   *\n   * @param {string} address - The fee address to be set for the forwarder address\n   * @returns {AddressInitializationBuilder} This transaction builder\n   */\n  feeAddress(address: string): this {\n    this.validateAddress({ address });\n    this.addressInitializationTransaction.feeAddress = address;\n    return this;\n  }\n\n  /**\n   * Sets the salt value for the forwarder address creation.\n   *\n   * @param {string} salt - The salt value to use for address creation\n   * @returns {AddressInitializationBuilder} This transaction builder\n   */\n  salt(salt: string): this {\n    this.addressInitializationTransaction.salt = salt;\n    return this;\n  }\n\n  /**\n   * Sets the initialization code for the forwarder contract.\n   *\n   * @param {string} address - The address to generate proxy init code for\n   * @returns {AddressInitializationBuilder} This transaction builder\n   */\n  initCode(address: string): this {\n    this.validateAddress({ address });\n    this.addressInitializationTransaction.initCode = getProxyInitcode(address);\n    return this;\n  }\n\n  /** @inheritdoc */\n  validateTransaction(transaction?: AddressInitializationTransaction): void {\n    if (!transaction) {\n      throw new Error('transaction not defined');\n    }\n    assert(transaction.contract, 'Contract address is required');\n    assert(transaction.baseAddress, 'Base address is required');\n    assert(transaction.feeAddress, 'Fee address is required');\n    assert(transaction.salt, 'Salt is required');\n    assert(transaction.initCode, 'Init code is required');\n\n    this.validateAddress({ address: transaction.contract });\n    this.validateAddress({ address: transaction.baseAddress });\n    this.validateAddress({ address: transaction.feeAddress });\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    const transactionData = this.getAddressInitializationData();\n    this.transaction.type = this.transactionType;\n    this.addressInitializationTransaction.transactionData = transactionData;\n    await this.addressInitializationTransaction.build();\n    return this.transaction;\n  }\n\n  /**\n   * Generates the transaction data for address initialization by encoding the createForwarder method call.\n   *\n   * @private\n   * @returns {string} The encoded transaction data as a hex string\n   */\n  private getAddressInitializationData(): string {\n    const saltBuffer = setLengthLeft(toBuffer(this.addressInitializationTransaction.salt), 32);\n    const { createForwarderParams, createForwarderTypes } = getCreateForwarderParamsAndTypes(\n      this.addressInitializationTransaction.baseAddress,\n      saltBuffer,\n      this.addressInitializationTransaction.feeAddress\n    );\n    const method = EthereumAbi.methodID('createForwarder', createForwarderTypes);\n    const args = EthereumAbi.rawEncode(createForwarderTypes, createForwarderParams);\n    return addHexPrefix(Buffer.concat([method, args]).toString('hex'));\n  }\n}\n"]}
@@ -0,0 +1,59 @@
1
+ import { TransactionClause } from '@vechain/sdk-core';
2
+ import { TransactionType } from '@bitgo-beta/sdk-core';
3
+ import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
4
+ import { TransactionBuilder } from './transactionBuilder';
5
+ import { BurnNftTransaction } from '../transaction/burnNftTransaction';
6
+ import { Transaction } from '../transaction/transaction';
7
+ export declare class BurnNftBuilder extends TransactionBuilder {
8
+ /**
9
+ * Creates a new BurnNftBuilder instance.
10
+ *
11
+ * @param {Readonly<CoinConfig>} _coinConfig - The coin configuration object
12
+ */
13
+ constructor(_coinConfig: Readonly<CoinConfig>);
14
+ /**
15
+ * Initializes the builder with an existing BurnNftTransaction.
16
+ *
17
+ * @param {BurnNftTransaction} tx - The transaction to initialize the builder with
18
+ */
19
+ initBuilder(tx: BurnNftTransaction): void;
20
+ /**
21
+ * Gets the burn NFT transaction instance.
22
+ *
23
+ * @returns {BurnNftTransaction} The burn NFT transaction
24
+ */
25
+ get burnNftTransaction(): BurnNftTransaction;
26
+ /**
27
+ * Gets the transaction type for burning NFT.
28
+ *
29
+ * @returns {TransactionType} The transaction type
30
+ */
31
+ protected get transactionType(): TransactionType;
32
+ /**
33
+ * Validates the transaction clauses for burning NFT.
34
+ * @param {TransactionClause[]} clauses - The transaction clauses to validate.
35
+ * @returns {boolean} - Returns true if the clauses are valid, false otherwise.
36
+ */
37
+ protected isValidTransactionClauses(clauses: TransactionClause[]): boolean;
38
+ /**
39
+ * Sets the token ID for this burn NFT transaction.
40
+ *
41
+ * @param {string} tokenId - The ID of the NFT token to burn
42
+ * @returns {BurnNftBuilder} This transaction builder
43
+ */
44
+ tokenId(tokenId: string): this;
45
+ /**
46
+ * Sets the staking contract address for this staking tx.
47
+ * The address must be explicitly provided to ensure the correct contract is used.
48
+ *
49
+ * @param {string} address - The staking contract address (required)
50
+ * @returns {StakingBuilder} This transaction builder
51
+ * @throws {Error} If no address is provided
52
+ */
53
+ stakingContractAddress(address: string): this;
54
+ /** @inheritdoc */
55
+ validateTransaction(transaction?: BurnNftTransaction): void;
56
+ /** @inheritdoc */
57
+ protected buildImplementation(): Promise<Transaction>;
58
+ }
59
+ //# sourceMappingURL=burnNftBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"burnNftBuilder.d.ts","sourceRoot":"","sources":["../../../../src/lib/transactionBuilder/burnNftBuilder.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAE7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AACvE,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AAIzD,qBAAa,cAAe,SAAQ,kBAAkB;IACpD;;;;OAIG;gBACS,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAK7C;;;;OAIG;IACH,WAAW,CAAC,EAAE,EAAE,kBAAkB,GAAG,IAAI;IAIzC;;;;OAIG;IACH,IAAI,kBAAkB,IAAI,kBAAkB,CAE3C;IAED;;;;OAIG;IACH,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED;;;;OAIG;IACH,SAAS,CAAC,yBAAyB,CAAC,OAAO,EAAE,iBAAiB,EAAE,GAAG,OAAO;IA4B1E;;;;;OAKG;IACH,OAAO,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAK9B;;;;;;;OAOG;IACH,sBAAsB,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAS7C,kBAAkB;IAClB,mBAAmB,CAAC,WAAW,CAAC,EAAE,kBAAkB,GAAG,IAAI;IAU3D,kBAAkB;cACF,mBAAmB,IAAI,OAAO,CAAC,WAAW,CAAC;CAK5D"}
@@ -0,0 +1,118 @@
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.BurnNftBuilder = void 0;
7
+ const assert_1 = __importDefault(require("assert"));
8
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
9
+ const transactionBuilder_1 = require("./transactionBuilder");
10
+ const burnNftTransaction_1 = require("../transaction/burnNftTransaction");
11
+ const utils_1 = __importDefault(require("../utils"));
12
+ const constants_1 = require("../constants");
13
+ class BurnNftBuilder extends transactionBuilder_1.TransactionBuilder {
14
+ /**
15
+ * Creates a new BurnNftBuilder instance.
16
+ *
17
+ * @param {Readonly<CoinConfig>} _coinConfig - The coin configuration object
18
+ */
19
+ constructor(_coinConfig) {
20
+ super(_coinConfig);
21
+ this._transaction = new burnNftTransaction_1.BurnNftTransaction(_coinConfig);
22
+ }
23
+ /**
24
+ * Initializes the builder with an existing BurnNftTransaction.
25
+ *
26
+ * @param {BurnNftTransaction} tx - The transaction to initialize the builder with
27
+ */
28
+ initBuilder(tx) {
29
+ this._transaction = tx;
30
+ }
31
+ /**
32
+ * Gets the burn NFT transaction instance.
33
+ *
34
+ * @returns {BurnNftTransaction} The burn NFT transaction
35
+ */
36
+ get burnNftTransaction() {
37
+ return this._transaction;
38
+ }
39
+ /**
40
+ * Gets the transaction type for burning NFT.
41
+ *
42
+ * @returns {TransactionType} The transaction type
43
+ */
44
+ get transactionType() {
45
+ return sdk_core_1.TransactionType.StakingWithdraw;
46
+ }
47
+ /**
48
+ * Validates the transaction clauses for burning NFT.
49
+ * @param {TransactionClause[]} clauses - The transaction clauses to validate.
50
+ * @returns {boolean} - Returns true if the clauses are valid, false otherwise.
51
+ */
52
+ isValidTransactionClauses(clauses) {
53
+ try {
54
+ if (!clauses || !Array.isArray(clauses) || clauses.length === 0) {
55
+ return false;
56
+ }
57
+ const clause = clauses[0];
58
+ if (!clause.to || !utils_1.default.isValidAddress(clause.to)) {
59
+ return false;
60
+ }
61
+ // For burn NFT transactions, value must be exactly '0x0'
62
+ if (clause.value !== 0) {
63
+ return false;
64
+ }
65
+ // Check if the data starts with the burn method ID
66
+ if (!clause.data.startsWith(constants_1.BURN_NFT_METHOD_ID)) {
67
+ return false;
68
+ }
69
+ return true;
70
+ }
71
+ catch (e) {
72
+ return false;
73
+ }
74
+ }
75
+ /**
76
+ * Sets the token ID for this burn NFT transaction.
77
+ *
78
+ * @param {string} tokenId - The ID of the NFT token to burn
79
+ * @returns {BurnNftBuilder} This transaction builder
80
+ */
81
+ tokenId(tokenId) {
82
+ this.burnNftTransaction.tokenId = tokenId;
83
+ return this;
84
+ }
85
+ /**
86
+ * Sets the staking contract address for this staking tx.
87
+ * The address must be explicitly provided to ensure the correct contract is used.
88
+ *
89
+ * @param {string} address - The staking contract address (required)
90
+ * @returns {StakingBuilder} This transaction builder
91
+ * @throws {Error} If no address is provided
92
+ */
93
+ stakingContractAddress(address) {
94
+ if (!address) {
95
+ throw new Error('Staking contract address is required');
96
+ }
97
+ this.validateAddress({ address });
98
+ this.burnNftTransaction.stakingContractAddress = address;
99
+ return this;
100
+ }
101
+ /** @inheritdoc */
102
+ validateTransaction(transaction) {
103
+ if (!transaction) {
104
+ throw new Error('transaction not defined');
105
+ }
106
+ (0, assert_1.default)(transaction.stakingContractAddress, 'Staking contract address is required');
107
+ (0, assert_1.default)(transaction.tokenId, 'Token ID is required');
108
+ this.validateAddress({ address: transaction.stakingContractAddress });
109
+ }
110
+ /** @inheritdoc */
111
+ async buildImplementation() {
112
+ this.transaction.type = this.transactionType;
113
+ await this.burnNftTransaction.build();
114
+ return this.transaction;
115
+ }
116
+ }
117
+ exports.BurnNftBuilder = BurnNftBuilder;
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"burnNftBuilder.js","sourceRoot":"","sources":["../../../../src/lib/transactionBuilder/burnNftBuilder.ts"],"names":[],"mappings":";;;;;;AAAA,oDAA4B;AAE5B,mDAAuD;AAGvD,6DAA0D;AAC1D,0EAAuE;AAEvE,qDAA6B;AAC7B,4CAAkD;AAElD,MAAa,cAAe,SAAQ,uCAAkB;IACpD;;;;OAIG;IACH,YAAY,WAAiC;QAC3C,KAAK,CAAC,WAAW,CAAC,CAAC;QACnB,IAAI,CAAC,YAAY,GAAG,IAAI,uCAAkB,CAAC,WAAW,CAAC,CAAC;IAC1D,CAAC;IAED;;;;OAIG;IACH,WAAW,CAAC,EAAsB;QAChC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;IACzB,CAAC;IAED;;;;OAIG;IACH,IAAI,kBAAkB;QACpB,OAAO,IAAI,CAAC,YAAkC,CAAC;IACjD,CAAC;IAED;;;;OAIG;IACH,IAAc,eAAe;QAC3B,OAAO,0BAAe,CAAC,eAAe,CAAC;IACzC,CAAC;IAED;;;;OAIG;IACO,yBAAyB,CAAC,OAA4B;QAC9D,IAAI,CAAC;YACH,IAAI,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAChE,OAAO,KAAK,CAAC;YACf,CAAC;YAED,MAAM,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;YAE1B,IAAI,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,eAAK,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC;gBACnD,OAAO,KAAK,CAAC;YACf,CAAC;YAED,yDAAyD;YACzD,IAAI,MAAM,CAAC,KAAK,KAAK,CAAC,EAAE,CAAC;gBACvB,OAAO,KAAK,CAAC;YACf,CAAC;YAED,mDAAmD;YACnD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,8BAAkB,CAAC,EAAE,CAAC;gBAChD,OAAO,KAAK,CAAC;YACf,CAAC;YAED,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,OAAO,CAAC,OAAe;QACrB,IAAI,CAAC,kBAAkB,CAAC,OAAO,GAAG,OAAO,CAAC;QAC1C,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;;;OAOG;IACH,sBAAsB,CAAC,OAAe;QACpC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;QAC1D,CAAC;QACD,IAAI,CAAC,eAAe,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC;QAClC,IAAI,CAAC,kBAAkB,CAAC,sBAAsB,GAAG,OAAO,CAAC;QACzD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,kBAAkB;IAClB,mBAAmB,CAAC,WAAgC;QAClD,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;QAC7C,CAAC;QACD,IAAA,gBAAM,EAAC,WAAW,CAAC,sBAAsB,EAAE,sCAAsC,CAAC,CAAC;QACnF,IAAA,gBAAM,EAAC,WAAW,CAAC,OAAO,EAAE,sBAAsB,CAAC,CAAC;QAEpD,IAAI,CAAC,eAAe,CAAC,EAAE,OAAO,EAAE,WAAW,CAAC,sBAAsB,EAAE,CAAC,CAAC;IACxE,CAAC;IAED,kBAAkB;IACR,KAAK,CAAC,mBAAmB;QACjC,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG,IAAI,CAAC,eAAe,CAAC;QAC7C,MAAM,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,CAAC;QACtC,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;CACF;AApHD,wCAoHC","sourcesContent":["import assert from 'assert';\nimport { TransactionClause } from '@vechain/sdk-core';\nimport { TransactionType } from '@bitgo-beta/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\n\nimport { TransactionBuilder } from './transactionBuilder';\nimport { BurnNftTransaction } from '../transaction/burnNftTransaction';\nimport { Transaction } from '../transaction/transaction';\nimport utils from '../utils';\nimport { BURN_NFT_METHOD_ID } from '../constants';\n\nexport class BurnNftBuilder extends TransactionBuilder {\n  /**\n   * Creates a new BurnNftBuilder instance.\n   *\n   * @param {Readonly<CoinConfig>} _coinConfig - The coin configuration object\n   */\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._transaction = new BurnNftTransaction(_coinConfig);\n  }\n\n  /**\n   * Initializes the builder with an existing BurnNftTransaction.\n   *\n   * @param {BurnNftTransaction} tx - The transaction to initialize the builder with\n   */\n  initBuilder(tx: BurnNftTransaction): void {\n    this._transaction = tx;\n  }\n\n  /**\n   * Gets the burn NFT transaction instance.\n   *\n   * @returns {BurnNftTransaction} The burn NFT transaction\n   */\n  get burnNftTransaction(): BurnNftTransaction {\n    return this._transaction as BurnNftTransaction;\n  }\n\n  /**\n   * Gets the transaction type for burning NFT.\n   *\n   * @returns {TransactionType} The transaction type\n   */\n  protected get transactionType(): TransactionType {\n    return TransactionType.StakingWithdraw;\n  }\n\n  /**\n   * Validates the transaction clauses for burning NFT.\n   * @param {TransactionClause[]} clauses - The transaction clauses to validate.\n   * @returns {boolean} - Returns true if the clauses are valid, false otherwise.\n   */\n  protected isValidTransactionClauses(clauses: TransactionClause[]): boolean {\n    try {\n      if (!clauses || !Array.isArray(clauses) || clauses.length === 0) {\n        return false;\n      }\n\n      const clause = clauses[0];\n\n      if (!clause.to || !utils.isValidAddress(clause.to)) {\n        return false;\n      }\n\n      // For burn NFT transactions, value must be exactly '0x0'\n      if (clause.value !== 0) {\n        return false;\n      }\n\n      // Check if the data starts with the burn method ID\n      if (!clause.data.startsWith(BURN_NFT_METHOD_ID)) {\n        return false;\n      }\n\n      return true;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  /**\n   * Sets the token ID for this burn NFT transaction.\n   *\n   * @param {string} tokenId - The ID of the NFT token to burn\n   * @returns {BurnNftBuilder} This transaction builder\n   */\n  tokenId(tokenId: string): this {\n    this.burnNftTransaction.tokenId = tokenId;\n    return this;\n  }\n\n  /**\n   * Sets the staking contract address for this staking tx.\n   * The address must be explicitly provided to ensure the correct contract is used.\n   *\n   * @param {string} address - The staking contract address (required)\n   * @returns {StakingBuilder} This transaction builder\n   * @throws {Error} If no address is provided\n   */\n  stakingContractAddress(address: string): this {\n    if (!address) {\n      throw new Error('Staking contract address is required');\n    }\n    this.validateAddress({ address });\n    this.burnNftTransaction.stakingContractAddress = address;\n    return this;\n  }\n\n  /** @inheritdoc */\n  validateTransaction(transaction?: BurnNftTransaction): void {\n    if (!transaction) {\n      throw new Error('transaction not defined');\n    }\n    assert(transaction.stakingContractAddress, 'Staking contract address is required');\n    assert(transaction.tokenId, 'Token ID is required');\n\n    this.validateAddress({ address: transaction.stakingContractAddress });\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    this.transaction.type = this.transactionType;\n    await this.burnNftTransaction.build();\n    return this.transaction;\n  }\n}\n"]}
@@ -0,0 +1,57 @@
1
+ import { TransactionType } from '@bitgo-beta/sdk-core';
2
+ import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
3
+ import { TransactionClause } from '@vechain/sdk-core';
4
+ import { TransactionBuilder } from './transactionBuilder';
5
+ import { ClaimRewardsTransaction } from '../transaction/claimRewards';
6
+ import { Transaction } from '../transaction/transaction';
7
+ import { ClaimRewardsData } from '../types';
8
+ export declare class ClaimRewardsBuilder extends TransactionBuilder {
9
+ /**
10
+ * Creates a new ClaimRewardsBuilder instance.
11
+ *
12
+ * @param {Readonly<CoinConfig>} _coinConfig - The coin configuration object
13
+ */
14
+ constructor(_coinConfig: Readonly<CoinConfig>);
15
+ /**
16
+ * Initializes the builder with an existing ClaimRewardsTransaction.
17
+ *
18
+ * @param {ClaimRewardsTransaction} tx - The transaction to initialize the builder with
19
+ */
20
+ initBuilder(tx: ClaimRewardsTransaction): void;
21
+ /**
22
+ * Gets the claim rewards transaction instance.
23
+ *
24
+ * @returns {ClaimRewardsTransaction} The claim rewards transaction
25
+ */
26
+ get claimRewardsTransaction(): ClaimRewardsTransaction;
27
+ /**
28
+ * Gets the transaction type for claim rewards.
29
+ *
30
+ * @returns {TransactionType} The transaction type
31
+ */
32
+ protected get transactionType(): TransactionType;
33
+ /**
34
+ * Validates the transaction clauses for claim rewards transaction.
35
+ * @param {TransactionClause[]} clauses - The transaction clauses to validate.
36
+ * @returns {boolean} - Returns true if the clauses are valid, false otherwise.
37
+ */
38
+ protected isValidTransactionClauses(clauses: TransactionClause[]): boolean;
39
+ /**
40
+ * Sets the claim rewards data for this transaction.
41
+ *
42
+ * @param {ClaimRewardsData} data - The claim rewards data
43
+ * @returns {ClaimRewardsBuilder} This transaction builder
44
+ */
45
+ claimRewardsData(data: ClaimRewardsData): this;
46
+ /**
47
+ * Validates the claim rewards data.
48
+ *
49
+ * @param {ClaimRewardsData} data - The claim rewards data to validate
50
+ */
51
+ private validateClaimRewardsData;
52
+ /** @inheritdoc */
53
+ validateTransaction(transaction?: ClaimRewardsTransaction): void;
54
+ /** @inheritdoc */
55
+ protected buildImplementation(): Promise<Transaction>;
56
+ }
57
+ //# sourceMappingURL=claimRewardsBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"claimRewardsBuilder.d.ts","sourceRoot":"","sources":["../../../../src/lib/transactionBuilder/claimRewardsBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AAGtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AACtE,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAI5C,qBAAa,mBAAoB,SAAQ,kBAAkB;IACzD;;;;OAIG;gBACS,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAK7C;;;;OAIG;IACH,WAAW,CAAC,EAAE,EAAE,uBAAuB,GAAG,IAAI;IAI9C;;;;OAIG;IACH,IAAI,uBAAuB,IAAI,uBAAuB,CAErD;IAED;;;;OAIG;IACH,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED;;;;OAIG;IACH,SAAS,CAAC,yBAAyB,CAAC,OAAO,EAAE,iBAAiB,EAAE,GAAG,OAAO;IAqC1E;;;;;OAKG;IACH,gBAAgB,CAAC,IAAI,EAAE,gBAAgB,GAAG,IAAI;IAM9C;;;;OAIG;IACH,OAAO,CAAC,wBAAwB;IA+BhC,kBAAkB;IAClB,mBAAmB,CAAC,WAAW,CAAC,EAAE,uBAAuB,GAAG,IAAI;IAehE,kBAAkB;cACF,mBAAmB,IAAI,OAAO,CAAC,WAAW,CAAC;CAK5D"}
@@ -0,0 +1,142 @@
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.ClaimRewardsBuilder = void 0;
7
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
8
+ const assert_1 = __importDefault(require("assert"));
9
+ const transactionBuilder_1 = require("./transactionBuilder");
10
+ const claimRewards_1 = require("../transaction/claimRewards");
11
+ const constants_1 = require("../constants");
12
+ const utils_1 = __importDefault(require("../utils"));
13
+ class ClaimRewardsBuilder extends transactionBuilder_1.TransactionBuilder {
14
+ /**
15
+ * Creates a new ClaimRewardsBuilder instance.
16
+ *
17
+ * @param {Readonly<CoinConfig>} _coinConfig - The coin configuration object
18
+ */
19
+ constructor(_coinConfig) {
20
+ super(_coinConfig);
21
+ this._transaction = new claimRewards_1.ClaimRewardsTransaction(_coinConfig);
22
+ }
23
+ /**
24
+ * Initializes the builder with an existing ClaimRewardsTransaction.
25
+ *
26
+ * @param {ClaimRewardsTransaction} tx - The transaction to initialize the builder with
27
+ */
28
+ initBuilder(tx) {
29
+ this._transaction = tx;
30
+ }
31
+ /**
32
+ * Gets the claim rewards transaction instance.
33
+ *
34
+ * @returns {ClaimRewardsTransaction} The claim rewards transaction
35
+ */
36
+ get claimRewardsTransaction() {
37
+ return this._transaction;
38
+ }
39
+ /**
40
+ * Gets the transaction type for claim rewards.
41
+ *
42
+ * @returns {TransactionType} The transaction type
43
+ */
44
+ get transactionType() {
45
+ return sdk_core_1.TransactionType.StakingClaim;
46
+ }
47
+ /**
48
+ * Validates the transaction clauses for claim rewards transaction.
49
+ * @param {TransactionClause[]} clauses - The transaction clauses to validate.
50
+ * @returns {boolean} - Returns true if the clauses are valid, false otherwise.
51
+ */
52
+ isValidTransactionClauses(clauses) {
53
+ try {
54
+ if (!clauses || !Array.isArray(clauses) || clauses.length === 0) {
55
+ return false;
56
+ }
57
+ let hasValidClaimClause = false;
58
+ for (const clause of clauses) {
59
+ if (!clause.to || !utils_1.default.isValidAddress(clause.to)) {
60
+ return false;
61
+ }
62
+ // For claim rewards transactions, value must be '0x0' or 0
63
+ if (clause.value !== '0x0' && clause.value !== 0 && clause.value !== '0') {
64
+ return false;
65
+ }
66
+ const isDelegationContract = utils_1.default.isDelegationContractAddress(clause.to);
67
+ const isNftContract = utils_1.default.isNftContractAddress(clause.to);
68
+ if (clause.data && (isDelegationContract || isNftContract)) {
69
+ if ((clause.data.startsWith(constants_1.CLAIM_BASE_REWARDS_METHOD_ID) && isNftContract) ||
70
+ (clause.data.startsWith(constants_1.CLAIM_STAKING_REWARDS_METHOD_ID) && isDelegationContract)) {
71
+ hasValidClaimClause = true;
72
+ }
73
+ }
74
+ }
75
+ return hasValidClaimClause;
76
+ }
77
+ catch (e) {
78
+ return false;
79
+ }
80
+ }
81
+ /**
82
+ * Sets the claim rewards data for this transaction.
83
+ *
84
+ * @param {ClaimRewardsData} data - The claim rewards data
85
+ * @returns {ClaimRewardsBuilder} This transaction builder
86
+ */
87
+ claimRewardsData(data) {
88
+ this.validateClaimRewardsData(data);
89
+ this.claimRewardsTransaction.claimRewardsData = data;
90
+ return this;
91
+ }
92
+ /**
93
+ * Validates the claim rewards data.
94
+ *
95
+ * @param {ClaimRewardsData} data - The claim rewards data to validate
96
+ */
97
+ validateClaimRewardsData(data) {
98
+ if (!data) {
99
+ throw new Error('Claim rewards data is required');
100
+ }
101
+ if (!data.tokenId) {
102
+ throw new Error('Token ID is required');
103
+ }
104
+ // Validate tokenId is a valid number string
105
+ if (!/^\d+$/.test(data.tokenId)) {
106
+ throw new Error('Token ID must be a valid number string');
107
+ }
108
+ if (data.claimBaseRewards !== undefined && typeof data.claimBaseRewards !== 'boolean') {
109
+ throw new Error('claimBaseRewards must be a boolean');
110
+ }
111
+ if (data.claimStakingRewards !== undefined && typeof data.claimStakingRewards !== 'boolean') {
112
+ throw new Error('claimStakingRewards must be a boolean');
113
+ }
114
+ // At least one type of rewards must be claimed (both default to true if undefined)
115
+ const claimBase = data.claimBaseRewards !== false;
116
+ const claimStaking = data.claimStakingRewards !== false;
117
+ if (!claimBase && !claimStaking) {
118
+ throw new Error('At least one type of rewards (base or staking) must be claimed');
119
+ }
120
+ }
121
+ /** @inheritdoc */
122
+ validateTransaction(transaction) {
123
+ if (!transaction) {
124
+ throw new Error('transaction not defined');
125
+ }
126
+ const claimData = transaction.claimRewardsData;
127
+ (0, assert_1.default)(claimData, 'Claim rewards data is required');
128
+ (0, assert_1.default)(claimData.tokenId, 'Token ID is required');
129
+ // Validate tokenId is a valid number string
130
+ if (!/^\d+$/.test(claimData.tokenId)) {
131
+ throw new Error('Token ID must be a valid number string');
132
+ }
133
+ }
134
+ /** @inheritdoc */
135
+ async buildImplementation() {
136
+ this.transaction.type = this.transactionType;
137
+ await this.claimRewardsTransaction.build();
138
+ return this.transaction;
139
+ }
140
+ }
141
+ exports.ClaimRewardsBuilder = ClaimRewardsBuilder;
142
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"claimRewardsBuilder.js","sourceRoot":"","sources":["../../../../src/lib/transactionBuilder/claimRewardsBuilder.ts"],"names":[],"mappings":";;;;;;AAAA,mDAAuD;AAGvD,oDAA4B;AAE5B,6DAA0D;AAC1D,8DAAsE;AAGtE,4CAA6F;AAC7F,qDAA6B;AAE7B,MAAa,mBAAoB,SAAQ,uCAAkB;IACzD;;;;OAIG;IACH,YAAY,WAAiC;QAC3C,KAAK,CAAC,WAAW,CAAC,CAAC;QACnB,IAAI,CAAC,YAAY,GAAG,IAAI,sCAAuB,CAAC,WAAW,CAAC,CAAC;IAC/D,CAAC;IAED;;;;OAIG;IACH,WAAW,CAAC,EAA2B;QACrC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;IACzB,CAAC;IAED;;;;OAIG;IACH,IAAI,uBAAuB;QACzB,OAAO,IAAI,CAAC,YAAuC,CAAC;IACtD,CAAC;IAED;;;;OAIG;IACH,IAAc,eAAe;QAC3B,OAAO,0BAAe,CAAC,YAAY,CAAC;IACtC,CAAC;IAED;;;;OAIG;IACO,yBAAyB,CAAC,OAA4B;QAC9D,IAAI,CAAC;YACH,IAAI,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAChE,OAAO,KAAK,CAAC;YACf,CAAC;YAED,IAAI,mBAAmB,GAAG,KAAK,CAAC;YAEhC,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;gBAC7B,IAAI,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,eAAK,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC;oBACnD,OAAO,KAAK,CAAC;gBACf,CAAC;gBAED,2DAA2D;gBAC3D,IAAI,MAAM,CAAC,KAAK,KAAK,KAAK,IAAI,MAAM,CAAC,KAAK,KAAK,CAAC,IAAI,MAAM,CAAC,KAAK,KAAK,GAAG,EAAE,CAAC;oBACzE,OAAO,KAAK,CAAC;gBACf,CAAC;gBAED,MAAM,oBAAoB,GAAG,eAAK,CAAC,2BAA2B,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;gBAC1E,MAAM,aAAa,GAAG,eAAK,CAAC,oBAAoB,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;gBAE5D,IAAI,MAAM,CAAC,IAAI,IAAI,CAAC,oBAAoB,IAAI,aAAa,CAAC,EAAE,CAAC;oBAC3D,IACE,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,wCAA4B,CAAC,IAAI,aAAa,CAAC;wBACvE,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,2CAA+B,CAAC,IAAI,oBAAoB,CAAC,EACjF,CAAC;wBACD,mBAAmB,GAAG,IAAI,CAAC;oBAC7B,CAAC;gBACH,CAAC;YACH,CAAC;YAED,OAAO,mBAAmB,CAAC;QAC7B,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,gBAAgB,CAAC,IAAsB;QACrC,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,CAAC;QACpC,IAAI,CAAC,uBAAuB,CAAC,gBAAgB,GAAG,IAAI,CAAC;QACrD,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;OAIG;IACK,wBAAwB,CAAC,IAAsB;QACrD,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;QACpD,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;QAC1C,CAAC;QAED,4CAA4C;QAC5C,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;YAChC,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;QAC5D,CAAC;QAED,IAAI,IAAI,CAAC,gBAAgB,KAAK,SAAS,IAAI,OAAO,IAAI,CAAC,gBAAgB,KAAK,SAAS,EAAE,CAAC;YACtF,MAAM,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAC;QACxD,CAAC;QAED,IAAI,IAAI,CAAC,mBAAmB,KAAK,SAAS,IAAI,OAAO,IAAI,CAAC,mBAAmB,KAAK,SAAS,EAAE,CAAC;YAC5F,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAC;QAC3D,CAAC;QAED,mFAAmF;QACnF,MAAM,SAAS,GAAG,IAAI,CAAC,gBAAgB,KAAK,KAAK,CAAC;QAClD,MAAM,YAAY,GAAG,IAAI,CAAC,mBAAmB,KAAK,KAAK,CAAC;QAExD,IAAI,CAAC,SAAS,IAAI,CAAC,YAAY,EAAE,CAAC;YAChC,MAAM,IAAI,KAAK,CAAC,gEAAgE,CAAC,CAAC;QACpF,CAAC;IACH,CAAC;IAED,kBAAkB;IAClB,mBAAmB,CAAC,WAAqC;QACvD,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;QAC7C,CAAC;QAED,MAAM,SAAS,GAAG,WAAW,CAAC,gBAAgB,CAAC;QAC/C,IAAA,gBAAM,EAAC,SAAS,EAAE,gCAAgC,CAAC,CAAC;QACpD,IAAA,gBAAM,EAAC,SAAS,CAAC,OAAO,EAAE,sBAAsB,CAAC,CAAC;QAElD,4CAA4C;QAC5C,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC;YACrC,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;QAC5D,CAAC;IACH,CAAC;IAED,kBAAkB;IACR,KAAK,CAAC,mBAAmB;QACjC,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG,IAAI,CAAC,eAAe,CAAC;QAC7C,MAAM,IAAI,CAAC,uBAAuB,CAAC,KAAK,EAAE,CAAC;QAC3C,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;CACF;AAtJD,kDAsJC","sourcesContent":["import { TransactionType } from '@bitgo-beta/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { TransactionClause } from '@vechain/sdk-core';\nimport assert from 'assert';\n\nimport { TransactionBuilder } from './transactionBuilder';\nimport { ClaimRewardsTransaction } from '../transaction/claimRewards';\nimport { Transaction } from '../transaction/transaction';\nimport { ClaimRewardsData } from '../types';\nimport { CLAIM_BASE_REWARDS_METHOD_ID, CLAIM_STAKING_REWARDS_METHOD_ID } from '../constants';\nimport utils from '../utils';\n\nexport class ClaimRewardsBuilder extends TransactionBuilder {\n  /**\n   * Creates a new ClaimRewardsBuilder instance.\n   *\n   * @param {Readonly<CoinConfig>} _coinConfig - The coin configuration object\n   */\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._transaction = new ClaimRewardsTransaction(_coinConfig);\n  }\n\n  /**\n   * Initializes the builder with an existing ClaimRewardsTransaction.\n   *\n   * @param {ClaimRewardsTransaction} tx - The transaction to initialize the builder with\n   */\n  initBuilder(tx: ClaimRewardsTransaction): void {\n    this._transaction = tx;\n  }\n\n  /**\n   * Gets the claim rewards transaction instance.\n   *\n   * @returns {ClaimRewardsTransaction} The claim rewards transaction\n   */\n  get claimRewardsTransaction(): ClaimRewardsTransaction {\n    return this._transaction as ClaimRewardsTransaction;\n  }\n\n  /**\n   * Gets the transaction type for claim rewards.\n   *\n   * @returns {TransactionType} The transaction type\n   */\n  protected get transactionType(): TransactionType {\n    return TransactionType.StakingClaim;\n  }\n\n  /**\n   * Validates the transaction clauses for claim rewards transaction.\n   * @param {TransactionClause[]} clauses - The transaction clauses to validate.\n   * @returns {boolean} - Returns true if the clauses are valid, false otherwise.\n   */\n  protected isValidTransactionClauses(clauses: TransactionClause[]): boolean {\n    try {\n      if (!clauses || !Array.isArray(clauses) || clauses.length === 0) {\n        return false;\n      }\n\n      let hasValidClaimClause = false;\n\n      for (const clause of clauses) {\n        if (!clause.to || !utils.isValidAddress(clause.to)) {\n          return false;\n        }\n\n        // For claim rewards transactions, value must be '0x0' or 0\n        if (clause.value !== '0x0' && clause.value !== 0 && clause.value !== '0') {\n          return false;\n        }\n\n        const isDelegationContract = utils.isDelegationContractAddress(clause.to);\n        const isNftContract = utils.isNftContractAddress(clause.to);\n\n        if (clause.data && (isDelegationContract || isNftContract)) {\n          if (\n            (clause.data.startsWith(CLAIM_BASE_REWARDS_METHOD_ID) && isNftContract) ||\n            (clause.data.startsWith(CLAIM_STAKING_REWARDS_METHOD_ID) && isDelegationContract)\n          ) {\n            hasValidClaimClause = true;\n          }\n        }\n      }\n\n      return hasValidClaimClause;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  /**\n   * Sets the claim rewards data for this transaction.\n   *\n   * @param {ClaimRewardsData} data - The claim rewards data\n   * @returns {ClaimRewardsBuilder} This transaction builder\n   */\n  claimRewardsData(data: ClaimRewardsData): this {\n    this.validateClaimRewardsData(data);\n    this.claimRewardsTransaction.claimRewardsData = data;\n    return this;\n  }\n\n  /**\n   * Validates the claim rewards data.\n   *\n   * @param {ClaimRewardsData} data - The claim rewards data to validate\n   */\n  private validateClaimRewardsData(data: ClaimRewardsData): void {\n    if (!data) {\n      throw new Error('Claim rewards data is required');\n    }\n\n    if (!data.tokenId) {\n      throw new Error('Token ID is required');\n    }\n\n    // Validate tokenId is a valid number string\n    if (!/^\\d+$/.test(data.tokenId)) {\n      throw new Error('Token ID must be a valid number string');\n    }\n\n    if (data.claimBaseRewards !== undefined && typeof data.claimBaseRewards !== 'boolean') {\n      throw new Error('claimBaseRewards must be a boolean');\n    }\n\n    if (data.claimStakingRewards !== undefined && typeof data.claimStakingRewards !== 'boolean') {\n      throw new Error('claimStakingRewards must be a boolean');\n    }\n\n    // At least one type of rewards must be claimed (both default to true if undefined)\n    const claimBase = data.claimBaseRewards !== false;\n    const claimStaking = data.claimStakingRewards !== false;\n\n    if (!claimBase && !claimStaking) {\n      throw new Error('At least one type of rewards (base or staking) must be claimed');\n    }\n  }\n\n  /** @inheritdoc */\n  validateTransaction(transaction?: ClaimRewardsTransaction): void {\n    if (!transaction) {\n      throw new Error('transaction not defined');\n    }\n\n    const claimData = transaction.claimRewardsData;\n    assert(claimData, 'Claim rewards data is required');\n    assert(claimData.tokenId, 'Token ID is required');\n\n    // Validate tokenId is a valid number string\n    if (!/^\\d+$/.test(claimData.tokenId)) {\n      throw new Error('Token ID must be a valid number string');\n    }\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    this.transaction.type = this.transactionType;\n    await this.claimRewardsTransaction.build();\n    return this.transaction;\n  }\n}\n"]}