2022-10-03 18:12:34 +00:00
|
|
|
import { useCallback, useState } from 'react';
|
|
|
|
import type { JsonRpcConnector } from './connectors';
|
|
|
|
import { ClientErrors } from './connectors';
|
|
|
|
import { WalletError } from './connectors';
|
|
|
|
import { useVegaWallet } from './use-vega-wallet';
|
|
|
|
|
|
|
|
export enum Status {
|
|
|
|
Idle = 'Idle',
|
|
|
|
CheckingVersion = 'CheckingVersion',
|
|
|
|
GettingChainId = 'GettingChainId',
|
|
|
|
Connecting = 'Connecting',
|
|
|
|
GettingPerms = 'GettingPerms',
|
|
|
|
ListingKeys = 'ListingKeys',
|
|
|
|
Connected = 'Connected',
|
|
|
|
Error = 'Error',
|
|
|
|
}
|
|
|
|
|
|
|
|
export const useJsonRpcConnect = (onConnect: () => void) => {
|
|
|
|
const { connect } = useVegaWallet();
|
|
|
|
const [status, setStatus] = useState(Status.Idle);
|
|
|
|
const [error, setError] = useState<WalletError | null>(null);
|
|
|
|
|
|
|
|
const attemptConnect = useCallback(
|
|
|
|
async (connector: JsonRpcConnector, appChainId: string) => {
|
|
|
|
try {
|
|
|
|
// Check that the running wallet is compatible with this connector
|
|
|
|
setStatus(Status.CheckingVersion);
|
|
|
|
await connector.checkCompat();
|
|
|
|
|
|
|
|
// Check if wallet is configured for the same chain as the app
|
|
|
|
setStatus(Status.GettingChainId);
|
|
|
|
const chainIdResult = await connector.getChainId();
|
|
|
|
|
2022-11-28 17:07:15 +00:00
|
|
|
// Dont throw in when cypress is running as trading app relies on
|
|
|
|
// mocks which result in a mismatch between chainId for app and
|
|
|
|
// chainId for wallet
|
|
|
|
const isTest = !('Cypress' in window);
|
|
|
|
|
|
|
|
if (chainIdResult.chainID !== appChainId && isTest) {
|
2022-10-03 18:12:34 +00:00
|
|
|
// Throw wallet error for consitent error handling
|
|
|
|
throw ClientErrors.WRONG_NETWORK;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Start connection flow. User will be prompted to select a wallet and enter
|
|
|
|
// its password in the wallet application, promise will resolve once successful
|
|
|
|
// or it will throw
|
|
|
|
setStatus(Status.Connecting);
|
|
|
|
await connector.connectWallet();
|
|
|
|
|
|
|
|
setStatus(Status.GettingPerms);
|
|
|
|
|
|
|
|
// Call connect in the wallet provider. The connector will be stored for
|
|
|
|
// future actions such as sending transactions
|
|
|
|
await connect(connector);
|
|
|
|
|
|
|
|
setStatus(Status.Connected);
|
|
|
|
onConnect();
|
|
|
|
} catch (err) {
|
|
|
|
if (err instanceof WalletError) {
|
|
|
|
setError(err);
|
|
|
|
}
|
|
|
|
setStatus(Status.Error);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
[onConnect, connect]
|
|
|
|
);
|
|
|
|
|
|
|
|
return {
|
|
|
|
status,
|
|
|
|
error,
|
|
|
|
connect: attemptConnect,
|
|
|
|
};
|
|
|
|
};
|