@bitgo-beta/sdk-coin-btc 1.2.3-alpha.30 → 1.2.3-alpha.31
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.
|
@@ -1,12 +1,34 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
2
|
import { AbstractUtxoCoin } from '@bitgo-beta/abstract-utxo';
|
|
3
|
-
import { IInscriptionBuilder, IWallet, PreparedInscriptionRevealData, SubmitTransactionResponse } from '@bitgo-beta/sdk-core';
|
|
3
|
+
import { IInscriptionBuilder, IWallet, PrebuildTransactionResult, PreparedInscriptionRevealData, SubmitTransactionResponse } from '@bitgo-beta/sdk-core';
|
|
4
4
|
import * as utxolib from '@bitgo-beta/utxo-lib';
|
|
5
5
|
export declare class InscriptionBuilder implements IInscriptionBuilder {
|
|
6
6
|
private readonly wallet;
|
|
7
7
|
private readonly coin;
|
|
8
8
|
constructor(wallet: IWallet, coin: AbstractUtxoCoin);
|
|
9
9
|
prepareReveal(inscriptionData: Buffer, contentType: string): Promise<PreparedInscriptionRevealData>;
|
|
10
|
+
/**
|
|
11
|
+
* Build a transaction to send an inscription
|
|
12
|
+
* @param satPoint Satpoint you want to send
|
|
13
|
+
* @param recipient Address you want to send to
|
|
14
|
+
* @param feeRateSatKB Fee rate for transaction
|
|
15
|
+
* @param signer first signer of the transaction
|
|
16
|
+
* @param cosigner second signer of the transaction
|
|
17
|
+
* @param inscriptionConstraints.minChangeOutput (optional) the minimum size of the change output
|
|
18
|
+
* @param inscriptionConstraints.minInscriptionOutput (optional) the minimum number of sats of the output containing the inscription
|
|
19
|
+
* @param inscriptionConstraints.maxInscriptionOutput (optional) the maximum number of sats of the output containing the inscription
|
|
20
|
+
* @param changeAddressType Address type of the change address
|
|
21
|
+
*/
|
|
22
|
+
prepareTransfer(satPoint: string, recipient: string, feeRateSatKB: number, { signer, cosigner, inscriptionConstraints, changeAddressType, }: {
|
|
23
|
+
signer: utxolib.bitgo.KeyName;
|
|
24
|
+
cosigner: utxolib.bitgo.KeyName;
|
|
25
|
+
inscriptionConstraints: {
|
|
26
|
+
minChangeOutput?: bigint;
|
|
27
|
+
minInscriptionOutput?: bigint;
|
|
28
|
+
maxInscriptionOutput?: bigint;
|
|
29
|
+
};
|
|
30
|
+
changeAddressType: utxolib.bitgo.outputScripts.ScriptType2Of3;
|
|
31
|
+
}): Promise<PrebuildTransactionResult>;
|
|
10
32
|
/**
|
|
11
33
|
*
|
|
12
34
|
* @param walletPassphrase
|
|
@@ -15,7 +37,14 @@ export declare class InscriptionBuilder implements IInscriptionBuilder {
|
|
|
15
37
|
* @param unsignedCommitTx
|
|
16
38
|
* @param commitTransactionUnspents
|
|
17
39
|
* @param recipientAddress
|
|
40
|
+
* @param inscriptionData
|
|
41
|
+
*/
|
|
42
|
+
signAndSendReveal(walletPassphrase: string, tapLeafScript: utxolib.bitgo.TapLeafScript, commitAddress: string, unsignedCommitTx: Buffer, commitTransactionUnspents: utxolib.bitgo.WalletUnspent[], recipientAddress: string, inscriptionData: Buffer): Promise<SubmitTransactionResponse>;
|
|
43
|
+
/**
|
|
44
|
+
* Sign and send a transaction that transfers an inscription
|
|
45
|
+
* @param walletPassphrase passphrase to unlock your keys
|
|
46
|
+
* @param txPrebuild this is the output of `inscription.prepareTransfer`
|
|
18
47
|
*/
|
|
19
|
-
|
|
48
|
+
signAndSendTransfer(walletPassphrase: string, txPrebuild: PrebuildTransactionResult): Promise<SubmitTransactionResponse>;
|
|
20
49
|
}
|
|
21
50
|
//# sourceMappingURL=inscriptionBuilder.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"inscriptionBuilder.d.ts","sourceRoot":"","sources":["../../src/inscriptionBuilder.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAEL,mBAAmB,EACnB,OAAO,EAEP,6BAA6B,EAC7B,yBAAyB,
|
|
1
|
+
{"version":3,"file":"inscriptionBuilder.d.ts","sourceRoot":"","sources":["../../src/inscriptionBuilder.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAEL,mBAAmB,EACnB,OAAO,EAEP,yBAAyB,EACzB,6BAA6B,EAC7B,yBAAyB,EAI1B,MAAM,sBAAsB,CAAC;AAC9B,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAWhD,qBAAa,kBAAmB,YAAW,mBAAmB;IAC5D,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAU;IACjC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAmB;gBAE5B,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,gBAAgB;IAK7C,aAAa,CAAC,eAAe,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,6BAA6B,CAAC;IAWzG;;;;;;;;;;;OAWG;IACG,eAAe,CACnB,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,EACjB,YAAY,EAAE,MAAM,EACpB,EACE,MAAe,EACf,QAAkB,EAClB,sBAAsD,EACtD,iBAA0B,GAC3B,EAAE;QACD,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC;QAC9B,QAAQ,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC;QAChC,sBAAsB,EAAE;YACtB,eAAe,CAAC,EAAE,MAAM,CAAC;YACzB,oBAAoB,CAAC,EAAE,MAAM,CAAC;YAC9B,oBAAoB,CAAC,EAAE,MAAM,CAAC;SAC/B,CAAC;QACF,iBAAiB,EAAE,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,cAAc,CAAC;KAC/D,GACA,OAAO,CAAC,yBAAyB,CAAC;IAiDrC;;;;;;;;;OASG;IACG,iBAAiB,CACrB,gBAAgB,EAAE,MAAM,EACxB,aAAa,EAAE,OAAO,CAAC,KAAK,CAAC,aAAa,EAC1C,aAAa,EAAE,MAAM,EACrB,gBAAgB,EAAE,MAAM,EACxB,yBAAyB,EAAE,OAAO,CAAC,KAAK,CAAC,aAAa,EAAE,EACxD,gBAAgB,EAAE,MAAM,EACxB,eAAe,EAAE,MAAM,GACtB,OAAO,CAAC,yBAAyB,CAAC;IAgCrC;;;;OAIG;IACG,mBAAmB,CACvB,gBAAgB,EAAE,MAAM,EACxB,UAAU,EAAE,yBAAyB,GACpC,OAAO,CAAC,yBAAyB,CAAC;CAOtC"}
|
|
@@ -1,10 +1,30 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
10
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
11
|
+
}) : function(o, v) {
|
|
12
|
+
o["default"] = v;
|
|
13
|
+
});
|
|
14
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
+
if (mod && mod.__esModule) return mod;
|
|
16
|
+
var result = {};
|
|
17
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
+
__setModuleDefault(result, mod);
|
|
19
|
+
return result;
|
|
20
|
+
};
|
|
2
21
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
22
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
23
|
};
|
|
5
24
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
25
|
exports.InscriptionBuilder = void 0;
|
|
7
26
|
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
27
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
8
28
|
const utxo_ord_1 = require("@bitgo-beta/utxo-ord");
|
|
9
29
|
const assert_1 = __importDefault(require("assert"));
|
|
10
30
|
class InscriptionBuilder {
|
|
@@ -15,8 +35,57 @@ class InscriptionBuilder {
|
|
|
15
35
|
async prepareReveal(inscriptionData, contentType) {
|
|
16
36
|
const user = await this.wallet.baseCoin.keychains().get({ id: this.wallet.keyIds()[sdk_core_1.KeyIndices.USER] });
|
|
17
37
|
assert_1.default(user.pub);
|
|
18
|
-
const
|
|
19
|
-
|
|
38
|
+
const derived = this.coin.deriveKeyWithSeed({ key: user.pub, seed: inscriptionData.toString() });
|
|
39
|
+
const compressedPublicKey = sdk_core_1.xpubToCompressedPub(derived.key);
|
|
40
|
+
const xOnlyPublicKey = utxolib.bitgo.outputScripts.toXOnlyPublicKey(Buffer.from(compressedPublicKey, 'hex'));
|
|
41
|
+
return utxo_ord_1.inscriptions.createInscriptionRevealData(xOnlyPublicKey, contentType, inscriptionData, this.coin.network);
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Build a transaction to send an inscription
|
|
45
|
+
* @param satPoint Satpoint you want to send
|
|
46
|
+
* @param recipient Address you want to send to
|
|
47
|
+
* @param feeRateSatKB Fee rate for transaction
|
|
48
|
+
* @param signer first signer of the transaction
|
|
49
|
+
* @param cosigner second signer of the transaction
|
|
50
|
+
* @param inscriptionConstraints.minChangeOutput (optional) the minimum size of the change output
|
|
51
|
+
* @param inscriptionConstraints.minInscriptionOutput (optional) the minimum number of sats of the output containing the inscription
|
|
52
|
+
* @param inscriptionConstraints.maxInscriptionOutput (optional) the maximum number of sats of the output containing the inscription
|
|
53
|
+
* @param changeAddressType Address type of the change address
|
|
54
|
+
*/
|
|
55
|
+
async prepareTransfer(satPoint, recipient, feeRateSatKB, { signer = 'user', cosigner = 'bitgo', inscriptionConstraints = utxo_ord_1.DefaultInscriptionConstraints, changeAddressType = 'p2tr', }) {
|
|
56
|
+
assert_1.default(utxo_ord_1.isSatPoint(satPoint));
|
|
57
|
+
const wk = (await this.wallet.baseCoin.keychains().list()).keys;
|
|
58
|
+
assert_1.default(wk.length === 3);
|
|
59
|
+
const rootWalletKeys = new utxolib.bitgo.RootWalletKeys(wk.map((k) => {
|
|
60
|
+
assert_1.default(k.pub);
|
|
61
|
+
return utxolib.bip32.fromBase58(k.pub);
|
|
62
|
+
}));
|
|
63
|
+
const parsedSatPoint = utxo_ord_1.parseSatPoint(satPoint);
|
|
64
|
+
const transaction = await this.wallet.getTransaction({ txHash: parsedSatPoint.txid });
|
|
65
|
+
// TODO(BG-70900): allow supplemental unspents
|
|
66
|
+
const unspents = [transaction.outputs[parsedSatPoint.vout]];
|
|
67
|
+
const txInfo = { unspents };
|
|
68
|
+
const changeAddress = await this.wallet.createAddress({
|
|
69
|
+
chain: utxolib.bitgo.getExternalChainCode(changeAddressType),
|
|
70
|
+
});
|
|
71
|
+
const outputs = {
|
|
72
|
+
inscriptionRecipient: recipient,
|
|
73
|
+
changeOutputs: [
|
|
74
|
+
{ chain: changeAddress.chain, index: changeAddress.index },
|
|
75
|
+
{ chain: changeAddress.chain, index: changeAddress.index },
|
|
76
|
+
],
|
|
77
|
+
};
|
|
78
|
+
const psbt = utxo_ord_1.createPsbtForSingleInscriptionPassingTransaction(this.coin.network, {
|
|
79
|
+
walletKeys: rootWalletKeys,
|
|
80
|
+
signer,
|
|
81
|
+
cosigner,
|
|
82
|
+
}, unspents, satPoint, outputs, { feeRateSatKB, ...inscriptionConstraints });
|
|
83
|
+
return {
|
|
84
|
+
walletId: this.wallet.id(),
|
|
85
|
+
txHex: psbt.getUnsignedTx().toHex(),
|
|
86
|
+
txInfo,
|
|
87
|
+
feeInfo: { fee: feeRateSatKB, feeString: feeRateSatKB.toString() },
|
|
88
|
+
};
|
|
20
89
|
}
|
|
21
90
|
/**
|
|
22
91
|
*
|
|
@@ -26,11 +95,11 @@ class InscriptionBuilder {
|
|
|
26
95
|
* @param unsignedCommitTx
|
|
27
96
|
* @param commitTransactionUnspents
|
|
28
97
|
* @param recipientAddress
|
|
98
|
+
* @param inscriptionData
|
|
29
99
|
*/
|
|
30
|
-
async signAndSendReveal(walletPassphrase, tapLeafScript, commitAddress, unsignedCommitTx, commitTransactionUnspents, recipientAddress) {
|
|
100
|
+
async signAndSendReveal(walletPassphrase, tapLeafScript, commitAddress, unsignedCommitTx, commitTransactionUnspents, recipientAddress, inscriptionData) {
|
|
31
101
|
const userKeychain = await this.wallet.baseCoin.keychains().get({ id: this.wallet.keyIds()[sdk_core_1.KeyIndices.USER] });
|
|
32
102
|
const xprv = await this.wallet.getUserPrv({ keychain: userKeychain, walletPassphrase });
|
|
33
|
-
const prv = sdk_core_1.xprvToRawPrv(xprv);
|
|
34
103
|
const halfSignedCommitTransaction = (await this.wallet.signTransaction({
|
|
35
104
|
prv: xprv,
|
|
36
105
|
txPrebuild: {
|
|
@@ -38,7 +107,9 @@ class InscriptionBuilder {
|
|
|
38
107
|
txInfo: { unspents: commitTransactionUnspents },
|
|
39
108
|
},
|
|
40
109
|
}));
|
|
41
|
-
const
|
|
110
|
+
const derived = this.coin.deriveKeyWithSeed({ key: xprv, seed: inscriptionData.toString() });
|
|
111
|
+
const prv = sdk_core_1.xprvToRawPrv(derived.key);
|
|
112
|
+
const fullySignedRevealTransaction = await utxo_ord_1.inscriptions.signRevealTransaction(Buffer.from(prv, 'hex'), tapLeafScript, commitAddress, recipientAddress, Buffer.from(halfSignedCommitTransaction.txHex, 'hex'), this.coin.network);
|
|
42
113
|
return this.wallet.submitTransaction({
|
|
43
114
|
halfSigned: {
|
|
44
115
|
txHex: halfSignedCommitTransaction.txHex,
|
|
@@ -46,6 +117,17 @@ class InscriptionBuilder {
|
|
|
46
117
|
},
|
|
47
118
|
});
|
|
48
119
|
}
|
|
120
|
+
/**
|
|
121
|
+
* Sign and send a transaction that transfers an inscription
|
|
122
|
+
* @param walletPassphrase passphrase to unlock your keys
|
|
123
|
+
* @param txPrebuild this is the output of `inscription.prepareTransfer`
|
|
124
|
+
*/
|
|
125
|
+
async signAndSendTransfer(walletPassphrase, txPrebuild) {
|
|
126
|
+
const userKeychain = await this.wallet.baseCoin.keychains().get({ id: this.wallet.keyIds()[sdk_core_1.KeyIndices.USER] });
|
|
127
|
+
const prv = this.wallet.getUserPrv({ keychain: userKeychain, walletPassphrase });
|
|
128
|
+
const halfSigned = (await this.wallet.signTransaction({ prv, txPrebuild }));
|
|
129
|
+
return this.wallet.submitTransaction({ halfSigned });
|
|
130
|
+
}
|
|
49
131
|
}
|
|
50
132
|
exports.InscriptionBuilder = InscriptionBuilder;
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5zY3JpcHRpb25CdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2luc2NyaXB0aW9uQnVpbGRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFDQSxtREFROEI7QUFFOUIsbURBQW9EO0FBQ3BELG9EQUE0QjtBQUU1QixNQUFhLGtCQUFrQjtJQUk3QixZQUFZLE1BQWUsRUFBRSxJQUFzQjtRQUNqRCxJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztJQUNuQixDQUFDO0lBRUQsS0FBSyxDQUFDLGFBQWEsQ0FBQyxlQUF1QixFQUFFLFdBQW1CO1FBQzlELE1BQU0sSUFBSSxHQUFHLE1BQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsU0FBUyxFQUFFLENBQUMsR0FBRyxDQUFDLEVBQUUsRUFBRSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxFQUFFLENBQUMscUJBQVUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDdkcsZ0JBQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDakIsTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBRTVDLE9BQU8sdUJBQVksQ0FBQywyQkFBMkIsQ0FBQyxNQUFNLEVBQUUsV0FBVyxFQUFFLGVBQWUsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzNHLENBQUM7SUFFRDs7Ozs7Ozs7T0FRRztJQUNILEtBQUssQ0FBQyxpQkFBaUIsQ0FDckIsZ0JBQXdCLEVBQ3hCLGFBQTBDLEVBQzFDLGFBQXFCLEVBQ3JCLGdCQUF3QixFQUN4Qix5QkFBd0QsRUFDeEQsZ0JBQXdCO1FBRXhCLE1BQU0sWUFBWSxHQUFHLE1BQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsU0FBUyxFQUFFLENBQUMsR0FBRyxDQUFDLEVBQUUsRUFBRSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxFQUFFLENBQUMscUJBQVUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDL0csTUFBTSxJQUFJLEdBQUcsTUFBTSxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxFQUFFLFFBQVEsRUFBRSxZQUFZLEVBQUUsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDO1FBQ3hGLE1BQU0sR0FBRyxHQUFHLHVCQUFZLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFL0IsTUFBTSwyQkFBMkIsR0FBRyxDQUFDLE1BQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyxlQUFlLENBQUM7WUFDckUsR0FBRyxFQUFFLElBQUk7WUFDVCxVQUFVLEVBQUU7Z0JBQ1YsS0FBSyxFQUFFLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUM7Z0JBQ3ZDLE1BQU0sRUFBRSxFQUFFLFFBQVEsRUFBRSx5QkFBeUIsRUFBRTthQUNoRDtTQUNGLENBQUMsQ0FBOEIsQ0FBQztRQUVqQyxNQUFNLDRCQUE0QixHQUFHLE1BQU0sdUJBQVksQ0FBQyxxQkFBcUIsQ0FDM0UsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQ3ZCLGFBQWEsRUFDYixhQUFhLEVBQ2IsZ0JBQWdCLEVBQ2hCLGdCQUFnQixFQUNoQixJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FDbEIsQ0FBQztRQUVGLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQztZQUNuQyxVQUFVLEVBQUU7Z0JBQ1YsS0FBSyxFQUFFLDJCQUEyQixDQUFDLEtBQUs7Z0JBQ3hDLGVBQWUsRUFBRSw0QkFBNEIsQ0FBQyxLQUFLLEVBQUU7YUFDdEQ7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0Y7QUE5REQsZ0RBOERDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWJzdHJhY3RVdHhvQ29pbiB9IGZyb20gJ0BiaXRnby1iZXRhL2Fic3RyYWN0LXV0eG8nO1xuaW1wb3J0IHtcbiAgSGFsZlNpZ25lZFV0eG9UcmFuc2FjdGlvbixcbiAgSUluc2NyaXB0aW9uQnVpbGRlcixcbiAgSVdhbGxldCxcbiAgS2V5SW5kaWNlcyxcbiAgUHJlcGFyZWRJbnNjcmlwdGlvblJldmVhbERhdGEsXG4gIFN1Ym1pdFRyYW5zYWN0aW9uUmVzcG9uc2UsXG4gIHhwcnZUb1Jhd1Bydixcbn0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5pbXBvcnQgeyBpbnNjcmlwdGlvbnMgfSBmcm9tICdAYml0Z28tYmV0YS91dHhvLW9yZCc7XG5pbXBvcnQgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5cbmV4cG9ydCBjbGFzcyBJbnNjcmlwdGlvbkJ1aWxkZXIgaW1wbGVtZW50cyBJSW5zY3JpcHRpb25CdWlsZGVyIHtcbiAgcHJpdmF0ZSByZWFkb25seSB3YWxsZXQ6IElXYWxsZXQ7XG4gIHByaXZhdGUgcmVhZG9ubHkgY29pbjogQWJzdHJhY3RVdHhvQ29pbjtcblxuICBjb25zdHJ1Y3Rvcih3YWxsZXQ6IElXYWxsZXQsIGNvaW46IEFic3RyYWN0VXR4b0NvaW4pIHtcbiAgICB0aGlzLndhbGxldCA9IHdhbGxldDtcbiAgICB0aGlzLmNvaW4gPSBjb2luO1xuICB9XG5cbiAgYXN5bmMgcHJlcGFyZVJldmVhbChpbnNjcmlwdGlvbkRhdGE6IEJ1ZmZlciwgY29udGVudFR5cGU6IHN0cmluZyk6IFByb21pc2U8UHJlcGFyZWRJbnNjcmlwdGlvblJldmVhbERhdGE+IHtcbiAgICBjb25zdCB1c2VyID0gYXdhaXQgdGhpcy53YWxsZXQuYmFzZUNvaW4ua2V5Y2hhaW5zKCkuZ2V0KHsgaWQ6IHRoaXMud2FsbGV0LmtleUlkcygpW0tleUluZGljZXMuVVNFUl0gfSk7XG4gICAgYXNzZXJ0KHVzZXIucHViKTtcbiAgICBjb25zdCBwdWJrZXkgPSBCdWZmZXIuZnJvbSh1c2VyLnB1YiwgJ2hleCcpO1xuXG4gICAgcmV0dXJuIGluc2NyaXB0aW9ucy5jcmVhdGVJbnNjcmlwdGlvblJldmVhbERhdGEocHVia2V5LCBjb250ZW50VHlwZSwgaW5zY3JpcHRpb25EYXRhLCB0aGlzLmNvaW4ubmV0d29yayk7XG4gIH1cblxuICAvKipcbiAgICpcbiAgICogQHBhcmFtIHdhbGxldFBhc3NwaHJhc2VcbiAgICogQHBhcmFtIHRhcExlYWZTY3JpcHRcbiAgICogQHBhcmFtIGNvbW1pdEFkZHJlc3NcbiAgICogQHBhcmFtIHVuc2lnbmVkQ29tbWl0VHhcbiAgICogQHBhcmFtIGNvbW1pdFRyYW5zYWN0aW9uVW5zcGVudHNcbiAgICogQHBhcmFtIHJlY2lwaWVudEFkZHJlc3NcbiAgICovXG4gIGFzeW5jIHNpZ25BbmRTZW5kUmV2ZWFsKFxuICAgIHdhbGxldFBhc3NwaHJhc2U6IHN0cmluZyxcbiAgICB0YXBMZWFmU2NyaXB0OiB1dHhvbGliLmJpdGdvLlRhcExlYWZTY3JpcHQsXG4gICAgY29tbWl0QWRkcmVzczogc3RyaW5nLFxuICAgIHVuc2lnbmVkQ29tbWl0VHg6IEJ1ZmZlcixcbiAgICBjb21taXRUcmFuc2FjdGlvblVuc3BlbnRzOiB1dHhvbGliLmJpdGdvLldhbGxldFVuc3BlbnRbXSxcbiAgICByZWNpcGllbnRBZGRyZXNzOiBzdHJpbmdcbiAgKTogUHJvbWlzZTxTdWJtaXRUcmFuc2FjdGlvblJlc3BvbnNlPiB7XG4gICAgY29uc3QgdXNlcktleWNoYWluID0gYXdhaXQgdGhpcy53YWxsZXQuYmFzZUNvaW4ua2V5Y2hhaW5zKCkuZ2V0KHsgaWQ6IHRoaXMud2FsbGV0LmtleUlkcygpW0tleUluZGljZXMuVVNFUl0gfSk7XG4gICAgY29uc3QgeHBydiA9IGF3YWl0IHRoaXMud2FsbGV0LmdldFVzZXJQcnYoeyBrZXljaGFpbjogdXNlcktleWNoYWluLCB3YWxsZXRQYXNzcGhyYXNlIH0pO1xuICAgIGNvbnN0IHBydiA9IHhwcnZUb1Jhd1Bydih4cHJ2KTtcblxuICAgIGNvbnN0IGhhbGZTaWduZWRDb21taXRUcmFuc2FjdGlvbiA9IChhd2FpdCB0aGlzLndhbGxldC5zaWduVHJhbnNhY3Rpb24oe1xuICAgICAgcHJ2OiB4cHJ2LFxuICAgICAgdHhQcmVidWlsZDoge1xuICAgICAgICB0eEhleDogdW5zaWduZWRDb21taXRUeC50b1N0cmluZygnaGV4JyksXG4gICAgICAgIHR4SW5mbzogeyB1bnNwZW50czogY29tbWl0VHJhbnNhY3Rpb25VbnNwZW50cyB9LFxuICAgICAgfSxcbiAgICB9KSkgYXMgSGFsZlNpZ25lZFV0eG9UcmFuc2FjdGlvbjtcblxuICAgIGNvbnN0IGZ1bGx5U2lnbmVkUmV2ZWFsVHJhbnNhY3Rpb24gPSBhd2FpdCBpbnNjcmlwdGlvbnMuc2lnblJldmVhbFRyYW5zYWN0aW9uKFxuICAgICAgQnVmZmVyLmZyb20ocHJ2LCAnaGV4JyksXG4gICAgICB0YXBMZWFmU2NyaXB0LFxuICAgICAgY29tbWl0QWRkcmVzcyxcbiAgICAgIHJlY2lwaWVudEFkZHJlc3MsXG4gICAgICB1bnNpZ25lZENvbW1pdFR4LFxuICAgICAgdGhpcy5jb2luLm5ldHdvcmtcbiAgICApO1xuXG4gICAgcmV0dXJuIHRoaXMud2FsbGV0LnN1Ym1pdFRyYW5zYWN0aW9uKHtcbiAgICAgIGhhbGZTaWduZWQ6IHtcbiAgICAgICAgdHhIZXg6IGhhbGZTaWduZWRDb21taXRUcmFuc2FjdGlvbi50eEhleCxcbiAgICAgICAgc2lnbmVkQ2hpbGRQc2J0OiBmdWxseVNpZ25lZFJldmVhbFRyYW5zYWN0aW9uLnRvSGV4KCksXG4gICAgICB9LFxuICAgIH0pO1xuICB9XG59XG4iXX0=
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inscriptionBuilder.js","sourceRoot":"","sources":["../../src/inscriptionBuilder.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AACA,mDAW8B;AAC9B,8DAAgD;AAChD,mDAO8B;AAC9B,oDAA4B;AAE5B,MAAa,kBAAkB;IAI7B,YAAY,MAAe,EAAE,IAAsB;QACjD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,eAAuB,EAAE,WAAmB;QAC9D,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,qBAAU,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACvG,gBAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAEjB,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,EAAE,eAAe,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QACjG,MAAM,mBAAmB,GAAG,8BAAmB,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAC7D,MAAM,cAAc,GAAG,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,mBAAmB,EAAE,KAAK,CAAC,CAAC,CAAC;QAE7G,OAAO,uBAAY,CAAC,2BAA2B,CAAC,cAAc,EAAE,WAAW,EAAE,eAAe,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACnH,CAAC;IAED;;;;;;;;;;;OAWG;IACH,KAAK,CAAC,eAAe,CACnB,QAAgB,EAChB,SAAiB,EACjB,YAAoB,EACpB,EACE,MAAM,GAAG,MAAM,EACf,QAAQ,GAAG,OAAO,EAClB,sBAAsB,GAAG,wCAA6B,EACtD,iBAAiB,GAAG,MAAM,GAU3B;QAED,gBAAM,CAAC,qBAAU,CAAC,QAAQ,CAAC,CAAC,CAAC;QAC7B,MAAM,EAAE,GAAG,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC;QAChE,gBAAM,CAAC,EAAE,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC;QACxB,MAAM,cAAc,GAAG,IAAI,OAAO,CAAC,KAAK,CAAC,cAAc,CACrD,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;YACX,gBAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;YACd,OAAO,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACzC,CAAC,CAAmC,CACrC,CAAC;QAEF,MAAM,cAAc,GAAG,wBAAa,CAAC,QAAQ,CAAC,CAAC;QAC/C,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,EAAE,MAAM,EAAE,cAAc,CAAC,IAAI,EAAE,CAAC,CAAC;QACtF,8CAA8C;QAC9C,MAAM,QAAQ,GAAG,CAAC,WAAW,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC;QAC5D,MAAM,MAAM,GAAG,EAAE,QAAQ,EAAE,CAAC;QAE5B,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC;YACpD,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,oBAAoB,CAAC,iBAAiB,CAAC;SAC7D,CAAC,CAAC;QACH,MAAM,OAAO,GAAuB;YAClC,oBAAoB,EAAE,SAAS;YAC/B,aAAa,EAAE;gBACb,EAAE,KAAK,EAAE,aAAa,CAAC,KAAK,EAAE,KAAK,EAAE,aAAa,CAAC,KAAK,EAAE;gBAC1D,EAAE,KAAK,EAAE,aAAa,CAAC,KAAK,EAAE,KAAK,EAAE,aAAa,CAAC,KAAK,EAAE;aAC3D;SACF,CAAC;QAEF,MAAM,IAAI,GAAG,2DAAgD,CAC3D,IAAI,CAAC,IAAI,CAAC,OAAO,EACjB;YACE,UAAU,EAAE,cAAc;YAC1B,MAAM;YACN,QAAQ;SACT,EACD,QAAQ,EACR,QAAQ,EACR,OAAO,EACP,EAAE,YAAY,EAAE,GAAG,sBAAsB,EAAE,CAC5C,CAAC;QAEF,OAAO;YACL,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE;YAC1B,KAAK,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,KAAK,EAAE;YACnC,MAAM;YACN,OAAO,EAAE,EAAE,GAAG,EAAE,YAAY,EAAE,SAAS,EAAE,YAAY,CAAC,QAAQ,EAAE,EAAE;SACnE,CAAC;IACJ,CAAC;IAED;;;;;;;;;OASG;IACH,KAAK,CAAC,iBAAiB,CACrB,gBAAwB,EACxB,aAA0C,EAC1C,aAAqB,EACrB,gBAAwB,EACxB,yBAAwD,EACxD,gBAAwB,EACxB,eAAuB;QAEvB,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,qBAAU,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC/G,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,EAAE,QAAQ,EAAE,YAAY,EAAE,gBAAgB,EAAE,CAAC,CAAC;QAExF,MAAM,2BAA2B,GAAG,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC;YACrE,GAAG,EAAE,IAAI;YACT,UAAU,EAAE;gBACV,KAAK,EAAE,gBAAgB,CAAC,QAAQ,CAAC,KAAK,CAAC;gBACvC,MAAM,EAAE,EAAE,QAAQ,EAAE,yBAAyB,EAAE;aAChD;SACF,CAAC,CAA8B,CAAC;QAEjC,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,eAAe,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QAC7F,MAAM,GAAG,GAAG,uBAAY,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAEtC,MAAM,4BAA4B,GAAG,MAAM,uBAAY,CAAC,qBAAqB,CAC3E,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,EACvB,aAAa,EACb,aAAa,EACb,gBAAgB,EAChB,MAAM,CAAC,IAAI,CAAC,2BAA2B,CAAC,KAAK,EAAE,KAAK,CAAC,EACrD,IAAI,CAAC,IAAI,CAAC,OAAO,CAClB,CAAC;QAEF,OAAO,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC;YACnC,UAAU,EAAE;gBACV,KAAK,EAAE,2BAA2B,CAAC,KAAK;gBACxC,eAAe,EAAE,4BAA4B,CAAC,KAAK,EAAE;aACtD;SACF,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,mBAAmB,CACvB,gBAAwB,EACxB,UAAqC;QAErC,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,qBAAU,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC/G,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,EAAE,QAAQ,EAAE,YAAY,EAAE,gBAAgB,EAAE,CAAC,CAAC;QAEjF,MAAM,UAAU,GAAG,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,EAAE,GAAG,EAAE,UAAU,EAAE,CAAC,CAA8B,CAAC;QACzG,OAAO,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC;IACvD,CAAC;CACF;AArKD,gDAqKC","sourcesContent":["import { AbstractUtxoCoin } from '@bitgo-beta/abstract-utxo';\nimport {\n  HalfSignedUtxoTransaction,\n  IInscriptionBuilder,\n  IWallet,\n  KeyIndices,\n  PrebuildTransactionResult,\n  PreparedInscriptionRevealData,\n  SubmitTransactionResponse,\n  Triple,\n  xprvToRawPrv,\n  xpubToCompressedPub,\n} from '@bitgo-beta/sdk-core';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\nimport {\n  createPsbtForSingleInscriptionPassingTransaction,\n  DefaultInscriptionConstraints,\n  InscriptionOutputs,\n  inscriptions,\n  parseSatPoint,\n  isSatPoint,\n} from '@bitgo-beta/utxo-ord';\nimport assert from 'assert';\n\nexport class InscriptionBuilder implements IInscriptionBuilder {\n  private readonly wallet: IWallet;\n  private readonly coin: AbstractUtxoCoin;\n\n  constructor(wallet: IWallet, coin: AbstractUtxoCoin) {\n    this.wallet = wallet;\n    this.coin = coin;\n  }\n\n  async prepareReveal(inscriptionData: Buffer, contentType: string): Promise<PreparedInscriptionRevealData> {\n    const user = await this.wallet.baseCoin.keychains().get({ id: this.wallet.keyIds()[KeyIndices.USER] });\n    assert(user.pub);\n\n    const derived = this.coin.deriveKeyWithSeed({ key: user.pub, seed: inscriptionData.toString() });\n    const compressedPublicKey = xpubToCompressedPub(derived.key);\n    const xOnlyPublicKey = utxolib.bitgo.outputScripts.toXOnlyPublicKey(Buffer.from(compressedPublicKey, 'hex'));\n\n    return inscriptions.createInscriptionRevealData(xOnlyPublicKey, contentType, inscriptionData, this.coin.network);\n  }\n\n  /**\n   * Build a transaction to send an inscription\n   * @param satPoint Satpoint you want to send\n   * @param recipient Address you want to send to\n   * @param feeRateSatKB Fee rate for transaction\n   * @param signer first signer of the transaction\n   * @param cosigner second signer of the transaction\n   * @param inscriptionConstraints.minChangeOutput (optional) the minimum size of the change output\n   * @param inscriptionConstraints.minInscriptionOutput (optional) the minimum number of sats of the output containing the inscription\n   * @param inscriptionConstraints.maxInscriptionOutput (optional) the maximum number of sats of the output containing the inscription\n   * @param changeAddressType Address type of the change address\n   */\n  async prepareTransfer(\n    satPoint: string,\n    recipient: string,\n    feeRateSatKB: number,\n    {\n      signer = 'user',\n      cosigner = 'bitgo',\n      inscriptionConstraints = DefaultInscriptionConstraints,\n      changeAddressType = 'p2tr',\n    }: {\n      signer: utxolib.bitgo.KeyName;\n      cosigner: utxolib.bitgo.KeyName;\n      inscriptionConstraints: {\n        minChangeOutput?: bigint;\n        minInscriptionOutput?: bigint;\n        maxInscriptionOutput?: bigint;\n      };\n      changeAddressType: utxolib.bitgo.outputScripts.ScriptType2Of3;\n    }\n  ): Promise<PrebuildTransactionResult> {\n    assert(isSatPoint(satPoint));\n    const wk = (await this.wallet.baseCoin.keychains().list()).keys;\n    assert(wk.length === 3);\n    const rootWalletKeys = new utxolib.bitgo.RootWalletKeys(\n      wk.map((k) => {\n        assert(k.pub);\n        return utxolib.bip32.fromBase58(k.pub);\n      }) as Triple<utxolib.BIP32Interface>\n    );\n\n    const parsedSatPoint = parseSatPoint(satPoint);\n    const transaction = await this.wallet.getTransaction({ txHash: parsedSatPoint.txid });\n    // TODO(BG-70900): allow supplemental unspents\n    const unspents = [transaction.outputs[parsedSatPoint.vout]];\n    const txInfo = { unspents };\n\n    const changeAddress = await this.wallet.createAddress({\n      chain: utxolib.bitgo.getExternalChainCode(changeAddressType),\n    });\n    const outputs: InscriptionOutputs = {\n      inscriptionRecipient: recipient,\n      changeOutputs: [\n        { chain: changeAddress.chain, index: changeAddress.index },\n        { chain: changeAddress.chain, index: changeAddress.index },\n      ],\n    };\n\n    const psbt = createPsbtForSingleInscriptionPassingTransaction(\n      this.coin.network,\n      {\n        walletKeys: rootWalletKeys,\n        signer,\n        cosigner,\n      },\n      unspents,\n      satPoint,\n      outputs,\n      { feeRateSatKB, ...inscriptionConstraints }\n    );\n\n    return {\n      walletId: this.wallet.id(),\n      txHex: psbt.getUnsignedTx().toHex(),\n      txInfo,\n      feeInfo: { fee: feeRateSatKB, feeString: feeRateSatKB.toString() },\n    };\n  }\n\n  /**\n   *\n   * @param walletPassphrase\n   * @param tapLeafScript\n   * @param commitAddress\n   * @param unsignedCommitTx\n   * @param commitTransactionUnspents\n   * @param recipientAddress\n   * @param inscriptionData\n   */\n  async signAndSendReveal(\n    walletPassphrase: string,\n    tapLeafScript: utxolib.bitgo.TapLeafScript,\n    commitAddress: string,\n    unsignedCommitTx: Buffer,\n    commitTransactionUnspents: utxolib.bitgo.WalletUnspent[],\n    recipientAddress: string,\n    inscriptionData: Buffer\n  ): Promise<SubmitTransactionResponse> {\n    const userKeychain = await this.wallet.baseCoin.keychains().get({ id: this.wallet.keyIds()[KeyIndices.USER] });\n    const xprv = await this.wallet.getUserPrv({ keychain: userKeychain, walletPassphrase });\n\n    const halfSignedCommitTransaction = (await this.wallet.signTransaction({\n      prv: xprv,\n      txPrebuild: {\n        txHex: unsignedCommitTx.toString('hex'),\n        txInfo: { unspents: commitTransactionUnspents },\n      },\n    })) as HalfSignedUtxoTransaction;\n\n    const derived = this.coin.deriveKeyWithSeed({ key: xprv, seed: inscriptionData.toString() });\n    const prv = xprvToRawPrv(derived.key);\n\n    const fullySignedRevealTransaction = await inscriptions.signRevealTransaction(\n      Buffer.from(prv, 'hex'),\n      tapLeafScript,\n      commitAddress,\n      recipientAddress,\n      Buffer.from(halfSignedCommitTransaction.txHex, 'hex'),\n      this.coin.network\n    );\n\n    return this.wallet.submitTransaction({\n      halfSigned: {\n        txHex: halfSignedCommitTransaction.txHex,\n        signedChildPsbt: fullySignedRevealTransaction.toHex(),\n      },\n    });\n  }\n\n  /**\n   * Sign and send a transaction that transfers an inscription\n   * @param walletPassphrase passphrase to unlock your keys\n   * @param txPrebuild this is the output of `inscription.prepareTransfer`\n   */\n  async signAndSendTransfer(\n    walletPassphrase: string,\n    txPrebuild: PrebuildTransactionResult\n  ): Promise<SubmitTransactionResponse> {\n    const userKeychain = await this.wallet.baseCoin.keychains().get({ id: this.wallet.keyIds()[KeyIndices.USER] });\n    const prv = this.wallet.getUserPrv({ keychain: userKeychain, walletPassphrase });\n\n    const halfSigned = (await this.wallet.signTransaction({ prv, txPrebuild })) as HalfSignedUtxoTransaction;\n    return this.wallet.submitTransaction({ halfSigned });\n  }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@bitgo-beta/sdk-coin-btc",
|
|
3
|
-
"version": "1.2.3-alpha.
|
|
3
|
+
"version": "1.2.3-alpha.31",
|
|
4
4
|
"description": "BitGo SDK coin library for Bitcoin",
|
|
5
5
|
"main": "./dist/src/index.js",
|
|
6
6
|
"types": "./dist/src/index.d.ts",
|
|
@@ -40,14 +40,14 @@
|
|
|
40
40
|
]
|
|
41
41
|
},
|
|
42
42
|
"dependencies": {
|
|
43
|
-
"@bitgo-beta/abstract-utxo": "1.6.1-alpha.
|
|
44
|
-
"@bitgo-beta/sdk-core": "2.4.1-alpha.
|
|
45
|
-
"@bitgo-beta/utxo-lib": "4.0.1-alpha.
|
|
43
|
+
"@bitgo-beta/abstract-utxo": "1.6.1-alpha.31",
|
|
44
|
+
"@bitgo-beta/sdk-core": "2.4.1-alpha.31",
|
|
45
|
+
"@bitgo-beta/utxo-lib": "4.0.1-alpha.31",
|
|
46
46
|
"@bitgo-beta/utxo-ord": "^1.0.0"
|
|
47
47
|
},
|
|
48
48
|
"devDependencies": {
|
|
49
|
-
"@bitgo-beta/sdk-api": "1.6.1-alpha.
|
|
49
|
+
"@bitgo-beta/sdk-api": "1.6.1-alpha.31",
|
|
50
50
|
"@bitgo-beta/sdk-test": "^1.2.15"
|
|
51
51
|
},
|
|
52
|
-
"gitHead": "
|
|
52
|
+
"gitHead": "eb8ffbe9497bf507509df2d677d2b7fc1319800c"
|
|
53
53
|
}
|