@swapkit/wallets 3.0.0-beta.3 → 3.0.0-beta.5
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/dist/src/bitget/index.js +1 -1
- package/dist/src/coinbase/index.js +1 -1
- package/dist/src/ctrl/index.js +1 -1
- package/dist/src/evm-extensions/index.js +1 -1
- package/dist/src/exodus/index.js +1 -1
- package/dist/src/index.js +1 -1
- package/dist/src/keepkey/index.js +1 -1
- package/dist/src/keepkey-bex/index.js +1 -1
- package/dist/src/keystore/index.cjs +2 -2
- package/dist/src/keystore/index.cjs.map +3 -3
- package/dist/src/keystore/index.js +2 -2
- package/dist/src/keystore/index.js.map +3 -3
- package/dist/src/ledger/index.js +1 -1
- package/dist/src/okx/index.js +1 -1
- package/dist/src/onekey/index.js +1 -1
- package/dist/src/phantom/index.js +1 -1
- package/dist/src/polkadotjs/index.js +1 -1
- package/dist/src/radix/index.js +1 -1
- package/dist/src/talisman/index.js +1 -1
- package/dist/src/trezor/index.js +1 -1
- package/dist/src/walletconnect/index.js +1 -1
- package/package.json +4 -6
- package/src/keystore/helpers.ts +2 -2
- /package/dist/{chunk-czhtd6cy.js → chunk-6ndrbmhg.js} +0 -0
- /package/dist/{chunk-czhtd6cy.js.map → chunk-6ndrbmhg.js.map} +0 -0
- /package/dist/{chunk-qadd75nn.js → chunk-hxt2nqa8.js} +0 -0
- /package/dist/{chunk-qadd75nn.js.map → chunk-hxt2nqa8.js.map} +0 -0
package/dist/src/bitget/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as h}from"../../chunk-
|
|
1
|
+
import{a as h}from"../../chunk-6ndrbmhg.js";import{c as w,d}from"../../chunk-p1kdg37m.js";import{Chain as m,EVMChains as x,WalletOption as v,createWallet as y,filterSupportedChains as E}from"@swapkit/helpers";import{Chain as s,ChainId as u,SwapKitError as l,prepareNetworkSwitch as C,switchEVMWalletNetwork as _}from"@swapkit/helpers";async function g(r){let t=window.bitkeep;switch(r){case s.Ethereum:case s.Base:case s.Avalanche:case s.Arbitrum:case s.Optimism:case s.Polygon:case s.BinanceSmartChain:{if(!(t&&("ethereum"in t)))throw new l("wallet_bitkeep_not_found");let o=t.ethereum,[a]=await o.send("eth_requestAccounts",[]);return{...await P({chain:r,walletProvider:o}),address:a}}case s.Bitcoin:{if(!(t&&("unisat"in t)))throw new l("wallet_bitkeep_not_found");let{unisat:o}=t,{Psbt:a}=await import("bitcoinjs-lib"),{getUtxoToolbox:e}=await import("@swapkit/toolboxes/utxo"),[i]=await o.requestAccounts();async function n(f){let b=await o.signPsbt(f.toHex(),{autoFinalized:!1});return a.fromHex(b)}let c={getAddress:()=>Promise.resolve(i),signTransaction:n};return{...await e(s.Bitcoin,{signer:c}),address:i}}case s.Cosmos:{if(!(t&&("keplr"in t)))throw new l("wallet_bitkeep_not_found");let{keplr:o}=t;await o.enable(u.Cosmos);let a=o.getOfflineSignerOnlyAmino(u.Cosmos),e=await a.getAccounts();if(!e?.[0])throw new Error("No cosmos account found");let{getCosmosToolbox:i}=await import("@swapkit/toolboxes/cosmos"),[{address:n}]=e,c={...a,getAddress:()=>Promise.resolve(n),signTransaction:async()=>Promise.resolve({})};return{...i(s.Cosmos,{signer:c}),address:n}}case s.Solana:{if(!(t&&("solana"in t)))throw new l("wallet_bitkeep_not_found");let{getSolanaToolbox:o}=await import("@swapkit/toolboxes/solana"),a=t?.solana,e=o({signer:a}),n=(await a.connect()).publicKey.toString();return{...e,address:n}}default:throw new l("wallet_chain_not_supported")}}var P=async({chain:r,walletProvider:t})=>{let{getEvmToolbox:o}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:a}=await import("ethers");if(!t)throw new l("wallet_provider_not_found");let e=new a(t,"any"),i=await e.getSigner(),n=await o(r,{provider:e,signer:i});try{if(r!==s.Ethereum&&"getNetworkParams"in n)await _(e,r,n.getNetworkParams())}catch(c){throw new Error(`Failed to add/switch ${r} network: ${r}`)}return C({chain:r,toolbox:n,provider:e})};var S=y({name:"connectBitget",walletType:v.BITGET,supportedChains:[...x,m.Cosmos,m.Bitcoin,m.Solana],connect:({addChain:r,walletType:t,supportedChains:o})=>async function a(e){let i=E({chains:e,supportedChains:o,walletType:t});return await Promise.all(i.map(async(n)=>{let c=await g(n),p=await c.getAddress()||"";r({...c,address:p,chain:n,walletType:t})})),!0}}),M=h(S);export{S as bitgetWallet,M as BITGET_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=40656D10401D604E64756E2164756E21
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as g}from"../../chunk-
|
|
1
|
+
import{a as g}from"../../chunk-6ndrbmhg.js";import{c as p,d as h}from"../../chunk-p1kdg37m.js";import{Chain as a,ChainToChainId as b,SKConfig as P,WalletOption as f,createWallet as v,filterSupportedChains as y}from"@swapkit/helpers";import{Chain as s}from"@swapkit/helpers";async function w(t,r){let{AbstractSigner:i}=await import("ethers");class o extends i{#e;constructor(e,n){super(n);this.#e=e}async getAddress(){let e=await this.#e.request({method:"eth_requestAccounts"});if(!e[0])throw new Error("No Account found");return e[0]}async signTransaction(){return await this.#e.request({method:"eth_signTransaction"})}async signMessage(e){return await this.#e.request({method:"personal_sign",params:[e,await this.getAddress()]})}signTypedData=()=>{throw new Error("this method is not implemented")};connect(e){return new o(this.#e,e)}}return new o(t,r)}var u=async({chain:t,coinbaseSdk:r})=>{switch(t){case s.Ethereum:case s.Avalanche:case s.Arbitrum:case s.Optimism:case s.Polygon:case s.BinanceSmartChain:{let i=r.getProvider(),{getEvmToolbox:o,getProvider:e}=await import("@swapkit/toolboxes/evm"),n=await e(t),c=await w(i,n),d=await o(t,{provider:n,signer:c}),m=await c.getAddress();return{...d,address:m}}default:throw new Error(`No wallet for chain ${t}`)}};var S=v({name:"connectCoinbaseWallet",walletType:f.COINBASE_MOBILE,supportedChains:[a.Arbitrum,a.Avalanche,a.Base,a.BinanceSmartChain,a.Ethereum,a.Optimism,a.Polygon],connect:({addChain:t,walletType:r,supportedChains:i})=>async function o(e){let{createCoinbaseWalletSDK:n}=await import("@coinbase/wallet-sdk"),c=y({chains:e,supportedChains:i,walletType:r}),d=P.get("integrations").coinbase||{appName:"Swapkit Playground"},m=n({...d,appChainIds:c.map((l)=>Number(b[l]))});return await Promise.all(c.map(async(l)=>{let C=await u({chain:l,coinbaseSdk:m});t({...C,chain:l,walletType:r})})),!0}}),T=g(S);export{S as coinbaseWallet,T as COINBASE_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=537C3F16ED1E206364756E2164756E21
|
package/dist/src/ctrl/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as m}from"../../chunk-
|
|
1
|
+
import{a as m}from"../../chunk-6ndrbmhg.js";import{c as R,d as g}from"../../chunk-p1kdg37m.js";import{Chain as w,ChainToChainId as $,SwapKitError as U,WalletOption as k,createWallet as c,filterSupportedChains as q}from"@swapkit/helpers";import{Chain as f,ChainToChainId as J,EVMChains as N,SwapKitError as b,WalletOption as P}from"@swapkit/helpers";import{erc20ABI as Q}from"@swapkit/helpers/contracts";async function S(o){if(!window.xfi)throw new b("wallet_ctrl_not_found");let{match:y}=await import("ts-pattern");return y(o).with(f.Arbitrum,f.Avalanche,f.Base,f.BinanceSmartChain,f.Ethereum,f.Optimism,f.Polygon,()=>window.xfi?.ethereum).with(f.Cosmos,f.Kujira,f.Maya,f.THORChain,()=>window.xfi?.keplr).with(f.Bitcoin,()=>window.xfi?.bitcoin).with(f.BitcoinCash,()=>window.xfi?.bitcoincash).with(f.Dogecoin,()=>window.xfi?.dogecoin).with(f.Litecoin,()=>window.xfi?.litecoin).with(f.Solana,()=>window.xfi?.solana).otherwise(()=>{return})}async function Z({method:o,params:y,chain:t}){let l=await S(t);return new Promise((_,T)=>{if(l&&"request"in l)l.request({method:o,params:y},(n,B)=>{n?T(n):_(B)})})}async function E(o){let y=await S(o);if(!y)throw new b({errorKey:"wallet_provider_not_found",info:{wallet:P.CTRL,chain:o}});if([f.Cosmos,f.Kujira].includes(o)){let t=await S(f.Cosmos);if(!t||"request"in t)throw new b({errorKey:"wallet_provider_not_found",info:{wallet:P.CTRL,chain:o}});let l=J[o];await t.enable(l);let _=t.getOfflineSigner(l),[T]=await _.getAccounts();return T?.address}if(N.includes(o)){let[t]=await y.request({method:"eth_requestAccounts",params:[]});return t}if(o===f.Solana)return(await(await S(f.Solana)).connect()).publicKey.toString();return new Promise((t,l)=>y.request({method:"request_accounts",params:[]},(_,[T])=>_?l(_):t(T)))}async function D({assetValue:o,recipient:y,memo:t,gasLimit:l},_="transfer"){if(!o)throw new b("wallet_ctrl_asset_not_defined");let T=await E(o.chain),n=[{amount:{amount:o.getBaseValue("number"),decimals:o.decimal},asset:{chain:o.chain,symbol:o.symbol.toUpperCase(),ticker:o.symbol.toUpperCase()},memo:t||"",from:T,recipient:y,gasLimit:l}];return Z({method:_,params:n,chain:o.chain})}function Y(o,y){return{call:async({contractAddress:t,abi:l,funcName:_,funcParams:T=[],txOverrides:n})=>{if(!t)throw new b("wallet_ctrl_contract_address_not_provided");let{createContract:B,getCreateContractTxObject:L,isStateChangingCall:M,toHexString:G}=await import("@swapkit/toolboxes/evm");if(M({abi:l,funcName:_})){let x=L({provider:o,chain:y}),{value:H,from:z,to:A,data:F}=await x({contractAddress:t,abi:l,funcName:_,funcParams:T,txOverrides:n});return o.send("eth_sendTransaction",[{value:G(BigInt(H||0)),from:z,to:A,data:F||"0x"}])}let W=await B(t,l,o)[_]?.(...T);return typeof W?.hash==="string"?W?.hash:W},approve:async({assetAddress:t,spenderAddress:l,amount:_,from:T})=>{let{MAX_APPROVAL:n,getCreateContractTxObject:B,toHexString:L}=await import("@swapkit/toolboxes/evm"),M=[l,BigInt(_||n)],O={contractAddress:t,abi:Q,funcName:"approve",funcParams:M,txOverrides:{from:T}},I=B({provider:o,chain:y}),{value:W,to:x,data:H}=await I(O);return o.send("eth_sendTransaction",[{value:L(BigInt(W||0)),from:T,to:x,data:H||"0x"}])},sendTransaction:async(t)=>{let{from:l,to:_,data:T,value:n}=t;if(!_)throw new b("wallet_ctrl_send_transaction_no_address");let{toHexString:B}=await import("@swapkit/toolboxes/evm");return o.send("eth_sendTransaction",[{value:B(BigInt(n||0)),from:l,to:_,data:T||"0x"}])}}}var K=c({name:"connectCtrl",walletType:k.CTRL,supportedChains:[w.Arbitrum,w.Avalanche,w.Base,w.BinanceSmartChain,w.Bitcoin,w.BitcoinCash,w.Cosmos,w.Dogecoin,w.Ethereum,w.Kujira,w.Litecoin,w.Maya,w.Optimism,w.Polygon,w.Solana,w.THORChain],connect:({addChain:o,walletType:y,supportedChains:t})=>async function l(_){let n=q({chains:_,supportedChains:t,walletType:y}).map(async(B)=>{let L=await E(B),M=await X(B);o({...M,address:L,chain:B,walletType:y})});return await Promise.all(n),!0}}),i=m(K);async function X(o){switch(o){case w.Solana:{let{getSolanaToolbox:y}=await import("@swapkit/toolboxes/solana"),t=window.xfi?.solana;if(!t)throw new U("wallet_ctrl_not_found");return{...y({signer:t})}}case w.Maya:case w.THORChain:{let{getCosmosToolbox:y,THORCHAIN_GAS_VALUE:t,MAYA_GAS_VALUE:l}=await import("@swapkit/toolboxes/cosmos"),_=o===w.Maya?l:t;return{...await y(o),deposit:(n)=>D({...n,recipient:""},"deposit"),transfer:(n)=>D({...n,gasLimit:_},"transfer")}}case w.Cosmos:case w.Kujira:{let{getCosmosToolbox:y}=await import("@swapkit/toolboxes/cosmos"),t=$[o],l=await S(o);await l?.enable(t);let _=l?.getOfflineSignerOnlyAmino(t);if(!_)throw new U("wallet_ctrl_not_found");return y(o,{signer:_})}case w.Bitcoin:case w.BitcoinCash:case w.Dogecoin:case w.Litecoin:{let{getUtxoToolbox:y}=await import("@swapkit/toolboxes/utxo");return{...await y(o),transfer:D}}case w.Arbitrum:case w.Avalanche:case w.Base:case w.BinanceSmartChain:case w.Ethereum:case w.Optimism:case w.Polygon:{let{prepareNetworkSwitch:y,switchEVMWalletNetwork:t}=await import("@swapkit/helpers"),{getEvmToolbox:l}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:_}=await import("ethers"),T=await S(o);if(!T)throw new U("wallet_ctrl_not_found");let n=new _(T,"any"),B=await n.getSigner(),L=await l(o,{provider:n,signer:B}),M=Y(n,o);try{if(o!==w.Ethereum){let G=L.getNetworkParams();await t(n,o,G)}}catch(G){throw new U({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:k.CTRL,chain:o}})}return y({provider:window.xfi?.ethereum,chain:o,toolbox:{...L,...M}})}default:return null}}export{K as ctrlWallet,i as CTRL_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=A42F7E7517D14D9064756E2164756E21
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as M}from"../../chunk-
|
|
1
|
+
import{a as M}from"../../chunk-6ndrbmhg.js";import{c as u,d as O}from"../../chunk-p1kdg37m.js";import{Chain as A,ChainToHexChainId as m,EVMChains as B,WalletOption as l,createWallet as C,filterSupportedChains as P,prepareNetworkSwitch as f,switchEVMWalletNetwork as N}from"@swapkit/helpers";var W=(n)=>{switch(n){case l.COINBASE_WEB:return window.coinbaseWalletExtension;case l.TRUSTWALLET_WEB:return window.trustwallet;default:return window.ethereum}},g=async({address:n,walletProvider:w,chain:t,provider:r})=>{if(!w)throw new Error("Requested web3 wallet is not installed");let{getEvmToolbox:e}=await import("@swapkit/toolboxes/evm"),a=await r.getSigner(),i=await e(t,{provider:r,signer:a});if(t!==A.Ethereum){if((await r.getNetwork()).chainId.toString()!==m[t])try{let o=i.getNetworkParams();await N(r,t,o)}catch(o){throw new Error(`Failed to add/switch ${t} network: ${t}`)}}return f({toolbox:{...i,getBalance:()=>i.getBalance(n)},chain:t,provider:r})},T=C({name:"connectEVMWallet",supportedChains:[...B],connect:({addChain:n,supportedChains:w})=>async function t(r,e=l.METAMASK,a){let i=P({chains:r,supportedChains:w,walletType:e}),{BrowserProvider:c}=await import("ethers");return await Promise.all(i.map(async(o)=>{if(e===l.EIP6963){if(!a)throw new Error("Missing provider");let E=new c(a,"any");await E.send("eth_requestAccounts",[]);let p=await(await E.getSigner()).getAddress(),S=await g({address:p,chain:o,provider:E,walletProvider:a});n({...S,address:p,chain:o,walletType:e});return}let s=new c(W(e),"any");await s.send("eth_requestAccounts",[]);let d=await(await s.getSigner()).getAddress(),h=await g({address:d,chain:o,walletProvider:W(e),provider:s});n({...h,address:d,chain:o,disconnect:()=>s.send("wallet_revokePermissions",[{eth_accounts:{}}]),walletType:e})})),!0}}),x=M(T);export{g as getWeb3WalletMethods,T as evmWallet,x as EVM_EXTENSIONS_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=7A8B333E21590AB164756E2164756E21
|
package/dist/src/exodus/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as V}from"../../chunk-
|
|
1
|
+
import{a as V}from"../../chunk-6ndrbmhg.js";import{c as $,d as D}from"../../chunk-p1kdg37m.js";import{Chain as z,EVMChains as A,SwapKitError as B,WalletOption as f,createWallet as E,filterSupportedChains as M,prepareNetworkSwitch as N,switchEVMWalletNetwork as S}from"@swapkit/helpers";import{AddressPurpose as O,BitcoinNetworkType as j,getAddress as y,signTransaction as W}from"sats-connect";export*from"@passkeys/react";export*from"@passkeys/core";async function u({walletProvider:K,provider:Z,chain:q}){switch(q){case z.Bitcoin:{let{Psbt:_}=await import("bitcoinjs-lib"),{getUtxoToolbox:X}=await import("@swapkit/toolboxes/utxo"),F="",G=()=>new Promise((H)=>H(Z)),L={getProvider:G,payload:{purposes:[O.Payment],message:"Address for receiving and sending payments",network:{type:j.Mainnet}},onFinish:(H)=>{if(!H.addresses[0])throw new Error("No address found");F=H.addresses[0].address},onCancel:()=>{throw new Error("Request canceled")}};await y(L);async function I(H){let Y,R={getProvider:G,payload:{message:"Sign transaction",network:{type:j.Mainnet},psbtBase64:H.toBase64(),broadcast:!1,inputsToSign:[{address:F,signingIndexes:H.txInputs.map((U,m)=>m)}]},onFinish:(U)=>{Y=_.fromBase64(U.psbtBase64)},onCancel:()=>{throw new Error("Signature canceled")}};if(await W(R),!Y)throw new B("wallet_exodus_sign_transaction_error");return Y}return{...await X(q,{signer:{signTransaction:I,getAddress:()=>Promise.resolve(F)}}),address:F}}case z.Arbitrum:case z.Avalanche:case z.Base:case z.BinanceSmartChain:case z.Ethereum:case z.Optimism:case z.Polygon:{if(!K)throw new Error("Requested web3 wallet is not installed");let{getProvider:_,getEvmToolbox:X}=await import("@swapkit/toolboxes/evm"),F=await _(q),G=Z;await G.send("eth_requestAccounts",[]);let L=await G.getSigner(),I=await L.getAddress(),J=await X(q,{provider:F,signer:L});try{if(q!==z.Ethereum){let Q=J.getNetworkParams();await S(G,q,Q)}}catch(Q){throw new Error(`Failed to add/switch ${q} network: ${q}`)}return{...N({toolbox:J,chain:q,provider:G}),address:I}}default:throw new Error(`Unsupported chain: ${q}`)}}var k=E({name:"connectExodusWallet",walletType:f.EXODUS,supportedChains:[...A,z.Bitcoin],connect:({addChain:K,walletType:Z,supportedChains:q})=>async function _(X,F){if(!F)throw new Error("Missing Exodus Wallet instance");let G=M({chains:X,supportedChains:q,walletType:Z}),{BrowserProvider:L}=await import("ethers"),{providers:I}=F;return await Promise.all(G.map(async(J)=>{let Q=J===z.Bitcoin?I.bitcoin:new L(I.ethereum,"any"),{address:H,...Y}=await u({chain:J,provider:Q,walletProvider:I.ethereum});K({...Y,disconnect:()=>Q.send("wallet_revokePermissions",[{eth_accounts:{}}]),chain:J,address:H,walletType:f.EXODUS})})),!0}}),P=V(k);export{k as exodusWallet,P as EXODUS_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=5DC2E5570624007664756E2164756E21
|
package/dist/src/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as l,b as n}from"../chunk-
|
|
1
|
+
import{a as l,b as n}from"../chunk-6ndrbmhg.js";import"../chunk-p1kdg37m.js";export{n as loadWallet,l as getWalletSupportedChains};
|
|
2
2
|
|
|
3
3
|
//# debugId=83059F908E6CD5F764756E2164756E21
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as o}from"../../chunk-czhtd6cy.js";import{c as w,d as F}from"../../chunk-p1kdg37m.js";import{Chain as X,NetworkDerivationPath as Wz,SKConfig as h,WalletOption as d,createWallet as Gz,filterSupportedChains as Lz}from"@swapkit/helpers";import{KeepKeySdk as _z}from"@keepkey/keepkey-sdk";import{Chain as P,ChainId as u,DerivationPath as t,SKConfig as i,derivationPathToString as a}from"@swapkit/helpers";var y;((Y)=>{Y.BTC="Bitcoin";Y.BCH="BitcoinCash";Y.DOGE="Dogecoin";Y.LTC="Litecoin";Y.DASH="Dash"})(y||={});function s(z){if(z==="m/")return!0;return/^m(((\/[0-9]+h)+|(\/[0-9]+H)+|(\/[0-9]+')*)((\/[0-9]+)*))$/.test(z)}function V(z){let J=z;if(!s(J))throw new Error(`Not a bip32 path: '${J}'`);if(/^m\//i.test(J))J=J.slice(2);let Q=J.split("/");if(Q.length===1&&Q[0]==="")return[];let R=new Array(Q.length);for(let Z=0;Z<Q.length;Z++){let Y=Q[Z];if(Y){let q=/(\d+)([hH']?)/.exec(Y);if(q===null)throw new Error("Invalid input");let[,$="",j=""]=q;if(R[Z]=Number.parseInt($,10),R[Z]>=2147483648)throw new Error("Invalid child index");if(j==="h"||j==="H"||j==="'")R[Z]+=2147483648;else if(j.length>0)throw new Error("Invalid modifier")}}return R}var C=async({sdk:z,derivationPath:J})=>{let{DEFAULT_COSMOS_FEE_MAINNET:Q,getCosmosToolbox:R,getFeeRateFromThorswap:Z,createStargateClient:Y}=await import("@swapkit/toolboxes/cosmos");try{let q=J?a(J):`${t.GAIA}/0`,{address:$}=await z.address.cosmosGetAddress({address_n:V(q)}),j=await R(P.Cosmos);if(Q.amount[0])Q.amount[0].amount=String(await Z(u.Cosmos,500));return{...j,transfer:async({assetValue:B,recipient:W,memo:L})=>{let _=B.getBaseValue("string"),U=await j.getAccount($),H=await z.cosmos.cosmosSignAmino({signerAddress:$,signDoc:{fee:Q,memo:L||"",sequence:U?.sequence.toString()??"",chain_id:u.Cosmos,account_number:U?.accountNumber.toString()??"",msgs:[{value:{amount:[{denom:"uatom",amount:_}],to_address:W,from_address:$},type:"cosmos-sdk/MsgSend"}]}}),M=atob(H.serialized),I=new Uint8Array(M.length).map((N,E)=>M.charCodeAt(E));return(await(await Y(i.get("rpcUrls")[P.Cosmos])).broadcastTx(I)).transactionHash},address:$}}catch(q){throw console.error(q),q}};import{ChainToChainId as e,NetworkDerivationPath as zz,derivationPathToString as Jz}from"@swapkit/helpers";import{AbstractSigner as Qz}from"ethers";class S extends Qz{sdk;chain;derivationPath;address;provider;constructor({sdk:z,chain:J,derivationPath:Q,provider:R}){super();this.sdk=z,this.chain=J,this.derivationPath=Q||zz.ETH,this.address="",this.provider=R}signTypedData(){throw new Error("this method is not implemented")}getAddress=async()=>{if(this.address)return this.address;let{address:z}=await this.sdk.address.ethereumGetAddress({address_n:V(Jz(this.derivationPath))});return this.address=z,z};signMessage=(z)=>this.sdk.eth.ethSign({address:this.address,message:z});signTransaction=async({to:z,value:J,gasLimit:Q,nonce:R,data:Z,maxFeePerGas:Y,maxPriorityFeePerGas:q,gasPrice:$})=>{if(!z)throw new Error("Missing to address");if(!Q)throw new Error("Missing gasLimit");if(!Z)throw new Error("Missing data");let j=!!((Y||q)&&!$);if(j&&!Y)throw new Error("Missing maxFeePerGas");if(j&&!q)throw new Error("Missing maxFeePerGas");if(!(j||$))throw new Error("Missing gasPrice");let{toHexString:G}=await import("@swapkit/toolboxes/evm"),B=R?BigInt(R):BigInt(await this.provider.getTransactionCount(await this.getAddress(),"pending")),W={gas:G(BigInt(Q)),addressNList:[2147483692,2147483708,2147483648,0,0],from:this.address,chainId:G(BigInt(e[this.chain])),to:z.toString(),value:G(BigInt(J||0)),nonce:G(B),data:Z,...j&&{maxFeePerGas:G(BigInt(Y?.toString()||"0")),maxPriorityFeePerGas:G(BigInt(q?.toString()||"0"))},...!j&&{gasPrice:G(BigInt($?.toString()||"0"))}};return(await this.sdk.eth.ethSignTransaction(W)).serialized};sendTransaction=async(z)=>{if(!this.provider)throw new Error("No provider set");let J=await this.signTransaction(z);return await this.provider.broadcastTransaction(J)};connect=(z)=>new S({sdk:this.sdk,chain:this.chain,derivationPath:this.derivationPath,provider:z})}import{Chain as k,ChainId as Xz,DerivationPath as Yz,SKConfig as g,derivationPathToString as Zz}from"@swapkit/helpers";var l=async({sdk:z,derivationPath:J})=>{let{createStargateClient:Q,getCosmosToolbox:R}=await import("@swapkit/toolboxes/cosmos"),Z=await R(k.Maya),Y=J?Zz(J):`${Yz.MAYA}/0`,{address:q}=await z.address.mayachainGetAddress({address_n:V(Y)}),$=async({assetValue:B,recipient:W,sender:L,memo:_})=>{let{makeSignDoc:U}=await import("@cosmjs/amino"),{getDenomWithChain:H}=await import("@swapkit/toolboxes/cosmos"),M=await Z.getAccount(L);if(!M)throw new Error("Account not found");let{accountNumber:I,sequence:D=0}=M,O=B.getBaseValue("string"),N=W&&W!=="",E=N?{type:"mayachain/MsgSend",value:{amount:[{amount:O,denom:B.symbol.toLowerCase()}],from_address:L,to_address:W}}:{type:"mayachain/MsgDeposit",value:{coins:[{amount:O,asset:H(B)}],memo:_,signer:L}},A=U([E],{gas:"500000000",amount:[]},Xz.Maya,_,I?.toString(),D),K=await(N?z.mayachain.mayachainSignAminoTransfer:z.mayachain.mayachainSignAminoDeposit)({signDoc:A,signerAddress:L}),f=atob(K.serialized);return new Uint8Array(f.length).map((n,v)=>f.charCodeAt(v))};return{...Z,transfer:async({assetValue:B,recipient:W,memo:L})=>{let _=await Q(g.get("rpcUrls")[k.Maya]),U=await $({assetValue:B,recipient:W,memo:L,sender:q}),{transactionHash:H}=await _.broadcastTx(U);return H},deposit:async({assetValue:B,memo:W})=>{let L=await Q(g.get("rpcUrls")[k.Maya]),_=await $({assetValue:B,memo:W,sender:q}),{transactionHash:U}=await L.broadcastTx(_);return U},address:q}};import{Chain as T,ChainId as $z,DerivationPath as qz,SKConfig as p,derivationPathToString as jz}from"@swapkit/helpers";var m=async({sdk:z,derivationPath:J})=>{let{makeSignDoc:Q}=await import("@cosmjs/amino"),{buildAminoMsg:R,getDefaultChainFee:Z,createStargateClient:Y,getCosmosToolbox:q}=await import("@swapkit/toolboxes/cosmos"),$=await q(T.THORChain),j=J?jz(J):`${qz.THOR}/0`,{address:G}=await z.address.thorchainGetAddress({address_n:V(j)}),B=async({assetValue:_,recipient:U,sender:H,memo:M})=>{let I=await $.getAccount(H);if(!I)throw new Error("Account not found");let{accountNumber:D,sequence:O=0}=I,N=U&&U!=="",E=R({sender:H,recipient:U,assetValue:_,memo:M}),A=$z.THORChain,b=Q([E],Z(T.THORChain),A,M,D?.toString(),O),K=N?await z.thorchain.thorchainSignAminoTransfer({signDoc:b,signerAddress:H}):await z.thorchain.thorchainSignAminoDeposit({signDoc:b,signerAddress:H}),f=atob(K.serialized);return new Uint8Array(f.length).map((n,v)=>f.charCodeAt(v))};return{...$,transfer:async({assetValue:_,recipient:U,memo:H})=>{let M=await Y(p.get("rpcUrls")[T.THORChain]),I=await B({assetValue:_,recipient:U,memo:H,sender:G}),{transactionHash:D}=await M.broadcastTx(I);return D},deposit:async({assetValue:_,memo:U})=>{let H=await Y(p.get("rpcUrls")[T.THORChain]),M=await B({assetValue:_,memo:U,sender:G}),{transactionHash:I}=await H.broadcastTx(M);return I},address:G}};import{Chain as x,DerivationPath as Uz,FeeOption as Rz,derivationPathToString as Bz}from"@swapkit/helpers";var c=async({sdk:z,chain:J,derivationPath:Q})=>{let{getUtxoToolbox:R}=await import("@swapkit/toolboxes/utxo"),Z=await R(J),Y=[x.Bitcoin,x.Litecoin].includes(J)?"p2wpkh":"p2pkh",q=Q?Bz(Q):`${Uz[J]}/0`,$={coin:y[J],script_type:Y,address_n:V(q)},j=(await z.address.utxoGetAddress($)).address,G=async(W,L,_="")=>{let U=W.txOutputs.map((I)=>{let{value:D,address:O,change:N}=I,E=J===x.BitcoinCash?Z.stripToCashAddress(O):O;if(N||O===j)return{addressNList:$.address_n,isChange:!0,addressType:"change",amount:D,scriptType:Y};if(E)return{address:E,amount:D,addressType:"spend"};return null}).filter(Boolean),H=(I)=>{return I.filter((D)=>D!==null&&typeof D==="object"&&Object.keys(D).length>0)};return(await z.utxo.utxoSignTransaction({coin:y[J],inputs:L,outputs:H(U),opReturnData:_})).serializedTx?.toString()};return{...Z,signTransaction:G,transfer:async({recipient:W,feeOptionKey:L,feeRate:_,memo:U,...H})=>{if(!j)throw new Error("From address must be provided");if(!W)throw new Error("Recipient address must be provided");let M=J===x.BitcoinCash?Z.buildTx:Z.createTransaction,{psbt:I,inputs:D}=await M({...H,memo:U,recipient:W,feeRate:_||(await Z.getFeeRates())[L||Rz.Fast],sender:j,fetchTxHex:!0}),O=D.map(({value:E,index:A,hash:b,txHex:K})=>({addressNList:$.address_n,amount:E.toString(),hex:K||"",scriptType:Y,txid:b,vout:A})),N=await G(I,O,U);return Z.broadcastTx(N)},address:j}};var Hz=Gz({name:"connectKeepkey",supportedChains:[X.Arbitrum,X.Avalanche,X.Base,X.BinanceSmartChain,X.Bitcoin,X.BitcoinCash,X.Cosmos,X.Dogecoin,X.Dash,X.Ethereum,X.Litecoin,X.Optimism,X.Polygon,X.THORChain,X.Maya],walletType:d.KEEPKEY,connect:({addChain:z,supportedChains:J,walletType:Q})=>async function R(Z,Y){let q=Lz({chains:Z,supportedChains:J,walletType:Q}),$=h.get("integrations").keepKey;if(!$)throw new Error("KeepKey config not found");await r();let j={...$,apiKey:h.get("apiKeys").keepKey},G=await _z.create(j);return await Promise.all(q.map(async(B)=>{let W=await Iz({chain:B,derivationPath:Y?.[B]||Wz[B],sdk:G}),L=await W.getAddress()||"";z({...W,address:L,chain:B,walletType:d.KEEPKEY})})),!0}}),hz=o(Hz);async function Iz({sdk:z,chain:J,derivationPath:Q}){let{getProvider:R,getEvmToolbox:Z}=await import("@swapkit/toolboxes/evm");switch(J){case X.BinanceSmartChain:case X.Arbitrum:case X.Optimism:case X.Polygon:case X.Avalanche:case X.Ethereum:{let Y=await R(J),q=new S({sdk:z,chain:J,derivationPath:Q,provider:Y});return await Z(J,{provider:Y,signer:q})}case X.Cosmos:return C({sdk:z,derivationPath:Q});case X.THORChain:return m({sdk:z,derivationPath:Q});case X.Maya:return l({sdk:z,derivationPath:Q});case X.Bitcoin:case X.BitcoinCash:case X.Dash:case X.Dogecoin:case X.Litecoin:return c({sdk:z,chain:J,derivationPath:Q});default:throw new Error(`Chain not supported ${J}`)}}async function r(z=0){if(z>=3)alert("KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started");if(!await Mz())window.location.assign("keepkey://launch"),await new Promise((Q)=>setTimeout(Q,30000)),r(z+1)}async function Mz(z="http://localhost:1646/spec/swagger.json"){try{return(await fetch(z)).status===200}catch(J){return console.error(J),!1}}export{Hz as keepkeyWallet,hz as KEEPKEY_SUPPORTED_CHAINS};
|
|
1
|
+
import{a as o}from"../../chunk-6ndrbmhg.js";import{c as w,d as F}from"../../chunk-p1kdg37m.js";import{Chain as X,NetworkDerivationPath as Wz,SKConfig as h,WalletOption as d,createWallet as Gz,filterSupportedChains as Lz}from"@swapkit/helpers";import{KeepKeySdk as _z}from"@keepkey/keepkey-sdk";import{Chain as P,ChainId as u,DerivationPath as t,SKConfig as i,derivationPathToString as a}from"@swapkit/helpers";var y;((Y)=>{Y.BTC="Bitcoin";Y.BCH="BitcoinCash";Y.DOGE="Dogecoin";Y.LTC="Litecoin";Y.DASH="Dash"})(y||={});function s(z){if(z==="m/")return!0;return/^m(((\/[0-9]+h)+|(\/[0-9]+H)+|(\/[0-9]+')*)((\/[0-9]+)*))$/.test(z)}function V(z){let J=z;if(!s(J))throw new Error(`Not a bip32 path: '${J}'`);if(/^m\//i.test(J))J=J.slice(2);let Q=J.split("/");if(Q.length===1&&Q[0]==="")return[];let R=new Array(Q.length);for(let Z=0;Z<Q.length;Z++){let Y=Q[Z];if(Y){let q=/(\d+)([hH']?)/.exec(Y);if(q===null)throw new Error("Invalid input");let[,$="",j=""]=q;if(R[Z]=Number.parseInt($,10),R[Z]>=2147483648)throw new Error("Invalid child index");if(j==="h"||j==="H"||j==="'")R[Z]+=2147483648;else if(j.length>0)throw new Error("Invalid modifier")}}return R}var C=async({sdk:z,derivationPath:J})=>{let{DEFAULT_COSMOS_FEE_MAINNET:Q,getCosmosToolbox:R,getFeeRateFromThorswap:Z,createStargateClient:Y}=await import("@swapkit/toolboxes/cosmos");try{let q=J?a(J):`${t.GAIA}/0`,{address:$}=await z.address.cosmosGetAddress({address_n:V(q)}),j=await R(P.Cosmos);if(Q.amount[0])Q.amount[0].amount=String(await Z(u.Cosmos,500));return{...j,transfer:async({assetValue:B,recipient:W,memo:L})=>{let _=B.getBaseValue("string"),U=await j.getAccount($),H=await z.cosmos.cosmosSignAmino({signerAddress:$,signDoc:{fee:Q,memo:L||"",sequence:U?.sequence.toString()??"",chain_id:u.Cosmos,account_number:U?.accountNumber.toString()??"",msgs:[{value:{amount:[{denom:"uatom",amount:_}],to_address:W,from_address:$},type:"cosmos-sdk/MsgSend"}]}}),M=atob(H.serialized),I=new Uint8Array(M.length).map((N,E)=>M.charCodeAt(E));return(await(await Y(i.get("rpcUrls")[P.Cosmos])).broadcastTx(I)).transactionHash},address:$}}catch(q){throw console.error(q),q}};import{ChainToChainId as e,NetworkDerivationPath as zz,derivationPathToString as Jz}from"@swapkit/helpers";import{AbstractSigner as Qz}from"ethers";class S extends Qz{sdk;chain;derivationPath;address;provider;constructor({sdk:z,chain:J,derivationPath:Q,provider:R}){super();this.sdk=z,this.chain=J,this.derivationPath=Q||zz.ETH,this.address="",this.provider=R}signTypedData(){throw new Error("this method is not implemented")}getAddress=async()=>{if(this.address)return this.address;let{address:z}=await this.sdk.address.ethereumGetAddress({address_n:V(Jz(this.derivationPath))});return this.address=z,z};signMessage=(z)=>this.sdk.eth.ethSign({address:this.address,message:z});signTransaction=async({to:z,value:J,gasLimit:Q,nonce:R,data:Z,maxFeePerGas:Y,maxPriorityFeePerGas:q,gasPrice:$})=>{if(!z)throw new Error("Missing to address");if(!Q)throw new Error("Missing gasLimit");if(!Z)throw new Error("Missing data");let j=!!((Y||q)&&!$);if(j&&!Y)throw new Error("Missing maxFeePerGas");if(j&&!q)throw new Error("Missing maxFeePerGas");if(!(j||$))throw new Error("Missing gasPrice");let{toHexString:G}=await import("@swapkit/toolboxes/evm"),B=R?BigInt(R):BigInt(await this.provider.getTransactionCount(await this.getAddress(),"pending")),W={gas:G(BigInt(Q)),addressNList:[2147483692,2147483708,2147483648,0,0],from:this.address,chainId:G(BigInt(e[this.chain])),to:z.toString(),value:G(BigInt(J||0)),nonce:G(B),data:Z,...j&&{maxFeePerGas:G(BigInt(Y?.toString()||"0")),maxPriorityFeePerGas:G(BigInt(q?.toString()||"0"))},...!j&&{gasPrice:G(BigInt($?.toString()||"0"))}};return(await this.sdk.eth.ethSignTransaction(W)).serialized};sendTransaction=async(z)=>{if(!this.provider)throw new Error("No provider set");let J=await this.signTransaction(z);return await this.provider.broadcastTransaction(J)};connect=(z)=>new S({sdk:this.sdk,chain:this.chain,derivationPath:this.derivationPath,provider:z})}import{Chain as k,ChainId as Xz,DerivationPath as Yz,SKConfig as g,derivationPathToString as Zz}from"@swapkit/helpers";var l=async({sdk:z,derivationPath:J})=>{let{createStargateClient:Q,getCosmosToolbox:R}=await import("@swapkit/toolboxes/cosmos"),Z=await R(k.Maya),Y=J?Zz(J):`${Yz.MAYA}/0`,{address:q}=await z.address.mayachainGetAddress({address_n:V(Y)}),$=async({assetValue:B,recipient:W,sender:L,memo:_})=>{let{makeSignDoc:U}=await import("@cosmjs/amino"),{getDenomWithChain:H}=await import("@swapkit/toolboxes/cosmos"),M=await Z.getAccount(L);if(!M)throw new Error("Account not found");let{accountNumber:I,sequence:D=0}=M,O=B.getBaseValue("string"),N=W&&W!=="",E=N?{type:"mayachain/MsgSend",value:{amount:[{amount:O,denom:B.symbol.toLowerCase()}],from_address:L,to_address:W}}:{type:"mayachain/MsgDeposit",value:{coins:[{amount:O,asset:H(B)}],memo:_,signer:L}},A=U([E],{gas:"500000000",amount:[]},Xz.Maya,_,I?.toString(),D),K=await(N?z.mayachain.mayachainSignAminoTransfer:z.mayachain.mayachainSignAminoDeposit)({signDoc:A,signerAddress:L}),f=atob(K.serialized);return new Uint8Array(f.length).map((n,v)=>f.charCodeAt(v))};return{...Z,transfer:async({assetValue:B,recipient:W,memo:L})=>{let _=await Q(g.get("rpcUrls")[k.Maya]),U=await $({assetValue:B,recipient:W,memo:L,sender:q}),{transactionHash:H}=await _.broadcastTx(U);return H},deposit:async({assetValue:B,memo:W})=>{let L=await Q(g.get("rpcUrls")[k.Maya]),_=await $({assetValue:B,memo:W,sender:q}),{transactionHash:U}=await L.broadcastTx(_);return U},address:q}};import{Chain as T,ChainId as $z,DerivationPath as qz,SKConfig as p,derivationPathToString as jz}from"@swapkit/helpers";var m=async({sdk:z,derivationPath:J})=>{let{makeSignDoc:Q}=await import("@cosmjs/amino"),{buildAminoMsg:R,getDefaultChainFee:Z,createStargateClient:Y,getCosmosToolbox:q}=await import("@swapkit/toolboxes/cosmos"),$=await q(T.THORChain),j=J?jz(J):`${qz.THOR}/0`,{address:G}=await z.address.thorchainGetAddress({address_n:V(j)}),B=async({assetValue:_,recipient:U,sender:H,memo:M})=>{let I=await $.getAccount(H);if(!I)throw new Error("Account not found");let{accountNumber:D,sequence:O=0}=I,N=U&&U!=="",E=R({sender:H,recipient:U,assetValue:_,memo:M}),A=$z.THORChain,b=Q([E],Z(T.THORChain),A,M,D?.toString(),O),K=N?await z.thorchain.thorchainSignAminoTransfer({signDoc:b,signerAddress:H}):await z.thorchain.thorchainSignAminoDeposit({signDoc:b,signerAddress:H}),f=atob(K.serialized);return new Uint8Array(f.length).map((n,v)=>f.charCodeAt(v))};return{...$,transfer:async({assetValue:_,recipient:U,memo:H})=>{let M=await Y(p.get("rpcUrls")[T.THORChain]),I=await B({assetValue:_,recipient:U,memo:H,sender:G}),{transactionHash:D}=await M.broadcastTx(I);return D},deposit:async({assetValue:_,memo:U})=>{let H=await Y(p.get("rpcUrls")[T.THORChain]),M=await B({assetValue:_,memo:U,sender:G}),{transactionHash:I}=await H.broadcastTx(M);return I},address:G}};import{Chain as x,DerivationPath as Uz,FeeOption as Rz,derivationPathToString as Bz}from"@swapkit/helpers";var c=async({sdk:z,chain:J,derivationPath:Q})=>{let{getUtxoToolbox:R}=await import("@swapkit/toolboxes/utxo"),Z=await R(J),Y=[x.Bitcoin,x.Litecoin].includes(J)?"p2wpkh":"p2pkh",q=Q?Bz(Q):`${Uz[J]}/0`,$={coin:y[J],script_type:Y,address_n:V(q)},j=(await z.address.utxoGetAddress($)).address,G=async(W,L,_="")=>{let U=W.txOutputs.map((I)=>{let{value:D,address:O,change:N}=I,E=J===x.BitcoinCash?Z.stripToCashAddress(O):O;if(N||O===j)return{addressNList:$.address_n,isChange:!0,addressType:"change",amount:D,scriptType:Y};if(E)return{address:E,amount:D,addressType:"spend"};return null}).filter(Boolean),H=(I)=>{return I.filter((D)=>D!==null&&typeof D==="object"&&Object.keys(D).length>0)};return(await z.utxo.utxoSignTransaction({coin:y[J],inputs:L,outputs:H(U),opReturnData:_})).serializedTx?.toString()};return{...Z,signTransaction:G,transfer:async({recipient:W,feeOptionKey:L,feeRate:_,memo:U,...H})=>{if(!j)throw new Error("From address must be provided");if(!W)throw new Error("Recipient address must be provided");let M=J===x.BitcoinCash?Z.buildTx:Z.createTransaction,{psbt:I,inputs:D}=await M({...H,memo:U,recipient:W,feeRate:_||(await Z.getFeeRates())[L||Rz.Fast],sender:j,fetchTxHex:!0}),O=D.map(({value:E,index:A,hash:b,txHex:K})=>({addressNList:$.address_n,amount:E.toString(),hex:K||"",scriptType:Y,txid:b,vout:A})),N=await G(I,O,U);return Z.broadcastTx(N)},address:j}};var Hz=Gz({name:"connectKeepkey",supportedChains:[X.Arbitrum,X.Avalanche,X.Base,X.BinanceSmartChain,X.Bitcoin,X.BitcoinCash,X.Cosmos,X.Dogecoin,X.Dash,X.Ethereum,X.Litecoin,X.Optimism,X.Polygon,X.THORChain,X.Maya],walletType:d.KEEPKEY,connect:({addChain:z,supportedChains:J,walletType:Q})=>async function R(Z,Y){let q=Lz({chains:Z,supportedChains:J,walletType:Q}),$=h.get("integrations").keepKey;if(!$)throw new Error("KeepKey config not found");await r();let j={...$,apiKey:h.get("apiKeys").keepKey},G=await _z.create(j);return await Promise.all(q.map(async(B)=>{let W=await Iz({chain:B,derivationPath:Y?.[B]||Wz[B],sdk:G}),L=await W.getAddress()||"";z({...W,address:L,chain:B,walletType:d.KEEPKEY})})),!0}}),hz=o(Hz);async function Iz({sdk:z,chain:J,derivationPath:Q}){let{getProvider:R,getEvmToolbox:Z}=await import("@swapkit/toolboxes/evm");switch(J){case X.BinanceSmartChain:case X.Arbitrum:case X.Optimism:case X.Polygon:case X.Avalanche:case X.Ethereum:{let Y=await R(J),q=new S({sdk:z,chain:J,derivationPath:Q,provider:Y});return await Z(J,{provider:Y,signer:q})}case X.Cosmos:return C({sdk:z,derivationPath:Q});case X.THORChain:return m({sdk:z,derivationPath:Q});case X.Maya:return l({sdk:z,derivationPath:Q});case X.Bitcoin:case X.BitcoinCash:case X.Dash:case X.Dogecoin:case X.Litecoin:return c({sdk:z,chain:J,derivationPath:Q});default:throw new Error(`Chain not supported ${J}`)}}async function r(z=0){if(z>=3)alert("KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started");if(!await Mz())window.location.assign("keepkey://launch"),await new Promise((Q)=>setTimeout(Q,30000)),r(z+1)}async function Mz(z="http://localhost:1646/spec/swagger.json"){try{return(await fetch(z)).status===200}catch(J){return console.error(J),!1}}export{Hz as keepkeyWallet,hz as KEEPKEY_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=ED8287149CCB327064756E2164756E21
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as l}from"../../chunk-
|
|
1
|
+
import{a as l}from"../../chunk-6ndrbmhg.js";import{c as d,d as u}from"../../chunk-p1kdg37m.js";import{AssetValue as F,Chain as t,ChainIdToChain as L,SwapKitError as b,WalletOption as B,createWallet as V,filterSupportedChains as j}from"@swapkit/helpers";import{Chain as a,EVMChains as D,SwapKitError as P,WalletOption as A}from"@swapkit/helpers";import{erc20ABI as I}from"@swapkit/helpers/contracts";var T=(e)=>{switch(e){case a.Bitcoin:return"bitcoin";case a.BitcoinCash:return"bitcoincash";case a.Dash:return"dash";case a.Dogecoin:return"dogecoin";case a.Litecoin:return"litecoin";default:throw new Error("Unsupported chain")}};function w(e){if(!window.keepkey)throw new P("wallet_keepkey_not_found");switch(e){case a.Ethereum:case a.Base:case a.Avalanche:case a.BinanceSmartChain:case a.Arbitrum:case a.Optimism:case a.Polygon:return window.keepkey.ethereum;case a.Cosmos:return window.keepkey.cosmos;case a.Bitcoin:return window.keepkey.bitcoin;case a.BitcoinCash:return window.keepkey.bitcoincash;case a.Dogecoin:return window.keepkey.dogecoin;case a.Litecoin:return window.keepkey.litecoin;case a.Dash:return window.keepkey.dash;case a.THORChain:return window.keepkey.thorchain;case a.Maya:return window.keepkey.mayachain;default:return}}async function K({method:e,params:c,chain:r}){let o=w(r);return new Promise((n,i)=>{if(o&&"request"in o)o.request({method:e,params:c},(s,m)=>{s?i(s):n(m)});else i(new P("wallet_provider_not_found"))})}async function _(e){let c=w(e);if(!c)throw new P({errorKey:"wallet_provider_not_found",info:{wallet:A.KEEPKEY,chain:e}});let r="request_accounts";if(D.includes(e))r="eth_requestAccounts";let[o]=await c.request({method:r,params:[]});return o}async function f({assetValue:e,recipient:c,memo:r,gasLimit:o},n="transfer"){if(!e)throw new P("wallet_keepkey_asset_not_defined");let i=await _(e.chain),s=[{amount:{amount:e.getValue("string"),decimals:e.decimal},asset:{chain:e.chain,symbol:e.symbol.toUpperCase(),ticker:e.symbol.toUpperCase()},memo:r,from:i,recipient:c,gasLimit:o}];return K({method:n,params:s,chain:e.chain})}function O(e,c){return{call:async({contractAddress:r,abi:o,funcName:n,funcParams:i=[],txOverrides:s})=>{if(!r)throw new P("wallet_keepkey_contract_address_not_provided");let{createContract:m,getCreateContractTxObject:g,isStateChangingCall:y,toHexString:p}=await import("@swapkit/toolboxes/evm");if(y({abi:o,funcName:n})){let X=g({provider:e,chain:c}),{value:U,from:q,to:M,data:x}=await X({contractAddress:r,abi:o,funcName:n,funcParams:i,txOverrides:s});return e.send("eth_sendTransaction",[{value:p(BigInt(U||0)),from:q,to:M,data:x||"0x"}])}let v=await m(r,o,e)[n]?.(...i);return typeof v?.hash==="string"?v?.hash:v},approve:async({assetAddress:r,spenderAddress:o,amount:n,from:i})=>{let{MAX_APPROVAL:s,getCreateContractTxObject:m,toHexString:g}=await import("@swapkit/toolboxes/evm"),y=m({provider:e,chain:c}),{value:p,to:k,data:E}=await y({contractAddress:r,abi:I,funcName:"approve",funcParams:[o,BigInt(n||s)],txOverrides:{from:i}});return e.send("eth_sendTransaction",[{value:g(BigInt(p||0)),from:i,to:k,data:E||"0x"}])},sendTransaction:async(r)=>{let{from:o,to:n,data:i,value:s}=r;if(!n)throw new P("wallet_keepkey_send_transaction_no_address");let{toHexString:m}=await import("@swapkit/toolboxes/evm");return e.send("eth_sendTransaction",[{value:m(BigInt(s||0)),from:o,to:n,data:i||"0x"}])}}}var H=V({name:"connectKeepkeyBex",supportedChains:[t.Arbitrum,t.Avalanche,t.BinanceSmartChain,t.Bitcoin,t.BitcoinCash,t.Base,t.Cosmos,t.Dash,t.Dogecoin,t.Ethereum,t.Kujira,t.Litecoin,t.Maya,t.Optimism,t.Polygon,t.Solana,t.THORChain],walletType:B.KEEPKEY_BEX,connect:({addChain:e,supportedChains:c,walletType:r})=>async function o(n){let i=j({chains:n,supportedChains:c,walletType:r});return await Promise.all(i.map(async(s)=>{let m=await _(s),g=await R(s);e({...g,address:m,chain:s,walletType:r})})),!0}}),$=l(H);async function R(e){switch(e){case t.Maya:case t.THORChain:{let{getCosmosToolbox:c,THORCHAIN_GAS_VALUE:r,MAYA_GAS_VALUE:o}=await import("@swapkit/toolboxes/cosmos"),n=e===t.Maya?o:r;return{...c(e),deposit:(s)=>f({...s,recipient:""},"deposit"),transfer:(s)=>f({...s,gasLimit:n},"transfer")}}case t.Cosmos:case t.Kujira:{let{getCosmosToolbox:c}=await import("@swapkit/toolboxes/cosmos"),r=window.keepkey?.cosmos?.getOfflineSignerOnlyAmino(L[e]);if(!r)throw new Error("Could not load signer");let o=c(e,{signer:r}),n=await r.getAccounts();if(!n?.[0]?.address)throw new Error("No accounts found");let[{address:i}]=n;return{...o,address:i}}case t.Dash:case t.Bitcoin:case t.BitcoinCash:case t.Dogecoin:case t.Litecoin:{let{getUtxoToolbox:c}=await import("@swapkit/toolboxes/utxo");return{...await c(e),getBalance:async()=>{try{let n=T(e),i=await window?.keepkey?.[n]?.request({method:"request_balance"});return[F.from({chain:e,value:i[0].balance})]}catch(n){throw console.error("Error fetching balance:",n),n}},transfer:f}}case t.Ethereum:case t.BinanceSmartChain:case t.Base:case t.Arbitrum:case t.Optimism:case t.Polygon:case t.Avalanche:{let{prepareNetworkSwitch:c,switchEVMWalletNetwork:r}=await import("@swapkit/helpers"),{getEvmToolbox:o}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:n}=await import("ethers"),i=w(e);if(!i)throw new b("wallet_keepkey_not_found");let s=new n(i,"any"),m=await s.getSigner(),g=await o(e,{provider:s,signer:m}),y=O(s,e);try{if(e!==t.Ethereum){let p=g.getNetworkParams();await r(s,e,p)}}catch(p){throw new b({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:B.KEEPKEY,chain:e}})}return c({provider:s,chain:e,toolbox:{...g,...y}})}default:return null}}export{H as keepkeyBexWallet,$ as KEEPKEY_BEX_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=AFAB0E6C797C305A64756E2164756E21
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
var A={};T(A,{validatePhrase:()=>P,keystoreWallet:()=>v,generatePhrase:()=>B,encryptToKeyStore:()=>C,decryptFromKeystore:()=>K,KEYSTORE_SUPPORTED_CHAINS:()=>E});module.exports=D(A);var t=require("@swapkit/helpers");var d=require("@scure/bip39"),g=require("@scure/bip39/wordlists/english");async function x(r){let{blake2bFinal:i,blake2bInit:s,blake2bUpdate:c}=await import("blakejs"),n=r;if(!(n instanceof Buffer))n=Buffer.from(n,"hex");let o=s(32);return c(o,n),Array.from(i(o)).map((e)=>e<16?`0${e.toString(16)}`:e.toString(16)).join("")}async function C(r,i){let{pbkdf2Sync:s,randomBytes:c,createCipheriv:n}=await import("
|
|
1
|
+
var A={};T(A,{validatePhrase:()=>P,keystoreWallet:()=>v,generatePhrase:()=>B,encryptToKeyStore:()=>C,decryptFromKeystore:()=>K,KEYSTORE_SUPPORTED_CHAINS:()=>E});module.exports=D(A);var t=require("@swapkit/helpers");var d=require("@scure/bip39"),g=require("@scure/bip39/wordlists/english");async function x(r){let{blake2bFinal:i,blake2bInit:s,blake2bUpdate:c}=await import("blakejs"),n=r;if(!(n instanceof Buffer))n=Buffer.from(n,"hex");let o=s(32);return c(o,n),Array.from(i(o)).map((e)=>e<16?`0${e.toString(16)}`:e.toString(16)).join("")}async function C(r,i){let{pbkdf2Sync:s,randomBytes:c,createCipheriv:n}=await import("crypto"),o="aes-128-ctr",e=c(16),p=c(32),a={c:262144,prf:"hmac-sha256",dklen:32,salt:p.toString("hex")},l=s(i,p,a.c,a.dklen,"sha256"),m=n("aes-128-ctr",l.subarray(0,16),e),f=Buffer.concat([m.update(Buffer.from(r,"utf8")),m.final()]),u=Buffer.concat([l.subarray(16,32),Buffer.from(f)]),y=await x(u);return{meta:"xchain-keystore",version:1,crypto:{cipher:"aes-128-ctr",cipherparams:{iv:e.toString("hex")},ciphertext:f.toString("hex"),kdf:"pbkdf2",kdfparams:a,mac:y}}}function B(r=12){return d.generateMnemonic(g.wordlist,r===12?128:256)}function P(r){return d.validateMnemonic(r,g.wordlist)}async function K(r,i){let{createDecipheriv:s,pbkdf2Sync:c}=await import("crypto"),{SwapKitError:n}=await import("@swapkit/helpers");switch(r.version){case 1:{let o=r.crypto.kdfparams,e=Buffer.from(o.salt,"hex"),p=c(i,e,o.c,o.dklen,"sha256"),a=Buffer.from(r.crypto.ciphertext,"hex"),l=Buffer.concat([p.subarray(16,32),a]);if(await x(l)!==r.crypto.mac)throw new n("wallet_keystore_invalid_password");let f=s(r.crypto.cipher,p.subarray(0,16),Buffer.from(r.crypto.cipherparams.iv,"hex"));return Buffer.concat([f.update(a),f.final()]).toString("utf8")}default:throw new n("wallet_keystore_unsupported_version")}}var v=t.createWallet({name:"connectKeystore",walletType:t.WalletOption.KEYSTORE,supportedChains:[...t.EVMChains,...t.UTXOChains,...t.CosmosChains,t.Chain.Polkadot,t.Chain.Chainflip,t.Chain.Ripple,t.Chain.Solana],connect:({addChain:r,supportedChains:i,walletType:s})=>async function c(n,o,e){let p=t.filterSupportedChains({chains:n,supportedChains:i,walletType:s});return await Promise.all(p.map(async(a)=>{let l=typeof e==="number"?e:0,m=e&&typeof e==="object"?e[a]:void 0,f=t.NetworkDerivationPath[a].slice(0,a===t.Chain.Solana?4:5),u=m||t.updateDerivationPath(f,{index:l}),{getToolbox:y}=await import("@swapkit/toolboxes"),w=await y(a,{phrase:o,derivationPath:u}),k=await w.getAddress()||"",S={...w,address:k};r({...S,chain:a,walletType:t.WalletOption.KEYSTORE})})),!0}}),E=b(v);
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=579D74A4588FBA0964756E2164756E21
|
|
@@ -3,9 +3,9 @@
|
|
|
3
3
|
"sources": ["../src/keystore/index.ts", "../src/keystore/helpers.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
5
|
"import {\n Chain,\n CosmosChains,\n type DerivationPathArray,\n EVMChains,\n NetworkDerivationPath,\n UTXOChains,\n WalletOption,\n createWallet,\n filterSupportedChains,\n updateDerivationPath,\n} from \"@swapkit/helpers\";\nimport { getWalletSupportedChains } from \"../utils\";\n\nexport const keystoreWallet = createWallet({\n name: \"connectKeystore\",\n walletType: WalletOption.KEYSTORE,\n supportedChains: [\n ...EVMChains,\n ...UTXOChains,\n ...CosmosChains,\n Chain.Polkadot,\n Chain.Chainflip,\n Chain.Ripple,\n Chain.Solana,\n ],\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectKeystore(\n chains: Chain[],\n phrase: string,\n derivationPathMapOrIndex?: { [chain in Chain]?: DerivationPathArray } | number,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const derivationPathIndex =\n typeof derivationPathMapOrIndex === \"number\" ? derivationPathMapOrIndex : 0;\n\n const derivationPathFromMap =\n derivationPathMapOrIndex && typeof derivationPathMapOrIndex === \"object\"\n ? derivationPathMapOrIndex[chain]\n : undefined;\n\n const derivationArrayToUpdate = NetworkDerivationPath[chain].slice(\n 0,\n chain === Chain.Solana ? 4 : 5,\n ) as DerivationPathArray;\n\n const derivationPath: DerivationPathArray =\n derivationPathFromMap ||\n updateDerivationPath(derivationArrayToUpdate, { index: derivationPathIndex });\n\n const { getToolbox } = await import(\"@swapkit/toolboxes\");\n\n const toolbox = await getToolbox(chain, { phrase, derivationPath });\n const address = (await toolbox.getAddress()) || \"\";\n\n const wallet = { ...toolbox, address };\n\n addChain({ ...wallet, chain, walletType: WalletOption.KEYSTORE });\n }),\n );\n\n return true;\n },\n});\n\nexport const KEYSTORE_SUPPORTED_CHAINS = getWalletSupportedChains(keystoreWallet);\n\nexport * from \"./helpers\";\n",
|
|
6
|
-
"import { generateMnemonic, validateMnemonic } from \"@scure/bip39\";\nimport { wordlist } from \"@scure/bip39/wordlists/english\";\n\nexport type Keystore = {\n version: number;\n meta: string;\n crypto: {\n cipher: string;\n cipherparams: { iv: string };\n ciphertext: string;\n kdf: string;\n kdfparams: { prf: string; dklen: number; salt: string; c: number };\n mac: string;\n };\n};\n\nasync function blake256(initData: Buffer | string) {\n const { blake2bFinal, blake2bInit, blake2bUpdate } = await import(\"blakejs\");\n let data = initData;\n\n if (!(data instanceof Buffer)) {\n // @ts-ignore\n data = Buffer.from(data, \"hex\");\n }\n\n const context = blake2bInit(32);\n blake2bUpdate(context, data);\n\n return Array.from(blake2bFinal(context))\n .map((byte) => (byte < 0x10 ? `0${byte.toString(16)}` : byte.toString(16)))\n .join(\"\");\n}\n\nexport async function encryptToKeyStore(phrase: string, password: string) {\n const { pbkdf2Sync, randomBytes, createCipheriv } = await import(\"
|
|
6
|
+
"import { generateMnemonic, validateMnemonic } from \"@scure/bip39\";\nimport { wordlist } from \"@scure/bip39/wordlists/english\";\n\nexport type Keystore = {\n version: number;\n meta: string;\n crypto: {\n cipher: string;\n cipherparams: { iv: string };\n ciphertext: string;\n kdf: string;\n kdfparams: { prf: string; dklen: number; salt: string; c: number };\n mac: string;\n };\n};\n\nasync function blake256(initData: Buffer | string) {\n const { blake2bFinal, blake2bInit, blake2bUpdate } = await import(\"blakejs\");\n let data = initData;\n\n if (!(data instanceof Buffer)) {\n // @ts-ignore\n data = Buffer.from(data, \"hex\");\n }\n\n const context = blake2bInit(32);\n blake2bUpdate(context, data);\n\n return Array.from(blake2bFinal(context))\n .map((byte) => (byte < 0x10 ? `0${byte.toString(16)}` : byte.toString(16)))\n .join(\"\");\n}\n\nexport async function encryptToKeyStore(phrase: string, password: string) {\n const { pbkdf2Sync, randomBytes, createCipheriv } = await import(\"crypto\");\n\n const cipher = \"aes-128-ctr\";\n const iv = randomBytes(16);\n const salt = randomBytes(32);\n const kdfParams = { c: 262144, prf: \"hmac-sha256\", dklen: 32, salt: salt.toString(\"hex\") };\n\n const derivedKey = pbkdf2Sync(password, salt, kdfParams.c, kdfParams.dklen, \"sha256\");\n const cipherIV = createCipheriv(cipher, derivedKey.subarray(0, 16), iv);\n const ciphertext = Buffer.concat([\n cipherIV.update(Buffer.from(phrase, \"utf8\")),\n cipherIV.final(),\n ]);\n const initData = Buffer.concat([derivedKey.subarray(16, 32), Buffer.from(ciphertext)]);\n const mac = await blake256(initData);\n\n return {\n meta: \"xchain-keystore\",\n version: 1,\n crypto: {\n cipher,\n cipherparams: { iv: iv.toString(\"hex\") },\n ciphertext: ciphertext.toString(\"hex\"),\n kdf: \"pbkdf2\",\n kdfparams: kdfParams,\n mac,\n },\n };\n}\n\nexport function generatePhrase(size: 12 | 24 = 12) {\n return generateMnemonic(wordlist, size === 12 ? 128 : 256);\n}\n\nexport function validatePhrase(phrase: string) {\n return validateMnemonic(phrase, wordlist);\n}\n\nexport async function decryptFromKeystore(keystore: Keystore, password: string) {\n const { createDecipheriv, pbkdf2Sync } = await import(\"crypto\");\n const { SwapKitError } = await import(\"@swapkit/helpers\");\n\n switch (keystore.version) {\n case 1: {\n const kdfParams = keystore.crypto.kdfparams;\n const salt = Buffer.from(kdfParams.salt, \"hex\");\n const derivedKey = pbkdf2Sync(password, salt, kdfParams.c, kdfParams.dklen, \"sha256\");\n\n const ciphertext = Buffer.from(keystore.crypto.ciphertext, \"hex\");\n const initData = Buffer.concat([derivedKey.subarray(16, 32), ciphertext]);\n const mac = await blake256(initData);\n\n if (mac !== keystore.crypto.mac) {\n throw new SwapKitError(\"wallet_keystore_invalid_password\");\n }\n\n const decipher = createDecipheriv(\n keystore.crypto.cipher,\n derivedKey.subarray(0, 16),\n Buffer.from(keystore.crypto.cipherparams.iv, \"hex\"),\n );\n\n const phrase = Buffer.concat([decipher.update(ciphertext), decipher.final()]);\n return phrase.toString(\"utf8\");\n }\n\n default:\n throw new SwapKitError(\"wallet_keystore_unsupported_version\");\n }\n}\n"
|
|
7
7
|
],
|
|
8
|
-
"mappings": "qLAWO,IAXP,8BCAmD,IAAnD,0BACA,4CAeA,eAAe,CAAQ,CAAC,EAA2B,CACjD,IAAQ,eAAc,cAAa,iBAAkB,KAAa,mBAC9D,EAAO,EAEX,KAAM,aAAgB,QAEpB,EAAO,OAAO,KAAK,EAAM,KAAK,EAGhC,IAAM,EAAU,EAAY,EAAE,EAG9B,OAFA,EAAc,EAAS,CAAI,EAEpB,MAAM,KAAK,EAAa,CAAO,CAAC,EACpC,IAAI,CAAC,IAAU,EAAO,GAAO,IAAI,EAAK,SAAS,EAAE,IAAM,EAAK,SAAS,EAAE,CAAE,EACzE,KAAK,EAAE,EAGZ,eAAsB,CAAiB,CAAC,EAAgB,EAAkB,CACxE,IAAQ,aAAY,cAAa,kBAAmB,KAAa,
|
|
9
|
-
"debugId": "
|
|
8
|
+
"mappings": "qLAWO,IAXP,8BCAmD,IAAnD,0BACA,4CAeA,eAAe,CAAQ,CAAC,EAA2B,CACjD,IAAQ,eAAc,cAAa,iBAAkB,KAAa,mBAC9D,EAAO,EAEX,KAAM,aAAgB,QAEpB,EAAO,OAAO,KAAK,EAAM,KAAK,EAGhC,IAAM,EAAU,EAAY,EAAE,EAG9B,OAFA,EAAc,EAAS,CAAI,EAEpB,MAAM,KAAK,EAAa,CAAO,CAAC,EACpC,IAAI,CAAC,IAAU,EAAO,GAAO,IAAI,EAAK,SAAS,EAAE,IAAM,EAAK,SAAS,EAAE,CAAE,EACzE,KAAK,EAAE,EAGZ,eAAsB,CAAiB,CAAC,EAAgB,EAAkB,CACxE,IAAQ,aAAY,cAAa,kBAAmB,KAAa,kBAE3D,EAAS,cACT,EAAK,EAAY,EAAE,EACnB,EAAO,EAAY,EAAE,EACrB,EAAY,CAAE,EAAG,OAAQ,IAAK,cAAe,MAAO,GAAI,KAAM,EAAK,SAAS,KAAK,CAAE,EAEnF,EAAa,EAAW,EAAU,EAAM,EAAU,EAAG,EAAU,MAAO,QAAQ,EAC9E,EAAW,EANF,cAMyB,EAAW,SAAS,EAAG,EAAE,EAAG,CAAE,EAChE,EAAa,OAAO,OAAO,CAC/B,EAAS,OAAO,OAAO,KAAK,EAAQ,MAAM,CAAC,EAC3C,EAAS,MAAM,CACjB,CAAC,EACK,EAAW,OAAO,OAAO,CAAC,EAAW,SAAS,GAAI,EAAE,EAAG,OAAO,KAAK,CAAU,CAAC,CAAC,EAC/E,EAAM,MAAM,EAAS,CAAQ,EAEnC,MAAO,CACL,KAAM,kBACN,QAAS,EACT,OAAQ,CACN,OAlBW,cAmBX,aAAc,CAAE,GAAI,EAAG,SAAS,KAAK,CAAE,EACvC,WAAY,EAAW,SAAS,KAAK,EACrC,IAAK,SACL,UAAW,EACX,KACF,CACF,EAGK,SAAS,CAAc,CAAC,EAAgB,GAAI,CACjD,OAAO,mBAAiB,WAAU,IAAS,GAAK,IAAM,GAAG,EAGpD,SAAS,CAAc,CAAC,EAAgB,CAC7C,OAAO,mBAAiB,EAAQ,UAAQ,EAG1C,eAAsB,CAAmB,CAAC,EAAoB,EAAkB,CAC9E,IAAQ,mBAAkB,cAAe,KAAa,mBAC9C,gBAAiB,KAAa,4BAEtC,OAAQ,EAAS,aACV,GAAG,CACN,IAAM,EAAY,EAAS,OAAO,UAC5B,EAAO,OAAO,KAAK,EAAU,KAAM,KAAK,EACxC,EAAa,EAAW,EAAU,EAAM,EAAU,EAAG,EAAU,MAAO,QAAQ,EAE9E,EAAa,OAAO,KAAK,EAAS,OAAO,WAAY,KAAK,EAC1D,EAAW,OAAO,OAAO,CAAC,EAAW,SAAS,GAAI,EAAE,EAAG,CAAU,CAAC,EAGxE,GAFY,MAAM,EAAS,CAAQ,IAEvB,EAAS,OAAO,IAC1B,MAAM,IAAI,EAAa,kCAAkC,EAG3D,IAAM,EAAW,EACf,EAAS,OAAO,OAChB,EAAW,SAAS,EAAG,EAAE,EACzB,OAAO,KAAK,EAAS,OAAO,aAAa,GAAI,KAAK,CACpD,EAGA,OADe,OAAO,OAAO,CAAC,EAAS,OAAO,CAAU,EAAG,EAAS,MAAM,CAAC,CAAC,EAC9D,SAAS,MAAM,CAC/B,SAGE,MAAM,IAAI,EAAa,qCAAqC,GDvF3D,IAAM,EAAiB,eAAa,CACzC,KAAM,kBACN,WAAY,eAAa,SACzB,gBAAiB,CACf,GAAG,YACH,GAAG,aACH,GAAG,eACH,QAAM,SACN,QAAM,UACN,QAAM,OACN,QAAM,MACR,EACA,QAAS,EAAG,WAAU,kBAAiB,gBACrC,eAAe,CAAe,CAC5B,EACA,EACA,EACA,CACA,IAAM,EAAiB,wBAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAgCpF,OA9BA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAM,EACJ,OAAO,IAA6B,SAAW,EAA2B,EAEtE,EACJ,GAA4B,OAAO,IAA6B,SAC5D,EAAyB,GACzB,OAEA,EAA0B,wBAAsB,GAAO,MAC3D,EACA,IAAU,QAAM,OAAS,EAAI,CAC/B,EAEM,EACJ,GACA,uBAAqB,EAAyB,CAAE,MAAO,CAAoB,CAAC,GAEtE,cAAe,KAAa,8BAE9B,EAAU,MAAM,EAAW,EAAO,CAAE,SAAQ,gBAAe,CAAC,EAC5D,EAAW,MAAM,EAAQ,WAAW,GAAM,GAE1C,EAAS,IAAK,EAAS,SAAQ,EAErC,EAAS,IAAK,EAAQ,QAAO,WAAY,eAAa,QAAS,CAAC,EACjE,CACH,EAEO,GAEb,CAAC,EAEY,EAA4B,EAAyB,CAAc",
|
|
9
|
+
"debugId": "579D74A4588FBA0964756E2164756E21",
|
|
10
10
|
"names": []
|
|
11
11
|
}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as b}from"../../chunk-
|
|
1
|
+
import{a as b}from"../../chunk-6ndrbmhg.js";import{c as m,d as h}from"../../chunk-p1kdg37m.js";import{Chain as u,CosmosChains as P,EVMChains as K,NetworkDerivationPath as D,UTXOChains as T,WalletOption as v,createWallet as E,filterSupportedChains as A,updateDerivationPath as _}from"@swapkit/helpers";import{generateMnemonic as C,validateMnemonic as B}from"@scure/bip39";import{wordlist as w}from"@scure/bip39/wordlists/english";async function x(t){let{blake2bFinal:o,blake2bInit:i,blake2bUpdate:s}=await import("blakejs"),a=t;if(!(a instanceof Buffer))a=Buffer.from(a,"hex");let n=i(32);return s(n,a),Array.from(o(n)).map((r)=>r<16?`0${r.toString(16)}`:r.toString(16)).join("")}async function F(t,o){let{pbkdf2Sync:i,randomBytes:s,createCipheriv:a}=await import("crypto"),n="aes-128-ctr",r=s(16),c=s(32),e={c:262144,prf:"hmac-sha256",dklen:32,salt:c.toString("hex")},f=i(o,c,e.c,e.dklen,"sha256"),l=a("aes-128-ctr",f.subarray(0,16),r),p=Buffer.concat([l.update(Buffer.from(t,"utf8")),l.final()]),d=Buffer.concat([f.subarray(16,32),Buffer.from(p)]),y=await x(d);return{meta:"xchain-keystore",version:1,crypto:{cipher:"aes-128-ctr",cipherparams:{iv:r.toString("hex")},ciphertext:p.toString("hex"),kdf:"pbkdf2",kdfparams:e,mac:y}}}function Y(t=12){return C(w,t===12?128:256)}function j(t){return B(t,w)}async function N(t,o){let{createDecipheriv:i,pbkdf2Sync:s}=await import("crypto"),{SwapKitError:a}=await import("@swapkit/helpers");switch(t.version){case 1:{let n=t.crypto.kdfparams,r=Buffer.from(n.salt,"hex"),c=s(o,r,n.c,n.dklen,"sha256"),e=Buffer.from(t.crypto.ciphertext,"hex"),f=Buffer.concat([c.subarray(16,32),e]);if(await x(f)!==t.crypto.mac)throw new a("wallet_keystore_invalid_password");let p=i(t.crypto.cipher,c.subarray(0,16),Buffer.from(t.crypto.cipherparams.iv,"hex"));return Buffer.concat([p.update(e),p.final()]).toString("utf8")}default:throw new a("wallet_keystore_unsupported_version")}}var R=E({name:"connectKeystore",walletType:v.KEYSTORE,supportedChains:[...K,...T,...P,u.Polkadot,u.Chainflip,u.Ripple,u.Solana],connect:({addChain:t,supportedChains:o,walletType:i})=>async function s(a,n,r){let c=A({chains:a,supportedChains:o,walletType:i});return await Promise.all(c.map(async(e)=>{let f=typeof r==="number"?r:0,l=r&&typeof r==="object"?r[e]:void 0,p=D[e].slice(0,e===u.Solana?4:5),d=l||_(p,{index:f}),{getToolbox:y}=await import("@swapkit/toolboxes"),g=await y(e,{phrase:n,derivationPath:d}),k=await g.getAddress()||"",S={...g,address:k};t({...S,chain:e,walletType:v.KEYSTORE})})),!0}}),X=b(R);export{j as validatePhrase,R as keystoreWallet,Y as generatePhrase,F as encryptToKeyStore,N as decryptFromKeystore,X as KEYSTORE_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=D774098E142DFD7064756E2164756E21
|
|
@@ -3,9 +3,9 @@
|
|
|
3
3
|
"sources": ["../src/keystore/index.ts", "../src/keystore/helpers.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
5
|
"import {\n Chain,\n CosmosChains,\n type DerivationPathArray,\n EVMChains,\n NetworkDerivationPath,\n UTXOChains,\n WalletOption,\n createWallet,\n filterSupportedChains,\n updateDerivationPath,\n} from \"@swapkit/helpers\";\nimport { getWalletSupportedChains } from \"../utils\";\n\nexport const keystoreWallet = createWallet({\n name: \"connectKeystore\",\n walletType: WalletOption.KEYSTORE,\n supportedChains: [\n ...EVMChains,\n ...UTXOChains,\n ...CosmosChains,\n Chain.Polkadot,\n Chain.Chainflip,\n Chain.Ripple,\n Chain.Solana,\n ],\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectKeystore(\n chains: Chain[],\n phrase: string,\n derivationPathMapOrIndex?: { [chain in Chain]?: DerivationPathArray } | number,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const derivationPathIndex =\n typeof derivationPathMapOrIndex === \"number\" ? derivationPathMapOrIndex : 0;\n\n const derivationPathFromMap =\n derivationPathMapOrIndex && typeof derivationPathMapOrIndex === \"object\"\n ? derivationPathMapOrIndex[chain]\n : undefined;\n\n const derivationArrayToUpdate = NetworkDerivationPath[chain].slice(\n 0,\n chain === Chain.Solana ? 4 : 5,\n ) as DerivationPathArray;\n\n const derivationPath: DerivationPathArray =\n derivationPathFromMap ||\n updateDerivationPath(derivationArrayToUpdate, { index: derivationPathIndex });\n\n const { getToolbox } = await import(\"@swapkit/toolboxes\");\n\n const toolbox = await getToolbox(chain, { phrase, derivationPath });\n const address = (await toolbox.getAddress()) || \"\";\n\n const wallet = { ...toolbox, address };\n\n addChain({ ...wallet, chain, walletType: WalletOption.KEYSTORE });\n }),\n );\n\n return true;\n },\n});\n\nexport const KEYSTORE_SUPPORTED_CHAINS = getWalletSupportedChains(keystoreWallet);\n\nexport * from \"./helpers\";\n",
|
|
6
|
-
"import { generateMnemonic, validateMnemonic } from \"@scure/bip39\";\nimport { wordlist } from \"@scure/bip39/wordlists/english\";\n\nexport type Keystore = {\n version: number;\n meta: string;\n crypto: {\n cipher: string;\n cipherparams: { iv: string };\n ciphertext: string;\n kdf: string;\n kdfparams: { prf: string; dklen: number; salt: string; c: number };\n mac: string;\n };\n};\n\nasync function blake256(initData: Buffer | string) {\n const { blake2bFinal, blake2bInit, blake2bUpdate } = await import(\"blakejs\");\n let data = initData;\n\n if (!(data instanceof Buffer)) {\n // @ts-ignore\n data = Buffer.from(data, \"hex\");\n }\n\n const context = blake2bInit(32);\n blake2bUpdate(context, data);\n\n return Array.from(blake2bFinal(context))\n .map((byte) => (byte < 0x10 ? `0${byte.toString(16)}` : byte.toString(16)))\n .join(\"\");\n}\n\nexport async function encryptToKeyStore(phrase: string, password: string) {\n const { pbkdf2Sync, randomBytes, createCipheriv } = await import(\"
|
|
6
|
+
"import { generateMnemonic, validateMnemonic } from \"@scure/bip39\";\nimport { wordlist } from \"@scure/bip39/wordlists/english\";\n\nexport type Keystore = {\n version: number;\n meta: string;\n crypto: {\n cipher: string;\n cipherparams: { iv: string };\n ciphertext: string;\n kdf: string;\n kdfparams: { prf: string; dklen: number; salt: string; c: number };\n mac: string;\n };\n};\n\nasync function blake256(initData: Buffer | string) {\n const { blake2bFinal, blake2bInit, blake2bUpdate } = await import(\"blakejs\");\n let data = initData;\n\n if (!(data instanceof Buffer)) {\n // @ts-ignore\n data = Buffer.from(data, \"hex\");\n }\n\n const context = blake2bInit(32);\n blake2bUpdate(context, data);\n\n return Array.from(blake2bFinal(context))\n .map((byte) => (byte < 0x10 ? `0${byte.toString(16)}` : byte.toString(16)))\n .join(\"\");\n}\n\nexport async function encryptToKeyStore(phrase: string, password: string) {\n const { pbkdf2Sync, randomBytes, createCipheriv } = await import(\"crypto\");\n\n const cipher = \"aes-128-ctr\";\n const iv = randomBytes(16);\n const salt = randomBytes(32);\n const kdfParams = { c: 262144, prf: \"hmac-sha256\", dklen: 32, salt: salt.toString(\"hex\") };\n\n const derivedKey = pbkdf2Sync(password, salt, kdfParams.c, kdfParams.dklen, \"sha256\");\n const cipherIV = createCipheriv(cipher, derivedKey.subarray(0, 16), iv);\n const ciphertext = Buffer.concat([\n cipherIV.update(Buffer.from(phrase, \"utf8\")),\n cipherIV.final(),\n ]);\n const initData = Buffer.concat([derivedKey.subarray(16, 32), Buffer.from(ciphertext)]);\n const mac = await blake256(initData);\n\n return {\n meta: \"xchain-keystore\",\n version: 1,\n crypto: {\n cipher,\n cipherparams: { iv: iv.toString(\"hex\") },\n ciphertext: ciphertext.toString(\"hex\"),\n kdf: \"pbkdf2\",\n kdfparams: kdfParams,\n mac,\n },\n };\n}\n\nexport function generatePhrase(size: 12 | 24 = 12) {\n return generateMnemonic(wordlist, size === 12 ? 128 : 256);\n}\n\nexport function validatePhrase(phrase: string) {\n return validateMnemonic(phrase, wordlist);\n}\n\nexport async function decryptFromKeystore(keystore: Keystore, password: string) {\n const { createDecipheriv, pbkdf2Sync } = await import(\"crypto\");\n const { SwapKitError } = await import(\"@swapkit/helpers\");\n\n switch (keystore.version) {\n case 1: {\n const kdfParams = keystore.crypto.kdfparams;\n const salt = Buffer.from(kdfParams.salt, \"hex\");\n const derivedKey = pbkdf2Sync(password, salt, kdfParams.c, kdfParams.dklen, \"sha256\");\n\n const ciphertext = Buffer.from(keystore.crypto.ciphertext, \"hex\");\n const initData = Buffer.concat([derivedKey.subarray(16, 32), ciphertext]);\n const mac = await blake256(initData);\n\n if (mac !== keystore.crypto.mac) {\n throw new SwapKitError(\"wallet_keystore_invalid_password\");\n }\n\n const decipher = createDecipheriv(\n keystore.crypto.cipher,\n derivedKey.subarray(0, 16),\n Buffer.from(keystore.crypto.cipherparams.iv, \"hex\"),\n );\n\n const phrase = Buffer.concat([decipher.update(ciphertext), decipher.final()]);\n return phrase.toString(\"utf8\");\n }\n\n default:\n throw new SwapKitError(\"wallet_keystore_unsupported_version\");\n }\n}\n"
|
|
7
7
|
],
|
|
8
|
-
"mappings": "iGAAA,cACE,kBACA,eAEA,2BACA,gBACA,kBACA,kBACA,2BACA,0BACA,yBCVF,2BAAS,sBAAkB,qBAC3B,mBAAS,uCAeT,eAAe,CAAQ,CAAC,EAA2B,CACjD,IAAQ,eAAc,cAAa,iBAAkB,KAAa,mBAC9D,EAAO,EAEX,KAAM,aAAgB,QAEpB,EAAO,OAAO,KAAK,EAAM,KAAK,EAGhC,IAAM,EAAU,EAAY,EAAE,EAG9B,OAFA,EAAc,EAAS,CAAI,EAEpB,MAAM,KAAK,EAAa,CAAO,CAAC,EACpC,IAAI,CAAC,IAAU,EAAO,GAAO,IAAI,EAAK,SAAS,EAAE,IAAM,EAAK,SAAS,EAAE,CAAE,EACzE,KAAK,EAAE,EAGZ,eAAsB,CAAiB,CAAC,EAAgB,EAAkB,CACxE,IAAQ,aAAY,cAAa,kBAAmB,KAAa,
|
|
9
|
-
"debugId": "
|
|
8
|
+
"mappings": "iGAAA,cACE,kBACA,eAEA,2BACA,gBACA,kBACA,kBACA,2BACA,0BACA,yBCVF,2BAAS,sBAAkB,qBAC3B,mBAAS,uCAeT,eAAe,CAAQ,CAAC,EAA2B,CACjD,IAAQ,eAAc,cAAa,iBAAkB,KAAa,mBAC9D,EAAO,EAEX,KAAM,aAAgB,QAEpB,EAAO,OAAO,KAAK,EAAM,KAAK,EAGhC,IAAM,EAAU,EAAY,EAAE,EAG9B,OAFA,EAAc,EAAS,CAAI,EAEpB,MAAM,KAAK,EAAa,CAAO,CAAC,EACpC,IAAI,CAAC,IAAU,EAAO,GAAO,IAAI,EAAK,SAAS,EAAE,IAAM,EAAK,SAAS,EAAE,CAAE,EACzE,KAAK,EAAE,EAGZ,eAAsB,CAAiB,CAAC,EAAgB,EAAkB,CACxE,IAAQ,aAAY,cAAa,kBAAmB,KAAa,kBAE3D,EAAS,cACT,EAAK,EAAY,EAAE,EACnB,EAAO,EAAY,EAAE,EACrB,EAAY,CAAE,EAAG,OAAQ,IAAK,cAAe,MAAO,GAAI,KAAM,EAAK,SAAS,KAAK,CAAE,EAEnF,EAAa,EAAW,EAAU,EAAM,EAAU,EAAG,EAAU,MAAO,QAAQ,EAC9E,EAAW,EANF,cAMyB,EAAW,SAAS,EAAG,EAAE,EAAG,CAAE,EAChE,EAAa,OAAO,OAAO,CAC/B,EAAS,OAAO,OAAO,KAAK,EAAQ,MAAM,CAAC,EAC3C,EAAS,MAAM,CACjB,CAAC,EACK,EAAW,OAAO,OAAO,CAAC,EAAW,SAAS,GAAI,EAAE,EAAG,OAAO,KAAK,CAAU,CAAC,CAAC,EAC/E,EAAM,MAAM,EAAS,CAAQ,EAEnC,MAAO,CACL,KAAM,kBACN,QAAS,EACT,OAAQ,CACN,OAlBW,cAmBX,aAAc,CAAE,GAAI,EAAG,SAAS,KAAK,CAAE,EACvC,WAAY,EAAW,SAAS,KAAK,EACrC,IAAK,SACL,UAAW,EACX,KACF,CACF,EAGK,SAAS,CAAc,CAAC,EAAgB,GAAI,CACjD,OAAO,EAAiB,EAAU,IAAS,GAAK,IAAM,GAAG,EAGpD,SAAS,CAAc,CAAC,EAAgB,CAC7C,OAAO,EAAiB,EAAQ,CAAQ,EAG1C,eAAsB,CAAmB,CAAC,EAAoB,EAAkB,CAC9E,IAAQ,mBAAkB,cAAe,KAAa,mBAC9C,gBAAiB,KAAa,4BAEtC,OAAQ,EAAS,aACV,GAAG,CACN,IAAM,EAAY,EAAS,OAAO,UAC5B,EAAO,OAAO,KAAK,EAAU,KAAM,KAAK,EACxC,EAAa,EAAW,EAAU,EAAM,EAAU,EAAG,EAAU,MAAO,QAAQ,EAE9E,EAAa,OAAO,KAAK,EAAS,OAAO,WAAY,KAAK,EAC1D,EAAW,OAAO,OAAO,CAAC,EAAW,SAAS,GAAI,EAAE,EAAG,CAAU,CAAC,EAGxE,GAFY,MAAM,EAAS,CAAQ,IAEvB,EAAS,OAAO,IAC1B,MAAM,IAAI,EAAa,kCAAkC,EAG3D,IAAM,EAAW,EACf,EAAS,OAAO,OAChB,EAAW,SAAS,EAAG,EAAE,EACzB,OAAO,KAAK,EAAS,OAAO,aAAa,GAAI,KAAK,CACpD,EAGA,OADe,OAAO,OAAO,CAAC,EAAS,OAAO,CAAU,EAAG,EAAS,MAAM,CAAC,CAAC,EAC9D,SAAS,MAAM,CAC/B,SAGE,MAAM,IAAI,EAAa,qCAAqC,GDvF3D,IAAM,EAAiB,EAAa,CACzC,KAAM,kBACN,WAAY,EAAa,SACzB,gBAAiB,CACf,GAAG,EACH,GAAG,EACH,GAAG,EACH,EAAM,SACN,EAAM,UACN,EAAM,OACN,EAAM,MACR,EACA,QAAS,EAAG,WAAU,kBAAiB,gBACrC,eAAe,CAAe,CAC5B,EACA,EACA,EACA,CACA,IAAM,EAAiB,EAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAgCpF,OA9BA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAM,EACJ,OAAO,IAA6B,SAAW,EAA2B,EAEtE,EACJ,GAA4B,OAAO,IAA6B,SAC5D,EAAyB,GACzB,OAEA,EAA0B,EAAsB,GAAO,MAC3D,EACA,IAAU,EAAM,OAAS,EAAI,CAC/B,EAEM,EACJ,GACA,EAAqB,EAAyB,CAAE,MAAO,CAAoB,CAAC,GAEtE,cAAe,KAAa,8BAE9B,EAAU,MAAM,EAAW,EAAO,CAAE,SAAQ,gBAAe,CAAC,EAC5D,EAAW,MAAM,EAAQ,WAAW,GAAM,GAE1C,EAAS,IAAK,EAAS,SAAQ,EAErC,EAAS,IAAK,EAAQ,QAAO,WAAY,EAAa,QAAS,CAAC,EACjE,CACH,EAEO,GAEb,CAAC,EAEY,EAA4B,EAAyB,CAAc",
|
|
9
|
+
"debugId": "D774098E142DFD7064756E2164756E21",
|
|
10
10
|
"names": []
|
|
11
11
|
}
|
package/dist/src/ledger/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{a as z0}from"../../chunk-czhtd6cy.js";import{c as Y,d as Z}from"../../chunk-p1kdg37m.js";import{Chain as $,ChainId as F2,FeeOption as X2,SKConfig as r,StagenetChain as J2,WalletOption as N0,createWallet as W2,filterSupportedChains as $2}from"@swapkit/helpers";import{Chain as m,SwapKitError as c0,WalletOption as u0}from"@swapkit/helpers";var S=async({chain:L,ledgerClient:_})=>{if(!_)return"";switch(L){case m.Cosmos:case m.THORChain:return _.connect();case m.Ethereum:case m.BinanceSmartChain:case m.Avalanche:case m.Polygon:case m.Arbitrum:case m.Optimism:case m.Base:return _.getAddress();case m.Bitcoin:case m.BitcoinCash:case m.Dash:case m.Dogecoin:case m.Litecoin:{let O=_;await O.connect();let B=await O.getAddress();return L===m.BitcoinCash?B.replace("bitcoincash:",""):B}default:throw new c0("wallet_chain_not_supported",{wallet:u0.LEDGER,chain:L})}};import{Chain as H,SwapKitError as B2,WalletOption as j2}from"@swapkit/helpers";import{NetworkDerivationPath as o0,derivationPathToString as t0}from"@swapkit/helpers";import{LedgerErrorCode as o,NetworkDerivationPath as p0,SwapKitError as t}from"@swapkit/helpers";var E=85,c=250;var K={GET_VERSION:0,INS_PUBLIC_KEY_SECP256K1:1,SIGN_SECP256K1:2,GET_ADDR_SECP256K1:4},P={INIT:0,ADD:1,LAST:2},u={ONLY_RETRIEVE:0,SHOW_ADDRESS_IN_DEVICE:1},C={JSON:0},R={NoError:36864},B0={1:"U2F: Unknown",2:"U2F: Bad request",3:"U2F: Configuration unsupported",4:"U2F: Device Ineligible",5:"U2F: Timeout",14:"Timeout",36864:"No errors",36865:"Device is busy",26626:"Error deriving keys",25600:"Execution Error",26368:"Wrong Length",27010:"Empty Buffer",27011:"Output buffer too small",27012:"Data is invalid",27013:"Conditions not satisfied",27014:"Transaction rejected",27264:"Bad key handle",27392:"Invalid P1/P2",27904:"Instruction not supported",28160:"App does not seem to be open",28416:"Unknown error",28417:"Sign/verify error"};function U(L){if(L in B0)return B0[L];return`Unknown Status Code: ${L}`}function h0(L){return typeof L==="object"&&L!==null&&!Array.isArray(L)&&!(L instanceof Date)}function M(L){if(L){if(h0(L)){if(Object.prototype.hasOwnProperty.call(L,"statusCode"))return{return_code:L.statusCode,error_message:U(L.statusCode)};if(Object.prototype.hasOwnProperty.call(L,"return_code")&&Object.prototype.hasOwnProperty.call(L,"error_message"))return L}return{return_code:65535,error_message:L.toString()}}return{return_code:65535,error_message:L.toString()}}async function h(L){return L.send(85,K.GET_VERSION,0,0).then((_)=>{let O=_.slice(-2),B=O[0]*256+O[1],G=0;if(_.length>=9)G=(_[5]<<24)+(_[6]<<16)+(_[7]<<8)+(_[8]<<0);return{return_code:B,error_message:U(B),test_mode:_[0]!==0,major:_[1],minor:_[2],patch:_[3],device_locked:_[4]===1,target_id:G.toString(16)}},M)}function j0(L){if(L==null||L.length<3)throw new Error("Invalid path.");if(L.length>10)throw new Error("Invalid path. Length should be <= 10");let _=Buffer.alloc(1+4*L.length);_.writeUInt8(L.length,0);for(let O=0;O<L.length;O+=1){let B=L[O]||0;if(O<3)B|=2147483648;_.writeInt32LE(B,1+O*4)}return _}async function d(L,_,O,B,G=C.JSON){return L.transport.send(E,K.SIGN_SECP256K1,_,G,B,[R.NoError,27012,27264]).then((j)=>{let X=j.slice(-2),F=X[0]*256+X[1],J=U(F);if(F===27264||F===27012)J=`${J} : ${j.slice(0,j.length-2).toString("ascii")}`;let W=null;if(j.length>2)W=j.slice(0,j.length-2);return{signature:W,return_code:F,error_message:J}},M)}function d0(L){if(L.length!==65)throw new Error("decompressed public key length should be 65 bytes");let _=L.slice(33,65),O=Buffer.from([2+(_[_.length-1]&1)]);return Buffer.concat([O,L.slice(1,33)])}async function F0(L,_){return L.transport.send(E,K.INS_PUBLIC_KEY_SECP256K1,0,0,_,[R.NoError]).then((O)=>{let B=O.slice(-2),G=B[0]*256+B[1],j=Buffer.from(O.slice(0,65));return{pk:j,compressed_pk:d0(j),return_code:G,error_message:U(G)}},M)}function X0(L){if(!L||L.length!==5)throw new Error("Invalid path.");let _=Buffer.alloc(20);return _.writeUInt32LE(2147483648+L[0],0),_.writeUInt32LE(2147483648+L[1],4),_.writeUInt32LE(2147483648+L[2],8),_.writeUInt32LE(L[3],12),_.writeUInt32LE(L[4],16),_}function J0(L,_,O,B,G=C.JSON){let j=P.ADD;if(_===1)j=P.INIT;if(_===O)j=P.LAST;return d(L,j,0,B,G)}async function W0(L,_){return L.transport.send(E,K.GET_ADDR_SECP256K1,0,0,_,[R.NoError]).then((O)=>{let B=O.slice(-2),G=B[0]*256+B[1];return{pk:"OBSOLETE PROPERTY",compressed_pk:Buffer.from(O.slice(0,33)),return_code:G,error_message:U(G)}},M)}class I{transport;versionResponse;constructor(L){if(!L)throw new Error("Transport has not been defined");this.transport=L}static serializeHRP(L){if(L==null||L.length<3||L.length>83)throw new Error("Invalid HRP");let _=Buffer.alloc(1+L.length);return _.writeUInt8(L.length,0),_.write(L,1),_}async serializePath(L){if(this.versionResponse=await h(this.transport),this.versionResponse.return_code!==R.NoError)throw this.versionResponse;switch(this.versionResponse.major){case 1:return j0(L);case 2:return X0(L);default:return Buffer.alloc(0)}}async signGetChunks(L,_){let O=await this.serializePath(L),B=[];B.push(O);for(let G=0;G<_.length;G+=c){let j=G+c;if(G>_.length)j=_.length;B.push(_.slice(G,j))}return B}async getVersion(){try{return this.versionResponse=await h(this.transport),this.versionResponse}catch(L){return M(L)}}async appInfo(){return this.transport.send(176,1,0,0).then((L)=>{let _=L.slice(-2),O=_[0]*256+_[1],B="",G="",j=0,X=0;if(L[0]!==1)return{return_code:36865,error_message:"response format ID not recognized"};let F=L[1];B=L.slice(2,2+F).toString("ascii");let J=2+F,W=L[J];J+=1,G=L.slice(J,J+W).toString("ascii"),J+=W;let Q=L[J];return J+=1,j=Q,X=L[J],{return_code:O,error_message:U(O),appName:B,appVersion:G,flagLen:j,flagsValue:X,flag_recovery:(X&1)!==0,flag_signed_mcu_code:(X&2)!==0,flag_onboarded:(X&4)!==0,flag_pin_validated:(X&128)!==0}},M)}async deviceInfo(){return this.transport.send(224,1,0,0,Buffer.from([]),[R.NoError,28160]).then((L)=>{let _=L.slice(-2),O=_[0]*256+_[1];if(O===28160)return{return_code:O,error_message:"This command is only available in the Dashboard"};let B=L.slice(0,4).toString("hex"),G=4,j=L[G];G+=1;let X=L.slice(G,G+j).toString();G+=j;let F=L[G];G+=1;let J=L.slice(G,G+F).toString("hex");G+=F;let W=L[G];G+=1;let Q=L.slice(G,G+W);if(Q[W-1]===0)Q=L.slice(G,G+W-1);let T=Q.toString();return{return_code:O,error_message:U(O),targetId:B,seVersion:X,flag:J,mcuVersion:T}},M)}async publicKey(L){try{let _=await this.serializePath(L);switch(this.versionResponse.major){case 1:return F0(this,_);case 2:{let O=Buffer.concat([I.serializeHRP("thor"),_]);return W0(this,O)}default:return{return_code:25600,error_message:"App Version is not supported"}}}catch(_){return M(_)}}async getAddressAndPubKey(L,_,O=!1){return this.serializePath(L).then((B)=>{let G=Buffer.concat([I.serializeHRP(_),B]);return this.transport.send(E,K.GET_ADDR_SECP256K1,O?u.SHOW_ADDRESS_IN_DEVICE:u.ONLY_RETRIEVE,0,G,[R.NoError]).then((j)=>{let X=j.slice(-2),F=X[0]*256+X[1],J=Buffer.from(j.slice(0,33));return{bech32_address:Buffer.from(j.slice(33,-2)).toString(),compressed_pk:J,return_code:F,error_message:U(F)}},M)}).catch((B)=>M(B))}showAddressAndPubKey(L,_){return this.getAddressAndPubKey(L,_,!0)}signSendChunk(L,_,O,B=C.JSON){switch(this.versionResponse.major){case 1:return d(this,L,_,O,B);case 2:return J0(this,L,_,O,B);default:return{return_code:25600,error_message:"App Version is not supported"}}}async sign(L,_,O=C.JSON){let B=Buffer.from(_),G=[],j;try{G=await this.signGetChunks(L,B),j=await this.signSendChunk(1,G.length,G[0],O)}catch(F){M(F)}let X={return_code:j.return_code,error_message:j.error_message,signature:null};for(let F=1;F<G.length;F+=1)if(X=await this.signSendChunk(1+F,G.length,G[F],O),X.return_code!==R.NoError)break;return{return_code:X.return_code,error_message:X.error_message,signature:X.signature}}}import{SwapKitError as i}from"@swapkit/helpers";var p=()=>navigator?.usb,i0=async()=>{let L=p();if(typeof L?.getDevices!=="function")return[];let{ledgerUSBVendorId:_}=await import("@ledgerhq/devices"),B=(await L?.getDevices()).filter((G)=>G.vendorId===_);if(B.length>0)return B[0];return L?.requestDevice({filters:[{vendorId:_}]})},N=async()=>{let L=await i0();if(!L)throw new i("wallet_ledger_device_not_found");if(await L.open(),L.configuration===null)await L.selectConfiguration(1);try{await L.reset()}catch{}let _=L.configurations[0].interfaces.find(({alternates:F})=>F.some(({interfaceClass:J})=>J===255));if(!_)throw await L.close(),new i("wallet_ledger_connection_error");try{await L.claimInterface(_.interfaceNumber)}catch(F){throw await L.close(),new i("wallet_ledger_connection_claimed",F)}let{default:O}=await import("@ledgerhq/hw-transport-webusb");if(!await O.isSupported())throw new Error("WebUSB not supported");let{DisconnectedDevice:G}=await import("@ledgerhq/errors"),j=new O(L,_.interfaceNumber),X=(F)=>{if(L===F.device)p()?.removeEventListener("disconnect",X),j._emitDisconnect(new G)};return p()?.addEventListener("disconnect",X),j};class l{ledgerTimeout=50000;derivationPath=p0.GAIA;transport;ledgerApp;chain="thor";checkOrCreateTransportAndLedger=async(L=!1)=>{if(!L&&this.transport&&this.ledgerApp)return;try{switch(this.transport=L||!this.transport?await N():this.transport,this.chain){case"thor":{this.ledgerApp=L||!this.ledgerApp?new I(this.transport):this.ledgerApp;break}case"cosmos":{let{default:_}=await import("@ledgerhq/hw-app-cosmos");this.ledgerApp=L||!this.ledgerApp?new _(this.transport):this.ledgerApp}}return this.ledgerApp}catch(_){throw new t("wallet_ledger_connection_error",_)}};validateResponse=(L,_)=>{switch(L){case o.NoError:return;case o.LockedDevice:throw new t("wallet_ledger_device_locked",{message:`Ledger is locked: ${_}`});case o.TC_NotFound:throw new t("wallet_ledger_device_not_found");default:{console.error(`Ledger error: ${L} ${_}`);break}}}}class n extends l{pubKey=null;derivationPath;constructor(L=o0.GAIA){super();this.chain="cosmos",this.derivationPath=t0(L)}connect=async()=>{await this.checkOrCreateTransportAndLedger(!0);let{publicKey:L,address:_}=await this.getAddressAndPubKey();return this.pubKey=Buffer.from(L,"hex").toString("base64"),_};getAddressAndPubKey=async()=>{return await this.checkOrCreateTransportAndLedger(!0),await this.ledgerApp.getAddress(this.derivationPath,this.chain)};signTransaction=async(L,_="0")=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:O,error_message:B,signature:G}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(O,B),[{pub_key:{type:"tendermint/PubKeySecp256k1",value:this.pubKey},sequence:_,signature:G}]};signAmino=async(L,_)=>{await this.checkOrCreateTransportAndLedger(!0);let O=await this.getAccounts();if(O.findIndex((Q)=>Q.address===L)===-1)throw new Error(`Address ${L} not found in wallet`);let{encodeSecp256k1Signature:G,serializeSignDoc:j}=await import("@cosmjs/amino"),{Secp256k1Signature:X}=await import("@cosmjs/crypto"),F=j(_),J=await this.ledgerApp.sign(this.derivationPath,F);this.validateResponse(J.return_code,J.error_message);let W=X.fromDer(J.signature).toFixedLength();return{signed:_,signature:G(O[0].pubkey,W)}};getAccounts=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.getAddressAndPubKey();return[{address:L.address,algo:"secp256k1",pubkey:Buffer.from(L.publicKey,"hex")}]}}import{ChainId as w,NetworkDerivationPath as n0,derivationPathToString as a0}from"@swapkit/helpers";import{AbstractSigner as s0}from"ethers";class y extends s0{chainId=w.Ethereum;derivationPath="";ledgerApp=null;ledgerTimeout=50000;constructor({provider:L,derivationPath:_=n0.OP,chainId:O=w.Optimism}){super(L);this.chainId=O||w.Ethereum,this.derivationPath=typeof _==="string"?_:a0(_),Object.defineProperty(this,"provider",{enumerable:!0,value:L||null,writable:!1})}connect=(L)=>new y({provider:L,derivationPath:this.derivationPath,chainId:this.chainId});checkOrCreateTransportAndLedger=async()=>{if(this.ledgerApp)return;await this.createTransportAndLedger()};createTransportAndLedger=async()=>{let L=await N(),{default:_}=await import("@ledgerhq/hw-app-eth");this.ledgerApp=new _(L)};getAddress=async()=>{let L=await this.getAddressAndPubKey();if(!L)throw new Error("Could not get Address");return L.address};getAddressAndPubKey=async()=>{return await this.createTransportAndLedger(),this.ledgerApp?.getAddress(this.derivationPath)};showAddressAndPubKey=async()=>{return await this.createTransportAndLedger(),this.ledgerApp?.getAddress(this.derivationPath,!0)};signMessage=async(L)=>{let{Signature:_}=await import("ethers");await this.createTransportAndLedger();let O=await this.ledgerApp?.signPersonalMessage(this.derivationPath,L);if(!O)throw new Error("Signing failed");return O.r=`0x${O.r}`,O.s=`0x${O.s}`,_.from(O).serialized};sendTransaction=async(L)=>{if(!this.provider)throw new Error("No provider set");let _=await this.signTransaction(L);return await this.provider.broadcastTransaction(_)};signTypedData(){throw new Error("Method not implemented.")}signTransaction=async(L)=>{let{Transaction:_}=await import("ethers");await this.createTransportAndLedger();let O=await this.provider?.getTransactionCount(L.from||await this.getAddress()),B={chainId:L.chainId||this.chainId,data:L.data,gasLimit:L.gasLimit,...L.gasPrice&&{gasPrice:L.gasPrice},...!L.gasPrice&&L.maxFeePerGas&&{maxFeePerGas:L.maxFeePerGas,maxPriorityFeePerGas:L.maxPriorityFeePerGas},nonce:L.nonce!==void 0?Number((L.nonce||O||0).toString()):O,to:L.to?.toString(),value:L.value,type:L.type&&!Number.isNaN(L.type)?L.type:L.maxFeePerGas?2:0},G=_.from(B).unsignedSerialized.slice(2),{ledgerService:j}=await import("@ledgerhq/hw-app-eth"),X=await j.resolveTransaction(G,{},{externalPlugins:!0,erc20:!0}),F=await this.ledgerApp?.signTransaction(this.derivationPath,G,X);if(!F)throw new Error("Could not sign transaction");let{r:J,s:W,v:Q}=F;return _.from({...B,signature:{v:Number(BigInt(Q)),r:`0x${J}`,s:`0x${W}`}}).serialized}}var $0=({provider:L,derivationPath:_})=>new y({chainId:w.Ethereum,provider:L,derivationPath:_}),Q0=({provider:L,derivationPath:_})=>new y({chainId:w.Avalanche,provider:L,derivationPath:_}),Y0=({provider:L,derivationPath:_})=>new y({chainId:w.BinanceSmartChain,provider:L,derivationPath:_}),Z0=({provider:L,derivationPath:_})=>new y({chainId:w.Arbitrum,provider:L,derivationPath:_}),H0=({provider:L,derivationPath:_})=>new y({chainId:w.Polygon,provider:L,derivationPath:_}),m0=({provider:L,derivationPath:_})=>new y({chainId:w.Optimism,provider:L,derivationPath:_}),M0=({provider:L,derivationPath:_})=>new y({chainId:w.Base,provider:L,derivationPath:_});import{base64 as e0}from"@scure/base";import{NetworkDerivationPath as L2}from"@swapkit/helpers";import{base64 as r0}from"@scure/base";var a=(L)=>{if(L.length<64)throw new Error("Invalid Signature: Too short");if(L[0]!==48)throw new Error("Invalid Ledger Signature TLV encoding: expected first byte 0x30");if(L[1]+2!==L.length)throw new Error("Invalid Signature: signature length does not match TLV");if(L[2]!==2)throw new Error("Invalid Ledger Signature TLV encoding: expected length type 0x02");let _=L[3],O=L.slice(4,_+4);if(O.length===33&&O[0]===0)O=O.slice(1,33);else if(O.length===33)throw new Error('Invalid signature: "r" too long');while(O.length<32)O.unshift(0);if(L[_+4]!==2)throw new Error("Invalid Ledger Signature TLV encoding: expected length type 0x02");let B=L[_+5];if(4+_+2+B!==L.length)throw new Error("Invalid Ledger Signature: TLV byte lengths do not match message length");let G=L.slice(_+6,L.length);if(G.length===33&&G[0]===0)G=G.slice(1,33);else if(G.length===33)throw new Error('Invalid signature: "s" too long');while(G.length<32)G.unshift(0);if(O.length!==32||G.length!==32)throw new Error("Invalid signatures: must be 32 bytes each");return r0.encode(Buffer.concat([O,G]))};class s extends l{pubKey=null;derivationPath;constructor(L=L2.THOR){super();this.chain="thor",this.derivationPath=L}get pubkey(){return this.pubKey}connect=async()=>{await this.checkOrCreateTransportAndLedger();let{compressed_pk:L,bech32_address:_}=await this.getAddressAndPubKey();return this.pubKey=e0.encode(L),_};getAddressAndPubKey=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.ledgerApp.getAddressAndPubKey(this.derivationPath,this.chain);return this.validateResponse(L.return_code,L.error_message),L};showAddressAndPubKey=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.ledgerApp.showAddressAndPubKey(this.derivationPath,this.chain);return this.validateResponse(L.return_code,L.error_message),L};signTransaction=async(L,_="0")=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:O,error_message:B,signature:G}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(O,B),[{pub_key:{type:"tendermint/PubKeySecp256k1",value:this.pubKey},sequence:_,signature:a(G)}]};sign=async(L)=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:_,error_message:O,signature:B}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(_,O),a(B)}}import{SwapKitError as T0,derivationPathToString as _2,getWalletFormatFor as O2}from"@swapkit/helpers";var G2=async({psbt:L,inputUtxos:_,btcApp:O,derivationPath:B},G)=>{let{Transaction:j}=await import("bitcoinjs-lib"),X=_.map((T)=>{let D=j.fromHex(T.txHex||"");return[O.splitTransaction(D.toHex(),D.hasWitnesses()),T.index,void 0,void 0]}),F=L.data.globalMap.unsignedTx.toBuffer().toString("hex"),J=O.splitTransaction(F,!0),W=O.serializeTransactionOutputs(J).toString("hex"),Q={additionals:["bech32"],associatedKeysets:X.map(()=>B),inputs:X,outputScriptHex:W,segwit:!0,useTrustedInputForSegwit:!0};return O.createPaymentTransaction({...Q,...G})},V=({chain:L,additionalSignParams:_})=>{let O,B=null;async function G(X=!0){if(X&&!O)new T0("wallet_ledger_connection_error",{message:`Ledger connection failed:
|
|
1
|
+
import{a as z0}from"../../chunk-6ndrbmhg.js";import{c as Y,d as Z}from"../../chunk-p1kdg37m.js";import{Chain as $,ChainId as F2,FeeOption as X2,SKConfig as r,StagenetChain as J2,WalletOption as N0,createWallet as W2,filterSupportedChains as $2}from"@swapkit/helpers";import{Chain as m,SwapKitError as c0,WalletOption as u0}from"@swapkit/helpers";var S=async({chain:L,ledgerClient:_})=>{if(!_)return"";switch(L){case m.Cosmos:case m.THORChain:return _.connect();case m.Ethereum:case m.BinanceSmartChain:case m.Avalanche:case m.Polygon:case m.Arbitrum:case m.Optimism:case m.Base:return _.getAddress();case m.Bitcoin:case m.BitcoinCash:case m.Dash:case m.Dogecoin:case m.Litecoin:{let O=_;await O.connect();let B=await O.getAddress();return L===m.BitcoinCash?B.replace("bitcoincash:",""):B}default:throw new c0("wallet_chain_not_supported",{wallet:u0.LEDGER,chain:L})}};import{Chain as H,SwapKitError as B2,WalletOption as j2}from"@swapkit/helpers";import{NetworkDerivationPath as o0,derivationPathToString as t0}from"@swapkit/helpers";import{LedgerErrorCode as o,NetworkDerivationPath as p0,SwapKitError as t}from"@swapkit/helpers";var E=85,c=250;var K={GET_VERSION:0,INS_PUBLIC_KEY_SECP256K1:1,SIGN_SECP256K1:2,GET_ADDR_SECP256K1:4},P={INIT:0,ADD:1,LAST:2},u={ONLY_RETRIEVE:0,SHOW_ADDRESS_IN_DEVICE:1},C={JSON:0},R={NoError:36864},B0={1:"U2F: Unknown",2:"U2F: Bad request",3:"U2F: Configuration unsupported",4:"U2F: Device Ineligible",5:"U2F: Timeout",14:"Timeout",36864:"No errors",36865:"Device is busy",26626:"Error deriving keys",25600:"Execution Error",26368:"Wrong Length",27010:"Empty Buffer",27011:"Output buffer too small",27012:"Data is invalid",27013:"Conditions not satisfied",27014:"Transaction rejected",27264:"Bad key handle",27392:"Invalid P1/P2",27904:"Instruction not supported",28160:"App does not seem to be open",28416:"Unknown error",28417:"Sign/verify error"};function U(L){if(L in B0)return B0[L];return`Unknown Status Code: ${L}`}function h0(L){return typeof L==="object"&&L!==null&&!Array.isArray(L)&&!(L instanceof Date)}function M(L){if(L){if(h0(L)){if(Object.prototype.hasOwnProperty.call(L,"statusCode"))return{return_code:L.statusCode,error_message:U(L.statusCode)};if(Object.prototype.hasOwnProperty.call(L,"return_code")&&Object.prototype.hasOwnProperty.call(L,"error_message"))return L}return{return_code:65535,error_message:L.toString()}}return{return_code:65535,error_message:L.toString()}}async function h(L){return L.send(85,K.GET_VERSION,0,0).then((_)=>{let O=_.slice(-2),B=O[0]*256+O[1],G=0;if(_.length>=9)G=(_[5]<<24)+(_[6]<<16)+(_[7]<<8)+(_[8]<<0);return{return_code:B,error_message:U(B),test_mode:_[0]!==0,major:_[1],minor:_[2],patch:_[3],device_locked:_[4]===1,target_id:G.toString(16)}},M)}function j0(L){if(L==null||L.length<3)throw new Error("Invalid path.");if(L.length>10)throw new Error("Invalid path. Length should be <= 10");let _=Buffer.alloc(1+4*L.length);_.writeUInt8(L.length,0);for(let O=0;O<L.length;O+=1){let B=L[O]||0;if(O<3)B|=2147483648;_.writeInt32LE(B,1+O*4)}return _}async function d(L,_,O,B,G=C.JSON){return L.transport.send(E,K.SIGN_SECP256K1,_,G,B,[R.NoError,27012,27264]).then((j)=>{let X=j.slice(-2),F=X[0]*256+X[1],J=U(F);if(F===27264||F===27012)J=`${J} : ${j.slice(0,j.length-2).toString("ascii")}`;let W=null;if(j.length>2)W=j.slice(0,j.length-2);return{signature:W,return_code:F,error_message:J}},M)}function d0(L){if(L.length!==65)throw new Error("decompressed public key length should be 65 bytes");let _=L.slice(33,65),O=Buffer.from([2+(_[_.length-1]&1)]);return Buffer.concat([O,L.slice(1,33)])}async function F0(L,_){return L.transport.send(E,K.INS_PUBLIC_KEY_SECP256K1,0,0,_,[R.NoError]).then((O)=>{let B=O.slice(-2),G=B[0]*256+B[1],j=Buffer.from(O.slice(0,65));return{pk:j,compressed_pk:d0(j),return_code:G,error_message:U(G)}},M)}function X0(L){if(!L||L.length!==5)throw new Error("Invalid path.");let _=Buffer.alloc(20);return _.writeUInt32LE(2147483648+L[0],0),_.writeUInt32LE(2147483648+L[1],4),_.writeUInt32LE(2147483648+L[2],8),_.writeUInt32LE(L[3],12),_.writeUInt32LE(L[4],16),_}function J0(L,_,O,B,G=C.JSON){let j=P.ADD;if(_===1)j=P.INIT;if(_===O)j=P.LAST;return d(L,j,0,B,G)}async function W0(L,_){return L.transport.send(E,K.GET_ADDR_SECP256K1,0,0,_,[R.NoError]).then((O)=>{let B=O.slice(-2),G=B[0]*256+B[1];return{pk:"OBSOLETE PROPERTY",compressed_pk:Buffer.from(O.slice(0,33)),return_code:G,error_message:U(G)}},M)}class I{transport;versionResponse;constructor(L){if(!L)throw new Error("Transport has not been defined");this.transport=L}static serializeHRP(L){if(L==null||L.length<3||L.length>83)throw new Error("Invalid HRP");let _=Buffer.alloc(1+L.length);return _.writeUInt8(L.length,0),_.write(L,1),_}async serializePath(L){if(this.versionResponse=await h(this.transport),this.versionResponse.return_code!==R.NoError)throw this.versionResponse;switch(this.versionResponse.major){case 1:return j0(L);case 2:return X0(L);default:return Buffer.alloc(0)}}async signGetChunks(L,_){let O=await this.serializePath(L),B=[];B.push(O);for(let G=0;G<_.length;G+=c){let j=G+c;if(G>_.length)j=_.length;B.push(_.slice(G,j))}return B}async getVersion(){try{return this.versionResponse=await h(this.transport),this.versionResponse}catch(L){return M(L)}}async appInfo(){return this.transport.send(176,1,0,0).then((L)=>{let _=L.slice(-2),O=_[0]*256+_[1],B="",G="",j=0,X=0;if(L[0]!==1)return{return_code:36865,error_message:"response format ID not recognized"};let F=L[1];B=L.slice(2,2+F).toString("ascii");let J=2+F,W=L[J];J+=1,G=L.slice(J,J+W).toString("ascii"),J+=W;let Q=L[J];return J+=1,j=Q,X=L[J],{return_code:O,error_message:U(O),appName:B,appVersion:G,flagLen:j,flagsValue:X,flag_recovery:(X&1)!==0,flag_signed_mcu_code:(X&2)!==0,flag_onboarded:(X&4)!==0,flag_pin_validated:(X&128)!==0}},M)}async deviceInfo(){return this.transport.send(224,1,0,0,Buffer.from([]),[R.NoError,28160]).then((L)=>{let _=L.slice(-2),O=_[0]*256+_[1];if(O===28160)return{return_code:O,error_message:"This command is only available in the Dashboard"};let B=L.slice(0,4).toString("hex"),G=4,j=L[G];G+=1;let X=L.slice(G,G+j).toString();G+=j;let F=L[G];G+=1;let J=L.slice(G,G+F).toString("hex");G+=F;let W=L[G];G+=1;let Q=L.slice(G,G+W);if(Q[W-1]===0)Q=L.slice(G,G+W-1);let T=Q.toString();return{return_code:O,error_message:U(O),targetId:B,seVersion:X,flag:J,mcuVersion:T}},M)}async publicKey(L){try{let _=await this.serializePath(L);switch(this.versionResponse.major){case 1:return F0(this,_);case 2:{let O=Buffer.concat([I.serializeHRP("thor"),_]);return W0(this,O)}default:return{return_code:25600,error_message:"App Version is not supported"}}}catch(_){return M(_)}}async getAddressAndPubKey(L,_,O=!1){return this.serializePath(L).then((B)=>{let G=Buffer.concat([I.serializeHRP(_),B]);return this.transport.send(E,K.GET_ADDR_SECP256K1,O?u.SHOW_ADDRESS_IN_DEVICE:u.ONLY_RETRIEVE,0,G,[R.NoError]).then((j)=>{let X=j.slice(-2),F=X[0]*256+X[1],J=Buffer.from(j.slice(0,33));return{bech32_address:Buffer.from(j.slice(33,-2)).toString(),compressed_pk:J,return_code:F,error_message:U(F)}},M)}).catch((B)=>M(B))}showAddressAndPubKey(L,_){return this.getAddressAndPubKey(L,_,!0)}signSendChunk(L,_,O,B=C.JSON){switch(this.versionResponse.major){case 1:return d(this,L,_,O,B);case 2:return J0(this,L,_,O,B);default:return{return_code:25600,error_message:"App Version is not supported"}}}async sign(L,_,O=C.JSON){let B=Buffer.from(_),G=[],j;try{G=await this.signGetChunks(L,B),j=await this.signSendChunk(1,G.length,G[0],O)}catch(F){M(F)}let X={return_code:j.return_code,error_message:j.error_message,signature:null};for(let F=1;F<G.length;F+=1)if(X=await this.signSendChunk(1+F,G.length,G[F],O),X.return_code!==R.NoError)break;return{return_code:X.return_code,error_message:X.error_message,signature:X.signature}}}import{SwapKitError as i}from"@swapkit/helpers";var p=()=>navigator?.usb,i0=async()=>{let L=p();if(typeof L?.getDevices!=="function")return[];let{ledgerUSBVendorId:_}=await import("@ledgerhq/devices"),B=(await L?.getDevices()).filter((G)=>G.vendorId===_);if(B.length>0)return B[0];return L?.requestDevice({filters:[{vendorId:_}]})},N=async()=>{let L=await i0();if(!L)throw new i("wallet_ledger_device_not_found");if(await L.open(),L.configuration===null)await L.selectConfiguration(1);try{await L.reset()}catch{}let _=L.configurations[0].interfaces.find(({alternates:F})=>F.some(({interfaceClass:J})=>J===255));if(!_)throw await L.close(),new i("wallet_ledger_connection_error");try{await L.claimInterface(_.interfaceNumber)}catch(F){throw await L.close(),new i("wallet_ledger_connection_claimed",F)}let{default:O}=await import("@ledgerhq/hw-transport-webusb");if(!await O.isSupported())throw new Error("WebUSB not supported");let{DisconnectedDevice:G}=await import("@ledgerhq/errors"),j=new O(L,_.interfaceNumber),X=(F)=>{if(L===F.device)p()?.removeEventListener("disconnect",X),j._emitDisconnect(new G)};return p()?.addEventListener("disconnect",X),j};class l{ledgerTimeout=50000;derivationPath=p0.GAIA;transport;ledgerApp;chain="thor";checkOrCreateTransportAndLedger=async(L=!1)=>{if(!L&&this.transport&&this.ledgerApp)return;try{switch(this.transport=L||!this.transport?await N():this.transport,this.chain){case"thor":{this.ledgerApp=L||!this.ledgerApp?new I(this.transport):this.ledgerApp;break}case"cosmos":{let{default:_}=await import("@ledgerhq/hw-app-cosmos");this.ledgerApp=L||!this.ledgerApp?new _(this.transport):this.ledgerApp}}return this.ledgerApp}catch(_){throw new t("wallet_ledger_connection_error",_)}};validateResponse=(L,_)=>{switch(L){case o.NoError:return;case o.LockedDevice:throw new t("wallet_ledger_device_locked",{message:`Ledger is locked: ${_}`});case o.TC_NotFound:throw new t("wallet_ledger_device_not_found");default:{console.error(`Ledger error: ${L} ${_}`);break}}}}class n extends l{pubKey=null;derivationPath;constructor(L=o0.GAIA){super();this.chain="cosmos",this.derivationPath=t0(L)}connect=async()=>{await this.checkOrCreateTransportAndLedger(!0);let{publicKey:L,address:_}=await this.getAddressAndPubKey();return this.pubKey=Buffer.from(L,"hex").toString("base64"),_};getAddressAndPubKey=async()=>{return await this.checkOrCreateTransportAndLedger(!0),await this.ledgerApp.getAddress(this.derivationPath,this.chain)};signTransaction=async(L,_="0")=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:O,error_message:B,signature:G}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(O,B),[{pub_key:{type:"tendermint/PubKeySecp256k1",value:this.pubKey},sequence:_,signature:G}]};signAmino=async(L,_)=>{await this.checkOrCreateTransportAndLedger(!0);let O=await this.getAccounts();if(O.findIndex((Q)=>Q.address===L)===-1)throw new Error(`Address ${L} not found in wallet`);let{encodeSecp256k1Signature:G,serializeSignDoc:j}=await import("@cosmjs/amino"),{Secp256k1Signature:X}=await import("@cosmjs/crypto"),F=j(_),J=await this.ledgerApp.sign(this.derivationPath,F);this.validateResponse(J.return_code,J.error_message);let W=X.fromDer(J.signature).toFixedLength();return{signed:_,signature:G(O[0].pubkey,W)}};getAccounts=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.getAddressAndPubKey();return[{address:L.address,algo:"secp256k1",pubkey:Buffer.from(L.publicKey,"hex")}]}}import{ChainId as w,NetworkDerivationPath as n0,derivationPathToString as a0}from"@swapkit/helpers";import{AbstractSigner as s0}from"ethers";class y extends s0{chainId=w.Ethereum;derivationPath="";ledgerApp=null;ledgerTimeout=50000;constructor({provider:L,derivationPath:_=n0.OP,chainId:O=w.Optimism}){super(L);this.chainId=O||w.Ethereum,this.derivationPath=typeof _==="string"?_:a0(_),Object.defineProperty(this,"provider",{enumerable:!0,value:L||null,writable:!1})}connect=(L)=>new y({provider:L,derivationPath:this.derivationPath,chainId:this.chainId});checkOrCreateTransportAndLedger=async()=>{if(this.ledgerApp)return;await this.createTransportAndLedger()};createTransportAndLedger=async()=>{let L=await N(),{default:_}=await import("@ledgerhq/hw-app-eth");this.ledgerApp=new _(L)};getAddress=async()=>{let L=await this.getAddressAndPubKey();if(!L)throw new Error("Could not get Address");return L.address};getAddressAndPubKey=async()=>{return await this.createTransportAndLedger(),this.ledgerApp?.getAddress(this.derivationPath)};showAddressAndPubKey=async()=>{return await this.createTransportAndLedger(),this.ledgerApp?.getAddress(this.derivationPath,!0)};signMessage=async(L)=>{let{Signature:_}=await import("ethers");await this.createTransportAndLedger();let O=await this.ledgerApp?.signPersonalMessage(this.derivationPath,L);if(!O)throw new Error("Signing failed");return O.r=`0x${O.r}`,O.s=`0x${O.s}`,_.from(O).serialized};sendTransaction=async(L)=>{if(!this.provider)throw new Error("No provider set");let _=await this.signTransaction(L);return await this.provider.broadcastTransaction(_)};signTypedData(){throw new Error("Method not implemented.")}signTransaction=async(L)=>{let{Transaction:_}=await import("ethers");await this.createTransportAndLedger();let O=await this.provider?.getTransactionCount(L.from||await this.getAddress()),B={chainId:L.chainId||this.chainId,data:L.data,gasLimit:L.gasLimit,...L.gasPrice&&{gasPrice:L.gasPrice},...!L.gasPrice&&L.maxFeePerGas&&{maxFeePerGas:L.maxFeePerGas,maxPriorityFeePerGas:L.maxPriorityFeePerGas},nonce:L.nonce!==void 0?Number((L.nonce||O||0).toString()):O,to:L.to?.toString(),value:L.value,type:L.type&&!Number.isNaN(L.type)?L.type:L.maxFeePerGas?2:0},G=_.from(B).unsignedSerialized.slice(2),{ledgerService:j}=await import("@ledgerhq/hw-app-eth"),X=await j.resolveTransaction(G,{},{externalPlugins:!0,erc20:!0}),F=await this.ledgerApp?.signTransaction(this.derivationPath,G,X);if(!F)throw new Error("Could not sign transaction");let{r:J,s:W,v:Q}=F;return _.from({...B,signature:{v:Number(BigInt(Q)),r:`0x${J}`,s:`0x${W}`}}).serialized}}var $0=({provider:L,derivationPath:_})=>new y({chainId:w.Ethereum,provider:L,derivationPath:_}),Q0=({provider:L,derivationPath:_})=>new y({chainId:w.Avalanche,provider:L,derivationPath:_}),Y0=({provider:L,derivationPath:_})=>new y({chainId:w.BinanceSmartChain,provider:L,derivationPath:_}),Z0=({provider:L,derivationPath:_})=>new y({chainId:w.Arbitrum,provider:L,derivationPath:_}),H0=({provider:L,derivationPath:_})=>new y({chainId:w.Polygon,provider:L,derivationPath:_}),m0=({provider:L,derivationPath:_})=>new y({chainId:w.Optimism,provider:L,derivationPath:_}),M0=({provider:L,derivationPath:_})=>new y({chainId:w.Base,provider:L,derivationPath:_});import{base64 as e0}from"@scure/base";import{NetworkDerivationPath as L2}from"@swapkit/helpers";import{base64 as r0}from"@scure/base";var a=(L)=>{if(L.length<64)throw new Error("Invalid Signature: Too short");if(L[0]!==48)throw new Error("Invalid Ledger Signature TLV encoding: expected first byte 0x30");if(L[1]+2!==L.length)throw new Error("Invalid Signature: signature length does not match TLV");if(L[2]!==2)throw new Error("Invalid Ledger Signature TLV encoding: expected length type 0x02");let _=L[3],O=L.slice(4,_+4);if(O.length===33&&O[0]===0)O=O.slice(1,33);else if(O.length===33)throw new Error('Invalid signature: "r" too long');while(O.length<32)O.unshift(0);if(L[_+4]!==2)throw new Error("Invalid Ledger Signature TLV encoding: expected length type 0x02");let B=L[_+5];if(4+_+2+B!==L.length)throw new Error("Invalid Ledger Signature: TLV byte lengths do not match message length");let G=L.slice(_+6,L.length);if(G.length===33&&G[0]===0)G=G.slice(1,33);else if(G.length===33)throw new Error('Invalid signature: "s" too long');while(G.length<32)G.unshift(0);if(O.length!==32||G.length!==32)throw new Error("Invalid signatures: must be 32 bytes each");return r0.encode(Buffer.concat([O,G]))};class s extends l{pubKey=null;derivationPath;constructor(L=L2.THOR){super();this.chain="thor",this.derivationPath=L}get pubkey(){return this.pubKey}connect=async()=>{await this.checkOrCreateTransportAndLedger();let{compressed_pk:L,bech32_address:_}=await this.getAddressAndPubKey();return this.pubKey=e0.encode(L),_};getAddressAndPubKey=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.ledgerApp.getAddressAndPubKey(this.derivationPath,this.chain);return this.validateResponse(L.return_code,L.error_message),L};showAddressAndPubKey=async()=>{await this.checkOrCreateTransportAndLedger(!0);let L=await this.ledgerApp.showAddressAndPubKey(this.derivationPath,this.chain);return this.validateResponse(L.return_code,L.error_message),L};signTransaction=async(L,_="0")=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:O,error_message:B,signature:G}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(O,B),[{pub_key:{type:"tendermint/PubKeySecp256k1",value:this.pubKey},sequence:_,signature:a(G)}]};sign=async(L)=>{await this.checkOrCreateTransportAndLedger(!0);let{return_code:_,error_message:O,signature:B}=await this.ledgerApp.sign(this.derivationPath,L);if(!this.pubKey)throw new Error("Public Key not found");return this.validateResponse(_,O),a(B)}}import{SwapKitError as T0,derivationPathToString as _2,getWalletFormatFor as O2}from"@swapkit/helpers";var G2=async({psbt:L,inputUtxos:_,btcApp:O,derivationPath:B},G)=>{let{Transaction:j}=await import("bitcoinjs-lib"),X=_.map((T)=>{let D=j.fromHex(T.txHex||"");return[O.splitTransaction(D.toHex(),D.hasWitnesses()),T.index,void 0,void 0]}),F=L.data.globalMap.unsignedTx.toBuffer().toString("hex"),J=O.splitTransaction(F,!0),W=O.serializeTransactionOutputs(J).toString("hex"),Q={additionals:["bech32"],associatedKeysets:X.map(()=>B),inputs:X,outputScriptHex:W,segwit:!0,useTrustedInputForSegwit:!0};return O.createPaymentTransaction({...Q,...G})},V=({chain:L,additionalSignParams:_})=>{let O,B=null;async function G(X=!0){if(X&&!O)new T0("wallet_ledger_connection_error",{message:`Ledger connection failed:
|
|
2
2
|
${JSON.stringify({checkBtcApp:X,btcApp:O})}`});B||=await N()}async function j(){B=await N();let{default:X}=await import("@ledgerhq/hw-app-btc");O=new X({transport:B,currency:L})}return(X)=>{let F=typeof X==="string"?X:_2(X),J=O2(F);return{connect:async()=>{await G(!1);let{default:W}=await import("@ledgerhq/hw-app-btc");O=new W({transport:B,currency:L})},getExtendedPublicKey:async(W="84'/0'/0'",Q=76067358)=>{return await G(!1),O.getWalletXpub({path:W,xpubVersion:Q})},signTransaction:async(W,Q)=>{return await j(),G2({psbt:W,derivationPath:F,btcApp:O,inputUtxos:Q},_)},getAddress:async()=>{let{toCashAddress:W}=await import("@swapkit/toolboxes/utxo");await G(!1);let{bitcoinAddress:Q}=await O.getWalletPublicKey(F,{format:J});if(!Q)throw new T0("wallet_ledger_get_address_error",{message:`Cannot get ${L} address from ledger derivation path: ${F}`});return L==="bitcoin-cash"&&J==="legacy"?W(Q).replace(/(bchtest:|bitcoincash:)/,""):Q}}}},U0=V({chain:"bitcoin"}),w0=V({chain:"litecoin"}),R0=V({chain:"bitcoin-cash",additionalSignParams:{segwit:!1,additionals:["abc"],sigHashType:65}}),y0=V({chain:"dogecoin",additionalSignParams:{additionals:[],segwit:!1,useTrustedInputForSegwit:!1}}),D0=V({chain:"dash",additionalSignParams:{additionals:[],segwit:!1,useTrustedInputForSegwit:!1}});var f=async({chain:L,derivationPath:_})=>{switch(L){case H.THORChain:return new s(_);case H.Cosmos:return new n(_);case H.Bitcoin:return U0(_);case H.BitcoinCash:return R0(_);case H.Dash:return D0(_);case H.Dogecoin:return y0(_);case H.Litecoin:return w0(_);case H.Arbitrum:case H.Avalanche:case H.BinanceSmartChain:case H.Ethereum:case H.Optimism:case H.Polygon:case H.Base:{let{getProvider:O}=await import("@swapkit/toolboxes/evm"),B={provider:await O(L),derivationPath:_};switch(L){case H.BinanceSmartChain:return Y0(B);case H.Avalanche:return Q0(B);case H.Arbitrum:return Z0(B);case H.Optimism:return m0(B);case H.Polygon:return H0(B);case H.Base:return M0(B);default:return $0(B)}}default:throw new B2("wallet_chain_not_supported",{wallet:j2.LEDGER,chain:L})}};var Q2=W2({name:"connectLedger",supportedChains:[$.Arbitrum,$.Avalanche,$.Base,$.BinanceSmartChain,$.Bitcoin,$.BitcoinCash,$.Cosmos,$.Dash,$.Dogecoin,$.Ethereum,$.Litecoin,$.Optimism,$.Polygon,$.THORChain],walletType:N0.LEDGER,connect:({addChain:L,supportedChains:_,walletType:O})=>async function B(G,j){let[X]=$2({chains:G,supportedChains:_,walletType:O});if(!X)return!1;let F=await H2({chain:X,derivationPath:j});return L({...F,chain:X,walletType:N0.LEDGER}),!0}}),X1=z0(Q2);function Y2(L,_="t"){if(!L?.includes("=:"))return L;let O=L.includes(`:${_}:`)?L.split(`:${_}:`)[0]:L;return O?.substring(0,O.lastIndexOf(":"))}function k(L){if(Array.isArray(L))return L.forEach((B,G)=>{L[G]=k(B)}),L;if(typeof L!=="object")return L;let _={},O=Object.keys(L).sort();for(let B of O)_[B]=k(L[B]);return _}function Z2(L){return JSON.stringify(k(L))}async function H2({chain:L,derivationPath:_}){switch(L){case $.BitcoinCash:case $.Bitcoin:case $.Dash:case $.Dogecoin:case $.Litecoin:{let{getUtxoToolbox:O}=await import("@swapkit/toolboxes/utxo"),B=await O(L),G=await f({chain:L,derivationPath:_}),j=await S({chain:L,ledgerClient:G});return{...B,address:j,transfer:async(F)=>{let J=F.feeRate||(await B.getFeeRates())[X2.Average],W=[$.Bitcoin].includes(L)?F.memo:Y2(F.memo),{psbt:Q,inputs:T}=await B.createTransaction({...F,feeRate:J,memo:W,sender:j,fetchTxHex:!0}),D=await G.signTransaction(Q,T);return await B.broadcastTx(D)}}}case $.Ethereum:case $.Avalanche:case $.Arbitrum:case $.Optimism:case $.Polygon:case $.BinanceSmartChain:case $.Base:{let{getEvmToolbox:O}=await import("@swapkit/toolboxes/evm"),B=await f({chain:L,derivationPath:_}),G=await S({chain:L,ledgerClient:B});return{...await O(L,{signer:B}),address:G}}case $.Cosmos:{let{createSigningStargateClient:O,getMsgSendDenom:B,getCosmosToolbox:G}=await import("@swapkit/toolboxes/cosmos"),j=await G($.Cosmos),X=await f({chain:L,derivationPath:_}),F=await S({chain:L,ledgerClient:X});return{...j,address:F,transfer:async({assetValue:W,recipient:Q,memo:T})=>{if(!W)throw new Error("invalid asset");let D={amount:[{amount:W.getBaseValue("string"),denom:B(`u${W.symbol}`).toLowerCase()}],fromAddress:F,toAddress:Q},q=await O(r.get("rpcUrls")[L],X,"0.007uatom"),{transactionHash:A}=await q.signAndBroadcast(F,[{typeUrl:"/cosmos.bank.v1beta1.MsgSend",value:D}],2,T);return A}}}case $.THORChain:{let{SignMode:O}=await import("cosmjs-types/cosmos/tx/signing/v1beta1/signing.js"),{TxRaw:B}=await import("cosmjs-types/cosmos/tx/v1beta1/tx.js"),{encodePubkey:G,makeAuthInfoBytes:j}=await import("@cosmjs/proto-signing"),{createStargateClient:X,buildEncodedTxBody:F,getCosmosToolbox:J,buildAminoMsg:W,getDefaultChainFee:Q,fromBase64:T,parseAminoMessageForDirectSigning:D}=await import("@swapkit/toolboxes/cosmos"),q=await J(L),A=await f({chain:L,derivationPath:_}),b=await S({chain:L,ledgerClient:A}),x=Q(L),{pubkey:e,signTransaction:K0,sign:q0}=A,L0=async({memo:z="",assetValue:_0,...S0})=>{let O0=await q.getAccount(b);if(!O0)throw new Error("invalid account");if(!_0)throw new Error("invalid asset");if(!e)throw new Error("Account pubkey not found");let{accountNumber:E0,sequence:C0}=O0,v=(C0||0).toString(),G0=k([W({sender:b,assetValue:_0,memo:z,...S0})]),f0=Z2({account_number:E0?.toString(),chain_id:F2.THORChain,fee:x,memo:z,msgs:G0,sequence:v}),g=await K0(f0,v);if(!g)throw new Error("tx signing failed");let I0=G({type:"tendermint/PubKeySecp256k1",value:e}),l0=G0.map(D),V0=await F({msgs:l0,chain:L,memo:z}),A0=j([{pubkey:I0,sequence:Number(v)}],x.amount,Number.parseInt(x.gas),void 0,void 0,O.SIGN_MODE_LEGACY_AMINO_JSON),P0=g?.[0]?.signature?T(g[0].signature):Uint8Array.from([]),k0=B.fromPartial({bodyBytes:V0,authInfoBytes:A0,signatures:[P0]}),b0=B.encode(k0).finish(),{isStagenet:x0}=r.get("envs"),v0=await X(r.get("rpcUrls")[x0?J2.THORChain:$.THORChain]),{transactionHash:g0}=await v0.broadcastTx(b0);return g0};return{...q,address:b,deposit:(z)=>L0(z),transfer:(z)=>L0(z),signMessage:q0}}default:throw new Error("Unsupported chain")}}export{Q2 as ledgerWallet,X1 as LEDGER_SUPPORTED_CHAINS};
|
|
3
3
|
|
|
4
4
|
//# debugId=BBF071F272C9653E64756E2164756E21
|
package/dist/src/okx/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as f}from"../../chunk-
|
|
1
|
+
import{a as f}from"../../chunk-6ndrbmhg.js";import{c,d}from"../../chunk-p1kdg37m.js";import{Chain as i,WalletOption as E,createWallet as P,filterSupportedChains as S}from"@swapkit/helpers";import{Chain as a,ChainId as p,SKConfig as h,prepareNetworkSwitch as k,switchEVMWalletNetwork as C}from"@swapkit/helpers";var b=()=>async({from:n,recipient:o,amount:e,asset:r,memo:t})=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new Error("No cosmos okxwallet found");let{createSigningStargateClient:l}=await import("@swapkit/toolboxes/cosmos"),{keplr:s}=window.okxwallet,w=s?.getOfflineSignerOnlyAmino(p.Cosmos),m=await l(h.get("rpcUrls").GAIA,w),g=[{denom:r?.symbol==="MUON"?"umuon":"uatom",amount:e.amount().toString()}],{transactionHash:x}=await m.sendTokens(n,o,g,1.6,t);return x};async function y({walletProvider:n,chain:o}){let{getEvmToolbox:e}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:r}=await import("ethers");if(!n)throw new Error("Requested web3 wallet is not installed");let t=new r(n,"any"),l=await t.getSigner(),s=await e(o,{provider:t,signer:l});try{if(o!==a.Ethereum&&"getNetworkParams"in s)await C(t,o,s.getNetworkParams())}catch(w){throw new Error(`Failed to add/switch ${o} network: ${o}`)}return k({toolbox:s,provider:t,chain:o})}async function u(n){switch(n){case a.Ethereum:case a.Base:case a.Avalanche:case a.Arbitrum:case a.Optimism:case a.Polygon:case a.BinanceSmartChain:{if(!(window.okxwallet&&("send"in window.okxwallet)))throw new Error("No okxwallet found");let o=await y({chain:n,walletProvider:window.okxwallet}),e=(await window.okxwallet.send("eth_requestAccounts",[])).result[0];return{...o,address:e}}case a.Bitcoin:{if(!(window.okxwallet&&("bitcoin"in window.okxwallet)))throw new Error("No bitcoin okxwallet found");let{Psbt:o}=await import("bitcoinjs-lib"),{getUtxoToolbox:e}=await import("@swapkit/toolboxes/utxo"),{bitcoin:r}=window.okxwallet,t=(await r.connect()).address;return{...await e(n,{signer:{signTransaction:async(w)=>{let m=await r.signPsbt(w.toHex(),{from:t,type:"list"});return o.fromHex(m)},getAddress:async()=>Promise.resolve(t)}}),address:t}}case a.Cosmos:{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new Error("No bitcoin okxwallet found");let{keplr:o}=window.okxwallet;await o.enable(p.Cosmos);let e=await o.getOfflineSignerOnlyAmino(p.Cosmos).getAccounts();if(!e?.[0])throw new Error("No cosmos account found");let{getCosmosToolbox:r}=await import("@swapkit/toolboxes/cosmos"),[{address:t}]=e;return{...r(a.Cosmos),address:t,transfer:b()}}default:throw new Error(`No wallet for chain ${n}`)}}var A=P({name:"connectOkx",walletType:E.OKX,supportedChains:[i.Arbitrum,i.Avalanche,i.Base,i.BinanceSmartChain,i.Bitcoin,i.Cosmos,i.Ethereum,i.Optimism,i.Polygon],connect:({addChain:n,supportedChains:o,walletType:e})=>async function r(t){let l=S({chains:t,supportedChains:o,walletType:e});return await Promise.all(l.map(async(s)=>{let w=await u(s),m=await w.getAddress()||"";n({...w,address:m,chain:s,walletType:e})})),!0}}),T=f(A);export{A as okxWallet,T as OKX_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=512295FA2983091F64756E2164756E21
|
package/dist/src/onekey/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as k}from"../../chunk-
|
|
1
|
+
import{a as k}from"../../chunk-6ndrbmhg.js";import{c as l,d as p}from"../../chunk-p1kdg37m.js";import{Chain as e,SKConfig as b,SwapKitError as r,WalletOption as u,addEVMWalletNetwork as A,createWallet as S,filterSupportedChains as E,prepareNetworkSwitch as O}from"@swapkit/helpers";async function B(t){switch(t){case e.Bitcoin:{if(!window.$onekey?.btc)throw new r({errorKey:"wallet_onekey_not_found",info:{chain:t}});let{Psbt:s}=await import("bitcoinjs-lib"),{getUtxoToolbox:a}=await import("@swapkit/toolboxes/utxo"),{signTransaction:w,getAddress:n,AddressPurpose:m,BitcoinNetworkType:i}=await import("sats-connect"),o="",c=()=>new Promise((d)=>d(window.$onekey?.btc)),g={getProvider:c,payload:{purposes:[m.Payment],message:"Address for receiving and sending payments",network:{type:i.Mainnet}},onFinish:(d)=>{if(d.addresses[0]?.address)o=d.addresses[0].address},onCancel:()=>{throw new r("wallet_connection_rejected_by_user")}};await n(g);async function y(d){let _,P={getProvider:c,payload:{message:"Sign transaction",network:{type:i.Mainnet},psbtBase64:d.toBase64(),broadcast:!1,inputsToSign:[{address:o,signingIndexes:d.txInputs.map((f,h)=>h)}]},onFinish:(f)=>{_=s.fromBase64(f.psbtBase64)},onCancel:()=>{throw new r("wallet_connection_rejected_by_user")}};if(await w(P),!_)throw new r("wallet_onekey_sign_transaction_error");return _}return{...await a(t,{signer:{signTransaction:y,getAddress:()=>Promise.resolve(o)}}),address:o}}case e.Solana:{if(!window.$onekey?.sol)throw new r({errorKey:"wallet_onekey_not_found",info:{chain:t}});let{getSolanaToolbox:s}=await import("@swapkit/toolboxes/solana"),a=window.$onekey.sol,w=await a.getAddress();return{...s({signer:a}),address:w}}case e.Arbitrum:case e.Avalanche:case e.Base:case e.BinanceSmartChain:case e.Ethereum:case e.Optimism:case e.Polygon:{let{getProvider:s,getEvmToolbox:a}=await import("@swapkit/toolboxes/evm");if(!window.$onekey?.ethereum)throw new r({errorKey:"wallet_onekey_not_found",info:{chain:t}});let{BrowserProvider:w}=await import("ethers"),n=new w(window.$onekey.ethereum,"any"),m=b.get("rpcUrls")[t];await n.send("eth_requestAccounts",[]);let i=await s(t,m),o=await n.getSigner(),c=await o.getAddress(),g=await a(t,{provider:i,signer:o});try{if(t!==e.Ethereum){let y=g.getNetworkParams();await A(n,y)}}catch(y){throw new r({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:t,error:y}})}return{address:c,...O({toolbox:g,chain:t,provider:n})}}default:throw new r({errorKey:"wallet_chain_not_supported",info:{chain:t,wallet:u.ONEKEY}})}}var v=S({name:"connectOnekeyWallet",walletType:u.ONEKEY,supportedChains:[e.Arbitrum,e.Avalanche,e.Base,e.BinanceSmartChain,e.Bitcoin,e.Ethereum,e.Optimism,e.Polygon,e.Solana],connect:({addChain:t,walletType:s,supportedChains:a})=>async function w(n){if(!window.$onekey)throw new r({errorKey:"wallet_onekey_not_found",info:{wallet:u.ONEKEY}});let m=E({chains:n,supportedChains:a,walletType:s});return await Promise.all(m.map(async(i)=>{let o=await B(i),c=await o.getAddress()||"F";t({...o,chain:i,address:c,walletType:s})})),!0}}),N=k(v);export{v as onekeyWallet,N as ONEKEY_WALLET_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=6FE71A965F54F3FD64756E2164756E21
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as f}from"../../chunk-
|
|
1
|
+
import{a as f}from"../../chunk-6ndrbmhg.js";import{c as l,d}from"../../chunk-p1kdg37m.js";import{Chain as i,SwapKitError as r,WalletOption as _,createWallet as S,filterSupportedChains as C}from"@swapkit/helpers";var A=S({name:"connectPhantom",walletType:_.PHANTOM,supportedChains:[i.Bitcoin,i.Ethereum,i.Solana],connect:({addChain:s,supportedChains:c,walletType:o})=>async function n(e){let a=C({chains:e,supportedChains:c,walletType:o});try{return await Promise.all(a.map(async(t)=>{let{address:h,...w}=await v(t);s({...w,chain:t,address:h,walletType:o})})),!0}catch(t){if(t instanceof r)throw t;throw new r("wallet_connection_rejected_by_user",t)}}}),N=f(A);async function v(s){let c=window?.phantom;switch(s){case i.Bitcoin:{let o=c?.bitcoin;if(!o?.isPhantom)throw new r("wallet_phantom_not_found");let{getUtxoToolbox:n}=await import("@swapkit/toolboxes/utxo"),[{address:e}]=await o.requestAccounts();return{...await n(s),address:e}}case i.Ethereum:{let{getEvmToolbox:o}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:n}=await import("ethers"),e=new n(c?.ethereum,"any"),[a]=await e.send("eth_requestAccounts",[]),t=await e.getSigner();return{...await o(s,{signer:t,provider:e}),address:a}}case i.Solana:{let{getSolanaToolbox:o}=await import("@swapkit/toolboxes/solana"),n=c?.solana;if(!n?.isPhantom)throw new r("wallet_phantom_not_found");let a=(await n.connect()).publicKey.toString(),t=await o();return{...t,transfer:async({recipient:w,assetValue:P,isProgramDerivedAddress:m})=>{let{PublicKey:b}=await import("@solana/web3.js"),y=await t.getAddressValidator();if(!(m||y(w)))throw new r("core_transaction_invalid_recipient_address");let g=new b(a),u=await t.getConnection(),p=await t.createTransaction({recipient:w,assetValue:P,sender:a,isProgramDerivedAddress:m});if(!p)throw new r("core_transaction_invalid_sender_address");let T=await u.getLatestBlockhash();p.recentBlockhash=T.blockhash,p.feePayer=g;let x=await n.signTransaction(p);return await u.sendRawTransaction(x.serialize())},address:a}}default:throw new r("wallet_chain_not_supported",{wallet:_.PHANTOM,chain:s})}}export{A as phantomWallet,N as PHANTOM_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=6EBF999D5EECFD6764756E2164756E21
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as c}from"../../chunk-
|
|
1
|
+
import{a as c}from"../../chunk-6ndrbmhg.js";import{c as u,d as f}from"../../chunk-p1kdg37m.js";import{Chain as i,SwapKitError as l,WalletOption as d,createWallet as _,filterSupportedChains as P}from"@swapkit/helpers";var h=_({name:"connectPolkadotJs",walletType:d.POLKADOT_JS,supportedChains:[i.Polkadot],connect:({addChain:t,supportedChains:s,walletType:r})=>async function a(n){let e=P({chains:n,supportedChains:s,walletType:r});return await Promise.all(e.map(async(o)=>{let{address:w,...p}=await m(o);t({...p,chain:o,address:w,walletType:r})})),!0}}),g=c(h);async function m(t){switch(t){case i.Polkadot:{let{getSubstrateToolbox:s}=await import("@swapkit/toolboxes/substrate"),a=await window?.injectedWeb3?.["polkadot-js"]?.enable?.("polkadot-js");if(!a)throw new l({errorKey:"wallet_polkadot_not_found",info:{chain:t}});let n=await s(t,{signer:a.signer}),[e]=await a.accounts.get();if(!e?.address)throw new l({errorKey:"wallet_missing_params",info:{wallet:d.POLKADOT_JS,address:e?.address}});let o=n.convertAddress(e.address,0);return{...n,getAddress:()=>o,address:o}}default:throw new l({errorKey:"wallet_chain_not_supported",info:{chain:t,wallet:d.POLKADOT_JS}})}}export{h as polkadotWallet,g as POLKADOT_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=E7C0639453A120E464756E2164756E21
|
package/dist/src/radix/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as q}from"../../chunk-
|
|
1
|
+
import{a as q}from"../../chunk-6ndrbmhg.js";import{c as Z,d as _}from"../../chunk-p1kdg37m.js";import{AssetValue as N,Chain as G,SKConfig as X,SwapKitError as S,WalletOption as x,createWallet as B,filterSupportedChains as C}from"@swapkit/helpers";var h=B({name:"connectRadixWallet",walletType:x.RADIX_WALLET,supportedChains:[G.Radix],connect:({addChain:L,supportedChains:K,walletType:H})=>async function V(M){let O=C({chains:M,supportedChains:K,walletType:H});if(!X.get("integrations").radix)throw new S("wallet_radix_not_found");return await Promise.all(O.map(async(z)=>{let j=await E();L({...j,chain:z,walletType:H})})),!0}}),f=q(h);async function k(L){let{GatewayApiClient:K}=await import("@radixdlt/babylon-gateway-api-sdk"),{applicationName:H}=X.get("integrations").radix,V=K.initialize({networkId:1,applicationName:H}),M=!0,O,U=[],z=await v(V);while(M){let j={address:L,limit_per_page:100,cursor:O,at_ledger_state:{state_version:z}},Q=await V.state.innerClient.entityFungiblesPage({stateEntityFungiblesPageRequest:j});if(U=U.concat(Q.items),Q.next_cursor)O=Q.next_cursor;else M=!1}return U}async function v(L){return L.status.getCurrent().then((K)=>K.ledger_state.state_version)}async function D(L){let{GatewayApiClient:K}=await import("@radixdlt/babylon-gateway-api-sdk"),H=await k(L),{applicationName:V}=X.get("integrations").radix,M=K.initialize({networkId:1,applicationName:V}),O=[],U=50,z=[];for(let j=0;j<H.length;j+=50)z.push(H.slice(j,j+50));for(let j of z){let Q=j.map((J)=>J.resource_address),Y=await M.state.getEntityDetailsVaultAggregated(Q),T=new Map;for(let J of Y)if(J.details!==void 0){let W=J.metadata?.items.find((I)=>I.key==="symbol"),$=W?.value.typed.type==="String"?W.value.typed.value:"?";if(J.details.type==="FungibleResource")T.set(J.address,{decimals:J.details.divisibility,symbol:$})}for(let J of j)if(J.aggregation_level==="Global"){let W=T.get(J.resource_address)||{decimals:0,symbol:"?"},$=N.from({asset:W.symbol!==G.Radix?`${G.Radix}.${W.symbol}-${J.resource_address}`:"XRD.XRD",value:J.amount});O.push($)}}return O}async function E(){let{RadixDappToolkit:L}=await import("@radixdlt/radix-dapp-toolkit"),K=X.get("integrations").radix,H=L({...K,networkId:K.network.networkId});function V(z){return new Promise((j)=>setTimeout(j,z))}await V(400);function M(){return H.walletApi.getWalletData()?.accounts?.[0]?.address}let O=async()=>{let{DataRequestBuilder:z}=await import("@radixdlt/radix-dapp-toolkit");H.walletApi.setRequestData(z.accounts().exactly(1));let j=await H.walletApi.sendRequest();if(!j)throw new Error("wallet_radix_no_account");let Q=j.unwrapOr(null)?.accounts[0]?.address;if(!Q)throw new Error("wallet_radix_no_account");return Q},U=M()||await O();return{radixDappToolkit:H,address:U,getAddress:M,getBalance:()=>D(U),transfer:(z)=>{throw new Error("Not implemented")},signAndBroadcast:async({manifest:z,message:j})=>{let Y=(await H.walletApi.sendTransaction({transactionManifest:z,message:j})).unwrapOr(null)?.transactionIntentHash;if(!Y)throw new Error("wallet_radix_transaction_failed");return Y}}}export{h as radixWallet,f as RADIX_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=2DC5F9112118385264756E2164756E21
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as p}from"../../chunk-
|
|
1
|
+
import{a as p}from"../../chunk-6ndrbmhg.js";import{c as d,d as m}from"../../chunk-p1kdg37m.js";import{Chain as t,SwapKitError as s,WalletOption as l,createWallet as h,filterSupportedChains as f,prepareNetworkSwitch as u,switchEVMWalletNetwork as _}from"@swapkit/helpers";var A=h({name:"connectTalisman",walletType:l.TALISMAN,supportedChains:[t.Ethereum,t.Arbitrum,t.Avalanche,t.Base,t.Polygon,t.BinanceSmartChain,t.Optimism,t.Polkadot,t.Chainflip],connect:({addChain:e,supportedChains:a,walletType:r})=>async function c(o){let i=f({chains:o,supportedChains:a,walletType:r});return await Promise.all(i.map(async(n)=>{let w=await S(n);e({...w,chain:n,walletType:r})})),!0}}),C=p(A);async function E({walletProvider:e,chain:a}){let{getEvmToolbox:r}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:c}=await import("ethers");if(!e)throw new s({errorKey:"wallet_provider_not_found",info:{wallet:l.TALISMAN,chain:a}});let o=new c(e,"any"),i=await o.getSigner(),n=await r(a,{provider:o,signer:i});try{if(a!==t.Ethereum)await _(o,a,n.getNetworkParams())}catch(w){throw new s({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:l.TALISMAN,chain:a}})}return u({toolbox:n,chain:a,provider:o})}async function S(e){switch(e){case t.Ethereum:case t.Arbitrum:case t.Optimism:case t.Polygon:case t.Avalanche:case t.BinanceSmartChain:case t.Base:{if(!(window.talismanEth&&("send"in window.talismanEth)))throw new s({errorKey:"wallet_talisman_not_found",info:{chain:e}});let a=await E({chain:e,walletProvider:window.talismanEth}),r=(await window.talismanEth.send("eth_requestAccounts",[]))[0];return{...a,address:r}}case t.Polkadot:case t.Chainflip:{let{getSubstrateToolbox:a,SubstrateNetwork:r}=await import("@swapkit/toolboxes/substrate"),o=await window?.injectedWeb3?.talisman?.enable?.("talisman");if(!o)throw new s({errorKey:"wallet_talisman_not_enabled",info:{chain:e}});let i=await a(e,{signer:o.signer}),n=await o.accounts.get();if(!n[0]?.address)throw new s({errorKey:"wallet_missing_params",info:{wallet:l.TALISMAN,accounts:n,address:n[0]?.address}});let w=i.convertAddress(n[0].address,r[e].prefix);return{...i,address:w}}default:throw new s({errorKey:"wallet_chain_not_supported",info:{chain:e,wallet:l.TALISMAN}})}}export{A as talismanWallet,C as TALISMAN_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=962A7B2CAE25081964756E2164756E21
|
package/dist/src/trezor/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as K}from"../../chunk-
|
|
1
|
+
import{a as K}from"../../chunk-6ndrbmhg.js";import{c as N,d as V}from"../../chunk-p1kdg37m.js";import{Chain as j,FeeOption as E,SKConfig as S,SwapKitError as M,WalletOption as f,createWallet as y,derivationPathToString as P,filterSupportedChains as b}from"@swapkit/helpers";function w(q){switch(q[0]){case 84:return{input:"SPENDWITNESS",output:"PAYTOWITNESS"};case 49:return{input:"SPENDP2SHWITNESS",output:"PAYTOP2SHWITNESS"};case 44:return{input:"SPENDADDRESS",output:"PAYTOADDRESS"};default:return null}}async function g({chain:q,derivationPath:Q}){switch(q){case j.BinanceSmartChain:case j.Avalanche:case j.Arbitrum:case j.Optimism:case j.Polygon:case j.Base:case j.Ethereum:{let{getProvider:H,getEvmToolbox:X}=await import("@swapkit/toolboxes/evm"),{getEVMSigner:Y}=await import("../../chunk-q81hzyra.js"),Z=await H(q),I=await Y({chain:q,derivationPath:Q,provider:Z}),D=await I.getAddress();return{...await X(q,{provider:Z,signer:I}),address:D}}case j.Bitcoin:case j.BitcoinCash:case j.Dash:case j.Dogecoin:case j.Litecoin:{let{toCashAddress:H,getUtxoToolbox:X}=await import("@swapkit/toolboxes/utxo"),Y=w(Q);if(!Y)throw new M({errorKey:"wallet_trezor_derivation_path_not_supported",info:{derivationPath:Q}});let Z=q.toLowerCase(),D=await(async($=Q)=>{let{default:F}=await import("@trezor/connect-web"),{success:_,payload:G}=await F.getAddress({path:P($),coin:Z});if(!_)throw new M({errorKey:"wallet_trezor_failed_to_get_address",info:{chain:q,error:G.error||"Unknown error"}});if(q===j.BitcoinCash)return(await X(q)).stripPrefix(G.address);return G.address})(),k=async($,F,_="")=>{let{default:G}=await import("@trezor/connect-web"),A=Q.map((B,J)=>J<3?(B|2147483648)>>>0:B),L=await X(q),R=await G.signTransaction({coin:Z,inputs:F.map(({hash:B,index:J,value:U})=>({address_n:A,prev_hash:B,prev_index:J,amount:U,script_type:Y.input})),outputs:$.txOutputs.map((B)=>{let J=q===j.BitcoinCash&&B.address?L.stripPrefix(H(B.address)):B.address,U=J===D;if(!B.address)return{amount:"0",op_return_data:Buffer.from(_).toString("hex"),script_type:"PAYTOOPRETURN"};return U?{amount:B.value,address_n:A,script_type:Y.output}:{amount:B.value,address:J,script_type:"PAYTOADDRESS"}})});if(R.success)return R.payload.serializedTx;throw new M({errorKey:"wallet_trezor_failed_to_sign_transaction",info:{chain:q,error:R.payload.error}})},W=async({recipient:$,feeOptionKey:F,feeRate:_,memo:G,...A})=>{if(!(D&&$))throw new M({errorKey:"wallet_missing_params",info:{wallet:f.TREZOR,memo:G,address:D,recipient:$}});let L=await X(q),R=_||(await L.getFeeRates())[F||E.Fast],B=q===j.BitcoinCash?L.buildTx:L.createTransaction,{psbt:J,inputs:U}=await B({...A,memo:G,recipient:$,feeRate:R,sender:D,fetchTxHex:!0}),O=await k(J,U,G);return await L.broadcastTx(O)};return{...await X(q),address:D,transfer:W,signTransaction:k}}default:throw new M({errorKey:"wallet_chain_not_supported",info:{chain:q,wallet:f.TREZOR}})}}var v=y({name:"connectTrezor",walletType:f.TREZOR,supportedChains:[j.Arbitrum,j.Avalanche,j.Base,j.BinanceSmartChain,j.Bitcoin,j.BitcoinCash,j.Dash,j.Dogecoin,j.Ethereum,j.Litecoin,j.Optimism,j.Polygon],connect:({addChain:q,supportedChains:Q,walletType:H})=>async function X(Y,Z){let[I]=b({chains:Y,supportedChains:Q,walletType:H});if(!I)throw new M({errorKey:"wallet_chain_not_supported",info:{chain:I,wallet:f.TREZOR}});let{default:D}=await import("@trezor/connect-web"),{success:k}=await D.getDeviceState();if(!k){let z=S.get("integrations").trezor||{appUrl:"",email:""};D.init({lazyLoad:!0,manifest:z})}let W=await g({chain:I,derivationPath:Z});return q({...W,chain:I,walletType:H}),!0}}),C=K(v);export{v as trezorWallet,C as TREZOR_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
3
|
//# debugId=A43C365DB73A7F2B64756E2164756E21
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{a as jr}from"../../chunk-
|
|
1
|
+
import{a as jr}from"../../chunk-6ndrbmhg.js";import{c as Y,d as J}from"../../chunk-p1kdg37m.js";import{Chain as N,ChainId as Vr,SKConfig as fr,SwapKitError as G,WalletOption as c,createWallet as er,filterSupportedChains as kr}from"@swapkit/helpers";var A="wss://relay.walletconnect.com",F="eip155:1",O="eip155:56",l="eip155:43114",X="cosmos:thorchain",L="cosmos:cosmoshub-4",o="cosmos:kaiyo-1",T="cosmos:mayachain-mainnet-v1",D="eip155:42161",E="eip155:10",S="eip155:137",rr="eip155:8453",sr="debug",ur={name:"THORSwap",description:"THORSwap multi-chain dex aggregator powered by THORChain",url:"https://app.thorswap.finance/",icons:["https://static.thorswap.net/logo.png"]},R;((t)=>{t.ETH_SEND_TRANSACTION="eth_sendTransaction";t.ETH_SIGN="eth_sign";t.PERSONAL_SIGN="personal_sign";t.ETH_SIGN_TYPED_DATA="eth_signTypedData"})(R||={});var w;((s)=>{s.ETH_CHAIN_CHANGED="chainChanged";s.ETH_ACCOUNTS_CHANGED="accountsChanged"})(w||={});var V;((p)=>{p.COSMOS_SIGN_DIRECT="cosmos_signDirect";p.COSMOS_SIGN_AMINO="cosmos_signAmino";p.COSMOS_GET_ACCOUNTS="cosmos_getAccounts"})(V||={});var Zr;((r)=>{})(Zr||={});var i;((s)=>{s.SOL_SIGN_TRANSACTION="solana_signTransaction";s.SOL_SIGN_MESSAGE="solana_signMessage"})(i||={});var P;((r)=>{})(P||={});var g;((s)=>{s.POLKADOT_SIGN_TRANSACTION="polkadot_signTransaction";s.POLKADOT_SIGN_MESSAGE="polkadot_signMessage"})(g||={});var x;((r)=>{})(x||={});var d;((I)=>{I.NEAR_SIGN_IN="near_signIn";I.NEAR_SIGN_OUT="near_signOut";I.NEAR_GET_ACCOUNTS="near_getAccounts";I.NEAR_SIGN_AND_SEND_TRANSACTION="near_signAndSendTransaction";I.NEAR_SIGN_AND_SEND_TRANSACTIONS="near_signAndSendTransactions"})(d||={});var n;((r)=>{})(n||={});import{SwapKitError as Nr,WalletOption as vr}from"@swapkit/helpers";import{AbstractSigner as $r}from"ethers";import{Chain as C}from"@swapkit/helpers";var e=(r,u)=>{return(u.find((t)=>t.startsWith(z(r)))||"")?.split(":")?.[2]||""},z=(r)=>{switch(r){case C.Avalanche:return l;case C.Base:return rr;case C.BinanceSmartChain:return O;case C.Ethereum:return F;case C.THORChain:return X;case C.Arbitrum:return D;case C.Optimism:return E;case C.Polygon:return S;case C.Maya:return T;case C.Cosmos:return L;case C.Kujira:return o;default:return""}};class _ extends $r{address;chain;walletconnect;provider;constructor({chain:r,provider:u,walletconnect:s}){super(u);this.chain=r,this.walletconnect=s,this.provider=u,this.address=""}getAddress=async()=>{if(!this.walletconnect)throw new Nr("wallet_walletconnect_connection_not_established");if(!this.address)this.address=e(this.chain,this.walletconnect.accounts);return this.address};signMessage=async(r)=>{let u=await this.walletconnect?.client.request({chainId:z(this.chain),topic:this.walletconnect.session.topic,request:{method:"eth_sign",params:[r]}});return u.startsWith("0x")?u:`0x${u}`};signTransaction=()=>{throw new Error("Not implemented: signTransaction")};signTypedData=()=>{throw new Error("Not implemented: signTypedData")};sendTransaction=async({from:r,to:u,value:s,data:p})=>{let{toHexString:t}=await import("@swapkit/toolboxes/evm"),I={from:r,to:u,value:t(BigInt(s||0)),data:p};return await this.walletconnect?.client.request({chainId:z(this.chain),topic:this.walletconnect.session.topic,request:{method:"eth_sendTransaction",params:[I]}})};connect=(r)=>{if(!r)throw new Nr({errorKey:"wallet_provider_not_found",info:{wallet:vr.WALLETCONNECT,chain:this.chain}});return new _({chain:this.chain,walletconnect:this.walletconnect,provider:r})}}var pr=async({chain:r,walletconnect:u,provider:s})=>new _({chain:r,walletconnect:u,provider:s});import{SwapKitError as tr}from"@swapkit/helpers";var br=(r)=>{let u=[];for(let s of r){let[p]=s.split(":");if(p&&!u.includes(p))u.push(p)}return u},qr=(r)=>{switch(r){case"eip155":return Object.values(R);case"cosmos":return Object.values(V);case"solana":return Object.values(i);case"polkadot":return Object.values(g);case"near":return Object.values(d);default:throw new tr({errorKey:"wallet_walletconnect_namespace_not_supported",info:{namespace:r}})}},Rr=(r)=>{switch(r){case"eip155":return Object.values(w);case"cosmos":return[];case"solana":return Object.values(P);case"polkadot":return Object.values(x);case"near":return Object.values(n);default:throw new tr({errorKey:"wallet_walletconnect_namespace_not_supported",info:{namespace:r}})}},Ir=(r)=>{let u=br(r);return Object.fromEntries(u.map((s)=>[s,{methods:qr(s),chains:r.filter((p)=>p.startsWith(s)),events:Rr(s)}]))};var mr=er({name:"connectWalletconnect",walletType:c.WALLETCONNECT,supportedChains:[N.Arbitrum,N.Avalanche,N.Base,N.BinanceSmartChain,N.Cosmos,N.Ethereum,N.Kujira,N.Maya,N.Optimism,N.Polygon,N.THORChain],connect:({addChain:r,supportedChains:u,walletType:s})=>async function p(t,I){let f=kr({chains:t,supportedChains:u,walletType:s}),{walletConnectProjectId:y}=fr.get("apiKeys");if(!y)throw new G("wallet_walletconnect_project_id_not_specified");let j=await Wr(f,y,I);if(!j)throw new G("wallet_walletconnect_connection_not_established");let{session:Q,accounts:Z}=j;return await Promise.all(f.map(async(K)=>{let v=e(K,Z),k=await Mr({session:Q,address:v,chain:K,walletconnect:j});r({...k,address:v,chain:K,disconnect:j.disconnect,walletType:c.WALLETCONNECT})})),!0}}),Er=jr(mr);async function Mr({chain:r,walletconnect:u,address:s,session:p}){switch(r){case N.Arbitrum:case N.Avalanche:case N.Base:case N.BinanceSmartChain:case N.Ethereum:case N.Optimism:case N.Polygon:{let{getProvider:t,getEvmToolbox:I}=await import("@swapkit/toolboxes/evm"),f=await t(r),y=await pr({walletconnect:u,chain:r,provider:f});return await I(r,{provider:f,signer:y})}case N.THORChain:{let{SignMode:t}=await import("cosmjs-types/cosmos/tx/signing/v1beta1/signing.js"),{TxRaw:I}=await import("cosmjs-types/cosmos/tx/v1beta1/tx.js"),{encodePubkey:f,makeAuthInfoBytes:y}=await import("@cosmjs/proto-signing"),{makeSignDoc:j}=await import("@cosmjs/amino"),{getCosmosToolbox:Q,buildAminoMsg:Z,buildEncodedTxBody:K,createStargateClient:v,fromBase64:k,getDefaultChainFee:Cr,parseAminoMessageForDirectSigning:yr}=await import("@swapkit/toolboxes/cosmos"),m=await Q(N.THORChain);async function hr(h){let b=await m.getAccount(h);if(r!==N.THORChain)return b;let[{address:B,algo:W,pubkey:q}]=await u?.client.request({chainId:X,topic:p.topic,request:{method:"cosmos_getAccounts",params:{}}});return{...b,address:B,pubkey:{type:W,value:q}}}let M=Cr(r),Br=(h)=>u?.client.request({chainId:X,topic:p.topic,request:{method:"cosmos_signAmino",params:{signerAddress:s,signDoc:h}}});async function U({assetValue:h,memo:$,...b}){let B=await m.getAccount(s);if(!B)throw new G({errorKey:"wallet_missing_params",info:{account:B}});if(!B.pubkey)throw new G({errorKey:"wallet_missing_params",info:{account:B,pubkey:B?.pubkey}});let{accountNumber:W,sequence:q=0}=B,H=[Z({assetValue:h,memo:$,sender:s,...b})],Yr=Vr.THORChain,Jr=j(H,M,Yr,$,W?.toString(),q?.toString()||"0"),a=await Br(Jr),Kr=await K({chain:N.THORChain,msgs:H.map(yr),memo:$||""}),zr=f(B.pubkey),Gr=y([{pubkey:zr,sequence:q}],M.amount,Number.parseInt(M.gas),void 0,void 0,t.SIGN_MODE_LEGACY_AMINO_JSON),Qr=I.fromPartial({bodyBytes:Kr,authInfoBytes:Gr,signatures:[k(typeof a.signature==="string"?a.signature:a.signature.signature)]}),Xr=I.encode(Qr).finish();return(await(await v(fr.get("rpcUrls")[N.THORChain])).broadcastTx(Xr)).transactionHash}return{...m,transfer:(h)=>U(h),deposit:(h)=>U(h),getAccount:hr}}default:throw new G({errorKey:"wallet_chain_not_supported",info:{chain:r,wallet:c.WALLETCONNECT}})}}async function Wr(r,u,s){let p;try{if(!u)throw new G("wallet_walletconnect_project_id_not_specified");let t=Ir(r.map(z)),{WalletConnectModalSign:I}=await import("@walletconnect/modal-sign-html"),f=new I({logger:sr,relayUrl:A,projectId:u,metadata:s?.metadata||ur,...s?.core}),y=await f.getSession();if(y)await f.disconnect({topic:y.topic,reason:{code:0,message:"Resetting session"}});let j=await f.connect({requiredNamespaces:t}),Q=Object.values(j.namespaces).flatMap((K)=>K.accounts);return{session:j,accounts:Q,client:f,disconnect:async()=>{await f.disconnect({topic:j.topic,reason:{code:0,message:"User disconnected"}})}}}catch(t){console.error(t)}finally{if(p)p.closeModal()}return}export{mr as walletconnectWallet,Er as WC_SUPPORTED_CHAINS,X as THORCHAIN_MAINNET_ID,S as POLYGON_MAINNET_ID,E as OPTIMISM_MAINNET_ID,T as MAYACHAIN_MAINNET_ID,o as KUJIRA_MAINNET_ID,F as ETHEREUM_MAINNET_ID,i as DEFAULT_SOLANA_METHODS,P as DEFAULT_SOLANA_EVENTS,A as DEFAULT_RELAY_URL,g as DEFAULT_POLKADOT_METHODS,x as DEFAULT_POLKADOT_EVENTS,d as DEFAULT_NEAR_METHODS,n as DEFAULT_NEAR_EVENTS,sr as DEFAULT_LOGGER,w as DEFAULT_EIP_155_EVENTS,R as DEFAULT_EIP155_METHODS,V as DEFAULT_COSMOS_METHODS,Zr as DEFAULT_COSMOS_EVENTS,ur as DEFAULT_APP_METADATA,L as COSMOS_HUB_MAINNET_ID,O as BSC_MAINNET_ID,rr as BASE_MAINNET_ID,l as AVALANCHE_MAINNET_ID,D as ARBITRUM_ONE_MAINNET_ID};
|
|
2
2
|
|
|
3
3
|
//# debugId=CF101C8AB8BC593A64756E2164756E21
|
package/package.json
CHANGED
|
@@ -25,8 +25,9 @@
|
|
|
25
25
|
"@radixdlt/radix-dapp-toolkit": "2.2.1",
|
|
26
26
|
"@scure/base": "1.2.4",
|
|
27
27
|
"@scure/bip39": "1.5.4",
|
|
28
|
-
"@
|
|
29
|
-
"@swapkit/
|
|
28
|
+
"@solana/web3.js": "1.98.2",
|
|
29
|
+
"@swapkit/helpers": "3.0.0-beta.5",
|
|
30
|
+
"@swapkit/toolboxes": "1.0.0-beta.5",
|
|
30
31
|
"@trezor/connect-web": "9.5.4",
|
|
31
32
|
"@walletconnect/modal-sign-html": "2.7.0",
|
|
32
33
|
"bitcoinjs-lib": "6.1.7",
|
|
@@ -35,9 +36,6 @@
|
|
|
35
36
|
"sats-connect": "3.3.0",
|
|
36
37
|
"ts-pattern": "5.7.0"
|
|
37
38
|
},
|
|
38
|
-
"peerDependencies": {
|
|
39
|
-
"@solana/web3.js": "1.98.0"
|
|
40
|
-
},
|
|
41
39
|
"devDependencies": {
|
|
42
40
|
"@walletconnect/logger": "2.1.2",
|
|
43
41
|
"@walletconnect/types": "2.19.2"
|
|
@@ -154,5 +152,5 @@
|
|
|
154
152
|
"type-check:go": "tsgo"
|
|
155
153
|
},
|
|
156
154
|
"type": "module",
|
|
157
|
-
"version": "3.0.0-beta.
|
|
155
|
+
"version": "3.0.0-beta.5"
|
|
158
156
|
}
|
package/src/keystore/helpers.ts
CHANGED
|
@@ -32,7 +32,7 @@ async function blake256(initData: Buffer | string) {
|
|
|
32
32
|
}
|
|
33
33
|
|
|
34
34
|
export async function encryptToKeyStore(phrase: string, password: string) {
|
|
35
|
-
const { pbkdf2Sync, randomBytes, createCipheriv } = await import("
|
|
35
|
+
const { pbkdf2Sync, randomBytes, createCipheriv } = await import("crypto");
|
|
36
36
|
|
|
37
37
|
const cipher = "aes-128-ctr";
|
|
38
38
|
const iv = randomBytes(16);
|
|
@@ -71,7 +71,7 @@ export function validatePhrase(phrase: string) {
|
|
|
71
71
|
}
|
|
72
72
|
|
|
73
73
|
export async function decryptFromKeystore(keystore: Keystore, password: string) {
|
|
74
|
-
const { createDecipheriv, pbkdf2Sync } = await import("
|
|
74
|
+
const { createDecipheriv, pbkdf2Sync } = await import("crypto");
|
|
75
75
|
const { SwapKitError } = await import("@swapkit/helpers");
|
|
76
76
|
|
|
77
77
|
switch (keystore.version) {
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|