@swapkit/wallets 4.0.0-beta.53 → 4.0.0-beta.55
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/{chunk-e674mh4n.js → chunk-mcrgqfr9.js} +3 -3
- package/dist/{chunk-e674mh4n.js.map → chunk-mcrgqfr9.js.map} +1 -1
- package/dist/{chunk-mvbb9fwb.js → chunk-sbf0f2p4.js} +2 -2
- package/dist/{chunk-p2ca0j1v.js → chunk-yqaz2d25.js} +3 -3
- package/dist/{chunk-p2ca0j1v.js.map → chunk-yqaz2d25.js.map} +1 -1
- package/dist/src/bitget/index.cjs +2 -2
- package/dist/src/bitget/index.cjs.map +3 -3
- package/dist/src/bitget/index.js +2 -2
- package/dist/src/bitget/index.js.map +3 -3
- package/dist/src/coinbase/index.cjs +2 -2
- package/dist/src/coinbase/index.cjs.map +3 -3
- package/dist/src/coinbase/index.js +2 -2
- package/dist/src/coinbase/index.js.map +3 -3
- package/dist/src/cosmostation/index.cjs +2 -2
- package/dist/src/cosmostation/index.cjs.map +3 -3
- package/dist/src/cosmostation/index.js +2 -2
- package/dist/src/cosmostation/index.js.map +3 -3
- package/dist/src/ctrl/index.cjs +2 -2
- package/dist/src/ctrl/index.cjs.map +3 -3
- package/dist/src/ctrl/index.js +2 -2
- package/dist/src/ctrl/index.js.map +3 -3
- package/dist/src/evm-extensions/index.cjs +2 -2
- package/dist/src/evm-extensions/index.cjs.map +3 -3
- package/dist/src/evm-extensions/index.js +2 -2
- package/dist/src/evm-extensions/index.js.map +3 -3
- package/dist/src/exodus/index.cjs +2 -2
- package/dist/src/exodus/index.cjs.map +3 -3
- package/dist/src/exodus/index.js +2 -2
- package/dist/src/exodus/index.js.map +3 -3
- package/dist/src/index.cjs +2 -2
- package/dist/src/index.cjs.map +5 -3
- package/dist/src/index.js +2 -2
- package/dist/src/index.js.map +5 -3
- package/dist/src/keepkey-bex/index.cjs +2 -2
- package/dist/src/keepkey-bex/index.cjs.map +3 -3
- package/dist/src/keepkey-bex/index.js +2 -2
- package/dist/src/keepkey-bex/index.js.map +3 -3
- package/dist/src/keepkey.cjs +4 -0
- package/dist/src/keepkey.cjs.map +10 -0
- package/dist/src/keepkey.js +4 -0
- package/dist/src/keepkey.js.map +10 -0
- package/dist/src/keplr/index.cjs +2 -2
- package/dist/src/keplr/index.cjs.map +3 -3
- package/dist/src/keplr/index.js +2 -2
- package/dist/src/keplr/index.js.map +3 -3
- package/dist/src/keystore.cjs +4 -0
- package/dist/src/keystore.cjs.map +10 -0
- package/dist/src/keystore.js +4 -0
- package/dist/src/keystore.js.map +10 -0
- package/dist/src/ledger.cjs +4 -0
- package/dist/src/ledger.cjs.map +10 -0
- package/dist/src/ledger.js +4 -0
- package/dist/src/ledger.js.map +10 -0
- package/dist/src/okx/index.cjs +2 -2
- package/dist/src/okx/index.cjs.map +4 -4
- package/dist/src/okx/index.js +2 -2
- package/dist/src/okx/index.js.map +4 -4
- package/dist/src/onekey/index.cjs +2 -2
- package/dist/src/onekey/index.cjs.map +3 -3
- package/dist/src/onekey/index.js +2 -2
- package/dist/src/onekey/index.js.map +3 -3
- package/dist/src/phantom/index.cjs +2 -2
- package/dist/src/phantom/index.cjs.map +3 -3
- package/dist/src/phantom/index.js +2 -2
- package/dist/src/phantom/index.js.map +3 -3
- package/dist/src/polkadotjs/index.cjs +2 -2
- package/dist/src/polkadotjs/index.cjs.map +3 -3
- package/dist/src/polkadotjs/index.js +2 -2
- package/dist/src/polkadotjs/index.js.map +3 -3
- package/dist/src/radix/index.cjs +2 -2
- package/dist/src/radix/index.cjs.map +3 -3
- package/dist/src/radix/index.js +2 -2
- package/dist/src/radix/index.js.map +3 -3
- package/dist/src/talisman/index.cjs +2 -2
- package/dist/src/talisman/index.cjs.map +3 -3
- package/dist/src/talisman/index.js +2 -2
- package/dist/src/talisman/index.js.map +3 -3
- package/dist/src/trezor.cjs +4 -0
- package/dist/src/trezor.cjs.map +10 -0
- package/dist/src/trezor.js +4 -0
- package/dist/src/trezor.js.map +10 -0
- package/dist/src/vultisig/index.cjs +2 -2
- package/dist/src/vultisig/index.cjs.map +3 -3
- package/dist/src/vultisig/index.js +2 -2
- package/dist/src/vultisig/index.js.map +3 -3
- package/dist/src/walletconnect/index.cjs +2 -2
- package/dist/src/walletconnect/index.cjs.map +3 -3
- package/dist/src/walletconnect/index.js +2 -2
- package/dist/src/walletconnect/index.js.map +3 -3
- package/dist/src/xaman/index.cjs +2 -2
- package/dist/src/xaman/index.cjs.map +5 -5
- package/dist/src/xaman/index.js +2 -2
- package/dist/src/xaman/index.js.map +5 -5
- package/dist/types/bitget/helpers.d.ts +330 -0
- package/dist/types/bitget/helpers.d.ts.map +1 -0
- package/dist/types/bitget/index.d.ts +11 -0
- package/dist/types/bitget/index.d.ts.map +1 -0
- package/dist/types/coinbase/index.d.ts +11 -0
- package/dist/types/coinbase/index.d.ts.map +1 -0
- package/dist/types/coinbase/signer.d.ts +91 -0
- package/dist/types/coinbase/signer.d.ts.map +1 -0
- package/dist/types/cosmostation/index.d.ts +21 -0
- package/dist/types/cosmostation/index.d.ts.map +1 -0
- package/dist/types/ctrl/index.d.ts +11 -0
- package/dist/types/ctrl/index.d.ts.map +1 -0
- package/dist/types/ctrl/walletHelpers.d.ts +24 -0
- package/dist/types/ctrl/walletHelpers.d.ts.map +1 -0
- package/dist/types/evm-extensions/index.d.ts +101 -0
- package/dist/types/evm-extensions/index.d.ts.map +1 -0
- package/{src/evm-extensions/types.ts → dist/types/evm-extensions/types.d.ts} +11 -13
- package/dist/types/evm-extensions/types.d.ts.map +1 -0
- package/dist/types/exodus/index.d.ts +14 -0
- package/dist/types/exodus/index.d.ts.map +1 -0
- package/dist/types/helpers/near.d.ts +57 -0
- package/dist/types/helpers/near.d.ts.map +1 -0
- package/dist/types/index.d.ts +4 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/keepkey-bex/index.d.ts +11 -0
- package/dist/types/keepkey-bex/index.d.ts.map +1 -0
- package/dist/types/keepkey-bex/walletHelpers.d.ts +45 -0
- package/dist/types/keepkey-bex/walletHelpers.d.ts.map +1 -0
- package/dist/types/keepkey.d.ts +2 -0
- package/dist/types/keepkey.d.ts.map +1 -0
- package/dist/types/keplr/chainRegistry.d.ts +4 -0
- package/dist/types/keplr/chainRegistry.d.ts.map +1 -0
- package/dist/types/keplr/index.d.ts +11 -0
- package/dist/types/keplr/index.d.ts.map +1 -0
- package/dist/types/keystore.d.ts +2 -0
- package/dist/types/keystore.d.ts.map +1 -0
- package/dist/types/ledger.d.ts +2 -0
- package/dist/types/ledger.d.ts.map +1 -0
- package/dist/types/okx/helpers.d.ts +227 -0
- package/dist/types/okx/helpers.d.ts.map +1 -0
- package/dist/types/okx/index.d.ts +11 -0
- package/dist/types/okx/index.d.ts.map +1 -0
- package/dist/types/okx/types.d.ts +104 -0
- package/dist/types/okx/types.d.ts.map +1 -0
- package/dist/types/onekey/evmSigner.d.ts +29 -0
- package/dist/types/onekey/evmSigner.d.ts.map +1 -0
- package/dist/types/onekey/index.d.ts +11 -0
- package/dist/types/onekey/index.d.ts.map +1 -0
- package/dist/types/phantom/index.d.ts +12 -0
- package/dist/types/phantom/index.d.ts.map +1 -0
- package/dist/types/polkadotjs/index.d.ts +11 -0
- package/dist/types/polkadotjs/index.d.ts.map +1 -0
- package/dist/types/radix/index.d.ts +11 -0
- package/dist/types/radix/index.d.ts.map +1 -0
- package/dist/types/talisman/index.d.ts +11 -0
- package/dist/types/talisman/index.d.ts.map +1 -0
- package/dist/types/trezor.d.ts +2 -0
- package/dist/types/trezor.d.ts.map +1 -0
- package/dist/types/types.d.ts +246 -0
- package/dist/types/types.d.ts.map +1 -0
- package/dist/types/utils.d.ts +4 -0
- package/dist/types/utils.d.ts.map +1 -0
- package/dist/types/vultisig/index.d.ts +11 -0
- package/dist/types/vultisig/index.d.ts.map +1 -0
- package/dist/types/vultisig/walletHelpers.d.ts +34 -0
- package/dist/types/vultisig/walletHelpers.d.ts.map +1 -0
- package/dist/types/walletconnect/constants.d.ts +85 -0
- package/dist/types/walletconnect/constants.d.ts.map +1 -0
- package/dist/types/walletconnect/evmSigner.d.ts +25 -0
- package/dist/types/walletconnect/evmSigner.d.ts.map +1 -0
- package/dist/types/walletconnect/helpers.d.ts +4 -0
- package/dist/types/walletconnect/helpers.d.ts.map +1 -0
- package/dist/types/walletconnect/index.d.ts +22 -0
- package/dist/types/walletconnect/index.d.ts.map +1 -0
- package/dist/types/walletconnect/namespaces.d.ts +7 -0
- package/dist/types/walletconnect/namespaces.d.ts.map +1 -0
- package/dist/types/walletconnect/types.d.ts +7 -0
- package/dist/types/walletconnect/types.d.ts.map +1 -0
- package/dist/types/xaman/helpers.d.ts +54 -0
- package/dist/types/xaman/helpers.d.ts.map +1 -0
- package/dist/types/xaman/index.d.ts +14 -0
- package/dist/types/xaman/index.d.ts.map +1 -0
- package/dist/types/xaman/types.d.ts +24 -0
- package/dist/types/xaman/types.d.ts.map +1 -0
- package/dist/types/xaman/walletMethods.d.ts +16 -0
- package/dist/types/xaman/walletMethods.d.ts.map +1 -0
- package/package.json +44 -68
- package/dist/chunk-2aa1w78q.js +0 -4
- package/dist/chunk-2aa1w78q.js.map +0 -10
- package/dist/chunk-31bmhjxx.js +0 -4
- package/dist/chunk-31bmhjxx.js.map +0 -10
- package/dist/chunk-3etn0w20.js +0 -4
- package/dist/chunk-3etn0w20.js.map +0 -10
- package/dist/chunk-bk58smyr.js +0 -4
- package/dist/chunk-bk58smyr.js.map +0 -10
- package/dist/chunk-etm8zfkk.js +0 -4
- package/dist/chunk-etm8zfkk.js.map +0 -10
- package/dist/chunk-h7myvxxm.js +0 -5
- package/dist/chunk-h7myvxxm.js.map +0 -10
- package/dist/chunk-htvthkj1.js +0 -5
- package/dist/chunk-htvthkj1.js.map +0 -10
- package/dist/chunk-nfas79hz.js +0 -4
- package/dist/chunk-nfas79hz.js.map +0 -10
- package/dist/src/keepkey/index.cjs +0 -4
- package/dist/src/keepkey/index.cjs.map +0 -15
- package/dist/src/keepkey/index.js +0 -4
- package/dist/src/keepkey/index.js.map +0 -15
- package/dist/src/keystore/index.cjs +0 -4
- package/dist/src/keystore/index.cjs.map +0 -11
- package/dist/src/keystore/index.js +0 -4
- package/dist/src/keystore/index.js.map +0 -11
- package/dist/src/ledger/index.cjs +0 -5
- package/dist/src/ledger/index.cjs.map +0 -25
- package/dist/src/ledger/index.js +0 -5
- package/dist/src/ledger/index.js.map +0 -25
- package/dist/src/trezor/index.cjs +0 -4
- package/dist/src/trezor/index.cjs.map +0 -10
- package/dist/src/trezor/index.js +0 -4
- package/dist/src/trezor/index.js.map +0 -10
- package/src/bitget/helpers.ts +0 -167
- package/src/bitget/index.ts +0 -34
- package/src/coinbase/index.ts +0 -52
- package/src/coinbase/signer.ts +0 -83
- package/src/cosmostation/index.ts +0 -142
- package/src/ctrl/index.ts +0 -248
- package/src/ctrl/walletHelpers.ts +0 -297
- package/src/evm-extensions/index.ts +0 -134
- package/src/exodus/index.ts +0 -179
- package/src/helpers/near-browser-provider.d.ts +0 -286
- package/src/helpers/near.ts +0 -206
- package/src/index.ts +0 -2
- package/src/keepkey/chains/cosmos.ts +0 -78
- package/src/keepkey/chains/evm.ts +0 -125
- package/src/keepkey/chains/mayachain.ts +0 -123
- package/src/keepkey/chains/ripple.ts +0 -118
- package/src/keepkey/chains/thorchain.ts +0 -118
- package/src/keepkey/chains/utxo.ts +0 -147
- package/src/keepkey/coins.ts +0 -71
- package/src/keepkey/index.ts +0 -153
- package/src/keepkey-bex/index.ts +0 -162
- package/src/keepkey-bex/walletHelpers.ts +0 -255
- package/src/keplr/chainRegistry.ts +0 -211
- package/src/keplr/index.ts +0 -55
- package/src/keystore/helpers.ts +0 -102
- package/src/keystore/index.ts +0 -73
- package/src/ledger/clients/cosmos.ts +0 -102
- package/src/ledger/clients/evm.ts +0 -183
- package/src/ledger/clients/near.ts +0 -86
- package/src/ledger/clients/thorchain/common.ts +0 -117
- package/src/ledger/clients/thorchain/helpers.ts +0 -149
- package/src/ledger/clients/thorchain/index.ts +0 -94
- package/src/ledger/clients/thorchain/lib.ts +0 -300
- package/src/ledger/clients/thorchain/utils.ts +0 -76
- package/src/ledger/clients/tron.ts +0 -92
- package/src/ledger/clients/utxo.ts +0 -148
- package/src/ledger/clients/xrp.ts +0 -66
- package/src/ledger/cosmosTypes.ts +0 -101
- package/src/ledger/helpers/getLedgerAddress.ts +0 -67
- package/src/ledger/helpers/getLedgerClient.ts +0 -124
- package/src/ledger/helpers/getLedgerTransport.ts +0 -80
- package/src/ledger/helpers/index.ts +0 -3
- package/src/ledger/index.ts +0 -311
- package/src/ledger/interfaces/CosmosLedgerInterface.ts +0 -65
- package/src/ledger/types.ts +0 -45
- package/src/okx/helpers.ts +0 -181
- package/src/okx/index.ts +0 -43
- package/src/okx/types.ts +0 -117
- package/src/onekey/evmSigner.ts +0 -133
- package/src/onekey/index.ts +0 -213
- package/src/phantom/index.ts +0 -126
- package/src/polkadotjs/index.ts +0 -67
- package/src/radix/index.ts +0 -202
- package/src/talisman/index.ts +0 -130
- package/src/trezor/evmSigner.ts +0 -197
- package/src/trezor/index.ts +0 -260
- package/src/types.ts +0 -280
- package/src/utils.ts +0 -60
- package/src/vultisig/index.ts +0 -199
- package/src/vultisig/walletHelpers.ts +0 -359
- package/src/walletconnect/constants.ts +0 -104
- package/src/walletconnect/evmSigner.ts +0 -147
- package/src/walletconnect/helpers.ts +0 -77
- package/src/walletconnect/index.ts +0 -460
- package/src/walletconnect/namespaces.ts +0 -87
- package/src/walletconnect/types.ts +0 -6
- package/src/xaman/README.md +0 -66
- package/src/xaman/helpers.ts +0 -59
- package/src/xaman/index.ts +0 -79
- package/src/xaman/types.ts +0 -26
- package/src/xaman/walletMethods.ts +0 -126
- /package/dist/{chunk-mvbb9fwb.js.map → chunk-sbf0f2p4.js.map} +0 -0
package/src/keepkey/coins.ts
DELETED
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
KeepKey Specific bip32 path conventions
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import { SwapKitError } from "@swapkit/helpers";
|
|
6
|
-
|
|
7
|
-
const HARDENED = 0x80000000;
|
|
8
|
-
|
|
9
|
-
export enum ChainToKeepKeyName {
|
|
10
|
-
BTC = "Bitcoin",
|
|
11
|
-
BCH = "BitcoinCash",
|
|
12
|
-
DOGE = "Dogecoin",
|
|
13
|
-
LTC = "Litecoin",
|
|
14
|
-
DASH = "Dash",
|
|
15
|
-
XRP = "Ripple",
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
export function addressNListToBIP32(address: number[]) {
|
|
19
|
-
return `m/${address.map((num) => (num >= HARDENED ? `${num - HARDENED}'` : num)).join("/")}`;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export function bip32Like(path: string) {
|
|
23
|
-
if (path === "m/") return true;
|
|
24
|
-
|
|
25
|
-
return /^m(((\/[0-9]+h)+|(\/[0-9]+H)+|(\/[0-9]+')*)((\/[0-9]+)*))$/.test(path);
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
// biome-ignore lint/complexity/noExcessiveCognitiveComplexity: TODO: Refactor
|
|
29
|
-
export function bip32ToAddressNList(initPath: string): number[] {
|
|
30
|
-
let path = initPath;
|
|
31
|
-
|
|
32
|
-
if (!bip32Like(path)) {
|
|
33
|
-
throw new SwapKitError("wallet_keepkey_invalid_params", {
|
|
34
|
-
reason: `Not a bip32 path: '${path}'`,
|
|
35
|
-
});
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
if (/^m\//i.test(path)) {
|
|
39
|
-
path = path.slice(2);
|
|
40
|
-
}
|
|
41
|
-
const segments = path.split("/");
|
|
42
|
-
|
|
43
|
-
if (segments.length === 1 && segments[0] === "") return [];
|
|
44
|
-
|
|
45
|
-
const ret = new Array(segments.length);
|
|
46
|
-
|
|
47
|
-
for (let i = 0; i < segments.length; i++) {
|
|
48
|
-
// TODO: Check for better way instead of exec
|
|
49
|
-
const segment = segments[i];
|
|
50
|
-
if (segment) {
|
|
51
|
-
const tmp = /(\d+)([hH']?)/.exec(segment);
|
|
52
|
-
if (tmp === null)
|
|
53
|
-
throw new SwapKitError("wallet_keepkey_invalid_params", { reason: "Invalid input" });
|
|
54
|
-
|
|
55
|
-
const [, num = "", modifier = ""] = tmp;
|
|
56
|
-
|
|
57
|
-
ret[i] = Number.parseInt(num, 10);
|
|
58
|
-
|
|
59
|
-
if (ret[i] >= HARDENED)
|
|
60
|
-
throw new SwapKitError("wallet_keepkey_invalid_params", { reason: "Invalid child index" });
|
|
61
|
-
|
|
62
|
-
if (modifier === "h" || modifier === "H" || modifier === "'") {
|
|
63
|
-
ret[i] += HARDENED;
|
|
64
|
-
} else if (modifier.length > 0) {
|
|
65
|
-
throw new SwapKitError("wallet_keepkey_invalid_params", { reason: "Invalid modifier" });
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
return ret;
|
|
71
|
-
}
|
package/src/keepkey/index.ts
DELETED
|
@@ -1,153 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
Chain,
|
|
3
|
-
type DerivationPathArray,
|
|
4
|
-
NetworkDerivationPath,
|
|
5
|
-
SKConfig,
|
|
6
|
-
SwapKitError,
|
|
7
|
-
WalletOption,
|
|
8
|
-
createWallet,
|
|
9
|
-
filterSupportedChains,
|
|
10
|
-
} from "@swapkit/helpers";
|
|
11
|
-
|
|
12
|
-
import { KeepKeySdk } from "@keepkey/keepkey-sdk";
|
|
13
|
-
export type { PairingInfo } from "@keepkey/keepkey-sdk";
|
|
14
|
-
|
|
15
|
-
import { getWalletSupportedChains } from "../utils";
|
|
16
|
-
import { cosmosWalletMethods } from "./chains/cosmos";
|
|
17
|
-
import { KeepKeySigner } from "./chains/evm";
|
|
18
|
-
import { mayachainWalletMethods } from "./chains/mayachain";
|
|
19
|
-
import { thorchainWalletMethods } from "./chains/thorchain";
|
|
20
|
-
import { utxoWalletMethods } from "./chains/utxo";
|
|
21
|
-
|
|
22
|
-
export const keepkeyWallet = createWallet({
|
|
23
|
-
name: "connectKeepkey",
|
|
24
|
-
supportedChains: [
|
|
25
|
-
Chain.Arbitrum,
|
|
26
|
-
Chain.Avalanche,
|
|
27
|
-
Chain.Base,
|
|
28
|
-
Chain.BinanceSmartChain,
|
|
29
|
-
Chain.Bitcoin,
|
|
30
|
-
Chain.BitcoinCash,
|
|
31
|
-
Chain.Cosmos,
|
|
32
|
-
Chain.Dogecoin,
|
|
33
|
-
Chain.Dash,
|
|
34
|
-
Chain.Ethereum,
|
|
35
|
-
Chain.Litecoin,
|
|
36
|
-
Chain.Ripple,
|
|
37
|
-
Chain.Optimism,
|
|
38
|
-
Chain.Polygon,
|
|
39
|
-
Chain.THORChain,
|
|
40
|
-
Chain.Maya,
|
|
41
|
-
],
|
|
42
|
-
walletType: WalletOption.KEEPKEY,
|
|
43
|
-
connect: ({ addChain, supportedChains, walletType }) =>
|
|
44
|
-
async function connectKeepkey(
|
|
45
|
-
chains: Chain[],
|
|
46
|
-
derivationPathMap?: Record<Chain, DerivationPathArray>,
|
|
47
|
-
) {
|
|
48
|
-
const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });
|
|
49
|
-
const pairingInfo = SKConfig.get("integrations").keepKey;
|
|
50
|
-
if (!pairingInfo) throw new Error("KeepKey config not found");
|
|
51
|
-
|
|
52
|
-
const initialApiKey = SKConfig.get("apiKeys").keepKey || "1234";
|
|
53
|
-
|
|
54
|
-
await checkAndLaunch();
|
|
55
|
-
|
|
56
|
-
// Conform to the expected { apiKey, pairingInfo } structure
|
|
57
|
-
const keepkeyConfig = { apiKey: initialApiKey, pairingInfo };
|
|
58
|
-
const keepKeySdk = await KeepKeySdk.create(keepkeyConfig);
|
|
59
|
-
|
|
60
|
-
// Persist the new API key via SKConfig after pairing
|
|
61
|
-
if (keepkeyConfig.apiKey && keepkeyConfig.apiKey !== initialApiKey) {
|
|
62
|
-
SKConfig.setApiKey("keepKey", keepkeyConfig.apiKey);
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
await Promise.all(
|
|
66
|
-
filteredChains.map(async (chain) => {
|
|
67
|
-
const walletMethods = await getWalletMethods({
|
|
68
|
-
chain,
|
|
69
|
-
derivationPath: derivationPathMap?.[chain] || NetworkDerivationPath[chain],
|
|
70
|
-
sdk: keepKeySdk,
|
|
71
|
-
});
|
|
72
|
-
const address = (await walletMethods.getAddress()) || "";
|
|
73
|
-
|
|
74
|
-
addChain({ ...walletMethods, address, chain, walletType: WalletOption.KEEPKEY });
|
|
75
|
-
}),
|
|
76
|
-
);
|
|
77
|
-
return true;
|
|
78
|
-
},
|
|
79
|
-
});
|
|
80
|
-
|
|
81
|
-
export const KEEPKEY_SUPPORTED_CHAINS = getWalletSupportedChains(keepkeyWallet);
|
|
82
|
-
|
|
83
|
-
async function getWalletMethods({
|
|
84
|
-
sdk,
|
|
85
|
-
chain,
|
|
86
|
-
derivationPath,
|
|
87
|
-
}: { sdk: KeepKeySdk; chain: Chain; derivationPath?: DerivationPathArray }) {
|
|
88
|
-
const { getProvider, getEvmToolbox } = await import("@swapkit/toolboxes/evm");
|
|
89
|
-
|
|
90
|
-
switch (chain) {
|
|
91
|
-
case Chain.BinanceSmartChain:
|
|
92
|
-
case Chain.Arbitrum:
|
|
93
|
-
case Chain.Optimism:
|
|
94
|
-
case Chain.Polygon:
|
|
95
|
-
case Chain.Avalanche:
|
|
96
|
-
case Chain.Base:
|
|
97
|
-
case Chain.Ethereum: {
|
|
98
|
-
const provider = await getProvider(chain);
|
|
99
|
-
const signer = new KeepKeySigner({ sdk, chain, derivationPath, provider });
|
|
100
|
-
const toolbox = await getEvmToolbox(chain, { provider, signer });
|
|
101
|
-
|
|
102
|
-
return toolbox;
|
|
103
|
-
}
|
|
104
|
-
case Chain.Cosmos: {
|
|
105
|
-
return cosmosWalletMethods({ sdk, derivationPath });
|
|
106
|
-
}
|
|
107
|
-
case Chain.THORChain: {
|
|
108
|
-
return thorchainWalletMethods({ sdk, derivationPath });
|
|
109
|
-
}
|
|
110
|
-
case Chain.Maya: {
|
|
111
|
-
return mayachainWalletMethods({ sdk, derivationPath });
|
|
112
|
-
}
|
|
113
|
-
case Chain.Bitcoin:
|
|
114
|
-
case Chain.BitcoinCash:
|
|
115
|
-
case Chain.Dash:
|
|
116
|
-
case Chain.Dogecoin:
|
|
117
|
-
case Chain.Litecoin: {
|
|
118
|
-
return utxoWalletMethods({ sdk, chain, derivationPath });
|
|
119
|
-
}
|
|
120
|
-
case Chain.Ripple: {
|
|
121
|
-
const { rippleWalletMethods } = await import("./chains/ripple");
|
|
122
|
-
return rippleWalletMethods({ sdk, derivationPath });
|
|
123
|
-
}
|
|
124
|
-
default:
|
|
125
|
-
throw new SwapKitError("wallet_keepkey_chain_not_supported", { chain });
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
// kk-sdk docs: https://keepkey.com/blog/building_on_the_keepkey_sdk
|
|
130
|
-
// test spec: if offline, launch keepkey-bridge
|
|
131
|
-
async function checkAndLaunch(attempts = 0) {
|
|
132
|
-
if (attempts >= 3) {
|
|
133
|
-
alert(
|
|
134
|
-
"KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started",
|
|
135
|
-
);
|
|
136
|
-
}
|
|
137
|
-
const isAvailable = await checkKeepkeyAvailability();
|
|
138
|
-
|
|
139
|
-
if (!isAvailable) {
|
|
140
|
-
window.location.assign("keepkey://launch");
|
|
141
|
-
await new Promise((resolve) => setTimeout(resolve, 30000));
|
|
142
|
-
checkAndLaunch(attempts + 1);
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
async function checkKeepkeyAvailability(spec = "http://localhost:1646/spec/swagger.json") {
|
|
147
|
-
try {
|
|
148
|
-
const response = await fetch(spec);
|
|
149
|
-
return response.status === 200;
|
|
150
|
-
} catch (_error) {
|
|
151
|
-
return false;
|
|
152
|
-
}
|
|
153
|
-
}
|
package/src/keepkey-bex/index.ts
DELETED
|
@@ -1,162 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
AssetValue,
|
|
3
|
-
Chain,
|
|
4
|
-
ChainIdToChain,
|
|
5
|
-
SwapKitError,
|
|
6
|
-
WalletOption,
|
|
7
|
-
createWallet,
|
|
8
|
-
filterSupportedChains,
|
|
9
|
-
} from "@swapkit/helpers";
|
|
10
|
-
import type { Eip1193Provider } from "ethers";
|
|
11
|
-
import { getWalletSupportedChains } from "../utils";
|
|
12
|
-
import {
|
|
13
|
-
type WalletTxParams,
|
|
14
|
-
getKEEPKEYAddress,
|
|
15
|
-
getKEEPKEYMethods,
|
|
16
|
-
getKEEPKEYProvider,
|
|
17
|
-
getProviderNameFromChain,
|
|
18
|
-
walletTransfer,
|
|
19
|
-
} from "./walletHelpers";
|
|
20
|
-
|
|
21
|
-
export const keepkeyBexWallet = createWallet({
|
|
22
|
-
name: "connectKeepkeyBex",
|
|
23
|
-
supportedChains: [
|
|
24
|
-
Chain.Arbitrum,
|
|
25
|
-
Chain.Avalanche,
|
|
26
|
-
Chain.BinanceSmartChain,
|
|
27
|
-
Chain.Bitcoin,
|
|
28
|
-
Chain.BitcoinCash,
|
|
29
|
-
Chain.Base,
|
|
30
|
-
Chain.Cosmos,
|
|
31
|
-
Chain.Dash,
|
|
32
|
-
Chain.Dogecoin,
|
|
33
|
-
Chain.Ethereum,
|
|
34
|
-
Chain.Kujira,
|
|
35
|
-
Chain.Litecoin,
|
|
36
|
-
Chain.Maya,
|
|
37
|
-
Chain.Optimism,
|
|
38
|
-
Chain.Polygon,
|
|
39
|
-
Chain.Ripple,
|
|
40
|
-
Chain.Solana,
|
|
41
|
-
Chain.THORChain,
|
|
42
|
-
],
|
|
43
|
-
walletType: WalletOption.KEEPKEY_BEX,
|
|
44
|
-
connect: ({ addChain, supportedChains, walletType }) =>
|
|
45
|
-
async function connectKeepkeyBex(chains: Chain[]) {
|
|
46
|
-
const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });
|
|
47
|
-
|
|
48
|
-
await Promise.all(
|
|
49
|
-
filteredChains.map(async (chain) => {
|
|
50
|
-
const address = await getKEEPKEYAddress(chain);
|
|
51
|
-
const walletMethods = await getWalletMethods(chain);
|
|
52
|
-
|
|
53
|
-
addChain({ ...walletMethods, address, chain, walletType });
|
|
54
|
-
}),
|
|
55
|
-
);
|
|
56
|
-
|
|
57
|
-
return true;
|
|
58
|
-
},
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
export const KEEPKEY_BEX_SUPPORTED_CHAINS = getWalletSupportedChains(keepkeyBexWallet);
|
|
62
|
-
|
|
63
|
-
async function getWalletMethods(chain: (typeof KEEPKEY_BEX_SUPPORTED_CHAINS)[number]) {
|
|
64
|
-
switch (chain) {
|
|
65
|
-
case Chain.Maya:
|
|
66
|
-
case Chain.THORChain: {
|
|
67
|
-
const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(
|
|
68
|
-
"@swapkit/toolboxes/cosmos"
|
|
69
|
-
);
|
|
70
|
-
|
|
71
|
-
const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;
|
|
72
|
-
const toolbox = getCosmosToolbox(chain);
|
|
73
|
-
|
|
74
|
-
return {
|
|
75
|
-
...toolbox,
|
|
76
|
-
deposit: (tx: WalletTxParams) => walletTransfer({ ...tx, recipient: "" }, "deposit"),
|
|
77
|
-
transfer: (tx: WalletTxParams) => walletTransfer({ ...tx, gasLimit }, "transfer"),
|
|
78
|
-
};
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
case Chain.Cosmos:
|
|
82
|
-
case Chain.Kujira: {
|
|
83
|
-
const { getCosmosToolbox } = await import("@swapkit/toolboxes/cosmos");
|
|
84
|
-
|
|
85
|
-
// @ts-expect-error assumed available connection
|
|
86
|
-
const signer = window.keepkey?.cosmos?.getOfflineSignerOnlyAmino(ChainIdToChain[chain]);
|
|
87
|
-
if (!signer) throw new SwapKitError("wallet_keepkey_signer_not_found");
|
|
88
|
-
const toolbox = getCosmosToolbox(chain, { signer });
|
|
89
|
-
|
|
90
|
-
const accounts = await signer.getAccounts();
|
|
91
|
-
if (!accounts?.[0]?.address) throw new SwapKitError("wallet_keepkey_no_accounts");
|
|
92
|
-
|
|
93
|
-
const [{ address }] = accounts;
|
|
94
|
-
|
|
95
|
-
return { ...toolbox, address };
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
case Chain.Dash:
|
|
99
|
-
case Chain.Bitcoin:
|
|
100
|
-
case Chain.BitcoinCash:
|
|
101
|
-
case Chain.Dogecoin:
|
|
102
|
-
case Chain.Litecoin: {
|
|
103
|
-
const { getUtxoToolbox } = await import("@swapkit/toolboxes/utxo");
|
|
104
|
-
const toolbox = await getUtxoToolbox(chain);
|
|
105
|
-
|
|
106
|
-
const getBalance = async () => {
|
|
107
|
-
const providerChain = getProviderNameFromChain(chain);
|
|
108
|
-
// @ts-expect-error We assuming there chains via switch
|
|
109
|
-
const balance = await window?.keepkey?.[providerChain]?.request({
|
|
110
|
-
method: "request_balance",
|
|
111
|
-
});
|
|
112
|
-
const assetValue = AssetValue.from({ chain, value: balance[0].balance });
|
|
113
|
-
return [assetValue];
|
|
114
|
-
};
|
|
115
|
-
|
|
116
|
-
return { ...toolbox, getBalance, transfer: walletTransfer };
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
case Chain.Ethereum:
|
|
120
|
-
case Chain.BinanceSmartChain:
|
|
121
|
-
case Chain.Base:
|
|
122
|
-
case Chain.Arbitrum:
|
|
123
|
-
case Chain.Optimism:
|
|
124
|
-
case Chain.Polygon:
|
|
125
|
-
case Chain.Avalanche: {
|
|
126
|
-
const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import("@swapkit/helpers");
|
|
127
|
-
const { getEvmToolbox } = await import("@swapkit/toolboxes/evm");
|
|
128
|
-
const { BrowserProvider } = await import("ethers");
|
|
129
|
-
const ethereumWindowProvider = getKEEPKEYProvider(chain) as Eip1193Provider;
|
|
130
|
-
|
|
131
|
-
if (!ethereumWindowProvider) {
|
|
132
|
-
throw new SwapKitError("wallet_keepkey_not_found");
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
const provider = new BrowserProvider(ethereumWindowProvider, "any");
|
|
136
|
-
const signer = await provider.getSigner();
|
|
137
|
-
const toolbox = await getEvmToolbox(chain, { provider, signer });
|
|
138
|
-
const keepkeyMethods = getKEEPKEYMethods(provider, chain);
|
|
139
|
-
|
|
140
|
-
try {
|
|
141
|
-
if (chain !== Chain.Ethereum) {
|
|
142
|
-
const networkParams = toolbox.getNetworkParams();
|
|
143
|
-
await switchEVMWalletNetwork(provider, chain, networkParams);
|
|
144
|
-
}
|
|
145
|
-
} catch (_error) {
|
|
146
|
-
throw new SwapKitError({
|
|
147
|
-
errorKey: "wallet_failed_to_add_or_switch_network",
|
|
148
|
-
info: { wallet: WalletOption.KEEPKEY, chain },
|
|
149
|
-
});
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
return prepareNetworkSwitch({
|
|
153
|
-
provider,
|
|
154
|
-
chain,
|
|
155
|
-
toolbox: { ...toolbox, ...keepkeyMethods },
|
|
156
|
-
});
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
default:
|
|
160
|
-
return null;
|
|
161
|
-
}
|
|
162
|
-
}
|
|
@@ -1,255 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
type AssetValue,
|
|
3
|
-
Chain,
|
|
4
|
-
type EVMChain,
|
|
5
|
-
EVMChains,
|
|
6
|
-
type FeeOption,
|
|
7
|
-
SwapKitError,
|
|
8
|
-
WalletOption,
|
|
9
|
-
} from "@swapkit/helpers";
|
|
10
|
-
import { erc20ABI } from "@swapkit/helpers/contracts";
|
|
11
|
-
import type { ApproveParams, CallParams, EVMTxParams } from "@swapkit/toolboxes/evm";
|
|
12
|
-
import type { BrowserProvider, Eip1193Provider } from "ethers";
|
|
13
|
-
|
|
14
|
-
interface UTXOProvider {
|
|
15
|
-
request: (
|
|
16
|
-
args: {
|
|
17
|
-
method: string;
|
|
18
|
-
params?: {
|
|
19
|
-
amount: { amount: string; decimals?: number };
|
|
20
|
-
asset: { chain: Chain; symbol: string; ticker: string };
|
|
21
|
-
memo: string | undefined;
|
|
22
|
-
from?: string;
|
|
23
|
-
recipient: string;
|
|
24
|
-
gasLimit?: string | bigint;
|
|
25
|
-
}[];
|
|
26
|
-
},
|
|
27
|
-
callback: (err: string, tx: string) => void,
|
|
28
|
-
) => void;
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
type TransactionMethod = "transfer" | "deposit";
|
|
32
|
-
|
|
33
|
-
type TransactionParams = {
|
|
34
|
-
asset: string | { chain: string; symbol: string; ticker: string };
|
|
35
|
-
amount: number | string | { amount: string | number; decimals?: number };
|
|
36
|
-
decimal?: number;
|
|
37
|
-
recipient: string;
|
|
38
|
-
memo?: string;
|
|
39
|
-
};
|
|
40
|
-
|
|
41
|
-
export type WalletTxParams = {
|
|
42
|
-
feeOptionKey?: FeeOption;
|
|
43
|
-
from?: string;
|
|
44
|
-
memo?: string;
|
|
45
|
-
recipient: string;
|
|
46
|
-
assetValue: AssetValue;
|
|
47
|
-
gasLimit?: string | bigint | undefined;
|
|
48
|
-
};
|
|
49
|
-
|
|
50
|
-
export const getProviderNameFromChain = (chain: Chain): string => {
|
|
51
|
-
switch (chain) {
|
|
52
|
-
case Chain.Bitcoin:
|
|
53
|
-
return "bitcoin";
|
|
54
|
-
case Chain.BitcoinCash:
|
|
55
|
-
return "bitcoincash";
|
|
56
|
-
case Chain.Dash:
|
|
57
|
-
return "dash";
|
|
58
|
-
case Chain.Dogecoin:
|
|
59
|
-
return "dogecoin";
|
|
60
|
-
case Chain.Litecoin:
|
|
61
|
-
return "litecoin";
|
|
62
|
-
default:
|
|
63
|
-
throw new SwapKitError("wallet_keepkey_chain_not_supported", { chain });
|
|
64
|
-
}
|
|
65
|
-
};
|
|
66
|
-
|
|
67
|
-
declare const window: {
|
|
68
|
-
keepkey?: {
|
|
69
|
-
binance: Eip1193Provider;
|
|
70
|
-
bitcoin: Eip1193Provider;
|
|
71
|
-
bitcoincash: Eip1193Provider;
|
|
72
|
-
dogecoin: Eip1193Provider;
|
|
73
|
-
ethereum: Eip1193Provider;
|
|
74
|
-
cosmos: Eip1193Provider;
|
|
75
|
-
dash: Eip1193Provider;
|
|
76
|
-
litecoin: Eip1193Provider;
|
|
77
|
-
thorchain: Eip1193Provider;
|
|
78
|
-
mayachain: Eip1193Provider;
|
|
79
|
-
};
|
|
80
|
-
} & Window;
|
|
81
|
-
|
|
82
|
-
export function getKEEPKEYProvider<T extends Chain>(chain: T) {
|
|
83
|
-
if (!window.keepkey) throw new SwapKitError("wallet_keepkey_not_found");
|
|
84
|
-
|
|
85
|
-
switch (chain) {
|
|
86
|
-
case Chain.Ethereum:
|
|
87
|
-
case Chain.Base:
|
|
88
|
-
case Chain.Avalanche:
|
|
89
|
-
case Chain.BinanceSmartChain:
|
|
90
|
-
case Chain.Arbitrum:
|
|
91
|
-
case Chain.Optimism:
|
|
92
|
-
case Chain.Polygon:
|
|
93
|
-
return window.keepkey.ethereum as Eip1193Provider;
|
|
94
|
-
case Chain.Cosmos:
|
|
95
|
-
return window.keepkey.cosmos as Eip1193Provider;
|
|
96
|
-
case Chain.Bitcoin:
|
|
97
|
-
return window.keepkey.bitcoin as UTXOProvider;
|
|
98
|
-
case Chain.BitcoinCash:
|
|
99
|
-
return window.keepkey.bitcoincash as UTXOProvider;
|
|
100
|
-
case Chain.Dogecoin:
|
|
101
|
-
return window.keepkey.dogecoin as UTXOProvider;
|
|
102
|
-
case Chain.Litecoin:
|
|
103
|
-
return window.keepkey.litecoin as UTXOProvider;
|
|
104
|
-
case Chain.Dash:
|
|
105
|
-
return window.keepkey.dash as UTXOProvider;
|
|
106
|
-
case Chain.THORChain:
|
|
107
|
-
return window.keepkey.thorchain as UTXOProvider;
|
|
108
|
-
case Chain.Maya:
|
|
109
|
-
return window.keepkey.mayachain as UTXOProvider;
|
|
110
|
-
|
|
111
|
-
default:
|
|
112
|
-
return undefined;
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
async function transaction({
|
|
117
|
-
method,
|
|
118
|
-
params,
|
|
119
|
-
chain,
|
|
120
|
-
}: {
|
|
121
|
-
method: TransactionMethod;
|
|
122
|
-
params: TransactionParams[];
|
|
123
|
-
chain: Chain;
|
|
124
|
-
}): Promise<string> {
|
|
125
|
-
const client = getKEEPKEYProvider(chain);
|
|
126
|
-
|
|
127
|
-
return new Promise<string>((resolve, reject) => {
|
|
128
|
-
if (client && "request" in client) {
|
|
129
|
-
// @ts-ignore
|
|
130
|
-
client.request({ method, params }, (err: string, tx: string) => {
|
|
131
|
-
err ? reject(err) : resolve(tx);
|
|
132
|
-
});
|
|
133
|
-
} else {
|
|
134
|
-
reject(new SwapKitError("wallet_provider_not_found"));
|
|
135
|
-
}
|
|
136
|
-
});
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
export async function getKEEPKEYAddress(chain: Chain) {
|
|
140
|
-
const eipProvider = getKEEPKEYProvider(chain) as Eip1193Provider;
|
|
141
|
-
if (!eipProvider) {
|
|
142
|
-
throw new SwapKitError({
|
|
143
|
-
errorKey: "wallet_provider_not_found",
|
|
144
|
-
info: { wallet: WalletOption.KEEPKEY, chain },
|
|
145
|
-
});
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
let method = "request_accounts";
|
|
149
|
-
if (EVMChains.includes(chain as EVMChain)) {
|
|
150
|
-
method = "eth_requestAccounts";
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
const [response] = await eipProvider.request({ method, params: [] });
|
|
154
|
-
return response;
|
|
155
|
-
}
|
|
156
|
-
|
|
157
|
-
export async function walletTransfer(
|
|
158
|
-
{ assetValue, recipient, memo, gasLimit }: WalletTxParams & { assetValue: AssetValue },
|
|
159
|
-
method: TransactionMethod = "transfer",
|
|
160
|
-
) {
|
|
161
|
-
if (!assetValue) {
|
|
162
|
-
throw new SwapKitError("wallet_keepkey_asset_not_defined");
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
const from = await getKEEPKEYAddress(assetValue.chain);
|
|
166
|
-
const params = [
|
|
167
|
-
{
|
|
168
|
-
amount: {
|
|
169
|
-
amount: assetValue.getValue("string"),
|
|
170
|
-
decimals: assetValue.decimal,
|
|
171
|
-
},
|
|
172
|
-
asset: {
|
|
173
|
-
chain: assetValue.chain,
|
|
174
|
-
symbol: assetValue.symbol.toUpperCase(),
|
|
175
|
-
ticker: assetValue.symbol.toUpperCase(),
|
|
176
|
-
},
|
|
177
|
-
memo,
|
|
178
|
-
from,
|
|
179
|
-
recipient,
|
|
180
|
-
gasLimit,
|
|
181
|
-
},
|
|
182
|
-
];
|
|
183
|
-
|
|
184
|
-
return transaction({ method, params, chain: assetValue.chain });
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
export function getKEEPKEYMethods(provider: BrowserProvider, chain: EVMChain) {
|
|
188
|
-
return {
|
|
189
|
-
call: async <T>({
|
|
190
|
-
contractAddress,
|
|
191
|
-
abi,
|
|
192
|
-
funcName,
|
|
193
|
-
funcParams = [],
|
|
194
|
-
txOverrides,
|
|
195
|
-
}: CallParams): Promise<T> => {
|
|
196
|
-
if (!contractAddress) {
|
|
197
|
-
throw new SwapKitError("wallet_keepkey_contract_address_not_provided");
|
|
198
|
-
}
|
|
199
|
-
const { createContract, getCreateContractTxObject, isStateChangingCall, toHexString } =
|
|
200
|
-
await import("@swapkit/toolboxes/evm");
|
|
201
|
-
|
|
202
|
-
const isStateChanging = isStateChangingCall({ abi, funcName });
|
|
203
|
-
|
|
204
|
-
if (isStateChanging) {
|
|
205
|
-
const createTx = getCreateContractTxObject({ provider, chain });
|
|
206
|
-
const { value, from, to, data } = await createTx({
|
|
207
|
-
contractAddress,
|
|
208
|
-
abi,
|
|
209
|
-
funcName,
|
|
210
|
-
funcParams,
|
|
211
|
-
txOverrides,
|
|
212
|
-
});
|
|
213
|
-
|
|
214
|
-
return provider.send("eth_sendTransaction", [
|
|
215
|
-
{ value: toHexString(BigInt(value || 0)), from, to, data: data || "0x" },
|
|
216
|
-
]);
|
|
217
|
-
}
|
|
218
|
-
const contract = createContract(contractAddress, abi, provider);
|
|
219
|
-
|
|
220
|
-
const result = await contract[funcName]?.(...funcParams);
|
|
221
|
-
|
|
222
|
-
return typeof result?.hash === "string" ? result?.hash : result;
|
|
223
|
-
},
|
|
224
|
-
approve: async ({ assetAddress, spenderAddress, amount, from }: ApproveParams) => {
|
|
225
|
-
const { MAX_APPROVAL, getCreateContractTxObject, toHexString } = await import(
|
|
226
|
-
"@swapkit/toolboxes/evm"
|
|
227
|
-
);
|
|
228
|
-
|
|
229
|
-
const createTx = getCreateContractTxObject({ provider, chain });
|
|
230
|
-
const { value, to, data } = await createTx({
|
|
231
|
-
contractAddress: assetAddress,
|
|
232
|
-
abi: erc20ABI,
|
|
233
|
-
funcName: "approve",
|
|
234
|
-
funcParams: [spenderAddress, BigInt(amount || MAX_APPROVAL)],
|
|
235
|
-
txOverrides: { from },
|
|
236
|
-
});
|
|
237
|
-
|
|
238
|
-
return provider.send("eth_sendTransaction", [
|
|
239
|
-
{ value: toHexString(BigInt(value || 0)), from, to, data: data || "0x" },
|
|
240
|
-
]);
|
|
241
|
-
},
|
|
242
|
-
sendTransaction: async (tx: EVMTxParams) => {
|
|
243
|
-
const { from, to, data, value } = tx;
|
|
244
|
-
if (!to) {
|
|
245
|
-
throw new SwapKitError("wallet_keepkey_send_transaction_no_address");
|
|
246
|
-
}
|
|
247
|
-
|
|
248
|
-
const { toHexString } = await import("@swapkit/toolboxes/evm");
|
|
249
|
-
|
|
250
|
-
return provider.send("eth_sendTransaction", [
|
|
251
|
-
{ value: toHexString(BigInt(value || 0)), from, to, data: data || "0x" },
|
|
252
|
-
]);
|
|
253
|
-
},
|
|
254
|
-
};
|
|
255
|
-
}
|