otx-btc-wallet-connectors 0.1.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/README.md +554 -0
- package/dist/base-IAFq7sd8.d.mts +53 -0
- package/dist/base-IAFq7sd8.d.ts +53 -0
- package/dist/binance/index.d.mts +81 -0
- package/dist/binance/index.d.ts +81 -0
- package/dist/binance/index.js +13 -0
- package/dist/binance/index.js.map +1 -0
- package/dist/binance/index.mjs +4 -0
- package/dist/binance/index.mjs.map +1 -0
- package/dist/bitget/index.d.mts +84 -0
- package/dist/bitget/index.d.ts +84 -0
- package/dist/bitget/index.js +13 -0
- package/dist/bitget/index.js.map +1 -0
- package/dist/bitget/index.mjs +4 -0
- package/dist/bitget/index.mjs.map +1 -0
- package/dist/chunk-5Z5Q2Y75.mjs +91 -0
- package/dist/chunk-5Z5Q2Y75.mjs.map +1 -0
- package/dist/chunk-7KK2LZLZ.mjs +208 -0
- package/dist/chunk-7KK2LZLZ.mjs.map +1 -0
- package/dist/chunk-AW2JZIHR.mjs +753 -0
- package/dist/chunk-AW2JZIHR.mjs.map +1 -0
- package/dist/chunk-EIJOSZXZ.js +331 -0
- package/dist/chunk-EIJOSZXZ.js.map +1 -0
- package/dist/chunk-EQHR7P7G.js +541 -0
- package/dist/chunk-EQHR7P7G.js.map +1 -0
- package/dist/chunk-EWRXLZO4.mjs +539 -0
- package/dist/chunk-EWRXLZO4.mjs.map +1 -0
- package/dist/chunk-FISNQZZ7.js +802 -0
- package/dist/chunk-FISNQZZ7.js.map +1 -0
- package/dist/chunk-HL4WDMGS.js +200 -0
- package/dist/chunk-HL4WDMGS.js.map +1 -0
- package/dist/chunk-IPYWR76I.js +314 -0
- package/dist/chunk-IPYWR76I.js.map +1 -0
- package/dist/chunk-JYYNWR5G.js +142 -0
- package/dist/chunk-JYYNWR5G.js.map +1 -0
- package/dist/chunk-LNKTYZJM.js +701 -0
- package/dist/chunk-LNKTYZJM.js.map +1 -0
- package/dist/chunk-LVZMONQL.mjs +699 -0
- package/dist/chunk-LVZMONQL.mjs.map +1 -0
- package/dist/chunk-MFXLQWOE.js +93 -0
- package/dist/chunk-MFXLQWOE.js.map +1 -0
- package/dist/chunk-NBIA4TTE.mjs +204 -0
- package/dist/chunk-NBIA4TTE.mjs.map +1 -0
- package/dist/chunk-O4DD2XJ2.js +206 -0
- package/dist/chunk-O4DD2XJ2.js.map +1 -0
- package/dist/chunk-P7HVBU2B.mjs +140 -0
- package/dist/chunk-P7HVBU2B.mjs.map +1 -0
- package/dist/chunk-Q7QVQYEB.js +210 -0
- package/dist/chunk-Q7QVQYEB.js.map +1 -0
- package/dist/chunk-RLZEG6KL.mjs +329 -0
- package/dist/chunk-RLZEG6KL.mjs.map +1 -0
- package/dist/chunk-SYLDBJ75.mjs +246 -0
- package/dist/chunk-SYLDBJ75.mjs.map +1 -0
- package/dist/chunk-TTEUU3CI.mjs +198 -0
- package/dist/chunk-TTEUU3CI.mjs.map +1 -0
- package/dist/chunk-V66BXDTR.mjs +292 -0
- package/dist/chunk-V66BXDTR.mjs.map +1 -0
- package/dist/chunk-X77ZT4OI.js +268 -0
- package/dist/chunk-X77ZT4OI.js.map +1 -0
- package/dist/imtoken/index.d.mts +116 -0
- package/dist/imtoken/index.d.ts +116 -0
- package/dist/imtoken/index.js +14 -0
- package/dist/imtoken/index.js.map +1 -0
- package/dist/imtoken/index.mjs +5 -0
- package/dist/imtoken/index.mjs.map +1 -0
- package/dist/index.d.mts +14 -0
- package/dist/index.d.ts +14 -0
- package/dist/index.js +170 -0
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +13 -0
- package/dist/index.mjs.map +1 -0
- package/dist/ledger/index.d.mts +290 -0
- package/dist/ledger/index.d.ts +290 -0
- package/dist/ledger/index.js +14 -0
- package/dist/ledger/index.js.map +1 -0
- package/dist/ledger/index.mjs +5 -0
- package/dist/ledger/index.mjs.map +1 -0
- package/dist/okx/index.d.mts +88 -0
- package/dist/okx/index.d.ts +88 -0
- package/dist/okx/index.js +13 -0
- package/dist/okx/index.js.map +1 -0
- package/dist/okx/index.mjs +4 -0
- package/dist/okx/index.mjs.map +1 -0
- package/dist/phantom/index.d.mts +96 -0
- package/dist/phantom/index.d.ts +96 -0
- package/dist/phantom/index.js +14 -0
- package/dist/phantom/index.js.map +1 -0
- package/dist/phantom/index.mjs +5 -0
- package/dist/phantom/index.mjs.map +1 -0
- package/dist/psbt-builder-CFOs69Z5.d.mts +131 -0
- package/dist/psbt-builder-CFOs69Z5.d.ts +131 -0
- package/dist/trezor/index.d.mts +155 -0
- package/dist/trezor/index.d.ts +155 -0
- package/dist/trezor/index.js +14 -0
- package/dist/trezor/index.js.map +1 -0
- package/dist/trezor/index.mjs +5 -0
- package/dist/trezor/index.mjs.map +1 -0
- package/dist/unisat/index.d.mts +75 -0
- package/dist/unisat/index.d.ts +75 -0
- package/dist/unisat/index.js +13 -0
- package/dist/unisat/index.js.map +1 -0
- package/dist/unisat/index.mjs +4 -0
- package/dist/unisat/index.mjs.map +1 -0
- package/dist/utils/index.d.mts +398 -0
- package/dist/utils/index.d.ts +398 -0
- package/dist/utils/index.js +120 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/index.mjs +3 -0
- package/dist/utils/index.mjs.map +1 -0
- package/dist/xverse/index.d.mts +79 -0
- package/dist/xverse/index.d.ts +79 -0
- package/dist/xverse/index.js +13 -0
- package/dist/xverse/index.js.map +1 -0
- package/dist/xverse/index.mjs +4 -0
- package/dist/xverse/index.mjs.map +1 -0
- package/package.json +108 -0
- package/src/base.ts +132 -0
- package/src/binance/BinanceConnector.ts +307 -0
- package/src/binance/index.ts +1 -0
- package/src/bitget/BitgetConnector.ts +301 -0
- package/src/bitget/index.ts +1 -0
- package/src/imtoken/ImTokenConnector.ts +420 -0
- package/src/imtoken/index.ts +2 -0
- package/src/index.ts +78 -0
- package/src/ledger/LedgerConnector.ts +1019 -0
- package/src/ledger/index.ts +8 -0
- package/src/okx/OKXConnector.ts +230 -0
- package/src/okx/index.ts +1 -0
- package/src/phantom/PhantomConnector.ts +381 -0
- package/src/phantom/index.ts +2 -0
- package/src/trezor/TrezorConnector.ts +824 -0
- package/src/trezor/index.ts +6 -0
- package/src/unisat/UnisatConnector.ts +312 -0
- package/src/unisat/index.ts +1 -0
- package/src/utils/blockstream.ts +230 -0
- package/src/utils/btc-service.ts +364 -0
- package/src/utils/index.ts +56 -0
- package/src/utils/mempool.ts +232 -0
- package/src/utils/psbt-builder.ts +492 -0
- package/src/utils/types.ts +183 -0
- package/src/xverse/XverseConnector.ts +479 -0
- package/src/xverse/index.ts +1 -0
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { BitcoinNetwork, WalletAccount, SignPsbtOptions } from 'otx-btc-wallet-core';
|
|
2
|
+
import { B as BaseConnector } from '../base-IAFq7sd8.mjs';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Binance sign PSBT options
|
|
6
|
+
* @see https://developers.binance.com/docs/binance-w3w/bitcoin-provider
|
|
7
|
+
*/
|
|
8
|
+
interface BinanceSignPsbtOptions {
|
|
9
|
+
autoFinalized?: boolean;
|
|
10
|
+
toSignInputs?: Array<{
|
|
11
|
+
index: number;
|
|
12
|
+
address?: string;
|
|
13
|
+
publicKey?: string;
|
|
14
|
+
sighashTypes?: number[];
|
|
15
|
+
disableTweakSigner?: boolean;
|
|
16
|
+
}>;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Binance Bitcoin provider interface
|
|
20
|
+
* Provider is accessible via window.binancew3w.bitcoin
|
|
21
|
+
* @see https://developers.binance.com/docs/binance-w3w/bitcoin-provider
|
|
22
|
+
*/
|
|
23
|
+
interface BinanceBitcoinProvider {
|
|
24
|
+
requestAccounts(): Promise<string[]>;
|
|
25
|
+
getAccounts(): Promise<string[]>;
|
|
26
|
+
getPublicKey(): Promise<string>;
|
|
27
|
+
getBalance(): Promise<{
|
|
28
|
+
confirmed: number;
|
|
29
|
+
unconfirmed: number;
|
|
30
|
+
total: number;
|
|
31
|
+
}>;
|
|
32
|
+
getNetwork(): Promise<string>;
|
|
33
|
+
switchNetwork(network: 'livenet' | 'testnet' | 'signet'): Promise<boolean>;
|
|
34
|
+
signMessage(msg: string, type?: 'ecdsa' | 'bip322-simple'): Promise<string>;
|
|
35
|
+
signPsbt(psbtHex: string, options?: BinanceSignPsbtOptions): Promise<string>;
|
|
36
|
+
signPsbts(psbtHexs: string[], options?: BinanceSignPsbtOptions[]): Promise<string[]>;
|
|
37
|
+
pushPsbt(psbtHex: string): Promise<string>;
|
|
38
|
+
sendBitcoin(toAddress: string, satoshis: number, options?: {
|
|
39
|
+
feeRate?: number;
|
|
40
|
+
}): Promise<string>;
|
|
41
|
+
on(event: 'accountsChanged', callback: (accounts: string[]) => void): void;
|
|
42
|
+
on(event: 'networkChanged', callback: (network: string) => void): void;
|
|
43
|
+
removeListener(event: 'accountsChanged', callback: (accounts: string[]) => void): void;
|
|
44
|
+
removeListener(event: 'networkChanged', callback: (network: string) => void): void;
|
|
45
|
+
}
|
|
46
|
+
declare global {
|
|
47
|
+
interface Window {
|
|
48
|
+
binancew3w?: {
|
|
49
|
+
bitcoin?: BinanceBitcoinProvider;
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Binance Wallet Connector
|
|
55
|
+
*
|
|
56
|
+
* @see https://developers.binance.com/docs/binance-w3w/bitcoin-provider
|
|
57
|
+
*/
|
|
58
|
+
declare class BinanceConnector extends BaseConnector {
|
|
59
|
+
readonly id = "binance";
|
|
60
|
+
readonly name = "Binance Wallet";
|
|
61
|
+
readonly icon = "";
|
|
62
|
+
private _removeAccountChangeListener;
|
|
63
|
+
private _removeNetworkChangeListener;
|
|
64
|
+
protected getProvider(): BinanceBitcoinProvider | undefined;
|
|
65
|
+
connect(network?: BitcoinNetwork): Promise<WalletAccount>;
|
|
66
|
+
private ensureNetwork;
|
|
67
|
+
private setupEventListeners;
|
|
68
|
+
private removeEventListeners;
|
|
69
|
+
disconnect(): Promise<void>;
|
|
70
|
+
getAccounts(): Promise<WalletAccount[]>;
|
|
71
|
+
signMessage(message: string): Promise<string>;
|
|
72
|
+
signPsbt(psbtHex: string, options?: SignPsbtOptions): Promise<string>;
|
|
73
|
+
signPsbts(psbtHexs: string[], options?: SignPsbtOptions): Promise<string[]>;
|
|
74
|
+
sendTransaction(to: string, satoshis: number): Promise<string>;
|
|
75
|
+
getNetwork(): Promise<BitcoinNetwork>;
|
|
76
|
+
switchNetwork(network: BitcoinNetwork): Promise<void>;
|
|
77
|
+
private mapNetwork;
|
|
78
|
+
private mapToBinanceNetwork;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
export { BinanceConnector };
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { BitcoinNetwork, WalletAccount, SignPsbtOptions } from 'otx-btc-wallet-core';
|
|
2
|
+
import { B as BaseConnector } from '../base-IAFq7sd8.js';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Binance sign PSBT options
|
|
6
|
+
* @see https://developers.binance.com/docs/binance-w3w/bitcoin-provider
|
|
7
|
+
*/
|
|
8
|
+
interface BinanceSignPsbtOptions {
|
|
9
|
+
autoFinalized?: boolean;
|
|
10
|
+
toSignInputs?: Array<{
|
|
11
|
+
index: number;
|
|
12
|
+
address?: string;
|
|
13
|
+
publicKey?: string;
|
|
14
|
+
sighashTypes?: number[];
|
|
15
|
+
disableTweakSigner?: boolean;
|
|
16
|
+
}>;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Binance Bitcoin provider interface
|
|
20
|
+
* Provider is accessible via window.binancew3w.bitcoin
|
|
21
|
+
* @see https://developers.binance.com/docs/binance-w3w/bitcoin-provider
|
|
22
|
+
*/
|
|
23
|
+
interface BinanceBitcoinProvider {
|
|
24
|
+
requestAccounts(): Promise<string[]>;
|
|
25
|
+
getAccounts(): Promise<string[]>;
|
|
26
|
+
getPublicKey(): Promise<string>;
|
|
27
|
+
getBalance(): Promise<{
|
|
28
|
+
confirmed: number;
|
|
29
|
+
unconfirmed: number;
|
|
30
|
+
total: number;
|
|
31
|
+
}>;
|
|
32
|
+
getNetwork(): Promise<string>;
|
|
33
|
+
switchNetwork(network: 'livenet' | 'testnet' | 'signet'): Promise<boolean>;
|
|
34
|
+
signMessage(msg: string, type?: 'ecdsa' | 'bip322-simple'): Promise<string>;
|
|
35
|
+
signPsbt(psbtHex: string, options?: BinanceSignPsbtOptions): Promise<string>;
|
|
36
|
+
signPsbts(psbtHexs: string[], options?: BinanceSignPsbtOptions[]): Promise<string[]>;
|
|
37
|
+
pushPsbt(psbtHex: string): Promise<string>;
|
|
38
|
+
sendBitcoin(toAddress: string, satoshis: number, options?: {
|
|
39
|
+
feeRate?: number;
|
|
40
|
+
}): Promise<string>;
|
|
41
|
+
on(event: 'accountsChanged', callback: (accounts: string[]) => void): void;
|
|
42
|
+
on(event: 'networkChanged', callback: (network: string) => void): void;
|
|
43
|
+
removeListener(event: 'accountsChanged', callback: (accounts: string[]) => void): void;
|
|
44
|
+
removeListener(event: 'networkChanged', callback: (network: string) => void): void;
|
|
45
|
+
}
|
|
46
|
+
declare global {
|
|
47
|
+
interface Window {
|
|
48
|
+
binancew3w?: {
|
|
49
|
+
bitcoin?: BinanceBitcoinProvider;
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Binance Wallet Connector
|
|
55
|
+
*
|
|
56
|
+
* @see https://developers.binance.com/docs/binance-w3w/bitcoin-provider
|
|
57
|
+
*/
|
|
58
|
+
declare class BinanceConnector extends BaseConnector {
|
|
59
|
+
readonly id = "binance";
|
|
60
|
+
readonly name = "Binance Wallet";
|
|
61
|
+
readonly icon = "";
|
|
62
|
+
private _removeAccountChangeListener;
|
|
63
|
+
private _removeNetworkChangeListener;
|
|
64
|
+
protected getProvider(): BinanceBitcoinProvider | undefined;
|
|
65
|
+
connect(network?: BitcoinNetwork): Promise<WalletAccount>;
|
|
66
|
+
private ensureNetwork;
|
|
67
|
+
private setupEventListeners;
|
|
68
|
+
private removeEventListeners;
|
|
69
|
+
disconnect(): Promise<void>;
|
|
70
|
+
getAccounts(): Promise<WalletAccount[]>;
|
|
71
|
+
signMessage(message: string): Promise<string>;
|
|
72
|
+
signPsbt(psbtHex: string, options?: SignPsbtOptions): Promise<string>;
|
|
73
|
+
signPsbts(psbtHexs: string[], options?: SignPsbtOptions): Promise<string[]>;
|
|
74
|
+
sendTransaction(to: string, satoshis: number): Promise<string>;
|
|
75
|
+
getNetwork(): Promise<BitcoinNetwork>;
|
|
76
|
+
switchNetwork(network: BitcoinNetwork): Promise<void>;
|
|
77
|
+
private mapNetwork;
|
|
78
|
+
private mapToBinanceNetwork;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
export { BinanceConnector };
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var chunkO4DD2XJ2_js = require('../chunk-O4DD2XJ2.js');
|
|
4
|
+
require('../chunk-MFXLQWOE.js');
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
Object.defineProperty(exports, "BinanceConnector", {
|
|
9
|
+
enumerable: true,
|
|
10
|
+
get: function () { return chunkO4DD2XJ2_js.BinanceConnector; }
|
|
11
|
+
});
|
|
12
|
+
//# sourceMappingURL=out.js.map
|
|
13
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":""}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { BitcoinNetwork, WalletAccount, SignPsbtOptions } from 'otx-btc-wallet-core';
|
|
2
|
+
import { B as BaseConnector } from '../base-IAFq7sd8.mjs';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Bitget sign PSBT options
|
|
6
|
+
* @see https://web3.bitget.com/en/docs/connect/mainnet/btc/
|
|
7
|
+
*/
|
|
8
|
+
interface BitgetSignPsbtOptions {
|
|
9
|
+
autoFinalized?: boolean;
|
|
10
|
+
toSignInputs?: Array<{
|
|
11
|
+
index: number;
|
|
12
|
+
address?: string;
|
|
13
|
+
publicKey?: string;
|
|
14
|
+
sighashTypes?: number[];
|
|
15
|
+
disableTweakSigner?: boolean;
|
|
16
|
+
}>;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Bitget Bitcoin provider interface
|
|
20
|
+
* Provider is accessible via window.bitkeep.unisat
|
|
21
|
+
* @see https://web3.bitget.com/en/docs/connect/mainnet/btc/
|
|
22
|
+
*/
|
|
23
|
+
interface BitgetBitcoinProvider {
|
|
24
|
+
requestAccounts(): Promise<string[]>;
|
|
25
|
+
getAccounts(): Promise<string[]>;
|
|
26
|
+
getPublicKey(): Promise<string>;
|
|
27
|
+
getBalance(): Promise<{
|
|
28
|
+
confirmed: number;
|
|
29
|
+
unconfirmed: number;
|
|
30
|
+
total: number;
|
|
31
|
+
}>;
|
|
32
|
+
getNetwork(): Promise<string>;
|
|
33
|
+
switchNetwork(network: 'livenet' | 'testnet' | 'signet'): Promise<void>;
|
|
34
|
+
signMessage(msg: string, type?: 'ecdsa' | 'bip322-simple'): Promise<string>;
|
|
35
|
+
signPsbt(psbtHex: string, options?: BitgetSignPsbtOptions): Promise<string>;
|
|
36
|
+
signPsbts(psbtHexs: string[], options?: BitgetSignPsbtOptions[]): Promise<string[]>;
|
|
37
|
+
pushPsbt(psbtHex: string): Promise<string>;
|
|
38
|
+
sendBitcoin(toAddress: string, satoshis: number, options?: {
|
|
39
|
+
feeRate?: number;
|
|
40
|
+
}): Promise<string>;
|
|
41
|
+
pushTx(options: {
|
|
42
|
+
rawtx: string;
|
|
43
|
+
}): Promise<string>;
|
|
44
|
+
on(event: 'accountsChanged', callback: (accounts: string[]) => void): void;
|
|
45
|
+
on(event: 'networkChanged', callback: (network: string) => void): void;
|
|
46
|
+
removeListener(event: 'accountsChanged', callback: (accounts: string[]) => void): void;
|
|
47
|
+
removeListener(event: 'networkChanged', callback: (network: string) => void): void;
|
|
48
|
+
}
|
|
49
|
+
declare global {
|
|
50
|
+
interface Window {
|
|
51
|
+
bitkeep?: {
|
|
52
|
+
unisat?: BitgetBitcoinProvider;
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Bitget Wallet Connector
|
|
58
|
+
*
|
|
59
|
+
* @see https://web3.bitget.com/en/docs/connect/mainnet/btc/
|
|
60
|
+
*/
|
|
61
|
+
declare class BitgetConnector extends BaseConnector {
|
|
62
|
+
readonly id = "bitget";
|
|
63
|
+
readonly name = "Bitget Wallet";
|
|
64
|
+
readonly icon = "";
|
|
65
|
+
private _removeAccountChangeListener;
|
|
66
|
+
private _removeNetworkChangeListener;
|
|
67
|
+
protected getProvider(): BitgetBitcoinProvider | undefined;
|
|
68
|
+
connect(network?: BitcoinNetwork): Promise<WalletAccount>;
|
|
69
|
+
private ensureNetwork;
|
|
70
|
+
private setupEventListeners;
|
|
71
|
+
private removeEventListeners;
|
|
72
|
+
disconnect(): Promise<void>;
|
|
73
|
+
getAccounts(): Promise<WalletAccount[]>;
|
|
74
|
+
signMessage(message: string): Promise<string>;
|
|
75
|
+
signPsbt(psbtHex: string, options?: SignPsbtOptions): Promise<string>;
|
|
76
|
+
signPsbts(psbtHexs: string[], options?: SignPsbtOptions): Promise<string[]>;
|
|
77
|
+
sendTransaction(to: string, satoshis: number): Promise<string>;
|
|
78
|
+
getNetwork(): Promise<BitcoinNetwork>;
|
|
79
|
+
switchNetwork(network: BitcoinNetwork): Promise<void>;
|
|
80
|
+
private mapNetwork;
|
|
81
|
+
private mapToBitgetNetwork;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
export { BitgetConnector };
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { BitcoinNetwork, WalletAccount, SignPsbtOptions } from 'otx-btc-wallet-core';
|
|
2
|
+
import { B as BaseConnector } from '../base-IAFq7sd8.js';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Bitget sign PSBT options
|
|
6
|
+
* @see https://web3.bitget.com/en/docs/connect/mainnet/btc/
|
|
7
|
+
*/
|
|
8
|
+
interface BitgetSignPsbtOptions {
|
|
9
|
+
autoFinalized?: boolean;
|
|
10
|
+
toSignInputs?: Array<{
|
|
11
|
+
index: number;
|
|
12
|
+
address?: string;
|
|
13
|
+
publicKey?: string;
|
|
14
|
+
sighashTypes?: number[];
|
|
15
|
+
disableTweakSigner?: boolean;
|
|
16
|
+
}>;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Bitget Bitcoin provider interface
|
|
20
|
+
* Provider is accessible via window.bitkeep.unisat
|
|
21
|
+
* @see https://web3.bitget.com/en/docs/connect/mainnet/btc/
|
|
22
|
+
*/
|
|
23
|
+
interface BitgetBitcoinProvider {
|
|
24
|
+
requestAccounts(): Promise<string[]>;
|
|
25
|
+
getAccounts(): Promise<string[]>;
|
|
26
|
+
getPublicKey(): Promise<string>;
|
|
27
|
+
getBalance(): Promise<{
|
|
28
|
+
confirmed: number;
|
|
29
|
+
unconfirmed: number;
|
|
30
|
+
total: number;
|
|
31
|
+
}>;
|
|
32
|
+
getNetwork(): Promise<string>;
|
|
33
|
+
switchNetwork(network: 'livenet' | 'testnet' | 'signet'): Promise<void>;
|
|
34
|
+
signMessage(msg: string, type?: 'ecdsa' | 'bip322-simple'): Promise<string>;
|
|
35
|
+
signPsbt(psbtHex: string, options?: BitgetSignPsbtOptions): Promise<string>;
|
|
36
|
+
signPsbts(psbtHexs: string[], options?: BitgetSignPsbtOptions[]): Promise<string[]>;
|
|
37
|
+
pushPsbt(psbtHex: string): Promise<string>;
|
|
38
|
+
sendBitcoin(toAddress: string, satoshis: number, options?: {
|
|
39
|
+
feeRate?: number;
|
|
40
|
+
}): Promise<string>;
|
|
41
|
+
pushTx(options: {
|
|
42
|
+
rawtx: string;
|
|
43
|
+
}): Promise<string>;
|
|
44
|
+
on(event: 'accountsChanged', callback: (accounts: string[]) => void): void;
|
|
45
|
+
on(event: 'networkChanged', callback: (network: string) => void): void;
|
|
46
|
+
removeListener(event: 'accountsChanged', callback: (accounts: string[]) => void): void;
|
|
47
|
+
removeListener(event: 'networkChanged', callback: (network: string) => void): void;
|
|
48
|
+
}
|
|
49
|
+
declare global {
|
|
50
|
+
interface Window {
|
|
51
|
+
bitkeep?: {
|
|
52
|
+
unisat?: BitgetBitcoinProvider;
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Bitget Wallet Connector
|
|
58
|
+
*
|
|
59
|
+
* @see https://web3.bitget.com/en/docs/connect/mainnet/btc/
|
|
60
|
+
*/
|
|
61
|
+
declare class BitgetConnector extends BaseConnector {
|
|
62
|
+
readonly id = "bitget";
|
|
63
|
+
readonly name = "Bitget Wallet";
|
|
64
|
+
readonly icon = "";
|
|
65
|
+
private _removeAccountChangeListener;
|
|
66
|
+
private _removeNetworkChangeListener;
|
|
67
|
+
protected getProvider(): BitgetBitcoinProvider | undefined;
|
|
68
|
+
connect(network?: BitcoinNetwork): Promise<WalletAccount>;
|
|
69
|
+
private ensureNetwork;
|
|
70
|
+
private setupEventListeners;
|
|
71
|
+
private removeEventListeners;
|
|
72
|
+
disconnect(): Promise<void>;
|
|
73
|
+
getAccounts(): Promise<WalletAccount[]>;
|
|
74
|
+
signMessage(message: string): Promise<string>;
|
|
75
|
+
signPsbt(psbtHex: string, options?: SignPsbtOptions): Promise<string>;
|
|
76
|
+
signPsbts(psbtHexs: string[], options?: SignPsbtOptions): Promise<string[]>;
|
|
77
|
+
sendTransaction(to: string, satoshis: number): Promise<string>;
|
|
78
|
+
getNetwork(): Promise<BitcoinNetwork>;
|
|
79
|
+
switchNetwork(network: BitcoinNetwork): Promise<void>;
|
|
80
|
+
private mapNetwork;
|
|
81
|
+
private mapToBitgetNetwork;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
export { BitgetConnector };
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var chunkHL4WDMGS_js = require('../chunk-HL4WDMGS.js');
|
|
4
|
+
require('../chunk-MFXLQWOE.js');
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
Object.defineProperty(exports, "BitgetConnector", {
|
|
9
|
+
enumerable: true,
|
|
10
|
+
get: function () { return chunkHL4WDMGS_js.BitgetConnector; }
|
|
11
|
+
});
|
|
12
|
+
//# sourceMappingURL=out.js.map
|
|
13
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":""}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
// src/base.ts
|
|
2
|
+
var BaseConnector = class {
|
|
3
|
+
constructor() {
|
|
4
|
+
this._ready = false;
|
|
5
|
+
this._accountsChangedCallbacks = /* @__PURE__ */ new Set();
|
|
6
|
+
this._networkChangedCallbacks = /* @__PURE__ */ new Set();
|
|
7
|
+
this.checkReady();
|
|
8
|
+
if (typeof window !== "undefined") {
|
|
9
|
+
if (document.readyState === "complete") {
|
|
10
|
+
this.checkReady();
|
|
11
|
+
} else {
|
|
12
|
+
window.addEventListener("load", () => this.checkReady());
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
get ready() {
|
|
17
|
+
return this._ready;
|
|
18
|
+
}
|
|
19
|
+
set ready(value) {
|
|
20
|
+
this._ready = value;
|
|
21
|
+
}
|
|
22
|
+
checkReady() {
|
|
23
|
+
this._ready = !!this.getProvider();
|
|
24
|
+
}
|
|
25
|
+
ensureInstalled() {
|
|
26
|
+
if (!this.ready) {
|
|
27
|
+
throw new Error(`${this.name} wallet is not installed`);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
inferAddressType(address) {
|
|
31
|
+
if (address.startsWith("bc1q") || address.startsWith("tb1q")) {
|
|
32
|
+
return "segwit";
|
|
33
|
+
}
|
|
34
|
+
if (address.startsWith("bc1p") || address.startsWith("tb1p")) {
|
|
35
|
+
return "taproot";
|
|
36
|
+
}
|
|
37
|
+
if (address.startsWith("3") || address.startsWith("2")) {
|
|
38
|
+
return "nested-segwit";
|
|
39
|
+
}
|
|
40
|
+
return "legacy";
|
|
41
|
+
}
|
|
42
|
+
handleError(error) {
|
|
43
|
+
console.error("Exception in connector", this.id, error);
|
|
44
|
+
throw error;
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Subscribe to account changes
|
|
48
|
+
*/
|
|
49
|
+
onAccountsChanged(callback) {
|
|
50
|
+
this._accountsChangedCallbacks.add(callback);
|
|
51
|
+
return () => {
|
|
52
|
+
this._accountsChangedCallbacks.delete(callback);
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Subscribe to network changes
|
|
57
|
+
*/
|
|
58
|
+
onNetworkChanged(callback) {
|
|
59
|
+
this._networkChangedCallbacks.add(callback);
|
|
60
|
+
return () => {
|
|
61
|
+
this._networkChangedCallbacks.delete(callback);
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Emit account change event
|
|
66
|
+
*/
|
|
67
|
+
emitAccountsChanged(accounts) {
|
|
68
|
+
for (const callback of this._accountsChangedCallbacks) {
|
|
69
|
+
callback(accounts);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Emit network change event
|
|
74
|
+
*/
|
|
75
|
+
emitNetworkChanged(network) {
|
|
76
|
+
for (const callback of this._networkChangedCallbacks) {
|
|
77
|
+
callback(network);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Clean up all listeners
|
|
82
|
+
*/
|
|
83
|
+
cleanup() {
|
|
84
|
+
this._accountsChangedCallbacks.clear();
|
|
85
|
+
this._networkChangedCallbacks.clear();
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
|
|
89
|
+
export { BaseConnector };
|
|
90
|
+
//# sourceMappingURL=out.js.map
|
|
91
|
+
//# sourceMappingURL=chunk-5Z5Q2Y75.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/base.ts"],"names":[],"mappings":";AAYO,IAAe,gBAAf,MAAyD;AAAA,EAW9D,cAAc;AANd,SAAQ,SAAS;AACjB,SAAQ,4BACN,oBAAI,IAAI;AACV,SAAQ,2BACN,oBAAI,IAAI;AAGR,SAAK,WAAW;AAEhB,QAAI,OAAO,WAAW,aAAa;AACjC,UAAI,SAAS,eAAe,YAAY;AACtC,aAAK,WAAW;AAAA,MAClB,OAAO;AACL,eAAO,iBAAiB,QAAQ,MAAM,KAAK,WAAW,CAAC;AAAA,MACzD;AAAA,IACF;AAAA,EACF;AAAA,EAEA,IAAI,QAAiB;AACnB,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAc,MAAM,OAAgB;AAClC,SAAK,SAAS;AAAA,EAChB;AAAA,EAEU,aAAmB;AAC3B,SAAK,SAAS,CAAC,CAAC,KAAK,YAAY;AAAA,EACnC;AAAA,EACU,kBAAwB;AAChC,QAAI,CAAC,KAAK,OAAO;AACf,YAAM,IAAI,MAAM,GAAG,KAAK,IAAI,0BAA0B;AAAA,IACxD;AAAA,EACF;AAAA,EACU,iBAAiB,SAA8B;AACvD,QAAI,QAAQ,WAAW,MAAM,KAAK,QAAQ,WAAW,MAAM,GAAG;AAC5D,aAAO;AAAA,IACT;AACA,QAAI,QAAQ,WAAW,MAAM,KAAK,QAAQ,WAAW,MAAM,GAAG;AAC5D,aAAO;AAAA,IACT;AACA,QAAI,QAAQ,WAAW,GAAG,KAAK,QAAQ,WAAW,GAAG,GAAG;AACtD,aAAO;AAAA,IACT;AACA,WAAO;AAAA,EACT;AAAA,EAEU,YAAY,OAAuB;AAC3C,YAAQ,MAAM,0BAA0B,KAAK,IAAI,KAAK;AAEtD,UAAM;AAAA,EACR;AAAA;AAAA;AAAA;AAAA,EAqBA,kBAAkB,UAA2D;AAC3E,SAAK,0BAA0B,IAAI,QAAQ;AAC3C,WAAO,MAAM;AACX,WAAK,0BAA0B,OAAO,QAAQ;AAAA,IAChD;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,iBAAiB,UAAyD;AACxE,SAAK,yBAAyB,IAAI,QAAQ;AAC1C,WAAO,MAAM;AACX,WAAK,yBAAyB,OAAO,QAAQ;AAAA,IAC/C;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKU,oBAAoB,UAAiC;AAC7D,eAAW,YAAY,KAAK,2BAA2B;AACrD,eAAS,QAAQ;AAAA,IACnB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKU,mBAAmB,SAA+B;AAC1D,eAAW,YAAY,KAAK,0BAA0B;AACpD,eAAS,OAAO;AAAA,IAClB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKU,UAAgB;AACxB,SAAK,0BAA0B,MAAM;AACrC,SAAK,yBAAyB,MAAM;AAAA,EACtC;AACF","sourcesContent":["import type {\n BitcoinConnector,\n WalletAccount,\n BitcoinNetwork,\n SignPsbtOptions,\n AddressType,\n} from 'otx-btc-wallet-core';\n\n/**\n * Abstract base class for all wallet connectors\n * Provides common functionality and enforces the BitcoinConnector interface\n */\nexport abstract class BaseConnector implements BitcoinConnector {\n abstract readonly id: string;\n abstract readonly name: string;\n abstract readonly icon: string;\n\n private _ready = false;\n private _accountsChangedCallbacks: Set<(accounts: WalletAccount[]) => void> =\n new Set();\n private _networkChangedCallbacks: Set<(network: BitcoinNetwork) => void> =\n new Set();\n\n constructor() {\n this.checkReady();\n // Some wallets inject after DOMContentLoaded\n if (typeof window !== 'undefined') {\n if (document.readyState === 'complete') {\n this.checkReady();\n } else {\n window.addEventListener('load', () => this.checkReady());\n }\n }\n }\n\n get ready(): boolean {\n return this._ready;\n }\n\n protected set ready(value: boolean) {\n this._ready = value;\n }\n protected abstract getProvider(): unknown;\n protected checkReady(): void {\n this._ready = !!this.getProvider();\n }\n protected ensureInstalled(): void {\n if (!this.ready) {\n throw new Error(`${this.name} wallet is not installed`);\n }\n }\n protected inferAddressType(address: string): AddressType {\n if (address.startsWith('bc1q') || address.startsWith('tb1q')) {\n return 'segwit';\n }\n if (address.startsWith('bc1p') || address.startsWith('tb1p')) {\n return 'taproot';\n }\n if (address.startsWith('3') || address.startsWith('2')) {\n return 'nested-segwit';\n }\n return 'legacy';\n }\n\n protected handleError(error: unknown): never {\n console.error('Exception in connector', this.id, error);\n // Throw raw error for other cases\n throw error;\n }\n // Abstract methods that must be implemented\n abstract connect(network?: BitcoinNetwork): Promise<WalletAccount>;\n abstract disconnect(): Promise<void>;\n abstract getAccounts(): Promise<WalletAccount[]>;\n abstract signMessage(message: string): Promise<string>;\n abstract signPsbt(psbtHex: string, options?: SignPsbtOptions): Promise<string>;\n abstract sendTransaction(to: string, satoshis: number): Promise<string>;\n abstract getNetwork(): Promise<BitcoinNetwork>;\n\n // Optional methods - can be overridden\n signPsbts?(\n psbtHexs: string[],\n options?: SignPsbtOptions\n ): Promise<string[]>;\n\n switchNetwork?(network: BitcoinNetwork): Promise<void>;\n\n /**\n * Subscribe to account changes\n */\n onAccountsChanged(callback: (accounts: WalletAccount[]) => void): () => void {\n this._accountsChangedCallbacks.add(callback);\n return () => {\n this._accountsChangedCallbacks.delete(callback);\n };\n }\n\n /**\n * Subscribe to network changes\n */\n onNetworkChanged(callback: (network: BitcoinNetwork) => void): () => void {\n this._networkChangedCallbacks.add(callback);\n return () => {\n this._networkChangedCallbacks.delete(callback);\n };\n }\n\n /**\n * Emit account change event\n */\n protected emitAccountsChanged(accounts: WalletAccount[]): void {\n for (const callback of this._accountsChangedCallbacks) {\n callback(accounts);\n }\n }\n\n /**\n * Emit network change event\n */\n protected emitNetworkChanged(network: BitcoinNetwork): void {\n for (const callback of this._networkChangedCallbacks) {\n callback(network);\n }\n }\n\n /**\n * Clean up all listeners\n */\n protected cleanup(): void {\n this._accountsChangedCallbacks.clear();\n this._networkChangedCallbacks.clear();\n }\n}\n"]}
|