@tcswap/wallet-hardware 4.2.16

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.
Files changed (123) hide show
  1. package/dist/chunk-1w9rn6fj.js +5 -0
  2. package/dist/chunk-1w9rn6fj.js.map +10 -0
  3. package/dist/chunk-1z3vq8v6.js +4 -0
  4. package/dist/chunk-1z3vq8v6.js.map +10 -0
  5. package/dist/chunk-3jd7804n.js +4 -0
  6. package/dist/chunk-3jd7804n.js.map +10 -0
  7. package/dist/chunk-4pybhxzx.js +4 -0
  8. package/dist/chunk-4pybhxzx.js.map +10 -0
  9. package/dist/chunk-9kbkdt6e.js +4 -0
  10. package/dist/chunk-9kbkdt6e.js.map +10 -0
  11. package/dist/chunk-eng8tyvd.js +4 -0
  12. package/dist/chunk-eng8tyvd.js.map +10 -0
  13. package/dist/chunk-fazw0jvt.js +4 -0
  14. package/dist/chunk-fazw0jvt.js.map +9 -0
  15. package/dist/chunk-zzfbcc7e.js +5 -0
  16. package/dist/chunk-zzfbcc7e.js.map +9 -0
  17. package/dist/index.cjs +4 -0
  18. package/dist/index.cjs.map +9 -0
  19. package/dist/index.js +3 -0
  20. package/dist/index.js.map +9 -0
  21. package/dist/keepkey/index.cjs +4 -0
  22. package/dist/keepkey/index.cjs.map +15 -0
  23. package/dist/keepkey/index.js +4 -0
  24. package/dist/keepkey/index.js.map +15 -0
  25. package/dist/ledger/index.cjs +5 -0
  26. package/dist/ledger/index.cjs.map +25 -0
  27. package/dist/ledger/index.js +5 -0
  28. package/dist/ledger/index.js.map +25 -0
  29. package/dist/trezor/index.cjs +4 -0
  30. package/dist/trezor/index.cjs.map +10 -0
  31. package/dist/trezor/index.js +4 -0
  32. package/dist/trezor/index.js.map +10 -0
  33. package/dist/types/index.d.ts +2 -0
  34. package/dist/types/index.d.ts.map +1 -0
  35. package/dist/types/keepkey/chains/cosmos.d.ts +7 -0
  36. package/dist/types/keepkey/chains/cosmos.d.ts.map +1 -0
  37. package/dist/types/keepkey/chains/evm.d.ts +29 -0
  38. package/dist/types/keepkey/chains/evm.d.ts.map +1 -0
  39. package/dist/types/keepkey/chains/mayachain.d.ts +10 -0
  40. package/dist/types/keepkey/chains/mayachain.d.ts.map +1 -0
  41. package/dist/types/keepkey/chains/ripple.d.ts +37 -0
  42. package/dist/types/keepkey/chains/ripple.d.ts.map +1 -0
  43. package/dist/types/keepkey/chains/thorchain.d.ts +10 -0
  44. package/dist/types/keepkey/chains/thorchain.d.ts.map +1 -0
  45. package/dist/types/keepkey/chains/utxo.d.ts +25 -0
  46. package/dist/types/keepkey/chains/utxo.d.ts.map +1 -0
  47. package/dist/types/keepkey/coins.d.ts +15 -0
  48. package/dist/types/keepkey/coins.d.ts.map +1 -0
  49. package/dist/types/keepkey/index.d.ts +15 -0
  50. package/dist/types/keepkey/index.d.ts.map +1 -0
  51. package/dist/types/ledger/clients/cosmos.d.ts +23 -0
  52. package/dist/types/ledger/clients/cosmos.d.ts.map +1 -0
  53. package/dist/types/ledger/clients/evm.d.ts +52 -0
  54. package/dist/types/ledger/clients/evm.d.ts.map +1 -0
  55. package/dist/types/ledger/clients/near.d.ts +7 -0
  56. package/dist/types/ledger/clients/near.d.ts.map +1 -0
  57. package/dist/types/ledger/clients/thorchain/common.d.ts +28 -0
  58. package/dist/types/ledger/clients/thorchain/common.d.ts.map +1 -0
  59. package/dist/types/ledger/clients/thorchain/helpers.d.ts +10 -0
  60. package/dist/types/ledger/clients/thorchain/helpers.d.ts.map +1 -0
  61. package/dist/types/ledger/clients/thorchain/index.d.ts +25 -0
  62. package/dist/types/ledger/clients/thorchain/index.d.ts.map +1 -0
  63. package/dist/types/ledger/clients/thorchain/lib.d.ts +25 -0
  64. package/dist/types/ledger/clients/thorchain/lib.d.ts.map +1 -0
  65. package/dist/types/ledger/clients/thorchain/utils.d.ts +5 -0
  66. package/dist/types/ledger/clients/thorchain/utils.d.ts.map +1 -0
  67. package/dist/types/ledger/clients/tron.d.ts +26 -0
  68. package/dist/types/ledger/clients/tron.d.ts.map +1 -0
  69. package/dist/types/ledger/clients/utxo.d.ts +43 -0
  70. package/dist/types/ledger/clients/utxo.d.ts.map +1 -0
  71. package/dist/types/ledger/clients/xrp.d.ts +11 -0
  72. package/dist/types/ledger/clients/xrp.d.ts.map +1 -0
  73. package/dist/types/ledger/cosmosTypes.d.ts +43 -0
  74. package/dist/types/ledger/cosmosTypes.d.ts.map +1 -0
  75. package/dist/types/ledger/helpers/getLedgerAddress.d.ts +10 -0
  76. package/dist/types/ledger/helpers/getLedgerAddress.d.ts.map +1 -0
  77. package/dist/types/ledger/helpers/getLedgerClient.d.ts +42 -0
  78. package/dist/types/ledger/helpers/getLedgerClient.d.ts.map +1 -0
  79. package/dist/types/ledger/helpers/getLedgerTransport.d.ts +6 -0
  80. package/dist/types/ledger/helpers/getLedgerTransport.d.ts.map +1 -0
  81. package/dist/types/ledger/helpers/index.d.ts +4 -0
  82. package/dist/types/ledger/helpers/index.d.ts.map +1 -0
  83. package/dist/types/ledger/index.d.ts +14 -0
  84. package/dist/types/ledger/index.d.ts.map +1 -0
  85. package/dist/types/ledger/interfaces/CosmosLedgerInterface.d.ts +14 -0
  86. package/dist/types/ledger/interfaces/CosmosLedgerInterface.d.ts.map +1 -0
  87. package/dist/types/ledger/types.d.ts +16 -0
  88. package/dist/types/ledger/types.d.ts.map +1 -0
  89. package/dist/types/trezor/evmSigner.d.ts +32 -0
  90. package/dist/types/trezor/evmSigner.d.ts.map +1 -0
  91. package/dist/types/trezor/index.d.ts +14 -0
  92. package/dist/types/trezor/index.d.ts.map +1 -0
  93. package/package.json +101 -0
  94. package/src/index.ts +1 -0
  95. package/src/keepkey/chains/cosmos.ts +69 -0
  96. package/src/keepkey/chains/evm.ts +117 -0
  97. package/src/keepkey/chains/mayachain.ts +102 -0
  98. package/src/keepkey/chains/ripple.ts +88 -0
  99. package/src/keepkey/chains/thorchain.ts +97 -0
  100. package/src/keepkey/chains/utxo.ts +141 -0
  101. package/src/keepkey/coins.ts +70 -0
  102. package/src/keepkey/index.ts +159 -0
  103. package/src/ledger/clients/cosmos.ts +83 -0
  104. package/src/ledger/clients/evm.ts +145 -0
  105. package/src/ledger/clients/near.ts +67 -0
  106. package/src/ledger/clients/thorchain/common.ts +93 -0
  107. package/src/ledger/clients/thorchain/helpers.ts +124 -0
  108. package/src/ledger/clients/thorchain/index.ts +91 -0
  109. package/src/ledger/clients/thorchain/lib.ts +282 -0
  110. package/src/ledger/clients/thorchain/utils.ts +71 -0
  111. package/src/ledger/clients/tron.ts +84 -0
  112. package/src/ledger/clients/utxo.ts +158 -0
  113. package/src/ledger/clients/xrp.ts +50 -0
  114. package/src/ledger/cosmosTypes.ts +102 -0
  115. package/src/ledger/helpers/getLedgerAddress.ts +73 -0
  116. package/src/ledger/helpers/getLedgerClient.ts +121 -0
  117. package/src/ledger/helpers/getLedgerTransport.ts +106 -0
  118. package/src/ledger/helpers/index.ts +3 -0
  119. package/src/ledger/index.ts +303 -0
  120. package/src/ledger/interfaces/CosmosLedgerInterface.ts +58 -0
  121. package/src/ledger/types.ts +40 -0
  122. package/src/trezor/evmSigner.ts +181 -0
  123. package/src/trezor/index.ts +350 -0
@@ -0,0 +1,350 @@
1
+ /**
2
+ * Modifications © 2025 Horizontal Systems.
3
+ */
4
+
5
+ import type { ZcashPsbt } from "@bitgo/utxo-lib/dist/src/bitgo";
6
+ import {
7
+ Chain,
8
+ type DerivationPathArray,
9
+ derivationPathToString,
10
+ FeeOption,
11
+ filterSupportedChains,
12
+ type GenericTransferParams,
13
+ USwapConfig,
14
+ USwapError,
15
+ WalletOption,
16
+ } from "@tcswap/helpers";
17
+ import type { UTXOToolboxes, UTXOType } from "@tcswap/toolboxes/utxo";
18
+ import { createWallet, getWalletSupportedChains } from "@tcswap/wallet-core";
19
+ import { type Psbt, script } from "bitcoinjs-lib";
20
+
21
+ function getScriptType(derivationPath: DerivationPathArray) {
22
+ switch (derivationPath[0]) {
23
+ case 84:
24
+ return { input: "SPENDWITNESS", output: "PAYTOWITNESS" } as const;
25
+ case 49:
26
+ return { input: "SPENDP2SHWITNESS", output: "PAYTOP2SHWITNESS" } as const;
27
+ case 44:
28
+ return { input: "SPENDADDRESS", output: "PAYTOADDRESS" } as const;
29
+ default:
30
+ return null;
31
+ }
32
+ }
33
+
34
+ async function getTrezorWallet<T extends Chain>({
35
+ chain,
36
+ derivationPath,
37
+ }: {
38
+ chain: T;
39
+ derivationPath: DerivationPathArray;
40
+ }) {
41
+ switch (chain) {
42
+ case Chain.Arbitrum:
43
+ case Chain.Aurora:
44
+ case Chain.Avalanche:
45
+ case Chain.Base:
46
+ case Chain.BinanceSmartChain:
47
+ case Chain.Ethereum:
48
+ case Chain.Gnosis:
49
+ case Chain.Monad:
50
+ case Chain.Optimism:
51
+ case Chain.Polygon:
52
+ case Chain.XLayer: {
53
+ const { getProvider, getEvmToolbox } = await import("@tcswap/toolboxes/evm");
54
+ const { getEVMSigner } = await import("./evmSigner");
55
+
56
+ const provider = await getProvider(chain);
57
+ const signer = await getEVMSigner({ chain, derivationPath, provider });
58
+ const address = await signer.getAddress();
59
+ const toolbox = await getEvmToolbox(chain, { provider, signer });
60
+
61
+ return { ...toolbox, address };
62
+ }
63
+
64
+ case Chain.Zcash: {
65
+ const { getUtxoToolbox } = await import("@tcswap/toolboxes/utxo");
66
+
67
+ const derivationPathStr = derivationPathToString(derivationPath);
68
+
69
+ const getAddress = async () => {
70
+ const TrezorConnect = (await import("@trezor/connect-web")).default;
71
+ const { success, payload } = await TrezorConnect.getAddress({ coin: "zcash", path: derivationPathStr });
72
+
73
+ if (!success) {
74
+ throw new USwapError({
75
+ errorKey: "wallet_trezor_failed_to_get_address",
76
+ info: { chain, error: (payload as { error: string; code?: string }).error || "Unknown error" },
77
+ });
78
+ }
79
+
80
+ return payload.address;
81
+ };
82
+
83
+ const address = await getAddress();
84
+
85
+ const signer = {
86
+ getAddress: async () => address,
87
+ signTransaction: async (zcashPsbt: ZcashPsbt) => {
88
+ const TrezorConnect = (await import("@trezor/connect-web")).default;
89
+ const { address: zcashAddress, networks } = await import("@bitgo/utxo-lib");
90
+ const address_n = derivationPath.map((pathElement, index) =>
91
+ index < 3 ? ((pathElement as number) | 0x80000000) >>> 0 : (pathElement as number),
92
+ );
93
+
94
+ const version = 5;
95
+ const versionGroupId = 0x26a7270a;
96
+ const branchId = 0x4dec4df0;
97
+
98
+ const inputs = zcashPsbt.txInputs.map((input, idx) => ({
99
+ address_n,
100
+ amount: zcashPsbt.data.inputs[idx]?.witnessUtxo?.value?.toString() || "0",
101
+ prev_hash: input.hash.reverse().toString("hex"),
102
+ prev_index: input.index,
103
+ script_type: "SPENDADDRESS" as const,
104
+ }));
105
+
106
+ const outputs = zcashPsbt.txOutputs.map((output) => {
107
+ if (
108
+ Number(output.value) === 0 &&
109
+ output.script.length > 0 &&
110
+ output.script[0] === 0x6a &&
111
+ script.decompile(output.script)
112
+ ) {
113
+ return {
114
+ amount: "0",
115
+ op_return_data: (script.decompile(output.script) as any)[1].toString("hex"),
116
+ script_type: "PAYTOOPRETURN",
117
+ };
118
+ }
119
+
120
+ const maybeRecipient = zcashAddress.fromOutputScript(output.script, networks.zcash);
121
+ const isChangeAddress = maybeRecipient === address;
122
+
123
+ return isChangeAddress
124
+ ? { address_n, amount: output.value.toString(), script_type: "PAYTOADDRESS" }
125
+ : { address: maybeRecipient, amount: output.value.toString(), script_type: "PAYTOADDRESS" };
126
+ });
127
+
128
+ const result = await TrezorConnect.signTransaction({
129
+ branchId,
130
+ coin: "zcash",
131
+ expiry: 0,
132
+ inputs,
133
+ locktime: 0,
134
+ // @ts-expect-error
135
+ outputs,
136
+ overwintered: true,
137
+ version,
138
+ versionGroupId,
139
+ });
140
+
141
+ if (result.success) {
142
+ return result.payload.serializedTx;
143
+ }
144
+
145
+ throw new USwapError({
146
+ errorKey: "wallet_trezor_failed_to_sign_transaction",
147
+ info: { chain, error: (result.payload as { error: string; code?: string }).error },
148
+ });
149
+ },
150
+ };
151
+
152
+ const toolbox = await getUtxoToolbox(Chain.Zcash);
153
+
154
+ const transfer = async (params: GenericTransferParams) => {
155
+ if (!(address && params.recipient)) {
156
+ throw new USwapError({
157
+ errorKey: "wallet_missing_params",
158
+ info: { address, recipient: params.recipient, wallet: WalletOption.TREZOR },
159
+ });
160
+ }
161
+
162
+ const feeRate = params.feeRate || (await toolbox.getFeeRates())[params.feeOptionKey || FeeOption.Fast];
163
+
164
+ const { psbt } = await toolbox.createTransaction({ ...params, feeRate, fetchTxHex: false, sender: address });
165
+
166
+ const txHex = await signer.signTransaction(psbt);
167
+ const tx = await toolbox.broadcastTx(txHex);
168
+
169
+ return tx;
170
+ };
171
+
172
+ return { ...toolbox, address, signTransaction: signer.signTransaction, transfer };
173
+ }
174
+
175
+ case Chain.Bitcoin:
176
+ case Chain.BitcoinCash:
177
+ case Chain.Dash:
178
+ case Chain.Dogecoin:
179
+ case Chain.Litecoin: {
180
+ const { toCashAddress, getUtxoToolbox } = await import("@tcswap/toolboxes/utxo");
181
+ const scriptType = getScriptType(derivationPath);
182
+
183
+ if (!scriptType) {
184
+ throw new USwapError({ errorKey: "wallet_trezor_derivation_path_not_supported", info: { derivationPath } });
185
+ }
186
+
187
+ const coin = chain.toLowerCase();
188
+
189
+ const getAddress = async (path: DerivationPathArray = derivationPath) => {
190
+ const TrezorConnect = (await import("@trezor/connect-web")).default;
191
+ const { success, payload } = await TrezorConnect.getAddress({ coin, path: derivationPathToString(path) });
192
+
193
+ if (!success) {
194
+ throw new USwapError({
195
+ errorKey: "wallet_trezor_failed_to_get_address",
196
+ info: { chain, error: (payload as { error: string; code?: string }).error || "Unknown error" },
197
+ });
198
+ }
199
+
200
+ if (chain === Chain.BitcoinCash) {
201
+ const toolbox = await getUtxoToolbox(chain as typeof Chain.BitcoinCash);
202
+ return toolbox.stripPrefix(payload.address);
203
+ }
204
+
205
+ return payload.address;
206
+ };
207
+
208
+ const address = await getAddress();
209
+
210
+ const signTransaction = async (psbt: Psbt, inputs: UTXOType[], memo = "") => {
211
+ const TrezorConnect = (await import("@trezor/connect-web")).default;
212
+ const address_n = derivationPath.map((pathElement, index) =>
213
+ index < 3 ? ((pathElement as number) | 0x80000000) >>> 0 : (pathElement as number),
214
+ );
215
+ const toolbox = await getUtxoToolbox(chain as typeof Chain.BitcoinCash);
216
+
217
+ const result = await TrezorConnect.signTransaction({
218
+ coin,
219
+ inputs: inputs.map(({ hash, index, value }) => ({
220
+ // Hardens the first 3 elements of the derivation path - required by trezor
221
+ address_n,
222
+ // object needs amount but does not use it for signing
223
+ amount: value,
224
+ prev_hash: hash,
225
+ prev_index: index,
226
+ script_type: scriptType.input,
227
+ })),
228
+ outputs: psbt.txOutputs.map((output) => {
229
+ if (!output.address) {
230
+ return { amount: "0", op_return_data: Buffer.from(memo).toString("hex"), script_type: "PAYTOOPRETURN" };
231
+ }
232
+
233
+ const outputAddress =
234
+ chain === Chain.BitcoinCash ? toolbox.stripPrefix(toCashAddress(output.address)) : output.address;
235
+
236
+ const isChangeAddress = outputAddress === address;
237
+
238
+ return isChangeAddress
239
+ ? { address_n, amount: output.value, script_type: scriptType.output }
240
+ : { address: outputAddress, amount: output.value, script_type: "PAYTOADDRESS" };
241
+ }),
242
+ });
243
+
244
+ if (result.success) {
245
+ return result.payload.serializedTx;
246
+ }
247
+
248
+ throw new USwapError({
249
+ errorKey: "wallet_trezor_failed_to_sign_transaction",
250
+ info: { chain, error: (result.payload as { error: string; code?: string }).error },
251
+ });
252
+ };
253
+
254
+ const transfer = async ({
255
+ recipient,
256
+ feeOptionKey,
257
+ feeRate: paramFeeRate,
258
+ memo,
259
+ ...rest
260
+ }: GenericTransferParams) => {
261
+ if (!(address && recipient)) {
262
+ throw new USwapError({
263
+ errorKey: "wallet_missing_params",
264
+ info: { address, memo, recipient, wallet: WalletOption.TREZOR },
265
+ });
266
+ }
267
+
268
+ const toolbox = await getUtxoToolbox(chain);
269
+
270
+ const feeRate = paramFeeRate || (await toolbox.getFeeRates())[feeOptionKey || FeeOption.Fast];
271
+
272
+ const createTxMethod =
273
+ chain === Chain.BitcoinCash
274
+ ? (toolbox as UTXOToolboxes["BCH"]).buildTx
275
+ : (toolbox as UTXOToolboxes["BTC"]).createTransaction;
276
+
277
+ const { psbt, inputs } = await createTxMethod({
278
+ ...rest,
279
+ feeRate,
280
+ fetchTxHex: true,
281
+ memo,
282
+ recipient,
283
+ sender: address,
284
+ });
285
+
286
+ const txHex = await signTransaction(psbt, inputs, memo);
287
+ const tx = await toolbox.broadcastTx(txHex);
288
+
289
+ return tx;
290
+ };
291
+
292
+ const toolbox = await getUtxoToolbox(chain);
293
+
294
+ return { ...toolbox, address, signTransaction, transfer };
295
+ }
296
+
297
+ default:
298
+ throw new USwapError({ errorKey: "wallet_chain_not_supported", info: { chain, wallet: WalletOption.TREZOR } });
299
+ }
300
+ }
301
+
302
+ export const trezorWallet = createWallet({
303
+ connect: ({ addChain, supportedChains, walletType }) =>
304
+ async function connectTrezor(chains: Chain[], derivationPath: DerivationPathArray) {
305
+ const [chain] = filterSupportedChains({ chains, supportedChains, walletType });
306
+ if (!chain) {
307
+ throw new USwapError({ errorKey: "wallet_chain_not_supported", info: { chain, wallet: WalletOption.TREZOR } });
308
+ }
309
+
310
+ const TrezorConnect = (await import("@trezor/connect-web")).default;
311
+ const { success } = await TrezorConnect.getDeviceState();
312
+
313
+ if (!success) {
314
+ const trezorConfig = USwapConfig.get("integrations").trezor;
315
+ const manifest = trezorConfig
316
+ ? { ...trezorConfig, appName: (trezorConfig as any).appName || "USwap" }
317
+ : { appName: "USwap", appUrl: "", email: "" };
318
+ TrezorConnect.init({ lazyLoad: true, manifest });
319
+ }
320
+
321
+ const wallet = await getTrezorWallet({ chain, derivationPath });
322
+
323
+ addChain({ ...wallet, chain, walletType });
324
+
325
+ return true;
326
+ },
327
+ name: "connectTrezor",
328
+ supportedChains: [
329
+ Chain.Arbitrum,
330
+ Chain.Aurora,
331
+ Chain.Avalanche,
332
+ Chain.Base,
333
+ Chain.BinanceSmartChain,
334
+ Chain.Bitcoin,
335
+ Chain.BitcoinCash,
336
+ Chain.Dash,
337
+ Chain.Dogecoin,
338
+ Chain.Ethereum,
339
+ Chain.Gnosis,
340
+ Chain.Litecoin,
341
+ Chain.Monad,
342
+ Chain.Optimism,
343
+ Chain.Polygon,
344
+ Chain.XLayer,
345
+ Chain.Zcash,
346
+ ],
347
+ walletType: WalletOption.TREZOR,
348
+ });
349
+
350
+ export const TREZOR_SUPPORTED_CHAINS = getWalletSupportedChains(trezorWallet);