@bitgo-beta/sdk-coin-vet 1.0.1-beta.27 → 1.0.1-beta.270
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.mocharc.yml +1 -1
- package/CHANGELOG.md +150 -0
- package/dist/src/index.d.ts +2 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +3 -1
- package/dist/src/lib/constants.d.ts +9 -1
- package/dist/src/lib/constants.d.ts.map +1 -1
- package/dist/src/lib/constants.js +11 -3
- package/dist/src/lib/iface.d.ts +25 -1
- package/dist/src/lib/iface.d.ts.map +1 -1
- package/dist/src/lib/iface.js +1 -1
- package/dist/src/lib/index.d.ts +14 -3
- package/dist/src/lib/index.d.ts.map +1 -1
- package/dist/src/lib/index.js +27 -5
- package/dist/src/lib/transaction/addressInitializationTransaction.d.ts +31 -0
- package/dist/src/lib/transaction/addressInitializationTransaction.d.ts.map +1 -0
- package/dist/src/lib/transaction/addressInitializationTransaction.js +170 -0
- package/dist/src/lib/transaction/burnNftTransaction.d.ts +26 -0
- package/dist/src/lib/transaction/burnNftTransaction.d.ts.map +1 -0
- package/dist/src/lib/transaction/burnNftTransaction.js +124 -0
- package/dist/src/lib/transaction/exitDelegation.d.ts +26 -0
- package/dist/src/lib/transaction/exitDelegation.d.ts.map +1 -0
- package/dist/src/lib/transaction/exitDelegation.js +124 -0
- package/dist/src/lib/transaction/flushTokenTransaction.d.ts +20 -0
- package/dist/src/lib/transaction/flushTokenTransaction.d.ts.map +1 -0
- package/dist/src/lib/transaction/flushTokenTransaction.js +98 -0
- package/dist/src/lib/transaction/nftTransaction.d.ts +17 -0
- package/dist/src/lib/transaction/nftTransaction.d.ts.map +1 -0
- package/dist/src/lib/transaction/nftTransaction.js +108 -0
- package/dist/src/lib/transaction/stakingTransaction.d.ts +21 -0
- package/dist/src/lib/transaction/stakingTransaction.d.ts.map +1 -0
- package/dist/src/lib/transaction/stakingTransaction.js +136 -0
- package/dist/src/lib/transaction/tokenTransaction.d.ts +14 -0
- package/dist/src/lib/transaction/tokenTransaction.d.ts.map +1 -0
- package/dist/src/lib/transaction/tokenTransaction.js +95 -0
- package/dist/src/lib/transaction/transaction.d.ts +106 -0
- package/dist/src/lib/transaction/transaction.d.ts.map +1 -0
- package/dist/src/lib/transaction/transaction.js +468 -0
- package/dist/src/lib/transactionBuilder/addressInitializationBuilder.d.ts +78 -0
- package/dist/src/lib/transactionBuilder/addressInitializationBuilder.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilder/addressInitializationBuilder.js +158 -0
- package/dist/src/lib/transactionBuilder/burnNftBuilder.d.ts +65 -0
- package/dist/src/lib/transactionBuilder/burnNftBuilder.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilder/burnNftBuilder.js +130 -0
- package/dist/src/lib/transactionBuilder/exitDelegationBuilder.d.ts +65 -0
- package/dist/src/lib/transactionBuilder/exitDelegationBuilder.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilder/exitDelegationBuilder.js +132 -0
- package/dist/src/lib/transactionBuilder/flushTokenTransactionBuilder.d.ts +66 -0
- package/dist/src/lib/transactionBuilder/flushTokenTransactionBuilder.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilder/flushTokenTransactionBuilder.js +129 -0
- package/dist/src/lib/transactionBuilder/nftTransactionBuilder.d.ts +23 -0
- package/dist/src/lib/transactionBuilder/nftTransactionBuilder.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilder/nftTransactionBuilder.js +93 -0
- package/dist/src/lib/transactionBuilder/stakingBuilder.d.ts +72 -0
- package/dist/src/lib/transactionBuilder/stakingBuilder.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilder/stakingBuilder.js +129 -0
- package/dist/src/lib/transactionBuilder/tokenTransactionBuilder.d.ts +21 -0
- package/dist/src/lib/transactionBuilder/tokenTransactionBuilder.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilder/tokenTransactionBuilder.js +70 -0
- package/dist/src/lib/{transactionBuilder.d.ts → transactionBuilder/transactionBuilder.d.ts} +29 -18
- package/dist/src/lib/transactionBuilder/transactionBuilder.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilder/transactionBuilder.js +155 -0
- package/dist/src/lib/{transferBuilder.d.ts → transactionBuilder/transferBuilder.d.ts} +4 -2
- package/dist/src/lib/transactionBuilder/transferBuilder.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilder/transferBuilder.js +45 -0
- package/dist/src/lib/transactionBuilderFactory.d.ts +55 -5
- package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilderFactory.js +125 -5
- package/dist/src/lib/types.d.ts +8 -0
- package/dist/src/lib/types.d.ts.map +1 -0
- package/dist/src/lib/types.js +3 -0
- package/dist/src/lib/utils.d.ts +19 -1
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +106 -3
- package/dist/src/register.d.ts.map +1 -1
- package/dist/src/register.js +9 -1
- package/dist/src/vet.d.ts +15 -4
- package/dist/src/vet.d.ts.map +1 -1
- package/dist/src/vet.js +154 -7
- package/dist/src/vetNFTCollection.d.ts +18 -0
- package/dist/src/vetNFTCollection.d.ts.map +1 -0
- package/dist/src/vetNFTCollection.js +52 -0
- package/dist/src/vetToken.d.ts +19 -0
- package/dist/src/vetToken.d.ts.map +1 -0
- package/dist/src/vetToken.js +52 -0
- package/package.json +14 -9
- package/dist/src/lib/transaction.d.ts +0 -8
- package/dist/src/lib/transaction.d.ts.map +0 -1
- package/dist/src/lib/transaction.js +0 -17
- package/dist/src/lib/transactionBuilder.d.ts.map +0 -1
- package/dist/src/lib/transactionBuilder.js +0 -78
- package/dist/src/lib/transferBuilder.d.ts.map +0 -1
- package/dist/src/lib/transferBuilder.js +0 -15
|
@@ -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,65 @@
|
|
|
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 NFT contract address for this burn NFT transaction.
|
|
47
|
+
* If not provided, uses the default address from constants.
|
|
48
|
+
*
|
|
49
|
+
* @param {string} address - The NFT contract address
|
|
50
|
+
* @returns {BurnNftBuilder} This transaction builder
|
|
51
|
+
*/
|
|
52
|
+
nftContract(address?: string): this;
|
|
53
|
+
/** @inheritdoc */
|
|
54
|
+
validateTransaction(transaction?: BurnNftTransaction): void;
|
|
55
|
+
/** @inheritdoc */
|
|
56
|
+
protected buildImplementation(): Promise<Transaction>;
|
|
57
|
+
/**
|
|
58
|
+
* Generates the transaction data for burning NFT by encoding the burn method call.
|
|
59
|
+
*
|
|
60
|
+
* @private
|
|
61
|
+
* @returns {string} The encoded transaction data as a hex string
|
|
62
|
+
*/
|
|
63
|
+
private getBurnNftData;
|
|
64
|
+
}
|
|
65
|
+
//# 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;AAI7D,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;;;;;;OAMG;IACH,WAAW,CAAC,OAAO,GAAE,MAA6B,GAAG,IAAI;IAMzD,kBAAkB;IAClB,mBAAmB,CAAC,WAAW,CAAC,EAAE,kBAAkB,GAAG,IAAI;IAU3D,kBAAkB;cACF,mBAAmB,IAAI,OAAO,CAAC,WAAW,CAAC;IAM3D;;;;;OAKG;IACH,OAAO,CAAC,cAAc;CAUvB"}
|
|
@@ -0,0 +1,130 @@
|
|
|
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 ethereumjs_abi_1 = __importDefault(require("ethereumjs-abi"));
|
|
10
|
+
const ethereumjs_util_1 = require("ethereumjs-util");
|
|
11
|
+
const transactionBuilder_1 = require("./transactionBuilder");
|
|
12
|
+
const burnNftTransaction_1 = require("../transaction/burnNftTransaction");
|
|
13
|
+
const utils_1 = __importDefault(require("../utils"));
|
|
14
|
+
const constants_1 = require("../constants");
|
|
15
|
+
class BurnNftBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
16
|
+
/**
|
|
17
|
+
* Creates a new BurnNftBuilder instance.
|
|
18
|
+
*
|
|
19
|
+
* @param {Readonly<CoinConfig>} _coinConfig - The coin configuration object
|
|
20
|
+
*/
|
|
21
|
+
constructor(_coinConfig) {
|
|
22
|
+
super(_coinConfig);
|
|
23
|
+
this._transaction = new burnNftTransaction_1.BurnNftTransaction(_coinConfig);
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Initializes the builder with an existing BurnNftTransaction.
|
|
27
|
+
*
|
|
28
|
+
* @param {BurnNftTransaction} tx - The transaction to initialize the builder with
|
|
29
|
+
*/
|
|
30
|
+
initBuilder(tx) {
|
|
31
|
+
this._transaction = tx;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Gets the burn NFT transaction instance.
|
|
35
|
+
*
|
|
36
|
+
* @returns {BurnNftTransaction} The burn NFT transaction
|
|
37
|
+
*/
|
|
38
|
+
get burnNftTransaction() {
|
|
39
|
+
return this._transaction;
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Gets the transaction type for burning NFT.
|
|
43
|
+
*
|
|
44
|
+
* @returns {TransactionType} The transaction type
|
|
45
|
+
*/
|
|
46
|
+
get transactionType() {
|
|
47
|
+
return sdk_core_1.TransactionType.StakingWithdraw;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Validates the transaction clauses for burning NFT.
|
|
51
|
+
* @param {TransactionClause[]} clauses - The transaction clauses to validate.
|
|
52
|
+
* @returns {boolean} - Returns true if the clauses are valid, false otherwise.
|
|
53
|
+
*/
|
|
54
|
+
isValidTransactionClauses(clauses) {
|
|
55
|
+
try {
|
|
56
|
+
if (!clauses || !Array.isArray(clauses) || clauses.length === 0) {
|
|
57
|
+
return false;
|
|
58
|
+
}
|
|
59
|
+
const clause = clauses[0];
|
|
60
|
+
if (!clause.to || !utils_1.default.isValidAddress(clause.to)) {
|
|
61
|
+
return false;
|
|
62
|
+
}
|
|
63
|
+
// For burn NFT transactions, value must be exactly '0x0'
|
|
64
|
+
if (clause.value !== 0) {
|
|
65
|
+
return false;
|
|
66
|
+
}
|
|
67
|
+
// Check if the data starts with the burn method ID
|
|
68
|
+
if (!clause.data.startsWith(constants_1.BURN_NFT_METHOD_ID)) {
|
|
69
|
+
return false;
|
|
70
|
+
}
|
|
71
|
+
return true;
|
|
72
|
+
}
|
|
73
|
+
catch (e) {
|
|
74
|
+
return false;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Sets the token ID for this burn NFT transaction.
|
|
79
|
+
*
|
|
80
|
+
* @param {string} tokenId - The ID of the NFT token to burn
|
|
81
|
+
* @returns {BurnNftBuilder} This transaction builder
|
|
82
|
+
*/
|
|
83
|
+
tokenId(tokenId) {
|
|
84
|
+
this.burnNftTransaction.tokenId = tokenId;
|
|
85
|
+
return this;
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Sets the NFT contract address for this burn NFT transaction.
|
|
89
|
+
* If not provided, uses the default address from constants.
|
|
90
|
+
*
|
|
91
|
+
* @param {string} address - The NFT contract address
|
|
92
|
+
* @returns {BurnNftBuilder} This transaction builder
|
|
93
|
+
*/
|
|
94
|
+
nftContract(address = constants_1.STARGATE_NFT_ADDRESS) {
|
|
95
|
+
this.validateAddress({ address });
|
|
96
|
+
this.burnNftTransaction.contract = address;
|
|
97
|
+
return this;
|
|
98
|
+
}
|
|
99
|
+
/** @inheritdoc */
|
|
100
|
+
validateTransaction(transaction) {
|
|
101
|
+
if (!transaction) {
|
|
102
|
+
throw new Error('transaction not defined');
|
|
103
|
+
}
|
|
104
|
+
(0, assert_1.default)(transaction.contract, 'NFT contract address is required');
|
|
105
|
+
(0, assert_1.default)(transaction.tokenId, 'Token ID is required');
|
|
106
|
+
this.validateAddress({ address: transaction.contract });
|
|
107
|
+
}
|
|
108
|
+
/** @inheritdoc */
|
|
109
|
+
async buildImplementation() {
|
|
110
|
+
this.transaction.type = this.transactionType;
|
|
111
|
+
await this.burnNftTransaction.build();
|
|
112
|
+
return this.transaction;
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* Generates the transaction data for burning NFT by encoding the burn method call.
|
|
116
|
+
*
|
|
117
|
+
* @private
|
|
118
|
+
* @returns {string} The encoded transaction data as a hex string
|
|
119
|
+
*/
|
|
120
|
+
getBurnNftData() {
|
|
121
|
+
const methodName = 'burn';
|
|
122
|
+
const types = ['uint256'];
|
|
123
|
+
const params = [this.burnNftTransaction.tokenId];
|
|
124
|
+
const method = ethereumjs_abi_1.default.methodID(methodName, types);
|
|
125
|
+
const args = ethereumjs_abi_1.default.rawEncode(types, params);
|
|
126
|
+
return (0, ethereumjs_util_1.addHexPrefix)(Buffer.concat([method, args]).toString('hex'));
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
exports.BurnNftBuilder = BurnNftBuilder;
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"burnNftBuilder.js","sourceRoot":"","sources":["../../../../src/lib/transactionBuilder/burnNftBuilder.ts"],"names":[],"mappings":"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","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';\nimport EthereumAbi from 'ethereumjs-abi';\nimport { addHexPrefix } from 'ethereumjs-util';\n\nimport { TransactionBuilder } from './transactionBuilder';\nimport { BurnNftTransaction } from '../transaction/burnNftTransaction';\nimport { Transaction } from '../transaction/transaction';\nimport utils from '../utils';\nimport { BURN_NFT_METHOD_ID, STARGATE_NFT_ADDRESS } 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 NFT contract address for this burn NFT transaction.\n   * If not provided, uses the default address from constants.\n   *\n   * @param {string} address - The NFT contract address\n   * @returns {BurnNftBuilder} This transaction builder\n   */\n  nftContract(address: string = STARGATE_NFT_ADDRESS): this {\n    this.validateAddress({ address });\n    this.burnNftTransaction.contract = 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.contract, 'NFT contract address is required');\n    assert(transaction.tokenId, 'Token ID is required');\n\n    this.validateAddress({ address: transaction.contract });\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  /**\n   * Generates the transaction data for burning NFT by encoding the burn method call.\n   *\n   * @private\n   * @returns {string} The encoded transaction data as a hex string\n   */\n  private getBurnNftData(): string {\n    const methodName = 'burn';\n    const types = ['uint256'];\n    const params = [this.burnNftTransaction.tokenId];\n\n    const method = EthereumAbi.methodID(methodName, types);\n    const args = EthereumAbi.rawEncode(types, params);\n\n    return addHexPrefix(Buffer.concat([method, args]).toString('hex'));\n  }\n}\n"]}
|
|
@@ -0,0 +1,65 @@
|
|
|
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 { ExitDelegationTransaction } from '../transaction/exitDelegation';
|
|
6
|
+
import { Transaction } from '../transaction/transaction';
|
|
7
|
+
export declare class ExitDelegationBuilder extends TransactionBuilder {
|
|
8
|
+
/**
|
|
9
|
+
* Creates a new ExitDelegationBuilder 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 ExitDelegationTransaction.
|
|
16
|
+
*
|
|
17
|
+
* @param {ExitDelegationTransaction} tx - The transaction to initialize the builder with
|
|
18
|
+
*/
|
|
19
|
+
initBuilder(tx: ExitDelegationTransaction): void;
|
|
20
|
+
/**
|
|
21
|
+
* Gets the exit delegation transaction instance.
|
|
22
|
+
*
|
|
23
|
+
* @returns {ExitDelegationTransaction} The exit delegation transaction
|
|
24
|
+
*/
|
|
25
|
+
get exitDelegationTransaction(): ExitDelegationTransaction;
|
|
26
|
+
/**
|
|
27
|
+
* Gets the transaction type for unstaking.
|
|
28
|
+
*
|
|
29
|
+
* @returns {TransactionType} The transaction type
|
|
30
|
+
*/
|
|
31
|
+
protected get transactionType(): TransactionType;
|
|
32
|
+
/**
|
|
33
|
+
* Validates the transaction clauses for unstaking.
|
|
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 unstaking transaction.
|
|
40
|
+
*
|
|
41
|
+
* @param {string} tokenId - The ID of the NFT token to unstake
|
|
42
|
+
* @returns {ExitDelegationBuilder} This transaction builder
|
|
43
|
+
*/
|
|
44
|
+
tokenId(tokenId: string): this;
|
|
45
|
+
/**
|
|
46
|
+
* Sets the delegation contract address for this unstaking transaction.
|
|
47
|
+
* If not provided, uses the default address from constants.
|
|
48
|
+
*
|
|
49
|
+
* @param {string} address - The delegation contract address
|
|
50
|
+
* @returns {ExitDelegationBuilder} This transaction builder
|
|
51
|
+
*/
|
|
52
|
+
delegationContract(address?: string): this;
|
|
53
|
+
/** @inheritdoc */
|
|
54
|
+
validateTransaction(transaction?: ExitDelegationTransaction): void;
|
|
55
|
+
/** @inheritdoc */
|
|
56
|
+
protected buildImplementation(): Promise<Transaction>;
|
|
57
|
+
/**
|
|
58
|
+
* Generates the transaction data for exit delegation by encoding the exitDelegation method call.
|
|
59
|
+
*
|
|
60
|
+
* @private
|
|
61
|
+
* @returns {string} The encoded transaction data as a hex string
|
|
62
|
+
*/
|
|
63
|
+
private getExitDelegationData;
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=exitDelegationBuilder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"exitDelegationBuilder.d.ts","sourceRoot":"","sources":["../../../../src/lib/transactionBuilder/exitDelegationBuilder.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;AAI7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,yBAAyB,EAAE,MAAM,+BAA+B,CAAC;AAC1E,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AAIzD,qBAAa,qBAAsB,SAAQ,kBAAkB;IAC3D;;;;OAIG;gBACS,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAK7C;;;;OAIG;IACH,WAAW,CAAC,EAAE,EAAE,yBAAyB,GAAG,IAAI;IAIhD;;;;OAIG;IACH,IAAI,yBAAyB,IAAI,yBAAyB,CAEzD;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;;;;;;OAMG;IACH,kBAAkB,CAAC,OAAO,GAAE,MAAoC,GAAG,IAAI;IAMvE,kBAAkB;IAClB,mBAAmB,CAAC,WAAW,CAAC,EAAE,yBAAyB,GAAG,IAAI;IAUlE,kBAAkB;cACF,mBAAmB,IAAI,OAAO,CAAC,WAAW,CAAC;IAQ3D;;;;;OAKG;IACH,OAAO,CAAC,qBAAqB;CAU9B"}
|
|
@@ -0,0 +1,132 @@
|
|
|
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.ExitDelegationBuilder = void 0;
|
|
7
|
+
const assert_1 = __importDefault(require("assert"));
|
|
8
|
+
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
9
|
+
const ethereumjs_abi_1 = __importDefault(require("ethereumjs-abi"));
|
|
10
|
+
const ethereumjs_util_1 = require("ethereumjs-util");
|
|
11
|
+
const transactionBuilder_1 = require("./transactionBuilder");
|
|
12
|
+
const exitDelegation_1 = require("../transaction/exitDelegation");
|
|
13
|
+
const utils_1 = __importDefault(require("../utils"));
|
|
14
|
+
const constants_1 = require("../constants");
|
|
15
|
+
class ExitDelegationBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
16
|
+
/**
|
|
17
|
+
* Creates a new ExitDelegationBuilder instance.
|
|
18
|
+
*
|
|
19
|
+
* @param {Readonly<CoinConfig>} _coinConfig - The coin configuration object
|
|
20
|
+
*/
|
|
21
|
+
constructor(_coinConfig) {
|
|
22
|
+
super(_coinConfig);
|
|
23
|
+
this._transaction = new exitDelegation_1.ExitDelegationTransaction(_coinConfig);
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Initializes the builder with an existing ExitDelegationTransaction.
|
|
27
|
+
*
|
|
28
|
+
* @param {ExitDelegationTransaction} tx - The transaction to initialize the builder with
|
|
29
|
+
*/
|
|
30
|
+
initBuilder(tx) {
|
|
31
|
+
this._transaction = tx;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Gets the exit delegation transaction instance.
|
|
35
|
+
*
|
|
36
|
+
* @returns {ExitDelegationTransaction} The exit delegation transaction
|
|
37
|
+
*/
|
|
38
|
+
get exitDelegationTransaction() {
|
|
39
|
+
return this._transaction;
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Gets the transaction type for unstaking.
|
|
43
|
+
*
|
|
44
|
+
* @returns {TransactionType} The transaction type
|
|
45
|
+
*/
|
|
46
|
+
get transactionType() {
|
|
47
|
+
return sdk_core_1.TransactionType.StakingUnlock;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Validates the transaction clauses for unstaking.
|
|
51
|
+
* @param {TransactionClause[]} clauses - The transaction clauses to validate.
|
|
52
|
+
* @returns {boolean} - Returns true if the clauses are valid, false otherwise.
|
|
53
|
+
*/
|
|
54
|
+
isValidTransactionClauses(clauses) {
|
|
55
|
+
try {
|
|
56
|
+
if (!clauses || !Array.isArray(clauses) || clauses.length === 0) {
|
|
57
|
+
return false;
|
|
58
|
+
}
|
|
59
|
+
const clause = clauses[0];
|
|
60
|
+
if (!clause.to || !utils_1.default.isValidAddress(clause.to)) {
|
|
61
|
+
return false;
|
|
62
|
+
}
|
|
63
|
+
// For unstaking transactions, value must be exactly '0x0'
|
|
64
|
+
if (clause.value !== 0) {
|
|
65
|
+
return false;
|
|
66
|
+
}
|
|
67
|
+
// Check if the data starts with the exitDelegation method ID
|
|
68
|
+
if (!clause.data.startsWith(constants_1.EXIT_DELEGATION_METHOD_ID)) {
|
|
69
|
+
return false;
|
|
70
|
+
}
|
|
71
|
+
return true;
|
|
72
|
+
}
|
|
73
|
+
catch (e) {
|
|
74
|
+
return false;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Sets the token ID for this unstaking transaction.
|
|
79
|
+
*
|
|
80
|
+
* @param {string} tokenId - The ID of the NFT token to unstake
|
|
81
|
+
* @returns {ExitDelegationBuilder} This transaction builder
|
|
82
|
+
*/
|
|
83
|
+
tokenId(tokenId) {
|
|
84
|
+
this.exitDelegationTransaction.tokenId = tokenId;
|
|
85
|
+
return this;
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Sets the delegation contract address for this unstaking transaction.
|
|
89
|
+
* If not provided, uses the default address from constants.
|
|
90
|
+
*
|
|
91
|
+
* @param {string} address - The delegation contract address
|
|
92
|
+
* @returns {ExitDelegationBuilder} This transaction builder
|
|
93
|
+
*/
|
|
94
|
+
delegationContract(address = constants_1.STARGATE_DELEGATION_ADDRESS) {
|
|
95
|
+
this.validateAddress({ address });
|
|
96
|
+
this.exitDelegationTransaction.contract = address;
|
|
97
|
+
return this;
|
|
98
|
+
}
|
|
99
|
+
/** @inheritdoc */
|
|
100
|
+
validateTransaction(transaction) {
|
|
101
|
+
if (!transaction) {
|
|
102
|
+
throw new Error('transaction not defined');
|
|
103
|
+
}
|
|
104
|
+
(0, assert_1.default)(transaction.contract, 'Delegation contract address is required');
|
|
105
|
+
(0, assert_1.default)(transaction.tokenId, 'Token ID is required');
|
|
106
|
+
this.validateAddress({ address: transaction.contract });
|
|
107
|
+
}
|
|
108
|
+
/** @inheritdoc */
|
|
109
|
+
async buildImplementation() {
|
|
110
|
+
this.transaction.type = this.transactionType;
|
|
111
|
+
// Set the transaction data before building
|
|
112
|
+
this.exitDelegationTransaction.transactionData = this.getExitDelegationData();
|
|
113
|
+
await this.exitDelegationTransaction.build();
|
|
114
|
+
return this.transaction;
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* Generates the transaction data for exit delegation by encoding the exitDelegation method call.
|
|
118
|
+
*
|
|
119
|
+
* @private
|
|
120
|
+
* @returns {string} The encoded transaction data as a hex string
|
|
121
|
+
*/
|
|
122
|
+
getExitDelegationData() {
|
|
123
|
+
const methodName = 'exitDelegation';
|
|
124
|
+
const types = ['uint256'];
|
|
125
|
+
const params = [this.exitDelegationTransaction.tokenId];
|
|
126
|
+
const method = ethereumjs_abi_1.default.methodID(methodName, types);
|
|
127
|
+
const args = ethereumjs_abi_1.default.rawEncode(types, params);
|
|
128
|
+
return (0, ethereumjs_util_1.addHexPrefix)(Buffer.concat([method, args]).toString('hex'));
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
exports.ExitDelegationBuilder = ExitDelegationBuilder;
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"exitDelegationBuilder.js","sourceRoot":"","sources":["../../../../src/lib/transactionBuilder/exitDelegationBuilder.ts"],"names":[],"mappings":"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","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';\nimport EthereumAbi from 'ethereumjs-abi';\nimport { addHexPrefix } from 'ethereumjs-util';\n\nimport { TransactionBuilder } from './transactionBuilder';\nimport { ExitDelegationTransaction } from '../transaction/exitDelegation';\nimport { Transaction } from '../transaction/transaction';\nimport utils from '../utils';\nimport { EXIT_DELEGATION_METHOD_ID, STARGATE_DELEGATION_ADDRESS } from '../constants';\n\nexport class ExitDelegationBuilder extends TransactionBuilder {\n  /**\n   * Creates a new ExitDelegationBuilder instance.\n   *\n   * @param {Readonly<CoinConfig>} _coinConfig - The coin configuration object\n   */\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._transaction = new ExitDelegationTransaction(_coinConfig);\n  }\n\n  /**\n   * Initializes the builder with an existing ExitDelegationTransaction.\n   *\n   * @param {ExitDelegationTransaction} tx - The transaction to initialize the builder with\n   */\n  initBuilder(tx: ExitDelegationTransaction): void {\n    this._transaction = tx;\n  }\n\n  /**\n   * Gets the exit delegation transaction instance.\n   *\n   * @returns {ExitDelegationTransaction} The exit delegation transaction\n   */\n  get exitDelegationTransaction(): ExitDelegationTransaction {\n    return this._transaction as ExitDelegationTransaction;\n  }\n\n  /**\n   * Gets the transaction type for unstaking.\n   *\n   * @returns {TransactionType} The transaction type\n   */\n  protected get transactionType(): TransactionType {\n    return TransactionType.StakingUnlock;\n  }\n\n  /**\n   * Validates the transaction clauses for unstaking.\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 unstaking transactions, value must be exactly '0x0'\n      if (clause.value !== 0) {\n        return false;\n      }\n\n      // Check if the data starts with the exitDelegation method ID\n      if (!clause.data.startsWith(EXIT_DELEGATION_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 unstaking transaction.\n   *\n   * @param {string} tokenId - The ID of the NFT token to unstake\n   * @returns {ExitDelegationBuilder} This transaction builder\n   */\n  tokenId(tokenId: string): this {\n    this.exitDelegationTransaction.tokenId = tokenId;\n    return this;\n  }\n\n  /**\n   * Sets the delegation contract address for this unstaking transaction.\n   * If not provided, uses the default address from constants.\n   *\n   * @param {string} address - The delegation contract address\n   * @returns {ExitDelegationBuilder} This transaction builder\n   */\n  delegationContract(address: string = STARGATE_DELEGATION_ADDRESS): this {\n    this.validateAddress({ address });\n    this.exitDelegationTransaction.contract = address;\n    return this;\n  }\n\n  /** @inheritdoc */\n  validateTransaction(transaction?: ExitDelegationTransaction): void {\n    if (!transaction) {\n      throw new Error('transaction not defined');\n    }\n    assert(transaction.contract, 'Delegation contract address is required');\n    assert(transaction.tokenId, 'Token ID is required');\n\n    this.validateAddress({ address: transaction.contract });\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    this.transaction.type = this.transactionType;\n    // Set the transaction data before building\n    this.exitDelegationTransaction.transactionData = this.getExitDelegationData();\n    await this.exitDelegationTransaction.build();\n    return this.transaction;\n  }\n\n  /**\n   * Generates the transaction data for exit delegation by encoding the exitDelegation method call.\n   *\n   * @private\n   * @returns {string} The encoded transaction data as a hex string\n   */\n  private getExitDelegationData(): string {\n    const methodName = 'exitDelegation';\n    const types = ['uint256'];\n    const params = [this.exitDelegationTransaction.tokenId];\n\n    const method = EthereumAbi.methodID(methodName, types);\n    const args = EthereumAbi.rawEncode(types, params);\n\n    return addHexPrefix(Buffer.concat([method, args]).toString('hex'));\n  }\n}\n"]}
|