@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.
- package/dist/index.cjs +735 -324
- package/dist/index.d.cts +152 -6
- package/dist/index.d.ts +152 -6
- package/dist/index.js +667 -325
- package/package.json +3 -2
- package/project.json +2 -2
- package/src/global.d.ts +7 -0
- package/src/index.ts +11 -8
- package/src/type.ts +8 -0
- package/src/utils/isMobile.ts +1 -1
- package/src/utils/log.ts +7 -0
- package/src/utils/utils.ts +5 -0
- package/src/wallet-api/balance.ts +4 -2
- package/src/wallet-api/connect.ts +77 -10
- package/src/wallet-api/sign-in.ts +20 -26
- package/src/wallet-api/sign-message.ts +80 -10
- package/src/wallets/Wallet.ts +2 -1
- package/src/wallets/default/backpackWallet/backpackWallet.ts +2 -4
- package/src/wallets/default/berasigWallet/berasigWallet.ts +2 -4
- package/src/wallets/default/binanceWallet/binanceWallet.ts +2 -4
- package/src/wallets/default/bitgetWallet/bitgetWallet.ts +2 -4
- package/src/wallets/default/bitskiWallet/bitskiWallet.ts +2 -4
- package/src/wallets/default/bitverseWallet/bitverseWallet.ts +2 -4
- package/src/wallets/default/bloomWallet/bloomWallet.ts +2 -4
- package/src/wallets/default/braveWallet/braveWallet.ts +2 -4
- package/src/wallets/default/bybitWallet/bybitWallet.ts +2 -4
- package/src/wallets/default/clvWallet/clvWallet.ts +2 -4
- package/src/wallets/default/coin98Wallet/coin98Wallet.ts +2 -4
- package/src/wallets/default/coinbaseWallet/coinbaseWallet.ts +2 -4
- package/src/wallets/default/compassWallet/compassWallet.ts +2 -4
- package/src/wallets/default/coreWallet/coreWallet.ts +2 -4
- package/src/wallets/default/ctrlWallet/ctrlWallet.ts +2 -4
- package/src/wallets/default/dawnWallet/dawnWallet.ts +2 -4
- package/src/wallets/default/desigWallet/desigWallet.ts +2 -4
- package/src/wallets/default/enkryptWallet/enkryptWallet.ts +2 -4
- package/src/wallets/default/foxWallet/foxWallet.ts +2 -4
- package/src/wallets/default/frameWallet/frameWallet.ts +2 -4
- package/src/wallets/default/gateWallet/gateWallet.ts +2 -4
- package/src/wallets/default/imTokenWallet/imTokenWallet.ts +2 -4
- package/src/wallets/default/injectedWallet/injectedWallet.ts +2 -4
- package/src/wallets/default/iopayWallet/iopayWallet.ts +2 -4
- package/src/wallets/default/kaiaWallet/kaiaWallet.ts +2 -4
- package/src/wallets/default/kaikasWallet/kaikasWallet.ts +2 -4
- package/src/wallets/default/krakenWallet/krakenWallet.ts +2 -4
- package/src/wallets/default/kresusWallet/kresusWallet.ts +2 -4
- package/src/wallets/default/ledgerWallet/ledgerWallet.ts +2 -4
- package/src/wallets/default/magicEdenWallet/magicEdenWallet.ts +5 -7
- package/src/wallets/default/mathWallet/mathWallet.svg +9 -0
- package/src/wallets/default/mathWallet/mathWallet.ts +2 -2
- package/src/wallets/default/metaMaskWallet/metaMaskWallet.ts +3 -2
- package/src/wallets/default/myDogeWallet/mydogeWallet.ts +1 -1
- package/src/wallets/default/nestWallet/nestWallet.ts +2 -4
- package/src/wallets/default/novaWallet/novaWallet.ts +2 -4
- package/src/wallets/default/oktoWallet/oktoWallet.ts +2 -4
- package/src/wallets/default/okxWallet/okxWallet.ts +2 -4
- package/src/wallets/default/omniWallet/omniWallet.ts +2 -4
- package/src/wallets/default/oneInchWallet/oneInchWallet.svg +30 -1
- package/src/wallets/default/oneInchWallet/oneInchWallet.ts +2 -4
- package/src/wallets/default/oneKeyWallet/oneKeyWallet.ts +2 -4
- package/src/wallets/default/paraSwapWallet/paraswapWallet.ts +2 -4
- package/src/wallets/default/petraWallet/petraWallet.svg +5 -0
- package/src/wallets/default/petraWallet/petraWallet.ts +24 -0
- package/src/wallets/default/phantomWallet/phantomWallet.ts +2 -4
- package/src/wallets/default/rabbyWallet/rabbyWallet.ts +2 -4
- package/src/wallets/default/rainbowWallet/rainbowWallet.ts +2 -4
- package/src/wallets/default/ramperWallet/ramperWallet.ts +2 -4
- package/src/wallets/default/readyWallet/readyWallet.ts +2 -4
- package/src/wallets/default/roninWallet/roninWallet.ts +2 -4
- package/src/wallets/default/safeWallet/safeWallet.ts +2 -4
- package/src/wallets/default/safeheronWallet/safeheronWallet.ts +2 -4
- package/src/wallets/default/safepalWallet/safepalWallet.ts +2 -4
- package/src/wallets/default/seifWallet/seifWallet.ts +2 -4
- package/src/wallets/default/solflareWallet/solflareWallet.svg +11 -0
- package/src/wallets/default/solflareWallet/solflareWallet.ts +2 -2
- package/src/wallets/default/subWallet/subWallet.ts +2 -4
- package/src/wallets/default/tahoWallet/tahoWallet.ts +2 -4
- package/src/wallets/default/talismanWallet/talismanWallet.ts +2 -4
- package/src/wallets/default/tokenPocketWallet/tokenPocketWallet.ts +2 -4
- package/src/wallets/default/tokenaryWallet/tokenaryWallet.ts +2 -4
- package/src/wallets/default/trezorWallet/trezorWallet.svg +7 -0
- package/src/wallets/default/trezorWallet/trezorWallet.ts +2 -2
- package/src/wallets/default/trustWallet/trustWallet.ts +3 -5
- package/src/wallets/default/uniswapWallet/uniswapWallet.ts +2 -4
- package/src/wallets/default/universalProfilesWallet/universalProfilesWallet.svg +13 -1351
- package/src/wallets/default/universalProfilesWallet/universalProfilesWallet.ts +2 -2
- package/src/wallets/default/valoraWallet/valoraWallet.ts +2 -4
- package/src/wallets/default/walletConnectWallet/walletConnectWallet.ts +2 -4
- package/src/wallets/default/wigwamWallet/wigwamWallet.ts +2 -4
- package/src/wallets/default/xPortalWallet/xPortalWallet.ts +2 -4
- package/src/wallets/default/zealWallet/zealWallet.ts +2 -4
- package/src/wallets/default/zerionWallet/zerionWallet.ts +2 -4
- package/src/wallets/default/zilPayWallet/zilPayWallet.ts +2 -4
- package/src/wallets/defaultConnectors.ts +213 -0
- package/src/wallets/detector.ts +11 -10
- package/src/wallets/index.ts +7 -76
- package/src/wallets/wallet-standard.ts +147 -47
- package/tsconfig.json +4 -1
- package/tsup.config.ts +55 -0
- package/src/wallets/default/mathWallet/icon.ts +0 -2
- package/src/wallets/default/metaMaskWallet/icon.ts +0 -2
- package/src/wallets/default/myDogeWallet/icon.ts +0 -2
- package/src/wallets/default/solflareWallet/icon.ts +0 -2
- package/src/wallets/default/trezorWallet/icon.ts +0 -2
- 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.
|
|
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
|
-
"@
|
|
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
|
|
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
|
|
17
|
+
"command": "tsup --watch",
|
|
18
18
|
"cwd": "packages/wallet-adaptor-base"
|
|
19
19
|
}
|
|
20
20
|
},
|
package/src/global.d.ts
ADDED
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
|
|
59
|
+
const connectorsDetecteds = [...evmWallets, ...solanaWallets, ...aptosWallets, ...wcWallets];
|
|
60
60
|
|
|
61
|
-
for (const connector of
|
|
62
|
-
const
|
|
63
|
-
if (
|
|
64
|
-
|
|
65
|
-
|
|
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 {
|
package/src/utils/isMobile.ts
CHANGED
package/src/utils/log.ts
ADDED
package/src/utils/utils.ts
CHANGED
|
@@ -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
|
-
|
|
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
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
|
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
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
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
|
|
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
|
-
|
|
51
|
-
|
|
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 (
|
|
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
|
|
31
|
+
const signature: string = await provider.request({
|
|
28
32
|
method: "personal_sign",
|
|
29
33
|
params: [message, address],
|
|
30
34
|
});
|
|
31
|
-
|
|
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
|
-
|
|
41
|
-
|
|
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
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
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
|
+
}
|
package/src/wallets/Wallet.ts
CHANGED
|
@@ -2,7 +2,7 @@ export type WalletConfig = {
|
|
|
2
2
|
id: string;
|
|
3
3
|
name: string;
|
|
4
4
|
rdns?: string;
|
|
5
|
-
namespace
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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
|
|
9
|
+
icon,
|
|
12
10
|
iconBackground: "#fff",
|
|
13
11
|
downloadUrls: {
|
|
14
12
|
chrome: "https://chrome.google.com/webstore/detail/bitski/feejiigddaafeojfddjjlmfkabimkell",
|