bitcoin-wallet-connector 0.1.0 → 0.2.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 +24 -21
- package/lib/BitcoinConnectionProvider.d.ts +3 -3
- package/lib/BitcoinWalletConnector-BC92ulXx.js +2 -0
- package/lib/BitcoinWalletConnector-BC92ulXx.js.map +1 -0
- package/lib/{BitcoinWalletAdapterConnector-Bq835yj0.mjs → BitcoinWalletConnector-CS0BshOl.mjs} +11 -19
- package/lib/BitcoinWalletConnector-CS0BshOl.mjs.map +1 -0
- package/lib/{BitcoinWalletAdapterConnector.d.ts → BitcoinWalletConnector.d.ts} +4 -5
- package/lib/BitgetWalletAdapter.impl-D8kqiYDi.mjs +11 -0
- package/lib/BitgetWalletAdapter.impl-D8kqiYDi.mjs.map +1 -0
- package/lib/BitgetWalletAdapter.impl-DiyzNQ9d.js +2 -0
- package/lib/BitgetWalletAdapter.impl-DiyzNQ9d.js.map +1 -0
- package/lib/{LeatherWalletAdapter.impl-RUYx555r.mjs → LeatherWalletAdapter.impl-B1PoZS7z.mjs} +48 -37
- package/lib/LeatherWalletAdapter.impl-B1PoZS7z.mjs.map +1 -0
- package/lib/LeatherWalletAdapter.impl-BIWirus3.js +2 -0
- package/lib/LeatherWalletAdapter.impl-BIWirus3.js.map +1 -0
- package/lib/{MagicEdenWalletAdapter.impl-CrA6SGvG.mjs → MagicEdenWalletAdapter.impl-B3d5lbkD.mjs} +31 -20
- package/lib/MagicEdenWalletAdapter.impl-B3d5lbkD.mjs.map +1 -0
- package/lib/MagicEdenWalletAdapter.impl-DLBP3p4o.js +2 -0
- package/lib/MagicEdenWalletAdapter.impl-DLBP3p4o.js.map +1 -0
- package/lib/OkxWalletAdapter.impl-7cj96tmr.js +2 -0
- package/lib/OkxWalletAdapter.impl-7cj96tmr.js.map +1 -0
- package/lib/{OkxWalletAdapter.impl-BepoUL1B.mjs → OkxWalletAdapter.impl-nRgHsPTn.mjs} +13 -9
- package/lib/OkxWalletAdapter.impl-nRgHsPTn.mjs.map +1 -0
- package/lib/{UnisatCompatibleWalletAdapterImpl-M38FqkZI.mjs → UnisatCompatibleWalletAdapterImpl-8lRRF7Zj.mjs} +18 -10
- package/lib/UnisatCompatibleWalletAdapterImpl-8lRRF7Zj.mjs.map +1 -0
- package/lib/{UnisatCompatibleWalletAdapterImpl-Cq2Oqk1b.js → UnisatCompatibleWalletAdapterImpl-C-JWrc9s.js} +2 -2
- package/lib/UnisatCompatibleWalletAdapterImpl-C-JWrc9s.js.map +1 -0
- package/lib/UnisatWalletAdapter.impl-DXDfnHz_.js +2 -0
- package/lib/UnisatWalletAdapter.impl-DXDfnHz_.js.map +1 -0
- package/lib/UnisatWalletAdapter.impl-DvA33Ikj.mjs +19 -0
- package/lib/UnisatWalletAdapter.impl-DvA33Ikj.mjs.map +1 -0
- package/lib/WalletAdapters.types-CExaiK0o.js +2 -0
- package/lib/WalletAdapters.types-CExaiK0o.js.map +1 -0
- package/lib/WalletAdapters.types-DBvhI1hu.mjs +20 -0
- package/lib/WalletAdapters.types-DBvhI1hu.mjs.map +1 -0
- package/lib/WalletAdapters.types.d.ts +7 -12
- package/lib/{XverseCompatibleWalletAdapterImpl-Bf-BK5VK.js → XverseCompatibleWalletAdapterImpl-Dp_GUxQM.js} +2 -2
- package/lib/XverseCompatibleWalletAdapterImpl-Dp_GUxQM.js.map +1 -0
- package/lib/{XverseCompatibleWalletAdapterImpl-DXKnO_-V.mjs → XverseCompatibleWalletAdapterImpl-bgp9xDYH.mjs} +12 -8
- package/lib/XverseCompatibleWalletAdapterImpl-bgp9xDYH.mjs.map +1 -0
- package/lib/{XverseWalletAdapter.impl-CZO0RQva.mjs → XverseWalletAdapter.impl-BOpY4Vf8.mjs} +15 -15
- package/lib/XverseWalletAdapter.impl-BOpY4Vf8.mjs.map +1 -0
- package/lib/XverseWalletAdapter.impl-D0eOtEOa.js +2 -0
- package/lib/XverseWalletAdapter.impl-D0eOtEOa.js.map +1 -0
- package/lib/adapters/BitgetWalletAdapter.d.ts +6 -2
- package/lib/adapters/LeatherWalletAdapter.d.ts +4 -2
- package/lib/adapters/LeatherWalletAdapter.impl.d.ts +8 -1
- package/lib/adapters/MagicEdenWalletAdapter.d.ts +5 -2
- package/lib/adapters/MagicEdenWalletAdapter.impl.d.ts +1 -1
- package/lib/adapters/MockAddressWalletAdapter.d.ts +8 -32
- package/lib/adapters/OkxWalletAdapter.d.ts +3 -2
- package/lib/adapters/OkxWalletAdapter.impl.d.ts +5 -1
- package/lib/adapters/UnisatWalletAdapter.d.ts +3 -2
- package/lib/adapters/UnisatWalletAdapter.impl.d.ts +4 -0
- package/lib/adapters/XverseWalletAdapter.d.ts +3 -2
- package/lib/adapters/XverseWalletAdapter.impl.d.ts +1 -1
- package/lib/adapters/index.d.ts +6 -6
- package/lib/adapters.js +1 -1
- package/lib/adapters.mjs +8 -8
- package/lib/constants-B7qVf97f.mjs +5 -0
- package/lib/constants-B7qVf97f.mjs.map +1 -0
- package/lib/constants-Dr0_Mix2.js +2 -0
- package/lib/constants-Dr0_Mix2.js.map +1 -0
- package/lib/constants.d.ts +1 -0
- package/lib/{index-D7YwhNAG.mjs → index-DM4G-LJz.mjs} +639 -590
- package/lib/index-DM4G-LJz.mjs.map +1 -0
- package/lib/index-jRY8YhyK.js +2 -0
- package/lib/index-jRY8YhyK.js.map +1 -0
- package/lib/index.d.ts +1 -1
- package/lib/index.js +1 -1
- package/lib/index.mjs +13 -13
- package/lib/react.js +1 -1
- package/lib/react.js.map +1 -1
- package/lib/react.mjs +7 -7
- package/lib/react.mjs.map +1 -1
- package/lib/{transaction-CiLOYSE_.mjs → transaction-4ShhFCwN.mjs} +2 -2
- package/lib/{transaction-CiLOYSE_.mjs.map → transaction-4ShhFCwN.mjs.map} +1 -1
- package/lib/{transaction-CzdnbXSo.js → transaction-B6SlpRzN.js} +2 -2
- package/lib/{transaction-CzdnbXSo.js.map → transaction-B6SlpRzN.js.map} +1 -1
- package/lib/utils/UnisatCompatibleWalletAdapterImpl.d.ts +11 -3
- package/lib/utils/XverseCompatibleWalletAdapterImpl.d.ts +4 -0
- package/lib/utils/XverseCompatibleWalletAdapterImpl_legacy.d.ts +7 -2
- package/package.json +9 -10
- package/src/BitcoinConnectionProvider.stories.tsx +111 -43
- package/src/BitcoinConnectionProvider.tsx +5 -5
- package/src/{BitcoinWalletAdapterConnector.ts → BitcoinWalletConnector.ts} +18 -26
- package/src/WalletAdapters.types.ts +13 -22
- package/src/adapters/BitgetWalletAdapter.impl.ts +2 -1
- package/src/adapters/BitgetWalletAdapter.ts +9 -7
- package/src/adapters/LeatherWalletAdapter.impl.ts +23 -13
- package/src/adapters/LeatherWalletAdapter.ts +11 -8
- package/src/adapters/MagicEdenWalletAdapter.impl.ts +9 -8
- package/src/adapters/MagicEdenWalletAdapter.ts +17 -14
- package/src/adapters/MockAddressWalletAdapter.ts +61 -35
- package/src/adapters/OkxWalletAdapter.impl.ts +12 -7
- package/src/adapters/OkxWalletAdapter.ts +10 -7
- package/src/adapters/UnisatWalletAdapter.impl.ts +8 -2
- package/src/adapters/UnisatWalletAdapter.ts +9 -7
- package/src/adapters/XverseWalletAdapter.impl.ts +6 -6
- package/src/adapters/XverseWalletAdapter.ts +10 -7
- package/src/adapters/index.ts +6 -6
- package/src/constants.ts +1 -0
- package/src/index.ts +1 -1
- package/src/utils/UnisatCompatibleWalletAdapterImpl.ts +11 -2
- package/src/utils/XverseCompatibleWalletAdapterImpl.ts +4 -0
- package/src/utils/XverseCompatibleWalletAdapterImpl_legacy.ts +19 -7
- package/lib/BitcoinWalletAdapterConnector-Bq835yj0.mjs.map +0 -1
- package/lib/BitcoinWalletAdapterConnector-DMef0iHV.js +0 -2
- package/lib/BitcoinWalletAdapterConnector-DMef0iHV.js.map +0 -1
- package/lib/BitgetWalletAdapter.impl-C_HLO7Oi.mjs +0 -10
- package/lib/BitgetWalletAdapter.impl-C_HLO7Oi.mjs.map +0 -1
- package/lib/BitgetWalletAdapter.impl-CxnKMf7U.js +0 -2
- package/lib/BitgetWalletAdapter.impl-CxnKMf7U.js.map +0 -1
- package/lib/LeatherWalletAdapter.impl-B2QgX_tO.js +0 -2
- package/lib/LeatherWalletAdapter.impl-B2QgX_tO.js.map +0 -1
- package/lib/LeatherWalletAdapter.impl-RUYx555r.mjs.map +0 -1
- package/lib/MagicEdenWalletAdapter.impl-CrA6SGvG.mjs.map +0 -1
- package/lib/MagicEdenWalletAdapter.impl-Di3Nu2S5.js +0 -2
- package/lib/MagicEdenWalletAdapter.impl-Di3Nu2S5.js.map +0 -1
- package/lib/OkxWalletAdapter.impl-BepoUL1B.mjs.map +0 -1
- package/lib/OkxWalletAdapter.impl-C8kesjGu.js +0 -2
- package/lib/OkxWalletAdapter.impl-C8kesjGu.js.map +0 -1
- package/lib/UnisatCompatibleWalletAdapterImpl-Cq2Oqk1b.js.map +0 -1
- package/lib/UnisatCompatibleWalletAdapterImpl-M38FqkZI.mjs.map +0 -1
- package/lib/UnisatWalletAdapter.impl-CJB22se8.mjs +0 -14
- package/lib/UnisatWalletAdapter.impl-CJB22se8.mjs.map +0 -1
- package/lib/UnisatWalletAdapter.impl-EISvxdpc.js +0 -2
- package/lib/UnisatWalletAdapter.impl-EISvxdpc.js.map +0 -1
- package/lib/WalletAdapters.types-CnvOqHFH.mjs +0 -32
- package/lib/WalletAdapters.types-CnvOqHFH.mjs.map +0 -1
- package/lib/WalletAdapters.types-De_x1lzr.js +0 -2
- package/lib/WalletAdapters.types-De_x1lzr.js.map +0 -1
- package/lib/XverseCompatibleWalletAdapterImpl-Bf-BK5VK.js.map +0 -1
- package/lib/XverseCompatibleWalletAdapterImpl-DXKnO_-V.mjs.map +0 -1
- package/lib/XverseWalletAdapter.impl-CZO0RQva.mjs.map +0 -1
- package/lib/XverseWalletAdapter.impl-lJwMi-Iv.js +0 -2
- package/lib/XverseWalletAdapter.impl-lJwMi-Iv.js.map +0 -1
- package/lib/index-D7YwhNAG.mjs.map +0 -1
- package/lib/index-Zx0KcpYx.js +0 -2
- package/lib/index-Zx0KcpYx.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"BitcoinWalletAdapterConnector-DMef0iHV.js","sources":["../src/utils/StateChannel.ts","../src/BitcoinWalletAdapterConnector.ts"],"sourcesContent":["export type StateChannelListener<T> = (value: T) => void\n\nexport interface StateChannelSubscription {\n unsubscribe: () => void\n}\n\nexport class StateChannel<T> {\n private listeners = new Set<StateChannelListener<T>>()\n constructor(private value: T) {}\n\n getValue(): T {\n return this.value\n }\n\n setValue(value: T): void {\n this.value = value\n this.emit()\n }\n\n update(updater: (current: T) => T): void {\n this.setValue(updater(this.value))\n }\n\n subscribe(listener: StateChannelListener<T>): StateChannelSubscription {\n this.listeners.add(listener)\n listener(this.value)\n return {\n unsubscribe: () => {\n this.listeners.delete(listener)\n },\n }\n }\n\n private emit(): void {\n for (const listener of this.listeners) {\n listener(this.value)\n }\n }\n}\n","import { AvailabilitySubscription } from \"./utils/createAdapterAvailability\"\nimport { BitcoinWalletAdapterError } from \"./utils/error\"\nimport { StateChannel, StateChannelListener } from \"./utils/StateChannel\"\nimport {\n WalletAdapter,\n WalletAdapterNotConnectedError,\n WalletAdapterStatic,\n} from \"./WalletAdapters.types\"\n\nconst previousConnectWalletAdapterIdLocalStorageKey =\n \"app:BitcoinWalletAdapterConnector:previousConnectWallet\"\n\nexport interface ConnectInfo {\n adapterId: string\n adapter: WalletAdapter\n}\n\nexport type AdapterEntry = readonly [string, WalletAdapter]\n\nexport class BitcoinWalletAdapterConnector {\n private availableAdaptersState = new StateChannel<AdapterEntry[]>([])\n private connectedInfoState = new StateChannel<null | ConnectInfo>(null)\n private autoConnectRunning = false\n private availabilitySubscriptions: AvailabilitySubscription[] = []\n private adapterOrder = new Map<string, number>()\n\n constructor(private Adapters: WalletAdapterStatic<WalletAdapter>[]) {\n this.adapterOrder = new Map(\n Adapters.map((adapter, index) => [adapter.adapterId, index]),\n )\n this.initializeAdapterAvailability()\n }\n\n dispose(): void {\n this.availabilitySubscriptions.forEach(s => s.unsubscribe())\n this.availabilitySubscriptions = []\n this.availableAdaptersState = new StateChannel<AdapterEntry[]>([])\n this.connectedInfoState = new StateChannel<null | ConnectInfo>(null)\n }\n\n subscribeAvailableAdapters(\n listener: StateChannelListener<AdapterEntry[]>,\n ): AvailabilitySubscription {\n return this.availableAdaptersState.subscribe(listener)\n }\n getAvailableAdapters(): AdapterEntry[] {\n return this.availableAdaptersState.getValue()\n }\n\n subscribeConnectedInfo(\n listener: StateChannelListener<null | ConnectInfo>,\n ): AvailabilitySubscription {\n return this.connectedInfoState.subscribe(listener)\n }\n getConnectedInfo(): null | ConnectInfo {\n return this.connectedInfoState.getValue()\n }\n\n private initializeAdapterAvailability(): void {\n this.availabilitySubscriptions = this.Adapters.map(Adapter => {\n return Adapter.getAdapter().subscribe(adapter => {\n this.addOrUpdateAvailableAdapter(Adapter.adapterId, adapter)\n })\n })\n }\n\n private addOrUpdateAvailableAdapter(\n adapterId: string,\n adapter: WalletAdapter,\n ): void {\n this.availableAdaptersState.update(current => {\n const next = [...current]\n const existingIndex = current.findIndex(([id]) => id === adapterId)\n if (existingIndex === -1) {\n next.push([adapterId, adapter] as const)\n } else {\n next[existingIndex] = [adapterId, adapter] as const\n }\n\n next.sort(\n (a, b) =>\n (this.adapterOrder.get(a[0]) ?? Number.MAX_SAFE_INTEGER) -\n (this.adapterOrder.get(b[0]) ?? Number.MAX_SAFE_INTEGER),\n )\n return next\n })\n\n void this.autoConnect()\n }\n\n async connect(adapterId: string, adapter: WalletAdapter): Promise<void> {\n const finalAdapter = adapter\n\n await finalAdapter.connect().catch(err => {\n if (err instanceof BitcoinWalletAdapterError) {\n alert(err.message)\n return\n }\n throw err\n })\n\n localStorage.setItem(\n previousConnectWalletAdapterIdLocalStorageKey,\n adapterId,\n )\n\n this.connectedInfoState.setValue({ adapterId, adapter: finalAdapter })\n }\n\n async disconnect(): Promise<void> {\n const info = this.connectedInfoState.getValue()\n if (info == null) return\n await this.disconnectAdapter(info.adapter)\n this.connectedInfoState.setValue(null)\n }\n private async disconnectAdapter(adapter: WalletAdapter): Promise<void> {\n await adapter.disconnect()\n localStorage.removeItem(previousConnectWalletAdapterIdLocalStorageKey)\n }\n\n private async autoConnect(): Promise<void> {\n if (this.isConnected || this.autoConnectRunning) return\n\n const previousAdapterId = this.previousConnectedWallet\n if (previousAdapterId == null) return\n\n const adapter = this.availableAdaptersState\n .getValue()\n .find(a => a[0] === previousAdapterId)?.[1]\n if (adapter == null) return\n\n this.autoConnectRunning = true\n try {\n await adapter.getAddresses()\n } catch (err: unknown) {\n if (err instanceof WalletAdapterNotConnectedError) {\n this.autoConnectRunning = false\n return\n }\n\n this.autoConnectRunning = false\n throw err\n }\n\n try {\n await this.connect(previousAdapterId, adapter)\n } finally {\n this.autoConnectRunning = false\n }\n }\n\n private get previousConnectedWallet(): string | undefined {\n const adapterId =\n localStorage.getItem(previousConnectWalletAdapterIdLocalStorageKey) ||\n undefined\n\n if (this.Adapters.some(adapter => adapter.adapterId === adapterId)) {\n return adapterId\n }\n return undefined\n }\n\n private get isConnected(): boolean {\n return this.connectedInfoState.getValue() != null\n }\n}\n"],"names":["StateChannel","value","updater","listener","previousConnectWalletAdapterIdLocalStorageKey","BitcoinWalletAdapterConnector","Adapters","adapter","index","s","Adapter","adapterId","current","next","existingIndex","id","a","b","finalAdapter","err","BitcoinWalletAdapterError","info","previousAdapterId","WalletAdapterNotConnectedError"],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"BitgetWalletAdapter.impl-C_HLO7Oi.mjs","sources":["../src/adapters/BitgetWalletAdapter.impl.ts"],"sourcesContent":["import {\n UnisatCompatibleProviderAPI,\n UnisatCompatibleWalletAdapterImpl,\n} from \"../utils/UnisatCompatibleWalletAdapterImpl\"\nimport { WalletAdapter } from \"../WalletAdapters.types\"\n\n/**\n * Derivation path (BIP-44): m/44'/0'/0'/0/ address_index\n */\nexport class BitgetWalletAdapterImpl\n extends UnisatCompatibleWalletAdapterImpl\n implements WalletAdapter\n{\n constructor(provider: UnisatCompatibleProviderAPI) {\n /**\n * Bitget Provider API:\n *\n * https://web3.bitget.com/zh-CN/docs/provider-api/btc.html\n */\n super(provider, \"Bitget\")\n }\n}\n"],"names":["BitgetWalletAdapterImpl","UnisatCompatibleWalletAdapterImpl","provider"],"mappings":";AASO,MAAMA,UACHC,EAEV;AAAA,EACE,YAAYC,GAAuC;AAMjD,UAAMA,GAAU,QAAQ;AAAA,EAC1B;AACF;"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./UnisatCompatibleWalletAdapterImpl-Cq2Oqk1b.js");class l extends e.UnisatCompatibleWalletAdapterImpl{constructor(t){super(t,"Bitget")}}exports.BitgetWalletAdapterImpl=l;
|
|
2
|
-
//# sourceMappingURL=BitgetWalletAdapter.impl-CxnKMf7U.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"BitgetWalletAdapter.impl-CxnKMf7U.js","sources":["../src/adapters/BitgetWalletAdapter.impl.ts"],"sourcesContent":["import {\n UnisatCompatibleProviderAPI,\n UnisatCompatibleWalletAdapterImpl,\n} from \"../utils/UnisatCompatibleWalletAdapterImpl\"\nimport { WalletAdapter } from \"../WalletAdapters.types\"\n\n/**\n * Derivation path (BIP-44): m/44'/0'/0'/0/ address_index\n */\nexport class BitgetWalletAdapterImpl\n extends UnisatCompatibleWalletAdapterImpl\n implements WalletAdapter\n{\n constructor(provider: UnisatCompatibleProviderAPI) {\n /**\n * Bitget Provider API:\n *\n * https://web3.bitget.com/zh-CN/docs/provider-api/btc.html\n */\n super(provider, \"Bitget\")\n }\n}\n"],"names":["BitgetWalletAdapterImpl","UnisatCompatibleWalletAdapterImpl","provider"],"mappings":"mJASO,MAAMA,UACHC,EAAAA,iCAEV,CACE,YAAYC,EAAuC,CAMjD,MAAMA,EAAU,QAAQ,CAC1B,CACF"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=require("./index-Zx0KcpYx.js"),r=require("./WalletAdapters.types-De_x1lzr.js"),y="LeatherProvider.BitcoinProvider",l=`app:${y}:`;class A{constructor(e){this.request=e}walletDisplayName="Leather";retrieveConnectedAddress(){let e;const s=localStorage.getItem(l)||void 0;if(s!=null)try{if(e=JSON.parse(s),e==null||!("addresses"in e)||!Array.isArray(e.addresses))throw new Error("Invalid stored addresses")}catch{localStorage.removeItem(l)}return e}async connect(){if(this.retrieveConnectedAddress()==null){const e=await o(this.request("getAddresses"));localStorage.setItem(l,JSON.stringify(e))}}async disconnect(){return localStorage.removeItem(l),Promise.resolve()}async getAddresses(){const e=this.retrieveConnectedAddress();if(e==null)throw new r.WalletAdapterNotConnectedError(this.walletDisplayName);const s=e.addresses.filter(t=>t.symbol==="BTC"&&t.type),a=s.filter(t=>t.type==="p2tr")[0].address.startsWith("bc");return s.map(t=>({network:a?r.WalletAdapterBitcoinNetwork.MAINNET:r.WalletAdapterBitcoinNetwork.TESTNET,purposes:t.type==="p2tr"?[r.WalletAdapterAddressPurpose.Ordinals,r.WalletAdapterAddressPurpose.BRC20,r.WalletAdapterAddressPurpose.Runes]:[r.WalletAdapterAddressPurpose.Bitcoin],addressType:t.type==="p2tr"?r.WalletAdapterAddressType.P2TR:r.WalletAdapterAddressType.P2WPKH,address:t.address,scriptPubKey:i.hex.encode(i.addressToScriptPubKey(i.getBitcoinNetwork(a?"mainnet":"testnet"),t.address)),publicKey:t.publicKey,tapInternalKey:t.type==="p2tr"?i.hex.encode(i.getTapInternalKeyOf_P2TR_publicKey(i.getBitcoinNetwork(a?"mainnet":"testnet"),i.hex.decode(t.publicKey))):void 0}))}async signMessage(e,s){const t=(await this.getAddresses()).find(p=>p.address===e)?.addressType,d=t===r.WalletAdapterAddressType.P2WPKH?"p2wpkh":t===r.WalletAdapterAddressType.P2TR?"p2tr":void 0;if(d==null)throw new r.BitcoinWalletAdapterError("Address is not supported");const n=await o(this.request("signMessage",{message:s,paymentType:d}));return{algorithm:n.algorithm==="ecdsa"?r.SignMessageAlgorithm.ECDSA:r.SignMessageAlgorithm.BIP322,result:n.signature,address:e,publicKey:n.publicKey}}sendBitcoinFeeRateCapability="required";async sendBitcoin(e,s,a,t){return{txid:(await o(this.request("sendBitcoin",{origin:e,destination:s,amount:a,feeRate:t?.feeRate}))).txid}}sendInscriptionFeeRateCapability="available";async sendInscription(e,s,a,t){const{txid:d}=await o(this.request("sendOrdinals",{ordinals:[{destination:s,id:a}],paymentType:"p2wpkh",sender:e,feeRate:t?.feeRate}));return{txid:d}}async signAndFinalizePsbt(e,s){const t=(await this.getAddresses()).find(n=>n.address===s[0]?.[0]);if(t==null)throw new r.WalletAdapterNotConnectedError(this.walletDisplayName);return{signedPsbtHex:(await o(this.request("signAndFinalizePsbt",{hex:e,inputsToSign:s.map(([n,p])=>({address:n,signingIndexes:[p],signatureHash:void 0,disableTweakSigner:void 0})),paymentType:t.addressType===r.WalletAdapterAddressType.P2TR?"p2tr":"p2wpkh"}))).hex}}onAddressesChanged(e){let s=!1;const a=async()=>{if(!s)try{const t=await this.getAddresses();e({addresses:t})}catch(t){if(t instanceof r.WalletAdapterNotConnectedError){s=!0;return}console.warn("[Leather] Failed to get addresses on change:",t)}finally{s||setTimeout(a,1e3)}};return setTimeout(a,1e3),{unsubscribe:()=>{s=!0}}}}class u extends r.BitcoinWalletAdapterError{constructor(e){super("Leather wallet error: "+e.error.message,{cause:e})}}const o=async c=>{try{return await c}catch(e){throw e instanceof r.UserRejectError?e:e.error?.code===4001?new r.UserRejectError:new u(e)}};exports.LeatherWalletAdapterError=u;exports.LeatherWalletAdapterImpl=A;
|
|
2
|
-
//# sourceMappingURL=LeatherWalletAdapter.impl-B2QgX_tO.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"LeatherWalletAdapter.impl-B2QgX_tO.js","sources":["../src/adapters/LeatherWalletAdapter.impl.ts"],"sourcesContent":["import type { RequestFn, RpcErrorBody, RpcErrorResponse } from \"@leather.io/rpc\"\nimport { hex } from \"@scure/base\"\nimport {\n addressToScriptPubKey,\n getTapInternalKeyOf_P2TR_publicKey,\n} from \"../utils/bitcoinAddressHelpers\"\nimport { getBitcoinNetwork } from \"../utils/bitcoinNetworkHelpers\"\nimport { UserRejectError, BitcoinWalletAdapterError } from \"../utils/error\"\nimport {\n SignMessageAlgorithm,\n SignMessageResult,\n WalletAdapter,\n WalletAdapter_onAddressesChanged_callback,\n WalletAdapterAddress,\n WalletAdapterAddressPurpose,\n WalletAdapterAddressType,\n WalletAdapterBitcoinNetwork,\n WalletAdapterNotConnectedError,\n} from \"../WalletAdapters.types\"\n\ntype GetAddressesResponseData = any\n\n/**\n * https://github.com/leather-io/mono/blob/a664e64040fed1c25abef1f8864a1c7fae5444c1/packages/rpc/src/rpc/schemas.ts#L64-L78\n */\nenum RpcErrorCode {\n // Spec defined server errors\n PARSE_ERROR = -32700,\n INVALID_REQUEST = -32600,\n METHOD_NOT_FOUND = -32601,\n INVALID_PARAMS = -32602,\n INTERNAL_ERROR = -32603,\n SERVER_ERROR = -32000,\n // Client defined errors\n USER_REJECTION = 4001,\n METHOD_NOT_SUPPORTED = 4002,\n // gRPC spec borrowed\n PERMISSION_DENIED = 7,\n UNAUTHENTICATED = 16,\n}\n\ntype Addresses = (WalletAdapterAddress & { publicKey: string })[]\n\nconst LEATHER_PROVIDER_ID = \"LeatherProvider.BitcoinProvider\"\n\nconst localStorageKey = `app:${LEATHER_PROVIDER_ID}:`\n\n/**\n * Derivation path (BIP-84): m/84'/0'/ account_index '/0/0\n */\nexport class LeatherWalletAdapterImpl implements WalletAdapter {\n constructor(private request: RequestFn) {}\n\n private readonly walletDisplayName = \"Leather\"\n\n private retrieveConnectedAddress(): GetAddressesResponseData | undefined {\n let resp: GetAddressesResponseData | undefined\n const stored = localStorage.getItem(localStorageKey) || undefined\n if (stored != null) {\n try {\n resp = JSON.parse(stored)\n if (\n resp == null ||\n !(\"addresses\" in resp) ||\n !Array.isArray(resp.addresses)\n ) {\n throw new Error(\"Invalid stored addresses\")\n }\n } catch {\n localStorage.removeItem(localStorageKey)\n }\n }\n return resp\n }\n\n async connect(): Promise<void> {\n if (this.retrieveConnectedAddress() == null) {\n const resp = await handleRpcError(\n /**\n * https://leather.gitbook.io/developers/bitcoin/connect-users/get-addresses\n */\n this.request(\"getAddresses\"),\n )\n localStorage.setItem(localStorageKey, JSON.stringify(resp))\n }\n }\n\n async disconnect(): Promise<void> {\n localStorage.removeItem(localStorageKey)\n return Promise.resolve()\n }\n\n async getAddresses(): Promise<Addresses> {\n const resp = this.retrieveConnectedAddress()\n\n if (resp == null) {\n throw new WalletAdapterNotConnectedError(this.walletDisplayName)\n }\n\n const addresses = resp.addresses.filter(\n (a: any) => (a as any).symbol === \"BTC\" && a.type,\n )\n\n const isMainnet = addresses\n .filter((a: any) => a.type === \"p2tr\")[0]\n .address.startsWith(\"bc\")\n\n return addresses.map((a: any) => ({\n network: isMainnet\n ? WalletAdapterBitcoinNetwork.MAINNET\n : WalletAdapterBitcoinNetwork.TESTNET,\n purposes:\n a.type === \"p2tr\"\n ? [\n WalletAdapterAddressPurpose.Ordinals,\n WalletAdapterAddressPurpose.BRC20,\n WalletAdapterAddressPurpose.Runes,\n ]\n : [WalletAdapterAddressPurpose.Bitcoin],\n addressType:\n a.type === \"p2tr\"\n ? WalletAdapterAddressType.P2TR\n : WalletAdapterAddressType.P2WPKH,\n address: a.address,\n scriptPubKey: hex.encode(\n addressToScriptPubKey(\n getBitcoinNetwork(isMainnet ? \"mainnet\" : \"testnet\"),\n a.address,\n ),\n ),\n publicKey: a.publicKey!,\n tapInternalKey:\n a.type === \"p2tr\"\n ? hex.encode(\n getTapInternalKeyOf_P2TR_publicKey(\n getBitcoinNetwork(isMainnet ? \"mainnet\" : \"testnet\"),\n hex.decode(a.publicKey!),\n ),\n )\n : undefined,\n }))\n }\n\n async signMessage(\n address: string,\n message: string,\n ): Promise<SignMessageResult> {\n const accounts = await this.getAddresses()\n\n const addressType = accounts.find(a => a.address === address)?.addressType\n\n // prettier-ignore\n const paymentType =\n addressType === WalletAdapterAddressType.P2WPKH ? 'p2wpkh' as const :\n addressType === WalletAdapterAddressType.P2TR ? 'p2tr' as const :\n undefined\n if (paymentType == null) {\n throw new BitcoinWalletAdapterError(\"Address is not supported\")\n }\n\n const resp: any = await handleRpcError(\n /**\n * https://leather.gitbook.io/developers/bitcoin-methods/signmessage\n */\n this.request(\"signMessage\", {\n message,\n paymentType,\n }),\n )\n\n return {\n algorithm:\n resp.algorithm === \"ecdsa\"\n ? SignMessageAlgorithm.ECDSA\n : SignMessageAlgorithm.BIP322,\n result: resp.signature,\n address,\n publicKey: resp.publicKey,\n }\n }\n\n sendBitcoinFeeRateCapability = \"required\" as const\n async sendBitcoin(\n fromAddress: string,\n receiverAddress: string,\n satoshiAmount: bigint,\n options?: { feeRate?: number },\n ): Promise<{ txid: string }> {\n const resp: any = await handleRpcError(\n /**\n * https://leather.gitbook.io/developers/bitcoin-methods/sendbitcoin\n */\n (this.request as any)(\"sendBitcoin\", {\n origin: fromAddress,\n destination: receiverAddress,\n amount: satoshiAmount,\n feeRate: options?.feeRate,\n }),\n )\n return { txid: resp.txid }\n }\n\n sendInscriptionFeeRateCapability = \"available\" as const\n\n async sendInscription(\n fromAddress: string,\n receiverAddress: string,\n inscriptionId: string,\n options?: { feeRate?: number },\n ): Promise<{ txid: string }> {\n const { txid }: any = await handleRpcError(\n /**\n * https://leather.gitbook.io/developers/ordinals/send-ordinals\n */\n (this.request as any)(\"sendOrdinals\", {\n ordinals: [\n {\n destination: receiverAddress,\n id: inscriptionId,\n },\n ],\n paymentType: \"p2wpkh\",\n sender: fromAddress,\n feeRate: options?.feeRate,\n }),\n )\n return { txid }\n }\n\n async signAndFinalizePsbt(\n psbtHex: string,\n signIndices: [address: string, signIndex: number][],\n ): Promise<{\n signedPsbtHex: string\n }> {\n const accounts = await this.getAddresses()\n const signingAccount = accounts.find(\n account => account.address === signIndices[0]?.[0],\n )\n if (signingAccount == null) {\n throw new WalletAdapterNotConnectedError(this.walletDisplayName)\n }\n\n const resp: any = await handleRpcError(\n /**\n * https://leather.gitbook.io/developers/bitcoin-methods/signandfinalizepsbt\n */\n (this.request as any)(\"signAndFinalizePsbt\", {\n hex: psbtHex,\n inputsToSign: signIndices.map(([address, signIndex]) => ({\n address,\n signingIndexes: [signIndex],\n signatureHash: undefined,\n disableTweakSigner: undefined,\n })),\n paymentType:\n signingAccount.addressType === WalletAdapterAddressType.P2TR\n ? \"p2tr\"\n : \"p2wpkh\",\n }),\n )\n\n return { signedPsbtHex: resp.hex }\n }\n\n onAddressesChanged(callback: WalletAdapter_onAddressesChanged_callback): {\n unsubscribe: () => void\n } {\n // Leather doesn't provide event, fallback to polling\n let stopped = false\n\n const tick = async (): Promise<void> => {\n if (stopped) return\n try {\n const addresses = await this.getAddresses()\n callback({ addresses })\n } catch (error) {\n if (error instanceof WalletAdapterNotConnectedError) {\n stopped = true\n return\n }\n console.warn(\"[Leather] Failed to get addresses on change:\", error)\n } finally {\n if (!stopped) {\n setTimeout(tick, 1000)\n }\n }\n }\n\n setTimeout(tick, 1000)\n\n return {\n unsubscribe: () => {\n stopped = true\n },\n }\n }\n}\n\nexport class LeatherWalletAdapterError extends BitcoinWalletAdapterError {\n constructor(rpcError: RpcErrorResponse<RpcErrorBody>) {\n super(\"Leather wallet error: \" + rpcError.error.message, {\n cause: rpcError,\n })\n }\n}\n\nconst handleRpcError = async <T>(\n promise: Promise<T>,\n): Promise<NonNullable<T>> => {\n try {\n return (await promise) as NonNullable<T>\n } catch (e: any) {\n if (e instanceof UserRejectError) {\n throw e\n }\n\n if (e.error?.code === RpcErrorCode.USER_REJECTION) {\n throw new UserRejectError()\n }\n\n throw new LeatherWalletAdapterError(e)\n }\n}\n"],"names":["LEATHER_PROVIDER_ID","localStorageKey","LeatherWalletAdapterImpl","request","resp","stored","handleRpcError","WalletAdapterNotConnectedError","addresses","a","isMainnet","WalletAdapterBitcoinNetwork","WalletAdapterAddressPurpose","WalletAdapterAddressType","hex","addressToScriptPubKey","getBitcoinNetwork","getTapInternalKeyOf_P2TR_publicKey","address","message","addressType","paymentType","BitcoinWalletAdapterError","SignMessageAlgorithm","fromAddress","receiverAddress","satoshiAmount","options","inscriptionId","txid","psbtHex","signIndices","signingAccount","account","signIndex","callback","stopped","tick","error","LeatherWalletAdapterError","rpcError","promise","UserRejectError"],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"LeatherWalletAdapter.impl-RUYx555r.mjs","sources":["../src/adapters/LeatherWalletAdapter.impl.ts"],"sourcesContent":["import type { RequestFn, RpcErrorBody, RpcErrorResponse } from \"@leather.io/rpc\"\nimport { hex } from \"@scure/base\"\nimport {\n addressToScriptPubKey,\n getTapInternalKeyOf_P2TR_publicKey,\n} from \"../utils/bitcoinAddressHelpers\"\nimport { getBitcoinNetwork } from \"../utils/bitcoinNetworkHelpers\"\nimport { UserRejectError, BitcoinWalletAdapterError } from \"../utils/error\"\nimport {\n SignMessageAlgorithm,\n SignMessageResult,\n WalletAdapter,\n WalletAdapter_onAddressesChanged_callback,\n WalletAdapterAddress,\n WalletAdapterAddressPurpose,\n WalletAdapterAddressType,\n WalletAdapterBitcoinNetwork,\n WalletAdapterNotConnectedError,\n} from \"../WalletAdapters.types\"\n\ntype GetAddressesResponseData = any\n\n/**\n * https://github.com/leather-io/mono/blob/a664e64040fed1c25abef1f8864a1c7fae5444c1/packages/rpc/src/rpc/schemas.ts#L64-L78\n */\nenum RpcErrorCode {\n // Spec defined server errors\n PARSE_ERROR = -32700,\n INVALID_REQUEST = -32600,\n METHOD_NOT_FOUND = -32601,\n INVALID_PARAMS = -32602,\n INTERNAL_ERROR = -32603,\n SERVER_ERROR = -32000,\n // Client defined errors\n USER_REJECTION = 4001,\n METHOD_NOT_SUPPORTED = 4002,\n // gRPC spec borrowed\n PERMISSION_DENIED = 7,\n UNAUTHENTICATED = 16,\n}\n\ntype Addresses = (WalletAdapterAddress & { publicKey: string })[]\n\nconst LEATHER_PROVIDER_ID = \"LeatherProvider.BitcoinProvider\"\n\nconst localStorageKey = `app:${LEATHER_PROVIDER_ID}:`\n\n/**\n * Derivation path (BIP-84): m/84'/0'/ account_index '/0/0\n */\nexport class LeatherWalletAdapterImpl implements WalletAdapter {\n constructor(private request: RequestFn) {}\n\n private readonly walletDisplayName = \"Leather\"\n\n private retrieveConnectedAddress(): GetAddressesResponseData | undefined {\n let resp: GetAddressesResponseData | undefined\n const stored = localStorage.getItem(localStorageKey) || undefined\n if (stored != null) {\n try {\n resp = JSON.parse(stored)\n if (\n resp == null ||\n !(\"addresses\" in resp) ||\n !Array.isArray(resp.addresses)\n ) {\n throw new Error(\"Invalid stored addresses\")\n }\n } catch {\n localStorage.removeItem(localStorageKey)\n }\n }\n return resp\n }\n\n async connect(): Promise<void> {\n if (this.retrieveConnectedAddress() == null) {\n const resp = await handleRpcError(\n /**\n * https://leather.gitbook.io/developers/bitcoin/connect-users/get-addresses\n */\n this.request(\"getAddresses\"),\n )\n localStorage.setItem(localStorageKey, JSON.stringify(resp))\n }\n }\n\n async disconnect(): Promise<void> {\n localStorage.removeItem(localStorageKey)\n return Promise.resolve()\n }\n\n async getAddresses(): Promise<Addresses> {\n const resp = this.retrieveConnectedAddress()\n\n if (resp == null) {\n throw new WalletAdapterNotConnectedError(this.walletDisplayName)\n }\n\n const addresses = resp.addresses.filter(\n (a: any) => (a as any).symbol === \"BTC\" && a.type,\n )\n\n const isMainnet = addresses\n .filter((a: any) => a.type === \"p2tr\")[0]\n .address.startsWith(\"bc\")\n\n return addresses.map((a: any) => ({\n network: isMainnet\n ? WalletAdapterBitcoinNetwork.MAINNET\n : WalletAdapterBitcoinNetwork.TESTNET,\n purposes:\n a.type === \"p2tr\"\n ? [\n WalletAdapterAddressPurpose.Ordinals,\n WalletAdapterAddressPurpose.BRC20,\n WalletAdapterAddressPurpose.Runes,\n ]\n : [WalletAdapterAddressPurpose.Bitcoin],\n addressType:\n a.type === \"p2tr\"\n ? WalletAdapterAddressType.P2TR\n : WalletAdapterAddressType.P2WPKH,\n address: a.address,\n scriptPubKey: hex.encode(\n addressToScriptPubKey(\n getBitcoinNetwork(isMainnet ? \"mainnet\" : \"testnet\"),\n a.address,\n ),\n ),\n publicKey: a.publicKey!,\n tapInternalKey:\n a.type === \"p2tr\"\n ? hex.encode(\n getTapInternalKeyOf_P2TR_publicKey(\n getBitcoinNetwork(isMainnet ? \"mainnet\" : \"testnet\"),\n hex.decode(a.publicKey!),\n ),\n )\n : undefined,\n }))\n }\n\n async signMessage(\n address: string,\n message: string,\n ): Promise<SignMessageResult> {\n const accounts = await this.getAddresses()\n\n const addressType = accounts.find(a => a.address === address)?.addressType\n\n // prettier-ignore\n const paymentType =\n addressType === WalletAdapterAddressType.P2WPKH ? 'p2wpkh' as const :\n addressType === WalletAdapterAddressType.P2TR ? 'p2tr' as const :\n undefined\n if (paymentType == null) {\n throw new BitcoinWalletAdapterError(\"Address is not supported\")\n }\n\n const resp: any = await handleRpcError(\n /**\n * https://leather.gitbook.io/developers/bitcoin-methods/signmessage\n */\n this.request(\"signMessage\", {\n message,\n paymentType,\n }),\n )\n\n return {\n algorithm:\n resp.algorithm === \"ecdsa\"\n ? SignMessageAlgorithm.ECDSA\n : SignMessageAlgorithm.BIP322,\n result: resp.signature,\n address,\n publicKey: resp.publicKey,\n }\n }\n\n sendBitcoinFeeRateCapability = \"required\" as const\n async sendBitcoin(\n fromAddress: string,\n receiverAddress: string,\n satoshiAmount: bigint,\n options?: { feeRate?: number },\n ): Promise<{ txid: string }> {\n const resp: any = await handleRpcError(\n /**\n * https://leather.gitbook.io/developers/bitcoin-methods/sendbitcoin\n */\n (this.request as any)(\"sendBitcoin\", {\n origin: fromAddress,\n destination: receiverAddress,\n amount: satoshiAmount,\n feeRate: options?.feeRate,\n }),\n )\n return { txid: resp.txid }\n }\n\n sendInscriptionFeeRateCapability = \"available\" as const\n\n async sendInscription(\n fromAddress: string,\n receiverAddress: string,\n inscriptionId: string,\n options?: { feeRate?: number },\n ): Promise<{ txid: string }> {\n const { txid }: any = await handleRpcError(\n /**\n * https://leather.gitbook.io/developers/ordinals/send-ordinals\n */\n (this.request as any)(\"sendOrdinals\", {\n ordinals: [\n {\n destination: receiverAddress,\n id: inscriptionId,\n },\n ],\n paymentType: \"p2wpkh\",\n sender: fromAddress,\n feeRate: options?.feeRate,\n }),\n )\n return { txid }\n }\n\n async signAndFinalizePsbt(\n psbtHex: string,\n signIndices: [address: string, signIndex: number][],\n ): Promise<{\n signedPsbtHex: string\n }> {\n const accounts = await this.getAddresses()\n const signingAccount = accounts.find(\n account => account.address === signIndices[0]?.[0],\n )\n if (signingAccount == null) {\n throw new WalletAdapterNotConnectedError(this.walletDisplayName)\n }\n\n const resp: any = await handleRpcError(\n /**\n * https://leather.gitbook.io/developers/bitcoin-methods/signandfinalizepsbt\n */\n (this.request as any)(\"signAndFinalizePsbt\", {\n hex: psbtHex,\n inputsToSign: signIndices.map(([address, signIndex]) => ({\n address,\n signingIndexes: [signIndex],\n signatureHash: undefined,\n disableTweakSigner: undefined,\n })),\n paymentType:\n signingAccount.addressType === WalletAdapterAddressType.P2TR\n ? \"p2tr\"\n : \"p2wpkh\",\n }),\n )\n\n return { signedPsbtHex: resp.hex }\n }\n\n onAddressesChanged(callback: WalletAdapter_onAddressesChanged_callback): {\n unsubscribe: () => void\n } {\n // Leather doesn't provide event, fallback to polling\n let stopped = false\n\n const tick = async (): Promise<void> => {\n if (stopped) return\n try {\n const addresses = await this.getAddresses()\n callback({ addresses })\n } catch (error) {\n if (error instanceof WalletAdapterNotConnectedError) {\n stopped = true\n return\n }\n console.warn(\"[Leather] Failed to get addresses on change:\", error)\n } finally {\n if (!stopped) {\n setTimeout(tick, 1000)\n }\n }\n }\n\n setTimeout(tick, 1000)\n\n return {\n unsubscribe: () => {\n stopped = true\n },\n }\n }\n}\n\nexport class LeatherWalletAdapterError extends BitcoinWalletAdapterError {\n constructor(rpcError: RpcErrorResponse<RpcErrorBody>) {\n super(\"Leather wallet error: \" + rpcError.error.message, {\n cause: rpcError,\n })\n }\n}\n\nconst handleRpcError = async <T>(\n promise: Promise<T>,\n): Promise<NonNullable<T>> => {\n try {\n return (await promise) as NonNullable<T>\n } catch (e: any) {\n if (e instanceof UserRejectError) {\n throw e\n }\n\n if (e.error?.code === RpcErrorCode.USER_REJECTION) {\n throw new UserRejectError()\n }\n\n throw new LeatherWalletAdapterError(e)\n }\n}\n"],"names":["LEATHER_PROVIDER_ID","localStorageKey","LeatherWalletAdapterImpl","request","resp","stored","handleRpcError","WalletAdapterNotConnectedError","addresses","a","isMainnet","WalletAdapterBitcoinNetwork","WalletAdapterAddressPurpose","WalletAdapterAddressType","hex","addressToScriptPubKey","getBitcoinNetwork","getTapInternalKeyOf_P2TR_publicKey","address","message","addressType","paymentType","BitcoinWalletAdapterError","SignMessageAlgorithm","fromAddress","receiverAddress","satoshiAmount","options","inscriptionId","txid","psbtHex","signIndices","signingAccount","account","signIndex","callback","stopped","tick","error","LeatherWalletAdapterError","rpcError","promise","UserRejectError"],"mappings":";;AA2CA,MAAMA,IAAsB,mCAEtBC,IAAkB,OAAOD,CAAmB;AAK3C,MAAME,EAAkD;AAAA,EAC7D,YAAoBC,GAAoB;AAApB,SAAA,UAAAA;AAAA,EAAqB;AAAA,EAExB,oBAAoB;AAAA,EAE7B,2BAAiE;AACvE,QAAIC;AACJ,UAAMC,IAAS,aAAa,QAAQJ,CAAe,KAAK;AACxD,QAAII,KAAU;AACZ,UAAI;AAEF,YADAD,IAAO,KAAK,MAAMC,CAAM,GAEtBD,KAAQ,QACR,EAAE,eAAeA,MACjB,CAAC,MAAM,QAAQA,EAAK,SAAS;AAE7B,gBAAM,IAAI,MAAM,0BAA0B;AAAA,MAE9C,QAAQ;AACN,qBAAa,WAAWH,CAAe;AAAA,MACzC;AAEF,WAAOG;AAAA,EACT;AAAA,EAEA,MAAM,UAAyB;AAC7B,QAAI,KAAK,yBAAA,KAA8B,MAAM;AAC3C,YAAMA,IAAO,MAAME;AAAA;AAAA;AAAA;AAAA,QAIjB,KAAK,QAAQ,cAAc;AAAA,MAAA;AAE7B,mBAAa,QAAQL,GAAiB,KAAK,UAAUG,CAAI,CAAC;AAAA,IAC5D;AAAA,EACF;AAAA,EAEA,MAAM,aAA4B;AAChC,wBAAa,WAAWH,CAAe,GAChC,QAAQ,QAAA;AAAA,EACjB;AAAA,EAEA,MAAM,eAAmC;AACvC,UAAMG,IAAO,KAAK,yBAAA;AAElB,QAAIA,KAAQ;AACV,YAAM,IAAIG,EAA+B,KAAK,iBAAiB;AAGjE,UAAMC,IAAYJ,EAAK,UAAU;AAAA,MAC/B,CAACK,MAAYA,EAAU,WAAW,SAASA,EAAE;AAAA,IAAA,GAGzCC,IAAYF,EACf,OAAO,CAACC,MAAWA,EAAE,SAAS,MAAM,EAAE,CAAC,EACvC,QAAQ,WAAW,IAAI;AAE1B,WAAOD,EAAU,IAAI,CAACC,OAAY;AAAA,MAChC,SAASC,IACLC,EAA4B,UAC5BA,EAA4B;AAAA,MAChC,UACEF,EAAE,SAAS,SACP;AAAA,QACEG,EAA4B;AAAA,QAC5BA,EAA4B;AAAA,QAC5BA,EAA4B;AAAA,MAAA,IAE9B,CAACA,EAA4B,OAAO;AAAA,MAC1C,aACEH,EAAE,SAAS,SACPI,EAAyB,OACzBA,EAAyB;AAAA,MAC/B,SAASJ,EAAE;AAAA,MACX,cAAcK,EAAI;AAAA,QAChBC;AAAA,UACEC,EAAkBN,IAAY,YAAY,SAAS;AAAA,UACnDD,EAAE;AAAA,QAAA;AAAA,MACJ;AAAA,MAEF,WAAWA,EAAE;AAAA,MACb,gBACEA,EAAE,SAAS,SACPK,EAAI;AAAA,QACFG;AAAA,UACED,EAAkBN,IAAY,YAAY,SAAS;AAAA,UACnDI,EAAI,OAAOL,EAAE,SAAU;AAAA,QAAA;AAAA,MACzB,IAEF;AAAA,IAAA,EACN;AAAA,EACJ;AAAA,EAEA,MAAM,YACJS,GACAC,GAC4B;AAG5B,UAAMC,KAFW,MAAM,KAAK,aAAA,GAEC,KAAK,OAAKX,EAAE,YAAYS,CAAO,GAAG,aAGzDG,IACJD,MAAgBP,EAAyB,SAAS,WAClDO,MAAgBP,EAAyB,OAAO,SAChD;AACF,QAAIQ,KAAe;AACjB,YAAM,IAAIC,EAA0B,0BAA0B;AAGhE,UAAMlB,IAAY,MAAME;AAAA;AAAA;AAAA;AAAA,MAItB,KAAK,QAAQ,eAAe;AAAA,QAC1B,SAAAa;AAAA,QACA,aAAAE;AAAA,MAAA,CACD;AAAA,IAAA;AAGH,WAAO;AAAA,MACL,WACEjB,EAAK,cAAc,UACfmB,EAAqB,QACrBA,EAAqB;AAAA,MAC3B,QAAQnB,EAAK;AAAA,MACb,SAAAc;AAAA,MACA,WAAWd,EAAK;AAAA,IAAA;AAAA,EAEpB;AAAA,EAEA,+BAA+B;AAAA,EAC/B,MAAM,YACJoB,GACAC,GACAC,GACAC,GAC2B;AAY3B,WAAO,EAAE,OAXS,MAAMrB;AAAA;AAAA;AAAA;AAAA,MAIrB,KAAK,QAAgB,eAAe;AAAA,QACnC,QAAQkB;AAAA,QACR,aAAaC;AAAA,QACb,QAAQC;AAAA,QACR,SAASC,GAAS;AAAA,MAAA,CACnB;AAAA,IAAA,GAEiB,KAAA;AAAA,EACtB;AAAA,EAEA,mCAAmC;AAAA,EAEnC,MAAM,gBACJH,GACAC,GACAG,GACAD,GAC2B;AAC3B,UAAM,EAAE,MAAAE,EAAA,IAAc,MAAMvB;AAAA;AAAA;AAAA;AAAA,MAIzB,KAAK,QAAgB,gBAAgB;AAAA,QACpC,UAAU;AAAA,UACR;AAAA,YACE,aAAamB;AAAA,YACb,IAAIG;AAAA,UAAA;AAAA,QACN;AAAA,QAEF,aAAa;AAAA,QACb,QAAQJ;AAAA,QACR,SAASG,GAAS;AAAA,MAAA,CACnB;AAAA,IAAA;AAEH,WAAO,EAAE,MAAAE,EAAA;AAAA,EACX;AAAA,EAEA,MAAM,oBACJC,GACAC,GAGC;AAED,UAAMC,KADW,MAAM,KAAK,aAAA,GACI;AAAA,MAC9B,OAAWC,EAAQ,YAAYF,EAAY,CAAC,IAAI,CAAC;AAAA,IAAA;AAEnD,QAAIC,KAAkB;AACpB,YAAM,IAAIzB,EAA+B,KAAK,iBAAiB;AAsBjE,WAAO,EAAE,gBAnBS,MAAMD;AAAA;AAAA;AAAA;AAAA,MAIrB,KAAK,QAAgB,uBAAuB;AAAA,QAC3C,KAAKwB;AAAA,QACL,cAAcC,EAAY,IAAI,CAAC,CAACb,GAASgB,CAAS,OAAO;AAAA,UACvD,SAAAhB;AAAA,UACA,gBAAgB,CAACgB,CAAS;AAAA,UAC1B,eAAe;AAAA,UACf,oBAAoB;AAAA,QAAA,EACpB;AAAA,QACF,aACEF,EAAe,gBAAgBnB,EAAyB,OACpD,SACA;AAAA,MAAA,CACP;AAAA,IAAA,GAG0B,IAAA;AAAA,EAC/B;AAAA,EAEA,mBAAmBsB,GAEjB;AAEA,QAAIC,IAAU;AAEd,UAAMC,IAAO,YAA2B;AACtC,UAAI,CAAAD;AACJ,YAAI;AACF,gBAAM5B,IAAY,MAAM,KAAK,aAAA;AAC7B,UAAA2B,EAAS,EAAE,WAAA3B,GAAW;AAAA,QACxB,SAAS8B,GAAO;AACd,cAAIA,aAAiB/B,GAAgC;AACnD,YAAA6B,IAAU;AACV;AAAA,UACF;AACA,kBAAQ,KAAK,gDAAgDE,CAAK;AAAA,QACpE,UAAA;AACE,UAAKF,KACH,WAAWC,GAAM,GAAI;AAAA,QAEzB;AAAA,IACF;AAEA,sBAAWA,GAAM,GAAI,GAEd;AAAA,MACL,aAAa,MAAM;AACjB,QAAAD,IAAU;AAAA,MACZ;AAAA,IAAA;AAAA,EAEJ;AACF;AAEO,MAAMG,UAAkCjB,EAA0B;AAAA,EACvE,YAAYkB,GAA0C;AACpD,UAAM,2BAA2BA,EAAS,MAAM,SAAS;AAAA,MACvD,OAAOA;AAAA,IAAA,CACR;AAAA,EACH;AACF;AAEA,MAAMlC,IAAiB,OACrBmC,MAC4B;AAC5B,MAAI;AACF,WAAQ,MAAMA;AAAA,EAChB,SAAS,GAAQ;AACf,UAAI,aAAaC,IACT,IAGJ,EAAE,OAAO,SAAS,OACd,IAAIA,EAAA,IAGN,IAAIH,EAA0B,CAAC;AAAA,EACvC;AACF;"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MagicEdenWalletAdapter.impl-CrA6SGvG.mjs","sources":["../src/utils/XverseCompatibleWalletAdapterImpl_legacy.ts","../src/adapters/MagicEdenWalletAdapter.impl.ts"],"sourcesContent":["import { base64, hex } from \"@scure/base\"\nimport * as btc from \"@scure/btc-signer\"\nimport { UserRejectError } from \"../utils/error\"\nimport {\n SignMessageAlgorithm,\n SignMessageResult,\n WalletAdapter,\n WalletAdapter_onAddressesChanged_callback,\n WalletAdapterAddress,\n WalletAdapterAddressPurpose,\n WalletAdapterBitcoinNetwork,\n WalletAdapterNotConnectedError,\n} from \"../WalletAdapters.types\"\nimport {\n XverseCompatibleProviderError,\n XverseRpcErrorCode,\n} from \"./XverseCompatibleWalletAdapterImpl\"\n\ntype GetAddressResponse = import(\"sats-connect\").GetAddressResponse\n\nexport type XverseCompatibleWalletAdapterGetProviderFn = () => Promise<\n import(\"sats-connect\").BitcoinProvider\n>\n\nexport type XverseCompatibleWalletAdapterParsedAddressesFn = (info: {\n sdk: typeof import(\"sats-connect\")\n addresses: import(\"sats-connect\").Address[]\n}) => Promise<XverseCompatibleWalletAdapterImplAddress[]>\n\nexport type XverseCompatibleWalletAdapterImplAddress = WalletAdapterAddress & {\n publicKey: string\n}\n\nexport class XverseCompatibleWalletAdapterImpl_legacy implements WalletAdapter {\n protected readonly network: WalletAdapterBitcoinNetwork\n protected readonly localStorageKey: string\n protected readonly walletDisplayName: string\n protected readonly getProvider: XverseCompatibleWalletAdapterGetProviderFn\n protected readonly parseAddresses: XverseCompatibleWalletAdapterParsedAddressesFn\n\n constructor(info: {\n network: WalletAdapterBitcoinNetwork\n localStorageKey: string\n walletDisplayName: string\n getProvider: XverseCompatibleWalletAdapterGetProviderFn\n parseAddresses: XverseCompatibleWalletAdapterParsedAddressesFn\n }) {\n this.network = info.network\n this.localStorageKey = info.localStorageKey\n this.walletDisplayName = info.walletDisplayName\n this.getProvider = info.getProvider\n this.parseAddresses = info.parseAddresses\n }\n\n private async getSdk(): Promise<typeof import(\"sats-connect\")> {\n return import(\"sats-connect\")\n }\n\n protected retrieveConnectedAddress(): GetAddressResponse | undefined {\n let resp: GetAddressResponse | undefined\n const stored = localStorage.getItem(this.localStorageKey) || undefined\n if (stored != null) {\n try {\n resp = JSON.parse(stored)\n if (\n resp == null ||\n !(\"addresses\" in resp) ||\n !Array.isArray(resp.addresses)\n ) {\n throw new Error(\"Invalid stored addresses\")\n }\n } catch {\n localStorage.removeItem(this.localStorageKey)\n }\n }\n return resp\n }\n protected async updateConnectedAddress(\n addresses: GetAddressResponse[\"addresses\"],\n ): Promise<void> {\n localStorage.setItem(this.localStorageKey, JSON.stringify({ addresses }))\n }\n\n async connect(): Promise<void> {\n if (this.retrieveConnectedAddress() == null) {\n const resp = await this.connectImpl()\n await this.updateConnectedAddress(resp.addresses)\n }\n }\n private async connectImpl(): Promise<GetAddressResponse> {\n const sdk = await this.getSdk()\n\n const networkType =\n this.network === WalletAdapterBitcoinNetwork.MAINNET\n ? sdk.BitcoinNetworkType.Mainnet\n : sdk.BitcoinNetworkType.Testnet\n\n return new Promise<GetAddressResponse>((resolve, reject) => {\n void sdk\n .getAddress({\n getProvider: () => this.getProvider(),\n payload: {\n purposes: [sdk.AddressPurpose.Ordinals, sdk.AddressPurpose.Payment],\n message: \"Address for receiving Ordinals and payments\",\n network: { type: networkType },\n },\n onFinish(resp) {\n resolve(resp)\n },\n onCancel() {\n reject(new UserRejectError())\n },\n })\n .catch(reject)\n })\n }\n\n async disconnect(): Promise<void> {\n localStorage.removeItem(this.localStorageKey)\n return Promise.resolve()\n }\n\n async getAddresses(): Promise<XverseCompatibleWalletAdapterImplAddress[]> {\n const resp = this.retrieveConnectedAddress()\n\n if (resp == null) {\n throw new WalletAdapterNotConnectedError(this.walletDisplayName)\n }\n\n const sdk = await this.getSdk()\n\n return this.parseAddresses({ sdk, addresses: resp.addresses })\n }\n\n async signMessage(\n address: string,\n message: string,\n ): Promise<SignMessageResult> {\n const sdk = await this.getSdk()\n\n return new Promise((resolve, reject) => {\n /**\n * https://docs.xverse.app/sats-connect/methods/signmessage\n */\n void sdk.signMessage({\n getProvider: () => this.getProvider(),\n payload: {\n network: {\n type:\n this.network === \"mainnet\"\n ? sdk.BitcoinNetworkType.Mainnet\n : sdk.BitcoinNetworkType.Testnet,\n },\n address,\n message,\n protocol: sdk.MessageSigningProtocols.BIP322,\n },\n onFinish(resp) {\n resolve({\n result: resp,\n address,\n algorithm: SignMessageAlgorithm.BIP322,\n })\n },\n onCancel() {\n reject(new UserRejectError())\n },\n })\n })\n }\n\n sendBitcoinFeeRateCapability = \"unavailable\" as const\n async sendBitcoin(\n fromAddress: string,\n receiverAddress: string,\n satoshiAmount: bigint,\n ): Promise<{ txid: string }> {\n const senderAddress = (await this.getAddresses()).find(a =>\n a.purposes.includes(WalletAdapterAddressPurpose.Bitcoin),\n )\n if (senderAddress == null) {\n throw new XverseCompatibleProviderError({\n code: XverseRpcErrorCode.INVALID_PARAMS,\n message: \"Bitcoin address not found\",\n })\n }\n\n const sdk = await this.getSdk()\n\n return new Promise((resolve, reject) => {\n void sdk\n .sendBtcTransaction({\n getProvider: () => this.getProvider(),\n payload: {\n network: {\n type:\n this.network === WalletAdapterBitcoinNetwork.MAINNET\n ? sdk.BitcoinNetworkType.Mainnet\n : sdk.BitcoinNetworkType.Testnet,\n },\n message: \"Send Bitcoin\",\n recipients: [\n {\n address: receiverAddress,\n amountSats: BigInt(satoshiAmount),\n },\n ],\n senderAddress: senderAddress.address,\n },\n onFinish(resp) {\n return resolve({ txid: resp })\n },\n onCancel() {\n reject(new UserRejectError())\n },\n })\n .catch(reject)\n })\n }\n\n sendInscriptionFeeRateCapability = \"unavailable\" as const\n\n async signAndFinalizePsbt(\n psbtHex: string,\n signIndices: [address: string, signIndex: number][],\n ): Promise<{\n signedPsbtHex: string\n }> {\n const sdk = await this.getSdk()\n\n const psbtBase64 = base64.encode(hex.decode(psbtHex))\n\n const signedPsbt = await new Promise<Uint8Array>((resolve, reject) => {\n void sdk\n .signTransaction({\n getProvider: () => this.getProvider(),\n payload: {\n network: {\n type:\n this.network === WalletAdapterBitcoinNetwork.MAINNET\n ? sdk.BitcoinNetworkType.Mainnet\n : sdk.BitcoinNetworkType.Testnet,\n },\n message: \"Sign transaction\",\n psbtBase64,\n inputsToSign: signIndices.map(([address, signIndex]) => ({\n address,\n signingIndexes: [signIndex],\n })),\n broadcast: false,\n },\n onFinish(resp) {\n resolve(base64.decode(resp.psbtBase64))\n },\n onCancel() {\n reject(new UserRejectError())\n },\n })\n .catch(reject)\n })\n\n const tx = btc.Transaction.fromPSBT(signedPsbt, {\n allowUnknownInputs: true,\n allowUnknownOutputs: true,\n disableScriptCheck: true,\n allowLegacyWitnessUtxo: true,\n })\n tx.finalize()\n\n return { signedPsbtHex: hex.encode(tx.toPSBT()) }\n }\n\n onAddressesChanged(callback: WalletAdapter_onAddressesChanged_callback): {\n unsubscribe: () => void\n } {\n throw new Error(\"Not implemented\")\n }\n}\n","import { hex } from \"@scure/base\"\nimport { addressToScriptPubKey } from \"../utils/bitcoinAddressHelpers\"\nimport { getBitcoinNetwork } from \"../utils/bitcoinNetworkHelpers\"\nimport {\n WalletAdapter,\n WalletAdapter_onAddressesChanged_callback,\n WalletAdapterAddressPurpose,\n WalletAdapterAddressType,\n WalletAdapterBitcoinNetwork,\n} from \"../WalletAdapters.types\"\nimport {\n XverseCompatibleWalletAdapterImpl_legacy,\n XverseCompatibleWalletAdapterImplAddress,\n} from \"../utils/XverseCompatibleWalletAdapterImpl_legacy\"\nimport { MAGICEDEN_PROVIDER_ID } from \"./MagicEdenWalletAdapter\"\n\ninterface MagicEdenBitcoinProviderEvents {\n accountsChanged: [\n event: {\n accounts: import(\"sats-connect\").GetAddressResponse[\"addresses\"]\n },\n ]\n}\n\nexport interface MagicEdenBitcoinProvider {\n isMagicEden: boolean\n on: <K extends keyof MagicEdenBitcoinProviderEvents>(\n event: K,\n handler: (...args: MagicEdenBitcoinProviderEvents[K]) => void,\n ) => void\n removeListener: <K extends keyof MagicEdenBitcoinProviderEvents>(\n event: K,\n handler: (...args: MagicEdenBitcoinProviderEvents[K]) => void,\n ) => void\n}\n\nconst localStorageKey = `app:${MAGICEDEN_PROVIDER_ID}:`\n\nexport class MagicEdenWalletAdapterImpl\n extends XverseCompatibleWalletAdapterImpl_legacy\n implements WalletAdapter\n{\n private magicEden: MagicEdenBitcoinProvider\n\n constructor(\n network: WalletAdapterBitcoinNetwork,\n provider: MagicEdenBitcoinProvider,\n ) {\n super({\n network,\n localStorageKey,\n walletDisplayName: \"Magic Eden\",\n getProvider: async () => {\n return provider as any\n },\n parseAddresses: async ({ sdk, addresses }) => {\n const isMainnet = addresses\n .filter(a => a.purpose === sdk.AddressPurpose.Ordinals)[0]\n .address.startsWith(\"bc\")\n\n return addresses.flatMap(\n (a): XverseCompatibleWalletAdapterImplAddress[] => {\n if (a.purpose === sdk.AddressPurpose.Payment) {\n return [\n {\n addressType: WalletAdapterAddressType.P2WPKH,\n purposes: [WalletAdapterAddressPurpose.Bitcoin],\n address: a.address,\n network: this.network,\n scriptPubKey: hex.encode(\n addressToScriptPubKey(\n getBitcoinNetwork(isMainnet ? \"mainnet\" : \"testnet\"),\n a.address,\n ),\n ),\n publicKey: a.publicKey,\n },\n ]\n }\n\n if (a.purpose === sdk.AddressPurpose.Ordinals) {\n return [\n {\n addressType: WalletAdapterAddressType.P2TR,\n purposes: [\n WalletAdapterAddressPurpose.Ordinals,\n WalletAdapterAddressPurpose.BRC20,\n WalletAdapterAddressPurpose.Runes,\n ],\n address: a.address,\n network: this.network,\n scriptPubKey: hex.encode(\n addressToScriptPubKey(\n getBitcoinNetwork(isMainnet ? \"mainnet\" : \"testnet\"),\n a.address,\n ),\n ),\n publicKey: a.publicKey,\n tapInternalKey: a.publicKey,\n },\n ]\n }\n\n return []\n },\n )\n },\n })\n this.magicEden = provider\n }\n\n onAddressesChanged(callback: WalletAdapter_onAddressesChanged_callback): {\n unsubscribe: () => void\n } {\n // MagicEden uses accountsChanged event\n // https://docs-wallet.magiceden.io/bitcoin/provider-events\n const provider = this.magicEden\n\n const handler = async (event: {\n accounts: import(\"sats-connect\").GetAddressResponse[\"addresses\"]\n }): Promise<void> => {\n try {\n await this.updateConnectedAddress(event.accounts)\n const addresses = await this.getAddresses()\n callback({ addresses })\n } catch (error) {\n console.warn(\"[Magic Eden] Failed to get addresses on change:\", error)\n }\n }\n\n provider.on(\"accountsChanged\", handler)\n\n return {\n unsubscribe: () => {\n provider.removeListener(\"accountsChanged\", handler)\n },\n }\n }\n}\n"],"names":["XverseCompatibleWalletAdapterImpl_legacy","info","resp","stored","addresses","sdk","networkType","WalletAdapterBitcoinNetwork","resolve","reject","UserRejectError","WalletAdapterNotConnectedError","address","message","SignMessageAlgorithm","fromAddress","receiverAddress","satoshiAmount","senderAddress","a","WalletAdapterAddressPurpose","XverseCompatibleProviderError","XverseRpcErrorCode","psbtHex","signIndices","psbtBase64","base64","hex","signedPsbt","signIndex","tx","btc.Transaction","callback","localStorageKey","MAGICEDEN_PROVIDER_ID","MagicEdenWalletAdapterImpl","network","provider","isMainnet","WalletAdapterAddressType","addressToScriptPubKey","getBitcoinNetwork","handler","event","error"],"mappings":"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"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=require("./index-Zx0KcpYx.js"),a=require("./WalletAdapters.types-De_x1lzr.js"),p=require("./XverseCompatibleWalletAdapterImpl-Bf-BK5VK.js"),y=require("./transaction-CzdnbXSo.js");class w{network;localStorageKey;walletDisplayName;getProvider;parseAddresses;constructor(e){this.network=e.network,this.localStorageKey=e.localStorageKey,this.walletDisplayName=e.walletDisplayName,this.getProvider=e.getProvider,this.parseAddresses=e.parseAddresses}async getSdk(){return Promise.resolve().then(()=>require("./index-CaV3F1Nm.js"))}retrieveConnectedAddress(){let e;const r=localStorage.getItem(this.localStorageKey)||void 0;if(r!=null)try{if(e=JSON.parse(r),e==null||!("addresses"in e)||!Array.isArray(e.addresses))throw new Error("Invalid stored addresses")}catch{localStorage.removeItem(this.localStorageKey)}return e}async updateConnectedAddress(e){localStorage.setItem(this.localStorageKey,JSON.stringify({addresses:e}))}async connect(){if(this.retrieveConnectedAddress()==null){const e=await this.connectImpl();await this.updateConnectedAddress(e.addresses)}}async connectImpl(){const e=await this.getSdk(),r=this.network===a.WalletAdapterBitcoinNetwork.MAINNET?e.BitcoinNetworkType.Mainnet:e.BitcoinNetworkType.Testnet;return new Promise((t,o)=>{e.getAddress({getProvider:()=>this.getProvider(),payload:{purposes:[e.AddressPurpose.Ordinals,e.AddressPurpose.Payment],message:"Address for receiving Ordinals and payments",network:{type:r}},onFinish(n){t(n)},onCancel(){o(new a.UserRejectError)}}).catch(o)})}async disconnect(){return localStorage.removeItem(this.localStorageKey),Promise.resolve()}async getAddresses(){const e=this.retrieveConnectedAddress();if(e==null)throw new a.WalletAdapterNotConnectedError(this.walletDisplayName);const r=await this.getSdk();return this.parseAddresses({sdk:r,addresses:e.addresses})}async signMessage(e,r){const t=await this.getSdk();return new Promise((o,n)=>{t.signMessage({getProvider:()=>this.getProvider(),payload:{network:{type:this.network==="mainnet"?t.BitcoinNetworkType.Mainnet:t.BitcoinNetworkType.Testnet},address:e,message:r,protocol:t.MessageSigningProtocols.BIP322},onFinish(s){o({result:s,address:e,algorithm:a.SignMessageAlgorithm.BIP322})},onCancel(){n(new a.UserRejectError)}})})}sendBitcoinFeeRateCapability="unavailable";async sendBitcoin(e,r,t){const o=(await this.getAddresses()).find(s=>s.purposes.includes(a.WalletAdapterAddressPurpose.Bitcoin));if(o==null)throw new p.XverseCompatibleProviderError({code:p.XverseRpcErrorCode.INVALID_PARAMS,message:"Bitcoin address not found"});const n=await this.getSdk();return new Promise((s,d)=>{n.sendBtcTransaction({getProvider:()=>this.getProvider(),payload:{network:{type:this.network===a.WalletAdapterBitcoinNetwork.MAINNET?n.BitcoinNetworkType.Mainnet:n.BitcoinNetworkType.Testnet},message:"Send Bitcoin",recipients:[{address:r,amountSats:BigInt(t)}],senderAddress:o.address},onFinish(c){return s({txid:c})},onCancel(){d(new a.UserRejectError)}}).catch(d)})}sendInscriptionFeeRateCapability="unavailable";async signAndFinalizePsbt(e,r){const t=await this.getSdk(),o=i.base64.encode(i.hex.decode(e)),n=await new Promise((d,c)=>{t.signTransaction({getProvider:()=>this.getProvider(),payload:{network:{type:this.network===a.WalletAdapterBitcoinNetwork.MAINNET?t.BitcoinNetworkType.Mainnet:t.BitcoinNetworkType.Testnet},message:"Sign transaction",psbtBase64:o,inputsToSign:r.map(([l,u])=>({address:l,signingIndexes:[u]})),broadcast:!1},onFinish(l){d(i.base64.decode(l.psbtBase64))},onCancel(){c(new a.UserRejectError)}}).catch(c)}),s=y.Transaction.fromPSBT(n,{allowUnknownInputs:!0,allowUnknownOutputs:!0,disableScriptCheck:!0,allowLegacyWitnessUtxo:!0});return s.finalize(),{signedPsbtHex:i.hex.encode(s.toPSBT())}}onAddressesChanged(e){throw new Error("Not implemented")}}const h=`app:${i.MAGICEDEN_PROVIDER_ID}:`;class A extends w{magicEden;constructor(e,r){super({network:e,localStorageKey:h,walletDisplayName:"Magic Eden",getProvider:async()=>r,parseAddresses:async({sdk:t,addresses:o})=>{const n=o.filter(s=>s.purpose===t.AddressPurpose.Ordinals)[0].address.startsWith("bc");return o.flatMap(s=>s.purpose===t.AddressPurpose.Payment?[{addressType:a.WalletAdapterAddressType.P2WPKH,purposes:[a.WalletAdapterAddressPurpose.Bitcoin],address:s.address,network:this.network,scriptPubKey:i.hex.encode(i.addressToScriptPubKey(i.getBitcoinNetwork(n?"mainnet":"testnet"),s.address)),publicKey:s.publicKey}]:s.purpose===t.AddressPurpose.Ordinals?[{addressType:a.WalletAdapterAddressType.P2TR,purposes:[a.WalletAdapterAddressPurpose.Ordinals,a.WalletAdapterAddressPurpose.BRC20,a.WalletAdapterAddressPurpose.Runes],address:s.address,network:this.network,scriptPubKey:i.hex.encode(i.addressToScriptPubKey(i.getBitcoinNetwork(n?"mainnet":"testnet"),s.address)),publicKey:s.publicKey,tapInternalKey:s.publicKey}]:[])}}),this.magicEden=r}onAddressesChanged(e){const r=this.magicEden,t=async o=>{try{await this.updateConnectedAddress(o.accounts);const n=await this.getAddresses();e({addresses:n})}catch(n){console.warn("[Magic Eden] Failed to get addresses on change:",n)}};return r.on("accountsChanged",t),{unsubscribe:()=>{r.removeListener("accountsChanged",t)}}}}exports.MagicEdenWalletAdapterImpl=A;
|
|
2
|
-
//# sourceMappingURL=MagicEdenWalletAdapter.impl-Di3Nu2S5.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MagicEdenWalletAdapter.impl-Di3Nu2S5.js","sources":["../src/utils/XverseCompatibleWalletAdapterImpl_legacy.ts","../src/adapters/MagicEdenWalletAdapter.impl.ts"],"sourcesContent":["import { base64, hex } from \"@scure/base\"\nimport * as btc from \"@scure/btc-signer\"\nimport { UserRejectError } from \"../utils/error\"\nimport {\n SignMessageAlgorithm,\n SignMessageResult,\n WalletAdapter,\n WalletAdapter_onAddressesChanged_callback,\n WalletAdapterAddress,\n WalletAdapterAddressPurpose,\n WalletAdapterBitcoinNetwork,\n WalletAdapterNotConnectedError,\n} from \"../WalletAdapters.types\"\nimport {\n XverseCompatibleProviderError,\n XverseRpcErrorCode,\n} from \"./XverseCompatibleWalletAdapterImpl\"\n\ntype GetAddressResponse = import(\"sats-connect\").GetAddressResponse\n\nexport type XverseCompatibleWalletAdapterGetProviderFn = () => Promise<\n import(\"sats-connect\").BitcoinProvider\n>\n\nexport type XverseCompatibleWalletAdapterParsedAddressesFn = (info: {\n sdk: typeof import(\"sats-connect\")\n addresses: import(\"sats-connect\").Address[]\n}) => Promise<XverseCompatibleWalletAdapterImplAddress[]>\n\nexport type XverseCompatibleWalletAdapterImplAddress = WalletAdapterAddress & {\n publicKey: string\n}\n\nexport class XverseCompatibleWalletAdapterImpl_legacy implements WalletAdapter {\n protected readonly network: WalletAdapterBitcoinNetwork\n protected readonly localStorageKey: string\n protected readonly walletDisplayName: string\n protected readonly getProvider: XverseCompatibleWalletAdapterGetProviderFn\n protected readonly parseAddresses: XverseCompatibleWalletAdapterParsedAddressesFn\n\n constructor(info: {\n network: WalletAdapterBitcoinNetwork\n localStorageKey: string\n walletDisplayName: string\n getProvider: XverseCompatibleWalletAdapterGetProviderFn\n parseAddresses: XverseCompatibleWalletAdapterParsedAddressesFn\n }) {\n this.network = info.network\n this.localStorageKey = info.localStorageKey\n this.walletDisplayName = info.walletDisplayName\n this.getProvider = info.getProvider\n this.parseAddresses = info.parseAddresses\n }\n\n private async getSdk(): Promise<typeof import(\"sats-connect\")> {\n return import(\"sats-connect\")\n }\n\n protected retrieveConnectedAddress(): GetAddressResponse | undefined {\n let resp: GetAddressResponse | undefined\n const stored = localStorage.getItem(this.localStorageKey) || undefined\n if (stored != null) {\n try {\n resp = JSON.parse(stored)\n if (\n resp == null ||\n !(\"addresses\" in resp) ||\n !Array.isArray(resp.addresses)\n ) {\n throw new Error(\"Invalid stored addresses\")\n }\n } catch {\n localStorage.removeItem(this.localStorageKey)\n }\n }\n return resp\n }\n protected async updateConnectedAddress(\n addresses: GetAddressResponse[\"addresses\"],\n ): Promise<void> {\n localStorage.setItem(this.localStorageKey, JSON.stringify({ addresses }))\n }\n\n async connect(): Promise<void> {\n if (this.retrieveConnectedAddress() == null) {\n const resp = await this.connectImpl()\n await this.updateConnectedAddress(resp.addresses)\n }\n }\n private async connectImpl(): Promise<GetAddressResponse> {\n const sdk = await this.getSdk()\n\n const networkType =\n this.network === WalletAdapterBitcoinNetwork.MAINNET\n ? sdk.BitcoinNetworkType.Mainnet\n : sdk.BitcoinNetworkType.Testnet\n\n return new Promise<GetAddressResponse>((resolve, reject) => {\n void sdk\n .getAddress({\n getProvider: () => this.getProvider(),\n payload: {\n purposes: [sdk.AddressPurpose.Ordinals, sdk.AddressPurpose.Payment],\n message: \"Address for receiving Ordinals and payments\",\n network: { type: networkType },\n },\n onFinish(resp) {\n resolve(resp)\n },\n onCancel() {\n reject(new UserRejectError())\n },\n })\n .catch(reject)\n })\n }\n\n async disconnect(): Promise<void> {\n localStorage.removeItem(this.localStorageKey)\n return Promise.resolve()\n }\n\n async getAddresses(): Promise<XverseCompatibleWalletAdapterImplAddress[]> {\n const resp = this.retrieveConnectedAddress()\n\n if (resp == null) {\n throw new WalletAdapterNotConnectedError(this.walletDisplayName)\n }\n\n const sdk = await this.getSdk()\n\n return this.parseAddresses({ sdk, addresses: resp.addresses })\n }\n\n async signMessage(\n address: string,\n message: string,\n ): Promise<SignMessageResult> {\n const sdk = await this.getSdk()\n\n return new Promise((resolve, reject) => {\n /**\n * https://docs.xverse.app/sats-connect/methods/signmessage\n */\n void sdk.signMessage({\n getProvider: () => this.getProvider(),\n payload: {\n network: {\n type:\n this.network === \"mainnet\"\n ? sdk.BitcoinNetworkType.Mainnet\n : sdk.BitcoinNetworkType.Testnet,\n },\n address,\n message,\n protocol: sdk.MessageSigningProtocols.BIP322,\n },\n onFinish(resp) {\n resolve({\n result: resp,\n address,\n algorithm: SignMessageAlgorithm.BIP322,\n })\n },\n onCancel() {\n reject(new UserRejectError())\n },\n })\n })\n }\n\n sendBitcoinFeeRateCapability = \"unavailable\" as const\n async sendBitcoin(\n fromAddress: string,\n receiverAddress: string,\n satoshiAmount: bigint,\n ): Promise<{ txid: string }> {\n const senderAddress = (await this.getAddresses()).find(a =>\n a.purposes.includes(WalletAdapterAddressPurpose.Bitcoin),\n )\n if (senderAddress == null) {\n throw new XverseCompatibleProviderError({\n code: XverseRpcErrorCode.INVALID_PARAMS,\n message: \"Bitcoin address not found\",\n })\n }\n\n const sdk = await this.getSdk()\n\n return new Promise((resolve, reject) => {\n void sdk\n .sendBtcTransaction({\n getProvider: () => this.getProvider(),\n payload: {\n network: {\n type:\n this.network === WalletAdapterBitcoinNetwork.MAINNET\n ? sdk.BitcoinNetworkType.Mainnet\n : sdk.BitcoinNetworkType.Testnet,\n },\n message: \"Send Bitcoin\",\n recipients: [\n {\n address: receiverAddress,\n amountSats: BigInt(satoshiAmount),\n },\n ],\n senderAddress: senderAddress.address,\n },\n onFinish(resp) {\n return resolve({ txid: resp })\n },\n onCancel() {\n reject(new UserRejectError())\n },\n })\n .catch(reject)\n })\n }\n\n sendInscriptionFeeRateCapability = \"unavailable\" as const\n\n async signAndFinalizePsbt(\n psbtHex: string,\n signIndices: [address: string, signIndex: number][],\n ): Promise<{\n signedPsbtHex: string\n }> {\n const sdk = await this.getSdk()\n\n const psbtBase64 = base64.encode(hex.decode(psbtHex))\n\n const signedPsbt = await new Promise<Uint8Array>((resolve, reject) => {\n void sdk\n .signTransaction({\n getProvider: () => this.getProvider(),\n payload: {\n network: {\n type:\n this.network === WalletAdapterBitcoinNetwork.MAINNET\n ? sdk.BitcoinNetworkType.Mainnet\n : sdk.BitcoinNetworkType.Testnet,\n },\n message: \"Sign transaction\",\n psbtBase64,\n inputsToSign: signIndices.map(([address, signIndex]) => ({\n address,\n signingIndexes: [signIndex],\n })),\n broadcast: false,\n },\n onFinish(resp) {\n resolve(base64.decode(resp.psbtBase64))\n },\n onCancel() {\n reject(new UserRejectError())\n },\n })\n .catch(reject)\n })\n\n const tx = btc.Transaction.fromPSBT(signedPsbt, {\n allowUnknownInputs: true,\n allowUnknownOutputs: true,\n disableScriptCheck: true,\n allowLegacyWitnessUtxo: true,\n })\n tx.finalize()\n\n return { signedPsbtHex: hex.encode(tx.toPSBT()) }\n }\n\n onAddressesChanged(callback: WalletAdapter_onAddressesChanged_callback): {\n unsubscribe: () => void\n } {\n throw new Error(\"Not implemented\")\n }\n}\n","import { hex } from \"@scure/base\"\nimport { addressToScriptPubKey } from \"../utils/bitcoinAddressHelpers\"\nimport { getBitcoinNetwork } from \"../utils/bitcoinNetworkHelpers\"\nimport {\n WalletAdapter,\n WalletAdapter_onAddressesChanged_callback,\n WalletAdapterAddressPurpose,\n WalletAdapterAddressType,\n WalletAdapterBitcoinNetwork,\n} from \"../WalletAdapters.types\"\nimport {\n XverseCompatibleWalletAdapterImpl_legacy,\n XverseCompatibleWalletAdapterImplAddress,\n} from \"../utils/XverseCompatibleWalletAdapterImpl_legacy\"\nimport { MAGICEDEN_PROVIDER_ID } from \"./MagicEdenWalletAdapter\"\n\ninterface MagicEdenBitcoinProviderEvents {\n accountsChanged: [\n event: {\n accounts: import(\"sats-connect\").GetAddressResponse[\"addresses\"]\n },\n ]\n}\n\nexport interface MagicEdenBitcoinProvider {\n isMagicEden: boolean\n on: <K extends keyof MagicEdenBitcoinProviderEvents>(\n event: K,\n handler: (...args: MagicEdenBitcoinProviderEvents[K]) => void,\n ) => void\n removeListener: <K extends keyof MagicEdenBitcoinProviderEvents>(\n event: K,\n handler: (...args: MagicEdenBitcoinProviderEvents[K]) => void,\n ) => void\n}\n\nconst localStorageKey = `app:${MAGICEDEN_PROVIDER_ID}:`\n\nexport class MagicEdenWalletAdapterImpl\n extends XverseCompatibleWalletAdapterImpl_legacy\n implements WalletAdapter\n{\n private magicEden: MagicEdenBitcoinProvider\n\n constructor(\n network: WalletAdapterBitcoinNetwork,\n provider: MagicEdenBitcoinProvider,\n ) {\n super({\n network,\n localStorageKey,\n walletDisplayName: \"Magic Eden\",\n getProvider: async () => {\n return provider as any\n },\n parseAddresses: async ({ sdk, addresses }) => {\n const isMainnet = addresses\n .filter(a => a.purpose === sdk.AddressPurpose.Ordinals)[0]\n .address.startsWith(\"bc\")\n\n return addresses.flatMap(\n (a): XverseCompatibleWalletAdapterImplAddress[] => {\n if (a.purpose === sdk.AddressPurpose.Payment) {\n return [\n {\n addressType: WalletAdapterAddressType.P2WPKH,\n purposes: [WalletAdapterAddressPurpose.Bitcoin],\n address: a.address,\n network: this.network,\n scriptPubKey: hex.encode(\n addressToScriptPubKey(\n getBitcoinNetwork(isMainnet ? \"mainnet\" : \"testnet\"),\n a.address,\n ),\n ),\n publicKey: a.publicKey,\n },\n ]\n }\n\n if (a.purpose === sdk.AddressPurpose.Ordinals) {\n return [\n {\n addressType: WalletAdapterAddressType.P2TR,\n purposes: [\n WalletAdapterAddressPurpose.Ordinals,\n WalletAdapterAddressPurpose.BRC20,\n WalletAdapterAddressPurpose.Runes,\n ],\n address: a.address,\n network: this.network,\n scriptPubKey: hex.encode(\n addressToScriptPubKey(\n getBitcoinNetwork(isMainnet ? \"mainnet\" : \"testnet\"),\n a.address,\n ),\n ),\n publicKey: a.publicKey,\n tapInternalKey: a.publicKey,\n },\n ]\n }\n\n return []\n },\n )\n },\n })\n this.magicEden = provider\n }\n\n onAddressesChanged(callback: WalletAdapter_onAddressesChanged_callback): {\n unsubscribe: () => void\n } {\n // MagicEden uses accountsChanged event\n // https://docs-wallet.magiceden.io/bitcoin/provider-events\n const provider = this.magicEden\n\n const handler = async (event: {\n accounts: import(\"sats-connect\").GetAddressResponse[\"addresses\"]\n }): Promise<void> => {\n try {\n await this.updateConnectedAddress(event.accounts)\n const addresses = await this.getAddresses()\n callback({ addresses })\n } catch (error) {\n console.warn(\"[Magic Eden] Failed to get addresses on change:\", error)\n }\n }\n\n provider.on(\"accountsChanged\", handler)\n\n return {\n unsubscribe: () => {\n provider.removeListener(\"accountsChanged\", handler)\n },\n }\n }\n}\n"],"names":["XverseCompatibleWalletAdapterImpl_legacy","info","resp","stored","addresses","sdk","networkType","WalletAdapterBitcoinNetwork","resolve","reject","UserRejectError","WalletAdapterNotConnectedError","address","message","SignMessageAlgorithm","fromAddress","receiverAddress","satoshiAmount","senderAddress","a","WalletAdapterAddressPurpose","XverseCompatibleProviderError","XverseRpcErrorCode","psbtHex","signIndices","psbtBase64","base64","hex","signedPsbt","signIndex","tx","btc.Transaction","callback","localStorageKey","MAGICEDEN_PROVIDER_ID","MagicEdenWalletAdapterImpl","network","provider","isMainnet","WalletAdapterAddressType","addressToScriptPubKey","getBitcoinNetwork","handler","event","error"],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"OkxWalletAdapter.impl-BepoUL1B.mjs","sources":["../src/adapters/OkxWalletAdapter.impl.ts"],"sourcesContent":["import { UserRejectError, BitcoinWalletAdapterError } from \"../utils/error\"\nimport {\n SignMessageResult,\n WalletAdapter,\n WalletAdapter_onAddressesChanged_callback,\n} from \"../WalletAdapters.types\"\nimport {\n UniSatEvents,\n UnisatCompatibleProviderAPI,\n UnisatCompatibleWalletAdapterImpl,\n} from \"../utils/UnisatCompatibleWalletAdapterImpl\"\n\nenum RpcErrorCode {\n PARSE_ERROR = -32700,\n INVALID_REQUEST = -32600,\n METHOD_NOT_FOUND = -32601,\n INVALID_PARAMS = -32602,\n INTERNAL_ERROR = -32603,\n SERVER_ERROR = -32000,\n USER_REJECTION = 4001,\n METHOD_NOT_SUPPORTED = 4002,\n}\n\ninterface RpcError<TErrorData = unknown> {\n code: number | RpcErrorCode\n message: string\n data?: TErrorData\n}\n\ninterface OkxBitcoinProvider\n extends UnisatCompatibleProviderAPI, Record<string, any> {\n connect(): Promise<void>\n on<K extends keyof UniSatEvents>(\n event: K,\n handler: (...args: UniSatEvents[K]) => void,\n ): void\n on(event: \"accountChanged\" | \"networkChanged\", handler: () => void): void\n removeListener<K extends keyof UniSatEvents>(\n event: K,\n handler: (...args: UniSatEvents[K]) => void,\n ): void\n removeListener(\n event: \"accountChanged\" | \"networkChanged\",\n handler: () => void,\n ): void\n}\n\nexport class OkxWalletAdapterImpl\n extends UnisatCompatibleWalletAdapterImpl\n implements WalletAdapter\n{\n private okxwallet: OkxBitcoinProvider\n constructor(provider: OkxBitcoinProvider) {\n /**\n * OKX Provider API:\n *\n * https://web3.okx.com/zh-hans/build/dev-docs/sdks/chains/bitcoin/provider\n */\n super(provider, \"OKX\")\n this.okxwallet = provider\n }\n\n async connect(): Promise<void> {\n // if not authorized, okx wallet will pop up a window to ask user to authorize\n // if authorized, okx wallet will do nothing\n await this.okxwallet.connect()\n }\n\n async signMessage(\n address: string,\n message: string,\n ): Promise<SignMessageResult> {\n return handleRpcError(super.signMessage(address, message))\n }\n\n async sendBitcoin(\n fromAddress: string,\n receiverAddress: string,\n satoshiAmount: bigint,\n options?: { feeRate?: number },\n ): Promise<{\n txid: string\n }> {\n return handleRpcError(\n super.sendBitcoin(fromAddress, receiverAddress, satoshiAmount, options),\n )\n }\n\n async sendInscription(\n fromAddress: string,\n receiverAddress: string,\n inscriptionId: string,\n options?: { feeRate?: number },\n ): Promise<{\n txid: string\n }> {\n return handleRpcError(\n super.sendInscription(\n fromAddress,\n receiverAddress,\n inscriptionId,\n options,\n ),\n )\n }\n\n async signAndFinalizePsbt(\n psbtHex: string,\n signIndices: [address: string, signIndex: number][],\n ): Promise<{\n signedPsbtHex: string\n }> {\n return handleRpcError(super.signAndFinalizePsbt(psbtHex, signIndices))\n }\n\n onAddressesChanged(callback: WalletAdapter_onAddressesChanged_callback): {\n unsubscribe: () => void\n } {\n // OKX uses 'accountChanged' (no 's') and 'networkChanged' events\n // https://web3.okx.com/build/dev-docs/sdks/chains/bitcoin/provider\n if (this.okxwallet?.on && this.okxwallet?.removeListener) {\n const handler = async (): Promise<void> => {\n try {\n const addresses = await this.getAddresses()\n callback({ addresses })\n } catch (error) {\n console.warn(\"[OKX] Failed to get addresses on change:\", error)\n }\n }\n\n // Listen to account and network changes (OKX uses 'accountChanged' not 'accountsChanged')\n this.okxwallet.on(\"accountChanged\", handler)\n this.okxwallet.on(\"networkChanged\", handler)\n\n return {\n unsubscribe: () => {\n this.okxwallet.removeListener(\"accountChanged\", handler)\n this.okxwallet.removeListener(\"networkChanged\", handler)\n },\n }\n } else {\n // Fallback to parent implementation (polling)\n return super.onAddressesChanged(callback)\n }\n }\n}\n\nexport class OkxWalletAdapterError extends BitcoinWalletAdapterError {\n constructor(rpcError: RpcError) {\n super(\"OKX wallet error: \" + rpcError.message, { cause: rpcError })\n }\n}\n\nconst handleRpcError = async <T>(promise: Promise<T>): Promise<T> => {\n try {\n return await promise\n } catch (e: any) {\n if (e instanceof UserRejectError) {\n throw e\n }\n\n if (e.code === RpcErrorCode.USER_REJECTION) {\n throw new UserRejectError()\n }\n\n throw new OkxWalletAdapterError(e)\n }\n}\n"],"names":["OkxWalletAdapterImpl","UnisatCompatibleWalletAdapterImpl","provider","address","message","handleRpcError","fromAddress","receiverAddress","satoshiAmount","options","inscriptionId","psbtHex","signIndices","callback","handler","addresses","error","OkxWalletAdapterError","BitcoinWalletAdapterError","rpcError","promise","UserRejectError"],"mappings":";;AA+CO,MAAMA,UACHC,EAEV;AAAA,EACU;AAAA,EACR,YAAYC,GAA8B;AAMxC,UAAMA,GAAU,KAAK,GACrB,KAAK,YAAYA;AAAA,EACnB;AAAA,EAEA,MAAM,UAAyB;AAG7B,UAAM,KAAK,UAAU,QAAA;AAAA,EACvB;AAAA,EAEA,MAAM,YACJC,GACAC,GAC4B;AAC5B,WAAOC,EAAe,MAAM,YAAYF,GAASC,CAAO,CAAC;AAAA,EAC3D;AAAA,EAEA,MAAM,YACJE,GACAC,GACAC,GACAC,GAGC;AACD,WAAOJ;AAAA,MACL,MAAM,YAAYC,GAAaC,GAAiBC,GAAeC,CAAO;AAAA,IAAA;AAAA,EAE1E;AAAA,EAEA,MAAM,gBACJH,GACAC,GACAG,GACAD,GAGC;AACD,WAAOJ;AAAA,MACL,MAAM;AAAA,QACJC;AAAA,QACAC;AAAA,QACAG;AAAA,QACAD;AAAA,MAAA;AAAA,IACF;AAAA,EAEJ;AAAA,EAEA,MAAM,oBACJE,GACAC,GAGC;AACD,WAAOP,EAAe,MAAM,oBAAoBM,GAASC,CAAW,CAAC;AAAA,EACvE;AAAA,EAEA,mBAAmBC,GAEjB;AAGA,QAAI,KAAK,WAAW,MAAM,KAAK,WAAW,gBAAgB;AACxD,YAAMC,IAAU,YAA2B;AACzC,YAAI;AACF,gBAAMC,IAAY,MAAM,KAAK,aAAA;AAC7B,UAAAF,EAAS,EAAE,WAAAE,GAAW;AAAA,QACxB,SAASC,GAAO;AACd,kBAAQ,KAAK,4CAA4CA,CAAK;AAAA,QAChE;AAAA,MACF;AAGA,kBAAK,UAAU,GAAG,kBAAkBF,CAAO,GAC3C,KAAK,UAAU,GAAG,kBAAkBA,CAAO,GAEpC;AAAA,QACL,aAAa,MAAM;AACjB,eAAK,UAAU,eAAe,kBAAkBA,CAAO,GACvD,KAAK,UAAU,eAAe,kBAAkBA,CAAO;AAAA,QACzD;AAAA,MAAA;AAAA,IAEJ;AAEE,aAAO,MAAM,mBAAmBD,CAAQ;AAAA,EAE5C;AACF;AAEO,MAAMI,UAA8BC,EAA0B;AAAA,EACnE,YAAYC,GAAoB;AAC9B,UAAM,uBAAuBA,EAAS,SAAS,EAAE,OAAOA,GAAU;AAAA,EACpE;AACF;AAEA,MAAMd,IAAiB,OAAUe,MAAoC;AACnE,MAAI;AACF,WAAO,MAAMA;AAAA,EACf,SAAS,GAAQ;AACf,UAAI,aAAaC,IACT,IAGJ,EAAE,SAAS,OACP,IAAIA,EAAA,IAGN,IAAIJ,EAAsB,CAAC;AAAA,EACnC;AACF;"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("./WalletAdapters.types-De_x1lzr.js"),i=require("./UnisatCompatibleWalletAdapterImpl-Cq2Oqk1b.js");class c extends i.UnisatCompatibleWalletAdapterImpl{okxwallet;constructor(e){super(e,"OKX"),this.okxwallet=e}async connect(){await this.okxwallet.connect()}async signMessage(e,t){return r(super.signMessage(e,t))}async sendBitcoin(e,t,s,a){return r(super.sendBitcoin(e,t,s,a))}async sendInscription(e,t,s,a){return r(super.sendInscription(e,t,s,a))}async signAndFinalizePsbt(e,t){return r(super.signAndFinalizePsbt(e,t))}onAddressesChanged(e){if(this.okxwallet?.on&&this.okxwallet?.removeListener){const t=async()=>{try{const s=await this.getAddresses();e({addresses:s})}catch(s){console.warn("[OKX] Failed to get addresses on change:",s)}};return this.okxwallet.on("accountChanged",t),this.okxwallet.on("networkChanged",t),{unsubscribe:()=>{this.okxwallet.removeListener("accountChanged",t),this.okxwallet.removeListener("networkChanged",t)}}}else return super.onAddressesChanged(e)}}class l extends o.BitcoinWalletAdapterError{constructor(e){super("OKX wallet error: "+e.message,{cause:e})}}const r=async n=>{try{return await n}catch(e){throw e instanceof o.UserRejectError?e:e.code===4001?new o.UserRejectError:new l(e)}};exports.OkxWalletAdapterError=l;exports.OkxWalletAdapterImpl=c;
|
|
2
|
-
//# sourceMappingURL=OkxWalletAdapter.impl-C8kesjGu.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"OkxWalletAdapter.impl-C8kesjGu.js","sources":["../src/adapters/OkxWalletAdapter.impl.ts"],"sourcesContent":["import { UserRejectError, BitcoinWalletAdapterError } from \"../utils/error\"\nimport {\n SignMessageResult,\n WalletAdapter,\n WalletAdapter_onAddressesChanged_callback,\n} from \"../WalletAdapters.types\"\nimport {\n UniSatEvents,\n UnisatCompatibleProviderAPI,\n UnisatCompatibleWalletAdapterImpl,\n} from \"../utils/UnisatCompatibleWalletAdapterImpl\"\n\nenum RpcErrorCode {\n PARSE_ERROR = -32700,\n INVALID_REQUEST = -32600,\n METHOD_NOT_FOUND = -32601,\n INVALID_PARAMS = -32602,\n INTERNAL_ERROR = -32603,\n SERVER_ERROR = -32000,\n USER_REJECTION = 4001,\n METHOD_NOT_SUPPORTED = 4002,\n}\n\ninterface RpcError<TErrorData = unknown> {\n code: number | RpcErrorCode\n message: string\n data?: TErrorData\n}\n\ninterface OkxBitcoinProvider\n extends UnisatCompatibleProviderAPI, Record<string, any> {\n connect(): Promise<void>\n on<K extends keyof UniSatEvents>(\n event: K,\n handler: (...args: UniSatEvents[K]) => void,\n ): void\n on(event: \"accountChanged\" | \"networkChanged\", handler: () => void): void\n removeListener<K extends keyof UniSatEvents>(\n event: K,\n handler: (...args: UniSatEvents[K]) => void,\n ): void\n removeListener(\n event: \"accountChanged\" | \"networkChanged\",\n handler: () => void,\n ): void\n}\n\nexport class OkxWalletAdapterImpl\n extends UnisatCompatibleWalletAdapterImpl\n implements WalletAdapter\n{\n private okxwallet: OkxBitcoinProvider\n constructor(provider: OkxBitcoinProvider) {\n /**\n * OKX Provider API:\n *\n * https://web3.okx.com/zh-hans/build/dev-docs/sdks/chains/bitcoin/provider\n */\n super(provider, \"OKX\")\n this.okxwallet = provider\n }\n\n async connect(): Promise<void> {\n // if not authorized, okx wallet will pop up a window to ask user to authorize\n // if authorized, okx wallet will do nothing\n await this.okxwallet.connect()\n }\n\n async signMessage(\n address: string,\n message: string,\n ): Promise<SignMessageResult> {\n return handleRpcError(super.signMessage(address, message))\n }\n\n async sendBitcoin(\n fromAddress: string,\n receiverAddress: string,\n satoshiAmount: bigint,\n options?: { feeRate?: number },\n ): Promise<{\n txid: string\n }> {\n return handleRpcError(\n super.sendBitcoin(fromAddress, receiverAddress, satoshiAmount, options),\n )\n }\n\n async sendInscription(\n fromAddress: string,\n receiverAddress: string,\n inscriptionId: string,\n options?: { feeRate?: number },\n ): Promise<{\n txid: string\n }> {\n return handleRpcError(\n super.sendInscription(\n fromAddress,\n receiverAddress,\n inscriptionId,\n options,\n ),\n )\n }\n\n async signAndFinalizePsbt(\n psbtHex: string,\n signIndices: [address: string, signIndex: number][],\n ): Promise<{\n signedPsbtHex: string\n }> {\n return handleRpcError(super.signAndFinalizePsbt(psbtHex, signIndices))\n }\n\n onAddressesChanged(callback: WalletAdapter_onAddressesChanged_callback): {\n unsubscribe: () => void\n } {\n // OKX uses 'accountChanged' (no 's') and 'networkChanged' events\n // https://web3.okx.com/build/dev-docs/sdks/chains/bitcoin/provider\n if (this.okxwallet?.on && this.okxwallet?.removeListener) {\n const handler = async (): Promise<void> => {\n try {\n const addresses = await this.getAddresses()\n callback({ addresses })\n } catch (error) {\n console.warn(\"[OKX] Failed to get addresses on change:\", error)\n }\n }\n\n // Listen to account and network changes (OKX uses 'accountChanged' not 'accountsChanged')\n this.okxwallet.on(\"accountChanged\", handler)\n this.okxwallet.on(\"networkChanged\", handler)\n\n return {\n unsubscribe: () => {\n this.okxwallet.removeListener(\"accountChanged\", handler)\n this.okxwallet.removeListener(\"networkChanged\", handler)\n },\n }\n } else {\n // Fallback to parent implementation (polling)\n return super.onAddressesChanged(callback)\n }\n }\n}\n\nexport class OkxWalletAdapterError extends BitcoinWalletAdapterError {\n constructor(rpcError: RpcError) {\n super(\"OKX wallet error: \" + rpcError.message, { cause: rpcError })\n }\n}\n\nconst handleRpcError = async <T>(promise: Promise<T>): Promise<T> => {\n try {\n return await promise\n } catch (e: any) {\n if (e instanceof UserRejectError) {\n throw e\n }\n\n if (e.code === RpcErrorCode.USER_REJECTION) {\n throw new UserRejectError()\n }\n\n throw new OkxWalletAdapterError(e)\n }\n}\n"],"names":["OkxWalletAdapterImpl","UnisatCompatibleWalletAdapterImpl","provider","address","message","handleRpcError","fromAddress","receiverAddress","satoshiAmount","options","inscriptionId","psbtHex","signIndices","callback","handler","addresses","error","OkxWalletAdapterError","BitcoinWalletAdapterError","rpcError","promise","UserRejectError"],"mappings":"mMA+CO,MAAMA,UACHC,EAAAA,iCAEV,CACU,UACR,YAAYC,EAA8B,CAMxC,MAAMA,EAAU,KAAK,EACrB,KAAK,UAAYA,CACnB,CAEA,MAAM,SAAyB,CAG7B,MAAM,KAAK,UAAU,QAAA,CACvB,CAEA,MAAM,YACJC,EACAC,EAC4B,CAC5B,OAAOC,EAAe,MAAM,YAAYF,EAASC,CAAO,CAAC,CAC3D,CAEA,MAAM,YACJE,EACAC,EACAC,EACAC,EAGC,CACD,OAAOJ,EACL,MAAM,YAAYC,EAAaC,EAAiBC,EAAeC,CAAO,CAAA,CAE1E,CAEA,MAAM,gBACJH,EACAC,EACAG,EACAD,EAGC,CACD,OAAOJ,EACL,MAAM,gBACJC,EACAC,EACAG,EACAD,CAAA,CACF,CAEJ,CAEA,MAAM,oBACJE,EACAC,EAGC,CACD,OAAOP,EAAe,MAAM,oBAAoBM,EAASC,CAAW,CAAC,CACvE,CAEA,mBAAmBC,EAEjB,CAGA,GAAI,KAAK,WAAW,IAAM,KAAK,WAAW,eAAgB,CACxD,MAAMC,EAAU,SAA2B,CACzC,GAAI,CACF,MAAMC,EAAY,MAAM,KAAK,aAAA,EAC7BF,EAAS,CAAE,UAAAE,EAAW,CACxB,OAASC,EAAO,CACd,QAAQ,KAAK,2CAA4CA,CAAK,CAChE,CACF,EAGA,YAAK,UAAU,GAAG,iBAAkBF,CAAO,EAC3C,KAAK,UAAU,GAAG,iBAAkBA,CAAO,EAEpC,CACL,YAAa,IAAM,CACjB,KAAK,UAAU,eAAe,iBAAkBA,CAAO,EACvD,KAAK,UAAU,eAAe,iBAAkBA,CAAO,CACzD,CAAA,CAEJ,KAEE,QAAO,MAAM,mBAAmBD,CAAQ,CAE5C,CACF,CAEO,MAAMI,UAA8BC,EAAAA,yBAA0B,CACnE,YAAYC,EAAoB,CAC9B,MAAM,qBAAuBA,EAAS,QAAS,CAAE,MAAOA,EAAU,CACpE,CACF,CAEA,MAAMd,EAAiB,MAAUe,GAAoC,CACnE,GAAI,CACF,OAAO,MAAMA,CACf,OAAS,EAAQ,CACf,MAAI,aAAaC,EAAAA,gBACT,EAGJ,EAAE,OAAS,KACP,IAAIA,EAAAA,gBAGN,IAAIJ,EAAsB,CAAC,CACnC,CACF"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"UnisatCompatibleWalletAdapterImpl-Cq2Oqk1b.js","sources":["../src/utils/UnisatCompatibleWalletAdapterImpl.ts"],"sourcesContent":["import { hex } from \"@scure/base\"\nimport * as btc from \"@scure/btc-signer\"\nimport { hasAny } from \"./misc\"\nimport {\n addressToScriptPubKey,\n getAddressType,\n getRedeemScriptOf_P2SH_P2WPKH_publicKey,\n getTapInternalKeyOf_P2TR_publicKey,\n} from \"./bitcoinAddressHelpers\"\nimport { getBitcoinNetwork } from \"./bitcoinNetworkHelpers\"\nimport { UserRejectError, BitcoinWalletAdapterError } from \"../utils/error\"\nimport {\n SignMessageAlgorithm,\n SignMessageResult,\n WalletAdapter,\n WalletAdapter_onAddressesChanged_callback,\n WalletAdapterAddress,\n WalletAdapterAddressPurpose,\n WalletAdapterAddressType,\n WalletAdapterBitcoinNetwork,\n WalletAdapterNotConnectedError,\n} from \"../WalletAdapters.types\"\n\n/**\n * https://docs.unisat.io/dev-center/open-api-documentation/unisat-wallet#events\n */\nexport interface UniSatEvents {\n accountsChanged: [accounts: Array<string>]\n networkChanged: [network: string]\n}\n\nexport interface UnisatCompatibleProviderAPI {\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#getaccounts\n */\n getAccounts(): Promise<string[]>\n\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#requestaccounts\n */\n requestAccounts(): Promise<string[]>\n\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#getpublickey\n */\n getPublicKey(): Promise<string>\n\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#getnetwork\n */\n getNetwork(): Promise<\"livenet\" | \"testnet\">\n\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#signmessage\n */\n signMessage(\n message: string,\n algorithm: \"ecdsa\" | \"bip322-simple\",\n ): Promise<string>\n\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#sendbitcoin\n */\n sendBitcoin(\n receiverAddress: string,\n satoshiAmount: number,\n options?: { feeRate?: number },\n ): Promise<string>\n\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#sendInscription\n */\n sendInscription(\n receiverAddress: string,\n inscriptionId: string,\n options?: { feeRate?: number },\n ): Promise<string>\n\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#signpsbt\n */\n signPsbt(\n psbtHex: string,\n options?: {\n autoFinalized?: boolean\n toSignInputs?: {\n index: number\n address?: string\n publicKey?: string\n sighashTypes?: number[]\n disableTweakSigner?: boolean\n }[]\n },\n ): Promise<string>\n\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#events\n */\n on<K extends keyof UniSatEvents>(\n event: K,\n handler: (...args: UniSatEvents[K]) => void,\n ): void\n removeListener(event: keyof UniSatEvents, handler: () => void): void\n}\n\nexport type UnisatCompatibleWalletAdapterAddresses = (WalletAdapterAddress & {\n publicKey: string\n})[]\n\nexport class UnisatCompatibleWalletAdapterImpl implements WalletAdapter {\n constructor(\n private unisat: UnisatCompatibleProviderAPI,\n private walletDisplayName: string,\n ) {}\n\n async connect(): Promise<void> {\n if ((await this.unisat.getAccounts()).length === 0) {\n await this.unisat.requestAccounts()\n }\n }\n\n disconnect(): Promise<void> {\n // do nothing\n return Promise.resolve()\n }\n\n async getAddresses(): Promise<UnisatCompatibleWalletAdapterAddresses> {\n const addresses: string[] = await this.unisat.getAccounts()\n\n if (addresses.length === 0) {\n throw new WalletAdapterNotConnectedError(this.walletDisplayName)\n }\n\n const publicKey: string = await this.unisat.getPublicKey()\n\n const _network: \"livenet\" | \"testnet\" = await this.unisat.getNetwork()\n const network = _network === \"livenet\" ? \"mainnet\" : \"testnet\"\n\n if (!hasAny(addresses)) {\n throw new BitcoinWalletAdapterError(\"Request wallet addresses failed\")\n }\n\n const address = addresses[0]\n const addrType = getAddressType(getBitcoinNetwork(network), address)\n // prettier-ignore\n const addressType =\n addrType === \"p2tr\" ? WalletAdapterAddressType.P2TR :\n addrType === \"p2sh\" ? WalletAdapterAddressType.P2SH_P2WPKH :\n addrType === \"p2wpkh\" ? WalletAdapterAddressType.P2WPKH :\n undefined\n\n if (addressType == null) {\n throw new BitcoinWalletAdapterError(\"Please select a SegWit address\")\n }\n\n const scriptPubKey = hex.encode(\n addressToScriptPubKey(getBitcoinNetwork(network), address),\n )\n\n const tapInternalKey =\n addressType !== WalletAdapterAddressType.P2TR\n ? undefined\n : hex.encode(\n getTapInternalKeyOf_P2TR_publicKey(\n getBitcoinNetwork(network),\n hex.decode(publicKey),\n ),\n )\n\n const redeemScript =\n addressType !== WalletAdapterAddressType.P2SH_P2WPKH\n ? undefined\n : hex.encode(\n getRedeemScriptOf_P2SH_P2WPKH_publicKey(\n getBitcoinNetwork(network),\n hex.decode(publicKey),\n ),\n )\n\n return [\n {\n addressType,\n address,\n scriptPubKey,\n redeemScript,\n tapInternalKey,\n publicKey,\n network:\n network === \"mainnet\"\n ? WalletAdapterBitcoinNetwork.MAINNET\n : WalletAdapterBitcoinNetwork.TESTNET,\n purposes: [\n WalletAdapterAddressPurpose.Bitcoin,\n WalletAdapterAddressPurpose.Ordinals,\n WalletAdapterAddressPurpose.BRC20,\n WalletAdapterAddressPurpose.Runes,\n ],\n },\n ]\n }\n\n async signMessage(\n address: string,\n message: string,\n ): Promise<SignMessageResult> {\n const result = await handleRpcError(\n this.unisat.signMessage(message, \"bip322-simple\"),\n )\n\n return {\n result,\n address,\n algorithm: SignMessageAlgorithm.BIP322,\n }\n }\n\n sendBitcoinFeeRateCapability: WalletAdapter[\"sendBitcoinFeeRateCapability\"] =\n \"available\" as const\n async sendBitcoin(\n fromAddress: string,\n receiverAddress: string,\n satoshiAmount: bigint,\n options?: { feeRate?: number },\n ): Promise<{ txid: string }> {\n const txid = await handleRpcError(\n this.unisat.sendBitcoin(receiverAddress, Number(satoshiAmount), {\n feeRate: options?.feeRate,\n }),\n )\n return { txid }\n }\n\n sendInscriptionFeeRateCapability: WalletAdapter[\"sendInscriptionFeeRateCapability\"] =\n \"available\" as const\n async sendInscription(\n fromAddress: string,\n receiverAddress: string,\n inscriptionId: string,\n options?: { feeRate?: number },\n ): Promise<{ txid: string }> {\n const txid = await handleRpcError(\n this.unisat.sendInscription(receiverAddress, inscriptionId, {\n feeRate: options?.feeRate,\n }),\n )\n return { txid }\n }\n\n async signAndFinalizePsbt(\n psbtHex: string,\n signIndices: [address: string, signIndex: number][],\n ): Promise<{\n signedPsbtHex: string\n }> {\n const addr = await this.getAddresses()\n\n const signedPsbtHex = await handleRpcError(\n this.unisat.signPsbt(psbtHex, {\n autoFinalized: false,\n toSignInputs: signIndices.map(([address, signIndex]) => ({\n index: signIndex,\n address,\n })),\n }),\n )\n\n /**\n * Some version of unisat's signPsbt API does not working well with the autoFinalized option,\n * so we finalize the PSBT manually.\n */\n const tx = btc.Transaction.fromPSBT(hex.decode(signedPsbtHex), {\n allowUnknownInputs: true,\n allowUnknownOutputs: true,\n disableScriptCheck: true,\n allowLegacyWitnessUtxo: true,\n })\n tx.finalize()\n\n return { signedPsbtHex: hex.encode(tx.toPSBT()) }\n }\n\n onAddressesChanged(callback: WalletAdapter_onAddressesChanged_callback): {\n unsubscribe: () => void\n } {\n const handler = async (): Promise<void> => {\n try {\n const addresses = await this.getAddresses()\n callback({ addresses })\n } catch (error) {\n // Ignore errors from getAddresses (e.g., wallet disconnected)\n console.warn(\n `[${this.walletDisplayName}] Failed to get addresses on change:`,\n error,\n )\n }\n }\n\n // Listen to both account and network changes\n this.unisat.on(\"accountsChanged\", handler)\n this.unisat.on(\"networkChanged\", handler)\n\n return {\n unsubscribe: () => {\n this.unisat.removeListener(\"accountsChanged\", handler)\n this.unisat.removeListener(\"networkChanged\", handler)\n },\n }\n }\n}\n\ninterface UnisatCompatibleProviderAPIThrownError {\n code: number\n message: string\n}\nfunction isUnisatCompatibleProviderAPIThrownError(\n err: any,\n): err is UnisatCompatibleProviderAPIThrownError {\n return err != null && \"code\" in err && \"message\" in err\n}\n\nexport class UnisatCompatibleProviderError extends Error {\n readonly code: number\n constructor(err: UnisatCompatibleProviderAPIThrownError) {\n super(err.message)\n this.code = err.code\n this.cause = err\n }\n}\n\nconst handleRpcError = async <T>(promise: Promise<T>): Promise<T> => {\n try {\n return await promise\n } catch (e: any) {\n if (isUnisatCompatibleProviderAPIThrownError(e)) {\n if (e.code === 4001) {\n throw new UserRejectError()\n }\n throw new UnisatCompatibleProviderError(e)\n }\n throw e\n }\n}\n"],"names":["UnisatCompatibleWalletAdapterImpl","unisat","walletDisplayName","addresses","WalletAdapterNotConnectedError","publicKey","network","hasAny","BitcoinWalletAdapterError","address","addrType","getAddressType","getBitcoinNetwork","addressType","WalletAdapterAddressType","scriptPubKey","hex","addressToScriptPubKey","tapInternalKey","getTapInternalKeyOf_P2TR_publicKey","redeemScript","getRedeemScriptOf_P2SH_P2WPKH_publicKey","WalletAdapterBitcoinNetwork","WalletAdapterAddressPurpose","message","handleRpcError","SignMessageAlgorithm","fromAddress","receiverAddress","satoshiAmount","options","inscriptionId","psbtHex","signIndices","signedPsbtHex","signIndex","tx","btc.Transaction","callback","handler","error","isUnisatCompatibleProviderAPIThrownError","err","UnisatCompatibleProviderError","promise","UserRejectError"],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"UnisatCompatibleWalletAdapterImpl-M38FqkZI.mjs","sources":["../src/utils/UnisatCompatibleWalletAdapterImpl.ts"],"sourcesContent":["import { hex } from \"@scure/base\"\nimport * as btc from \"@scure/btc-signer\"\nimport { hasAny } from \"./misc\"\nimport {\n addressToScriptPubKey,\n getAddressType,\n getRedeemScriptOf_P2SH_P2WPKH_publicKey,\n getTapInternalKeyOf_P2TR_publicKey,\n} from \"./bitcoinAddressHelpers\"\nimport { getBitcoinNetwork } from \"./bitcoinNetworkHelpers\"\nimport { UserRejectError, BitcoinWalletAdapterError } from \"../utils/error\"\nimport {\n SignMessageAlgorithm,\n SignMessageResult,\n WalletAdapter,\n WalletAdapter_onAddressesChanged_callback,\n WalletAdapterAddress,\n WalletAdapterAddressPurpose,\n WalletAdapterAddressType,\n WalletAdapterBitcoinNetwork,\n WalletAdapterNotConnectedError,\n} from \"../WalletAdapters.types\"\n\n/**\n * https://docs.unisat.io/dev-center/open-api-documentation/unisat-wallet#events\n */\nexport interface UniSatEvents {\n accountsChanged: [accounts: Array<string>]\n networkChanged: [network: string]\n}\n\nexport interface UnisatCompatibleProviderAPI {\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#getaccounts\n */\n getAccounts(): Promise<string[]>\n\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#requestaccounts\n */\n requestAccounts(): Promise<string[]>\n\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#getpublickey\n */\n getPublicKey(): Promise<string>\n\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#getnetwork\n */\n getNetwork(): Promise<\"livenet\" | \"testnet\">\n\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#signmessage\n */\n signMessage(\n message: string,\n algorithm: \"ecdsa\" | \"bip322-simple\",\n ): Promise<string>\n\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#sendbitcoin\n */\n sendBitcoin(\n receiverAddress: string,\n satoshiAmount: number,\n options?: { feeRate?: number },\n ): Promise<string>\n\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#sendInscription\n */\n sendInscription(\n receiverAddress: string,\n inscriptionId: string,\n options?: { feeRate?: number },\n ): Promise<string>\n\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#signpsbt\n */\n signPsbt(\n psbtHex: string,\n options?: {\n autoFinalized?: boolean\n toSignInputs?: {\n index: number\n address?: string\n publicKey?: string\n sighashTypes?: number[]\n disableTweakSigner?: boolean\n }[]\n },\n ): Promise<string>\n\n /**\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet#events\n */\n on<K extends keyof UniSatEvents>(\n event: K,\n handler: (...args: UniSatEvents[K]) => void,\n ): void\n removeListener(event: keyof UniSatEvents, handler: () => void): void\n}\n\nexport type UnisatCompatibleWalletAdapterAddresses = (WalletAdapterAddress & {\n publicKey: string\n})[]\n\nexport class UnisatCompatibleWalletAdapterImpl implements WalletAdapter {\n constructor(\n private unisat: UnisatCompatibleProviderAPI,\n private walletDisplayName: string,\n ) {}\n\n async connect(): Promise<void> {\n if ((await this.unisat.getAccounts()).length === 0) {\n await this.unisat.requestAccounts()\n }\n }\n\n disconnect(): Promise<void> {\n // do nothing\n return Promise.resolve()\n }\n\n async getAddresses(): Promise<UnisatCompatibleWalletAdapterAddresses> {\n const addresses: string[] = await this.unisat.getAccounts()\n\n if (addresses.length === 0) {\n throw new WalletAdapterNotConnectedError(this.walletDisplayName)\n }\n\n const publicKey: string = await this.unisat.getPublicKey()\n\n const _network: \"livenet\" | \"testnet\" = await this.unisat.getNetwork()\n const network = _network === \"livenet\" ? \"mainnet\" : \"testnet\"\n\n if (!hasAny(addresses)) {\n throw new BitcoinWalletAdapterError(\"Request wallet addresses failed\")\n }\n\n const address = addresses[0]\n const addrType = getAddressType(getBitcoinNetwork(network), address)\n // prettier-ignore\n const addressType =\n addrType === \"p2tr\" ? WalletAdapterAddressType.P2TR :\n addrType === \"p2sh\" ? WalletAdapterAddressType.P2SH_P2WPKH :\n addrType === \"p2wpkh\" ? WalletAdapterAddressType.P2WPKH :\n undefined\n\n if (addressType == null) {\n throw new BitcoinWalletAdapterError(\"Please select a SegWit address\")\n }\n\n const scriptPubKey = hex.encode(\n addressToScriptPubKey(getBitcoinNetwork(network), address),\n )\n\n const tapInternalKey =\n addressType !== WalletAdapterAddressType.P2TR\n ? undefined\n : hex.encode(\n getTapInternalKeyOf_P2TR_publicKey(\n getBitcoinNetwork(network),\n hex.decode(publicKey),\n ),\n )\n\n const redeemScript =\n addressType !== WalletAdapterAddressType.P2SH_P2WPKH\n ? undefined\n : hex.encode(\n getRedeemScriptOf_P2SH_P2WPKH_publicKey(\n getBitcoinNetwork(network),\n hex.decode(publicKey),\n ),\n )\n\n return [\n {\n addressType,\n address,\n scriptPubKey,\n redeemScript,\n tapInternalKey,\n publicKey,\n network:\n network === \"mainnet\"\n ? WalletAdapterBitcoinNetwork.MAINNET\n : WalletAdapterBitcoinNetwork.TESTNET,\n purposes: [\n WalletAdapterAddressPurpose.Bitcoin,\n WalletAdapterAddressPurpose.Ordinals,\n WalletAdapterAddressPurpose.BRC20,\n WalletAdapterAddressPurpose.Runes,\n ],\n },\n ]\n }\n\n async signMessage(\n address: string,\n message: string,\n ): Promise<SignMessageResult> {\n const result = await handleRpcError(\n this.unisat.signMessage(message, \"bip322-simple\"),\n )\n\n return {\n result,\n address,\n algorithm: SignMessageAlgorithm.BIP322,\n }\n }\n\n sendBitcoinFeeRateCapability: WalletAdapter[\"sendBitcoinFeeRateCapability\"] =\n \"available\" as const\n async sendBitcoin(\n fromAddress: string,\n receiverAddress: string,\n satoshiAmount: bigint,\n options?: { feeRate?: number },\n ): Promise<{ txid: string }> {\n const txid = await handleRpcError(\n this.unisat.sendBitcoin(receiverAddress, Number(satoshiAmount), {\n feeRate: options?.feeRate,\n }),\n )\n return { txid }\n }\n\n sendInscriptionFeeRateCapability: WalletAdapter[\"sendInscriptionFeeRateCapability\"] =\n \"available\" as const\n async sendInscription(\n fromAddress: string,\n receiverAddress: string,\n inscriptionId: string,\n options?: { feeRate?: number },\n ): Promise<{ txid: string }> {\n const txid = await handleRpcError(\n this.unisat.sendInscription(receiverAddress, inscriptionId, {\n feeRate: options?.feeRate,\n }),\n )\n return { txid }\n }\n\n async signAndFinalizePsbt(\n psbtHex: string,\n signIndices: [address: string, signIndex: number][],\n ): Promise<{\n signedPsbtHex: string\n }> {\n const addr = await this.getAddresses()\n\n const signedPsbtHex = await handleRpcError(\n this.unisat.signPsbt(psbtHex, {\n autoFinalized: false,\n toSignInputs: signIndices.map(([address, signIndex]) => ({\n index: signIndex,\n address,\n })),\n }),\n )\n\n /**\n * Some version of unisat's signPsbt API does not working well with the autoFinalized option,\n * so we finalize the PSBT manually.\n */\n const tx = btc.Transaction.fromPSBT(hex.decode(signedPsbtHex), {\n allowUnknownInputs: true,\n allowUnknownOutputs: true,\n disableScriptCheck: true,\n allowLegacyWitnessUtxo: true,\n })\n tx.finalize()\n\n return { signedPsbtHex: hex.encode(tx.toPSBT()) }\n }\n\n onAddressesChanged(callback: WalletAdapter_onAddressesChanged_callback): {\n unsubscribe: () => void\n } {\n const handler = async (): Promise<void> => {\n try {\n const addresses = await this.getAddresses()\n callback({ addresses })\n } catch (error) {\n // Ignore errors from getAddresses (e.g., wallet disconnected)\n console.warn(\n `[${this.walletDisplayName}] Failed to get addresses on change:`,\n error,\n )\n }\n }\n\n // Listen to both account and network changes\n this.unisat.on(\"accountsChanged\", handler)\n this.unisat.on(\"networkChanged\", handler)\n\n return {\n unsubscribe: () => {\n this.unisat.removeListener(\"accountsChanged\", handler)\n this.unisat.removeListener(\"networkChanged\", handler)\n },\n }\n }\n}\n\ninterface UnisatCompatibleProviderAPIThrownError {\n code: number\n message: string\n}\nfunction isUnisatCompatibleProviderAPIThrownError(\n err: any,\n): err is UnisatCompatibleProviderAPIThrownError {\n return err != null && \"code\" in err && \"message\" in err\n}\n\nexport class UnisatCompatibleProviderError extends Error {\n readonly code: number\n constructor(err: UnisatCompatibleProviderAPIThrownError) {\n super(err.message)\n this.code = err.code\n this.cause = err\n }\n}\n\nconst handleRpcError = async <T>(promise: Promise<T>): Promise<T> => {\n try {\n return await promise\n } catch (e: any) {\n if (isUnisatCompatibleProviderAPIThrownError(e)) {\n if (e.code === 4001) {\n throw new UserRejectError()\n }\n throw new UnisatCompatibleProviderError(e)\n }\n throw e\n }\n}\n"],"names":["UnisatCompatibleWalletAdapterImpl","unisat","walletDisplayName","addresses","WalletAdapterNotConnectedError","publicKey","network","hasAny","BitcoinWalletAdapterError","address","addrType","getAddressType","getBitcoinNetwork","addressType","WalletAdapterAddressType","scriptPubKey","hex","addressToScriptPubKey","tapInternalKey","getTapInternalKeyOf_P2TR_publicKey","redeemScript","getRedeemScriptOf_P2SH_P2WPKH_publicKey","WalletAdapterBitcoinNetwork","WalletAdapterAddressPurpose","message","handleRpcError","SignMessageAlgorithm","fromAddress","receiverAddress","satoshiAmount","options","inscriptionId","psbtHex","signIndices","signedPsbtHex","signIndex","tx","btc.Transaction","callback","handler","error","isUnisatCompatibleProviderAPIThrownError","err","UnisatCompatibleProviderError","promise","UserRejectError"],"mappings":"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"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { U as a } from "./UnisatCompatibleWalletAdapterImpl-M38FqkZI.mjs";
|
|
2
|
-
class l extends a {
|
|
3
|
-
constructor(e) {
|
|
4
|
-
super(e, "UniSat");
|
|
5
|
-
}
|
|
6
|
-
sendBitcoinFeeRateCapability = "required";
|
|
7
|
-
// The default fee rate of unisat is not aligned with mempool.space, so
|
|
8
|
-
// sometimes the tx will be rejected by mempool due to uneligible network fee.
|
|
9
|
-
sendInscriptionFeeRateCapability = "unavailable";
|
|
10
|
-
}
|
|
11
|
-
export {
|
|
12
|
-
l as UnisatWalletAdapterImpl
|
|
13
|
-
};
|
|
14
|
-
//# sourceMappingURL=UnisatWalletAdapter.impl-CJB22se8.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"UnisatWalletAdapter.impl-CJB22se8.mjs","sources":["../src/adapters/UnisatWalletAdapter.impl.ts"],"sourcesContent":["import {\n UnisatCompatibleProviderAPI,\n UnisatCompatibleWalletAdapterImpl,\n} from \"../utils/UnisatCompatibleWalletAdapterImpl\"\nimport { WalletAdapter } from \"../WalletAdapters.types\"\n\n/**\n * Derivation path (Native SegWit) (BIP-84): m/84'/0'/0'/0/address_index\n * Derivation path (Nested SegWit) (BIP-49): m/49'/0'/0'/0/address_index\n * Derivation path (Taproot) (BIP-86): m/86'/0'/0'/0/address_index\n * Derivation path (Taproot) (BIP-44): m/44'/0'/0'/0/address_index\n * Derivation path (Legacy) (BIP-44): m/44'/0'/0'/0/address_index\n */\nexport class UnisatWalletAdapterImpl\n extends UnisatCompatibleWalletAdapterImpl\n implements WalletAdapter\n{\n constructor(provider: UnisatCompatibleProviderAPI) {\n /**\n * UniSat Provider API:\n *\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet\n */\n super(provider, \"UniSat\")\n }\n\n sendBitcoinFeeRateCapability = \"required\" as const\n\n // The default fee rate of unisat is not aligned with mempool.space, so\n // sometimes the tx will be rejected by mempool due to uneligible network fee.\n sendInscriptionFeeRateCapability = \"unavailable\" as const\n}\n"],"names":["UnisatWalletAdapterImpl","UnisatCompatibleWalletAdapterImpl","provider"],"mappings":";AAaO,MAAMA,UACHC,EAEV;AAAA,EACE,YAAYC,GAAuC;AAMjD,UAAMA,GAAU,QAAQ;AAAA,EAC1B;AAAA,EAEA,+BAA+B;AAAA;AAAA;AAAA,EAI/B,mCAAmC;AACrC;"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("./UnisatCompatibleWalletAdapterImpl-Cq2Oqk1b.js");class a extends t.UnisatCompatibleWalletAdapterImpl{constructor(e){super(e,"UniSat")}sendBitcoinFeeRateCapability="required";sendInscriptionFeeRateCapability="unavailable"}exports.UnisatWalletAdapterImpl=a;
|
|
2
|
-
//# sourceMappingURL=UnisatWalletAdapter.impl-EISvxdpc.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"UnisatWalletAdapter.impl-EISvxdpc.js","sources":["../src/adapters/UnisatWalletAdapter.impl.ts"],"sourcesContent":["import {\n UnisatCompatibleProviderAPI,\n UnisatCompatibleWalletAdapterImpl,\n} from \"../utils/UnisatCompatibleWalletAdapterImpl\"\nimport { WalletAdapter } from \"../WalletAdapters.types\"\n\n/**\n * Derivation path (Native SegWit) (BIP-84): m/84'/0'/0'/0/address_index\n * Derivation path (Nested SegWit) (BIP-49): m/49'/0'/0'/0/address_index\n * Derivation path (Taproot) (BIP-86): m/86'/0'/0'/0/address_index\n * Derivation path (Taproot) (BIP-44): m/44'/0'/0'/0/address_index\n * Derivation path (Legacy) (BIP-44): m/44'/0'/0'/0/address_index\n */\nexport class UnisatWalletAdapterImpl\n extends UnisatCompatibleWalletAdapterImpl\n implements WalletAdapter\n{\n constructor(provider: UnisatCompatibleProviderAPI) {\n /**\n * UniSat Provider API:\n *\n * https://docs.unisat.io/dev/unisat-developer-service/unisat-wallet\n */\n super(provider, \"UniSat\")\n }\n\n sendBitcoinFeeRateCapability = \"required\" as const\n\n // The default fee rate of unisat is not aligned with mempool.space, so\n // sometimes the tx will be rejected by mempool due to uneligible network fee.\n sendInscriptionFeeRateCapability = \"unavailable\" as const\n}\n"],"names":["UnisatWalletAdapterImpl","UnisatCompatibleWalletAdapterImpl","provider"],"mappings":"mJAaO,MAAMA,UACHC,EAAAA,iCAEV,CACE,YAAYC,EAAuC,CAMjD,MAAMA,EAAU,QAAQ,CAC1B,CAEA,6BAA+B,WAI/B,iCAAmC,aACrC"}
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
class s extends Error {
|
|
2
|
-
constructor(n, t) {
|
|
3
|
-
super(n, t), this.name = "BitcoinWalletAdapterError";
|
|
4
|
-
}
|
|
5
|
-
}
|
|
6
|
-
class u extends s {
|
|
7
|
-
constructor(n, t) {
|
|
8
|
-
super(n, t), this.name = "UserRejectError";
|
|
9
|
-
}
|
|
10
|
-
}
|
|
11
|
-
var o = /* @__PURE__ */ ((r) => (r.MAINNET = "mainnet", r.TESTNET = "testnet", r.UNKNOWN = "unknown", r))(o || {}), a = /* @__PURE__ */ ((r) => (r.Bitcoin = "bitcoin", r.Ordinals = "ordinals", r.BRC20 = "brc20", r.Runes = "runes", r))(a || {}), c = /* @__PURE__ */ ((r) => (r.P2SH_P2WPKH = "p2sh-p2wpkh", r.P2WPKH = "p2wpkh", r.P2TR = "p2tr", r.P2PKH = "p2pkh", r))(c || {}), e = /* @__PURE__ */ ((r) => (r.ECDSA = "ECDSA", r.BIP322 = "BIP322", r))(e || {});
|
|
12
|
-
class E extends Error {
|
|
13
|
-
constructor(n) {
|
|
14
|
-
super(n), this.name = "WalletAdapterErrorBase";
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
class i extends E {
|
|
18
|
-
constructor(n, t) {
|
|
19
|
-
super(t ?? `Wallet ${n} is not connected`), this.name = "WalletAdapterNotConnectedError";
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
export {
|
|
23
|
-
s as B,
|
|
24
|
-
e as S,
|
|
25
|
-
u as U,
|
|
26
|
-
o as W,
|
|
27
|
-
a,
|
|
28
|
-
c as b,
|
|
29
|
-
E as c,
|
|
30
|
-
i as d
|
|
31
|
-
};
|
|
32
|
-
//# sourceMappingURL=WalletAdapters.types-CnvOqHFH.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"WalletAdapters.types-CnvOqHFH.mjs","sources":["../src/utils/error.ts","../src/WalletAdapters.types.ts"],"sourcesContent":["export class BitcoinWalletAdapterError extends Error {\n constructor(message?: string, options?: ErrorOptions) {\n super(message, options)\n this.name = \"BitcoinWalletAdapterError\"\n }\n}\n\nexport class UserRejectError extends BitcoinWalletAdapterError {\n constructor(message?: string, options?: ErrorOptions) {\n super(message, options)\n this.name = \"UserRejectError\"\n }\n}\n","import { Availability } from \"./utils/createAdapterAvailability\"\n\nexport enum WalletAdapterBitcoinNetwork {\n MAINNET = \"mainnet\",\n TESTNET = \"testnet\",\n UNKNOWN = \"unknown\",\n}\n\nexport enum WalletAdapterAddressPurpose {\n Bitcoin = \"bitcoin\",\n Ordinals = \"ordinals\",\n BRC20 = \"brc20\",\n Runes = \"runes\",\n}\n\n// prettier-ignore\nexport enum WalletAdapterAddressType {\n P2SH_P2WPKH = \"p2sh-p2wpkh\", // aka Nested SegWit\n P2WPKH = \"p2wpkh\", // aka Native SegWit\n P2TR = \"p2tr\", // aka Taproot\n P2PKH = \"p2pkh\", // aka Legacy\n}\n\nexport enum SignMessageAlgorithm {\n ECDSA = \"ECDSA\",\n BIP322 = \"BIP322\",\n}\nexport type SignMessageResult =\n | SignMessageResult.ECDSA\n | SignMessageResult.BIP322\nexport namespace SignMessageResult {\n export interface ECDSA {\n algorithm: SignMessageAlgorithm.ECDSA\n result: string\n address: string\n publicKey: string\n }\n\n export interface BIP322 {\n algorithm: SignMessageAlgorithm.BIP322\n result: string\n address: string\n }\n}\n\nexport interface WalletAdapterAddressBasic {\n addressType: WalletAdapterAddressType\n address: string\n scriptPubKey: string\n}\n\nexport interface WalletAdapterAddressWithPublicKey {\n /**\n * Some wallet may won't give us the public key of the address, like Xverse\n */\n publicKey: string\n}\n\nexport interface WalletAdapterAddressWithRedeemScript {\n /**\n * Some address is SH address, which requires redeem script to spend, like Xverse\n */\n redeemScript: string\n}\n\nexport interface WalletAdapterAddressWithTapInternalKey {\n /**\n * Some address is taproot address, which requires taproot internal key to spend.\n */\n tapInternalKey: string\n}\n\nexport interface WalletAdapterAddress extends Partial<\n WalletAdapterAddressWithPublicKey &\n WalletAdapterAddressWithRedeemScript &\n WalletAdapterAddressWithTapInternalKey\n> {\n addressType: WalletAdapterAddressType\n address: string\n scriptPubKey: string\n network: WalletAdapterBitcoinNetwork\n purposes: WalletAdapterAddressPurpose[]\n}\n\nexport interface WalletAdapterMetadata {\n name: string\n iconUrl: Promise<string>\n websiteUrl: string\n downloadUrl: string\n}\n\nexport interface WalletAdapterStatic<T extends WalletAdapter> {\n adapterId: string\n metadata: WalletAdapterMetadata\n getAdapter(): Availability<T>\n}\n\nexport type WalletAdapter_onAddressesChanged_callback = (data: {\n addresses: WalletAdapterAddress[]\n}) => void\n\nexport interface WalletAdapter {\n connect(): Promise<void>\n\n disconnect(): Promise<void>\n\n getAddresses(): Promise<WalletAdapterAddress[]>\n onAddressesChanged(callback: WalletAdapter_onAddressesChanged_callback): {\n unsubscribe: () => void\n }\n\n signMessage(address: string, message: string): Promise<SignMessageResult>\n\n readonly sendBitcoinFeeRateCapability:\n | \"unavailable\"\n | \"available\"\n | \"required\"\n sendBitcoin(\n fromAddress: string,\n receiverAddress: string,\n satoshiAmount: bigint,\n options?: { feeRate?: number },\n ): Promise<{ txid: string }>\n\n readonly sendInscriptionFeeRateCapability:\n | \"unavailable\"\n | \"available\"\n | \"required\"\n sendInscription?(\n fromAddress: string,\n receiverAddress: string,\n inscriptionId: string,\n options?: { feeRate?: number },\n ): Promise<{ txid: string }>\n\n signAndFinalizePsbt(\n psbtHex: string,\n signIndices: [address: string, signIndex: number][],\n ): Promise<{ signedPsbtHex: string }>\n}\n\nexport class WalletAdapterErrorBase extends Error {\n constructor(message: string) {\n super(message)\n this.name = \"WalletAdapterErrorBase\"\n }\n}\n\nexport class WalletAdapterNotConnectedError extends WalletAdapterErrorBase {\n constructor(walletName: string, message?: string) {\n super(message ?? `Wallet ${walletName} is not connected`)\n this.name = \"WalletAdapterNotConnectedError\"\n }\n}\n"],"names":["BitcoinWalletAdapterError","message","options","UserRejectError","WalletAdapterBitcoinNetwork","WalletAdapterAddressPurpose","WalletAdapterAddressType","SignMessageAlgorithm","WalletAdapterErrorBase","WalletAdapterNotConnectedError","walletName"],"mappings":"AAAO,MAAMA,UAAkC,MAAM;AAAA,EACnD,YAAYC,GAAkBC,GAAwB;AACpD,UAAMD,GAASC,CAAO,GACtB,KAAK,OAAO;AAAA,EACd;AACF;AAEO,MAAMC,UAAwBH,EAA0B;AAAA,EAC7D,YAAYC,GAAkBC,GAAwB;AACpD,UAAMD,GAASC,CAAO,GACtB,KAAK,OAAO;AAAA,EACd;AACF;ACVO,IAAKE,sBAAAA,OACVA,EAAA,UAAU,WACVA,EAAA,UAAU,WACVA,EAAA,UAAU,WAHAA,IAAAA,KAAA,CAAA,CAAA,GAMAC,sBAAAA,OACVA,EAAA,UAAU,WACVA,EAAA,WAAW,YACXA,EAAA,QAAQ,SACRA,EAAA,QAAQ,SAJEA,IAAAA,KAAA,CAAA,CAAA,GAQAC,sBAAAA,OACVA,EAAA,cAAc,eACdA,EAAA,SAAS,UACTA,EAAA,OAAO,QACPA,EAAA,QAAQ,SAJEA,IAAAA,KAAA,CAAA,CAAA,GAOAC,sBAAAA,OACVA,EAAA,QAAQ,SACRA,EAAA,SAAS,UAFCA,IAAAA,KAAA,CAAA,CAAA;AAsHL,MAAMC,UAA+B,MAAM;AAAA,EAChD,YAAYP,GAAiB;AAC3B,UAAMA,CAAO,GACb,KAAK,OAAO;AAAA,EACd;AACF;AAEO,MAAMQ,UAAuCD,EAAuB;AAAA,EACzE,YAAYE,GAAoBT,GAAkB;AAChD,UAAMA,KAAW,UAAUS,CAAU,mBAAmB,GACxD,KAAK,OAAO;AAAA,EACd;AACF;"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";class n extends Error{constructor(t,e){super(t,e),this.name="BitcoinWalletAdapterError"}}class i extends n{constructor(t,e){super(t,e),this.name="UserRejectError"}}var o=(r=>(r.MAINNET="mainnet",r.TESTNET="testnet",r.UNKNOWN="unknown",r))(o||{}),s=(r=>(r.Bitcoin="bitcoin",r.Ordinals="ordinals",r.BRC20="brc20",r.Runes="runes",r))(s||{}),a=(r=>(r.P2SH_P2WPKH="p2sh-p2wpkh",r.P2WPKH="p2wpkh",r.P2TR="p2tr",r.P2PKH="p2pkh",r))(a||{}),c=(r=>(r.ECDSA="ECDSA",r.BIP322="BIP322",r))(c||{});class E extends Error{constructor(t){super(t),this.name="WalletAdapterErrorBase"}}class l extends E{constructor(t,e){super(e??`Wallet ${t} is not connected`),this.name="WalletAdapterNotConnectedError"}}exports.BitcoinWalletAdapterError=n;exports.SignMessageAlgorithm=c;exports.UserRejectError=i;exports.WalletAdapterAddressPurpose=s;exports.WalletAdapterAddressType=a;exports.WalletAdapterBitcoinNetwork=o;exports.WalletAdapterErrorBase=E;exports.WalletAdapterNotConnectedError=l;
|
|
2
|
-
//# sourceMappingURL=WalletAdapters.types-De_x1lzr.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"WalletAdapters.types-De_x1lzr.js","sources":["../src/utils/error.ts","../src/WalletAdapters.types.ts"],"sourcesContent":["export class BitcoinWalletAdapterError extends Error {\n constructor(message?: string, options?: ErrorOptions) {\n super(message, options)\n this.name = \"BitcoinWalletAdapterError\"\n }\n}\n\nexport class UserRejectError extends BitcoinWalletAdapterError {\n constructor(message?: string, options?: ErrorOptions) {\n super(message, options)\n this.name = \"UserRejectError\"\n }\n}\n","import { Availability } from \"./utils/createAdapterAvailability\"\n\nexport enum WalletAdapterBitcoinNetwork {\n MAINNET = \"mainnet\",\n TESTNET = \"testnet\",\n UNKNOWN = \"unknown\",\n}\n\nexport enum WalletAdapterAddressPurpose {\n Bitcoin = \"bitcoin\",\n Ordinals = \"ordinals\",\n BRC20 = \"brc20\",\n Runes = \"runes\",\n}\n\n// prettier-ignore\nexport enum WalletAdapterAddressType {\n P2SH_P2WPKH = \"p2sh-p2wpkh\", // aka Nested SegWit\n P2WPKH = \"p2wpkh\", // aka Native SegWit\n P2TR = \"p2tr\", // aka Taproot\n P2PKH = \"p2pkh\", // aka Legacy\n}\n\nexport enum SignMessageAlgorithm {\n ECDSA = \"ECDSA\",\n BIP322 = \"BIP322\",\n}\nexport type SignMessageResult =\n | SignMessageResult.ECDSA\n | SignMessageResult.BIP322\nexport namespace SignMessageResult {\n export interface ECDSA {\n algorithm: SignMessageAlgorithm.ECDSA\n result: string\n address: string\n publicKey: string\n }\n\n export interface BIP322 {\n algorithm: SignMessageAlgorithm.BIP322\n result: string\n address: string\n }\n}\n\nexport interface WalletAdapterAddressBasic {\n addressType: WalletAdapterAddressType\n address: string\n scriptPubKey: string\n}\n\nexport interface WalletAdapterAddressWithPublicKey {\n /**\n * Some wallet may won't give us the public key of the address, like Xverse\n */\n publicKey: string\n}\n\nexport interface WalletAdapterAddressWithRedeemScript {\n /**\n * Some address is SH address, which requires redeem script to spend, like Xverse\n */\n redeemScript: string\n}\n\nexport interface WalletAdapterAddressWithTapInternalKey {\n /**\n * Some address is taproot address, which requires taproot internal key to spend.\n */\n tapInternalKey: string\n}\n\nexport interface WalletAdapterAddress extends Partial<\n WalletAdapterAddressWithPublicKey &\n WalletAdapterAddressWithRedeemScript &\n WalletAdapterAddressWithTapInternalKey\n> {\n addressType: WalletAdapterAddressType\n address: string\n scriptPubKey: string\n network: WalletAdapterBitcoinNetwork\n purposes: WalletAdapterAddressPurpose[]\n}\n\nexport interface WalletAdapterMetadata {\n name: string\n iconUrl: Promise<string>\n websiteUrl: string\n downloadUrl: string\n}\n\nexport interface WalletAdapterStatic<T extends WalletAdapter> {\n adapterId: string\n metadata: WalletAdapterMetadata\n getAdapter(): Availability<T>\n}\n\nexport type WalletAdapter_onAddressesChanged_callback = (data: {\n addresses: WalletAdapterAddress[]\n}) => void\n\nexport interface WalletAdapter {\n connect(): Promise<void>\n\n disconnect(): Promise<void>\n\n getAddresses(): Promise<WalletAdapterAddress[]>\n onAddressesChanged(callback: WalletAdapter_onAddressesChanged_callback): {\n unsubscribe: () => void\n }\n\n signMessage(address: string, message: string): Promise<SignMessageResult>\n\n readonly sendBitcoinFeeRateCapability:\n | \"unavailable\"\n | \"available\"\n | \"required\"\n sendBitcoin(\n fromAddress: string,\n receiverAddress: string,\n satoshiAmount: bigint,\n options?: { feeRate?: number },\n ): Promise<{ txid: string }>\n\n readonly sendInscriptionFeeRateCapability:\n | \"unavailable\"\n | \"available\"\n | \"required\"\n sendInscription?(\n fromAddress: string,\n receiverAddress: string,\n inscriptionId: string,\n options?: { feeRate?: number },\n ): Promise<{ txid: string }>\n\n signAndFinalizePsbt(\n psbtHex: string,\n signIndices: [address: string, signIndex: number][],\n ): Promise<{ signedPsbtHex: string }>\n}\n\nexport class WalletAdapterErrorBase extends Error {\n constructor(message: string) {\n super(message)\n this.name = \"WalletAdapterErrorBase\"\n }\n}\n\nexport class WalletAdapterNotConnectedError extends WalletAdapterErrorBase {\n constructor(walletName: string, message?: string) {\n super(message ?? `Wallet ${walletName} is not connected`)\n this.name = \"WalletAdapterNotConnectedError\"\n }\n}\n"],"names":["BitcoinWalletAdapterError","message","options","UserRejectError","WalletAdapterBitcoinNetwork","WalletAdapterAddressPurpose","WalletAdapterAddressType","SignMessageAlgorithm","WalletAdapterErrorBase","WalletAdapterNotConnectedError","walletName"],"mappings":"aAAO,MAAMA,UAAkC,KAAM,CACnD,YAAYC,EAAkBC,EAAwB,CACpD,MAAMD,EAASC,CAAO,EACtB,KAAK,KAAO,2BACd,CACF,CAEO,MAAMC,UAAwBH,CAA0B,CAC7D,YAAYC,EAAkBC,EAAwB,CACpD,MAAMD,EAASC,CAAO,EACtB,KAAK,KAAO,iBACd,CACF,CCVO,IAAKE,GAAAA,IACVA,EAAA,QAAU,UACVA,EAAA,QAAU,UACVA,EAAA,QAAU,UAHAA,IAAAA,GAAA,CAAA,CAAA,EAMAC,GAAAA,IACVA,EAAA,QAAU,UACVA,EAAA,SAAW,WACXA,EAAA,MAAQ,QACRA,EAAA,MAAQ,QAJEA,IAAAA,GAAA,CAAA,CAAA,EAQAC,GAAAA,IACVA,EAAA,YAAc,cACdA,EAAA,OAAS,SACTA,EAAA,KAAO,OACPA,EAAA,MAAQ,QAJEA,IAAAA,GAAA,CAAA,CAAA,EAOAC,GAAAA,IACVA,EAAA,MAAQ,QACRA,EAAA,OAAS,SAFCA,IAAAA,GAAA,CAAA,CAAA,EAsHL,MAAMC,UAA+B,KAAM,CAChD,YAAYP,EAAiB,CAC3B,MAAMA,CAAO,EACb,KAAK,KAAO,wBACd,CACF,CAEO,MAAMQ,UAAuCD,CAAuB,CACzE,YAAYE,EAAoBT,EAAkB,CAChD,MAAMA,GAAW,UAAUS,CAAU,mBAAmB,EACxD,KAAK,KAAO,gCACd,CACF"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"XverseCompatibleWalletAdapterImpl-Bf-BK5VK.js","sources":["../src/utils/XverseCompatibleWalletAdapterImpl.ts"],"sourcesContent":["import { base64, hex } from \"@scure/base\"\nimport * as btc from \"@scure/btc-signer\"\nimport { UserRejectError } from \"../utils/error\"\nimport {\n SignMessageAlgorithm,\n SignMessageResult,\n WalletAdapter,\n WalletAdapter_onAddressesChanged_callback,\n WalletAdapterAddress,\n WalletAdapterAddressPurpose,\n WalletAdapterNotConnectedError,\n} from \"../WalletAdapters.types\"\n\nexport type XverseCompatibleWalletAdapterGetProviderIdFn = () => Promise<string>\n\nexport type XverseCompatibleWalletAdapterParsedAddressesFn = (info: {\n sdk: typeof import(\"sats-connect\")\n network: import(\"sats-connect\").BitcoinNetworkType\n addresses: import(\"sats-connect\").Address[]\n}) => Promise<XverseCompatibleWalletAdapterImplAddress[]>\n\nexport type XverseCompatibleWalletAdapterImplAddress = WalletAdapterAddress & {\n publicKey: string\n}\n\nexport class XverseCompatibleWalletAdapterImpl implements WalletAdapter {\n protected readonly walletDisplayName: string\n protected readonly getProviderId: XverseCompatibleWalletAdapterGetProviderIdFn\n protected readonly parseAddresses: XverseCompatibleWalletAdapterParsedAddressesFn\n\n constructor(info: {\n walletDisplayName: string\n getProviderId: XverseCompatibleWalletAdapterGetProviderIdFn\n parseAddresses: XverseCompatibleWalletAdapterParsedAddressesFn\n }) {\n this.walletDisplayName = info.walletDisplayName\n this.getProviderId = info.getProviderId\n this.parseAddresses = info.parseAddresses\n }\n\n private async getSdk(): Promise<typeof import(\"sats-connect\")> {\n return import(\"sats-connect\")\n }\n\n async connect(): Promise<void> {\n await (await this.getSdk()).request(\"wallet_connect\", null)\n }\n\n async disconnect(): Promise<void> {\n return Promise.resolve()\n }\n\n async getAddresses(): Promise<XverseCompatibleWalletAdapterImplAddress[]> {\n const sdk = await this.getSdk()\n\n const resp = await handleRpcError(\n sdk.request(\n \"getAddresses\",\n {\n purposes: [sdk.AddressPurpose.Ordinals, sdk.AddressPurpose.Payment],\n },\n await this.getProviderId(),\n ),\n )\n\n if (resp == null) {\n throw new WalletAdapterNotConnectedError(this.walletDisplayName)\n }\n\n return this.parseAddresses({\n sdk,\n network: resp.network.bitcoin.name,\n addresses: resp.addresses,\n })\n }\n\n async signMessage(\n address: string,\n message: string,\n ): Promise<SignMessageResult> {\n const sdk = await this.getSdk()\n\n const result = await handleRpcError(\n sdk.request(\n \"signMessage\",\n {\n address,\n message,\n protocol: sdk.MessageSigningProtocols.BIP322,\n },\n await this.getProviderId(),\n ),\n )\n\n return {\n result: result.signature,\n address,\n algorithm: SignMessageAlgorithm.BIP322,\n }\n }\n\n sendBitcoinFeeRateCapability = \"unavailable\" as const\n async sendBitcoin(\n fromAddress: string,\n receiverAddress: string,\n satoshiAmount: bigint,\n ): Promise<{ txid: string }> {\n const senderAddress = (await this.getAddresses()).find(a =>\n a.purposes.includes(WalletAdapterAddressPurpose.Bitcoin),\n )\n if (senderAddress == null) {\n throw new XverseCompatibleProviderError({\n code: XverseRpcErrorCode.INVALID_PARAMS,\n message: \"Bitcoin address not found\",\n })\n }\n\n const sdk = await this.getSdk()\n\n return await handleRpcError(\n sdk.request(\n \"sendTransfer\",\n {\n recipients: [\n {\n address: receiverAddress,\n amount: Number(satoshiAmount),\n },\n ],\n },\n await this.getProviderId(),\n ),\n )\n }\n\n sendInscriptionFeeRateCapability = \"unavailable\" as const\n\n async signAndFinalizePsbt(\n psbtHex: string,\n signIndices: [address: string, signIndex: number][],\n ): Promise<{\n signedPsbtHex: string\n }> {\n const sdk = await this.getSdk()\n\n const psbtBase64 = base64.encode(hex.decode(psbtHex))\n\n const result = await handleRpcError(\n sdk.request(\n \"signPsbt\",\n {\n psbt: psbtBase64,\n signInputs: signIndices.reduce(\n (acc, [address, signIndex]) => {\n acc[address] = [signIndex]\n return acc\n },\n {} as Record<string, number[]>,\n ),\n broadcast: false,\n },\n await this.getProviderId(),\n ),\n )\n\n const tx = btc.Transaction.fromPSBT(base64.decode(result.psbt), {\n allowUnknownInputs: true,\n allowUnknownOutputs: true,\n disableScriptCheck: true,\n allowLegacyWitnessUtxo: true,\n })\n tx.finalize()\n\n return { signedPsbtHex: hex.encode(tx.toPSBT()) }\n }\n\n onAddressesChanged(callback: WalletAdapter_onAddressesChanged_callback): {\n unsubscribe: () => void\n } {\n // Xverse uses sats-connect Wallet.addListener for events\n // https://docs.xverse.app/sats-connect/xverse-wallet-events\n const removeListeners: Array<() => void> = []\n\n void (async () => {\n const sdk = await this.getSdk()\n\n const handler = async (): Promise<void> => {\n try {\n const addresses = await this.getAddresses()\n callback({ addresses })\n } catch (error) {\n console.warn(\n `[${this.walletDisplayName}] Failed to get addresses on change:`,\n error,\n )\n }\n }\n\n // Listen to account and network changes\n const removeAccountListener = sdk.addListener(\"accountChange\", handler)\n const removeNetworkListener = sdk.addListener(\"networkChange\", handler)\n\n removeListeners.push(removeAccountListener, removeNetworkListener)\n })()\n\n return {\n unsubscribe: () => {\n removeListeners.forEach(remove => remove())\n },\n }\n }\n}\n\nexport enum XverseRpcErrorCode {\n /**\n * Parse error Invalid JSON\n **/\n PARSE_ERROR = -32700,\n /**\n * The JSON sent is not a valid Request object.\n **/\n INVALID_REQUEST = -32600,\n /**\n * The method does not exist/is not available.\n **/\n METHOD_NOT_FOUND = -32601,\n /**\n * Invalid method parameter(s).\n */\n INVALID_PARAMS = -32602,\n /**\n * Internal JSON-RPC error.\n * This is a generic error, used when the server encounters an error in performing the request.\n **/\n INTERNAL_ERROR = -32603,\n /**\n * user rejected/canceled the request\n */\n USER_REJECTION = -32000,\n /**\n * method is not supported for the address provided\n */\n METHOD_NOT_SUPPORTED = -32001,\n /**\n * The client does not have permission to access the requested resource.\n */\n ACCESS_DENIED = -32002,\n}\nexport interface XverseCompatibleProviderAPIThrownError {\n code: XverseRpcErrorCode\n message: string\n}\nexport function isXverseCompatibleProviderAPIThrownError(\n err: any,\n): err is XverseCompatibleProviderAPIThrownError {\n return err != null && \"code\" in err && \"message\" in err\n}\n\nexport class XverseCompatibleProviderError extends Error {\n readonly code: number\n constructor(err: XverseCompatibleProviderAPIThrownError) {\n super(err.message)\n this.code = err.code\n this.cause = err\n }\n}\n\nconst handleRpcError = async <T>(\n promise: Promise<\n { status: \"success\"; result: T } | { status: \"error\"; error: unknown }\n >,\n): Promise<T> => {\n try {\n const res = await promise\n if (res.status === \"error\") {\n throw res.error\n }\n return res.result\n } catch (e: any) {\n if (isXverseCompatibleProviderAPIThrownError(e)) {\n if (e.code === XverseRpcErrorCode.USER_REJECTION) {\n throw new UserRejectError()\n }\n throw new XverseCompatibleProviderError(e)\n }\n throw e\n }\n}\n"],"names":["XverseCompatibleWalletAdapterImpl","info","sdk","resp","handleRpcError","WalletAdapterNotConnectedError","address","message","SignMessageAlgorithm","fromAddress","receiverAddress","satoshiAmount","a","WalletAdapterAddressPurpose","XverseCompatibleProviderError","psbtHex","signIndices","psbtBase64","base64","hex","result","acc","signIndex","tx","btc.Transaction","callback","removeListeners","handler","addresses","error","removeAccountListener","removeNetworkListener","remove","XverseRpcErrorCode","isXverseCompatibleProviderAPIThrownError","err","promise","res","UserRejectError"],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"XverseCompatibleWalletAdapterImpl-DXKnO_-V.mjs","sources":["../src/utils/XverseCompatibleWalletAdapterImpl.ts"],"sourcesContent":["import { base64, hex } from \"@scure/base\"\nimport * as btc from \"@scure/btc-signer\"\nimport { UserRejectError } from \"../utils/error\"\nimport {\n SignMessageAlgorithm,\n SignMessageResult,\n WalletAdapter,\n WalletAdapter_onAddressesChanged_callback,\n WalletAdapterAddress,\n WalletAdapterAddressPurpose,\n WalletAdapterNotConnectedError,\n} from \"../WalletAdapters.types\"\n\nexport type XverseCompatibleWalletAdapterGetProviderIdFn = () => Promise<string>\n\nexport type XverseCompatibleWalletAdapterParsedAddressesFn = (info: {\n sdk: typeof import(\"sats-connect\")\n network: import(\"sats-connect\").BitcoinNetworkType\n addresses: import(\"sats-connect\").Address[]\n}) => Promise<XverseCompatibleWalletAdapterImplAddress[]>\n\nexport type XverseCompatibleWalletAdapterImplAddress = WalletAdapterAddress & {\n publicKey: string\n}\n\nexport class XverseCompatibleWalletAdapterImpl implements WalletAdapter {\n protected readonly walletDisplayName: string\n protected readonly getProviderId: XverseCompatibleWalletAdapterGetProviderIdFn\n protected readonly parseAddresses: XverseCompatibleWalletAdapterParsedAddressesFn\n\n constructor(info: {\n walletDisplayName: string\n getProviderId: XverseCompatibleWalletAdapterGetProviderIdFn\n parseAddresses: XverseCompatibleWalletAdapterParsedAddressesFn\n }) {\n this.walletDisplayName = info.walletDisplayName\n this.getProviderId = info.getProviderId\n this.parseAddresses = info.parseAddresses\n }\n\n private async getSdk(): Promise<typeof import(\"sats-connect\")> {\n return import(\"sats-connect\")\n }\n\n async connect(): Promise<void> {\n await (await this.getSdk()).request(\"wallet_connect\", null)\n }\n\n async disconnect(): Promise<void> {\n return Promise.resolve()\n }\n\n async getAddresses(): Promise<XverseCompatibleWalletAdapterImplAddress[]> {\n const sdk = await this.getSdk()\n\n const resp = await handleRpcError(\n sdk.request(\n \"getAddresses\",\n {\n purposes: [sdk.AddressPurpose.Ordinals, sdk.AddressPurpose.Payment],\n },\n await this.getProviderId(),\n ),\n )\n\n if (resp == null) {\n throw new WalletAdapterNotConnectedError(this.walletDisplayName)\n }\n\n return this.parseAddresses({\n sdk,\n network: resp.network.bitcoin.name,\n addresses: resp.addresses,\n })\n }\n\n async signMessage(\n address: string,\n message: string,\n ): Promise<SignMessageResult> {\n const sdk = await this.getSdk()\n\n const result = await handleRpcError(\n sdk.request(\n \"signMessage\",\n {\n address,\n message,\n protocol: sdk.MessageSigningProtocols.BIP322,\n },\n await this.getProviderId(),\n ),\n )\n\n return {\n result: result.signature,\n address,\n algorithm: SignMessageAlgorithm.BIP322,\n }\n }\n\n sendBitcoinFeeRateCapability = \"unavailable\" as const\n async sendBitcoin(\n fromAddress: string,\n receiverAddress: string,\n satoshiAmount: bigint,\n ): Promise<{ txid: string }> {\n const senderAddress = (await this.getAddresses()).find(a =>\n a.purposes.includes(WalletAdapterAddressPurpose.Bitcoin),\n )\n if (senderAddress == null) {\n throw new XverseCompatibleProviderError({\n code: XverseRpcErrorCode.INVALID_PARAMS,\n message: \"Bitcoin address not found\",\n })\n }\n\n const sdk = await this.getSdk()\n\n return await handleRpcError(\n sdk.request(\n \"sendTransfer\",\n {\n recipients: [\n {\n address: receiverAddress,\n amount: Number(satoshiAmount),\n },\n ],\n },\n await this.getProviderId(),\n ),\n )\n }\n\n sendInscriptionFeeRateCapability = \"unavailable\" as const\n\n async signAndFinalizePsbt(\n psbtHex: string,\n signIndices: [address: string, signIndex: number][],\n ): Promise<{\n signedPsbtHex: string\n }> {\n const sdk = await this.getSdk()\n\n const psbtBase64 = base64.encode(hex.decode(psbtHex))\n\n const result = await handleRpcError(\n sdk.request(\n \"signPsbt\",\n {\n psbt: psbtBase64,\n signInputs: signIndices.reduce(\n (acc, [address, signIndex]) => {\n acc[address] = [signIndex]\n return acc\n },\n {} as Record<string, number[]>,\n ),\n broadcast: false,\n },\n await this.getProviderId(),\n ),\n )\n\n const tx = btc.Transaction.fromPSBT(base64.decode(result.psbt), {\n allowUnknownInputs: true,\n allowUnknownOutputs: true,\n disableScriptCheck: true,\n allowLegacyWitnessUtxo: true,\n })\n tx.finalize()\n\n return { signedPsbtHex: hex.encode(tx.toPSBT()) }\n }\n\n onAddressesChanged(callback: WalletAdapter_onAddressesChanged_callback): {\n unsubscribe: () => void\n } {\n // Xverse uses sats-connect Wallet.addListener for events\n // https://docs.xverse.app/sats-connect/xverse-wallet-events\n const removeListeners: Array<() => void> = []\n\n void (async () => {\n const sdk = await this.getSdk()\n\n const handler = async (): Promise<void> => {\n try {\n const addresses = await this.getAddresses()\n callback({ addresses })\n } catch (error) {\n console.warn(\n `[${this.walletDisplayName}] Failed to get addresses on change:`,\n error,\n )\n }\n }\n\n // Listen to account and network changes\n const removeAccountListener = sdk.addListener(\"accountChange\", handler)\n const removeNetworkListener = sdk.addListener(\"networkChange\", handler)\n\n removeListeners.push(removeAccountListener, removeNetworkListener)\n })()\n\n return {\n unsubscribe: () => {\n removeListeners.forEach(remove => remove())\n },\n }\n }\n}\n\nexport enum XverseRpcErrorCode {\n /**\n * Parse error Invalid JSON\n **/\n PARSE_ERROR = -32700,\n /**\n * The JSON sent is not a valid Request object.\n **/\n INVALID_REQUEST = -32600,\n /**\n * The method does not exist/is not available.\n **/\n METHOD_NOT_FOUND = -32601,\n /**\n * Invalid method parameter(s).\n */\n INVALID_PARAMS = -32602,\n /**\n * Internal JSON-RPC error.\n * This is a generic error, used when the server encounters an error in performing the request.\n **/\n INTERNAL_ERROR = -32603,\n /**\n * user rejected/canceled the request\n */\n USER_REJECTION = -32000,\n /**\n * method is not supported for the address provided\n */\n METHOD_NOT_SUPPORTED = -32001,\n /**\n * The client does not have permission to access the requested resource.\n */\n ACCESS_DENIED = -32002,\n}\nexport interface XverseCompatibleProviderAPIThrownError {\n code: XverseRpcErrorCode\n message: string\n}\nexport function isXverseCompatibleProviderAPIThrownError(\n err: any,\n): err is XverseCompatibleProviderAPIThrownError {\n return err != null && \"code\" in err && \"message\" in err\n}\n\nexport class XverseCompatibleProviderError extends Error {\n readonly code: number\n constructor(err: XverseCompatibleProviderAPIThrownError) {\n super(err.message)\n this.code = err.code\n this.cause = err\n }\n}\n\nconst handleRpcError = async <T>(\n promise: Promise<\n { status: \"success\"; result: T } | { status: \"error\"; error: unknown }\n >,\n): Promise<T> => {\n try {\n const res = await promise\n if (res.status === \"error\") {\n throw res.error\n }\n return res.result\n } catch (e: any) {\n if (isXverseCompatibleProviderAPIThrownError(e)) {\n if (e.code === XverseRpcErrorCode.USER_REJECTION) {\n throw new UserRejectError()\n }\n throw new XverseCompatibleProviderError(e)\n }\n throw e\n }\n}\n"],"names":["XverseCompatibleWalletAdapterImpl","info","sdk","resp","handleRpcError","WalletAdapterNotConnectedError","address","message","SignMessageAlgorithm","fromAddress","receiverAddress","satoshiAmount","a","WalletAdapterAddressPurpose","XverseCompatibleProviderError","psbtHex","signIndices","psbtBase64","base64","hex","result","acc","signIndex","tx","btc.Transaction","callback","removeListeners","handler","addresses","error","removeAccountListener","removeNetworkListener","remove","XverseRpcErrorCode","isXverseCompatibleProviderAPIThrownError","err","promise","res","e","UserRejectError"],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"XverseWalletAdapter.impl-CZO0RQva.mjs","sources":["../src/adapters/XverseWalletAdapter.impl.ts"],"sourcesContent":["import { hex } from \"@scure/base\"\nimport {\n addressToScriptPubKey,\n getRedeemScriptOf_P2SH_P2WPKH_publicKey,\n} from \"../utils/bitcoinAddressHelpers\"\nimport { getBitcoinNetwork } from \"../utils/bitcoinNetworkHelpers\"\nimport { checkNever } from \"../utils/misc\"\nimport {\n WalletAdapter,\n WalletAdapterAddressPurpose,\n WalletAdapterAddressType,\n WalletAdapterBitcoinNetwork,\n} from \"../WalletAdapters.types\"\nimport {\n XverseCompatibleWalletAdapterImpl,\n XverseCompatibleWalletAdapterImplAddress,\n} from \"../utils/XverseCompatibleWalletAdapterImpl\"\nimport { XVERSE_PROVIDER_ID } from \"./XverseWalletAdapter\"\n\ndeclare global {\n interface Window {\n btc_providers?: import(\"sats-connect\").Provider[]\n }\n}\n\nexport type XverseWalletAdapterAddresses =\n XverseCompatibleWalletAdapterImplAddress\n\n/**\n * Derivation path (BIP-49): m/49'/0'/0'/0/ address_index\n */\n\nexport class XverseWalletAdapterImpl\n extends XverseCompatibleWalletAdapterImpl\n implements WalletAdapter\n{\n constructor() {\n super({\n walletDisplayName: \"Xverse\",\n getProviderId: async () => {\n return XVERSE_PROVIDER_ID\n },\n parseAddresses: async ({ sdk, network: xverseNetwork, addresses }) => {\n // prettier-ignore\n const network =\n xverseNetwork === sdk.BitcoinNetworkType.Mainnet ? WalletAdapterBitcoinNetwork.MAINNET :\n xverseNetwork === sdk.BitcoinNetworkType.Testnet ? WalletAdapterBitcoinNetwork.TESTNET :\n xverseNetwork === sdk.BitcoinNetworkType.Testnet4 ? WalletAdapterBitcoinNetwork.TESTNET :\n xverseNetwork === sdk.BitcoinNetworkType.Signet ? WalletAdapterBitcoinNetwork.UNKNOWN :\n xverseNetwork === sdk.BitcoinNetworkType.Regtest ? WalletAdapterBitcoinNetwork.UNKNOWN :\n (checkNever(xverseNetwork), WalletAdapterBitcoinNetwork.UNKNOWN)\n\n const bitcoinNetwork = getBitcoinNetwork(\n network === WalletAdapterBitcoinNetwork.MAINNET\n ? \"mainnet\"\n : \"testnet\",\n )\n\n return addresses.flatMap((a): XverseWalletAdapterAddresses[] => {\n const purposes: WalletAdapterAddressPurpose[] = []\n switch (a.purpose) {\n case sdk.AddressPurpose.Ordinals:\n purposes.push(\n WalletAdapterAddressPurpose.Ordinals,\n WalletAdapterAddressPurpose.BRC20,\n WalletAdapterAddressPurpose.Runes,\n )\n break\n case sdk.AddressPurpose.Payment:\n purposes.push(WalletAdapterAddressPurpose.Bitcoin)\n break\n }\n\n const scriptPubKey = hex.encode(\n addressToScriptPubKey(bitcoinNetwork, a.address),\n )\n\n switch (a.addressType) {\n case sdk.AddressType.stacks:\n return []\n case sdk.AddressType.p2pkh:\n return [\n {\n purposes,\n network,\n addressType: WalletAdapterAddressType.P2PKH,\n address: a.address,\n scriptPubKey,\n publicKey: a.publicKey,\n },\n ]\n case sdk.AddressType.p2wpkh:\n return [\n {\n purposes,\n network,\n addressType: WalletAdapterAddressType.P2WPKH,\n address: a.address,\n scriptPubKey,\n publicKey: a.publicKey,\n },\n ]\n case sdk.AddressType.p2tr: {\n const tapInternalKey: string = a.publicKey\n return [\n {\n purposes,\n network,\n addressType: WalletAdapterAddressType.P2TR,\n address: a.address,\n scriptPubKey,\n publicKey: a.publicKey,\n tapInternalKey,\n },\n ]\n }\n case sdk.AddressType.p2sh: {\n const redeemScript = hex.encode(\n getRedeemScriptOf_P2SH_P2WPKH_publicKey(\n bitcoinNetwork,\n hex.decode(a.publicKey),\n ),\n )\n return [\n {\n purposes,\n network,\n addressType: WalletAdapterAddressType.P2SH_P2WPKH,\n address: a.address,\n scriptPubKey,\n publicKey: a.publicKey,\n redeemScript,\n },\n ]\n }\n case sdk.AddressType.p2wsh:\n // not supported\n return []\n case sdk.AddressType.starknet:\n case sdk.AddressType.spark:\n return []\n default:\n checkNever(a.addressType)\n return []\n }\n })\n },\n })\n }\n}\n"],"names":["XverseWalletAdapterImpl","XverseCompatibleWalletAdapterImpl","XVERSE_PROVIDER_ID","sdk","xverseNetwork","addresses","network","WalletAdapterBitcoinNetwork","bitcoinNetwork","getBitcoinNetwork","a","purposes","WalletAdapterAddressPurpose","scriptPubKey","hex","addressToScriptPubKey","WalletAdapterAddressType","tapInternalKey","redeemScript","getRedeemScriptOf_P2SH_P2WPKH_publicKey","checkNever"],"mappings":"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"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("./index-Zx0KcpYx.js"),o=require("./misc-CigR0RqC.js"),t=require("./WalletAdapters.types-De_x1lzr.js"),u=require("./XverseCompatibleWalletAdapterImpl-Bf-BK5VK.js");class y extends u.XverseCompatibleWalletAdapterImpl{constructor(){super({walletDisplayName:"Xverse",getProviderId:async()=>s.XVERSE_PROVIDER_ID,parseAddresses:async({sdk:e,network:d,addresses:n})=>{const a=d===e.BitcoinNetworkType.Mainnet?t.WalletAdapterBitcoinNetwork.MAINNET:d===e.BitcoinNetworkType.Testnet||d===e.BitcoinNetworkType.Testnet4?t.WalletAdapterBitcoinNetwork.TESTNET:(d===e.BitcoinNetworkType.Signet||d===e.BitcoinNetworkType.Regtest,t.WalletAdapterBitcoinNetwork.UNKNOWN),i=s.getBitcoinNetwork(a===t.WalletAdapterBitcoinNetwork.MAINNET?"mainnet":"testnet");return n.flatMap(r=>{const p=[];switch(r.purpose){case e.AddressPurpose.Ordinals:p.push(t.WalletAdapterAddressPurpose.Ordinals,t.WalletAdapterAddressPurpose.BRC20,t.WalletAdapterAddressPurpose.Runes);break;case e.AddressPurpose.Payment:p.push(t.WalletAdapterAddressPurpose.Bitcoin);break}const l=s.hex.encode(s.addressToScriptPubKey(i,r.address));switch(r.addressType){case e.AddressType.stacks:return[];case e.AddressType.p2pkh:return[{purposes:p,network:a,addressType:t.WalletAdapterAddressType.P2PKH,address:r.address,scriptPubKey:l,publicKey:r.publicKey}];case e.AddressType.p2wpkh:return[{purposes:p,network:a,addressType:t.WalletAdapterAddressType.P2WPKH,address:r.address,scriptPubKey:l,publicKey:r.publicKey}];case e.AddressType.p2tr:{const c=r.publicKey;return[{purposes:p,network:a,addressType:t.WalletAdapterAddressType.P2TR,address:r.address,scriptPubKey:l,publicKey:r.publicKey,tapInternalKey:c}]}case e.AddressType.p2sh:{const c=s.hex.encode(s.getRedeemScriptOf_P2SH_P2WPKH_publicKey(i,s.hex.decode(r.publicKey)));return[{purposes:p,network:a,addressType:t.WalletAdapterAddressType.P2SH_P2WPKH,address:r.address,scriptPubKey:l,publicKey:r.publicKey,redeemScript:c}]}case e.AddressType.p2wsh:return[];case e.AddressType.starknet:case e.AddressType.spark:return[];default:return o.checkNever(r.addressType),[]}})}})}}exports.XverseWalletAdapterImpl=y;
|
|
2
|
-
//# sourceMappingURL=XverseWalletAdapter.impl-lJwMi-Iv.js.map
|