@btc-vision/transaction 1.0.61 → 1.0.63

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 (276) hide show
  1. package/.gitattributes +2 -2
  2. package/browser/_version.d.ts +1 -1
  3. package/browser/index.js +1 -1
  4. package/browser/transaction/TransactionFactory.d.ts +1 -0
  5. package/browser/transaction/builders/TapUnwarpTransaction.d.ts +40 -40
  6. package/browser/transaction/builders/UnwarpTransaction.d.ts +34 -34
  7. package/browser/utxo/UTXOManager.d.ts +7 -7
  8. package/build/_version.d.ts +1 -1
  9. package/build/_version.js +1 -1
  10. package/build/metadata/tokens.js +1 -1
  11. package/build/transaction/TransactionFactory.d.ts +1 -0
  12. package/build/transaction/TransactionFactory.js +4 -0
  13. package/gulpfile.js +152 -152
  14. package/package.json +1 -1
  15. package/src/_version.ts +1 -1
  16. package/src/consensus/Consensus.ts +36 -36
  17. package/src/consensus/ConsensusConfig.ts +39 -39
  18. package/src/crypto/crypto-browser.js +75 -75
  19. package/src/generators/AddressGenerator.ts +24 -24
  20. package/src/generators/Features.ts +5 -5
  21. package/src/generators/Generator.ts +75 -75
  22. package/src/generators/builders/CalldataGenerator.ts +148 -148
  23. package/src/generators/builders/DeploymentGenerator.ts +66 -66
  24. package/src/index.ts +4 -4
  25. package/src/keypair/AddressVerificator.ts +40 -40
  26. package/src/keypair/EcKeyPair.ts +282 -282
  27. package/src/keypair/Wallet.ts +97 -97
  28. package/src/keypair/interfaces/IWallet.ts +19 -19
  29. package/src/metadata/ContractBaseMetadata.ts +23 -23
  30. package/src/metadata/tokens.ts +1 -1
  31. package/src/network/NetworkInformation.ts +7 -7
  32. package/src/opnet.ts +84 -84
  33. package/src/transaction/TransactionFactory.ts +6 -0
  34. package/src/transaction/browser/BrowserSignerBase.ts +37 -37
  35. package/src/transaction/browser/Web3Provider.ts +46 -46
  36. package/src/transaction/browser/extensions/UnisatSigner.ts +218 -218
  37. package/src/transaction/browser/types/Unisat.ts +80 -80
  38. package/src/transaction/builders/FundingTransaction.ts +40 -40
  39. package/src/transaction/builders/InteractionTransaction.ts +38 -38
  40. package/src/transaction/builders/SharedInteractionTransaction.ts +368 -368
  41. package/src/transaction/builders/TransactionBuilder.ts +665 -665
  42. package/src/transaction/interfaces/Tap.ts +26 -26
  43. package/src/transaction/psbt/PSBTTypes.ts +3 -3
  44. package/src/transaction/shared/TweakedTransaction.ts +537 -537
  45. package/src/utxo/OPNetLimitedProvider.ts +244 -244
  46. package/src/utxo/interfaces/BroadcastResponse.ts +10 -10
  47. package/src/utxo/interfaces/IUTXO.ts +29 -29
  48. package/src/verification/TapscriptVerificator.ts +89 -89
  49. package/src/wbtc/Generate.ts +40 -40
  50. package/src/wbtc/UnwrapGeneration.ts +13 -13
  51. package/src/wbtc/WrappedGenerationParameters.ts +33 -33
  52. package/webpack.config.js +78 -78
  53. package/build/Utils.d.ts +0 -0
  54. package/build/Utils.js +0 -1
  55. package/build/consensus/metadata/RoswsellConsensus.d.ts +0 -2
  56. package/build/consensus/metadata/RoswsellConsensus.js +0 -4
  57. package/build/contracts/ContractMetadataManager.d.ts +0 -0
  58. package/build/contracts/ContractMetadataManager.js +0 -1
  59. package/build/generators/OPNetAddressGenerator.d.ts +0 -0
  60. package/build/generators/OPNetAddressGenerator.js +0 -1
  61. package/build/generators/builders/UnwrapGenerator.d.ts +0 -8
  62. package/build/generators/builders/UnwrapGenerator.js +0 -79
  63. package/build/keypair/interfaces/GeneratedWallet.d.ts +0 -5
  64. package/build/keypair/interfaces/GeneratedWallet.js +0 -1
  65. package/build/metadata/CommonContracts.d.ts +0 -6
  66. package/build/metadata/CommonContracts.js +0 -5
  67. package/build/metadata/ContractMetadataManager.d.ts +0 -1
  68. package/build/metadata/ContractMetadataManager.js +0 -9
  69. package/build/metadata/contracts/ContractBase.d.ts +0 -9
  70. package/build/metadata/contracts/ContractBase.js +0 -13
  71. package/build/metadata/contracts/ContractBaseMetadata.d.ts +0 -9
  72. package/build/metadata/contracts/ContractBaseMetadata.js +0 -13
  73. package/build/metadata/contracts/ContractMetadataManager.d.ts +0 -0
  74. package/build/metadata/contracts/ContractMetadataManager.js +0 -1
  75. package/build/network/NetworkConverter.d.ts +0 -0
  76. package/build/network/NetworkConverter.js +0 -14
  77. package/build/scripts/Regtest.d.ts +0 -2
  78. package/build/scripts/Regtest.js +0 -15
  79. package/build/scripts/test.d.ts +0 -1
  80. package/build/scripts/test.js +0 -74
  81. package/build/signer/Regtest.d.ts +0 -2
  82. package/build/signer/Regtest.js +0 -15
  83. package/build/tests/Regtest.d.ts +0 -3
  84. package/build/tests/Regtest.js +0 -29
  85. package/build/tests/adaptPSBT.d.ts +0 -1
  86. package/build/tests/adaptPSBT.js +0 -44
  87. package/build/tests/btc/send.d.ts +0 -1
  88. package/build/tests/btc/send.js +0 -35
  89. package/build/tests/btc/transfer.d.ts +0 -1
  90. package/build/tests/btc/transfer.js +0 -35
  91. package/build/tests/createPairReg.d.ts +0 -1
  92. package/build/tests/createPairReg.js +0 -73
  93. package/build/tests/deploy/deployMoto.d.ts +0 -4
  94. package/build/tests/deploy/deployMoto.js +0 -89
  95. package/build/tests/deploy/deployPool.d.ts +0 -1
  96. package/build/tests/deploy/deployPool.js +0 -5
  97. package/build/tests/deploy/deployStep1.d.ts +0 -1
  98. package/build/tests/deploy/deployStep1.js +0 -5
  99. package/build/tests/deploy/deployStep2.d.ts +0 -1
  100. package/build/tests/deploy/deployStep2.js +0 -5
  101. package/build/tests/deploy/deployStep3.d.ts +0 -1
  102. package/build/tests/deploy/deployStep3.js +0 -5
  103. package/build/tests/deploy.d.ts +0 -1
  104. package/build/tests/deploy.js +0 -41
  105. package/build/tests/deployMotoRegStep1.d.ts +0 -1
  106. package/build/tests/deployMotoRegStep1.js +0 -85
  107. package/build/tests/deployReg.d.ts +0 -1
  108. package/build/tests/deployReg.js +0 -85
  109. package/build/tests/factory/createPairReg.d.ts +0 -1
  110. package/build/tests/factory/createPairReg.js +0 -13
  111. package/build/tests/gen.d.ts +0 -1
  112. package/build/tests/gen.js +0 -19
  113. package/build/tests/interaction.d.ts +0 -5
  114. package/build/tests/interaction.js +0 -62
  115. package/build/tests/massWrapReg.d.ts +0 -1
  116. package/build/tests/massWrapReg.js +0 -105
  117. package/build/tests/mineReg.d.ts +0 -1
  118. package/build/tests/mineReg.js +0 -19
  119. package/build/tests/moto/airdropToken.d.ts +0 -1
  120. package/build/tests/moto/airdropToken.js +0 -21
  121. package/build/tests/moto/airdropTokens.d.ts +0 -1
  122. package/build/tests/moto/airdropTokens.js +0 -60
  123. package/build/tests/moto/allowance.d.ts +0 -1
  124. package/build/tests/moto/allowance.js +0 -6
  125. package/build/tests/moto/approve.d.ts +0 -1
  126. package/build/tests/moto/approve.js +0 -10
  127. package/build/tests/moto/approveWBTC.d.ts +0 -1
  128. package/build/tests/moto/approveWBTC.js +0 -12
  129. package/build/tests/moto/balanceOf.d.ts +0 -1
  130. package/build/tests/moto/balanceOf.js +0 -12
  131. package/build/tests/moto/transfer.d.ts +0 -1
  132. package/build/tests/moto/transfer.js +0 -16
  133. package/build/tests/motoswap/airdropToken.d.ts +0 -11
  134. package/build/tests/motoswap/airdropToken.js +0 -36
  135. package/build/tests/motoswap/deployMoto.d.ts +0 -4
  136. package/build/tests/motoswap/deployMoto.js +0 -89
  137. package/build/tests/motoswap/deployMotoRegStep1.d.ts +0 -1
  138. package/build/tests/motoswap/deployMotoRegStep1.js +0 -91
  139. package/build/tests/motoswap/deployMotoRegStep2.d.ts +0 -1
  140. package/build/tests/motoswap/deployMotoRegStep2.js +0 -91
  141. package/build/tests/motoswap/deployPool.d.ts +0 -1
  142. package/build/tests/motoswap/deployPool.js +0 -5
  143. package/build/tests/motoswap/deployStep1.d.ts +0 -1
  144. package/build/tests/motoswap/deployStep1.js +0 -5
  145. package/build/tests/motoswap/deployStep2.d.ts +0 -1
  146. package/build/tests/motoswap/deployStep2.js +0 -5
  147. package/build/tests/motoswap/deployStep3.d.ts +0 -1
  148. package/build/tests/motoswap/deployStep3.js +0 -5
  149. package/build/tests/motoswap/interaction.d.ts +0 -3
  150. package/build/tests/motoswap/interaction.js +0 -63
  151. package/build/tests/motoswap/routerAddLiquidity.d.ts +0 -11
  152. package/build/tests/motoswap/routerAddLiquidity.js +0 -35
  153. package/build/tests/motoswap-router/addLiquidity.d.ts +0 -11
  154. package/build/tests/motoswap-router/addLiquidity.js +0 -36
  155. package/build/tests/motoswap-router/deployMoto.d.ts +0 -4
  156. package/build/tests/motoswap-router/deployMoto.js +0 -89
  157. package/build/tests/motoswap-router/deployPool.d.ts +0 -1
  158. package/build/tests/motoswap-router/deployPool.js +0 -5
  159. package/build/tests/motoswap-router/deployStep1.d.ts +0 -1
  160. package/build/tests/motoswap-router/deployStep1.js +0 -5
  161. package/build/tests/motoswap-router/deployStep2.d.ts +0 -1
  162. package/build/tests/motoswap-router/deployStep2.js +0 -5
  163. package/build/tests/motoswap-router/deployStep3.d.ts +0 -1
  164. package/build/tests/motoswap-router/deployStep3.js +0 -5
  165. package/build/tests/motoswap-router/getAmountsOut.d.ts +0 -5
  166. package/build/tests/motoswap-router/getAmountsOut.js +0 -34
  167. package/build/tests/motoswap-router/routerAddLiquidity.d.ts +0 -11
  168. package/build/tests/motoswap-router/routerAddLiquidity.js +0 -35
  169. package/build/tests/motoswap-router/swap.d.ts +0 -8
  170. package/build/tests/motoswap-router/swap.js +0 -24
  171. package/build/tests/multisign.d.ts +0 -1
  172. package/build/tests/multisign.js +0 -47
  173. package/build/tests/multisign2.d.ts +0 -1
  174. package/build/tests/multisign2.js +0 -27
  175. package/build/tests/pool/DecodePoolAddress.d.ts +0 -6
  176. package/build/tests/pool/DecodePoolAddress.js +0 -12
  177. package/build/tests/pool/decodeReserves.d.ts +0 -5
  178. package/build/tests/pool/decodeReserves.js +0 -13
  179. package/build/tests/pool/reserves.d.ts +0 -1
  180. package/build/tests/pool/reserves.js +0 -18
  181. package/build/tests/shared/Utils.d.ts +0 -2
  182. package/build/tests/shared/Utils.js +0 -14
  183. package/build/tests/shared/interaction.d.ts +0 -7
  184. package/build/tests/shared/interaction.js +0 -85
  185. package/build/tests/shared/tokens.d.ts +0 -6
  186. package/build/tests/shared/tokens.js +0 -5
  187. package/build/tests/stakeReg.d.ts +0 -1
  188. package/build/tests/stakeReg.js +0 -73
  189. package/build/tests/stakedReg.d.ts +0 -1
  190. package/build/tests/stakedReg.js +0 -28
  191. package/build/tests/test.d.ts +0 -1
  192. package/build/tests/test.js +0 -51
  193. package/build/tests/test2.d.ts +0 -1
  194. package/build/tests/test2.js +0 -73
  195. package/build/tests/testReg.d.ts +0 -1
  196. package/build/tests/testReg.js +0 -91
  197. package/build/tests/tokens.d.ts +0 -6
  198. package/build/tests/tokens.js +0 -5
  199. package/build/tests/totalRewardReg.d.ts +0 -1
  200. package/build/tests/totalRewardReg.js +0 -28
  201. package/build/tests/transfer.d.ts +0 -1
  202. package/build/tests/transfer.js +0 -74
  203. package/build/tests/transferReg.d.ts +0 -1
  204. package/build/tests/transferReg.js +0 -74
  205. package/build/tests/unStakeReg.d.ts +0 -1
  206. package/build/tests/unStakeReg.js +0 -72
  207. package/build/tests/unwrapReg.d.ts +0 -1
  208. package/build/tests/unwrapReg.js +0 -61
  209. package/build/tests/unwrapReg2.d.ts +0 -1
  210. package/build/tests/unwrapReg2.js +0 -56
  211. package/build/tests/unwrapRegSegwit.d.ts +0 -1
  212. package/build/tests/unwrapRegSegwit.js +0 -83
  213. package/build/tests/wbtc/approve.d.ts +0 -1
  214. package/build/tests/wbtc/approve.js +0 -6
  215. package/build/tests/wbtc/approveWBTC.d.ts +0 -1
  216. package/build/tests/wbtc/approveWBTC.js +0 -12
  217. package/build/tests/wbtc/massWrapReg.d.ts +0 -1
  218. package/build/tests/wbtc/massWrapReg.js +0 -105
  219. package/build/tests/wbtc/transfer.d.ts +0 -1
  220. package/build/tests/wbtc/transfer.js +0 -16
  221. package/build/tests/wbtc/transferReg.d.ts +0 -1
  222. package/build/tests/wbtc/transferReg.js +0 -16
  223. package/build/tests/wbtc/unStakeReg.d.ts +0 -1
  224. package/build/tests/wbtc/unStakeReg.js +0 -72
  225. package/build/tests/wbtc/unwrapReg.d.ts +0 -1
  226. package/build/tests/wbtc/unwrapReg.js +0 -60
  227. package/build/tests/wbtc/unwrapRegSegwit.d.ts +0 -1
  228. package/build/tests/wbtc/unwrapRegSegwit.js +0 -83
  229. package/build/tests/wbtc/withdrawalRequestReg.d.ts +0 -1
  230. package/build/tests/wbtc/withdrawalRequestReg.js +0 -71
  231. package/build/tests/wbtc/wrapReg.d.ts +0 -1
  232. package/build/tests/wbtc/wrapReg.js +0 -65
  233. package/build/tests/wbtc/wrapTest.d.ts +0 -1
  234. package/build/tests/wbtc/wrapTest.js +0 -66
  235. package/build/tests/withdrawalRequestReg.d.ts +0 -1
  236. package/build/tests/withdrawalRequestReg.js +0 -71
  237. package/build/tests/wrap.d.ts +0 -1
  238. package/build/tests/wrap.js +0 -65
  239. package/build/tests/wrapReg.d.ts +0 -1
  240. package/build/tests/wrapReg.js +0 -68
  241. package/build/tests/wrapTest.d.ts +0 -1
  242. package/build/tests/wrapTest.js +0 -66
  243. package/build/tests/wrapTestg.d.ts +0 -1
  244. package/build/tests/wrapTestg.js +0 -66
  245. package/build/tests/writers/allowance.d.ts +0 -3
  246. package/build/tests/writers/allowance.js +0 -10
  247. package/build/tests/writers/approve.d.ts +0 -4
  248. package/build/tests/writers/approve.js +0 -11
  249. package/build/transaction/TransactionBuilder.d.ts +0 -60
  250. package/build/transaction/TransactionBuilder.js +0 -244
  251. package/build/transaction/browser/BrowserSigner.d.ts +0 -11
  252. package/build/transaction/browser/BrowserSigner.js +0 -10
  253. package/build/transaction/browser/extensions/Unisat.d.ts +0 -54
  254. package/build/transaction/browser/extensions/Unisat.js +0 -11
  255. package/build/transaction/builders/GenericTransaction.d.ts +0 -11
  256. package/build/transaction/builders/GenericTransaction.js +0 -23
  257. package/build/transaction/builders/TapUnwarpTransaction.d.ts +0 -37
  258. package/build/transaction/builders/TapUnwarpTransaction.js +0 -201
  259. package/build/transaction/builders/UnwarpSegwitTransaction.d.ts +0 -34
  260. package/build/transaction/builders/UnwarpSegwitTransaction.js +0 -184
  261. package/build/transaction/builders/UnwarpTransaction.d.ts +0 -35
  262. package/build/transaction/builders/UnwarpTransaction.js +0 -199
  263. package/build/transaction/interfaces/ITransactions.d.ts +0 -32
  264. package/build/transaction/interfaces/ITransactions.js +0 -1
  265. package/build/utxo/IUTXO.d.ts +0 -0
  266. package/build/utxo/IUTXO.js +0 -1
  267. package/build/utxo/OPNetUtils.d.ts +0 -7
  268. package/build/utxo/OPNetUtils.js +0 -47
  269. package/build/utxo/UTXOManager.d.ts +0 -7
  270. package/build/utxo/UTXOManager.js +0 -47
  271. package/build/wbtc/BroadcastResponse.d.ts +0 -0
  272. package/build/wbtc/BroadcastResponse.js +0 -1
  273. /package/build/generators/{features.d.ts → Features.d.ts} +0 -0
  274. /package/build/generators/{features.js → Features.js} +0 -0
  275. /package/build/generators/builders/{MultisignGenerator.d.ts → MultiSignGenerator.d.ts} +0 -0
  276. /package/build/generators/builders/{MultisignGenerator.js → MultiSignGenerator.js} +0 -0
@@ -1,54 +0,0 @@
1
- import { Address } from '@btc-vision/bsi-binary';
2
- export declare enum UnisatNetwork {
3
- testnet = "testnet",
4
- mainnet = "livenet",
5
- regtest = "regtest"
6
- }
7
- export interface Balance {
8
- readonly confirmed: number;
9
- readonly unconfirmed: number;
10
- readonly total: number;
11
- }
12
- export declare enum MessageType {
13
- ecdsa = "ecdsa",
14
- bip322 = "bip322-simple"
15
- }
16
- interface ToSignInputBase {
17
- readonly index: number;
18
- readonly sighashTypes?: number[];
19
- readonly disableTweakSigner?: boolean;
20
- }
21
- export interface ToSignInputPublicKey extends ToSignInputBase {
22
- readonly publicKey: string;
23
- }
24
- export interface ToSignInputAddress extends ToSignInputBase {
25
- readonly address: Address;
26
- }
27
- export type ToSignInput = ToSignInputPublicKey | ToSignInputAddress;
28
- export interface PsbtSignatureOptions {
29
- readonly autoFinalized?: boolean;
30
- readonly toSignInputs?: ToSignInput[];
31
- }
32
- export interface Unisat {
33
- sendBitcoin(toAddress: Address, satoshis: number, options: {
34
- feeRate: number;
35
- }): Promise<string>;
36
- requestAccounts(): Promise<string[]>;
37
- getNetwork(): Promise<UnisatNetwork>;
38
- getAccounts(): Promise<string[]>;
39
- switchNetwork(network: UnisatNetwork): Promise<void>;
40
- getPublicKey(): Promise<string>;
41
- getBalance(): Promise<Balance>;
42
- signMessage(message: string, type?: MessageType): Promise<string>;
43
- pushTx(options: {
44
- rawtx: string;
45
- }): Promise<string>;
46
- signPsbt(psbtHex: string, psbtOptions: PsbtSignatureOptions): Promise<string>;
47
- signPsbts(psbtHex: string[], psbtOptions: PsbtSignatureOptions): Promise<string[]>;
48
- pushPsbt(psbtHex: string): Promise<string>;
49
- on(event: 'accountsChanged', listener: (accounts: string[]) => void): void;
50
- on(event: 'networkChanged', listener: (network: UnisatNetwork) => void): void;
51
- removeListener(event: 'accountsChanged', listener: (accounts: string[]) => void): void;
52
- removeListener(event: 'networkChanged', listener: (network: UnisatNetwork) => void): void;
53
- }
54
- export {};
@@ -1,11 +0,0 @@
1
- export var UnisatNetwork;
2
- (function (UnisatNetwork) {
3
- UnisatNetwork["testnet"] = "testnet";
4
- UnisatNetwork["mainnet"] = "livenet";
5
- UnisatNetwork["regtest"] = "regtest";
6
- })(UnisatNetwork || (UnisatNetwork = {}));
7
- export var MessageType;
8
- (function (MessageType) {
9
- MessageType["ecdsa"] = "ecdsa";
10
- MessageType["bip322"] = "bip322-simple";
11
- })(MessageType || (MessageType = {}));
@@ -1,11 +0,0 @@
1
- import { TransactionBuilder } from './TransactionBuilder.js';
2
- import { TransactionType } from '../enums/TransactionType.js';
3
- import { IFundingTransactionParameters } from '../interfaces/ITransactionParameters.js';
4
- import { Signer } from 'bitcoinjs-lib';
5
- export declare class FundingTransaction extends TransactionBuilder<TransactionType.FUNDING> {
6
- readonly type: TransactionType.FUNDING;
7
- protected childTransactionRequiredFees: bigint;
8
- constructor(parameters: IFundingTransactionParameters);
9
- protected buildTransaction(): void;
10
- protected getSignerKey(): Signer;
11
- }
@@ -1,23 +0,0 @@
1
- import { TransactionBuilder } from './TransactionBuilder.js';
2
- import { TransactionType } from '../enums/TransactionType.js';
3
- export class FundingTransaction extends TransactionBuilder {
4
- type = TransactionType.FUNDING;
5
- childTransactionRequiredFees;
6
- constructor(parameters) {
7
- super(parameters);
8
- this.childTransactionRequiredFees = parameters.childTransactionRequiredFees;
9
- this.internalInit();
10
- }
11
- buildTransaction() {
12
- this.addInputsFromUTXO();
13
- const amountSpent = this.getTransactionOPNetFee() + this.childTransactionRequiredFees;
14
- this.setFeeOutput({
15
- value: Number(amountSpent),
16
- address: this.to,
17
- });
18
- this.addRefundOutput(amountSpent);
19
- }
20
- getSignerKey() {
21
- return this.signer;
22
- }
23
- }
@@ -1,37 +0,0 @@
1
- /// <reference types="node" />
2
- import { Taptree } from 'bitcoinjs-lib/src/types.js';
3
- import { TransactionType } from '../enums/TransactionType.js';
4
- import { IUnwrapParameters } from '../interfaces/ITransactionParameters.js';
5
- import { SharedInteractionTransaction } from './SharedInteractionTransaction.js';
6
- import bitcoin, { Payment, Psbt } from 'bitcoinjs-lib';
7
- import { VaultUTXOs } from '../processor/PsbtTransaction.js';
8
- import { PsbtInput } from 'bip174/src/lib/interfaces.js';
9
- export declare class TapUnwrapTransaction extends SharedInteractionTransaction<TransactionType.WBTC_UNWRAP> {
10
- private static readonly UNWRAP_SELECTOR;
11
- type: TransactionType.WBTC_UNWRAP;
12
- readonly amount: bigint;
13
- protected readonly compiledTargetScript: Buffer;
14
- protected readonly scriptTree: Taptree;
15
- protected sighashTypes: number[];
16
- protected readonly contractSecret: Buffer;
17
- protected readonly vaultUTXOs: VaultUTXOs[];
18
- private readonly wbtc;
19
- private readonly calculatedSignHash;
20
- constructor(parameters: IUnwrapParameters);
21
- static generateBurnCalldata(amount: bigint): Buffer;
22
- signPSBT(): Psbt;
23
- mergeVaults(input: VaultUTXOs[]): void;
24
- protected internalPubKeyToXOnly(): Buffer;
25
- protected generateTapDataForInput(pubkeys: Buffer[], minimumSignatures: number): {
26
- internalPubkey: Buffer;
27
- network: bitcoin.Network;
28
- scriptTree: Taptree;
29
- redeem: Payment;
30
- };
31
- protected getScriptSolution(input: PsbtInput): Buffer[];
32
- protected internalBuildTransaction(transaction: Psbt): boolean;
33
- private addVaultUTXO;
34
- private addVaultInputs;
35
- private calculateOutputLeftAmountFromVaults;
36
- private getVaultTotalOutputAmount;
37
- }
@@ -1,201 +0,0 @@
1
- import { TransactionType } from '../enums/TransactionType.js';
2
- import { SharedInteractionTransaction } from './SharedInteractionTransaction.js';
3
- import { TransactionBuilder } from './TransactionBuilder.js';
4
- import { ABICoder, BinaryWriter } from '@btc-vision/bsi-binary';
5
- import { wBTC } from '../../metadata/contracts/wBTC.js';
6
- import { payments } from 'bitcoinjs-lib';
7
- import { EcKeyPair } from '../../keypair/EcKeyPair.js';
8
- import { PsbtTransaction } from '../processor/PsbtTransaction.js';
9
- import { MultiSignGenerator } from '../../generators/builders/MultiSignGenerator.js';
10
- import { MultiSignTransaction } from './MultiSignTransaction.js';
11
- import { toXOnly } from 'bitcoinjs-lib/src/psbt/bip371.js';
12
- import { CalldataGenerator } from '../../generators/builders/CalldataGenerator.js';
13
- const abiCoder = new ABICoder();
14
- const numsPoint = Buffer.from('50929b74c1a04954b78b4b6035e97a5e078a5a0f28ec96d547bfee9ace803ac0', 'hex');
15
- export class TapUnwrapTransaction extends SharedInteractionTransaction {
16
- static UNWRAP_SELECTOR = Number('0x' + abiCoder.encodeSelector('burn'));
17
- type = TransactionType.WBTC_UNWRAP;
18
- amount;
19
- compiledTargetScript;
20
- scriptTree;
21
- sighashTypes = [];
22
- contractSecret;
23
- vaultUTXOs;
24
- wbtc;
25
- calculatedSignHash = PsbtTransaction.calculateSignHash(this.sighashTypes);
26
- constructor(parameters) {
27
- if (parameters.amount < TransactionBuilder.MINIMUM_DUST) {
28
- throw new Error('Amount is below dust limit');
29
- }
30
- parameters.disableAutoRefund = true;
31
- parameters.calldata = TapUnwrapTransaction.generateBurnCalldata(parameters.amount);
32
- super(parameters);
33
- this.wbtc = new wBTC(parameters.network);
34
- this.to = this.wbtc.getAddress();
35
- this.vaultUTXOs = parameters.unwrapUTXOs;
36
- this.amount = parameters.amount;
37
- this.contractSecret = this.generateSecret();
38
- this.calldataGenerator = new CalldataGenerator(toXOnly(this.signer.publicKey), this.scriptSignerXOnlyPubKey(), this.network);
39
- this.compiledTargetScript = this.calldataGenerator.compile(this.calldata, this.contractSecret);
40
- this.scriptTree = this.getScriptTree();
41
- this.internalInit();
42
- }
43
- static generateBurnCalldata(amount) {
44
- if (!amount)
45
- throw new Error('Amount is required');
46
- const bufWriter = new BinaryWriter();
47
- bufWriter.writeSelector(TapUnwrapTransaction.UNWRAP_SELECTOR);
48
- bufWriter.writeU256(amount);
49
- return Buffer.from(bufWriter.getBuffer());
50
- }
51
- signPSBT() {
52
- if (this.to && !EcKeyPair.verifyContractAddress(this.to, this.network)) {
53
- throw new Error('Invalid contract address. The contract address must be a taproot address.');
54
- }
55
- if (!this.vaultUTXOs.length) {
56
- throw new Error('No vault UTXOs provided');
57
- }
58
- this.buildTransaction();
59
- this.ignoreSignatureError();
60
- this.mergeVaults(this.vaultUTXOs);
61
- const builtTx = this.internalBuildTransaction(this.transaction);
62
- if (builtTx) {
63
- return this.transaction;
64
- }
65
- throw new Error('Could not sign transaction');
66
- }
67
- mergeVaults(input) {
68
- const firstVault = input[0];
69
- if (!firstVault) {
70
- throw new Error('No vaults provided');
71
- }
72
- const outputLeftAmount = this.calculateOutputLeftAmountFromVaults(input);
73
- if (outputLeftAmount < 0) {
74
- throw new Error(`Output left amount is negative ${outputLeftAmount} for vault ${firstVault.vault}`);
75
- }
76
- this.addOutput({
77
- address: firstVault.vault,
78
- value: Number(outputLeftAmount),
79
- });
80
- this.addOutput({
81
- address: this.from,
82
- value: Number(this.amount),
83
- });
84
- for (const vault of input) {
85
- this.addVaultInputs(vault);
86
- }
87
- }
88
- internalPubKeyToXOnly() {
89
- return toXOnly(numsPoint);
90
- }
91
- generateTapDataForInput(pubkeys, minimumSignatures) {
92
- const compiledTargetScript = MultiSignGenerator.compile(pubkeys, minimumSignatures);
93
- const scriptTree = [
94
- {
95
- output: compiledTargetScript,
96
- version: 192,
97
- },
98
- {
99
- output: MultiSignTransaction.LOCK_LEAF_SCRIPT,
100
- version: 192,
101
- },
102
- ];
103
- const redeem = {
104
- output: compiledTargetScript,
105
- redeemVersion: 192,
106
- };
107
- return {
108
- internalPubkey: this.internalPubKeyToXOnly(),
109
- network: this.network,
110
- scriptTree: scriptTree,
111
- redeem: redeem,
112
- };
113
- }
114
- getScriptSolution(input) {
115
- if (!input.tapScriptSig) {
116
- throw new Error('Tap script signature is required');
117
- }
118
- return [
119
- this.contractSecret,
120
- toXOnly(this.signer.publicKey),
121
- input.tapScriptSig[0].signature,
122
- input.tapScriptSig[1].signature,
123
- ];
124
- }
125
- internalBuildTransaction(transaction) {
126
- if (transaction.data.inputs.length === 0) {
127
- const inputs = this.getInputs();
128
- const outputs = this.getOutputs();
129
- transaction.setMaximumFeeRate(this._maximumFeeRate);
130
- transaction.addInputs(inputs);
131
- for (let i = 0; i < this.updateInputs.length; i++) {
132
- transaction.updateInput(i, this.updateInputs[i]);
133
- }
134
- transaction.addOutputs(outputs);
135
- }
136
- try {
137
- this.signInput(transaction, transaction.data.inputs[0], 0, this.scriptSigner);
138
- this.signInput(transaction, transaction.data.inputs[0], 0);
139
- try {
140
- transaction.finalizeInput(0, this.customFinalizer);
141
- }
142
- catch (e) {
143
- console.log(e);
144
- }
145
- if (this.finalized) {
146
- this.transactionFee = BigInt(transaction.getFee());
147
- }
148
- return true;
149
- }
150
- catch (e) {
151
- const err = e;
152
- this.error(`[internalBuildTransaction] Something went wrong while getting building the transaction: ${err.stack}`);
153
- }
154
- return false;
155
- }
156
- addVaultUTXO(utxo, pubkeys, minimumSignatures) {
157
- const tapInput = this.generateTapDataForInput(pubkeys, minimumSignatures);
158
- const tap = payments.p2tr(tapInput);
159
- if (!tap.witness)
160
- throw new Error('Failed to generate taproot witness');
161
- this.disableRBF();
162
- const controlBlock = tap.witness[tap.witness.length - 1];
163
- const input = {
164
- hash: utxo.hash,
165
- index: utxo.outputIndex,
166
- witnessUtxo: {
167
- script: Buffer.from(utxo.output, 'base64'),
168
- value: Number(utxo.value),
169
- },
170
- tapInternalKey: tapInput.internalPubkey,
171
- sequence: this.sequence,
172
- tapLeafScript: [
173
- {
174
- leafVersion: tapInput.redeem.redeemVersion,
175
- script: tapInput.redeem.output,
176
- controlBlock: controlBlock,
177
- },
178
- ],
179
- };
180
- this.addInput(input);
181
- }
182
- addVaultInputs(vault) {
183
- const pubKeys = vault.publicKeys.map((key) => Buffer.from(key, 'base64'));
184
- for (const utxo of vault.utxos) {
185
- this.addVaultUTXO(utxo, pubKeys, vault.minimum);
186
- }
187
- }
188
- calculateOutputLeftAmountFromVaults(vaults) {
189
- const total = this.getVaultTotalOutputAmount(vaults);
190
- return total - this.amount;
191
- }
192
- getVaultTotalOutputAmount(vaults) {
193
- let total = BigInt(0);
194
- for (const vault of vaults) {
195
- for (const utxo of vault.utxos) {
196
- total += BigInt(utxo.value);
197
- }
198
- }
199
- return total;
200
- }
201
- }
@@ -1,34 +0,0 @@
1
- /// <reference types="node" />
2
- import { Taptree } from 'bitcoinjs-lib/src/types.js';
3
- import { TransactionType } from '../enums/TransactionType.js';
4
- import { IUnwrapParameters } from '../interfaces/ITransactionParameters.js';
5
- import { SharedInteractionTransaction } from './SharedInteractionTransaction.js';
6
- import { Psbt } from 'bitcoinjs-lib';
7
- import { VaultUTXOs } from '../processor/PsbtTransaction.js';
8
- export declare class UnwrapTransaction extends SharedInteractionTransaction<TransactionType.WBTC_UNWRAP> {
9
- static readonly MINIMUM_CONSOLIDATION_AMOUNT: bigint;
10
- private static readonly UNWRAP_SELECTOR;
11
- type: TransactionType.WBTC_UNWRAP;
12
- readonly amount: bigint;
13
- protected readonly compiledTargetScript: Buffer;
14
- protected readonly scriptTree: Taptree;
15
- protected sighashTypes: number[];
16
- protected readonly contractSecret: Buffer;
17
- protected readonly vaultUTXOs: VaultUTXOs[];
18
- private readonly wbtc;
19
- private readonly calculatedSignHash;
20
- constructor(parameters: IUnwrapParameters);
21
- static generateBurnCalldata(amount: bigint): Buffer;
22
- signPSBT(): Psbt;
23
- mergeVaults(input: VaultUTXOs[]): void;
24
- protected internalBuildTransaction(transaction: Psbt): boolean;
25
- protected generateMultiSignRedeemScript(publicKeys: string[], minimum: number): {
26
- witnessUtxo: Buffer;
27
- redeemScript: Buffer;
28
- witnessScript: Buffer;
29
- };
30
- private addVaultUTXO;
31
- private addVaultInputs;
32
- private calculateOutputLeftAmountFromVaults;
33
- private getVaultTotalOutputAmount;
34
- }
@@ -1,184 +0,0 @@
1
- import { TransactionType } from '../enums/TransactionType.js';
2
- import { SharedInteractionTransaction } from './SharedInteractionTransaction.js';
3
- import { TransactionBuilder } from './TransactionBuilder.js';
4
- import { ABICoder, BinaryWriter } from '@btc-vision/bsi-binary';
5
- import { wBTC } from '../../metadata/contracts/wBTC.js';
6
- import { payments } from 'bitcoinjs-lib';
7
- import { EcKeyPair } from '../../keypair/EcKeyPair.js';
8
- import { PsbtTransaction } from '../processor/PsbtTransaction.js';
9
- const abiCoder = new ABICoder();
10
- export class UnwrapTransaction extends SharedInteractionTransaction {
11
- static MINIMUM_CONSOLIDATION_AMOUNT = 200000n;
12
- static UNWRAP_SELECTOR = Number('0x' + abiCoder.encodeSelector('burn'));
13
- type = TransactionType.WBTC_UNWRAP;
14
- amount;
15
- compiledTargetScript;
16
- scriptTree;
17
- sighashTypes = [];
18
- contractSecret;
19
- vaultUTXOs;
20
- wbtc;
21
- calculatedSignHash = PsbtTransaction.calculateSignHash(this.sighashTypes);
22
- constructor(parameters) {
23
- if (parameters.amount < TransactionBuilder.MINIMUM_DUST) {
24
- throw new Error('Amount is below dust limit');
25
- }
26
- parameters.disableAutoRefund = true;
27
- parameters.calldata = UnwrapTransaction.generateBurnCalldata(parameters.amount);
28
- super(parameters);
29
- this.wbtc = new wBTC(parameters.network);
30
- this.to = this.wbtc.getAddress();
31
- this.vaultUTXOs = parameters.unwrapUTXOs;
32
- this.amount = parameters.amount;
33
- this.contractSecret = this.generateSecret();
34
- this.compiledTargetScript = this.calldataGenerator.compile(this.calldata, this.contractSecret);
35
- this.scriptTree = this.getScriptTree();
36
- this.internalInit();
37
- }
38
- static generateBurnCalldata(amount) {
39
- if (!amount)
40
- throw new Error('Amount is required');
41
- const bufWriter = new BinaryWriter();
42
- bufWriter.writeSelector(UnwrapTransaction.UNWRAP_SELECTOR);
43
- bufWriter.writeU256(amount);
44
- return Buffer.from(bufWriter.getBuffer());
45
- }
46
- signPSBT() {
47
- if (this.to && !EcKeyPair.verifyContractAddress(this.to, this.network)) {
48
- throw new Error('Invalid contract address. The contract address must be a taproot address.');
49
- }
50
- if (!this.vaultUTXOs.length) {
51
- throw new Error('No vault UTXOs provided');
52
- }
53
- if (this.signed)
54
- throw new Error('Transaction is already signed');
55
- this.signed = true;
56
- this.buildTransaction();
57
- this.ignoreSignatureError();
58
- this.mergeVaults(this.vaultUTXOs);
59
- const builtTx = this.internalBuildTransaction(this.transaction);
60
- if (builtTx) {
61
- return this.transaction;
62
- }
63
- throw new Error('Could not sign transaction');
64
- }
65
- mergeVaults(input) {
66
- const firstVault = input[0];
67
- if (!firstVault) {
68
- throw new Error('No vaults provided');
69
- }
70
- const total = this.getVaultTotalOutputAmount(input);
71
- if (total < this.amount) {
72
- throw new Error(`Total vault amount (${total} sat) is less than the amount to unwrap (${this.amount} sat)`);
73
- }
74
- const outputLeftAmount = this.calculateOutputLeftAmountFromVaults(input);
75
- if (outputLeftAmount < UnwrapTransaction.MINIMUM_CONSOLIDATION_AMOUNT) {
76
- throw new Error(`Output left amount is below minimum consolidation (${UnwrapTransaction.MINIMUM_CONSOLIDATION_AMOUNT} sat) amount ${outputLeftAmount} for vault ${firstVault.vault}`);
77
- }
78
- this.addOutput({
79
- address: firstVault.vault,
80
- value: Number(outputLeftAmount),
81
- });
82
- this.addOutput({
83
- address: this.from,
84
- value: Number(this.amount),
85
- });
86
- for (const vault of input) {
87
- this.addVaultInputs(vault);
88
- }
89
- }
90
- internalBuildTransaction(transaction) {
91
- if (transaction.data.inputs.length === 0) {
92
- const inputs = this.getInputs();
93
- const outputs = this.getOutputs();
94
- transaction.setMaximumFeeRate(this._maximumFeeRate);
95
- transaction.addInputs(inputs);
96
- for (let i = 0; i < this.updateInputs.length; i++) {
97
- transaction.updateInput(i, this.updateInputs[i]);
98
- }
99
- transaction.addOutputs(outputs);
100
- }
101
- try {
102
- this.signInputs(transaction);
103
- if (this.finalized) {
104
- this.transactionFee = BigInt(transaction.getFee());
105
- }
106
- return true;
107
- }
108
- catch (e) {
109
- const err = e;
110
- this.error(`[internalBuildTransaction] Something went wrong while getting building the transaction: ${err.stack}`);
111
- }
112
- return false;
113
- }
114
- generateMultiSignRedeemScript(publicKeys, minimum) {
115
- const p2ms = payments.p2ms({
116
- m: minimum,
117
- pubkeys: publicKeys.map((key) => Buffer.from(key, 'base64')),
118
- network: this.network,
119
- });
120
- const p2wsh = payments.p2wsh({
121
- redeem: p2ms,
122
- network: this.network,
123
- });
124
- const witnessUtxo = p2wsh.output;
125
- const redeemScript = p2wsh.redeem?.output;
126
- const witnessScript = p2ms.output;
127
- if (!witnessUtxo || !redeemScript || !witnessScript) {
128
- throw new Error('Failed to generate redeem script');
129
- }
130
- return {
131
- witnessUtxo,
132
- redeemScript,
133
- witnessScript,
134
- };
135
- }
136
- addVaultUTXO(utxo, witness) {
137
- const input = {
138
- hash: utxo.hash,
139
- index: utxo.outputIndex,
140
- witnessUtxo: {
141
- script: Buffer.from(utxo.output, 'base64'),
142
- value: Number(utxo.value),
143
- },
144
- witnessScript: witness.witnessScript,
145
- sequence: this.sequence,
146
- };
147
- if (this.calculatedSignHash) {
148
- input.sighashType = this.calculatedSignHash;
149
- }
150
- this.addInput(input);
151
- }
152
- addVaultInputs(vault, firstSigner = this.signer) {
153
- const p2wshOutput = this.generateMultiSignRedeemScript(vault.publicKeys, vault.minimum);
154
- for (const utxo of vault.utxos) {
155
- const inputIndex = this.transaction.inputCount;
156
- this.addVaultUTXO(utxo, p2wshOutput);
157
- if (firstSigner) {
158
- this.log(`Signing input ${inputIndex} with ${firstSigner.publicKey.toString('hex')}`);
159
- try {
160
- this.signInput(this.transaction, this.transaction.data.inputs[inputIndex], inputIndex, this.signer);
161
- this.log(`Signed input ${inputIndex} with ${firstSigner.publicKey.toString('hex')}`);
162
- }
163
- catch (e) {
164
- if (!this.ignoreSignatureErrors) {
165
- this.warn(`Failed to sign input ${inputIndex} with ${firstSigner.publicKey.toString('hex')} ${e.message}`);
166
- }
167
- }
168
- }
169
- }
170
- }
171
- calculateOutputLeftAmountFromVaults(vaults) {
172
- const total = this.getVaultTotalOutputAmount(vaults);
173
- return total - this.amount;
174
- }
175
- getVaultTotalOutputAmount(vaults) {
176
- let total = BigInt(0);
177
- for (const vault of vaults) {
178
- for (const utxo of vault.utxos) {
179
- total += BigInt(utxo.value);
180
- }
181
- }
182
- return total;
183
- }
184
- }
@@ -1,35 +0,0 @@
1
- /// <reference types="node" />
2
- import { Taptree } from 'bitcoinjs-lib/src/types.js';
3
- import { TransactionType } from '../enums/TransactionType.js';
4
- import { IUnwrapParameters } from '../interfaces/ITransactionParameters.js';
5
- import { SharedInteractionTransaction } from './SharedInteractionTransaction.js';
6
- import { Psbt } from 'bitcoinjs-lib';
7
- import { VaultUTXOs } from '../processor/PsbtTransaction.js';
8
- export declare class UnwrapTransaction extends SharedInteractionTransaction<TransactionType.WBTC_UNWRAP> {
9
- static readonly MINIMUM_CONSOLIDATION_AMOUNT: bigint;
10
- private static readonly UNWRAP_SELECTOR;
11
- type: TransactionType.WBTC_UNWRAP;
12
- readonly amount: bigint;
13
- protected readonly compiledTargetScript: Buffer;
14
- protected readonly scriptTree: Taptree;
15
- protected sighashTypes: number[];
16
- protected readonly contractSecret: Buffer;
17
- protected readonly vaultUTXOs: VaultUTXOs[];
18
- private readonly wbtc;
19
- private readonly calculatedSignHash;
20
- constructor(parameters: IUnwrapParameters);
21
- static generateBurnCalldata(amount: bigint): Buffer;
22
- signPSBT(): Psbt;
23
- mergeVaults(input: VaultUTXOs[]): void;
24
- estimateVaultFees(feeRate: bigint, numInputs: bigint, numOutputs: bigint, numSignatures: bigint, numPubkeys: bigint): bigint;
25
- protected internalBuildTransaction(transaction: Psbt): boolean;
26
- protected generateMultiSignRedeemScript(publicKeys: string[], minimum: number): {
27
- witnessUtxo: Buffer;
28
- redeemScript: Buffer;
29
- witnessScript: Buffer;
30
- };
31
- private addVaultUTXO;
32
- private addVaultInputs;
33
- private calculateOutputLeftAmountFromVaults;
34
- private getVaultTotalOutputAmount;
35
- }