@swapkit/wallet-hardware 4.1.12 → 4.1.14
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/trezor/index.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var
|
|
1
|
+
var T={};y(T,{trezorWallet:()=>f,TREZOR_SUPPORTED_CHAINS:()=>w});module.exports=S(T);var q=require("@swapkit/helpers"),K=require("@swapkit/wallet-core");function E(B){switch(B[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 z({chain:B,derivationPath:H}){switch(B){case q.Chain.Arbitrum:case q.Chain.Aurora:case q.Chain.Avalanche:case q.Chain.Base:case q.Chain.BinanceSmartChain:case q.Chain.Ethereum:case q.Chain.Gnosis:case q.Chain.Optimism:case q.Chain.Polygon:{let{getProvider:k,getEvmToolbox:M}=await import("@swapkit/toolboxes/evm"),{getEVMSigner:U}=await import("../chunk-4k7gb7ss.js"),L=await k(B),Y=await U({chain:B,derivationPath:H,provider:L}),I=await Y.getAddress();return{...await M(B,{provider:L,signer:Y}),address:I}}case q.Chain.Zcash:{let{getUtxoToolbox:k}=await import("@swapkit/toolboxes/utxo"),M=q.derivationPathToString(H),L=await(async()=>{let J=(await import("@trezor/connect-web")).default,{success:Z,payload:G}=await J.getAddress({coin:"zcash",path:M});if(!Z)throw new q.SwapKitError({errorKey:"wallet_trezor_failed_to_get_address",info:{chain:B,error:G.error||"Unknown error"}});return G.address})(),Y={getAddress:async()=>L,signTransaction:async(J)=>{let Z=(await import("@trezor/connect-web")).default,{address:G,networks:F}=await import("@bitgo/utxo-lib"),$=H.map((D,N)=>N<3?(D|2147483648)>>>0:D),j=4,O=2301567109,W=3370586197,_=J.txInputs.map((D,N)=>({address_n:$,amount:J.data.inputs[N]?.witnessUtxo?.value?.toString()||"0",prev_hash:D.hash.reverse().toString("hex"),prev_index:D.index,script_type:"SPENDADDRESS"})),Q=J.txOutputs.map((D)=>{let N=G.fromOutputScript(D.script,F.zcash);if(D.value===0n&&D.script.length>0&&D.script[0]===106)return{amount:"0",op_return_data:D.script.toString("hex"),script_type:"PAYTOOPRETURN"};let R=N===L;return console.log({inputs:_,output:D,maybeRecipient:N,isChangeAddress:R}),console.log(R?{address_n:$,amount:D.value.toString(),script_type:"PAYTOADDRESS"}:{address:N,amount:D.value.toString(),script_type:"PAYTOADDRESS"}),R?{address_n:$,amount:D.value.toString(),script_type:"PAYTOADDRESS"}:{address:N,amount:D.value.toString(),script_type:"PAYTOADDRESS"}}),X=await Z.signTransaction({branchId:3370586197,coin:"zcash",expiry:0,inputs:_,locktime:0,outputs:Q,overwintered:!0,version:4,versionGroupId:2301567109});if(X.success)return console.log("returning",X.payload.serializedTx),X.payload.serializedTx;throw new q.SwapKitError({errorKey:"wallet_trezor_failed_to_sign_transaction",info:{chain:B,error:X.payload.error}})}},I=await k(q.Chain.Zcash),A=async(J)=>{if(!(L&&J.recipient))throw new q.SwapKitError({errorKey:"wallet_missing_params",info:{address:L,recipient:J.recipient,wallet:q.WalletOption.TREZOR}});let Z=J.feeRate||(await I.getFeeRates())[J.feeOptionKey||q.FeeOption.Fast],{psbt:G}=await I.createTransaction({...J,feeRate:Z,fetchTxHex:!1,sender:L}),F=await Y.signTransaction(G);return await I.broadcastTx(F)};return{...I,address:L,signTransaction:Y.signTransaction,transfer:A}}case q.Chain.Bitcoin:case q.Chain.BitcoinCash:case q.Chain.Dash:case q.Chain.Dogecoin:case q.Chain.Litecoin:{let{toCashAddress:k,getUtxoToolbox:M}=await import("@swapkit/toolboxes/utxo"),U=E(H);if(!U)throw new q.SwapKitError({errorKey:"wallet_trezor_derivation_path_not_supported",info:{derivationPath:H}});let L=B.toLowerCase(),I=await(async(G=H)=>{let F=(await import("@trezor/connect-web")).default,{success:$,payload:j}=await F.getAddress({coin:L,path:q.derivationPathToString(G)});if(!$)throw new q.SwapKitError({errorKey:"wallet_trezor_failed_to_get_address",info:{chain:B,error:j.error||"Unknown error"}});if(B===q.Chain.BitcoinCash)return(await M(B)).stripPrefix(j.address);return j.address})(),A=async(G,F,$="")=>{let j=(await import("@trezor/connect-web")).default,O=H.map((Q,X)=>X<3?(Q|2147483648)>>>0:Q),W=await M(B),_=await j.signTransaction({coin:L,inputs:F.map(({hash:Q,index:X,value:D})=>({address_n:O,amount:D,prev_hash:Q,prev_index:X,script_type:U.input})),outputs:G.txOutputs.map((Q)=>{if(!Q.address)return{amount:"0",op_return_data:Buffer.from($).toString("hex"),script_type:"PAYTOOPRETURN"};let X=B===q.Chain.BitcoinCash?W.stripPrefix(k(Q.address)):Q.address;return X===I?{address_n:O,amount:Q.value,script_type:U.output}:{address:X,amount:Q.value,script_type:"PAYTOADDRESS"}})});if(_.success)return _.payload.serializedTx;throw new q.SwapKitError({errorKey:"wallet_trezor_failed_to_sign_transaction",info:{chain:B,error:_.payload.error}})},J=async({recipient:G,feeOptionKey:F,feeRate:$,memo:j,...O})=>{if(!(I&&G))throw new q.SwapKitError({errorKey:"wallet_missing_params",info:{address:I,memo:j,recipient:G,wallet:q.WalletOption.TREZOR}});let W=await M(B),_=$||(await W.getFeeRates())[F||q.FeeOption.Fast],Q=B===q.Chain.BitcoinCash?W.buildTx:W.createTransaction,{psbt:X,inputs:D}=await Q({...O,feeRate:_,fetchTxHex:!0,memo:j,recipient:G,sender:I}),N=await A(X,D,j);return await W.broadcastTx(N)};return{...await M(B),address:I,signTransaction:A,transfer:J}}default:throw new q.SwapKitError({errorKey:"wallet_chain_not_supported",info:{chain:B,wallet:q.WalletOption.TREZOR}})}}var f=K.createWallet({connect:({addChain:B,supportedChains:H,walletType:k})=>async function(U,L){let[Y]=q.filterSupportedChains({chains:U,supportedChains:H,walletType:k});if(!Y)throw new q.SwapKitError({errorKey:"wallet_chain_not_supported",info:{chain:Y,wallet:q.WalletOption.TREZOR}});let I=(await import("@trezor/connect-web")).default,{success:A}=await I.getDeviceState();if(!A){let Z=q.SKConfig.get("integrations").trezor,G=Z?{...Z,appName:Z.appName||"SwapKit"}:{appName:"SwapKit",appUrl:"",email:""};I.init({lazyLoad:!0,manifest:G})}let J=await z({chain:Y,derivationPath:L});return B({...J,chain:Y,walletType:k}),!0},name:"connectTrezor",supportedChains:[q.Chain.Arbitrum,q.Chain.Aurora,q.Chain.Avalanche,q.Chain.Base,q.Chain.BinanceSmartChain,q.Chain.Bitcoin,q.Chain.BitcoinCash,q.Chain.Dash,q.Chain.Dogecoin,q.Chain.Ethereum,q.Chain.Gnosis,q.Chain.Litecoin,q.Chain.Optimism,q.Chain.Polygon,q.Chain.Zcash],walletType:q.WalletOption.TREZOR}),w=K.getWalletSupportedChains(f);
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=260FD0E088F2B26864756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -2,9 +2,9 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/trezor/index.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
|
-
"import type { ZcashPsbt } from \"@bitgo/utxo-lib/dist/src/bitgo\";\nimport {\n Chain,\n type DerivationPathArray,\n derivationPathToString,\n FeeOption,\n filterSupportedChains,\n type GenericTransferParams,\n SKConfig,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport type { UTXOToolboxes, UTXOType } from \"@swapkit/toolboxes/utxo\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport type { Psbt } from \"bitcoinjs-lib\";\n\nfunction getScriptType(derivationPath: DerivationPathArray) {\n switch (derivationPath[0]) {\n case 84:\n return { input: \"SPENDWITNESS\", output: \"PAYTOWITNESS\" } as const;\n case 49:\n return { input: \"SPENDP2SHWITNESS\", output: \"PAYTOP2SHWITNESS\" } as const;\n case 44:\n return { input: \"SPENDADDRESS\", output: \"PAYTOADDRESS\" } as const;\n default:\n return null;\n }\n}\n\nasync function getTrezorWallet<T extends Chain>({\n chain,\n derivationPath,\n}: {\n chain: T;\n derivationPath: DerivationPathArray;\n}) {\n switch (chain) {\n case Chain.Arbitrum:\n case Chain.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { getProvider, getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { getEVMSigner } = await import(\"./evmSigner\");\n\n const provider = await getProvider(chain);\n const signer = await getEVMSigner({ chain, derivationPath, provider });\n const address = await signer.getAddress();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n return { ...toolbox, address };\n }\n\n case Chain.Zcash: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n\n const derivationPathStr = derivationPathToString(derivationPath);\n\n const getAddress = async () => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const { success, payload } = await TrezorConnect.getAddress({ coin: \"zec\", path: derivationPathStr });\n\n if (!success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_get_address\",\n info: { chain, error: (payload as { error: string; code?: string }).error || \"Unknown error\" },\n });\n }\n\n return payload.address;\n };\n\n const address = await getAddress();\n\n // Create a signer that works with ZcashPsbt\n const signer = {\n getAddress: async () => address,\n signTransaction: async (zcashPsbt: ZcashPsbt) => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const address_n = derivationPath.map((pathElement, index) =>\n index < 3 ? ((pathElement as number) | 0x80000000) >>> 0 : (pathElement as number),\n );\n\n // Extract Zcash-specific parameters from the PSBT\n // Use getVersion() method instead of accessing protected tx property\n const version = 4; // Sapling version\n const versionGroupId = 0x892f2085; // Sapling\n const branchId = 0xe9ff75a6; // Canopy\n\n const inputs = zcashPsbt.txInputs.map((input, idx) => ({\n address_n,\n amount: zcashPsbt.data.inputs[idx]?.witnessUtxo?.value?.toString() || \"0\",\n prev_hash: input.hash.reverse().toString(\"hex\"),\n prev_index: input.index,\n script_type: \"SPENDADDRESS\" as const,\n }));\n\n const result = await TrezorConnect.signTransaction({\n branchId,\n coin: \"zec\",\n inputs,\n outputs: zcashPsbt.txOutputs.map((output) => {\n // OP_RETURN\n if (!output.address) {\n return { amount: \"0\", op_return_data: output.script.toString(\"hex\"), script_type: \"PAYTOOPRETURN\" };\n }\n\n const outputAddress = output.address;\n\n const isChangeAddress = outputAddress === address;\n\n return isChangeAddress\n ? { address_n, amount: output.value.toString(), script_type: \"PAYTOADDRESS\" }\n : { address: outputAddress, amount: output.value.toString(), script_type: \"PAYTOADDRESS\" };\n }),\n overwintered: true,\n version,\n versionGroupId,\n }); // Type assertion needed due to Trezor Connect types not supporting PAYTOOPRETURN\n\n if (!result.success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { chain, error: (result.payload as { error: string; code?: string }).error },\n });\n }\n\n // Trezor returns the fully signed transaction hex\n // We need to update the PSBT with the signatures and finalize it\n // For now, we'll store the signed tx hex in a way the toolbox can use\n return result.payload.serializedTx;\n },\n };\n\n const toolbox = await getUtxoToolbox(Chain.Zcash);\n\n const transfer = async (params: GenericTransferParams) => {\n if (!(address && params.recipient)) {\n throw new SwapKitError({\n errorKey: \"wallet_missing_params\",\n info: { address, recipient: params.recipient, wallet: WalletOption.TREZOR },\n });\n }\n\n const feeRate = params.feeRate || (await toolbox.getFeeRates())[params.feeOptionKey || FeeOption.Fast];\n\n const { psbt } = await toolbox.createTransaction({ ...params, feeRate, fetchTxHex: false, sender: address });\n\n const signedPsbt = await signer.signTransaction(psbt);\n // Extract the signed transaction hex that we stored\n const txHex = (signedPsbt as any).signedTxHex;\n if (!txHex) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { chain, error: \"No signed transaction hex returned\" },\n });\n }\n return toolbox.broadcastTx(txHex);\n };\n\n return { ...toolbox, address, signTransaction: signer.signTransaction, transfer };\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { toCashAddress, getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const scriptType = getScriptType(derivationPath);\n\n if (!scriptType) {\n throw new SwapKitError({ errorKey: \"wallet_trezor_derivation_path_not_supported\", info: { derivationPath } });\n }\n\n const coin = chain.toLowerCase();\n\n const getAddress = async (path: DerivationPathArray = derivationPath) => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const { success, payload } = await TrezorConnect.getAddress({ coin, path: derivationPathToString(path) });\n\n if (!success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_get_address\",\n info: { chain, error: (payload as { error: string; code?: string }).error || \"Unknown error\" },\n });\n }\n\n if (chain === Chain.BitcoinCash) {\n const toolbox = await getUtxoToolbox(chain as Chain.BitcoinCash);\n return toolbox.stripPrefix(payload.address);\n }\n\n return payload.address;\n };\n\n const address = await getAddress();\n\n const signTransaction = async (psbt: Psbt, inputs: UTXOType[], memo = \"\") => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const address_n = derivationPath.map((pathElement, index) =>\n index < 3 ? ((pathElement as number) | 0x80000000) >>> 0 : (pathElement as number),\n );\n const toolbox = await getUtxoToolbox(chain as Chain.BitcoinCash);\n\n const result = await TrezorConnect.signTransaction({\n coin,\n inputs: inputs.map(({ hash, index, value }) => ({\n // Hardens the first 3 elements of the derivation path - required by trezor\n address_n,\n // object needs amount but does not use it for signing\n amount: value,\n prev_hash: hash,\n prev_index: index,\n script_type: scriptType.input,\n })),\n outputs: psbt.txOutputs.map((output) => {\n // OP_RETURN\n if (!output.address) {\n return { amount: \"0\", op_return_data: Buffer.from(memo).toString(\"hex\"), script_type: \"PAYTOOPRETURN\" };\n }\n\n const outputAddress =\n chain === Chain.BitcoinCash ? toolbox.stripPrefix(toCashAddress(output.address)) : output.address;\n\n const isChangeAddress = outputAddress === address;\n\n return isChangeAddress\n ? { address_n, amount: output.value, script_type: scriptType.output }\n : { address: outputAddress, amount: output.value, script_type: \"PAYTOADDRESS\" };\n }),\n });\n\n if (result.success) {\n return result.payload.serializedTx;\n }\n\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { chain, error: (result.payload as { error: string; code?: string }).error },\n });\n };\n\n const transfer = async ({\n recipient,\n feeOptionKey,\n feeRate: paramFeeRate,\n memo,\n ...rest\n }: GenericTransferParams) => {\n if (!(address && recipient)) {\n throw new SwapKitError({\n errorKey: \"wallet_missing_params\",\n info: { address, memo, recipient, wallet: WalletOption.TREZOR },\n });\n }\n\n const toolbox = await getUtxoToolbox(chain);\n\n const feeRate = paramFeeRate || (await toolbox.getFeeRates())[feeOptionKey || FeeOption.Fast];\n\n const createTxMethod =\n chain === Chain.BitcoinCash\n ? (toolbox as UTXOToolboxes[\"BCH\"]).buildTx\n : (toolbox as UTXOToolboxes[\"BTC\"]).createTransaction;\n\n const { psbt, inputs } = await createTxMethod({\n ...rest,\n feeRate,\n fetchTxHex: true,\n memo,\n recipient,\n sender: address,\n });\n\n const txHex = await signTransaction(psbt, inputs, memo);\n const tx = await toolbox.broadcastTx(txHex);\n\n return tx;\n };\n\n const toolbox = await getUtxoToolbox(chain);\n\n return { ...toolbox, address, signTransaction, transfer };\n }\n\n default:\n throw new SwapKitError({ errorKey: \"wallet_chain_not_supported\", info: { chain, wallet: WalletOption.TREZOR } });\n }\n}\n\nexport const trezorWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectTrezor(chains: Chain[], derivationPath: DerivationPathArray) {\n const [chain] = filterSupportedChains({ chains, supportedChains, walletType });\n if (!chain) {\n throw new SwapKitError({\n errorKey: \"wallet_chain_not_supported\",\n info: { chain, wallet: WalletOption.TREZOR },\n });\n }\n\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const { success } = await TrezorConnect.getDeviceState();\n\n if (!success) {\n const trezorConfig = SKConfig.get(\"integrations\").trezor;\n const manifest = trezorConfig\n ? { ...trezorConfig, appName: (trezorConfig as any).appName || \"SwapKit\" }\n : { appName: \"SwapKit\", appUrl: \"\", email: \"\" };\n TrezorConnect.init({ lazyLoad: true, manifest });\n }\n\n const wallet = await getTrezorWallet({ chain, derivationPath });\n\n addChain({ ...wallet, chain, walletType });\n\n return true;\n },\n name: \"connectTrezor\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Dash,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Litecoin,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Zcash,\n ],\n walletType: WalletOption.TREZOR,\n});\n\nexport const TREZOR_SUPPORTED_CHAINS = getWalletSupportedChains(trezorWallet);\n"
|
|
5
|
+
"import type { ZcashPsbt } from \"@bitgo/utxo-lib/dist/src/bitgo\";\nimport {\n Chain,\n type DerivationPathArray,\n derivationPathToString,\n FeeOption,\n filterSupportedChains,\n type GenericTransferParams,\n SKConfig,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport type { UTXOToolboxes, UTXOType } from \"@swapkit/toolboxes/utxo\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport type { Psbt } from \"bitcoinjs-lib\";\n\nfunction getScriptType(derivationPath: DerivationPathArray) {\n switch (derivationPath[0]) {\n case 84:\n return { input: \"SPENDWITNESS\", output: \"PAYTOWITNESS\" } as const;\n case 49:\n return { input: \"SPENDP2SHWITNESS\", output: \"PAYTOP2SHWITNESS\" } as const;\n case 44:\n return { input: \"SPENDADDRESS\", output: \"PAYTOADDRESS\" } as const;\n default:\n return null;\n }\n}\n\nasync function getTrezorWallet<T extends Chain>({\n chain,\n derivationPath,\n}: {\n chain: T;\n derivationPath: DerivationPathArray;\n}) {\n switch (chain) {\n case Chain.Arbitrum:\n case Chain.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { getProvider, getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { getEVMSigner } = await import(\"./evmSigner\");\n\n const provider = await getProvider(chain);\n const signer = await getEVMSigner({ chain, derivationPath, provider });\n const address = await signer.getAddress();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n return { ...toolbox, address };\n }\n\n case Chain.Zcash: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n\n const derivationPathStr = derivationPathToString(derivationPath);\n\n const getAddress = async () => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const { success, payload } = await TrezorConnect.getAddress({ coin: \"zcash\", path: derivationPathStr });\n\n if (!success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_get_address\",\n info: { chain, error: (payload as { error: string; code?: string }).error || \"Unknown error\" },\n });\n }\n\n return payload.address;\n };\n\n const address = await getAddress();\n\n // Create a signer that works with ZcashPsbt\n const signer = {\n getAddress: async () => address,\n signTransaction: async (zcashPsbt: ZcashPsbt) => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const { address: zcashAddress, networks } = await import(\"@bitgo/utxo-lib\");\n const address_n = derivationPath.map((pathElement, index) =>\n index < 3 ? ((pathElement as number) | 0x80000000) >>> 0 : (pathElement as number),\n );\n\n const version = 4;\n const versionGroupId = 0x892f2085;\n const branchId = 0xc8e71055;\n\n const inputs = zcashPsbt.txInputs.map((input, idx) => ({\n address_n,\n amount: zcashPsbt.data.inputs[idx]?.witnessUtxo?.value?.toString() || \"0\",\n prev_hash: input.hash.reverse().toString(\"hex\"),\n prev_index: input.index,\n script_type: \"SPENDADDRESS\" as const,\n }));\n\n const outputs = zcashPsbt.txOutputs.map((output) => {\n const maybeRecipient = zcashAddress.fromOutputScript(output.script, networks.zcash); // Validate address\n // OP_RETURN\n if (output.value === 0n && output.script.length > 0 && output.script[0] === 0x6a) {\n return { amount: \"0\", op_return_data: output.script.toString(\"hex\"), script_type: \"PAYTOOPRETURN\" };\n }\n\n const isChangeAddress = maybeRecipient === address;\n\n console.log({ inputs, output, maybeRecipient, isChangeAddress });\n console.log(\n isChangeAddress\n ? { address_n, amount: output.value.toString(), script_type: \"PAYTOADDRESS\" }\n : { address: maybeRecipient, amount: output.value.toString(), script_type: \"PAYTOADDRESS\" },\n );\n\n return isChangeAddress\n ? { address_n, amount: output.value.toString(), script_type: \"PAYTOADDRESS\" }\n : { address: maybeRecipient, amount: output.value.toString(), script_type: \"PAYTOADDRESS\" };\n });\n\n const result = await TrezorConnect.signTransaction({\n branchId,\n coin: \"zcash\",\n expiry: 0,\n inputs,\n locktime: 0,\n // @ts-expect-error\n outputs,\n overwintered: true,\n version,\n versionGroupId,\n });\n\n if (result.success) {\n console.log(\"returning\", result.payload.serializedTx);\n return result.payload.serializedTx;\n }\n\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { chain, error: (result.payload as { error: string; code?: string }).error },\n });\n },\n };\n\n const toolbox = await getUtxoToolbox(Chain.Zcash);\n\n const transfer = async (params: GenericTransferParams) => {\n if (!(address && params.recipient)) {\n throw new SwapKitError({\n errorKey: \"wallet_missing_params\",\n info: { address, recipient: params.recipient, wallet: WalletOption.TREZOR },\n });\n }\n\n const feeRate = params.feeRate || (await toolbox.getFeeRates())[params.feeOptionKey || FeeOption.Fast];\n\n const { psbt } = await toolbox.createTransaction({ ...params, feeRate, fetchTxHex: false, sender: address });\n\n const txHex = await signer.signTransaction(psbt);\n const tx = await toolbox.broadcastTx(txHex);\n\n return tx;\n };\n\n return { ...toolbox, address, signTransaction: signer.signTransaction, transfer };\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { toCashAddress, getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const scriptType = getScriptType(derivationPath);\n\n if (!scriptType) {\n throw new SwapKitError({ errorKey: \"wallet_trezor_derivation_path_not_supported\", info: { derivationPath } });\n }\n\n const coin = chain.toLowerCase();\n\n const getAddress = async (path: DerivationPathArray = derivationPath) => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const { success, payload } = await TrezorConnect.getAddress({ coin, path: derivationPathToString(path) });\n\n if (!success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_get_address\",\n info: { chain, error: (payload as { error: string; code?: string }).error || \"Unknown error\" },\n });\n }\n\n if (chain === Chain.BitcoinCash) {\n const toolbox = await getUtxoToolbox(chain as Chain.BitcoinCash);\n return toolbox.stripPrefix(payload.address);\n }\n\n return payload.address;\n };\n\n const address = await getAddress();\n\n const signTransaction = async (psbt: Psbt, inputs: UTXOType[], memo = \"\") => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const address_n = derivationPath.map((pathElement, index) =>\n index < 3 ? ((pathElement as number) | 0x80000000) >>> 0 : (pathElement as number),\n );\n const toolbox = await getUtxoToolbox(chain as Chain.BitcoinCash);\n\n const result = await TrezorConnect.signTransaction({\n coin,\n inputs: inputs.map(({ hash, index, value }) => ({\n // Hardens the first 3 elements of the derivation path - required by trezor\n address_n,\n // object needs amount but does not use it for signing\n amount: value,\n prev_hash: hash,\n prev_index: index,\n script_type: scriptType.input,\n })),\n outputs: psbt.txOutputs.map((output) => {\n // OP_RETURN\n if (!output.address) {\n return { amount: \"0\", op_return_data: Buffer.from(memo).toString(\"hex\"), script_type: \"PAYTOOPRETURN\" };\n }\n\n const outputAddress =\n chain === Chain.BitcoinCash ? toolbox.stripPrefix(toCashAddress(output.address)) : output.address;\n\n const isChangeAddress = outputAddress === address;\n\n return isChangeAddress\n ? { address_n, amount: output.value, script_type: scriptType.output }\n : { address: outputAddress, amount: output.value, script_type: \"PAYTOADDRESS\" };\n }),\n });\n\n if (result.success) {\n return result.payload.serializedTx;\n }\n\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { chain, error: (result.payload as { error: string; code?: string }).error },\n });\n };\n\n const transfer = async ({\n recipient,\n feeOptionKey,\n feeRate: paramFeeRate,\n memo,\n ...rest\n }: GenericTransferParams) => {\n if (!(address && recipient)) {\n throw new SwapKitError({\n errorKey: \"wallet_missing_params\",\n info: { address, memo, recipient, wallet: WalletOption.TREZOR },\n });\n }\n\n const toolbox = await getUtxoToolbox(chain);\n\n const feeRate = paramFeeRate || (await toolbox.getFeeRates())[feeOptionKey || FeeOption.Fast];\n\n const createTxMethod =\n chain === Chain.BitcoinCash\n ? (toolbox as UTXOToolboxes[\"BCH\"]).buildTx\n : (toolbox as UTXOToolboxes[\"BTC\"]).createTransaction;\n\n const { psbt, inputs } = await createTxMethod({\n ...rest,\n feeRate,\n fetchTxHex: true,\n memo,\n recipient,\n sender: address,\n });\n\n const txHex = await signTransaction(psbt, inputs, memo);\n const tx = await toolbox.broadcastTx(txHex);\n\n return tx;\n };\n\n const toolbox = await getUtxoToolbox(chain);\n\n return { ...toolbox, address, signTransaction, transfer };\n }\n\n default:\n throw new SwapKitError({ errorKey: \"wallet_chain_not_supported\", info: { chain, wallet: WalletOption.TREZOR } });\n }\n}\n\nexport const trezorWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectTrezor(chains: Chain[], derivationPath: DerivationPathArray) {\n const [chain] = filterSupportedChains({ chains, supportedChains, walletType });\n if (!chain) {\n throw new SwapKitError({\n errorKey: \"wallet_chain_not_supported\",\n info: { chain, wallet: WalletOption.TREZOR },\n });\n }\n\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const { success } = await TrezorConnect.getDeviceState();\n\n if (!success) {\n const trezorConfig = SKConfig.get(\"integrations\").trezor;\n const manifest = trezorConfig\n ? { ...trezorConfig, appName: (trezorConfig as any).appName || \"SwapKit\" }\n : { appName: \"SwapKit\", appUrl: \"\", email: \"\" };\n TrezorConnect.init({ lazyLoad: true, manifest });\n }\n\n const wallet = await getTrezorWallet({ chain, derivationPath });\n\n addChain({ ...wallet, chain, walletType });\n\n return true;\n },\n name: \"connectTrezor\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Dash,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Litecoin,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Zcash,\n ],\n walletType: WalletOption.TREZOR,\n});\n\nexport const TREZOR_SUPPORTED_CHAINS = getWalletSupportedChains(trezorWallet);\n"
|
|
6
6
|
],
|
|
7
|
-
"mappings": "qFAWO,IAVP,8BAYA,kCAGA,SAAS,CAAa,CAAC,EAAqC,CAC1D,OAAQ,EAAe,QAChB,IACH,MAAO,CAAE,MAAO,eAAgB,OAAQ,cAAe,MACpD,IACH,MAAO,CAAE,MAAO,mBAAoB,OAAQ,kBAAmB,MAC5D,IACH,MAAO,CAAE,MAAO,eAAgB,OAAQ,cAAe,UAEvD,OAAO,MAIb,eAAe,CAAgC,EAC7C,QACA,kBAIC,CACD,OAAQ,QACD,QAAM,cACN,QAAM,YACN,QAAM,eACN,QAAM,UACN,QAAM,uBACN,QAAM,cACN,QAAM,YACN,QAAM,cACN,QAAM,QAAS,CAClB,IAAQ,cAAa,iBAAkB,KAAa,mCAC5C,gBAAiB,KAAa,gCAEhC,EAAW,MAAM,EAAY,CAAK,EAClC,EAAS,MAAM,EAAa,CAAE,QAAO,iBAAgB,UAAS,CAAC,EAC/D,EAAU,MAAM,EAAO,WAAW,EAGxC,MAAO,IAFS,MAAM,EAAc,EAAO,CAAE,WAAU,QAAO,CAAC,EAE1C,SAAQ,CAC/B,MAEK,QAAM,MAAO,CAChB,IAAQ,kBAAmB,KAAa,mCAElC,EAAoB,yBAAuB,CAAc,EAgBzD,EAAU,MAdG,SAAY,CAC7B,IAAM,GAAiB,KAAa,gCAAwB,SACpD,UAAS,WAAY,MAAM,EAAc,WAAW,CAAE,KAAM,
|
|
8
|
-
"debugId": "
|
|
7
|
+
"mappings": "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",
|
|
8
|
+
"debugId": "260FD0E088F2B26864756E2164756E21",
|
|
9
9
|
"names": []
|
|
10
10
|
}
|
package/dist/trezor/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{c as
|
|
1
|
+
import{c as V,d as H}from"../chunk-zn26fh3j.js";import{Chain as q,derivationPathToString as y,FeeOption as E,filterSupportedChains as z,SKConfig as w,SwapKitError as U,WalletOption as f}from"@swapkit/helpers";import{createWallet as T,getWalletSupportedChains as v}from"@swapkit/wallet-core";function P(B){switch(B[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:B,derivationPath:M}){switch(B){case q.Arbitrum:case q.Aurora:case q.Avalanche:case q.Base:case q.BinanceSmartChain:case q.Ethereum:case q.Gnosis:case q.Optimism:case q.Polygon:{let{getProvider:_,getEvmToolbox:F}=await import("@swapkit/toolboxes/evm"),{getEVMSigner:A}=await import("../chunk-swt2b003.js"),L=await _(B),Y=await A({chain:B,derivationPath:M,provider:L}),I=await Y.getAddress();return{...await F(B,{provider:L,signer:Y}),address:I}}case q.Zcash:{let{getUtxoToolbox:_}=await import("@swapkit/toolboxes/utxo"),F=y(M),L=await(async()=>{let J=(await import("@trezor/connect-web")).default,{success:Z,payload:G}=await J.getAddress({coin:"zcash",path:F});if(!Z)throw new U({errorKey:"wallet_trezor_failed_to_get_address",info:{chain:B,error:G.error||"Unknown error"}});return G.address})(),Y={getAddress:async()=>L,signTransaction:async(J)=>{let Z=(await import("@trezor/connect-web")).default,{address:G,networks:k}=await import("@bitgo/utxo-lib"),$=M.map((D,N)=>N<3?(D|2147483648)>>>0:D),j=4,K=2301567109,R=3370586197,W=J.txInputs.map((D,N)=>({address_n:$,amount:J.data.inputs[N]?.witnessUtxo?.value?.toString()||"0",prev_hash:D.hash.reverse().toString("hex"),prev_index:D.index,script_type:"SPENDADDRESS"})),Q=J.txOutputs.map((D)=>{let N=G.fromOutputScript(D.script,k.zcash);if(D.value===0n&&D.script.length>0&&D.script[0]===106)return{amount:"0",op_return_data:D.script.toString("hex"),script_type:"PAYTOOPRETURN"};let S=N===L;return console.log({inputs:W,output:D,maybeRecipient:N,isChangeAddress:S}),console.log(S?{address_n:$,amount:D.value.toString(),script_type:"PAYTOADDRESS"}:{address:N,amount:D.value.toString(),script_type:"PAYTOADDRESS"}),S?{address_n:$,amount:D.value.toString(),script_type:"PAYTOADDRESS"}:{address:N,amount:D.value.toString(),script_type:"PAYTOADDRESS"}}),X=await Z.signTransaction({branchId:3370586197,coin:"zcash",expiry:0,inputs:W,locktime:0,outputs:Q,overwintered:!0,version:4,versionGroupId:2301567109});if(X.success)return console.log("returning",X.payload.serializedTx),X.payload.serializedTx;throw new U({errorKey:"wallet_trezor_failed_to_sign_transaction",info:{chain:B,error:X.payload.error}})}},I=await _(q.Zcash),O=async(J)=>{if(!(L&&J.recipient))throw new U({errorKey:"wallet_missing_params",info:{address:L,recipient:J.recipient,wallet:f.TREZOR}});let Z=J.feeRate||(await I.getFeeRates())[J.feeOptionKey||E.Fast],{psbt:G}=await I.createTransaction({...J,feeRate:Z,fetchTxHex:!1,sender:L}),k=await Y.signTransaction(G);return await I.broadcastTx(k)};return{...I,address:L,signTransaction:Y.signTransaction,transfer:O}}case q.Bitcoin:case q.BitcoinCash:case q.Dash:case q.Dogecoin:case q.Litecoin:{let{toCashAddress:_,getUtxoToolbox:F}=await import("@swapkit/toolboxes/utxo"),A=P(M);if(!A)throw new U({errorKey:"wallet_trezor_derivation_path_not_supported",info:{derivationPath:M}});let L=B.toLowerCase(),I=await(async(G=M)=>{let k=(await import("@trezor/connect-web")).default,{success:$,payload:j}=await k.getAddress({coin:L,path:y(G)});if(!$)throw new U({errorKey:"wallet_trezor_failed_to_get_address",info:{chain:B,error:j.error||"Unknown error"}});if(B===q.BitcoinCash)return(await F(B)).stripPrefix(j.address);return j.address})(),O=async(G,k,$="")=>{let j=(await import("@trezor/connect-web")).default,K=M.map((Q,X)=>X<3?(Q|2147483648)>>>0:Q),R=await F(B),W=await j.signTransaction({coin:L,inputs:k.map(({hash:Q,index:X,value:D})=>({address_n:K,amount:D,prev_hash:Q,prev_index:X,script_type:A.input})),outputs:G.txOutputs.map((Q)=>{if(!Q.address)return{amount:"0",op_return_data:Buffer.from($).toString("hex"),script_type:"PAYTOOPRETURN"};let X=B===q.BitcoinCash?R.stripPrefix(_(Q.address)):Q.address;return X===I?{address_n:K,amount:Q.value,script_type:A.output}:{address:X,amount:Q.value,script_type:"PAYTOADDRESS"}})});if(W.success)return W.payload.serializedTx;throw new U({errorKey:"wallet_trezor_failed_to_sign_transaction",info:{chain:B,error:W.payload.error}})},J=async({recipient:G,feeOptionKey:k,feeRate:$,memo:j,...K})=>{if(!(I&&G))throw new U({errorKey:"wallet_missing_params",info:{address:I,memo:j,recipient:G,wallet:f.TREZOR}});let R=await F(B),W=$||(await R.getFeeRates())[k||E.Fast],Q=B===q.BitcoinCash?R.buildTx:R.createTransaction,{psbt:X,inputs:D}=await Q({...K,feeRate:W,fetchTxHex:!0,memo:j,recipient:G,sender:I}),N=await O(X,D,j);return await R.broadcastTx(N)};return{...await F(B),address:I,signTransaction:O,transfer:J}}default:throw new U({errorKey:"wallet_chain_not_supported",info:{chain:B,wallet:f.TREZOR}})}}var x=T({connect:({addChain:B,supportedChains:M,walletType:_})=>async function(A,L){let[Y]=z({chains:A,supportedChains:M,walletType:_});if(!Y)throw new U({errorKey:"wallet_chain_not_supported",info:{chain:Y,wallet:f.TREZOR}});let I=(await import("@trezor/connect-web")).default,{success:O}=await I.getDeviceState();if(!O){let Z=w.get("integrations").trezor,G=Z?{...Z,appName:Z.appName||"SwapKit"}:{appName:"SwapKit",appUrl:"",email:""};I.init({lazyLoad:!0,manifest:G})}let J=await g({chain:Y,derivationPath:L});return B({...J,chain:Y,walletType:_}),!0},name:"connectTrezor",supportedChains:[q.Arbitrum,q.Aurora,q.Avalanche,q.Base,q.BinanceSmartChain,q.Bitcoin,q.BitcoinCash,q.Dash,q.Dogecoin,q.Ethereum,q.Gnosis,q.Litecoin,q.Optimism,q.Polygon,q.Zcash],walletType:f.TREZOR}),C=v(x);export{x as trezorWallet,C as TREZOR_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=1E15D2D0944DD2AD64756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.js.map
|
package/dist/trezor/index.js.map
CHANGED
|
@@ -2,9 +2,9 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/trezor/index.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
|
-
"import type { ZcashPsbt } from \"@bitgo/utxo-lib/dist/src/bitgo\";\nimport {\n Chain,\n type DerivationPathArray,\n derivationPathToString,\n FeeOption,\n filterSupportedChains,\n type GenericTransferParams,\n SKConfig,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport type { UTXOToolboxes, UTXOType } from \"@swapkit/toolboxes/utxo\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport type { Psbt } from \"bitcoinjs-lib\";\n\nfunction getScriptType(derivationPath: DerivationPathArray) {\n switch (derivationPath[0]) {\n case 84:\n return { input: \"SPENDWITNESS\", output: \"PAYTOWITNESS\" } as const;\n case 49:\n return { input: \"SPENDP2SHWITNESS\", output: \"PAYTOP2SHWITNESS\" } as const;\n case 44:\n return { input: \"SPENDADDRESS\", output: \"PAYTOADDRESS\" } as const;\n default:\n return null;\n }\n}\n\nasync function getTrezorWallet<T extends Chain>({\n chain,\n derivationPath,\n}: {\n chain: T;\n derivationPath: DerivationPathArray;\n}) {\n switch (chain) {\n case Chain.Arbitrum:\n case Chain.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { getProvider, getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { getEVMSigner } = await import(\"./evmSigner\");\n\n const provider = await getProvider(chain);\n const signer = await getEVMSigner({ chain, derivationPath, provider });\n const address = await signer.getAddress();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n return { ...toolbox, address };\n }\n\n case Chain.Zcash: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n\n const derivationPathStr = derivationPathToString(derivationPath);\n\n const getAddress = async () => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const { success, payload } = await TrezorConnect.getAddress({ coin: \"zec\", path: derivationPathStr });\n\n if (!success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_get_address\",\n info: { chain, error: (payload as { error: string; code?: string }).error || \"Unknown error\" },\n });\n }\n\n return payload.address;\n };\n\n const address = await getAddress();\n\n // Create a signer that works with ZcashPsbt\n const signer = {\n getAddress: async () => address,\n signTransaction: async (zcashPsbt: ZcashPsbt) => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const address_n = derivationPath.map((pathElement, index) =>\n index < 3 ? ((pathElement as number) | 0x80000000) >>> 0 : (pathElement as number),\n );\n\n // Extract Zcash-specific parameters from the PSBT\n // Use getVersion() method instead of accessing protected tx property\n const version = 4; // Sapling version\n const versionGroupId = 0x892f2085; // Sapling\n const branchId = 0xe9ff75a6; // Canopy\n\n const inputs = zcashPsbt.txInputs.map((input, idx) => ({\n address_n,\n amount: zcashPsbt.data.inputs[idx]?.witnessUtxo?.value?.toString() || \"0\",\n prev_hash: input.hash.reverse().toString(\"hex\"),\n prev_index: input.index,\n script_type: \"SPENDADDRESS\" as const,\n }));\n\n const result = await TrezorConnect.signTransaction({\n branchId,\n coin: \"zec\",\n inputs,\n outputs: zcashPsbt.txOutputs.map((output) => {\n // OP_RETURN\n if (!output.address) {\n return { amount: \"0\", op_return_data: output.script.toString(\"hex\"), script_type: \"PAYTOOPRETURN\" };\n }\n\n const outputAddress = output.address;\n\n const isChangeAddress = outputAddress === address;\n\n return isChangeAddress\n ? { address_n, amount: output.value.toString(), script_type: \"PAYTOADDRESS\" }\n : { address: outputAddress, amount: output.value.toString(), script_type: \"PAYTOADDRESS\" };\n }),\n overwintered: true,\n version,\n versionGroupId,\n }); // Type assertion needed due to Trezor Connect types not supporting PAYTOOPRETURN\n\n if (!result.success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { chain, error: (result.payload as { error: string; code?: string }).error },\n });\n }\n\n // Trezor returns the fully signed transaction hex\n // We need to update the PSBT with the signatures and finalize it\n // For now, we'll store the signed tx hex in a way the toolbox can use\n return result.payload.serializedTx;\n },\n };\n\n const toolbox = await getUtxoToolbox(Chain.Zcash);\n\n const transfer = async (params: GenericTransferParams) => {\n if (!(address && params.recipient)) {\n throw new SwapKitError({\n errorKey: \"wallet_missing_params\",\n info: { address, recipient: params.recipient, wallet: WalletOption.TREZOR },\n });\n }\n\n const feeRate = params.feeRate || (await toolbox.getFeeRates())[params.feeOptionKey || FeeOption.Fast];\n\n const { psbt } = await toolbox.createTransaction({ ...params, feeRate, fetchTxHex: false, sender: address });\n\n const signedPsbt = await signer.signTransaction(psbt);\n // Extract the signed transaction hex that we stored\n const txHex = (signedPsbt as any).signedTxHex;\n if (!txHex) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { chain, error: \"No signed transaction hex returned\" },\n });\n }\n return toolbox.broadcastTx(txHex);\n };\n\n return { ...toolbox, address, signTransaction: signer.signTransaction, transfer };\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { toCashAddress, getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const scriptType = getScriptType(derivationPath);\n\n if (!scriptType) {\n throw new SwapKitError({ errorKey: \"wallet_trezor_derivation_path_not_supported\", info: { derivationPath } });\n }\n\n const coin = chain.toLowerCase();\n\n const getAddress = async (path: DerivationPathArray = derivationPath) => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const { success, payload } = await TrezorConnect.getAddress({ coin, path: derivationPathToString(path) });\n\n if (!success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_get_address\",\n info: { chain, error: (payload as { error: string; code?: string }).error || \"Unknown error\" },\n });\n }\n\n if (chain === Chain.BitcoinCash) {\n const toolbox = await getUtxoToolbox(chain as Chain.BitcoinCash);\n return toolbox.stripPrefix(payload.address);\n }\n\n return payload.address;\n };\n\n const address = await getAddress();\n\n const signTransaction = async (psbt: Psbt, inputs: UTXOType[], memo = \"\") => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const address_n = derivationPath.map((pathElement, index) =>\n index < 3 ? ((pathElement as number) | 0x80000000) >>> 0 : (pathElement as number),\n );\n const toolbox = await getUtxoToolbox(chain as Chain.BitcoinCash);\n\n const result = await TrezorConnect.signTransaction({\n coin,\n inputs: inputs.map(({ hash, index, value }) => ({\n // Hardens the first 3 elements of the derivation path - required by trezor\n address_n,\n // object needs amount but does not use it for signing\n amount: value,\n prev_hash: hash,\n prev_index: index,\n script_type: scriptType.input,\n })),\n outputs: psbt.txOutputs.map((output) => {\n // OP_RETURN\n if (!output.address) {\n return { amount: \"0\", op_return_data: Buffer.from(memo).toString(\"hex\"), script_type: \"PAYTOOPRETURN\" };\n }\n\n const outputAddress =\n chain === Chain.BitcoinCash ? toolbox.stripPrefix(toCashAddress(output.address)) : output.address;\n\n const isChangeAddress = outputAddress === address;\n\n return isChangeAddress\n ? { address_n, amount: output.value, script_type: scriptType.output }\n : { address: outputAddress, amount: output.value, script_type: \"PAYTOADDRESS\" };\n }),\n });\n\n if (result.success) {\n return result.payload.serializedTx;\n }\n\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { chain, error: (result.payload as { error: string; code?: string }).error },\n });\n };\n\n const transfer = async ({\n recipient,\n feeOptionKey,\n feeRate: paramFeeRate,\n memo,\n ...rest\n }: GenericTransferParams) => {\n if (!(address && recipient)) {\n throw new SwapKitError({\n errorKey: \"wallet_missing_params\",\n info: { address, memo, recipient, wallet: WalletOption.TREZOR },\n });\n }\n\n const toolbox = await getUtxoToolbox(chain);\n\n const feeRate = paramFeeRate || (await toolbox.getFeeRates())[feeOptionKey || FeeOption.Fast];\n\n const createTxMethod =\n chain === Chain.BitcoinCash\n ? (toolbox as UTXOToolboxes[\"BCH\"]).buildTx\n : (toolbox as UTXOToolboxes[\"BTC\"]).createTransaction;\n\n const { psbt, inputs } = await createTxMethod({\n ...rest,\n feeRate,\n fetchTxHex: true,\n memo,\n recipient,\n sender: address,\n });\n\n const txHex = await signTransaction(psbt, inputs, memo);\n const tx = await toolbox.broadcastTx(txHex);\n\n return tx;\n };\n\n const toolbox = await getUtxoToolbox(chain);\n\n return { ...toolbox, address, signTransaction, transfer };\n }\n\n default:\n throw new SwapKitError({ errorKey: \"wallet_chain_not_supported\", info: { chain, wallet: WalletOption.TREZOR } });\n }\n}\n\nexport const trezorWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectTrezor(chains: Chain[], derivationPath: DerivationPathArray) {\n const [chain] = filterSupportedChains({ chains, supportedChains, walletType });\n if (!chain) {\n throw new SwapKitError({\n errorKey: \"wallet_chain_not_supported\",\n info: { chain, wallet: WalletOption.TREZOR },\n });\n }\n\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const { success } = await TrezorConnect.getDeviceState();\n\n if (!success) {\n const trezorConfig = SKConfig.get(\"integrations\").trezor;\n const manifest = trezorConfig\n ? { ...trezorConfig, appName: (trezorConfig as any).appName || \"SwapKit\" }\n : { appName: \"SwapKit\", appUrl: \"\", email: \"\" };\n TrezorConnect.init({ lazyLoad: true, manifest });\n }\n\n const wallet = await getTrezorWallet({ chain, derivationPath });\n\n addChain({ ...wallet, chain, walletType });\n\n return true;\n },\n name: \"connectTrezor\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Dash,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Litecoin,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Zcash,\n ],\n walletType: WalletOption.TREZOR,\n});\n\nexport const TREZOR_SUPPORTED_CHAINS = getWalletSupportedChains(trezorWallet);\n"
|
|
5
|
+
"import type { ZcashPsbt } from \"@bitgo/utxo-lib/dist/src/bitgo\";\nimport {\n Chain,\n type DerivationPathArray,\n derivationPathToString,\n FeeOption,\n filterSupportedChains,\n type GenericTransferParams,\n SKConfig,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport type { UTXOToolboxes, UTXOType } from \"@swapkit/toolboxes/utxo\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport type { Psbt } from \"bitcoinjs-lib\";\n\nfunction getScriptType(derivationPath: DerivationPathArray) {\n switch (derivationPath[0]) {\n case 84:\n return { input: \"SPENDWITNESS\", output: \"PAYTOWITNESS\" } as const;\n case 49:\n return { input: \"SPENDP2SHWITNESS\", output: \"PAYTOP2SHWITNESS\" } as const;\n case 44:\n return { input: \"SPENDADDRESS\", output: \"PAYTOADDRESS\" } as const;\n default:\n return null;\n }\n}\n\nasync function getTrezorWallet<T extends Chain>({\n chain,\n derivationPath,\n}: {\n chain: T;\n derivationPath: DerivationPathArray;\n}) {\n switch (chain) {\n case Chain.Arbitrum:\n case Chain.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { getProvider, getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { getEVMSigner } = await import(\"./evmSigner\");\n\n const provider = await getProvider(chain);\n const signer = await getEVMSigner({ chain, derivationPath, provider });\n const address = await signer.getAddress();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n return { ...toolbox, address };\n }\n\n case Chain.Zcash: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n\n const derivationPathStr = derivationPathToString(derivationPath);\n\n const getAddress = async () => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const { success, payload } = await TrezorConnect.getAddress({ coin: \"zcash\", path: derivationPathStr });\n\n if (!success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_get_address\",\n info: { chain, error: (payload as { error: string; code?: string }).error || \"Unknown error\" },\n });\n }\n\n return payload.address;\n };\n\n const address = await getAddress();\n\n // Create a signer that works with ZcashPsbt\n const signer = {\n getAddress: async () => address,\n signTransaction: async (zcashPsbt: ZcashPsbt) => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const { address: zcashAddress, networks } = await import(\"@bitgo/utxo-lib\");\n const address_n = derivationPath.map((pathElement, index) =>\n index < 3 ? ((pathElement as number) | 0x80000000) >>> 0 : (pathElement as number),\n );\n\n const version = 4;\n const versionGroupId = 0x892f2085;\n const branchId = 0xc8e71055;\n\n const inputs = zcashPsbt.txInputs.map((input, idx) => ({\n address_n,\n amount: zcashPsbt.data.inputs[idx]?.witnessUtxo?.value?.toString() || \"0\",\n prev_hash: input.hash.reverse().toString(\"hex\"),\n prev_index: input.index,\n script_type: \"SPENDADDRESS\" as const,\n }));\n\n const outputs = zcashPsbt.txOutputs.map((output) => {\n const maybeRecipient = zcashAddress.fromOutputScript(output.script, networks.zcash); // Validate address\n // OP_RETURN\n if (output.value === 0n && output.script.length > 0 && output.script[0] === 0x6a) {\n return { amount: \"0\", op_return_data: output.script.toString(\"hex\"), script_type: \"PAYTOOPRETURN\" };\n }\n\n const isChangeAddress = maybeRecipient === address;\n\n console.log({ inputs, output, maybeRecipient, isChangeAddress });\n console.log(\n isChangeAddress\n ? { address_n, amount: output.value.toString(), script_type: \"PAYTOADDRESS\" }\n : { address: maybeRecipient, amount: output.value.toString(), script_type: \"PAYTOADDRESS\" },\n );\n\n return isChangeAddress\n ? { address_n, amount: output.value.toString(), script_type: \"PAYTOADDRESS\" }\n : { address: maybeRecipient, amount: output.value.toString(), script_type: \"PAYTOADDRESS\" };\n });\n\n const result = await TrezorConnect.signTransaction({\n branchId,\n coin: \"zcash\",\n expiry: 0,\n inputs,\n locktime: 0,\n // @ts-expect-error\n outputs,\n overwintered: true,\n version,\n versionGroupId,\n });\n\n if (result.success) {\n console.log(\"returning\", result.payload.serializedTx);\n return result.payload.serializedTx;\n }\n\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { chain, error: (result.payload as { error: string; code?: string }).error },\n });\n },\n };\n\n const toolbox = await getUtxoToolbox(Chain.Zcash);\n\n const transfer = async (params: GenericTransferParams) => {\n if (!(address && params.recipient)) {\n throw new SwapKitError({\n errorKey: \"wallet_missing_params\",\n info: { address, recipient: params.recipient, wallet: WalletOption.TREZOR },\n });\n }\n\n const feeRate = params.feeRate || (await toolbox.getFeeRates())[params.feeOptionKey || FeeOption.Fast];\n\n const { psbt } = await toolbox.createTransaction({ ...params, feeRate, fetchTxHex: false, sender: address });\n\n const txHex = await signer.signTransaction(psbt);\n const tx = await toolbox.broadcastTx(txHex);\n\n return tx;\n };\n\n return { ...toolbox, address, signTransaction: signer.signTransaction, transfer };\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { toCashAddress, getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const scriptType = getScriptType(derivationPath);\n\n if (!scriptType) {\n throw new SwapKitError({ errorKey: \"wallet_trezor_derivation_path_not_supported\", info: { derivationPath } });\n }\n\n const coin = chain.toLowerCase();\n\n const getAddress = async (path: DerivationPathArray = derivationPath) => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const { success, payload } = await TrezorConnect.getAddress({ coin, path: derivationPathToString(path) });\n\n if (!success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_get_address\",\n info: { chain, error: (payload as { error: string; code?: string }).error || \"Unknown error\" },\n });\n }\n\n if (chain === Chain.BitcoinCash) {\n const toolbox = await getUtxoToolbox(chain as Chain.BitcoinCash);\n return toolbox.stripPrefix(payload.address);\n }\n\n return payload.address;\n };\n\n const address = await getAddress();\n\n const signTransaction = async (psbt: Psbt, inputs: UTXOType[], memo = \"\") => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const address_n = derivationPath.map((pathElement, index) =>\n index < 3 ? ((pathElement as number) | 0x80000000) >>> 0 : (pathElement as number),\n );\n const toolbox = await getUtxoToolbox(chain as Chain.BitcoinCash);\n\n const result = await TrezorConnect.signTransaction({\n coin,\n inputs: inputs.map(({ hash, index, value }) => ({\n // Hardens the first 3 elements of the derivation path - required by trezor\n address_n,\n // object needs amount but does not use it for signing\n amount: value,\n prev_hash: hash,\n prev_index: index,\n script_type: scriptType.input,\n })),\n outputs: psbt.txOutputs.map((output) => {\n // OP_RETURN\n if (!output.address) {\n return { amount: \"0\", op_return_data: Buffer.from(memo).toString(\"hex\"), script_type: \"PAYTOOPRETURN\" };\n }\n\n const outputAddress =\n chain === Chain.BitcoinCash ? toolbox.stripPrefix(toCashAddress(output.address)) : output.address;\n\n const isChangeAddress = outputAddress === address;\n\n return isChangeAddress\n ? { address_n, amount: output.value, script_type: scriptType.output }\n : { address: outputAddress, amount: output.value, script_type: \"PAYTOADDRESS\" };\n }),\n });\n\n if (result.success) {\n return result.payload.serializedTx;\n }\n\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { chain, error: (result.payload as { error: string; code?: string }).error },\n });\n };\n\n const transfer = async ({\n recipient,\n feeOptionKey,\n feeRate: paramFeeRate,\n memo,\n ...rest\n }: GenericTransferParams) => {\n if (!(address && recipient)) {\n throw new SwapKitError({\n errorKey: \"wallet_missing_params\",\n info: { address, memo, recipient, wallet: WalletOption.TREZOR },\n });\n }\n\n const toolbox = await getUtxoToolbox(chain);\n\n const feeRate = paramFeeRate || (await toolbox.getFeeRates())[feeOptionKey || FeeOption.Fast];\n\n const createTxMethod =\n chain === Chain.BitcoinCash\n ? (toolbox as UTXOToolboxes[\"BCH\"]).buildTx\n : (toolbox as UTXOToolboxes[\"BTC\"]).createTransaction;\n\n const { psbt, inputs } = await createTxMethod({\n ...rest,\n feeRate,\n fetchTxHex: true,\n memo,\n recipient,\n sender: address,\n });\n\n const txHex = await signTransaction(psbt, inputs, memo);\n const tx = await toolbox.broadcastTx(txHex);\n\n return tx;\n };\n\n const toolbox = await getUtxoToolbox(chain);\n\n return { ...toolbox, address, signTransaction, transfer };\n }\n\n default:\n throw new SwapKitError({ errorKey: \"wallet_chain_not_supported\", info: { chain, wallet: WalletOption.TREZOR } });\n }\n}\n\nexport const trezorWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectTrezor(chains: Chain[], derivationPath: DerivationPathArray) {\n const [chain] = filterSupportedChains({ chains, supportedChains, walletType });\n if (!chain) {\n throw new SwapKitError({\n errorKey: \"wallet_chain_not_supported\",\n info: { chain, wallet: WalletOption.TREZOR },\n });\n }\n\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const { success } = await TrezorConnect.getDeviceState();\n\n if (!success) {\n const trezorConfig = SKConfig.get(\"integrations\").trezor;\n const manifest = trezorConfig\n ? { ...trezorConfig, appName: (trezorConfig as any).appName || \"SwapKit\" }\n : { appName: \"SwapKit\", appUrl: \"\", email: \"\" };\n TrezorConnect.init({ lazyLoad: true, manifest });\n }\n\n const wallet = await getTrezorWallet({ chain, derivationPath });\n\n addChain({ ...wallet, chain, walletType });\n\n return true;\n },\n name: \"connectTrezor\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Dash,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Litecoin,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Zcash,\n ],\n walletType: WalletOption.TREZOR,\n});\n\nexport const TREZOR_SUPPORTED_CHAINS = getWalletSupportedChains(trezorWallet);\n"
|
|
6
6
|
],
|
|
7
|
-
"mappings": "gDACA,gBACE,4BAEA,eACA,2BACA,cAEA,kBACA,kBACA,yBAGF,uBAAS,8BAAc,6BAGvB,SAAS,CAAa,CAAC,EAAqC,CAC1D,OAAQ,EAAe,QAChB,IACH,MAAO,CAAE,MAAO,eAAgB,OAAQ,cAAe,MACpD,IACH,MAAO,CAAE,MAAO,mBAAoB,OAAQ,kBAAmB,MAC5D,IACH,MAAO,CAAE,MAAO,eAAgB,OAAQ,cAAe,UAEvD,OAAO,MAIb,eAAe,CAAgC,EAC7C,QACA,kBAIC,CACD,OAAQ,QACD,EAAM,cACN,EAAM,YACN,EAAM,eACN,EAAM,UACN,EAAM,uBACN,EAAM,cACN,EAAM,YACN,EAAM,cACN,EAAM,QAAS,CAClB,IAAQ,cAAa,iBAAkB,KAAa,mCAC5C,gBAAiB,KAAa,gCAEhC,EAAW,MAAM,EAAY,CAAK,EAClC,EAAS,MAAM,EAAa,CAAE,QAAO,iBAAgB,UAAS,CAAC,EAC/D,EAAU,MAAM,EAAO,WAAW,EAGxC,MAAO,IAFS,MAAM,EAAc,EAAO,CAAE,WAAU,QAAO,CAAC,EAE1C,SAAQ,CAC/B,MAEK,EAAM,MAAO,CAChB,IAAQ,kBAAmB,KAAa,mCAElC,EAAoB,EAAuB,CAAc,EAgBzD,EAAU,MAdG,SAAY,CAC7B,IAAM,GAAiB,KAAa,gCAAwB,SACpD,UAAS,WAAY,MAAM,EAAc,WAAW,CAAE,KAAM,
|
|
8
|
-
"debugId": "
|
|
7
|
+
"mappings": "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",
|
|
8
|
+
"debugId": "1E15D2D0944DD2AD64756E2164756E21",
|
|
9
9
|
"names": []
|
|
10
10
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/trezor/index.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,EACL,KAAK,mBAAmB,EAQzB,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/trezor/index.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,EACL,KAAK,mBAAmB,EAQzB,MAAM,kBAAkB,CAAC;AA8R1B,eAAO,MAAM,YAAY;;;;;;;CA+CvB,CAAC;AAEH,eAAO,MAAM,uBAAuB,8PAAyC,CAAC"}
|
package/package.json
CHANGED
|
@@ -13,8 +13,8 @@
|
|
|
13
13
|
"@ledgerhq/hw-transport": "~6.31.0",
|
|
14
14
|
"@ledgerhq/hw-transport-webusb": "~6.29.0",
|
|
15
15
|
"@ledgerhq/wallet-api-client": "~1.11.0",
|
|
16
|
-
"@swapkit/helpers": "4.0.
|
|
17
|
-
"@swapkit/toolboxes": "4.0.
|
|
16
|
+
"@swapkit/helpers": "4.0.15",
|
|
17
|
+
"@swapkit/toolboxes": "4.0.15",
|
|
18
18
|
"ethers": "^6.14.0",
|
|
19
19
|
"ts-pattern": "^5.7.0"
|
|
20
20
|
},
|
|
@@ -72,5 +72,5 @@
|
|
|
72
72
|
"type-check:go": "tsgo"
|
|
73
73
|
},
|
|
74
74
|
"type": "module",
|
|
75
|
-
"version": "4.1.
|
|
75
|
+
"version": "4.1.14"
|
|
76
76
|
}
|