@tomo-inc/wallet-adaptor-base 0.0.1 → 0.0.2

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 (104) hide show
  1. package/dist/index.cjs +735 -324
  2. package/dist/index.d.cts +152 -6
  3. package/dist/index.d.ts +152 -6
  4. package/dist/index.js +667 -325
  5. package/package.json +3 -2
  6. package/project.json +2 -2
  7. package/src/global.d.ts +7 -0
  8. package/src/index.ts +11 -8
  9. package/src/type.ts +8 -0
  10. package/src/utils/isMobile.ts +1 -1
  11. package/src/utils/log.ts +7 -0
  12. package/src/utils/utils.ts +5 -0
  13. package/src/wallet-api/balance.ts +4 -2
  14. package/src/wallet-api/connect.ts +77 -10
  15. package/src/wallet-api/sign-in.ts +20 -26
  16. package/src/wallet-api/sign-message.ts +80 -10
  17. package/src/wallets/Wallet.ts +2 -1
  18. package/src/wallets/default/backpackWallet/backpackWallet.ts +2 -4
  19. package/src/wallets/default/berasigWallet/berasigWallet.ts +2 -4
  20. package/src/wallets/default/binanceWallet/binanceWallet.ts +2 -4
  21. package/src/wallets/default/bitgetWallet/bitgetWallet.ts +2 -4
  22. package/src/wallets/default/bitskiWallet/bitskiWallet.ts +2 -4
  23. package/src/wallets/default/bitverseWallet/bitverseWallet.ts +2 -4
  24. package/src/wallets/default/bloomWallet/bloomWallet.ts +2 -4
  25. package/src/wallets/default/braveWallet/braveWallet.ts +2 -4
  26. package/src/wallets/default/bybitWallet/bybitWallet.ts +2 -4
  27. package/src/wallets/default/clvWallet/clvWallet.ts +2 -4
  28. package/src/wallets/default/coin98Wallet/coin98Wallet.ts +2 -4
  29. package/src/wallets/default/coinbaseWallet/coinbaseWallet.ts +2 -4
  30. package/src/wallets/default/compassWallet/compassWallet.ts +2 -4
  31. package/src/wallets/default/coreWallet/coreWallet.ts +2 -4
  32. package/src/wallets/default/ctrlWallet/ctrlWallet.ts +2 -4
  33. package/src/wallets/default/dawnWallet/dawnWallet.ts +2 -4
  34. package/src/wallets/default/desigWallet/desigWallet.ts +2 -4
  35. package/src/wallets/default/enkryptWallet/enkryptWallet.ts +2 -4
  36. package/src/wallets/default/foxWallet/foxWallet.ts +2 -4
  37. package/src/wallets/default/frameWallet/frameWallet.ts +2 -4
  38. package/src/wallets/default/gateWallet/gateWallet.ts +2 -4
  39. package/src/wallets/default/imTokenWallet/imTokenWallet.ts +2 -4
  40. package/src/wallets/default/injectedWallet/injectedWallet.ts +2 -4
  41. package/src/wallets/default/iopayWallet/iopayWallet.ts +2 -4
  42. package/src/wallets/default/kaiaWallet/kaiaWallet.ts +2 -4
  43. package/src/wallets/default/kaikasWallet/kaikasWallet.ts +2 -4
  44. package/src/wallets/default/krakenWallet/krakenWallet.ts +2 -4
  45. package/src/wallets/default/kresusWallet/kresusWallet.ts +2 -4
  46. package/src/wallets/default/ledgerWallet/ledgerWallet.ts +2 -4
  47. package/src/wallets/default/magicEdenWallet/magicEdenWallet.ts +5 -7
  48. package/src/wallets/default/mathWallet/mathWallet.svg +9 -0
  49. package/src/wallets/default/mathWallet/mathWallet.ts +2 -2
  50. package/src/wallets/default/metaMaskWallet/metaMaskWallet.ts +3 -2
  51. package/src/wallets/default/myDogeWallet/mydogeWallet.ts +1 -1
  52. package/src/wallets/default/nestWallet/nestWallet.ts +2 -4
  53. package/src/wallets/default/novaWallet/novaWallet.ts +2 -4
  54. package/src/wallets/default/oktoWallet/oktoWallet.ts +2 -4
  55. package/src/wallets/default/okxWallet/okxWallet.ts +2 -4
  56. package/src/wallets/default/omniWallet/omniWallet.ts +2 -4
  57. package/src/wallets/default/oneInchWallet/oneInchWallet.svg +30 -1
  58. package/src/wallets/default/oneInchWallet/oneInchWallet.ts +2 -4
  59. package/src/wallets/default/oneKeyWallet/oneKeyWallet.ts +2 -4
  60. package/src/wallets/default/paraSwapWallet/paraswapWallet.ts +2 -4
  61. package/src/wallets/default/petraWallet/petraWallet.svg +5 -0
  62. package/src/wallets/default/petraWallet/petraWallet.ts +24 -0
  63. package/src/wallets/default/phantomWallet/phantomWallet.ts +2 -4
  64. package/src/wallets/default/rabbyWallet/rabbyWallet.ts +2 -4
  65. package/src/wallets/default/rainbowWallet/rainbowWallet.ts +2 -4
  66. package/src/wallets/default/ramperWallet/ramperWallet.ts +2 -4
  67. package/src/wallets/default/readyWallet/readyWallet.ts +2 -4
  68. package/src/wallets/default/roninWallet/roninWallet.ts +2 -4
  69. package/src/wallets/default/safeWallet/safeWallet.ts +2 -4
  70. package/src/wallets/default/safeheronWallet/safeheronWallet.ts +2 -4
  71. package/src/wallets/default/safepalWallet/safepalWallet.ts +2 -4
  72. package/src/wallets/default/seifWallet/seifWallet.ts +2 -4
  73. package/src/wallets/default/solflareWallet/solflareWallet.svg +11 -0
  74. package/src/wallets/default/solflareWallet/solflareWallet.ts +2 -2
  75. package/src/wallets/default/subWallet/subWallet.ts +2 -4
  76. package/src/wallets/default/tahoWallet/tahoWallet.ts +2 -4
  77. package/src/wallets/default/talismanWallet/talismanWallet.ts +2 -4
  78. package/src/wallets/default/tokenPocketWallet/tokenPocketWallet.ts +2 -4
  79. package/src/wallets/default/tokenaryWallet/tokenaryWallet.ts +2 -4
  80. package/src/wallets/default/trezorWallet/trezorWallet.svg +7 -0
  81. package/src/wallets/default/trezorWallet/trezorWallet.ts +2 -2
  82. package/src/wallets/default/trustWallet/trustWallet.ts +3 -5
  83. package/src/wallets/default/uniswapWallet/uniswapWallet.ts +2 -4
  84. package/src/wallets/default/universalProfilesWallet/universalProfilesWallet.svg +13 -1351
  85. package/src/wallets/default/universalProfilesWallet/universalProfilesWallet.ts +2 -2
  86. package/src/wallets/default/valoraWallet/valoraWallet.ts +2 -4
  87. package/src/wallets/default/walletConnectWallet/walletConnectWallet.ts +2 -4
  88. package/src/wallets/default/wigwamWallet/wigwamWallet.ts +2 -4
  89. package/src/wallets/default/xPortalWallet/xPortalWallet.ts +2 -4
  90. package/src/wallets/default/zealWallet/zealWallet.ts +2 -4
  91. package/src/wallets/default/zerionWallet/zerionWallet.ts +2 -4
  92. package/src/wallets/default/zilPayWallet/zilPayWallet.ts +2 -4
  93. package/src/wallets/defaultConnectors.ts +213 -0
  94. package/src/wallets/detector.ts +11 -10
  95. package/src/wallets/index.ts +7 -76
  96. package/src/wallets/wallet-standard.ts +147 -47
  97. package/tsconfig.json +4 -1
  98. package/tsup.config.ts +55 -0
  99. package/src/wallets/default/mathWallet/icon.ts +0 -2
  100. package/src/wallets/default/metaMaskWallet/icon.ts +0 -2
  101. package/src/wallets/default/myDogeWallet/icon.ts +0 -2
  102. package/src/wallets/default/solflareWallet/icon.ts +0 -2
  103. package/src/wallets/default/trezorWallet/icon.ts +0 -2
  104. package/src/wallets/default/universalProfilesWallet/icon.ts +0 -2
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tomo-inc/wallet-adaptor-base",
3
- "version": "0.0.1",
3
+ "version": "0.0.2",
4
4
  "author": "tomo.inc",
5
5
  "license": "MIT",
6
6
  "private": false,
@@ -16,9 +16,10 @@
16
16
  }
17
17
  },
18
18
  "dependencies": {
19
+ "@aptos-labs/ts-sdk": "^5.1.1",
19
20
  "@solana/spl-token": "^0.4.13",
20
21
  "@solana/web3.js": "^1.98.0",
21
- "@aptos-labs/ts-sdk": "^5.1.1",
22
+ "@wallet-standard/core": "^1.1.0",
22
23
  "viem": "2.21.54",
23
24
  "@tomo-inc/wallet-connect-protocol": "0.0.3"
24
25
  },
package/project.json CHANGED
@@ -7,14 +7,14 @@
7
7
  "executor": "nx:run-commands",
8
8
  "outputs": ["{projectRoot}/dist"],
9
9
  "options": {
10
- "command": "tsup src/index.ts --format esm,cjs --dts --treeshake",
10
+ "command": "tsup",
11
11
  "cwd": "packages/wallet-adaptor-base"
12
12
  }
13
13
  },
14
14
  "dev": {
15
15
  "executor": "nx:run-commands",
16
16
  "options": {
17
- "command": "tsup src/index.ts --format esm,cjs --dts --watch",
17
+ "command": "tsup --watch",
18
18
  "cwd": "packages/wallet-adaptor-base"
19
19
  }
20
20
  },
@@ -0,0 +1,7 @@
1
+ declare global {
2
+ interface Window {
3
+ ethereum?: any;
4
+ }
5
+ }
6
+
7
+ export {};
package/src/index.ts CHANGED
@@ -1,8 +1,8 @@
1
1
  import { AdaptorChainType, Connector, WalletConnectorType } from "./type";
2
2
  import { uniqueConnectors } from "./utils/utils";
3
- import { defaultConnectors } from "./wallets";
4
- import { WagmiWalletConfig, WalletConfig } from "./wallets/Wallet";
3
+ import { defaultConnectors } from "./wallets/defaultConnectors";
5
4
  import { connectorDector, supportedWalletConfigTypes, walletConfigAdapter } from "./wallets/detector";
5
+ import { WagmiWalletConfig, WalletConfig } from "./wallets/Wallet";
6
6
  import { eip6963Wallets } from "./wallets/wallet-eip6963";
7
7
  import { walletStandardWallets } from "./wallets/wallet-standard";
8
8
  import { setWalletConnectConfig, walletConnectWallets } from "./wallets/wallet-walletconnect";
@@ -56,13 +56,13 @@ export async function loadConnectors({
56
56
  const connectorsFromConfig = uniqueConnectors([...recommonedConnectorsDetected, ...defaultConnectors]);
57
57
 
58
58
  // Include WalletConnect wallets along with other detected wallets
59
- const connectorsDetected = [...evmWallets, ...solanaWallets, ...aptosWallets, ...wcWallets];
59
+ const connectorsDetecteds = [...evmWallets, ...solanaWallets, ...aptosWallets, ...wcWallets];
60
60
 
61
- for (const connector of connectorsDetected) {
62
- const connectorsDetected = connectorsFromConfig.find((c) => c.info.name === connector.info.name);
63
- if (connectorsDetected) {
64
- connectorsDetected.isInstalled = true;
65
- connectorsDetected.providers = { ...connectorsDetected.providers, ...connector.providers };
61
+ for (const connector of connectorsDetecteds) {
62
+ const _connector = connectorsFromConfig.find((c) => c.info.name === connector.info.name);
63
+ if (_connector) {
64
+ _connector.isInstalled = true;
65
+ _connector.providers = { ..._connector.providers, ...connector.providers };
66
66
  } else {
67
67
  connectorsFromConfig.push(connector);
68
68
  }
@@ -91,3 +91,6 @@ export async function loadConnectors({
91
91
 
92
92
  //api
93
93
  export * from "./wallet-api";
94
+
95
+ // Export all wallets
96
+ export * from "./wallets";
package/src/type.ts CHANGED
@@ -4,6 +4,7 @@ export enum ProviderProtocol {
4
4
  EIP6963 = "eip6963",
5
5
  WALLET_STANDARD = "wallet-standard",
6
6
  WALLET_CONNECT = "wallet-connect",
7
+ INJECT = "inject",
7
8
  }
8
9
 
9
10
  export enum ProviderChainType {
@@ -21,11 +22,13 @@ export const SupportedChainTypes = ["evm", "solana", "aptos"];
21
22
  export interface WalletInfo {
22
23
  uuid: string;
23
24
  name: string;
25
+ sameNames?: string[];
24
26
  namespace?: string;
25
27
  icon: string;
26
28
  iconBackground?: string;
27
29
  rdns?: string;
28
30
  isWalletConnect?: boolean;
31
+ deeplink?: string;
29
32
  links: {
30
33
  homepage?: string;
31
34
  ios_install?: string;
@@ -62,6 +65,10 @@ export interface Connector {
62
65
  };
63
66
  }
64
67
 
68
+ export interface ConnectParams {
69
+ dappLink: string;
70
+ }
71
+
65
72
  export interface SignInParams {
66
73
  scheme?: "https" | "http";
67
74
  domain: string;
@@ -83,6 +90,7 @@ export interface WalletOptions {
83
90
  network?: string;
84
91
  };
85
92
  provider: WalletProvider;
93
+ walletInfo?: WalletInfo;
86
94
  }
87
95
 
88
96
  export interface ChainInfo {
@@ -18,5 +18,5 @@ export function isIOS(): boolean {
18
18
  }
19
19
 
20
20
  export function isMobile(): boolean {
21
- return isAndroid() || isIOS();
21
+ return isAndroid() || isIOS() || isLargeIOS();
22
22
  }
@@ -0,0 +1,7 @@
1
+ const isDebug = true;
2
+
3
+ export function debugLog(...args: any[]) {
4
+ if (isDebug) {
5
+ console.log(...args);
6
+ }
7
+ }
@@ -12,3 +12,8 @@ export function uniqueConnectors(allConnectors: Connector[]) {
12
12
  });
13
13
  return connectors;
14
14
  }
15
+
16
+ // uint8array to hex
17
+ export function uint8arrayToHex(uint8array: Uint8Array) {
18
+ return Array.from(uint8array, (byte) => byte.toString(16).padStart(2, "0")).join("");
19
+ }
@@ -1,5 +1,5 @@
1
- import { PublicKey, Connection } from "@solana/web3.js";
2
1
  import { Aptos, AptosConfig, Network } from "@aptos-labs/ts-sdk";
2
+ import { Connection, PublicKey } from "@solana/web3.js";
3
3
  import { WalletOptions } from "type";
4
4
 
5
5
  export interface BalanceParams {
@@ -41,6 +41,7 @@ export const getBalance = async (
41
41
  method: "eth_getBalance",
42
42
  params: [address, "latest"],
43
43
  });
44
+ console.log("getBalance evm res:", chainType, provider, { address, chainId, balance });
44
45
  return {
45
46
  total: Number(balance || "0") || 0,
46
47
  tokenInfo,
@@ -52,7 +53,7 @@ export const getBalance = async (
52
53
  const connection = new Connection(rpcUrl);
53
54
 
54
55
  const balances = await connection.getMultipleAccountsInfo([address].map((addr) => new PublicKey(addr)));
55
- console.log("solana balances", balances);
56
+ console.log("solana balances", chainType, provider, { address, chainId, balances });
56
57
 
57
58
  return {
58
59
  total: balances[0]?.lamports || 0,
@@ -86,6 +87,7 @@ export const getBalance = async (
86
87
  throw error;
87
88
  }
88
89
 
90
+ console.log("solana balances", chainType, provider, { address, chainId, balance });
89
91
  return {
90
92
  total: balance,
91
93
  tokenInfo,
@@ -1,8 +1,27 @@
1
- import { WalletOptions } from "type";
1
+ import { ConnectParams, WalletOptions } from "type";
2
+ import { isMobile } from "../utils/isMobile";
2
3
 
3
4
  export const connect = async (
4
- walletOptions: WalletOptions,
5
+ connectParams: ConnectParams,
6
+ walletOptions: Omit<WalletOptions, "account">,
5
7
  ): Promise<{ address: string; chainId?: string; network?: string }> => {
8
+ //deeplink in mobile
9
+ //https://link.metamask.io/dapp/app.uniswap.org
10
+ if (isMobile()) {
11
+ const deeplink = walletOptions?.walletInfo?.deeplink || "";
12
+ if (!deeplink) {
13
+ throw new Error("Deeplink not supported");
14
+ }
15
+ const dappLink = connectParams?.dappLink || "";
16
+ if (!dappLink) {
17
+ throw new Error("Dapp link is required");
18
+ }
19
+ const { hostname, pathname } = new URL(dappLink);
20
+ const link = `${deeplink}${hostname}${pathname}`;
21
+ (window as any).location.href = link;
22
+ }
23
+
24
+ //inject provider/walletconnect provider
6
25
  const { provider, chainType } = walletOptions;
7
26
 
8
27
  if (!provider) {
@@ -20,25 +39,59 @@ export const connect = async (
20
39
  address = res?.[0] || "";
21
40
  chainId = await provider.request({ method: "eth_chainId" });
22
41
  }
42
+
43
+ // console.log("connect request:", chainType, provider);
23
44
  if (chainType === "solana") {
24
45
  let res = null;
25
46
  if (provider?.connect) {
26
47
  res = await provider.connect();
48
+ address = res?.publicKey?.toString() || "";
27
49
  }
28
50
  if (provider?.request) {
29
51
  res = await provider.request({
30
52
  method: "connect",
31
53
  });
54
+ address = res?.publicKey?.toString() || "";
55
+ }
56
+ if (provider?.["standard:connect"]) {
57
+ res = await provider["standard:connect"]?.connect();
58
+ address = res?.accounts?.[0]?.address || "";
32
59
  }
33
- address = provider?.publicKey?.toString() || "";
34
60
  network = "mainnet-beta";
35
61
  }
62
+
36
63
  if (chainType === "aptos") {
37
- await provider?.connect();
38
- const account = await provider?.account();
39
- network = ((await provider?.network()) || "Mainnet") as string;
40
- address = account?.address || "";
64
+ if (provider?.connect) {
65
+ await provider?.connect();
66
+ } else if (provider?.request) {
67
+ await provider.request({ method: "connect" });
68
+ } else if (provider?.["aptos:connect"]) {
69
+ await provider["aptos:connect"]?.connect();
70
+ }
71
+
72
+ if (provider?.account) {
73
+ const account = await provider?.account();
74
+ address = account?.address || "";
75
+ } else if (provider?.["aptos:account"]) {
76
+ const account = await provider?.["aptos:account"]?.account();
77
+ const addressData = account?.address?.data;
78
+ const hexString = addressData
79
+ ? Array.from(addressData as Uint8Array)
80
+ .map((b) => b.toString(16).padStart(2, "0"))
81
+ .join("")
82
+ : null;
83
+ address = `0x${hexString}`;
84
+ }
85
+
86
+ // if (provider?.network) {
87
+ // network = ((await provider?.network()) || "Mainnet") as string;
88
+ // }
89
+ // if (provider?.["aptos:network"]) {
90
+ // network = ((await provider?.["aptos:network"]?.network())?.name || "Mainnet") as string;
91
+ // }
92
+ network = "mainnet";
41
93
  }
94
+ console.log("connect res:", chainType, provider, { address, chainId, network });
42
95
  return { address, chainId, network };
43
96
  };
44
97
 
@@ -56,10 +109,24 @@ export const disconnect = async (walletOptions: WalletOptions): Promise<boolean>
56
109
  await provider.request({ method: "wallet_revokePermissions" });
57
110
  }
58
111
  if (chainType === "solana") {
59
- await provider.disconnect();
112
+ if (provider?.disconnect) {
113
+ await provider.disconnect();
114
+ return true;
115
+ }
116
+ if (provider?.["standard:disconnect"]) {
117
+ await provider["standard:disconnect"]?.disconnect();
118
+ return true;
119
+ }
60
120
  }
61
121
  if (chainType === "aptos") {
62
- await provider.disconnect();
122
+ if (provider?.disconnect) {
123
+ await provider.disconnect();
124
+ return true;
125
+ }
126
+ if (provider?.["aptos:disconnect"]) {
127
+ await provider["aptos:disconnect"]?.disconnect();
128
+ return true;
129
+ }
63
130
  }
64
- return true;
131
+ return false;
65
132
  };
@@ -1,5 +1,6 @@
1
1
  import { SignInParams, WalletOptions } from "type";
2
-
2
+ import { uint8arrayToHex } from "utils/utils";
3
+ import { signMessage } from "./sign-message";
3
4
  /*
4
5
  const params = {
5
6
  domain: window.location.host,
@@ -12,7 +13,7 @@ const params = {
12
13
  };
13
14
  */
14
15
 
15
- export const signInWithWallet = async (signInData: SignInParams, walletOptions: WalletOptions) => {
16
+ export const signInWithWallet = async (signInData: SignInParams, walletOptions: WalletOptions): Promise<string> => {
16
17
  const { chainType, account, provider } = walletOptions;
17
18
 
18
19
  if (!provider) {
@@ -20,23 +21,16 @@ export const signInWithWallet = async (signInData: SignInParams, walletOptions:
20
21
  }
21
22
 
22
23
  const message = signInMessageBuilder(signInData, walletOptions);
23
- const { address } = account;
24
-
25
24
  if (chainType === "evm") {
26
- try {
27
- const sign: string = await provider.request({
28
- method: "personal_sign",
29
- params: [message, address],
30
- });
31
- return sign;
32
- } catch (error) {
33
- throw error as Error;
34
- }
25
+ return await signMessage({ message, nonce: signInData.nonce }, walletOptions);
26
+ }
27
+ if (chainType === "aptos") {
28
+ return await signMessage({ message, nonce: signInData.nonce }, walletOptions);
35
29
  }
36
30
 
37
31
  if (chainType === "solana") {
38
32
  try {
39
- if (provider?.signIn) {
33
+ if (provider?.signIn || provider?.["solana:signIn"]) {
40
34
  // Create params object without address, scheme, and chainId
41
35
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
42
36
  const { address: _address, scheme: _scheme, chainId: _chainId, ...signInDataWithoutFields } = signInData;
@@ -44,25 +38,25 @@ export const signInWithWallet = async (signInData: SignInParams, walletOptions:
44
38
  const { address: _accountAddress, chainId: _accountChainId, ...accountWithoutFields } = account;
45
39
  const params = { ...signInDataWithoutFields, ...accountWithoutFields };
46
40
 
47
- const { signature } = await provider.signIn(params);
41
+ const res = provider.signIn ? await provider.signIn(params) : await provider["solana:signIn"]?.signIn(params);
42
+ let signature = "";
43
+ if (typeof res === "object" && res?.signature) {
44
+ signature = res?.signature?.toHex?.() || uint8arrayToHex(res?.signature as Uint8Array) || "";
45
+ } else if (Array.isArray(res)) {
46
+ signature = res?.[0]?.signature?.toHex?.() || uint8arrayToHex(res?.[0]?.signature as Uint8Array) || "";
47
+ } else {
48
+ signature = res || "";
49
+ }
50
+ console.log("signInWithWallet solana res:", chainType, provider, { params, signature });
48
51
  return signature;
49
52
  }
50
- const encodedMessage = new TextEncoder().encode(message);
51
- const { signature } = await provider.signMessage(encodedMessage, "utf8");
52
- return signature;
53
+
54
+ return await signMessage({ message, nonce: signInData.nonce }, walletOptions);
53
55
  } catch (error) {
54
56
  throw error as Error;
55
57
  }
56
58
  }
57
59
 
58
- if (chainType === "aptos") {
59
- const { signature } = await provider.signMessage({
60
- message,
61
- nonce: signInData.nonce,
62
- });
63
- return signature;
64
- }
65
-
66
60
  throw new Error(`signInWithWallet not supported in ${chainType}`);
67
61
  };
68
62
 
@@ -1,4 +1,5 @@
1
1
  import { WalletOptions } from "type";
2
+ import { uint8arrayToHex } from "utils/utils";
2
3
 
3
4
  /*
4
5
  const params = {
@@ -12,7 +13,10 @@ const params = {
12
13
  };
13
14
  */
14
15
 
15
- export const signMessage = async (data: { message: string; nonce: string }, walletOptions: WalletOptions) => {
16
+ export const signMessage = async (
17
+ data: { message: string; nonce: string },
18
+ walletOptions: WalletOptions,
19
+ ): Promise<string> => {
16
20
  const { chainType, account, provider } = walletOptions;
17
21
  const { message, nonce } = data;
18
22
 
@@ -24,11 +28,12 @@ export const signMessage = async (data: { message: string; nonce: string }, wall
24
28
 
25
29
  if (chainType === "evm") {
26
30
  try {
27
- const sign: string = await provider.request({
31
+ const signature: string = await provider.request({
28
32
  method: "personal_sign",
29
33
  params: [message, address],
30
34
  });
31
- return sign;
35
+ console.log("signMessage res:", chainType, provider, message, signature);
36
+ return signature;
32
37
  } catch (error) {
33
38
  throw error as Error;
34
39
  }
@@ -37,20 +42,57 @@ export const signMessage = async (data: { message: string; nonce: string }, wall
37
42
  if (chainType === "solana") {
38
43
  try {
39
44
  const encodedMessage = new TextEncoder().encode(message);
40
- const { signature } = await provider.signMessage(encodedMessage, "utf8");
41
- return signature;
45
+ let signature = "";
46
+ if (provider?.signMessage) {
47
+ const res = await provider.signMessage(encodedMessage, "utf8");
48
+ if (typeof res === "object" && res?.signature) {
49
+ signature = res?.signature?.toHex?.() || uint8arrayToHex(res?.signature as Uint8Array) || "";
50
+ } else if (Array.isArray(res)) {
51
+ signature = res?.[0]?.signature?.toHex?.() || uint8arrayToHex(res?.[0]?.signature as Uint8Array) || "";
52
+ } else {
53
+ signature = res || "";
54
+ }
55
+ console.log("signMessage solana res:", chainType, provider, message, signature);
56
+ return signature;
57
+ }
58
+ if (provider?.["solana:signMessage"]) {
59
+ const res: any[] = await provider["solana:signMessage"]?.signMessage({
60
+ message: encodedMessage,
61
+ account: { address },
62
+ });
63
+ signature = res?.[0]?.signature?.toHex?.() || uint8arrayToHex(res?.[0]?.signature as Uint8Array) || "";
64
+ console.log("signMessage solana res:", chainType, provider, message, signature);
65
+ return signature;
66
+ }
67
+ throw new Error("signMessage solana not supported");
42
68
  } catch (error) {
69
+ console.log("signMessage solana error:", chainType, provider, message, error);
43
70
  throw error as Error;
44
71
  }
45
72
  }
46
73
 
47
74
  if (chainType === "aptos") {
48
75
  try {
49
- const { signature } = await provider.signMessage({
50
- message,
51
- nonce,
52
- });
53
- return signature;
76
+ let signature = "";
77
+ if (provider?.signMessage) {
78
+ const res = await provider.signMessage({
79
+ message,
80
+ nonce,
81
+ });
82
+ signature = getAPTOSSignatureFromResponse(res);
83
+ console.log("signMessage aptos res:", chainType, provider, message, signature);
84
+ return signature;
85
+ }
86
+ if (provider?.["aptos:signMessage"]) {
87
+ const res = await provider["aptos:signMessage"]?.signMessage({
88
+ message,
89
+ nonce,
90
+ });
91
+ signature = getAPTOSSignatureFromResponse(res);
92
+ console.log("signMessage aptos res:", chainType, provider, message, signature);
93
+ return signature;
94
+ }
95
+ throw new Error("signMessage aptos not supported");
54
96
  } catch (error) {
55
97
  throw error as Error;
56
98
  }
@@ -58,3 +100,31 @@ export const signMessage = async (data: { message: string; nonce: string }, wall
58
100
 
59
101
  throw new Error(`signMessage not supported in ${chainType}`);
60
102
  };
103
+
104
+ function getAPTOSSignatureFromResponse(res: any): string {
105
+ let signature = "";
106
+ if (typeof res === "object" && res?.args?.signature) {
107
+ const oSignature = res?.args?.signature;
108
+ // signature is an object with data and signature properties
109
+ if (typeof oSignature === "object" && oSignature?.data?.data) {
110
+ // some wallet signature is an object, can be converted to hex string
111
+ if (oSignature?.data?.data?.toHex) {
112
+ signature = oSignature?.data?.data?.toHex?.() || "";
113
+ } else if (typeof oSignature?.data?.data === "object") {
114
+ // the gate wallet signature is an object like { data: { data: { } } }, need to convert to hex string
115
+ signature = uint8arrayToHex(new Uint8Array(Object.values(oSignature?.data?.data))) || "";
116
+ } else {
117
+ signature = oSignature || "";
118
+ }
119
+ // signature is an object with signature property, like petra wallet
120
+ } else if (typeof oSignature === "object" && oSignature?.signature) {
121
+ signature = oSignature?.signature?.toString("hex") || "";
122
+ } else {
123
+ signature = oSignature || "";
124
+ }
125
+ // signature is a string, like okx wallet
126
+ } else if (res?.signature && typeof res?.signature === "string") {
127
+ signature = res?.signature || "";
128
+ }
129
+ return signature;
130
+ }
@@ -2,7 +2,7 @@ export type WalletConfig = {
2
2
  id: string;
3
3
  name: string;
4
4
  rdns?: string;
5
- namespace: string;
5
+ namespace?: string;
6
6
  flag?: string;
7
7
  solana?: {
8
8
  namespace?: string;
@@ -16,6 +16,7 @@ export type WalletConfig = {
16
16
  iconAccent?: string;
17
17
  iconBackground: string;
18
18
  installed?: boolean;
19
+ deeplink?: string;
19
20
  downloadUrls?: {
20
21
  android?: string;
21
22
  ios?: string;
@@ -1,7 +1,5 @@
1
1
  import type { WalletConfig } from "../../Wallet";
2
-
3
- const backpackWalletIcon =
4
- "";
2
+ import icon from "./backpackWallet.svg";
5
3
 
6
4
  export const backpackWallet = (): WalletConfig => {
7
5
  return {
@@ -9,7 +7,7 @@ export const backpackWallet = (): WalletConfig => {
9
7
  name: "Backpack",
10
8
  namespace: "backpack.ethereum",
11
9
  rdns: "app.backpack.mobile",
12
- icon: backpackWalletIcon,
10
+ icon,
13
11
  iconBackground: "#0C0D10",
14
12
  downloadUrls: {
15
13
  android: "https://play.google.com/store/apps/details?id=app.backpack.mobile",
@@ -1,7 +1,5 @@
1
1
  import type { WalletConfig } from "../../Wallet";
2
-
3
- const berasigWalletIcon =
4
- "";
2
+ import icon from "./berasigWallet.svg";
5
3
 
6
4
  export const berasigWallet = (): WalletConfig => {
7
5
  return {
@@ -9,7 +7,7 @@ export const berasigWallet = (): WalletConfig => {
9
7
  name: "BeraSig",
10
8
  namespace: "berasig.ethereum",
11
9
  rdns: "app.berasig",
12
- icon: berasigWalletIcon,
10
+ icon,
13
11
  iconBackground: "#ffffff",
14
12
  downloadUrls: {
15
13
  android: "https://play.google.com/store/apps/details?id=io.berasig.ios",
@@ -1,7 +1,5 @@
1
1
  import type { WalletConfig } from "../../Wallet";
2
-
3
- const binanceWalletIcon =
4
- "";
2
+ import icon from "./binanceWallet.svg";
5
3
 
6
4
  export const binanceWallet = (): WalletConfig => {
7
5
  return {
@@ -10,7 +8,7 @@ export const binanceWallet = (): WalletConfig => {
10
8
  namespace: "binancew3w.isExtension",
11
9
  flag: "isBinance",
12
10
  rdns: "com.binance.wallet",
13
- icon: binanceWalletIcon,
11
+ icon,
14
12
  iconBackground: "#000000",
15
13
  downloadUrls: {
16
14
  android: "https://play.google.com/store/apps/details?id=com.binance.dev",
@@ -1,7 +1,5 @@
1
1
  import type { WalletConfig } from "../../Wallet";
2
-
3
- const bitgetWalletIcon =
4
- "";
2
+ import icon from "./bitgetWallet.svg";
5
3
 
6
4
  export const bitgetWallet = (): WalletConfig => {
7
5
  return {
@@ -15,7 +13,7 @@ export const bitgetWallet = (): WalletConfig => {
15
13
  namespace: "bitkeep.aptos",
16
14
  },
17
15
  rdns: "com.bitget.web3",
18
- icon: bitgetWalletIcon,
16
+ icon,
19
17
  iconAccent: "#f6851a",
20
18
  iconBackground: "#fff",
21
19
  downloadUrls: {
@@ -1,14 +1,12 @@
1
1
  import type { WalletConfig } from "../../Wallet";
2
-
3
- const bitskiWalletIcon =
4
- "";
2
+ import icon from "./bitskiWallet.svg";
5
3
 
6
4
  export const bitskiWallet = (): WalletConfig => ({
7
5
  id: "bitski",
8
6
  name: "Bitski",
9
7
  namespace: "",
10
8
  flag: "isBitski",
11
- icon: bitskiWalletIcon,
9
+ icon,
12
10
  iconBackground: "#fff",
13
11
  downloadUrls: {
14
12
  chrome: "https://chrome.google.com/webstore/detail/bitski/feejiigddaafeojfddjjlmfkabimkell",