@bitgo-beta/sdk-coin-flrp 1.0.0-alpha.12 → 1.0.0-alpha.13

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 (70) hide show
  1. package/dist/src/lib/atomicTransactionBuilder.d.ts +7 -10
  2. package/dist/src/lib/atomicTransactionBuilder.d.ts.map +1 -1
  3. package/dist/src/lib/atomicTransactionBuilder.js +89 -155
  4. package/dist/src/lib/constants.d.ts +1 -160
  5. package/dist/src/lib/constants.d.ts.map +1 -1
  6. package/dist/src/lib/constants.js +3 -213
  7. package/dist/src/lib/exportInCTxBuilder.d.ts +1 -1
  8. package/dist/src/lib/exportInCTxBuilder.d.ts.map +1 -1
  9. package/dist/src/lib/exportInCTxBuilder.js +17 -46
  10. package/dist/src/lib/exportInPTxBuilder.d.ts +1 -1
  11. package/dist/src/lib/exportInPTxBuilder.d.ts.map +1 -1
  12. package/dist/src/lib/exportInPTxBuilder.js +6 -70
  13. package/dist/src/lib/index.d.ts +0 -5
  14. package/dist/src/lib/index.d.ts.map +1 -1
  15. package/dist/src/lib/index.js +2 -11
  16. package/dist/src/lib/transaction.d.ts.map +1 -1
  17. package/dist/src/lib/transaction.js +13 -14
  18. package/dist/src/lib/utils.d.ts +0 -2
  19. package/dist/src/lib/utils.d.ts.map +1 -1
  20. package/dist/src/lib/utils.js +12 -23
  21. package/dist/test/unit/lib/exportTxBuilder.d.ts +2 -0
  22. package/dist/test/unit/lib/exportTxBuilder.d.ts.map +1 -0
  23. package/dist/test/unit/lib/exportTxBuilder.js +45 -0
  24. package/dist/tsconfig.tsbuildinfo +1 -1
  25. package/package.json +6 -6
  26. package/dist/src/lib/delegatorTxBuilder.d.ts +0 -58
  27. package/dist/src/lib/delegatorTxBuilder.d.ts.map +0 -1
  28. package/dist/src/lib/delegatorTxBuilder.js +0 -224
  29. package/dist/src/lib/importInCTxBuilder.d.ts +0 -67
  30. package/dist/src/lib/importInCTxBuilder.d.ts.map +0 -1
  31. package/dist/src/lib/importInCTxBuilder.js +0 -403
  32. package/dist/src/lib/importInPTxBuilder.d.ts +0 -73
  33. package/dist/src/lib/importInPTxBuilder.d.ts.map +0 -1
  34. package/dist/src/lib/importInPTxBuilder.js +0 -464
  35. package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts +0 -81
  36. package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts.map +0 -1
  37. package/dist/src/lib/permissionlessValidatorTxBuilder.js +0 -248
  38. package/dist/src/lib/transactionBuilder.d.ts +0 -85
  39. package/dist/src/lib/transactionBuilder.d.ts.map +0 -1
  40. package/dist/src/lib/transactionBuilder.js +0 -167
  41. package/dist/src/lib/types.d.ts +0 -78
  42. package/dist/src/lib/types.d.ts.map +0 -1
  43. package/dist/src/lib/types.js +0 -5
  44. package/dist/src/lib/validatorTxBuilder.d.ts +0 -40
  45. package/dist/src/lib/validatorTxBuilder.d.ts.map +0 -1
  46. package/dist/src/lib/validatorTxBuilder.js +0 -180
  47. package/dist/test/unit/delegatorTxBuilder.test.d.ts +0 -2
  48. package/dist/test/unit/delegatorTxBuilder.test.d.ts.map +0 -1
  49. package/dist/test/unit/delegatorTxBuilder.test.js +0 -233
  50. package/dist/test/unit/lib/exportInCTxBuilder.d.ts +0 -2
  51. package/dist/test/unit/lib/exportInCTxBuilder.d.ts.map +0 -1
  52. package/dist/test/unit/lib/exportInCTxBuilder.js +0 -584
  53. package/dist/test/unit/lib/exportInPTxBuilder.d.ts +0 -2
  54. package/dist/test/unit/lib/exportInPTxBuilder.d.ts.map +0 -1
  55. package/dist/test/unit/lib/exportInPTxBuilder.js +0 -377
  56. package/dist/test/unit/lib/importInCTxBuilder.d.ts +0 -2
  57. package/dist/test/unit/lib/importInCTxBuilder.d.ts.map +0 -1
  58. package/dist/test/unit/lib/importInCTxBuilder.js +0 -257
  59. package/dist/test/unit/lib/importInPTxBuilder.d.ts +0 -2
  60. package/dist/test/unit/lib/importInPTxBuilder.d.ts.map +0 -1
  61. package/dist/test/unit/lib/importInPTxBuilder.js +0 -500
  62. package/dist/test/unit/permissionlessValidatorTxBuilder.test.d.ts +0 -2
  63. package/dist/test/unit/permissionlessValidatorTxBuilder.test.d.ts.map +0 -1
  64. package/dist/test/unit/permissionlessValidatorTxBuilder.test.js +0 -271
  65. package/dist/test/unit/transactionBuilder.test.d.ts +0 -2
  66. package/dist/test/unit/transactionBuilder.test.d.ts.map +0 -1
  67. package/dist/test/unit/transactionBuilder.test.js +0 -114
  68. package/dist/test/unit/validatorTxBuilder.test.d.ts +0 -2
  69. package/dist/test/unit/validatorTxBuilder.test.d.ts.map +0 -1
  70. package/dist/test/unit/validatorTxBuilder.test.js +0 -293
@@ -1,248 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.PermissionlessValidatorTxBuilder = void 0;
4
- const sdk_core_1 = require("@bitgo-beta/sdk-core");
5
- const atomicTransactionBuilder_1 = require("./atomicTransactionBuilder");
6
- const constants_1 = require("./constants");
7
- const utils_1 = require("./utils");
8
- class PermissionlessValidatorTxBuilder extends atomicTransactionBuilder_1.AtomicTransactionBuilder {
9
- /**
10
- * @param coinConfig
11
- */
12
- constructor(coinConfig) {
13
- super(coinConfig);
14
- this._nodeID = undefined;
15
- this._blsPublicKey = undefined;
16
- this._blsSignature = undefined;
17
- this._startTime = undefined;
18
- this._endTime = undefined;
19
- this._stakeAmount = undefined;
20
- this._delegationFeeRate = undefined;
21
- }
22
- /**
23
- * get transaction type
24
- * @protected
25
- */
26
- get transactionType() {
27
- return sdk_core_1.TransactionType.AddPermissionlessValidator;
28
- }
29
- /**
30
- * Set the node ID for permissionless validation
31
- * @param nodeID - The node ID
32
- */
33
- nodeID(nodeID) {
34
- if (!nodeID || nodeID.length === 0) {
35
- throw new sdk_core_1.BuildTransactionError('Node ID cannot be empty');
36
- }
37
- this._nodeID = nodeID;
38
- return this;
39
- }
40
- /**
41
- * Set the BLS public key for permissionless validation
42
- * @param blsPublicKey - The BLS public key
43
- */
44
- blsPublicKey(blsPublicKey) {
45
- if (!blsPublicKey || blsPublicKey.length === 0) {
46
- throw new sdk_core_1.BuildTransactionError('BLS public key cannot be empty');
47
- }
48
- // BLS public key should be 48 bytes (96 hex characters) with 0x prefix or 192 hex characters with 0x prefix for uncompressed
49
- if (!(0, utils_1.createHexRegex)(constants_1.BLS_PUBLIC_KEY_COMPRESSED_LENGTH, true).test(blsPublicKey) &&
50
- !(0, utils_1.createHexRegex)(constants_1.BLS_PUBLIC_KEY_UNCOMPRESSED_LENGTH, true).test(blsPublicKey)) {
51
- throw new sdk_core_1.BuildTransactionError('Invalid BLS public key format');
52
- }
53
- this._blsPublicKey = blsPublicKey;
54
- return this;
55
- }
56
- /**
57
- * Set the BLS signature for permissionless validation
58
- * @param blsSignature - The BLS signature
59
- */
60
- blsSignature(blsSignature) {
61
- if (!blsSignature || blsSignature.length === 0) {
62
- throw new sdk_core_1.BuildTransactionError('BLS signature cannot be empty');
63
- }
64
- // BLS signature should be 96 bytes (192 hex characters) with 0x prefix
65
- if (!(0, utils_1.createHexRegex)(constants_1.BLS_SIGNATURE_LENGTH, true).test(blsSignature)) {
66
- throw new sdk_core_1.BuildTransactionError('Invalid BLS signature format');
67
- }
68
- this._blsSignature = blsSignature;
69
- return this;
70
- }
71
- /**
72
- * Set the start time for validation
73
- * @param startTime - Unix timestamp for when validation starts
74
- */
75
- startTime(startTime) {
76
- const time = BigInt(startTime);
77
- if (time < 0) {
78
- throw new sdk_core_1.BuildTransactionError('Start time must be non-negative');
79
- }
80
- this._startTime = time;
81
- return this;
82
- }
83
- /**
84
- * Set the end time for validation
85
- * @param endTime - Unix timestamp for when validation ends
86
- */
87
- endTime(endTime) {
88
- const time = BigInt(endTime);
89
- if (time <= 0) {
90
- throw new sdk_core_1.BuildTransactionError('End time must be positive');
91
- }
92
- this._endTime = time;
93
- return this;
94
- }
95
- /**
96
- * Set the stake amount for validation
97
- * @param amount - Amount to stake (in nFLR)
98
- */
99
- stakeAmount(amount) {
100
- const stake = BigInt(amount);
101
- if (stake <= 0) {
102
- throw new sdk_core_1.BuildTransactionError('Stake amount must be positive');
103
- }
104
- this._stakeAmount = stake;
105
- return this;
106
- }
107
- /**
108
- * Set the delegation fee rate
109
- * @param value - Delegation fee rate in basis points
110
- */
111
- delegationFeeRate(value) {
112
- this.validateDelegationFeeRate(value);
113
- this._delegationFeeRate = value;
114
- return this;
115
- }
116
- /**
117
- * Set reward addresses where validation rewards should be sent
118
- * @param addresses - Array of reward addresses
119
- */
120
- rewardAddresses(addresses) {
121
- if (!addresses || addresses.length === 0) {
122
- throw new sdk_core_1.BuildTransactionError('At least one reward address is required');
123
- }
124
- // Store reward addresses in the transaction (we'll need to extend the type)
125
- this.transaction._rewardAddresses = addresses;
126
- return this;
127
- }
128
- /**
129
- * Validate that the delegation fee is at least the minDelegationFee
130
- * @param delegationFeeRate number
131
- */
132
- validateDelegationFeeRate(delegationFeeRate) {
133
- // For Flare, use a minimum delegation fee of 2% (20000 basis points)
134
- const minDelegationFee = constants_1.MIN_DELEGATION_FEE_BASIS_POINTS;
135
- if (delegationFeeRate < minDelegationFee) {
136
- const minDelegationFeePercent = (minDelegationFee / constants_1.BASIS_POINTS_DIVISOR) * constants_1.PERCENTAGE_MULTIPLIER;
137
- throw new sdk_core_1.BuildTransactionError(`Delegation fee cannot be less than ${minDelegationFee} basis points (${minDelegationFeePercent}%)`);
138
- }
139
- }
140
- /** @inheritdoc */
141
- initBuilder(tx) {
142
- // Extract permissionless validator-specific fields from transaction
143
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
144
- const txData = tx;
145
- if (txData.nodeID) {
146
- this._nodeID = txData.nodeID;
147
- }
148
- if (txData.blsPublicKey) {
149
- this._blsPublicKey = txData.blsPublicKey;
150
- }
151
- if (txData.blsSignature) {
152
- this._blsSignature = txData.blsSignature;
153
- }
154
- if (txData.startTime) {
155
- this._startTime = BigInt(txData.startTime);
156
- }
157
- if (txData.endTime) {
158
- this._endTime = BigInt(txData.endTime);
159
- }
160
- if (txData.stakeAmount) {
161
- this._stakeAmount = BigInt(txData.stakeAmount);
162
- }
163
- if (txData.delegationFeeRate !== undefined) {
164
- this._delegationFeeRate = txData.delegationFeeRate;
165
- }
166
- if (txData.rewardAddresses) {
167
- this.transaction._rewardAddresses =
168
- txData.rewardAddresses;
169
- }
170
- return this;
171
- }
172
- /**
173
- * Verify if the transaction is a permissionless validator transaction
174
- * @param tx
175
- */
176
- static verifyTxType(tx) {
177
- // Check if transaction has permissionless validator-specific properties
178
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
179
- const txData = tx;
180
- return txData && txData.blsPublicKey && txData.blsSignature;
181
- }
182
- verifyTxType(tx) {
183
- return PermissionlessValidatorTxBuilder.verifyTxType(tx);
184
- }
185
- /**
186
- * Build the permissionless validator transaction
187
- * @protected
188
- */
189
- async buildFlareTransaction() {
190
- // Basic validation
191
- if (!this._nodeID) {
192
- throw new sdk_core_1.BuildTransactionError('Node ID is required for permissionless validator transaction');
193
- }
194
- if (!this._blsPublicKey) {
195
- throw new sdk_core_1.BuildTransactionError('BLS public key is required for permissionless validator transaction');
196
- }
197
- if (!this._blsSignature) {
198
- throw new sdk_core_1.BuildTransactionError('BLS signature is required for permissionless validator transaction');
199
- }
200
- if (!this._startTime) {
201
- throw new sdk_core_1.BuildTransactionError('Start time is required for permissionless validator transaction');
202
- }
203
- if (!this._endTime) {
204
- throw new sdk_core_1.BuildTransactionError('End time is required for permissionless validator transaction');
205
- }
206
- if (!this._stakeAmount) {
207
- throw new sdk_core_1.BuildTransactionError('Stake amount is required for permissionless validator transaction');
208
- }
209
- if (this._delegationFeeRate === undefined) {
210
- throw new sdk_core_1.BuildTransactionError('Delegation fee rate is required for permissionless validator transaction');
211
- }
212
- const rewardAddresses = this.transaction
213
- ._rewardAddresses;
214
- if (!rewardAddresses || rewardAddresses.length === 0) {
215
- throw new sdk_core_1.BuildTransactionError('Reward addresses are required for permissionless validator transaction');
216
- }
217
- // Validate time range
218
- if (this._endTime <= this._startTime) {
219
- throw new sdk_core_1.BuildTransactionError('End time must be after start time');
220
- }
221
- try {
222
- // TODO: Implement actual FlareJS PVM API call when available
223
- // For now, create a placeholder transaction structure
224
- const validatorTx = {
225
- type: constants_1.ADD_PERMISSIONLESS_VALIDATOR_TYPE,
226
- nodeID: this._nodeID,
227
- blsPublicKey: this._blsPublicKey,
228
- blsSignature: this._blsSignature,
229
- startTime: this._startTime,
230
- endTime: this._endTime,
231
- stakeAmount: this._stakeAmount,
232
- delegationFeeRate: this._delegationFeeRate,
233
- rewardAddress: rewardAddresses[0],
234
- fromAddresses: this.transaction._fromAddresses,
235
- networkId: this.transaction._networkID,
236
- sourceBlockchainId: this.transaction._blockchainID,
237
- threshold: this.transaction._threshold || 1,
238
- locktime: this.transaction._locktime || 0n,
239
- };
240
- this.transaction.setTransaction(validatorTx);
241
- }
242
- catch (error) {
243
- throw new sdk_core_1.BuildTransactionError(`Failed to build permissionless validator transaction: ${error instanceof Error ? error.message : 'Unknown error'}`);
244
- }
245
- }
246
- }
247
- exports.PermissionlessValidatorTxBuilder = PermissionlessValidatorTxBuilder;
248
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"permissionlessValidatorTxBuilder.js","sourceRoot":"","sources":["../../../src/lib/permissionlessValidatorTxBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BuildTransactionError, TransactionType } from '@bitgo-beta/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { AtomicTransactionBuilder } from './atomicTransactionBuilder';\nimport { Tx } from './iface';\nimport { PermissionlessValidatorExtendedTransaction } from './types';\nimport {\n  ADD_PERMISSIONLESS_VALIDATOR_TYPE,\n  BASIS_POINTS_DIVISOR,\n  BLS_PUBLIC_KEY_COMPRESSED_LENGTH,\n  BLS_PUBLIC_KEY_UNCOMPRESSED_LENGTH,\n  BLS_SIGNATURE_LENGTH,\n  MIN_DELEGATION_FEE_BASIS_POINTS,\n  PERCENTAGE_MULTIPLIER,\n} from './constants';\nimport { createHexRegex } from './utils';\n\nexport class PermissionlessValidatorTxBuilder extends AtomicTransactionBuilder {\n  protected _nodeID: string | undefined;\n  protected _blsPublicKey: string | undefined;\n  protected _blsSignature: string | undefined;\n  protected _startTime: bigint | undefined;\n  protected _endTime: bigint | undefined;\n  protected _stakeAmount: bigint | undefined;\n  protected _delegationFeeRate: number | undefined;\n\n  /**\n   * @param coinConfig\n   */\n  constructor(coinConfig: Readonly<CoinConfig>) {\n    super(coinConfig);\n    this._nodeID = undefined;\n    this._blsPublicKey = undefined;\n    this._blsSignature = undefined;\n    this._startTime = undefined;\n    this._endTime = undefined;\n    this._stakeAmount = undefined;\n    this._delegationFeeRate = undefined;\n  }\n\n  /**\n   * get transaction type\n   * @protected\n   */\n  protected get transactionType(): TransactionType {\n    return TransactionType.AddPermissionlessValidator;\n  }\n\n  /**\n   * Set the node ID for permissionless validation\n   * @param nodeID - The node ID\n   */\n  nodeID(nodeID: string): this {\n    if (!nodeID || nodeID.length === 0) {\n      throw new BuildTransactionError('Node ID cannot be empty');\n    }\n    this._nodeID = nodeID;\n    return this;\n  }\n\n  /**\n   * Set the BLS public key for permissionless validation\n   * @param blsPublicKey - The BLS public key\n   */\n  blsPublicKey(blsPublicKey: string): this {\n    if (!blsPublicKey || blsPublicKey.length === 0) {\n      throw new BuildTransactionError('BLS public key cannot be empty');\n    }\n\n    // BLS public key should be 48 bytes (96 hex characters) with 0x prefix or 192 hex characters with 0x prefix for uncompressed\n    if (\n      !createHexRegex(BLS_PUBLIC_KEY_COMPRESSED_LENGTH, true).test(blsPublicKey) &&\n      !createHexRegex(BLS_PUBLIC_KEY_UNCOMPRESSED_LENGTH, true).test(blsPublicKey)\n    ) {\n      throw new BuildTransactionError('Invalid BLS public key format');\n    }\n\n    this._blsPublicKey = blsPublicKey;\n    return this;\n  }\n\n  /**\n   * Set the BLS signature for permissionless validation\n   * @param blsSignature - The BLS signature\n   */\n  blsSignature(blsSignature: string): this {\n    if (!blsSignature || blsSignature.length === 0) {\n      throw new BuildTransactionError('BLS signature cannot be empty');\n    }\n\n    // BLS signature should be 96 bytes (192 hex characters) with 0x prefix\n    if (!createHexRegex(BLS_SIGNATURE_LENGTH, true).test(blsSignature)) {\n      throw new BuildTransactionError('Invalid BLS signature format');\n    }\n\n    this._blsSignature = blsSignature;\n    return this;\n  }\n\n  /**\n   * Set the start time for validation\n   * @param startTime - Unix timestamp for when validation starts\n   */\n  startTime(startTime: string | number | bigint): this {\n    const time = BigInt(startTime);\n    if (time < 0) {\n      throw new BuildTransactionError('Start time must be non-negative');\n    }\n    this._startTime = time;\n    return this;\n  }\n\n  /**\n   * Set the end time for validation\n   * @param endTime - Unix timestamp for when validation ends\n   */\n  endTime(endTime: string | number | bigint): this {\n    const time = BigInt(endTime);\n    if (time <= 0) {\n      throw new BuildTransactionError('End time must be positive');\n    }\n    this._endTime = time;\n    return this;\n  }\n\n  /**\n   * Set the stake amount for validation\n   * @param amount - Amount to stake (in nFLR)\n   */\n  stakeAmount(amount: string | number | bigint): this {\n    const stake = BigInt(amount);\n    if (stake <= 0) {\n      throw new BuildTransactionError('Stake amount must be positive');\n    }\n    this._stakeAmount = stake;\n    return this;\n  }\n\n  /**\n   * Set the delegation fee rate\n   * @param value - Delegation fee rate in basis points\n   */\n  delegationFeeRate(value: number): this {\n    this.validateDelegationFeeRate(value);\n    this._delegationFeeRate = value;\n    return this;\n  }\n\n  /**\n   * Set reward addresses where validation rewards should be sent\n   * @param addresses - Array of reward addresses\n   */\n  rewardAddresses(addresses: string[]): this {\n    if (!addresses || addresses.length === 0) {\n      throw new BuildTransactionError('At least one reward address is required');\n    }\n    // Store reward addresses in the transaction (we'll need to extend the type)\n    (this.transaction as unknown as PermissionlessValidatorExtendedTransaction)._rewardAddresses = addresses;\n    return this;\n  }\n\n  /**\n   * Validate that the delegation fee is at least the minDelegationFee\n   * @param delegationFeeRate number\n   */\n  validateDelegationFeeRate(delegationFeeRate: number): void {\n    // For Flare, use a minimum delegation fee of 2% (20000 basis points)\n    const minDelegationFee = MIN_DELEGATION_FEE_BASIS_POINTS;\n    if (delegationFeeRate < minDelegationFee) {\n      const minDelegationFeePercent = (minDelegationFee / BASIS_POINTS_DIVISOR) * PERCENTAGE_MULTIPLIER;\n      throw new BuildTransactionError(\n        `Delegation fee cannot be less than ${minDelegationFee} basis points (${minDelegationFeePercent}%)`\n      );\n    }\n  }\n\n  /** @inheritdoc */\n  initBuilder(tx: Tx): this {\n    // Extract permissionless validator-specific fields from transaction\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    const txData = tx as any;\n\n    if (txData.nodeID) {\n      this._nodeID = txData.nodeID;\n    }\n    if (txData.blsPublicKey) {\n      this._blsPublicKey = txData.blsPublicKey;\n    }\n    if (txData.blsSignature) {\n      this._blsSignature = txData.blsSignature;\n    }\n    if (txData.startTime) {\n      this._startTime = BigInt(txData.startTime);\n    }\n    if (txData.endTime) {\n      this._endTime = BigInt(txData.endTime);\n    }\n    if (txData.stakeAmount) {\n      this._stakeAmount = BigInt(txData.stakeAmount);\n    }\n    if (txData.delegationFeeRate !== undefined) {\n      this._delegationFeeRate = txData.delegationFeeRate;\n    }\n    if (txData.rewardAddresses) {\n      (this.transaction as unknown as PermissionlessValidatorExtendedTransaction)._rewardAddresses =\n        txData.rewardAddresses;\n    }\n\n    return this;\n  }\n\n  /**\n   * Verify if the transaction is a permissionless validator transaction\n   * @param tx\n   */\n  static verifyTxType(tx: unknown): boolean {\n    // Check if transaction has permissionless validator-specific properties\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    const txData = tx as any;\n    return txData && txData.blsPublicKey && txData.blsSignature;\n  }\n\n  verifyTxType(tx: unknown): boolean {\n    return PermissionlessValidatorTxBuilder.verifyTxType(tx);\n  }\n\n  /**\n   * Build the permissionless validator transaction\n   * @protected\n   */\n  protected async buildFlareTransaction(): Promise<void> {\n    // Basic validation\n    if (!this._nodeID) {\n      throw new BuildTransactionError('Node ID is required for permissionless validator transaction');\n    }\n    if (!this._blsPublicKey) {\n      throw new BuildTransactionError('BLS public key is required for permissionless validator transaction');\n    }\n    if (!this._blsSignature) {\n      throw new BuildTransactionError('BLS signature is required for permissionless validator transaction');\n    }\n    if (!this._startTime) {\n      throw new BuildTransactionError('Start time is required for permissionless validator transaction');\n    }\n    if (!this._endTime) {\n      throw new BuildTransactionError('End time is required for permissionless validator transaction');\n    }\n    if (!this._stakeAmount) {\n      throw new BuildTransactionError('Stake amount is required for permissionless validator transaction');\n    }\n    if (this._delegationFeeRate === undefined) {\n      throw new BuildTransactionError('Delegation fee rate is required for permissionless validator transaction');\n    }\n\n    const rewardAddresses = (this.transaction as unknown as PermissionlessValidatorExtendedTransaction)\n      ._rewardAddresses;\n    if (!rewardAddresses || rewardAddresses.length === 0) {\n      throw new BuildTransactionError('Reward addresses are required for permissionless validator transaction');\n    }\n\n    // Validate time range\n    if (this._endTime <= this._startTime) {\n      throw new BuildTransactionError('End time must be after start time');\n    }\n\n    try {\n      // TODO: Implement actual FlareJS PVM API call when available\n      // For now, create a placeholder transaction structure\n      const validatorTx = {\n        type: ADD_PERMISSIONLESS_VALIDATOR_TYPE,\n        nodeID: this._nodeID,\n        blsPublicKey: this._blsPublicKey,\n        blsSignature: this._blsSignature,\n        startTime: this._startTime,\n        endTime: this._endTime,\n        stakeAmount: this._stakeAmount,\n        delegationFeeRate: this._delegationFeeRate,\n        rewardAddress: rewardAddresses[0],\n        fromAddresses: this.transaction._fromAddresses,\n        networkId: this.transaction._networkID,\n        sourceBlockchainId: this.transaction._blockchainID,\n        threshold: this.transaction._threshold || 1,\n        locktime: this.transaction._locktime || 0n,\n      };\n\n      this.transaction.setTransaction(validatorTx);\n    } catch (error) {\n      throw new BuildTransactionError(\n        `Failed to build permissionless validator transaction: ${\n          error instanceof Error ? error.message : 'Unknown error'\n        }`\n      );\n    }\n  }\n}\n"]}
@@ -1,85 +0,0 @@
1
- import { BaseTransactionBuilder } from '@bitgo-beta/sdk-core';
2
- import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
3
- import { DecodedUtxoObj, Tx } from './iface';
4
- import { KeyPair } from './keyPair';
5
- import { Transaction } from './transaction';
6
- export declare abstract class TransactionBuilder extends BaseTransactionBuilder {
7
- protected _transaction: Transaction;
8
- protected recoverSigner: boolean;
9
- _signer: KeyPair[];
10
- protected _recoveryMode: boolean;
11
- constructor(_coinConfig: Readonly<CoinConfig>);
12
- /**
13
- * Initialize the transaction builder fields using the decoded transaction data
14
- *
15
- * @param {Tx} tx the transaction data
16
- * @returns itself
17
- */
18
- initBuilder(tx: Tx): this;
19
- /**
20
- * Validates the threshold
21
- * @param threshold
22
- */
23
- validateThreshold(threshold: number): void;
24
- /**
25
- * Check the UTXO has expected fields.
26
- * @param UTXO
27
- */
28
- validateUtxo(value: DecodedUtxoObj): void;
29
- /**
30
- * Check the list of UTXOS is empty and check each UTXO.
31
- * @param values
32
- */
33
- validateUtxos(values: DecodedUtxoObj[]): void;
34
- /**
35
- * Validates locktime
36
- * @param locktime
37
- */
38
- validateLocktime(locktime: bigint): void;
39
- /**
40
- * Threshold is an int that names the number of unique signatures required to spend the output.
41
- * Must be less than or equal to the length of Addresses.
42
- * @param {number} value
43
- */
44
- threshold(value: number): this;
45
- /**
46
- * Locktime is a long that contains the unix timestamp that this output can be spent after.
47
- * The unix timestamp is specific to the second.
48
- * @param value
49
- */
50
- locktime(value: string | number): this;
51
- /**
52
- * When using recovery key must be set here
53
- * @param {boolean}[recoverSigner=true] whether it's recovery signer
54
- */
55
- recoverMode(recoverSigner?: boolean): this;
56
- /**
57
- * fromPubKey is a list of unique addresses that correspond to the private keys that can be used to spend this output
58
- * @param {string | string[]} senderPubKey
59
- */
60
- fromPubKey(senderPubKey: string | string[]): this;
61
- /**
62
- * List of UTXO required as inputs.
63
- * A UTXO is a standalone representation of a transaction output.
64
- *
65
- * @param {DecodedUtxoObj[]} list of UTXOS
66
- */
67
- utxos(value: DecodedUtxoObj[]): this;
68
- /**
69
- * Build the Flare transaction using FlareJS API
70
- * @protected
71
- */
72
- protected abstract buildFlareTransaction(): Promise<void> | void;
73
- /** @inheritdoc */
74
- protected fromImplementation(rawTransaction: string): Transaction;
75
- /**
76
- * Get the transaction instance
77
- */
78
- get transaction(): Transaction;
79
- /**
80
- * Validate required fields before building transaction
81
- * @protected
82
- */
83
- protected validateRequiredFields(): void;
84
- }
85
- //# sourceMappingURL=transactionBuilder.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"transactionBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAyB,MAAM,sBAAsB,CAAC;AACrF,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM,SAAS,CAAC;AAC7C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAiB5C,8BAAsB,kBAAmB,SAAQ,sBAAsB;IACrE,SAAS,CAAC,YAAY,EAAE,WAAW,CAAC;IACpC,SAAS,CAAC,aAAa,UAAS;IACzB,OAAO,EAAE,OAAO,EAAE,CAAM;IAG/B,SAAS,CAAC,aAAa,UAAS;gBAEpB,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAK7C;;;;;OAKG;IACH,WAAW,CAAC,EAAE,EAAE,EAAE,GAAG,IAAI;IAyBzB;;;OAGG;IACH,iBAAiB,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAM1C;;;OAGG;IACH,YAAY,CAAC,KAAK,EAAE,cAAc,GAAG,IAAI;IAMzC;;;OAGG;IACH,aAAa,CAAC,MAAM,EAAE,cAAc,EAAE,GAAG,IAAI;IAO7C;;;OAGG;IACH,gBAAgB,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAOxC;;;;OAIG;IACH,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAM9B;;;;OAIG;IACH,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAMtC;;;OAGG;IACH,WAAW,CAAC,aAAa,UAAO,GAAG,IAAI;IAYvC;;;OAGG;IACH,UAAU,CAAC,YAAY,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,IAAI;IAMjD;;;;;OAKG;IACH,KAAK,CAAC,KAAK,EAAE,cAAc,EAAE,GAAG,IAAI;IAMpC;;;OAGG;IACH,SAAS,CAAC,QAAQ,CAAC,qBAAqB,IAAI,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI;IAEhE,kBAAkB;IAClB,SAAS,CAAC,kBAAkB,CAAC,cAAc,EAAE,MAAM,GAAG,WAAW;IAajE;;OAEG;IACH,IAAI,WAAW,IAAI,WAAW,CAE7B;IAED;;;OAGG;IACH,SAAS,CAAC,sBAAsB,IAAI,IAAI;CAQzC"}
@@ -1,167 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.TransactionBuilder = void 0;
4
- const sdk_core_1 = require("@bitgo-beta/sdk-core");
5
- const transaction_1 = require("./transaction");
6
- const constants_1 = require("./constants");
7
- class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
8
- constructor(_coinConfig) {
9
- super(_coinConfig);
10
- this.recoverSigner = false;
11
- this._signer = [];
12
- // Recovery mode flag for transaction building
13
- this._recoveryMode = false;
14
- this._transaction = new transaction_1.Transaction(_coinConfig);
15
- }
16
- /**
17
- * Initialize the transaction builder fields using the decoded transaction data
18
- *
19
- * @param {Tx} tx the transaction data
20
- * @returns itself
21
- */
22
- initBuilder(tx) {
23
- // Validate network and blockchain IDs if available
24
- const txData = tx;
25
- if (txData.networkID !== undefined && txData.networkID !== this._transaction._networkID) {
26
- throw new Error(constants_1.ERROR_NETWORK_ID_MISMATCH);
27
- }
28
- if (txData.blockchainID) {
29
- const blockchainID = Buffer.isBuffer(txData.blockchainID)
30
- ? txData.blockchainID
31
- : Buffer.from(txData.blockchainID, constants_1.HEX_ENCODING);
32
- const transactionBlockchainID = Buffer.isBuffer(this._transaction._blockchainID)
33
- ? this._transaction._blockchainID
34
- : Buffer.from(this._transaction._blockchainID, constants_1.HEX_ENCODING);
35
- if (!blockchainID.equals(transactionBlockchainID)) {
36
- throw new Error(constants_1.ERROR_BLOCKCHAIN_ID_MISMATCH_BUILDER);
37
- }
38
- }
39
- this._transaction.setTransaction(tx);
40
- return this;
41
- }
42
- // region Validators
43
- /**
44
- * Validates the threshold
45
- * @param threshold
46
- */
47
- validateThreshold(threshold) {
48
- if (!threshold || threshold !== 2) {
49
- throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_INVALID_THRESHOLD);
50
- }
51
- }
52
- /**
53
- * Check the UTXO has expected fields.
54
- * @param UTXO
55
- */
56
- validateUtxo(value) {
57
- constants_1.UTXO_REQUIRED_FIELDS.forEach((field) => {
58
- if (!value.hasOwnProperty(field))
59
- throw new sdk_core_1.BuildTransactionError(`${constants_1.ERROR_UTXOS_MISSING_FIELD} ${field}`);
60
- });
61
- }
62
- /**
63
- * Check the list of UTXOS is empty and check each UTXO.
64
- * @param values
65
- */
66
- validateUtxos(values) {
67
- if (values.length === 0) {
68
- throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_UTXOS_EMPTY_ARRAY);
69
- }
70
- values.forEach(this.validateUtxo);
71
- }
72
- /**
73
- * Validates locktime
74
- * @param locktime
75
- */
76
- validateLocktime(locktime) {
77
- if (!locktime || locktime < BigInt(0)) {
78
- throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_INVALID_LOCKTIME);
79
- }
80
- }
81
- // endregion
82
- /**
83
- * Threshold is an int that names the number of unique signatures required to spend the output.
84
- * Must be less than or equal to the length of Addresses.
85
- * @param {number} value
86
- */
87
- threshold(value) {
88
- this.validateThreshold(value);
89
- this._transaction._threshold = value;
90
- return this;
91
- }
92
- /**
93
- * Locktime is a long that contains the unix timestamp that this output can be spent after.
94
- * The unix timestamp is specific to the second.
95
- * @param value
96
- */
97
- locktime(value) {
98
- this.validateLocktime(BigInt(value));
99
- this._transaction._locktime = BigInt(value);
100
- return this;
101
- }
102
- /**
103
- * When using recovery key must be set here
104
- * @param {boolean}[recoverSigner=true] whether it's recovery signer
105
- */
106
- recoverMode(recoverSigner = true) {
107
- this.recoverSigner = recoverSigner;
108
- this._recoveryMode = recoverSigner;
109
- // Recovery operations typically need single signature
110
- if (recoverSigner && !this._transaction._threshold) {
111
- this._transaction._threshold = 1;
112
- }
113
- return this;
114
- }
115
- /**
116
- * fromPubKey is a list of unique addresses that correspond to the private keys that can be used to spend this output
117
- * @param {string | string[]} senderPubKey
118
- */
119
- fromPubKey(senderPubKey) {
120
- const pubKeys = senderPubKey instanceof Array ? senderPubKey : [senderPubKey];
121
- this._transaction._fromAddresses = pubKeys; // Store as strings directly
122
- return this;
123
- }
124
- /**
125
- * List of UTXO required as inputs.
126
- * A UTXO is a standalone representation of a transaction output.
127
- *
128
- * @param {DecodedUtxoObj[]} list of UTXOS
129
- */
130
- utxos(value) {
131
- this.validateUtxos(value);
132
- this._transaction._utxos = value;
133
- return this;
134
- }
135
- /** @inheritdoc */
136
- fromImplementation(rawTransaction) {
137
- // Parse the raw transaction and initialize the builder
138
- try {
139
- const parsedTx = JSON.parse(rawTransaction);
140
- this.initBuilder(parsedTx);
141
- return this._transaction;
142
- }
143
- catch (error) {
144
- throw new Error(`${constants_1.ERROR_PARSE_RAW_TRANSACTION}: ${error instanceof Error ? error.message : constants_1.ERROR_UNKNOWN_PARSING}`);
145
- }
146
- }
147
- /**
148
- * Get the transaction instance
149
- */
150
- get transaction() {
151
- return this._transaction;
152
- }
153
- /**
154
- * Validate required fields before building transaction
155
- * @protected
156
- */
157
- validateRequiredFields() {
158
- if (this._transaction._fromAddresses.length === 0) {
159
- throw new Error(constants_1.ERROR_FROM_ADDRESSES_REQUIRED);
160
- }
161
- if (this._transaction._utxos.length === 0) {
162
- throw new Error(constants_1.ERROR_UTXOS_REQUIRED_BUILDER);
163
- }
164
- }
165
- }
166
- exports.TransactionBuilder = TransactionBuilder;
167
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transactionBuilder.js","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseTransactionBuilder, BuildTransactionError } from '@bitgo-beta/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { DecodedUtxoObj, Tx } from './iface';\nimport { KeyPair } from './keyPair';\nimport { Transaction } from './transaction';\nimport { RawTransactionData } from './types';\nimport {\n  ERROR_NETWORK_ID_MISMATCH,\n  ERROR_BLOCKCHAIN_ID_MISMATCH_BUILDER,\n  ERROR_INVALID_THRESHOLD,\n  ERROR_INVALID_LOCKTIME,\n  ERROR_UTXOS_EMPTY_ARRAY,\n  ERROR_UTXOS_MISSING_FIELD,\n  ERROR_FROM_ADDRESSES_REQUIRED,\n  ERROR_UTXOS_REQUIRED_BUILDER,\n  ERROR_PARSE_RAW_TRANSACTION,\n  ERROR_UNKNOWN_PARSING,\n  UTXO_REQUIRED_FIELDS,\n  HEX_ENCODING,\n} from './constants';\n\nexport abstract class TransactionBuilder extends BaseTransactionBuilder {\n  protected _transaction: Transaction;\n  protected recoverSigner = false;\n  public _signer: KeyPair[] = [];\n\n  // Recovery mode flag for transaction building\n  protected _recoveryMode = false;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._transaction = new Transaction(_coinConfig);\n  }\n\n  /**\n   * Initialize the transaction builder fields using the decoded transaction data\n   *\n   * @param {Tx} tx the transaction data\n   * @returns itself\n   */\n  initBuilder(tx: Tx): this {\n    // Validate network and blockchain IDs if available\n    const txData = tx as unknown as RawTransactionData;\n\n    if (txData.networkID !== undefined && txData.networkID !== this._transaction._networkID) {\n      throw new Error(ERROR_NETWORK_ID_MISMATCH);\n    }\n\n    if (txData.blockchainID) {\n      const blockchainID = Buffer.isBuffer(txData.blockchainID)\n        ? txData.blockchainID\n        : Buffer.from(txData.blockchainID, HEX_ENCODING);\n      const transactionBlockchainID = Buffer.isBuffer(this._transaction._blockchainID)\n        ? this._transaction._blockchainID\n        : Buffer.from(this._transaction._blockchainID, HEX_ENCODING);\n      if (!blockchainID.equals(transactionBlockchainID)) {\n        throw new Error(ERROR_BLOCKCHAIN_ID_MISMATCH_BUILDER);\n      }\n    }\n\n    this._transaction.setTransaction(tx);\n    return this;\n  }\n\n  // region Validators\n  /**\n   * Validates the threshold\n   * @param threshold\n   */\n  validateThreshold(threshold: number): void {\n    if (!threshold || threshold !== 2) {\n      throw new BuildTransactionError(ERROR_INVALID_THRESHOLD);\n    }\n  }\n\n  /**\n   * Check the UTXO has expected fields.\n   * @param UTXO\n   */\n  validateUtxo(value: DecodedUtxoObj): void {\n    UTXO_REQUIRED_FIELDS.forEach((field) => {\n      if (!value.hasOwnProperty(field)) throw new BuildTransactionError(`${ERROR_UTXOS_MISSING_FIELD} ${field}`);\n    });\n  }\n\n  /**\n   * Check the list of UTXOS is empty and check each UTXO.\n   * @param values\n   */\n  validateUtxos(values: DecodedUtxoObj[]): void {\n    if (values.length === 0) {\n      throw new BuildTransactionError(ERROR_UTXOS_EMPTY_ARRAY);\n    }\n    values.forEach(this.validateUtxo);\n  }\n\n  /**\n   * Validates locktime\n   * @param locktime\n   */\n  validateLocktime(locktime: bigint): void {\n    if (!locktime || locktime < BigInt(0)) {\n      throw new BuildTransactionError(ERROR_INVALID_LOCKTIME);\n    }\n  }\n  // endregion\n\n  /**\n   * Threshold is an int that names the number of unique signatures required to spend the output.\n   * Must be less than or equal to the length of Addresses.\n   * @param {number} value\n   */\n  threshold(value: number): this {\n    this.validateThreshold(value);\n    this._transaction._threshold = value;\n    return this;\n  }\n\n  /**\n   * Locktime is a long that contains the unix timestamp that this output can be spent after.\n   * The unix timestamp is specific to the second.\n   * @param value\n   */\n  locktime(value: string | number): this {\n    this.validateLocktime(BigInt(value));\n    this._transaction._locktime = BigInt(value);\n    return this;\n  }\n\n  /**\n   * When using recovery key must be set here\n   * @param {boolean}[recoverSigner=true] whether it's recovery signer\n   */\n  recoverMode(recoverSigner = true): this {\n    this.recoverSigner = recoverSigner;\n    this._recoveryMode = recoverSigner;\n\n    // Recovery operations typically need single signature\n    if (recoverSigner && !this._transaction._threshold) {\n      this._transaction._threshold = 1;\n    }\n\n    return this;\n  }\n\n  /**\n   * fromPubKey is a list of unique addresses that correspond to the private keys that can be used to spend this output\n   * @param {string | string[]} senderPubKey\n   */\n  fromPubKey(senderPubKey: string | string[]): this {\n    const pubKeys = senderPubKey instanceof Array ? senderPubKey : [senderPubKey];\n    this._transaction._fromAddresses = pubKeys; // Store as strings directly\n    return this;\n  }\n\n  /**\n   * List of UTXO required as inputs.\n   * A UTXO is a standalone representation of a transaction output.\n   *\n   * @param {DecodedUtxoObj[]} list of UTXOS\n   */\n  utxos(value: DecodedUtxoObj[]): this {\n    this.validateUtxos(value);\n    this._transaction._utxos = value;\n    return this;\n  }\n\n  /**\n   * Build the Flare transaction using FlareJS API\n   * @protected\n   */\n  protected abstract buildFlareTransaction(): Promise<void> | void;\n\n  /** @inheritdoc */\n  protected fromImplementation(rawTransaction: string): Transaction {\n    // Parse the raw transaction and initialize the builder\n    try {\n      const parsedTx = JSON.parse(rawTransaction);\n      this.initBuilder(parsedTx);\n      return this._transaction;\n    } catch (error) {\n      throw new Error(\n        `${ERROR_PARSE_RAW_TRANSACTION}: ${error instanceof Error ? error.message : ERROR_UNKNOWN_PARSING}`\n      );\n    }\n  }\n\n  /**\n   * Get the transaction instance\n   */\n  get transaction(): Transaction {\n    return this._transaction;\n  }\n\n  /**\n   * Validate required fields before building transaction\n   * @protected\n   */\n  protected validateRequiredFields(): void {\n    if (this._transaction._fromAddresses.length === 0) {\n      throw new Error(ERROR_FROM_ADDRESSES_REQUIRED);\n    }\n    if (this._transaction._utxos.length === 0) {\n      throw new Error(ERROR_UTXOS_REQUIRED_BUILDER);\n    }\n  }\n}\n"]}
@@ -1,78 +0,0 @@
1
- import { DecodedUtxoObj } from './iface';
2
- /**
3
- * Base extended transaction interface with common optional properties
4
- */
5
- export interface BaseExtendedTransaction {
6
- _memo?: Uint8Array;
7
- _outputAmount?: string;
8
- _utxos?: DecodedUtxoObj[];
9
- }
10
- /**
11
- * Extended transaction for staking transactions (delegator/validator)
12
- */
13
- export interface StakingExtendedTransaction extends BaseExtendedTransaction {
14
- _rewardAddresses: string[];
15
- _nodeID?: string;
16
- _startTime?: bigint;
17
- _endTime?: bigint;
18
- _stakeAmount?: bigint;
19
- }
20
- /**
21
- * Extended transaction for validator transactions
22
- */
23
- export interface ValidatorExtendedTransaction extends StakingExtendedTransaction {
24
- _delegationFeeRate?: number;
25
- }
26
- /**
27
- * Extended transaction for permissionless validator transactions
28
- */
29
- export interface PermissionlessValidatorExtendedTransaction extends ValidatorExtendedTransaction {
30
- _blsPublicKey?: string;
31
- _blsSignature?: string;
32
- }
33
- /**
34
- * Base raw transaction data structure from serialized transactions
35
- */
36
- export interface BaseRawTransactionData {
37
- memo?: Uint8Array | string;
38
- utxos?: DecodedUtxoObj[];
39
- outputAmount?: string;
40
- networkID?: number;
41
- blockchainID?: Buffer | string;
42
- }
43
- /**
44
- * Raw transaction data for delegator transactions
45
- */
46
- export interface DelegatorRawTransactionData extends BaseRawTransactionData {
47
- nodeID: string;
48
- startTime: string | number | bigint;
49
- endTime: string | number | bigint;
50
- stakeAmount: string | number | bigint;
51
- rewardAddresses: string[];
52
- }
53
- /**
54
- * Raw transaction data for validator transactions
55
- */
56
- export interface ValidatorRawTransactionData extends DelegatorRawTransactionData {
57
- delegationFeeRate: number;
58
- }
59
- /**
60
- * Raw transaction data for permissionless validator transactions
61
- */
62
- export interface PermissionlessValidatorRawTransactionData extends ValidatorRawTransactionData {
63
- blsPublicKey: string;
64
- blsSignature: string;
65
- }
66
- /**
67
- * Raw transaction data structure from serialized transactions
68
- * Union type supporting all transaction types with proper type safety
69
- */
70
- export type RawTransactionData = BaseRawTransactionData | DelegatorRawTransactionData | ValidatorRawTransactionData | PermissionlessValidatorRawTransactionData;
71
- /**
72
- * Specific transaction extension types for better type safety
73
- */
74
- export type TransactionWithBaseExtensions = BaseExtendedTransaction & Record<string, unknown>;
75
- export type TransactionWithStakingExtensions = StakingExtendedTransaction & Record<string, unknown>;
76
- export type TransactionWithValidatorExtensions = ValidatorExtendedTransaction & Record<string, unknown>;
77
- export type TransactionWithPermissionlessValidatorExtensions = PermissionlessValidatorExtendedTransaction & Record<string, unknown>;
78
- //# sourceMappingURL=types.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/lib/types.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAEzC;;GAEG;AACH,MAAM,WAAW,uBAAuB;IACtC,KAAK,CAAC,EAAE,UAAU,CAAC;IACnB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,MAAM,CAAC,EAAE,cAAc,EAAE,CAAC;CAC3B;AAED;;GAEG;AACH,MAAM,WAAW,0BAA2B,SAAQ,uBAAuB;IACzE,gBAAgB,EAAE,MAAM,EAAE,CAAC;IAC3B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED;;GAEG;AACH,MAAM,WAAW,4BAA6B,SAAQ,0BAA0B;IAC9E,kBAAkB,CAAC,EAAE,MAAM,CAAC;CAC7B;AAED;;GAEG;AACH,MAAM,WAAW,0CAA2C,SAAQ,4BAA4B;IAC9F,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED;;GAEG;AACH,MAAM,WAAW,sBAAsB;IAErC,IAAI,CAAC,EAAE,UAAU,GAAG,MAAM,CAAC;IAC3B,KAAK,CAAC,EAAE,cAAc,EAAE,CAAC;IACzB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;CAChC;AAED;;GAEG;AACH,MAAM,WAAW,2BAA4B,SAAQ,sBAAsB;IAEzE,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;IACpC,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;IAClC,WAAW,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;IACtC,eAAe,EAAE,MAAM,EAAE,CAAC;CAC3B;AAED;;GAEG;AACH,MAAM,WAAW,2BAA4B,SAAQ,2BAA2B;IAE9E,iBAAiB,EAAE,MAAM,CAAC;CAC3B;AAED;;GAEG;AACH,MAAM,WAAW,yCAA0C,SAAQ,2BAA2B;IAE5F,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC;CACtB;AAED;;;GAGG;AACH,MAAM,MAAM,kBAAkB,GAC1B,sBAAsB,GACtB,2BAA2B,GAC3B,2BAA2B,GAC3B,yCAAyC,CAAC;AAE9C;;GAEG;AACH,MAAM,MAAM,6BAA6B,GAAG,uBAAuB,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AAC9F,MAAM,MAAM,gCAAgC,GAAG,0BAA0B,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AACpG,MAAM,MAAM,kCAAkC,GAAG,4BAA4B,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AACxG,MAAM,MAAM,gDAAgD,GAAG,0CAA0C,GACvG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC"}