@teleportdao/bitcoin 1.8.9 → 1.9.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.
- package/.tmp/rbf.ts +24 -27
- package/package.json +4 -4
- package/src/bitcoin-interface-ordinal.ts +181 -181
- package/src/bitcoin-interface-teleswap.ts +252 -252
- package/src/bitcoin-interface-utils.ts +60 -60
- package/src/bitcoin-interface.ts +239 -239
- package/src/bitcoin-utils.ts +591 -591
- package/src/bitcoin-wallet-base.ts +310 -310
- package/src/helper/brc20-helper.ts +179 -179
- package/src/helper/ordinal-helper.ts +118 -118
- package/src/index.ts +15 -15
- package/src/ordinal-wallet.ts +748 -748
- package/src/sign/index.ts +1 -1
- package/src/sign/sign-transaction.ts +108 -108
- package/src/teleswap-wallet.ts +155 -155
- package/src/transaction-builder/bitcoin-transaction-builder.ts +44 -44
- package/src/transaction-builder/index.ts +3 -3
- package/src/transaction-builder/ordinal-transaction-builder.ts +147 -147
- package/src/transaction-builder/transaction-builder.ts +706 -706
- package/src/type.ts +48 -48
- package/src/utils/networks.ts +33 -33
- package/src/utils/tools.ts +92 -92
- package/tsconfig.json +9 -9
- package/webpack.config.js +16 -16
- package/.tmp/ordinal-helper.ts +0 -133
- package/.tmp/ordinal.ts +0 -25
|
@@ -1,147 +1,147 @@
|
|
|
1
|
-
import { ExtendedUtxo, Target } from "./transaction-builder"
|
|
2
|
-
import * as bitcoin from "bitcoinjs-lib"
|
|
3
|
-
import { LEAF_VERSION_TAPSCRIPT } from "bitcoinjs-lib/src/payments/bip341"
|
|
4
|
-
import { BitcoinTransactionBuilder } from "./bitcoin-transaction-builder"
|
|
5
|
-
import { getOrdinalScript, toXOnly } from "../helper/ordinal-helper"
|
|
6
|
-
|
|
7
|
-
export class OrdinalTransactionBuilder extends BitcoinTransactionBuilder {
|
|
8
|
-
async createNftPsbt({
|
|
9
|
-
extendedUtxo,
|
|
10
|
-
nftExtendedUtxo,
|
|
11
|
-
receiverAddress,
|
|
12
|
-
feeRate,
|
|
13
|
-
changeAddress,
|
|
14
|
-
otherTargets,
|
|
15
|
-
}: {
|
|
16
|
-
nftExtendedUtxo: ExtendedUtxo
|
|
17
|
-
extendedUtxo: ExtendedUtxo[]
|
|
18
|
-
feeRate: number
|
|
19
|
-
changeAddress: string
|
|
20
|
-
receiverAddress: string
|
|
21
|
-
otherTargets?: Target[]
|
|
22
|
-
}) {
|
|
23
|
-
let targets: Target[] = [
|
|
24
|
-
{
|
|
25
|
-
address: receiverAddress,
|
|
26
|
-
value: nftExtendedUtxo.value,
|
|
27
|
-
},
|
|
28
|
-
]
|
|
29
|
-
|
|
30
|
-
if (otherTargets) targets.push(...otherTargets)
|
|
31
|
-
|
|
32
|
-
if (!changeAddress && targets.length === 0) throw new Error("no target")
|
|
33
|
-
let changeObject = {
|
|
34
|
-
address: changeAddress,
|
|
35
|
-
}
|
|
36
|
-
let { inputs, outputs, change, fee } = await this.filterAndConvertTxDataToStandardFormat({
|
|
37
|
-
extendedUtxo: [nftExtendedUtxo, ...extendedUtxo],
|
|
38
|
-
targets,
|
|
39
|
-
changeObject,
|
|
40
|
-
feeRate,
|
|
41
|
-
selectType: "inOrder",
|
|
42
|
-
})
|
|
43
|
-
|
|
44
|
-
let unsignedTx = this.createUnsignedTransaction({
|
|
45
|
-
inputs,
|
|
46
|
-
outputs,
|
|
47
|
-
change,
|
|
48
|
-
fee,
|
|
49
|
-
feeRate,
|
|
50
|
-
})
|
|
51
|
-
|
|
52
|
-
return unsignedTx
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
createOrdinalAddress(
|
|
56
|
-
file: {
|
|
57
|
-
buffer: Buffer
|
|
58
|
-
type: string
|
|
59
|
-
},
|
|
60
|
-
publicKey: Buffer,
|
|
61
|
-
) {
|
|
62
|
-
const internalPublicKey = toXOnly(publicKey).toString("hex")
|
|
63
|
-
let leafScript = getOrdinalScript(file, internalPublicKey)
|
|
64
|
-
|
|
65
|
-
const scriptTree = {
|
|
66
|
-
output: leafScript,
|
|
67
|
-
}
|
|
68
|
-
const redeem = {
|
|
69
|
-
output: leafScript,
|
|
70
|
-
redeemVersion: LEAF_VERSION_TAPSCRIPT,
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
const p2trTapOrdinalScript = bitcoin.payments.p2tr({
|
|
74
|
-
internalPubkey: Buffer.from(internalPublicKey, "hex"),
|
|
75
|
-
scriptTree,
|
|
76
|
-
network: this.network,
|
|
77
|
-
redeem,
|
|
78
|
-
})
|
|
79
|
-
let ordinalAddress = p2trTapOrdinalScript.address!
|
|
80
|
-
const controlBlock = p2trTapOrdinalScript.witness![p2trTapOrdinalScript.witness!.length - 1]
|
|
81
|
-
return {
|
|
82
|
-
ordinalAddress,
|
|
83
|
-
ordinalScript: p2trTapOrdinalScript.output!,
|
|
84
|
-
redeem,
|
|
85
|
-
controlBlock,
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
createInscribeUnsignedTx(
|
|
90
|
-
ordinalSpendDetails: {
|
|
91
|
-
ordinalAddress: string
|
|
92
|
-
ordinalScript: Buffer
|
|
93
|
-
redeem: {
|
|
94
|
-
output: Buffer
|
|
95
|
-
redeemVersion: number
|
|
96
|
-
}
|
|
97
|
-
controlBlock: Buffer
|
|
98
|
-
},
|
|
99
|
-
inscribeDeposit: {
|
|
100
|
-
hash: string
|
|
101
|
-
index: number
|
|
102
|
-
value: number
|
|
103
|
-
},
|
|
104
|
-
receiverAddress: string,
|
|
105
|
-
ordinalAmount = 600,
|
|
106
|
-
) {
|
|
107
|
-
const psbt = new bitcoin.Psbt({ network: this.network })
|
|
108
|
-
.addInput({
|
|
109
|
-
...inscribeDeposit,
|
|
110
|
-
witnessUtxo: { value: inscribeDeposit.value, script: ordinalSpendDetails.ordinalScript },
|
|
111
|
-
// tapInternalKey: toXOnly(node.publicKey),
|
|
112
|
-
// tapMerkleRoot: p2trTapOrdinalScript.hash!,
|
|
113
|
-
tapLeafScript: [
|
|
114
|
-
{
|
|
115
|
-
leafVersion: ordinalSpendDetails.redeem.redeemVersion,
|
|
116
|
-
script: ordinalSpendDetails.redeem.output,
|
|
117
|
-
controlBlock: ordinalSpendDetails.controlBlock,
|
|
118
|
-
},
|
|
119
|
-
],
|
|
120
|
-
})
|
|
121
|
-
.addOutput({
|
|
122
|
-
value: ordinalAmount,
|
|
123
|
-
address: receiverAddress,
|
|
124
|
-
})
|
|
125
|
-
|
|
126
|
-
return {
|
|
127
|
-
unsignedTransaction: psbt.toBase64(),
|
|
128
|
-
inputs: [inscribeDeposit],
|
|
129
|
-
outputs: [
|
|
130
|
-
{
|
|
131
|
-
value: ordinalAmount,
|
|
132
|
-
address: receiverAddress,
|
|
133
|
-
},
|
|
134
|
-
],
|
|
135
|
-
fee: inscribeDeposit.value - ordinalAmount,
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
// use with caution. just segwit address
|
|
140
|
-
getUnsignedPsbtTxId(unsignedPsbt: string): string {
|
|
141
|
-
// use with caution
|
|
142
|
-
let psbt = bitcoin.Psbt.fromBase64(unsignedPsbt, {
|
|
143
|
-
network: this.network,
|
|
144
|
-
})
|
|
145
|
-
return (psbt as any).__CACHE.__TX.getId()
|
|
146
|
-
}
|
|
147
|
-
}
|
|
1
|
+
import { ExtendedUtxo, Target } from "./transaction-builder"
|
|
2
|
+
import * as bitcoin from "bitcoinjs-lib"
|
|
3
|
+
import { LEAF_VERSION_TAPSCRIPT } from "bitcoinjs-lib/src/payments/bip341"
|
|
4
|
+
import { BitcoinTransactionBuilder } from "./bitcoin-transaction-builder"
|
|
5
|
+
import { getOrdinalScript, toXOnly } from "../helper/ordinal-helper"
|
|
6
|
+
|
|
7
|
+
export class OrdinalTransactionBuilder extends BitcoinTransactionBuilder {
|
|
8
|
+
async createNftPsbt({
|
|
9
|
+
extendedUtxo,
|
|
10
|
+
nftExtendedUtxo,
|
|
11
|
+
receiverAddress,
|
|
12
|
+
feeRate,
|
|
13
|
+
changeAddress,
|
|
14
|
+
otherTargets,
|
|
15
|
+
}: {
|
|
16
|
+
nftExtendedUtxo: ExtendedUtxo
|
|
17
|
+
extendedUtxo: ExtendedUtxo[]
|
|
18
|
+
feeRate: number
|
|
19
|
+
changeAddress: string
|
|
20
|
+
receiverAddress: string
|
|
21
|
+
otherTargets?: Target[]
|
|
22
|
+
}) {
|
|
23
|
+
let targets: Target[] = [
|
|
24
|
+
{
|
|
25
|
+
address: receiverAddress,
|
|
26
|
+
value: nftExtendedUtxo.value,
|
|
27
|
+
},
|
|
28
|
+
]
|
|
29
|
+
|
|
30
|
+
if (otherTargets) targets.push(...otherTargets)
|
|
31
|
+
|
|
32
|
+
if (!changeAddress && targets.length === 0) throw new Error("no target")
|
|
33
|
+
let changeObject = {
|
|
34
|
+
address: changeAddress,
|
|
35
|
+
}
|
|
36
|
+
let { inputs, outputs, change, fee } = await this.filterAndConvertTxDataToStandardFormat({
|
|
37
|
+
extendedUtxo: [nftExtendedUtxo, ...extendedUtxo],
|
|
38
|
+
targets,
|
|
39
|
+
changeObject,
|
|
40
|
+
feeRate,
|
|
41
|
+
selectType: "inOrder",
|
|
42
|
+
})
|
|
43
|
+
|
|
44
|
+
let unsignedTx = this.createUnsignedTransaction({
|
|
45
|
+
inputs,
|
|
46
|
+
outputs,
|
|
47
|
+
change,
|
|
48
|
+
fee,
|
|
49
|
+
feeRate,
|
|
50
|
+
})
|
|
51
|
+
|
|
52
|
+
return unsignedTx
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
createOrdinalAddress(
|
|
56
|
+
file: {
|
|
57
|
+
buffer: Buffer
|
|
58
|
+
type: string
|
|
59
|
+
},
|
|
60
|
+
publicKey: Buffer,
|
|
61
|
+
) {
|
|
62
|
+
const internalPublicKey = toXOnly(publicKey).toString("hex")
|
|
63
|
+
let leafScript = getOrdinalScript(file, internalPublicKey)
|
|
64
|
+
|
|
65
|
+
const scriptTree = {
|
|
66
|
+
output: leafScript,
|
|
67
|
+
}
|
|
68
|
+
const redeem = {
|
|
69
|
+
output: leafScript,
|
|
70
|
+
redeemVersion: LEAF_VERSION_TAPSCRIPT,
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
const p2trTapOrdinalScript = bitcoin.payments.p2tr({
|
|
74
|
+
internalPubkey: Buffer.from(internalPublicKey, "hex"),
|
|
75
|
+
scriptTree,
|
|
76
|
+
network: this.network,
|
|
77
|
+
redeem,
|
|
78
|
+
})
|
|
79
|
+
let ordinalAddress = p2trTapOrdinalScript.address!
|
|
80
|
+
const controlBlock = p2trTapOrdinalScript.witness![p2trTapOrdinalScript.witness!.length - 1]
|
|
81
|
+
return {
|
|
82
|
+
ordinalAddress,
|
|
83
|
+
ordinalScript: p2trTapOrdinalScript.output!,
|
|
84
|
+
redeem,
|
|
85
|
+
controlBlock,
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
createInscribeUnsignedTx(
|
|
90
|
+
ordinalSpendDetails: {
|
|
91
|
+
ordinalAddress: string
|
|
92
|
+
ordinalScript: Buffer
|
|
93
|
+
redeem: {
|
|
94
|
+
output: Buffer
|
|
95
|
+
redeemVersion: number
|
|
96
|
+
}
|
|
97
|
+
controlBlock: Buffer
|
|
98
|
+
},
|
|
99
|
+
inscribeDeposit: {
|
|
100
|
+
hash: string
|
|
101
|
+
index: number
|
|
102
|
+
value: number
|
|
103
|
+
},
|
|
104
|
+
receiverAddress: string,
|
|
105
|
+
ordinalAmount = 600,
|
|
106
|
+
) {
|
|
107
|
+
const psbt = new bitcoin.Psbt({ network: this.network })
|
|
108
|
+
.addInput({
|
|
109
|
+
...inscribeDeposit,
|
|
110
|
+
witnessUtxo: { value: inscribeDeposit.value, script: ordinalSpendDetails.ordinalScript },
|
|
111
|
+
// tapInternalKey: toXOnly(node.publicKey),
|
|
112
|
+
// tapMerkleRoot: p2trTapOrdinalScript.hash!,
|
|
113
|
+
tapLeafScript: [
|
|
114
|
+
{
|
|
115
|
+
leafVersion: ordinalSpendDetails.redeem.redeemVersion,
|
|
116
|
+
script: ordinalSpendDetails.redeem.output,
|
|
117
|
+
controlBlock: ordinalSpendDetails.controlBlock,
|
|
118
|
+
},
|
|
119
|
+
],
|
|
120
|
+
})
|
|
121
|
+
.addOutput({
|
|
122
|
+
value: ordinalAmount,
|
|
123
|
+
address: receiverAddress,
|
|
124
|
+
})
|
|
125
|
+
|
|
126
|
+
return {
|
|
127
|
+
unsignedTransaction: psbt.toBase64(),
|
|
128
|
+
inputs: [inscribeDeposit],
|
|
129
|
+
outputs: [
|
|
130
|
+
{
|
|
131
|
+
value: ordinalAmount,
|
|
132
|
+
address: receiverAddress,
|
|
133
|
+
},
|
|
134
|
+
],
|
|
135
|
+
fee: inscribeDeposit.value - ordinalAmount,
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
// use with caution. just segwit address
|
|
140
|
+
getUnsignedPsbtTxId(unsignedPsbt: string): string {
|
|
141
|
+
// use with caution
|
|
142
|
+
let psbt = bitcoin.Psbt.fromBase64(unsignedPsbt, {
|
|
143
|
+
network: this.network,
|
|
144
|
+
})
|
|
145
|
+
return (psbt as any).__CACHE.__TX.getId()
|
|
146
|
+
}
|
|
147
|
+
}
|