@teleportdao/bitcoin 1.6.0 → 1.7.0

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 (129) hide show
  1. package/.tmp/psbt/sign-transaction.ts +9 -3
  2. package/dist/bitcoin-interface-ordinal.d.ts +104 -0
  3. package/dist/bitcoin-interface-ordinal.d.ts.map +1 -0
  4. package/dist/bitcoin-interface-ordinal.js +113 -0
  5. package/dist/bitcoin-interface-ordinal.js.map +1 -0
  6. package/dist/bitcoin-interface-teleswap.d.ts +148 -0
  7. package/dist/bitcoin-interface-teleswap.d.ts.map +1 -0
  8. package/dist/bitcoin-interface-teleswap.js +179 -0
  9. package/dist/bitcoin-interface-teleswap.js.map +1 -0
  10. package/dist/bitcoin-interface.d.ts +45 -333
  11. package/dist/bitcoin-interface.d.ts.map +1 -1
  12. package/dist/bitcoin-interface.js +68 -202
  13. package/dist/bitcoin-interface.js.map +1 -1
  14. package/dist/bitcoin-utils.d.ts +6 -53
  15. package/dist/bitcoin-utils.d.ts.map +1 -1
  16. package/dist/bitcoin-utils.js +4 -4
  17. package/dist/bitcoin-utils.js.map +1 -1
  18. package/dist/{bitcoin-base.d.ts → bitcoin-wallet-base.d.ts} +8 -8
  19. package/dist/bitcoin-wallet-base.d.ts.map +1 -0
  20. package/dist/{bitcoin-base.js → bitcoin-wallet-base.js} +12 -11
  21. package/dist/bitcoin-wallet-base.js.map +1 -0
  22. package/dist/helper/brc20-helper.d.ts +43 -0
  23. package/dist/helper/brc20-helper.d.ts.map +1 -0
  24. package/dist/helper/brc20-helper.js +129 -0
  25. package/dist/helper/brc20-helper.js.map +1 -0
  26. package/dist/helper/index.d.ts +4 -0
  27. package/dist/helper/index.d.ts.map +1 -0
  28. package/dist/helper/index.js +30 -0
  29. package/dist/helper/index.js.map +1 -0
  30. package/dist/helper/ordinal-helper.d.ts +13 -0
  31. package/dist/helper/ordinal-helper.d.ts.map +1 -0
  32. package/dist/helper/ordinal-helper.js +127 -0
  33. package/dist/helper/ordinal-helper.js.map +1 -0
  34. package/dist/helper/teleswap-helper.d.ts +84 -0
  35. package/dist/helper/teleswap-helper.d.ts.map +1 -0
  36. package/dist/helper/teleswap-helper.js +181 -0
  37. package/dist/helper/teleswap-helper.js.map +1 -0
  38. package/dist/index.d.ts +10 -3
  39. package/dist/index.d.ts.map +1 -1
  40. package/dist/index.js +10 -3
  41. package/dist/index.js.map +1 -1
  42. package/dist/ordinal-wallet.d.ts +536 -0
  43. package/dist/ordinal-wallet.d.ts.map +1 -0
  44. package/dist/ordinal-wallet.js +446 -0
  45. package/dist/ordinal-wallet.js.map +1 -0
  46. package/dist/sign/index.d.ts +2 -0
  47. package/dist/sign/index.d.ts.map +1 -0
  48. package/dist/sign/index.js +9 -0
  49. package/dist/sign/index.js.map +1 -0
  50. package/dist/sign/sign-transaction.d.ts +2 -1
  51. package/dist/sign/sign-transaction.d.ts.map +1 -1
  52. package/dist/sign/sign-transaction.js +14 -33
  53. package/dist/sign/sign-transaction.js.map +1 -1
  54. package/dist/teleswap-wallet.d.ts +54 -0
  55. package/dist/teleswap-wallet.d.ts.map +1 -0
  56. package/dist/teleswap-wallet.js +87 -0
  57. package/dist/teleswap-wallet.js.map +1 -0
  58. package/dist/transaction-builder/bitcoin-transaction-builder.d.ts +3 -21
  59. package/dist/transaction-builder/bitcoin-transaction-builder.d.ts.map +1 -1
  60. package/dist/transaction-builder/bitcoin-transaction-builder.js +7 -9
  61. package/dist/transaction-builder/bitcoin-transaction-builder.js.map +1 -1
  62. package/dist/transaction-builder/index.d.ts +4 -0
  63. package/dist/transaction-builder/index.d.ts.map +1 -0
  64. package/dist/transaction-builder/index.js +20 -0
  65. package/dist/transaction-builder/index.js.map +1 -0
  66. package/dist/transaction-builder/ordinal-transaction-builder.d.ts +63 -0
  67. package/dist/transaction-builder/ordinal-transaction-builder.d.ts.map +1 -0
  68. package/dist/transaction-builder/ordinal-transaction-builder.js +131 -0
  69. package/dist/transaction-builder/ordinal-transaction-builder.js.map +1 -0
  70. package/dist/transaction-builder/transaction-builder.d.ts +32 -5
  71. package/dist/transaction-builder/transaction-builder.d.ts.map +1 -1
  72. package/dist/transaction-builder/transaction-builder.js +65 -49
  73. package/dist/transaction-builder/transaction-builder.js.map +1 -1
  74. package/dist/type.d.ts +43 -0
  75. package/dist/type.d.ts.map +1 -0
  76. package/dist/type.js +3 -0
  77. package/dist/type.js.map +1 -0
  78. package/dist/utils/tools.d.ts +4 -4
  79. package/dist/utils/tools.d.ts.map +1 -1
  80. package/dist/utils/tools.js +8 -5
  81. package/dist/utils/tools.js.map +1 -1
  82. package/package.json +6 -8
  83. package/src/bitcoin-interface-ordinal.ts +128 -0
  84. package/src/bitcoin-interface-teleswap.ts +255 -0
  85. package/src/bitcoin-interface.ts +99 -303
  86. package/src/bitcoin-utils.ts +6 -32
  87. package/src/{bitcoin-base.ts → bitcoin-wallet-base.ts} +20 -14
  88. package/src/helper/brc20-helper.ts +181 -0
  89. package/src/helper/index.ts +3 -0
  90. package/src/helper/ordinal-helper.ts +118 -0
  91. package/src/helper/teleswap-helper.ts +300 -0
  92. package/src/index.ts +13 -3
  93. package/src/ordinal-wallet.ts +738 -0
  94. package/src/sign/index.ts +1 -0
  95. package/src/sign/sign-transaction.ts +20 -9
  96. package/src/teleswap-wallet.ts +155 -0
  97. package/src/transaction-builder/bitcoin-transaction-builder.ts +8 -25
  98. package/src/transaction-builder/index.ts +3 -0
  99. package/src/transaction-builder/ordinal-transaction-builder.ts +147 -0
  100. package/src/transaction-builder/transaction-builder.ts +117 -60
  101. package/src/type.ts +43 -0
  102. package/src/utils/tools.ts +17 -11
  103. package/tsconfig.json +1 -2
  104. package/dist/bitcoin-base.d.ts.map +0 -1
  105. package/dist/bitcoin-base.js.map +0 -1
  106. package/dist/bitcoin-utils-2.d.ts +0 -2
  107. package/dist/bitcoin-utils-2.d.ts.map +0 -1
  108. package/dist/bitcoin-utils-2.js +0 -13
  109. package/dist/bitcoin-utils-2.js.map +0 -1
  110. package/dist/bundle.js +0 -17
  111. package/dist/helper/burn-request-helper.d.ts +0 -7
  112. package/dist/helper/burn-request-helper.d.ts.map +0 -1
  113. package/dist/helper/burn-request-helper.js +0 -26
  114. package/dist/helper/burn-request-helper.js.map +0 -1
  115. package/dist/helper/teleport-request-helper.d.ts +0 -47
  116. package/dist/helper/teleport-request-helper.d.ts.map +0 -1
  117. package/dist/helper/teleport-request-helper.js +0 -146
  118. package/dist/helper/teleport-request-helper.js.map +0 -1
  119. package/dist/mempool-space.d.ts +0 -69
  120. package/dist/mempool-space.d.ts.map +0 -1
  121. package/dist/mempool-space.js +0 -266
  122. package/dist/mempool-space.js.map +0 -1
  123. package/dist/teleport-dao-payments.d.ts +0 -76
  124. package/dist/teleport-dao-payments.d.ts.map +0 -1
  125. package/dist/teleport-dao-payments.js +0 -217
  126. package/dist/teleport-dao-payments.js.map +0 -1
  127. package/src/helper/burn-request-helper.js +0 -27
  128. package/src/helper/teleport-request-helper.js +0 -181
  129. package/src/teleport-dao-payments.ts +0 -347
@@ -0,0 +1,446 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ const bitcoin_wallet_base_1 = require("./bitcoin-wallet-base");
16
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
17
+ const transaction_builder_1 = require("./transaction-builder");
18
+ const sign_transaction_1 = __importDefault(require("./sign/sign-transaction"));
19
+ const bitcoin_interface_ordinal_1 = require("./bitcoin-interface-ordinal");
20
+ const brc20_helper_1 = require("./helper/brc20-helper");
21
+ const tools_1 = require("./utils/tools");
22
+ class OrdinalWallet extends bitcoin_wallet_base_1.BitcoinBaseWallet {
23
+ constructor(networkName, uniSatToken, connectionInfo = {
24
+ api: {
25
+ provider: "MempoolSpace",
26
+ },
27
+ }) {
28
+ var _a;
29
+ super(networkName, connectionInfo);
30
+ if (!((_a = connectionInfo.rpc) === null || _a === void 0 ? void 0 : _a.enabled)) {
31
+ throw new Error("rpc is required");
32
+ }
33
+ this.transactionBuilder = new transaction_builder_1.OrdinalTransactionBuilder(connectionInfo, networkName);
34
+ this.signer = new sign_transaction_1.default(this.network);
35
+ this.btcInterface = new bitcoin_interface_ordinal_1.BitcoinInterfaceOrdinal(connectionInfo, networkName, uniSatToken);
36
+ this.unisat = this.btcInterface.unisat;
37
+ }
38
+ sendSignedPsbtWithRetry(signedPsbt, { numberOfRetry = 5, sleepTime = 5000 } = {}) {
39
+ return __awaiter(this, void 0, void 0, function* () {
40
+ let count = 0;
41
+ while (count <= numberOfRetry) {
42
+ try {
43
+ let txId = yield this.sendSignedPsbt(signedPsbt);
44
+ return txId;
45
+ }
46
+ catch (e) {
47
+ console.log(e.message);
48
+ yield (0, tools_1.sleep)(sleepTime + count * 5000);
49
+ count += 1;
50
+ }
51
+ }
52
+ throw new Error("failed to send transaction");
53
+ });
54
+ }
55
+ static deployBRC20Data(tickName, max, limit) {
56
+ let data = {
57
+ p: "brc-20",
58
+ op: "deploy",
59
+ tick: tickName,
60
+ max: `${max}`,
61
+ lim: `${limit}`,
62
+ };
63
+ return {
64
+ buffer: Buffer.from(JSON.stringify(data), "utf8"),
65
+ type: "text/plain",
66
+ };
67
+ }
68
+ static mintBRC20Data(tickName, amount) {
69
+ let data = {
70
+ p: "brc-20",
71
+ op: "mint",
72
+ tick: tickName,
73
+ amt: `${amount}`,
74
+ };
75
+ return {
76
+ buffer: Buffer.from(JSON.stringify(data), "utf8"),
77
+ type: "text/plain",
78
+ };
79
+ }
80
+ static transferBRC20Data(tickName, amount) {
81
+ let data = {
82
+ p: "brc-20",
83
+ op: "transfer",
84
+ tick: tickName,
85
+ amt: `${amount}`,
86
+ };
87
+ return {
88
+ buffer: Buffer.from(JSON.stringify(data), "utf8"),
89
+ type: "text/plain",
90
+ };
91
+ }
92
+ sendUsingUtxosUnsigned({ receivers, speed = "normal", utxo, changeAddress, staticFeeRate, }) {
93
+ return __awaiter(this, void 0, void 0, function* () {
94
+ let extendedUtxo = utxo;
95
+ receivers.forEach(({ value }) => {
96
+ if (value - +value.toFixed(0) !== 0)
97
+ throw new Error("incorrect amount. amount should be in satoshi");
98
+ });
99
+ let feeRate = staticFeeRate || (yield this.transactionBuilder._getFeeRate(speed));
100
+ let unsignedTx = yield this.transactionBuilder.processUnsignedTransaction({
101
+ extendedUtxo,
102
+ targets: receivers,
103
+ changeAddress,
104
+ feeRate,
105
+ fullAmount: false,
106
+ });
107
+ return Object.assign(Object.assign({}, unsignedTx), { possibleTxId: this.transactionBuilder.getUnsignedPsbtTxId(unsignedTx.unsignedTransaction) });
108
+ });
109
+ }
110
+ sendUsingUtxos({ receivers, speed = "normal", utxo, }) {
111
+ return __awaiter(this, void 0, void 0, function* () {
112
+ if (!this.currentAccount || !this.currentAccountType || !this.publicKey || !this.privateKey) {
113
+ throw new Error("account not initialized");
114
+ }
115
+ let extendedUtxo = utxo
116
+ ? utxo.filter((u) => u.signerInfo.address === this.currentAccount)
117
+ : yield this.getExtendedUtxo({
118
+ address: this.currentAccount,
119
+ addressType: this.currentAccountType,
120
+ publicKey: this.publicKey.toString("hex"),
121
+ });
122
+ let unsignedTx = yield this.sendUsingUtxosUnsigned({
123
+ receivers,
124
+ speed,
125
+ utxo: extendedUtxo,
126
+ changeAddress: this.bitcoinAddress,
127
+ });
128
+ let signedPsbt = yield this.signer.signPsbt(unsignedTx, this.privateKey);
129
+ let signedTx = this.signer.finalizePsbts([signedPsbt]);
130
+ let txId = yield this.transactionBuilder.sendTx(signedTx);
131
+ const { inputs, outputs, change, fee } = unsignedTx;
132
+ return { txId, inputs, outputs, change, fee };
133
+ });
134
+ }
135
+ inscribeOrdinalDepositUnsigned(file, signer, extendedUtxo, staticFeeRate) {
136
+ return __awaiter(this, void 0, void 0, function* () {
137
+ const publicKey = Buffer.from(signer.publicKey, "hex");
138
+ let transferOrdinal = this.transactionBuilder.createOrdinalAddress(file, publicKey);
139
+ const leafScript = transferOrdinal.redeem.output;
140
+ const { ordinalAddress } = transferOrdinal;
141
+ let feeRate = staticFeeRate || (yield this.btcInterface.getFeeRate("normal"));
142
+ let fee = +(((400 + leafScript.length) / 4) * feeRate * 1.5).toFixed(0);
143
+ let ordinalAmount = 600;
144
+ let utxo1 = extendedUtxo || (yield this.btcInterface.getBTCUtxo(signer.address, signer));
145
+ let inscribeDepositUnsignedInfo = yield this.sendUsingUtxosUnsigned({
146
+ receivers: [
147
+ {
148
+ address: ordinalAddress,
149
+ value: ordinalAmount + fee,
150
+ },
151
+ ],
152
+ utxo: utxo1,
153
+ changeAddress: signer.address,
154
+ });
155
+ return {
156
+ inscribeDepositUnsignedInfo,
157
+ transferOrdinal,
158
+ };
159
+ });
160
+ }
161
+ inscribeOrdinalUnsigned(file, signer, extendedUtxo, staticFeeRate) {
162
+ return __awaiter(this, void 0, void 0, function* () {
163
+ const { inscribeDepositUnsignedInfo, transferOrdinal } = yield this.inscribeOrdinalDepositUnsigned(file, signer, extendedUtxo, staticFeeRate);
164
+ const { ordinalAddress } = transferOrdinal;
165
+ let ordinalAmount = 600;
166
+ let inscribeDeposit = {
167
+ hash: inscribeDepositUnsignedInfo.possibleTxId,
168
+ value: inscribeDepositUnsignedInfo.outputs[0].value,
169
+ index: 0,
170
+ };
171
+ let inscribeUnsignedInfo = this.transactionBuilder.createInscribeUnsignedTx(transferOrdinal, inscribeDeposit, this.bitcoinAddress, ordinalAmount);
172
+ return {
173
+ inscribeDepositUnsignedInfo: Object.assign(Object.assign({}, inscribeDepositUnsignedInfo), { possibleTxId: this.transactionBuilder.getUnsignedPsbtTxId(inscribeDepositUnsignedInfo.unsignedTransaction) }),
174
+ inscribeUnsignedInfo: Object.assign(Object.assign({}, inscribeUnsignedInfo), { possibleTxId: this.transactionBuilder.getUnsignedPsbtTxId(inscribeUnsignedInfo.unsignedTransaction) }),
175
+ inscribeAddress: ordinalAddress,
176
+ };
177
+ });
178
+ }
179
+ inscribeOrdinal(file, extendedUtxo, staticFeeRate) {
180
+ return __awaiter(this, void 0, void 0, function* () {
181
+ if (!this.currentAccount || !this.currentAccountType || !this.publicKey || !this.privateKey) {
182
+ throw new Error("account not initialized");
183
+ }
184
+ const { inscribeDepositUnsignedInfo, transferOrdinal } = yield this.inscribeOrdinalDepositUnsigned(file, this.signerInfo, extendedUtxo, staticFeeRate);
185
+ let ordinalUtxo = yield this.btcInterface.getBTCUtxo(transferOrdinal.ordinalAddress, this.signerInfo);
186
+ let inscribeDeposit;
187
+ if (ordinalUtxo.length > 1) {
188
+ throw new Error("multiple deposit found for this ordinal address");
189
+ }
190
+ if (ordinalUtxo.length === 0 ||
191
+ ordinalUtxo[0].value <
192
+ inscribeDepositUnsignedInfo.outputs[0].value -
193
+ inscribeDepositUnsignedInfo.outputs[0].value * 0.15) {
194
+ const signedPsbt1 = yield this.signer.signPsbt(inscribeDepositUnsignedInfo, this.privateKey);
195
+ console.log("inscribe deposit tx ...");
196
+ const inscribeDepositTxId = yield this.sendSignedPsbt(signedPsbt1);
197
+ console.log(`inscribe deposit txId : ${inscribeDepositTxId}`);
198
+ inscribeDeposit = {
199
+ hash: inscribeDepositTxId,
200
+ value: inscribeDepositUnsignedInfo.outputs[0].value,
201
+ index: 0,
202
+ inputs: inscribeDepositUnsignedInfo.inputs,
203
+ change: inscribeDepositUnsignedInfo.change,
204
+ changeIndex: inscribeDepositUnsignedInfo.change
205
+ ? inscribeDepositUnsignedInfo.outputs.length
206
+ : undefined,
207
+ };
208
+ }
209
+ else {
210
+ inscribeDeposit = {
211
+ hash: ordinalUtxo[0].hash,
212
+ value: ordinalUtxo[0].value,
213
+ index: ordinalUtxo[0].index,
214
+ inputs: [],
215
+ };
216
+ console.log("no need to deposit", inscribeDeposit);
217
+ }
218
+ const ordinalAmount = 600;
219
+ let inscribeUnsignedInfo = this.transactionBuilder.createInscribeUnsignedTx(transferOrdinal, inscribeDeposit, this.bitcoinAddress, ordinalAmount);
220
+ const signedPsbt2 = yield this.signer.signPsbt(inscribeUnsignedInfo, this.privateKey, undefined, false);
221
+ console.log("inscribeTxId ...");
222
+ yield (0, tools_1.sleep)(10 * 1000);
223
+ let inscribeTxId = yield this.sendSignedPsbtWithRetry(signedPsbt2);
224
+ console.log("inscribeTxId", inscribeTxId);
225
+ return {
226
+ inscribeTx: { hash: inscribeTxId, index: 0, value: ordinalAmount },
227
+ inscribeDepositTx: inscribeDeposit,
228
+ inscribeAddress: transferOrdinal.ordinalAddress,
229
+ };
230
+ });
231
+ }
232
+ deployBrc20(brc, extendedUtxo, staticFeeRate) {
233
+ return __awaiter(this, void 0, void 0, function* () {
234
+ let file = OrdinalWallet.deployBRC20Data(brc.tick, brc.max, brc.limit);
235
+ return this.inscribeOrdinal(file, extendedUtxo, staticFeeRate);
236
+ });
237
+ }
238
+ mintBrc20(brc, extendedUtxo, staticFeeRate) {
239
+ return __awaiter(this, void 0, void 0, function* () {
240
+ let file = OrdinalWallet.mintBRC20Data(brc.tick, brc.amount);
241
+ return this.inscribeOrdinal(file, extendedUtxo, staticFeeRate);
242
+ });
243
+ }
244
+ inscribeBrc20Unsigned(brc, signer, extendedUtxo, staticFeeRate) {
245
+ return __awaiter(this, void 0, void 0, function* () {
246
+ let file = OrdinalWallet.transferBRC20Data(brc.tick, brc.amount);
247
+ return this.inscribeOrdinalUnsigned(file, signer, extendedUtxo, staticFeeRate);
248
+ });
249
+ }
250
+ inscribeBrc20(brc, extendedUtxo, staticFeeRate) {
251
+ return __awaiter(this, void 0, void 0, function* () {
252
+ let file = OrdinalWallet.transferBRC20Data(brc.tick, brc.amount);
253
+ return this.inscribeOrdinal(file, extendedUtxo, staticFeeRate);
254
+ });
255
+ }
256
+ transferBrc20Unsigned(receiver, brcInscribeUtxo, signer, extendedUtxo, staticFeeRate, otherTargets) {
257
+ return __awaiter(this, void 0, void 0, function* () {
258
+ let utxo = extendedUtxo || (yield this.btcInterface.getBTCUtxo(signer.address, signer));
259
+ let feeRate = staticFeeRate || (yield this.btcInterface.getFeeRate("normal"));
260
+ let unsignedTx = yield this.transactionBuilder.createNftPsbt({
261
+ extendedUtxo: utxo,
262
+ nftExtendedUtxo: {
263
+ hash: brcInscribeUtxo.hash,
264
+ index: 0,
265
+ value: brcInscribeUtxo.value,
266
+ signerInfo: signer,
267
+ },
268
+ feeRate,
269
+ receiverAddress: receiver,
270
+ changeAddress: signer.address,
271
+ otherTargets,
272
+ });
273
+ return Object.assign(Object.assign({}, unsignedTx), { possibleTxId: this.transactionBuilder.getUnsignedPsbtTxId(unsignedTx.unsignedTransaction) });
274
+ });
275
+ }
276
+ transferBrc20(receiver, brcInscribeUtxo, extendedUtxo, staticFeeRate, otherTargets) {
277
+ return __awaiter(this, void 0, void 0, function* () {
278
+ if (!this.currentAccount || !this.currentAccountType || !this.publicKey || !this.privateKey) {
279
+ throw new Error("account not initialized");
280
+ }
281
+ let feeRate = staticFeeRate || (yield this.btcInterface.getFeeRate("normal"));
282
+ let unsignedTx = yield this.transactionBuilder.createNftPsbt({
283
+ extendedUtxo,
284
+ nftExtendedUtxo: {
285
+ hash: brcInscribeUtxo.hash,
286
+ index: 0,
287
+ value: brcInscribeUtxo.value,
288
+ signerInfo: this.signerInfo,
289
+ },
290
+ feeRate,
291
+ receiverAddress: receiver,
292
+ changeAddress: this.bitcoinAddress,
293
+ otherTargets,
294
+ });
295
+ let signedTx = yield this.signer.signPsbt(unsignedTx, this.privateKey);
296
+ let finalTransferTxId = yield this.sendSignedPsbtWithRetry(signedTx);
297
+ return {
298
+ hash: finalTransferTxId,
299
+ index: 0,
300
+ value: brcInscribeUtxo.value,
301
+ inputs: unsignedTx.inputs,
302
+ change: unsignedTx.change,
303
+ changeIndex: unsignedTx.change ? unsignedTx.outputs.length : undefined,
304
+ };
305
+ });
306
+ }
307
+ inscribeAndTransferBrc20Unsigned(receiver, brc, signer, otherTargets, extendedUtxo, staticFeeRate) {
308
+ return __awaiter(this, void 0, void 0, function* () {
309
+ let brc20Balance = yield this.unisat.getBrc20AddressBalanceForTicker(signer.address, brc.tick);
310
+ if ((0, bignumber_js_1.default)(brc20Balance.transferableBalance).gte(brc.amount)) {
311
+ let transferrableInscription = brc20Balance.transferableInscriptions.find((insc) => insc.data.tick === brc.tick && (0, bignumber_js_1.default)(insc.data.amt).isEqualTo(brc.amount));
312
+ console.log("transferrableInscription", transferrableInscription);
313
+ }
314
+ if ((0, bignumber_js_1.default)(brc20Balance.availableBalanceSafe).isLessThan(brc.amount)) {
315
+ throw new Error("insufficient balance");
316
+ }
317
+ let feeRate = staticFeeRate || (yield this.btcInterface.getFeeRate("normal"));
318
+ let utxo1 = extendedUtxo || (yield this.btcInterface.getBTCUtxo(signer.address, signer));
319
+ let utxo2 = [];
320
+ const { inscribeAddress, inscribeDepositUnsignedInfo, inscribeUnsignedInfo } = yield this.inscribeBrc20Unsigned(brc, signer, utxo1, feeRate);
321
+ utxo2 = utxo1.filter((u) => inscribeDepositUnsignedInfo.inputs.findIndex((i) => i.hash === u.hash && i.index === u.index) === -1);
322
+ if (inscribeDepositUnsignedInfo.change) {
323
+ utxo2.push({
324
+ hash: inscribeDepositUnsignedInfo.possibleTxId,
325
+ index: inscribeDepositUnsignedInfo.outputs.length,
326
+ value: inscribeDepositUnsignedInfo.change.value,
327
+ signerInfo: signer,
328
+ });
329
+ }
330
+ let transferTxUnsignedInfo = yield this.transferBrc20Unsigned(receiver, {
331
+ hash: inscribeUnsignedInfo.possibleTxId,
332
+ value: inscribeUnsignedInfo.outputs[0].value,
333
+ index: 0,
334
+ }, signer, utxo2, feeRate, otherTargets);
335
+ return {
336
+ inscribeDepositUnsignedInfo,
337
+ inscribeUnsignedInfo,
338
+ transferTxUnsignedInfo,
339
+ inscribeAddress,
340
+ };
341
+ });
342
+ }
343
+ inscribeAndTransferBrc20(receiver, brc, otherTargets, extendedUtxo, staticFeeRate) {
344
+ return __awaiter(this, void 0, void 0, function* () {
345
+ let brc20Balance = yield this.unisat.getBrc20AddressBalanceForTicker(this.bitcoinAddress, brc.tick);
346
+ if ((0, bignumber_js_1.default)(brc20Balance.transferableBalance).gte(brc.amount)) {
347
+ let transferrableInscription = brc20Balance.transferableInscriptions.find((insc) => insc.data.tick === brc.tick && (0, bignumber_js_1.default)(insc.data.amt).isEqualTo(brc.amount));
348
+ console.log("transferrableInscription", transferrableInscription);
349
+ if (transferrableInscription) {
350
+ let ins = yield this.btcInterface.unisat.getInscriptionInfo(transferrableInscription.inscriptionId);
351
+ if (ins) {
352
+ let transferTx = yield this.transferBrc20(receiver, {
353
+ hash: ins.utxo.txid,
354
+ index: ins.utxo.vout,
355
+ value: ins.utxo.satoshi,
356
+ }, extendedUtxo ||
357
+ (yield this.btcInterface.getBTCUtxo(this.bitcoinAddress, this.signerInfo)), staticFeeRate || (yield this.btcInterface.getFeeRate("normal")), otherTargets);
358
+ return {
359
+ transferTx,
360
+ };
361
+ }
362
+ }
363
+ }
364
+ if ((0, bignumber_js_1.default)(brc20Balance.availableBalanceSafe).isLessThan(brc.amount)) {
365
+ throw new Error(`insufficient balance ${brc20Balance.availableBalanceSafe} ${brc.amount}`);
366
+ }
367
+ let feeRate = staticFeeRate || (yield this.btcInterface.getFeeRate("normal"));
368
+ let utxo1 = extendedUtxo || (yield this.btcInterface.getBTCUtxo(this.bitcoinAddress, this.signerInfo));
369
+ let utxo2 = [];
370
+ const { inscribeAddress, inscribeDepositTx, inscribeTx } = yield this.inscribeBrc20(brc, utxo1, feeRate);
371
+ utxo2 = utxo1.filter((u) => inscribeDepositTx.inputs.findIndex((i) => i.hash === u.hash && i.index === u.index) === -1);
372
+ if (inscribeDepositTx.change) {
373
+ utxo2.push({
374
+ hash: inscribeDepositTx.hash,
375
+ index: inscribeDepositTx.changeIndex,
376
+ value: inscribeDepositTx.change.value,
377
+ signerInfo: this.signerInfo,
378
+ });
379
+ }
380
+ yield (0, tools_1.sleep)(10 * 1000);
381
+ let transferTx = yield this.transferBrc20(receiver, inscribeTx, utxo2, feeRate, otherTargets);
382
+ return {
383
+ inscribeTx,
384
+ inscribeAddress,
385
+ inscribeDepositTx,
386
+ transferTx,
387
+ };
388
+ });
389
+ }
390
+ wrapBrc20Unsigned(recipientAddress, brc, brc20TokenId, signer, lockerAddress, exchange, extendedUtxo, staticFeeRate, { chainId = 137, appId = exchange ? 1 : 0, } = {}) {
391
+ return __awaiter(this, void 0, void 0, function* () {
392
+ const isExchange = !!exchange;
393
+ let dataHex = (0, brc20_helper_1.generateBrc2OpReturn)({
394
+ chainId,
395
+ appId,
396
+ brc20TokenId,
397
+ inputAmount: (0, bignumber_js_1.default)(brc.amount).multipliedBy(1e18).toFixed(0),
398
+ recipientAddress,
399
+ isExchange,
400
+ outputToken: exchange === null || exchange === void 0 ? void 0 : exchange.outputToken,
401
+ outputAmount: exchange === null || exchange === void 0 ? void 0 : exchange.outputAmount,
402
+ });
403
+ let opTarget = this.transactionBuilder.getOpReturnTarget(dataHex);
404
+ return this.inscribeAndTransferBrc20Unsigned(lockerAddress, brc, signer, [opTarget], extendedUtxo, staticFeeRate);
405
+ });
406
+ }
407
+ wrapBrc20OnlyTransferUnsigned(recipientAddress, brcInscribeTx, brc, brc20TokenId, signer, lockerAddress, exchange, extendedUtxo, staticFeeRate, { chainId = 137, appId = exchange ? 1 : 0, } = {}) {
408
+ return __awaiter(this, void 0, void 0, function* () {
409
+ let utxo = extendedUtxo || (yield this.btcInterface.getBTCUtxo(signer.address, signer));
410
+ const isExchange = !!exchange;
411
+ let dataHex = (0, brc20_helper_1.generateBrc2OpReturn)({
412
+ chainId,
413
+ appId,
414
+ brc20TokenId,
415
+ inputAmount: (0, bignumber_js_1.default)(brc.amount).multipliedBy(1e18).toFixed(0),
416
+ recipientAddress,
417
+ isExchange,
418
+ outputToken: exchange === null || exchange === void 0 ? void 0 : exchange.outputToken,
419
+ outputAmount: exchange === null || exchange === void 0 ? void 0 : exchange.outputAmount,
420
+ });
421
+ let opTarget = this.transactionBuilder.getOpReturnTarget(dataHex);
422
+ let feeRate = staticFeeRate || (yield this.btcInterface.getFeeRate("normal"));
423
+ let transferTxUnsignedInfo = yield this.transferBrc20Unsigned(lockerAddress, brcInscribeTx, signer, utxo, feeRate, [opTarget]);
424
+ return transferTxUnsignedInfo;
425
+ });
426
+ }
427
+ wrapBrc20(recipientAddress, brc, brc20TokenId, lockerAddress, exchange, extendedUtxo, staticFeeRate, { chainId = 137, appId = exchange ? 1 : 0, } = {}) {
428
+ return __awaiter(this, void 0, void 0, function* () {
429
+ const isExchange = !!exchange;
430
+ let dataHex = (0, brc20_helper_1.generateBrc2OpReturn)({
431
+ chainId,
432
+ appId,
433
+ brc20TokenId,
434
+ inputAmount: (0, bignumber_js_1.default)(brc.amount).multipliedBy(1e18).toFixed(0),
435
+ recipientAddress,
436
+ isExchange,
437
+ outputToken: exchange === null || exchange === void 0 ? void 0 : exchange.outputToken,
438
+ outputAmount: exchange === null || exchange === void 0 ? void 0 : exchange.outputAmount,
439
+ });
440
+ let opTarget = this.transactionBuilder.getOpReturnTarget(dataHex);
441
+ return this.inscribeAndTransferBrc20(lockerAddress, brc, [opTarget], extendedUtxo, staticFeeRate);
442
+ });
443
+ }
444
+ }
445
+ exports.default = OrdinalWallet;
446
+ //# sourceMappingURL=ordinal-wallet.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ordinal-wallet.js","sourceRoot":"","sources":["../src/ordinal-wallet.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export { default as BaseBitcoinSigner } from "./sign-transaction";
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/sign/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,iBAAiB,EAAE,MAAM,oBAAoB,CAAA"}
@@ -0,0 +1,9 @@
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.BaseBitcoinSigner = void 0;
7
+ var sign_transaction_1 = require("./sign-transaction");
8
+ Object.defineProperty(exports, "BaseBitcoinSigner", { enumerable: true, get: function () { return __importDefault(sign_transaction_1).default; } });
9
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/sign/index.ts"],"names":[],"mappings":";;;;;;AAAA,uDAAiE;AAAxD,sIAAA,OAAO,OAAqB"}
@@ -5,7 +5,8 @@ declare class BitcoinLikeSignTransaction {
5
5
  constructor(network: Network);
6
6
  signPsbt(unsignedPsbt: {
7
7
  unsignedTransaction: string;
8
- }, privateKey: Buffer): Promise<string>;
8
+ inputsToSign?: number[];
9
+ }, privateKey: Buffer, sighashTypes?: any[], usingTweakSignerIfNeeded?: boolean): Promise<string>;
9
10
  finalizePsbts(psbtsBase64?: string[]): string;
10
11
  }
11
12
  export default BitcoinLikeSignTransaction;
@@ -1 +1 @@
1
- {"version":3,"file":"sign-transaction.d.ts","sourceRoot":"","sources":["../../src/sign/sign-transaction.ts"],"names":[],"mappings":";AAAA,OAAO,EAAgB,OAAO,EAAE,MAAM,eAAe,CAAA;AA0CrD,cAAM,0BAA0B;IAC9B,OAAO,EAAE,OAAO,CAAA;gBACJ,OAAO,EAAE,OAAO;IAItB,QAAQ,CACZ,YAAY,EAAE;QACZ,mBAAmB,EAAE,MAAM,CAAA;KAC5B,EACD,UAAU,EAAE,MAAM;IA4BpB,aAAa,CAAC,WAAW,GAAE,MAAM,EAAO;CAczC;AAED,eAAe,0BAA0B,CAAA"}
1
+ {"version":3,"file":"sign-transaction.d.ts","sourceRoot":"","sources":["../../src/sign/sign-transaction.ts"],"names":[],"mappings":";AAAA,OAAO,EAAgB,OAAO,EAAE,MAAM,eAAe,CAAA;AA2CrD,cAAM,0BAA0B;IAC9B,OAAO,EAAE,OAAO,CAAA;gBAEJ,OAAO,EAAE,OAAO;IAItB,QAAQ,CACZ,YAAY,EAAE;QACZ,mBAAmB,EAAE,MAAM,CAAA;QAC3B,YAAY,CAAC,EAAE,MAAM,EAAE,CAAA;KACxB,EACD,UAAU,EAAE,MAAM,EAClB,YAAY,CAAC,EAAE,GAAG,EAAE,EACpB,wBAAwB,UAAO;IAkCjC,aAAa,CAAC,WAAW,GAAE,MAAM,EAAO;CAczC;AAED,eAAe,0BAA0B,CAAA"}
@@ -1,27 +1,4 @@
1
1
  "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
2
  var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
26
3
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
27
4
  return new (P || (P = Promise))(function (resolve, reject) {
@@ -37,15 +14,15 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
37
14
  Object.defineProperty(exports, "__esModule", { value: true });
38
15
  const bitcoinjs_lib_1 = require("bitcoinjs-lib");
39
16
  const secp256k1_1 = __importDefault(require("@bitcoinerlab/secp256k1"));
40
- const bitcoinEcPair = __importStar(require("bitcoinjs-ecpair"));
41
- const ECPair = bitcoinEcPair.ECPair;
17
+ const ecpair_1 = __importDefault(require("ecpair"));
18
+ const ECPair = (0, ecpair_1.default)(secp256k1_1.default);
42
19
  function tapTweakHash(pubKey, h) {
43
20
  return bitcoinjs_lib_1.crypto.taggedHash("TapTweak", Buffer.concat(h ? [pubKey, h] : [pubKey]));
44
21
  }
45
- function tweakSigner(privateKey, opts = {}, network) {
22
+ function tweakSigner(privateKey, network, opts = {}) {
46
23
  let newPrv = privateKey;
47
24
  let keyPair = ECPair.fromPrivateKey(privateKey, {
48
- network: network,
25
+ network,
49
26
  compressed: true,
50
27
  });
51
28
  if (!keyPair.privateKey)
@@ -58,14 +35,14 @@ function tweakSigner(privateKey, opts = {}, network) {
58
35
  throw new Error("Invalid tweaked private key!");
59
36
  }
60
37
  return ECPair.fromPrivateKey(Buffer.from(tweakedPrivateKey), {
61
- network: network,
38
+ network,
62
39
  });
63
40
  }
64
41
  class BitcoinLikeSignTransaction {
65
42
  constructor(network) {
66
43
  this.network = network;
67
44
  }
68
- signPsbt(unsignedPsbt, privateKey) {
45
+ signPsbt(unsignedPsbt, privateKey, sighashTypes, usingTweakSignerIfNeeded = true) {
69
46
  return __awaiter(this, void 0, void 0, function* () {
70
47
  const { network } = this;
71
48
  const keyPair = ECPair.fromPrivateKey(privateKey, {
@@ -77,13 +54,17 @@ class BitcoinLikeSignTransaction {
77
54
  });
78
55
  let numberOfInputs = psbt.inputCount;
79
56
  for (let i = 0; i < numberOfInputs; i += 1) {
57
+ if (unsignedPsbt.inputsToSign && !unsignedPsbt.inputsToSign.includes(i)) {
58
+ continue;
59
+ }
80
60
  let type = psbt.getInputType(i);
81
- if (type === "nonstandard") {
82
- let a = tweakSigner(privateKey, undefined, this.network);
83
- yield psbt.signInputAsync(i, a);
61
+ if (usingTweakSignerIfNeeded && type === "nonstandard") {
62
+ console.log("using tweak signer");
63
+ let a = tweakSigner(privateKey, this.network);
64
+ yield psbt.signInputAsync(i, a, sighashTypes);
84
65
  }
85
66
  else {
86
- yield psbt.signInputAsync(i, keyPair);
67
+ yield psbt.signInputAsync(i, keyPair, sighashTypes);
87
68
  }
88
69
  }
89
70
  const partialSigendPsbt = psbt.toBase64();
@@ -1 +1 @@
1
- {"version":3,"file":"sign-transaction.js","sourceRoot":"","sources":["../../src/sign/sign-transaction.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,iDAAqD;AAErD,wEAAyC;AACzC,gEAAiD;AACjD,MAAM,MAAM,GAAG,aAAa,CAAC,MAAM,CAAA;AAEnC,SAAS,YAAY,CAAC,MAAc,EAAE,CAAU;IAC9C,OAAO,sBAAM,CAAC,UAAU,CAAC,UAAU,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAA;AACjF,CAAC;AAED,SAAS,WAAW,CAClB,UAAkB,EAClB,OAAO,EAEN,EACD,OAAgB;IAEhB,IAAI,MAAM,GAAG,UAAU,CAAA;IACvB,IAAI,OAAO,GAAG,MAAM,CAAC,cAAc,CAAC,UAAU,EAAE;QAC9C,OAAO,EAAE,OAAO;QAChB,UAAU,EAAE,IAAI;KACjB,CAAC,CAAA;IAEF,IAAI,CAAC,OAAO,CAAC,UAAU;QAAE,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAA;IAEjE,IAAI,OAAO,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;QACtD,MAAM,GAAG,mBAAG,CAAC,aAAa,CAAC,OAAO,CAAC,UAAU,CAAW,CAAA;KACzD;IAED,MAAM,iBAAiB,GAAG,mBAAG,CAAC,UAAU,CACtC,MAAM,EACN,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,SAAS,CAAC,CAC9F,CAAA;IACD,IAAI,CAAC,iBAAiB,EAAE;QACtB,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAA;KAChD;IAED,OAAO,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,EAAE;QAC3D,OAAO,EAAE,OAAO;KACjB,CAAC,CAAA;AACJ,CAAC;AAED,MAAM,0BAA0B;IAE9B,YAAY,OAAgB;QAC1B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;IACxB,CAAC;IAEK,QAAQ,CACZ,YAEC,EACD,UAAkB;;YAElB,MAAM,EAAE,OAAO,EAAE,GAAG,IAAI,CAAA;YACxB,MAAM,OAAO,GAAG,MAAM,CAAC,cAAc,CAAC,UAAU,EAAE;gBAChD,OAAO;gBACP,UAAU,EAAE,IAAI;aACjB,CAAC,CAAA;YACF,MAAM,IAAI,GAAG,oBAAI,CAAC,UAAU,CAAC,YAAY,CAAC,mBAAmB,EAAE;gBAC7D,OAAO;aACR,CAAC,CAAA;YAEF,IAAI,cAAc,GAAG,IAAI,CAAC,UAAU,CAAA;YAEpC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,cAAc,EAAE,CAAC,IAAI,CAAC,EAAE;gBAC1C,IAAI,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAA;gBAC/B,IAAI,IAAI,KAAK,aAAa,EAAE;oBAC1B,IAAI,CAAC,GAAG,WAAW,CAAC,UAAU,EAAE,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;oBACxD,MAAM,IAAI,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;iBAChC;qBAAM;oBACL,MAAM,IAAI,CAAC,cAAc,CAAC,CAAC,EAAE,OAAO,CAAC,CAAA;iBACtC;aACF;YAGD,MAAM,iBAAiB,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAA;YACzC,OAAO,iBAAiB,CAAA;QAC1B,CAAC;KAAA;IAED,aAAa,CAAC,cAAwB,EAAE;QACtC,MAAM,MAAM,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAC5C,oBAAI,CAAC,UAAU,CAAC,UAAU,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CACvD,CAAA;QACD,MAAM,IAAI,GACR,MAAM,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,oBAAI,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,MAAM,CAAC,CAAA;QAE1F,IAAI,CAAC,iBAAiB,EAAE,CAAA;QAExB,IAAI,UAAU,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAA;QAG1C,OAAO,UAAU,CAAC,KAAK,EAAE,CAAA;IAC3B,CAAC;CACF;AAED,kBAAe,0BAA0B,CAAA"}
1
+ {"version":3,"file":"sign-transaction.js","sourceRoot":"","sources":["../../src/sign/sign-transaction.ts"],"names":[],"mappings":"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"}