@swapkit/wallet-hardware 4.2.11 → 4.6.1

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 (96) hide show
  1. package/dist/LICENSE +246 -0
  2. package/dist/{chunk-7fsaymh4.js → chunk-1jexf7qt.js} +3 -3
  3. package/dist/{chunk-7fsaymh4.js.map → chunk-1jexf7qt.js.map} +1 -1
  4. package/dist/chunk-1jpcb30j.js +5 -0
  5. package/dist/{chunk-fazw0jvt.js.map → chunk-1jpcb30j.js.map} +1 -1
  6. package/dist/chunk-4fapcrj9.js +5 -0
  7. package/dist/chunk-4fapcrj9.js.map +10 -0
  8. package/dist/chunk-d54qkn5p.js +4 -0
  9. package/dist/chunk-d54qkn5p.js.map +10 -0
  10. package/dist/chunk-jj2v7mke.js +4 -0
  11. package/dist/chunk-jj2v7mke.js.map +10 -0
  12. package/dist/chunk-p94hfx8x.js +4 -0
  13. package/dist/{chunk-zzfbcc7e.js.map → chunk-p94hfx8x.js.map} +1 -1
  14. package/dist/chunk-skvfn1dg.js +4 -0
  15. package/dist/chunk-skvfn1dg.js.map +10 -0
  16. package/dist/{chunk-37bgpz1y.js → chunk-ybje7f3s.js} +3 -3
  17. package/dist/{chunk-37bgpz1y.js.map → chunk-ybje7f3s.js.map} +1 -1
  18. package/dist/keepkey/index.cjs +2 -2
  19. package/dist/keepkey/index.cjs.map +5 -5
  20. package/dist/keepkey/index.js +2 -2
  21. package/dist/keepkey/index.js.map +5 -5
  22. package/dist/ledger/index.cjs +3 -3
  23. package/dist/ledger/index.cjs.map +11 -10
  24. package/dist/ledger/index.js +3 -3
  25. package/dist/ledger/index.js.map +11 -10
  26. package/dist/trezor/index.cjs +2 -2
  27. package/dist/trezor/index.cjs.map +3 -3
  28. package/dist/trezor/index.js +2 -2
  29. package/dist/trezor/index.js.map +3 -3
  30. package/dist/types/core.d.ts +18 -0
  31. package/dist/types/core.d.ts.map +1 -0
  32. package/dist/types/keepkey/chains/evm.d.ts +2 -2
  33. package/dist/types/keepkey/chains/evm.d.ts.map +1 -1
  34. package/dist/types/keepkey/chains/ripple.d.ts +15 -8
  35. package/dist/types/keepkey/chains/ripple.d.ts.map +1 -1
  36. package/dist/types/keepkey/chains/utxo.d.ts +331 -5
  37. package/dist/types/keepkey/chains/utxo.d.ts.map +1 -1
  38. package/dist/types/keepkey/index.d.ts +3 -3
  39. package/dist/types/keepkey/index.d.ts.map +1 -1
  40. package/dist/types/ledger/clients/evm.d.ts +3 -2
  41. package/dist/types/ledger/clients/evm.d.ts.map +1 -1
  42. package/dist/types/ledger/clients/sui.d.ts +27 -0
  43. package/dist/types/ledger/clients/sui.d.ts.map +1 -0
  44. package/dist/types/ledger/clients/thorchain/lib.d.ts.map +1 -1
  45. package/dist/types/ledger/clients/utxo.d.ts +43 -7
  46. package/dist/types/ledger/clients/utxo.d.ts.map +1 -1
  47. package/dist/types/ledger/clients/xrp.d.ts +2 -2
  48. package/dist/types/ledger/clients/xrp.d.ts.map +1 -1
  49. package/dist/types/ledger/helpers/getLedgerAddress.d.ts.map +1 -1
  50. package/dist/types/ledger/helpers/getLedgerClient.d.ts +4 -1
  51. package/dist/types/ledger/helpers/getLedgerClient.d.ts.map +1 -1
  52. package/dist/types/ledger/index.d.ts +3 -3
  53. package/dist/types/ledger/index.d.ts.map +1 -1
  54. package/dist/types/ledger/types.d.ts +2 -0
  55. package/dist/types/ledger/types.d.ts.map +1 -1
  56. package/dist/types/trezor/evmSigner.d.ts +2 -2
  57. package/dist/types/trezor/evmSigner.d.ts.map +1 -1
  58. package/dist/types/trezor/index.d.ts +3 -3
  59. package/dist/types/trezor/index.d.ts.map +1 -1
  60. package/package.json +51 -40
  61. package/dist/chunk-4k7gb7ss.js +0 -4
  62. package/dist/chunk-4k7gb7ss.js.map +0 -10
  63. package/dist/chunk-93cj7bky.js +0 -4
  64. package/dist/chunk-93cj7bky.js.map +0 -10
  65. package/dist/chunk-fazw0jvt.js +0 -4
  66. package/dist/chunk-zzfbcc7e.js +0 -5
  67. package/src/index.ts +0 -1
  68. package/src/keepkey/chains/cosmos.ts +0 -69
  69. package/src/keepkey/chains/evm.ts +0 -114
  70. package/src/keepkey/chains/mayachain.ts +0 -98
  71. package/src/keepkey/chains/ripple.ts +0 -88
  72. package/src/keepkey/chains/thorchain.ts +0 -93
  73. package/src/keepkey/chains/utxo.ts +0 -137
  74. package/src/keepkey/coins.ts +0 -67
  75. package/src/keepkey/index.ts +0 -155
  76. package/src/ledger/clients/cosmos.ts +0 -84
  77. package/src/ledger/clients/evm.ts +0 -141
  78. package/src/ledger/clients/near.ts +0 -63
  79. package/src/ledger/clients/thorchain/common.ts +0 -93
  80. package/src/ledger/clients/thorchain/helpers.ts +0 -120
  81. package/src/ledger/clients/thorchain/index.ts +0 -87
  82. package/src/ledger/clients/thorchain/lib.ts +0 -278
  83. package/src/ledger/clients/thorchain/utils.ts +0 -69
  84. package/src/ledger/clients/tron.ts +0 -85
  85. package/src/ledger/clients/utxo.ts +0 -154
  86. package/src/ledger/clients/xrp.ts +0 -50
  87. package/src/ledger/cosmosTypes.ts +0 -98
  88. package/src/ledger/helpers/getLedgerAddress.ts +0 -69
  89. package/src/ledger/helpers/getLedgerClient.ts +0 -117
  90. package/src/ledger/helpers/getLedgerTransport.ts +0 -102
  91. package/src/ledger/helpers/index.ts +0 -3
  92. package/src/ledger/index.ts +0 -299
  93. package/src/ledger/interfaces/CosmosLedgerInterface.ts +0 -54
  94. package/src/ledger/types.ts +0 -40
  95. package/src/trezor/evmSigner.ts +0 -177
  96. package/src/trezor/index.ts +0 -349
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/ledger/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,EASN,MAAM,kBAAkB,CAAC;AAO1B,eAAO,MAAM,YAAY;;;;;;;CAuCvB,CAAC;AAEH,eAAO,MAAM,uBAAuB,qWAAyC,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/ledger/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,KAAK,EAYN,MAAM,kBAAkB,CAAC;AAc1B,eAAO,MAAM,YAAY;;;;;;;CAyCvB,CAAC;AAEH,eAAO,MAAM,uBAAuB,mYAAyC,CAAC"}
@@ -1,5 +1,6 @@
1
1
  import type { CosmosLedger } from "./clients/cosmos";
2
2
  import type { ArbitrumLedger, AuroraLedger, AvalancheLedger, BaseLedger, BinanceSmartChainLedger, EthereumLedger, GnosisLedger, OptimismLedger, PolygonLedger } from "./clients/evm";
3
+ import type { SuiLedger } from "./clients/sui";
3
4
  import type { THORChainLedger } from "./clients/thorchain";
4
5
  import type { TronLedger } from "./clients/tron";
5
6
  import type { BitcoinCashLedger, BitcoinLedger, DogecoinLedger, LitecoinLedger } from "./clients/utxo";
@@ -7,6 +8,7 @@ export type UTXOLedgerClients = ReturnType<typeof BitcoinLedger> | ReturnType<ty
7
8
  export type CosmosLedgerClients = CosmosLedger | THORChainLedger;
8
9
  export type EVMLedgerClients = ReturnType<typeof ArbitrumLedger> | ReturnType<typeof AuroraLedger> | ReturnType<typeof AvalancheLedger> | ReturnType<typeof BaseLedger> | ReturnType<typeof BinanceSmartChainLedger> | ReturnType<typeof GnosisLedger> | ReturnType<typeof EthereumLedger> | ReturnType<typeof OptimismLedger> | ReturnType<typeof PolygonLedger>;
9
10
  export type TronLedgerClient = ReturnType<typeof TronLedger>;
11
+ export type SuiLedgerClient = ReturnType<typeof SuiLedger>;
10
12
  export type GetAddressAndPubKeyResponse = {
11
13
  bech32_address: string;
12
14
  compressed_pk: any;
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/ledger/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,KAAK,EACV,cAAc,EACd,YAAY,EACZ,eAAe,EACf,UAAU,EACV,uBAAuB,EACvB,cAAc,EACd,YAAY,EACZ,cAAc,EACd,aAAa,EACd,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,KAAK,EAAE,iBAAiB,EAAE,aAAa,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAEvG,MAAM,MAAM,iBAAiB,GACzB,UAAU,CAAC,OAAO,aAAa,CAAC,GAChC,UAAU,CAAC,OAAO,iBAAiB,CAAC,GACpC,UAAU,CAAC,OAAO,cAAc,CAAC,GACjC,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AACtC,MAAM,MAAM,mBAAmB,GAAG,YAAY,GAAG,eAAe,CAAC;AACjE,MAAM,MAAM,gBAAgB,GACxB,UAAU,CAAC,OAAO,cAAc,CAAC,GACjC,UAAU,CAAC,OAAO,YAAY,CAAC,GAC/B,UAAU,CAAC,OAAO,eAAe,CAAC,GAClC,UAAU,CAAC,OAAO,UAAU,CAAC,GAC7B,UAAU,CAAC,OAAO,uBAAuB,CAAC,GAC1C,UAAU,CAAC,OAAO,YAAY,CAAC,GAC/B,UAAU,CAAC,OAAO,cAAc,CAAC,GACjC,UAAU,CAAC,OAAO,cAAc,CAAC,GACjC,UAAU,CAAC,OAAO,aAAa,CAAC,CAAC;AACrC,MAAM,MAAM,gBAAgB,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAC;AAE7D,MAAM,MAAM,2BAA2B,GAAG;IACxC,cAAc,EAAE,MAAM,CAAC;IACvB,aAAa,EAAE,GAAG,CAAC;IACnB,aAAa,EAAE,MAAM,CAAC;IACtB,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/ledger/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,KAAK,EACV,cAAc,EACd,YAAY,EACZ,eAAe,EACf,UAAU,EACV,uBAAuB,EACvB,cAAc,EACd,YAAY,EACZ,cAAc,EACd,aAAa,EACd,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,KAAK,EAAE,iBAAiB,EAAE,aAAa,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAEvG,MAAM,MAAM,iBAAiB,GACzB,UAAU,CAAC,OAAO,aAAa,CAAC,GAChC,UAAU,CAAC,OAAO,iBAAiB,CAAC,GACpC,UAAU,CAAC,OAAO,cAAc,CAAC,GACjC,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AACtC,MAAM,MAAM,mBAAmB,GAAG,YAAY,GAAG,eAAe,CAAC;AACjE,MAAM,MAAM,gBAAgB,GACxB,UAAU,CAAC,OAAO,cAAc,CAAC,GACjC,UAAU,CAAC,OAAO,YAAY,CAAC,GAC/B,UAAU,CAAC,OAAO,eAAe,CAAC,GAClC,UAAU,CAAC,OAAO,UAAU,CAAC,GAC7B,UAAU,CAAC,OAAO,uBAAuB,CAAC,GAC1C,UAAU,CAAC,OAAO,YAAY,CAAC,GAC/B,UAAU,CAAC,OAAO,cAAc,CAAC,GACjC,UAAU,CAAC,OAAO,cAAc,CAAC,GACjC,UAAU,CAAC,OAAO,aAAa,CAAC,CAAC;AACrC,MAAM,MAAM,gBAAgB,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAC;AAC7D,MAAM,MAAM,eAAe,GAAG,UAAU,CAAC,OAAO,SAAS,CAAC,CAAC;AAE3D,MAAM,MAAM,2BAA2B,GAAG;IACxC,cAAc,EAAE,MAAM,CAAC;IACvB,aAAa,EAAE,GAAG,CAAC;IACnB,aAAa,EAAE,MAAM,CAAC;IACtB,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC"}
@@ -1,5 +1,5 @@
1
1
  import { type Chain, type DerivationPathArray } from "@swapkit/helpers";
2
- import type { JsonRpcProvider, Provider, TransactionRequest } from "ethers";
2
+ import type { JsonRpcProvider, Provider, TransactionRequest, TypedDataDomain, TypedDataField } from "ethers";
3
3
  type TrezorEVMSignerParams = {
4
4
  chain: Chain;
5
5
  derivationPath: DerivationPathArray;
@@ -12,7 +12,7 @@ export declare function getEVMSigner({ chain, derivationPath, provider }: Trezor
12
12
  readonly provider: Provider | JsonRpcProvider;
13
13
  getAddress: () => Promise<string>;
14
14
  signMessage: (message: string) => Promise<string>;
15
- signTypedData(): Promise<string>;
15
+ signTypedData: (domain: TypedDataDomain, types: Record<string, TypedDataField[]>, value: Record<string, unknown>, explicitPrimaryType?: string) => Promise<string>;
16
16
  signTransaction: ({ to, gasLimit, value, data, nonce, maxFeePerGas, maxPriorityFeePerGas, gasPrice, }: TransactionRequest) => Promise<string>;
17
17
  connect: (provider: Provider | null) => /*elided*/ any;
18
18
  getNonce(blockTag?: import("ethers").BlockTag): Promise<number>;
@@ -1 +1 @@
1
- {"version":3,"file":"evmSigner.d.ts","sourceRoot":"","sources":["../../../src/trezor/evmSigner.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,KAAK,EAEV,KAAK,mBAAmB,EAKzB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,KAAK,EAAE,eAAe,EAAE,QAAQ,EAAE,kBAAkB,EAAE,MAAM,QAAQ,CAAC;AAE5E,KAAK,qBAAqB,GAAG;IAC3B,KAAK,EAAE,KAAK,CAAC;IACb,cAAc,EAAE,mBAAmB,CAAC;IACpC,QAAQ,EAAE,QAAQ,GAAG,eAAe,CAAC;CACtC,CAAC;AAEF,wBAAsB,YAAY,CAAC,EAAE,KAAK,EAAE,cAAc,EAAE,QAAQ,EAAE,EAAE,qBAAqB;aAIhF,MAAM;WACR,KAAK;oBACI,mBAAmB;uBAChB,QAAQ,GAAG,eAAe;;kBAiCxB,SAAS,MAAM;qBAkBnB,OAAO,CAAC,MAAM,CAAC;sBAIP,qFAUtB,kBAAkB;cA0EV,UAAU,QAAQ,GAAG,IAAI;;;;;;;;;;GAavC"}
1
+ {"version":3,"file":"evmSigner.d.ts","sourceRoot":"","sources":["../../../src/trezor/evmSigner.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,KAAK,EAEV,KAAK,mBAAmB,EAKzB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,KAAK,EAAE,eAAe,EAAE,QAAQ,EAAE,kBAAkB,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAC;AAE7G,KAAK,qBAAqB,GAAG;IAC3B,KAAK,EAAE,KAAK,CAAC;IACb,cAAc,EAAE,mBAAmB,CAAC;IACpC,QAAQ,EAAE,QAAQ,GAAG,eAAe,CAAC;CACtC,CAAC;AAEF,wBAAsB,YAAY,CAAC,EAAE,KAAK,EAAE,cAAc,EAAE,QAAQ,EAAE,EAAE,qBAAqB;aAIhF,MAAM;WACR,KAAK;oBACI,mBAAmB;uBAChB,QAAQ,GAAG,eAAe;;kBAiCxB,SAAS,MAAM;oBAmBlC,QAAQ,eAAe,EACvB,OAAO,MAAM,CAAC,MAAM,EAAE,cAAc,EAAE,CAAC,EACvC,OAAO,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC9B,sBAAsB,MAAM;sBAiCL,qFAUtB,kBAAkB;cA0EV,UAAU,QAAQ,GAAG,IAAI;;;;;;;;;;GAavC"}
@@ -3,9 +3,9 @@ export declare const trezorWallet: {
3
3
  connectTrezor: {
4
4
  connectWallet: (connectParams: {
5
5
  addChain: import("@swapkit/helpers").AddChainType;
6
- }) => (chains: Chain[], derivationPath: [44, 118, 0, 0, 0] | [44, 931, 0, 0, 0] | [number, number, number, number, number] | [44, 397, 0, 0, 0] | [0, 0, 0, 0, 0] | [44, 144, 0, 0, 0] | [44, 501, 0, 0, 0] | [44, 607, 0, 0, 0] | [44, 195, 0, 0, 0] | [44, 784, 0, 0, 0] | [1852, 1815, 0, 0, 0] | [number, number, number, number, (number | undefined)?] | [44, 145, 0, 0, 0] | [84, 2, 0, 0, 0] | [44, 3, 0, 0, 0] | [44, 5, 0, 0, 0] | [44, 133, 0, 0, 0]) => Promise<boolean>;
7
- supportedChains: (Chain.Arbitrum | Chain.Aurora | Chain.Avalanche | Chain.Base | Chain.BinanceSmartChain | Chain.Bitcoin | Chain.BitcoinCash | Chain.Dash | Chain.Dogecoin | Chain.Ethereum | Chain.Gnosis | Chain.Litecoin | Chain.Monad | Chain.Optimism | Chain.Polygon | Chain.XLayer | Chain.Zcash)[];
6
+ }) => (chains: Chain[], derivationPath: [44, 118, 0, 0, 0] | [44, 931, 0, 0, 0] | [number, number, number, number, number] | [44, 637, 0, 0, 0] | [44, 397, 0, 0, 0] | [0, 0, 0, 0, 0] | [44, 144, 0, 0, 0] | [44, 501, 0, 0, 0] | [44, 607, 0, 0, 0] | [44, 195, 0, 0, 0] | [44, 148, 0, 0, 0] | [44, 784, 0, 0, 0] | [1852, 1815, 0, 0, 0] | [44, 9004, 0, 0, 0] | [number, number, number, number, (number | undefined)?] | [44, 145, 0, 0, 0] | [84, 2, 0, 0, 0] | [44, 3, 0, 0, 0] | [44, 5, 0, 0, 0] | [44, 133, 0, 0, 0]) => Promise<boolean>;
7
+ supportedChains: (Chain.Arbitrum | Chain.Aurora | Chain.Avalanche | Chain.Base | Chain.Berachain | Chain.BinanceSmartChain | Chain.Bitcoin | Chain.BitcoinCash | Chain.Dash | Chain.Dogecoin | Chain.Ethereum | Chain.Gnosis | Chain.Litecoin | Chain.Monad | Chain.Optimism | Chain.Polygon | Chain.XLayer | Chain.Zcash)[];
8
8
  };
9
9
  };
10
- export declare const TREZOR_SUPPORTED_CHAINS: (Chain.Arbitrum | Chain.Aurora | Chain.Avalanche | Chain.Base | Chain.BinanceSmartChain | Chain.Bitcoin | Chain.BitcoinCash | Chain.Dash | Chain.Dogecoin | Chain.Ethereum | Chain.Gnosis | Chain.Litecoin | Chain.Monad | Chain.Optimism | Chain.Polygon | Chain.XLayer | Chain.Zcash)[];
10
+ export declare const TREZOR_SUPPORTED_CHAINS: (Chain.Arbitrum | Chain.Aurora | Chain.Avalanche | Chain.Base | Chain.Berachain | Chain.BinanceSmartChain | Chain.Bitcoin | Chain.BitcoinCash | Chain.Dash | Chain.Dogecoin | Chain.Ethereum | Chain.Gnosis | Chain.Litecoin | Chain.Monad | Chain.Optimism | Chain.Polygon | Chain.XLayer | Chain.Zcash)[];
11
11
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/trezor/index.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,EASN,MAAM,kBAAkB,CAAC;AA8R1B,eAAO,MAAM,YAAY;;;;;;;CAiDvB,CAAC;AAEH,eAAO,MAAM,uBAAuB,2RAAyC,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/trezor/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,EAUN,MAAM,kBAAkB,CAAC;AAstB1B,eAAO,MAAM,YAAY;;;;;;;CAkDvB,CAAC;AAEH,eAAO,MAAM,uBAAuB,6SAAyC,CAAC"}
package/package.json CHANGED
@@ -1,56 +1,64 @@
1
1
  {
2
- "author": "swapkit-oss",
2
+ "author": "swapkit",
3
3
  "dependencies": {
4
+ "@cosmjs/amino": "~0.37.0",
4
5
  "@cosmjs/crypto": "0.37.0",
6
+ "@cosmjs/proto-signing": "~0.37.0",
5
7
  "@keepkey/keepkey-sdk": "~0.2.62",
6
- "@ledgerhq/devices": "~8.7.0",
7
- "@ledgerhq/errors": "~6.27.0",
8
- "@ledgerhq/hw-app-btc": "~10.12.0",
9
- "@ledgerhq/hw-app-cosmos": "~6.32.9",
10
- "@ledgerhq/hw-app-eth": "~6.47.0",
11
- "@ledgerhq/hw-app-near": "~6.31.9",
12
- "@ledgerhq/hw-app-trx": "~6.31.9",
13
- "@ledgerhq/hw-app-xrp": "~6.32.7",
14
- "@ledgerhq/hw-transport": "~6.31.0",
15
- "@ledgerhq/hw-transport-webhid": "~6.30.9",
16
- "@ledgerhq/hw-transport-webusb": "~6.29.13",
17
- "@ledgerhq/wallet-api-client": "~1.12.4",
8
+ "@ledgerhq/devices": "~8.10.0",
9
+ "@ledgerhq/errors": "~6.29.0",
10
+ "@ledgerhq/hw-app-btc": "~10.17.0",
11
+ "@ledgerhq/hw-app-cosmos": "~6.33.0",
12
+ "@ledgerhq/hw-app-eth": "~7.4.1",
13
+ "@ledgerhq/hw-app-near": "~6.32.0",
14
+ "@ledgerhq/hw-app-sui": "~1.5.0",
15
+ "@ledgerhq/hw-app-trx": "~6.32.0",
16
+ "@ledgerhq/hw-app-xrp": "~6.33.0",
17
+ "@ledgerhq/hw-transport": "~6.32.0",
18
+ "@ledgerhq/hw-transport-webhid": "~6.31.0",
19
+ "@ledgerhq/hw-transport-webusb": "~6.30.0",
20
+ "@ledgerhq/wallet-api-client": "~1.13.1",
18
21
  "@near-js/crypto": "~2.5.0",
19
22
  "@near-js/transactions": "~2.5.0",
20
- "@scure/base": "~2.0.0",
21
- "@swapkit/helpers": "4.5.9",
22
- "@swapkit/toolboxes": "4.3.10",
23
- "@swapkit/wallet-core": "4.0.53",
23
+ "@scure/base": "2.0.0",
24
+ "@swapkit/helpers": "^4.12.0",
25
+ "@swapkit/toolboxes": "^4.11.2",
26
+ "@swapkit/utxo-signer": "^2.1.0",
24
27
  "@trezor/connect-web": "~9.6.4",
25
28
  "cosmjs-types": "~0.10.1",
26
29
  "ethers": "^6.14.0",
27
30
  "ripple-binary-codec": "2.5.1",
28
- "ts-pattern": "^5.9.0"
31
+ "ts-pattern": "^5.9.0",
32
+ "xrpl": "~4.4.2"
29
33
  },
30
34
  "description": "SwapKit - Wallet Hardware",
31
35
  "devDependencies": {
36
+ "@cosmjs/amino": "0.37.0",
32
37
  "@cosmjs/crypto": "0.37.0",
38
+ "@cosmjs/proto-signing": "0.37.0",
33
39
  "@keepkey/keepkey-sdk": "0.2.62",
34
- "@ledgerhq/devices": "8.7.0",
35
- "@ledgerhq/errors": "6.27.0",
36
- "@ledgerhq/hw-app-btc": "10.12.0",
37
- "@ledgerhq/hw-app-cosmos": "6.32.9",
38
- "@ledgerhq/hw-app-eth": "6.47.0",
39
- "@ledgerhq/hw-app-near": "6.31.9",
40
- "@ledgerhq/hw-app-trx": "6.31.9",
41
- "@ledgerhq/hw-app-xrp": "6.32.7",
42
- "@ledgerhq/hw-transport": "6.31.10",
43
- "@ledgerhq/hw-transport-webhid": "6.30.9",
44
- "@ledgerhq/hw-transport-webusb": "6.29.13",
45
- "@ledgerhq/wallet-api-client": "1.12.4",
40
+ "@ledgerhq/devices": "8.10.0",
41
+ "@ledgerhq/errors": "6.29.0",
42
+ "@ledgerhq/hw-app-btc": "10.17.0",
43
+ "@ledgerhq/hw-app-cosmos": "6.33.0",
44
+ "@ledgerhq/hw-app-eth": "7.4.1",
45
+ "@ledgerhq/hw-app-near": "6.32.0",
46
+ "@ledgerhq/hw-app-sui": "1.5.0",
47
+ "@ledgerhq/hw-app-trx": "6.32.0",
48
+ "@ledgerhq/hw-app-xrp": "6.33.0",
49
+ "@ledgerhq/hw-transport": "6.32.0",
50
+ "@ledgerhq/hw-transport-webhid": "6.31.0",
51
+ "@ledgerhq/hw-transport-webusb": "6.30.0",
52
+ "@ledgerhq/wallet-api-client": "1.13.1",
46
53
  "@near-js/crypto": "2.5.0",
47
54
  "@near-js/transactions": "2.5.0",
48
55
  "@scure/base": "2.0.0",
49
56
  "@trezor/connect-web": "9.6.4",
50
57
  "cosmjs-types": "0.10.1",
51
- "ethers": "6.15.0",
58
+ "ethers": "6.16.0",
52
59
  "ripple-binary-codec": "2.5.1",
53
- "ts-pattern": "5.9.0"
60
+ "ts-pattern": "^5.9.0",
61
+ "xrpl": "4.4.2"
54
62
  },
55
63
  "exports": {
56
64
  ".": {
@@ -78,24 +86,27 @@
78
86
  "types": "./dist/types/trezor/index.d.ts"
79
87
  }
80
88
  },
81
- "files": ["dist/", "src/"],
82
- "homepage": "https://github.com/swapkit/SwapKit",
83
- "license": "Apache-2.0",
89
+ "files": [
90
+ "dist/"
91
+ ],
92
+ "homepage": "https://github.com/swapkit/wallets",
93
+ "license": "SEE LICENSE IN LICENSE",
84
94
  "name": "@swapkit/wallet-hardware",
95
+ "publishConfig": {
96
+ "access": "public"
97
+ },
85
98
  "repository": {
86
- "directory": "packages/wallet-hardware",
87
99
  "type": "git",
88
- "url": "git+https://github.com/swapkit/SwapKit.git"
100
+ "url": "git+https://github.com/swapkit/wallets.git",
101
+ "directory": "packages/wallet-hardware"
89
102
  },
90
103
  "scripts": {
91
104
  "build": "bun run ./build.ts",
92
105
  "build:clean": "rm -rf dist && bun run ./build.ts",
93
106
  "clean": "rm -rf dist node_modules *.tsbuildinfo",
94
- "test": "echo 'bun test'",
95
- "test:ci": "echo 'bun test --coverage'",
96
107
  "type-check": "bun tsc --noEmit",
97
108
  "type-check:go": "tsgo"
98
109
  },
99
110
  "type": "module",
100
- "version": "4.2.11"
111
+ "version": "4.6.1"
101
112
  }
@@ -1,4 +0,0 @@
1
- var j=require("@swapkit/helpers");async function T({chain:A,derivationPath:O,provider:W}){let{AbstractSigner:k,Signature:N}=await import("ethers");class X extends k{address;chain;derivationPath;provider;constructor({chain:q,derivationPath:B,provider:D}){super(D);this.address="",this.chain=q,this.derivationPath=B,this.provider=D}getAddress=async()=>{if(!this.address){let B=await(await import("@trezor/connect-web")).default.ethereumGetAddress({path:j.derivationPathToString(this.derivationPath),showOnTrezor:!0});if(!B.success)throw new j.SwapKitError({errorKey:"wallet_trezor_failed_to_get_address",info:{...B,chain:this.chain,derivationPath:this.derivationPath}});this.address=B.payload.address}return this.address};signMessage=async(q)=>{let D=await(await import("@trezor/connect-web")).default.ethereumSignMessage({message:q,path:j.derivationPathToString(this.derivationPath)});if(!D.success)throw new j.SwapKitError({errorKey:"wallet_trezor_failed_to_sign_transaction",info:{...D,chain:this.chain,derivationPath:this.derivationPath,message:q}});return D.payload.signature};signTypedData(){throw new j.SwapKitError("wallet_trezor_method_not_supported",{method:"signTypedData"})}signTransaction=async({to:q,gasLimit:B,value:D,data:f,nonce:C,maxFeePerGas:R,maxPriorityFeePerGas:U,gasPrice:V})=>{if(!q)throw new j.SwapKitError({errorKey:"wallet_missing_params",info:{to:q}});if(!B)throw new j.SwapKitError({errorKey:"wallet_missing_params",info:{gasLimit:B}});let Q=R&&U;if(Q&&!R)throw new j.SwapKitError({errorKey:"wallet_missing_params",info:{maxFeePerGas:R}});if(Q&&!U)throw new j.SwapKitError({errorKey:"wallet_missing_params",info:{maxPriorityFeePerGas:U}});if(!(Q||V))throw new j.SwapKitError({errorKey:"wallet_missing_params",info:{gasPrice:V}});let _=(await import("@trezor/connect-web")).default,{toHexString:J}=await import("@swapkit/toolboxes/evm"),{Transaction:H}=await import("ethers"),I=Q?{maxFeePerGas:J(BigInt(R?.toString()||0)),maxPriorityFeePerGas:J(BigInt(U?.toString()||0))}:V&&{gasPrice:J(BigInt(V?.toString()||0))}||{gasPrice:"0x0"},L=J(BigInt(C||await this.provider.getTransactionCount(await this.getAddress(),"pending"))),Y={chainId:Number.parseInt(j.ChainToChainId[this.chain],10),data:f?.toString()||"0x",gasLimit:J(BigInt(B?.toString()||0)),nonce:L,to:q.toString(),value:J(BigInt(D?.toString()||0)),...I},{success:b,payload:Z}=await _.ethereumSignTransaction({path:j.derivationPathToString(this.derivationPath),transaction:Y});if(!b)throw new j.SwapKitError({errorKey:"wallet_trezor_failed_to_sign_transaction",info:{...Z,chain:this.chain,derivationPath:this.derivationPath}});let{r:z,s:u,v:K}=Z,y=N.from({r:z,s:u,v:new j.SwapKitNumber(BigInt(K)).getBaseValue("number")}),$=H.from({...Y,nonce:Number.parseInt(Y.nonce,16),signature:y,type:Q?2:0}).serialized;if(!$)throw new j.SwapKitError({errorKey:"wallet_trezor_failed_to_sign_transaction",info:{chain:this.chain,derivationPath:this.derivationPath}});return $};connect=(q)=>{if(!q)throw new j.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:this.chain,derivationPath:this.derivationPath,wallet:j.WalletOption.TREZOR}});return new X({chain:this.chain,derivationPath:this.derivationPath,provider:q})}}return new X({chain:A,derivationPath:O,provider:W})}
2
-
3
- //# debugId=C5A074C8508251DA64756E2164756E21
4
- //# sourceMappingURL=chunk-4k7gb7ss.js.map
@@ -1,10 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../src/trezor/evmSigner.ts"],
4
- "sourcesContent": [
5
- "import {\n type Chain,\n ChainToChainId,\n type DerivationPathArray,\n derivationPathToString,\n SwapKitError,\n SwapKitNumber,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport type { JsonRpcProvider, Provider, TransactionRequest } from \"ethers\";\n\ntype TrezorEVMSignerParams = {\n chain: Chain;\n derivationPath: DerivationPathArray;\n provider: Provider | JsonRpcProvider;\n};\n\nexport async function getEVMSigner({ chain, derivationPath, provider }: TrezorEVMSignerParams) {\n const { AbstractSigner, Signature } = await import(\"ethers\");\n\n class TrezorSigner extends AbstractSigner {\n address: string;\n chain: Chain;\n derivationPath: DerivationPathArray;\n readonly provider: Provider | JsonRpcProvider;\n\n constructor({ chain, derivationPath, provider }: TrezorEVMSignerParams) {\n super(provider);\n\n this.address = \"\";\n this.chain = chain;\n this.derivationPath = derivationPath;\n this.provider = provider;\n }\n\n getAddress = async () => {\n if (!this.address) {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n\n const result = await TrezorConnect.ethereumGetAddress({\n path: derivationPathToString(this.derivationPath),\n showOnTrezor: true,\n });\n\n if (!result.success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_get_address\",\n info: { ...result, chain: this.chain, derivationPath: this.derivationPath },\n });\n }\n\n this.address = result.payload.address;\n }\n\n return this.address;\n };\n\n signMessage = async (message: string) => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n\n const result = await TrezorConnect.ethereumSignMessage({\n message,\n path: derivationPathToString(this.derivationPath),\n });\n\n if (!result.success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { ...result, chain: this.chain, derivationPath: this.derivationPath, message },\n });\n }\n\n return result.payload.signature;\n };\n\n signTypedData(): Promise<string> {\n throw new SwapKitError(\"wallet_trezor_method_not_supported\", { method: \"signTypedData\" });\n }\n\n signTransaction = async ({\n to,\n gasLimit,\n value,\n data,\n nonce,\n maxFeePerGas,\n maxPriorityFeePerGas,\n gasPrice,\n // biome-ignore lint/complexity/noExcessiveCognitiveComplexity: any: refactor\n }: TransactionRequest) => {\n if (!to) throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { to } });\n if (!gasLimit) throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { gasLimit } });\n\n const isEIP1559 = maxFeePerGas && maxPriorityFeePerGas;\n\n if (isEIP1559 && !maxFeePerGas) {\n throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { maxFeePerGas } });\n }\n if (isEIP1559 && !maxPriorityFeePerGas) {\n throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { maxPriorityFeePerGas } });\n }\n if (!(isEIP1559 || gasPrice)) {\n throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { gasPrice } });\n }\n\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const { toHexString } = await import(\"@swapkit/toolboxes/evm\");\n const { Transaction } = await import(\"ethers\");\n\n const additionalFields = isEIP1559\n ? {\n maxFeePerGas: toHexString(BigInt(maxFeePerGas?.toString() || 0)),\n maxPriorityFeePerGas: toHexString(BigInt(maxPriorityFeePerGas?.toString() || 0)),\n }\n : (gasPrice && { gasPrice: toHexString(BigInt(gasPrice?.toString() || 0)) }) || { gasPrice: \"0x0\" };\n\n const hexifiedNonce = toHexString(\n BigInt(nonce || (await this.provider.getTransactionCount(await this.getAddress(), \"pending\"))),\n );\n\n const formattedTx = {\n chainId: Number.parseInt(ChainToChainId[this.chain], 10),\n data: data?.toString() || \"0x\",\n gasLimit: toHexString(BigInt(gasLimit?.toString() || 0)),\n nonce: hexifiedNonce,\n to: to.toString(),\n value: toHexString(BigInt(value?.toString() || 0)),\n ...additionalFields,\n };\n\n const { success, payload } = await TrezorConnect.ethereumSignTransaction({\n path: derivationPathToString(this.derivationPath),\n transaction: formattedTx,\n });\n\n if (!success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { ...payload, chain: this.chain, derivationPath: this.derivationPath },\n });\n }\n\n const { r, s, v } = payload;\n\n const signature = Signature.from({ r, s, v: new SwapKitNumber(BigInt(v)).getBaseValue(\"number\") });\n\n const serializedTx = Transaction.from({\n ...formattedTx,\n nonce: Number.parseInt(formattedTx.nonce, 16),\n signature,\n type: isEIP1559 ? 2 : 0,\n }).serialized;\n\n if (!serializedTx) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { chain: this.chain, derivationPath: this.derivationPath },\n });\n }\n\n return serializedTx;\n };\n\n connect = (provider: Provider | null) => {\n if (!provider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { chain: this.chain, derivationPath: this.derivationPath, wallet: WalletOption.TREZOR },\n });\n }\n\n return new TrezorSigner({ chain: this.chain, derivationPath: this.derivationPath, provider });\n };\n }\n\n return new TrezorSigner({ chain, derivationPath, provider });\n}\n"
6
- ],
7
- "mappings": "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",
8
- "debugId": "C5A074C8508251DA64756E2164756E21",
9
- "names": []
10
- }
@@ -1,4 +0,0 @@
1
- import{c as M,d as Q}from"./chunk-zzfbcc7e.js";import{ChainToChainId as h,derivationPathToString as $,SwapKitError as q,SwapKitNumber as w,WalletOption as E}from"@swapkit/helpers";async function l({chain:W,derivationPath:k,provider:N}){let{AbstractSigner:f,Signature:C}=await import("ethers");class Y extends f{address;chain;derivationPath;provider;constructor({chain:j,derivationPath:B,provider:D}){super(D);this.address="",this.chain=j,this.derivationPath=B,this.provider=D}getAddress=async()=>{if(!this.address){let B=await(await import("@trezor/connect-web")).default.ethereumGetAddress({path:$(this.derivationPath),showOnTrezor:!0});if(!B.success)throw new q({errorKey:"wallet_trezor_failed_to_get_address",info:{...B,chain:this.chain,derivationPath:this.derivationPath}});this.address=B.payload.address}return this.address};signMessage=async(j)=>{let D=await(await import("@trezor/connect-web")).default.ethereumSignMessage({message:j,path:$(this.derivationPath)});if(!D.success)throw new q({errorKey:"wallet_trezor_failed_to_sign_transaction",info:{...D,chain:this.chain,derivationPath:this.derivationPath,message:j}});return D.payload.signature};signTypedData(){throw new q("wallet_trezor_method_not_supported",{method:"signTypedData"})}signTransaction=async({to:j,gasLimit:B,value:D,data:_,nonce:H,maxFeePerGas:U,maxPriorityFeePerGas:V,gasPrice:X})=>{if(!j)throw new q({errorKey:"wallet_missing_params",info:{to:j}});if(!B)throw new q({errorKey:"wallet_missing_params",info:{gasLimit:B}});let R=U&&V;if(R&&!U)throw new q({errorKey:"wallet_missing_params",info:{maxFeePerGas:U}});if(R&&!V)throw new q({errorKey:"wallet_missing_params",info:{maxPriorityFeePerGas:V}});if(!(R||X))throw new q({errorKey:"wallet_missing_params",info:{gasPrice:X}});let I=(await import("@trezor/connect-web")).default,{toHexString:J}=await import("@swapkit/toolboxes/evm"),{Transaction:L}=await import("ethers"),b=R?{maxFeePerGas:J(BigInt(U?.toString()||0)),maxPriorityFeePerGas:J(BigInt(V?.toString()||0))}:X&&{gasPrice:J(BigInt(X?.toString()||0))}||{gasPrice:"0x0"},z=J(BigInt(H||await this.provider.getTransactionCount(await this.getAddress(),"pending"))),Z={chainId:Number.parseInt(h[this.chain],10),data:_?.toString()||"0x",gasLimit:J(BigInt(B?.toString()||0)),nonce:z,to:j.toString(),value:J(BigInt(D?.toString()||0)),...b},{success:u,payload:A}=await I.ethereumSignTransaction({path:$(this.derivationPath),transaction:Z});if(!u)throw new q({errorKey:"wallet_trezor_failed_to_sign_transaction",info:{...A,chain:this.chain,derivationPath:this.derivationPath}});let{r:K,s:y,v:T}=A,G=C.from({r:K,s:y,v:new w(BigInt(T)).getBaseValue("number")}),O=L.from({...Z,nonce:Number.parseInt(Z.nonce,16),signature:G,type:R?2:0}).serialized;if(!O)throw new q({errorKey:"wallet_trezor_failed_to_sign_transaction",info:{chain:this.chain,derivationPath:this.derivationPath}});return O};connect=(j)=>{if(!j)throw new q({errorKey:"wallet_provider_not_found",info:{chain:this.chain,derivationPath:this.derivationPath,wallet:E.TREZOR}});return new Y({chain:this.chain,derivationPath:this.derivationPath,provider:j})}}return new Y({chain:W,derivationPath:k,provider:N})}export{l as getEVMSigner};
2
-
3
- //# debugId=BAD457F1141C18E364756E2164756E21
4
- //# sourceMappingURL=chunk-93cj7bky.js.map
@@ -1,10 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../src/trezor/evmSigner.ts"],
4
- "sourcesContent": [
5
- "import {\n type Chain,\n ChainToChainId,\n type DerivationPathArray,\n derivationPathToString,\n SwapKitError,\n SwapKitNumber,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport type { JsonRpcProvider, Provider, TransactionRequest } from \"ethers\";\n\ntype TrezorEVMSignerParams = {\n chain: Chain;\n derivationPath: DerivationPathArray;\n provider: Provider | JsonRpcProvider;\n};\n\nexport async function getEVMSigner({ chain, derivationPath, provider }: TrezorEVMSignerParams) {\n const { AbstractSigner, Signature } = await import(\"ethers\");\n\n class TrezorSigner extends AbstractSigner {\n address: string;\n chain: Chain;\n derivationPath: DerivationPathArray;\n readonly provider: Provider | JsonRpcProvider;\n\n constructor({ chain, derivationPath, provider }: TrezorEVMSignerParams) {\n super(provider);\n\n this.address = \"\";\n this.chain = chain;\n this.derivationPath = derivationPath;\n this.provider = provider;\n }\n\n getAddress = async () => {\n if (!this.address) {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n\n const result = await TrezorConnect.ethereumGetAddress({\n path: derivationPathToString(this.derivationPath),\n showOnTrezor: true,\n });\n\n if (!result.success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_get_address\",\n info: { ...result, chain: this.chain, derivationPath: this.derivationPath },\n });\n }\n\n this.address = result.payload.address;\n }\n\n return this.address;\n };\n\n signMessage = async (message: string) => {\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n\n const result = await TrezorConnect.ethereumSignMessage({\n message,\n path: derivationPathToString(this.derivationPath),\n });\n\n if (!result.success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { ...result, chain: this.chain, derivationPath: this.derivationPath, message },\n });\n }\n\n return result.payload.signature;\n };\n\n signTypedData(): Promise<string> {\n throw new SwapKitError(\"wallet_trezor_method_not_supported\", { method: \"signTypedData\" });\n }\n\n signTransaction = async ({\n to,\n gasLimit,\n value,\n data,\n nonce,\n maxFeePerGas,\n maxPriorityFeePerGas,\n gasPrice,\n // biome-ignore lint/complexity/noExcessiveCognitiveComplexity: any: refactor\n }: TransactionRequest) => {\n if (!to) throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { to } });\n if (!gasLimit) throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { gasLimit } });\n\n const isEIP1559 = maxFeePerGas && maxPriorityFeePerGas;\n\n if (isEIP1559 && !maxFeePerGas) {\n throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { maxFeePerGas } });\n }\n if (isEIP1559 && !maxPriorityFeePerGas) {\n throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { maxPriorityFeePerGas } });\n }\n if (!(isEIP1559 || gasPrice)) {\n throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { gasPrice } });\n }\n\n const TrezorConnect = (await import(\"@trezor/connect-web\")).default;\n const { toHexString } = await import(\"@swapkit/toolboxes/evm\");\n const { Transaction } = await import(\"ethers\");\n\n const additionalFields = isEIP1559\n ? {\n maxFeePerGas: toHexString(BigInt(maxFeePerGas?.toString() || 0)),\n maxPriorityFeePerGas: toHexString(BigInt(maxPriorityFeePerGas?.toString() || 0)),\n }\n : (gasPrice && { gasPrice: toHexString(BigInt(gasPrice?.toString() || 0)) }) || { gasPrice: \"0x0\" };\n\n const hexifiedNonce = toHexString(\n BigInt(nonce || (await this.provider.getTransactionCount(await this.getAddress(), \"pending\"))),\n );\n\n const formattedTx = {\n chainId: Number.parseInt(ChainToChainId[this.chain], 10),\n data: data?.toString() || \"0x\",\n gasLimit: toHexString(BigInt(gasLimit?.toString() || 0)),\n nonce: hexifiedNonce,\n to: to.toString(),\n value: toHexString(BigInt(value?.toString() || 0)),\n ...additionalFields,\n };\n\n const { success, payload } = await TrezorConnect.ethereumSignTransaction({\n path: derivationPathToString(this.derivationPath),\n transaction: formattedTx,\n });\n\n if (!success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { ...payload, chain: this.chain, derivationPath: this.derivationPath },\n });\n }\n\n const { r, s, v } = payload;\n\n const signature = Signature.from({ r, s, v: new SwapKitNumber(BigInt(v)).getBaseValue(\"number\") });\n\n const serializedTx = Transaction.from({\n ...formattedTx,\n nonce: Number.parseInt(formattedTx.nonce, 16),\n signature,\n type: isEIP1559 ? 2 : 0,\n }).serialized;\n\n if (!serializedTx) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { chain: this.chain, derivationPath: this.derivationPath },\n });\n }\n\n return serializedTx;\n };\n\n connect = (provider: Provider | null) => {\n if (!provider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { chain: this.chain, derivationPath: this.derivationPath, wallet: WalletOption.TREZOR },\n });\n }\n\n return new TrezorSigner({ chain: this.chain, derivationPath: this.derivationPath, provider });\n };\n }\n\n return new TrezorSigner({ chain, derivationPath, provider });\n}\n"
6
- ],
7
- "mappings": "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",
8
- "debugId": "BAD457F1141C18E364756E2164756E21",
9
- "names": []
10
- }
@@ -1,4 +0,0 @@
1
- var j=Object.create;var{getPrototypeOf:k,defineProperty:e,getOwnPropertyNames:h,getOwnPropertyDescriptor:l}=Object,i=Object.prototype.hasOwnProperty;var m=(a,b,c)=>{c=a!=null?j(k(a)):{};let d=b||!a||!a.__esModule?e(c,"default",{value:a,enumerable:!0}):c;for(let f of h(a))if(!i.call(d,f))e(d,f,{get:()=>a[f],enumerable:!0});return d},g=new WeakMap,n=(a)=>{var b=g.get(a),c;if(b)return b;if(b=e({},"__esModule",{value:!0}),a&&typeof a==="object"||typeof a==="function")h(a).map((d)=>!i.call(b,d)&&e(b,d,{get:()=>a[d],enumerable:!(c=l(a,d))||c.enumerable}));return g.set(a,b),b};var o=(a,b)=>{for(var c in b)e(a,c,{get:b[c],enumerable:!0,configurable:!0,set:(d)=>b[c]=()=>d})};
2
-
3
- //# debugId=9E860276D712218864756E2164756E21
4
- //# sourceMappingURL=chunk-fazw0jvt.js.map
@@ -1,5 +0,0 @@
1
- var g=Object.create;var{getPrototypeOf:h,defineProperty:f,getOwnPropertyNames:i}=Object;var j=Object.prototype.hasOwnProperty;var k=(a,c,b)=>{b=a!=null?g(h(a)):{};let d=c||!a||!a.__esModule?f(b,"default",{value:a,enumerable:!0}):b;for(let e of i(a))if(!j.call(d,e))f(d,e,{get:()=>a[e],enumerable:!0});return d};var l=((a)=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(a,{get:(c,b)=>(typeof require<"u"?require:c)[b]}):a)(function(a){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+a+'" is not supported')});
2
- export{k as c,l as d};
3
-
4
- //# debugId=B199D22A6B72ED5764756E2164756E21
5
- //# sourceMappingURL=chunk-zzfbcc7e.js.map
package/src/index.ts DELETED
@@ -1 +0,0 @@
1
- export {};
@@ -1,69 +0,0 @@
1
- import type { KeepKeySdk } from "@keepkey/keepkey-sdk";
2
- import type { GenericTransferParams } from "@swapkit/helpers";
3
- import {
4
- Chain,
5
- DerivationPath,
6
- type DerivationPathArray,
7
- derivationPathToString,
8
- GAIAConfig,
9
- getRPCUrl,
10
- } from "@swapkit/helpers";
11
-
12
- import { bip32ToAddressNList } from "../coins";
13
-
14
- export async function cosmosWalletMethods({
15
- sdk,
16
- derivationPath,
17
- }: {
18
- sdk: KeepKeySdk;
19
- derivationPath?: DerivationPathArray;
20
- }): Promise<any> {
21
- const { DEFAULT_COSMOS_FEE_MAINNET, getCosmosToolbox, getFeeRateFromSwapKit, createStargateClient } = await import(
22
- "@swapkit/toolboxes/cosmos"
23
- );
24
- const derivationPathString = derivationPath ? derivationPathToString(derivationPath) : `${DerivationPath.GAIA}/0`;
25
-
26
- const { address: fromAddress } = (await sdk.address.cosmosGetAddress({
27
- address_n: bip32ToAddressNList(derivationPathString),
28
- })) as { address: string };
29
-
30
- const toolbox = await getCosmosToolbox(Chain.Cosmos);
31
-
32
- if (DEFAULT_COSMOS_FEE_MAINNET.amount[0]) {
33
- DEFAULT_COSMOS_FEE_MAINNET.amount[0].amount = String(await getFeeRateFromSwapKit(GAIAConfig.chainId, 500));
34
- }
35
-
36
- // TODO support other cosmos assets
37
- const transfer = async ({ assetValue, recipient, memo }: GenericTransferParams) => {
38
- const amount = assetValue.getBaseValue("string");
39
- const accountInfo = await toolbox.getAccount(fromAddress);
40
-
41
- const keepKeySignedTx = await sdk.cosmos.cosmosSignAmino({
42
- signDoc: {
43
- account_number: accountInfo?.accountNumber.toString() ?? "",
44
- chain_id: GAIAConfig.chainId,
45
- fee: DEFAULT_COSMOS_FEE_MAINNET,
46
- memo: memo || "",
47
- msgs: [
48
- {
49
- type: "cosmos-sdk/MsgSend",
50
- value: { amount: [{ amount, denom: "uatom" }], from_address: fromAddress, to_address: recipient },
51
- },
52
- ],
53
- sequence: accountInfo?.sequence.toString() ?? "",
54
- },
55
- signerAddress: fromAddress,
56
- });
57
-
58
- const decodedBytes = atob(keepKeySignedTx.serialized);
59
- const uint8Array = new Uint8Array(decodedBytes.length).map((_, i) => decodedBytes.charCodeAt(i));
60
-
61
- const rpcUrl = await getRPCUrl(Chain.Cosmos);
62
- const client = await createStargateClient(rpcUrl);
63
- const response = await client.broadcastTx(uint8Array);
64
-
65
- return response.transactionHash;
66
- };
67
-
68
- return { ...toolbox, address: fromAddress, transfer };
69
- }
@@ -1,114 +0,0 @@
1
- import type { KeepKeySdk } from "@keepkey/keepkey-sdk";
2
- import {
3
- type Chain,
4
- ChainToChainId,
5
- type DerivationPathArray,
6
- derivationPathToString,
7
- NetworkDerivationPath,
8
- SwapKitError,
9
- } from "@swapkit/helpers";
10
- import type { JsonRpcProvider, Provider, TransactionRequest } from "ethers";
11
- import { AbstractSigner } from "ethers";
12
-
13
- import { bip32ToAddressNList } from "../coins";
14
-
15
- interface KeepKeyEVMSignerParams {
16
- sdk: KeepKeySdk;
17
- chain: Chain;
18
- derivationPath?: DerivationPathArray;
19
- provider: Provider | JsonRpcProvider;
20
- }
21
-
22
- export class KeepKeySigner extends AbstractSigner {
23
- private sdk: KeepKeySdk;
24
- private chain: Chain;
25
- private derivationPath: DerivationPathArray;
26
- private address: string;
27
- readonly provider: Provider | JsonRpcProvider;
28
-
29
- constructor({ sdk, chain, derivationPath, provider }: KeepKeyEVMSignerParams) {
30
- super();
31
- this.sdk = sdk;
32
- this.chain = chain;
33
- this.derivationPath = derivationPath || NetworkDerivationPath.ETH;
34
- this.address = "";
35
- this.provider = provider;
36
- }
37
-
38
- signTypedData(): Promise<string> {
39
- throw new SwapKitError("wallet_keepkey_method_not_supported", { method: "signTypedData" });
40
- }
41
-
42
- getAddress = async () => {
43
- if (this.address) return this.address;
44
- const { address } = await this.sdk.address.ethereumGetAddress({
45
- address_n: bip32ToAddressNList(derivationPathToString(this.derivationPath)),
46
- });
47
-
48
- this.address = address;
49
- return address;
50
- };
51
-
52
- signMessage = (message: string) => this.sdk.eth.ethSign({ address: this.address, message }) as Promise<string>;
53
-
54
- signTransaction = async ({
55
- to,
56
- value,
57
- gasLimit,
58
- nonce,
59
- data,
60
- maxFeePerGas,
61
- maxPriorityFeePerGas,
62
- gasPrice,
63
- }: TransactionRequest) => {
64
- if (!to) throw new SwapKitError("wallet_keepkey_invalid_params", { reason: "Missing to address" });
65
- if (!gasLimit) throw new SwapKitError("wallet_keepkey_invalid_params", { reason: "Missing gasLimit" });
66
- if (!data) throw new SwapKitError("wallet_keepkey_invalid_params", { reason: "Missing data" });
67
-
68
- const isEIP1559 = !!((maxFeePerGas || maxPriorityFeePerGas) && !gasPrice);
69
- if (isEIP1559 && !maxFeePerGas)
70
- throw new SwapKitError("wallet_keepkey_invalid_params", { reason: "Missing maxFeePerGas" });
71
- if (isEIP1559 && !maxPriorityFeePerGas)
72
- throw new SwapKitError("wallet_keepkey_invalid_params", { reason: "Missing maxPriorityFeePerGas" });
73
- if (!(isEIP1559 || gasPrice))
74
- throw new SwapKitError("wallet_keepkey_invalid_params", { reason: "Missing gasPrice" });
75
-
76
- const { toHexString } = await import("@swapkit/toolboxes/evm");
77
-
78
- const nonceValue = nonce
79
- ? BigInt(nonce)
80
- : BigInt(await this.provider.getTransactionCount(await this.getAddress(), "pending"));
81
-
82
- const input = {
83
- addressNList: [2147483692, 2147483708, 2147483648, 0, 0],
84
- chainId: toHexString(BigInt(ChainToChainId[this.chain])),
85
- data,
86
- from: this.address,
87
- gas: toHexString(BigInt(gasLimit)),
88
- nonce: toHexString(nonceValue),
89
- to: to.toString(),
90
- value: toHexString(BigInt(value || 0)),
91
- ...(isEIP1559 && {
92
- maxFeePerGas: toHexString(BigInt(maxFeePerGas?.toString() || "0")),
93
- maxPriorityFeePerGas: toHexString(BigInt(maxPriorityFeePerGas?.toString() || "0")),
94
- }),
95
- ...(!isEIP1559 && {
96
- // Fixed syntax error and structure here
97
- gasPrice: toHexString(BigInt(gasPrice?.toString() || "0")),
98
- }),
99
- };
100
- const responseSign = await this.sdk.eth.ethSignTransaction(input);
101
- return responseSign.serialized;
102
- };
103
-
104
- sendTransaction = async (tx: TransactionRequest): Promise<any> => {
105
- if (!this.provider) throw new SwapKitError("wallet_keepkey_no_provider");
106
-
107
- const signedTxHex = await this.signTransaction(tx);
108
-
109
- return await this.provider.broadcastTransaction(signedTxHex);
110
- };
111
-
112
- connect = (provider: Provider) =>
113
- new KeepKeySigner({ chain: this.chain, derivationPath: this.derivationPath, provider, sdk: this.sdk });
114
- }
@@ -1,98 +0,0 @@
1
- import type { KeepKeySdk } from "@keepkey/keepkey-sdk";
2
- import {
3
- type AssetValue,
4
- Chain,
5
- DerivationPath,
6
- type DerivationPathArray,
7
- derivationPathToString,
8
- type GenericTransferParams,
9
- getRPCUrl,
10
- MAYAConfig,
11
- SwapKitError,
12
- } from "@swapkit/helpers";
13
- import type { ThorchainDepositParams } from "@swapkit/toolboxes/cosmos";
14
-
15
- import { bip32ToAddressNList } from "../coins";
16
-
17
- type SignTransactionParams = { assetValue: AssetValue; recipient?: string; sender: string; memo: string | undefined };
18
-
19
- export async function mayachainWalletMethods({
20
- sdk,
21
- derivationPath,
22
- }: {
23
- sdk: KeepKeySdk;
24
- derivationPath?: DerivationPathArray;
25
- }): Promise<any> {
26
- const { createStargateClient, getCosmosToolbox } = await import("@swapkit/toolboxes/cosmos");
27
-
28
- const toolbox = await getCosmosToolbox(Chain.Maya);
29
- const derivationPathString = derivationPath ? derivationPathToString(derivationPath) : `${DerivationPath.MAYA}/0`;
30
-
31
- const { address: fromAddress } = (await sdk.address.mayachainGetAddress({
32
- address_n: bip32ToAddressNList(derivationPathString),
33
- })) as { address: string };
34
-
35
- const signTransaction = async ({ assetValue, recipient, sender, memo }: SignTransactionParams) => {
36
- const importedAmino = await import("@cosmjs/amino");
37
- const makeSignDoc = importedAmino.makeSignDoc ?? importedAmino.default?.makeSignDoc;
38
- const { getDenomWithChain } = await import("@swapkit/toolboxes/cosmos");
39
-
40
- const account = await toolbox.getAccount(sender);
41
- if (!account) throw new SwapKitError("wallet_keepkey_account_not_found");
42
- const { accountNumber, sequence = 0 } = account;
43
- const amount = assetValue.getBaseValue("string");
44
-
45
- const isTransfer = recipient && recipient !== "";
46
-
47
- // TODO check if we can move to toolbox created msg
48
- const msg = isTransfer
49
- ? {
50
- type: "mayachain/MsgSend",
51
- value: {
52
- amount: [{ amount, denom: assetValue.symbol.toLowerCase() }],
53
- from_address: sender,
54
- to_address: recipient,
55
- },
56
- }
57
- : {
58
- type: "mayachain/MsgDeposit",
59
- value: { coins: [{ amount, asset: getDenomWithChain(assetValue) }], memo, signer: sender },
60
- };
61
-
62
- const signDoc = makeSignDoc(
63
- [msg],
64
- { amount: [], gas: "500000000" },
65
- MAYAConfig.chainId,
66
- memo,
67
- accountNumber?.toString(),
68
- sequence,
69
- );
70
-
71
- const sdkMethod = isTransfer ? sdk.mayachain.mayachainSignAminoTransfer : sdk.mayachain.mayachainSignAminoDeposit;
72
-
73
- // @ts-expect-error TC
74
- const signedTx = await sdkMethod({ signDoc, signerAddress: sender });
75
- const decodedBytes = atob(signedTx.serialized);
76
- return new Uint8Array(decodedBytes.length).map((_, i) => decodedBytes.charCodeAt(i));
77
- };
78
-
79
- const transfer = async ({ assetValue, recipient, memo }: GenericTransferParams) => {
80
- const rpcUrl = await getRPCUrl(Chain.Maya);
81
- const stargateClient = await createStargateClient(rpcUrl);
82
- const signedTransaction = await signTransaction({ assetValue, memo, recipient, sender: fromAddress });
83
- const { transactionHash } = await stargateClient.broadcastTx(signedTransaction);
84
-
85
- return transactionHash;
86
- };
87
-
88
- const deposit = async ({ assetValue, memo }: ThorchainDepositParams) => {
89
- const rpcUrl = await getRPCUrl(Chain.Maya);
90
- const stargateClient = await createStargateClient(rpcUrl);
91
- const signedTransaction = await signTransaction({ assetValue, memo, sender: fromAddress });
92
- const { transactionHash } = await stargateClient.broadcastTx(signedTransaction);
93
-
94
- return transactionHash;
95
- };
96
-
97
- return { ...toolbox, address: fromAddress, deposit, transfer };
98
- }