Skip to content

Commit

Permalink
feat(evm): propogate chain change event to dapps
Browse files Browse the repository at this point in the history
  • Loading branch information
CedrikNikita committed Dec 16, 2024
1 parent e3d46b8 commit 4e3b4a2
Show file tree
Hide file tree
Showing 6 changed files with 86 additions and 8 deletions.
14 changes: 13 additions & 1 deletion src/background/index.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { IBackgroundMessageData } from '@/types';
import type { IBackgroundMessageData } from '@/types';
import {
openPopup,
removePopup,
Expand Down Expand Up @@ -47,6 +47,18 @@ const handleMessage: browser.runtime.onMessageBool = (
popupType,
} = msg.params ?? {};
switch (msg.method) {
case 'chainChanged':
browser.tabs.query({ active: true, lastFocusedWindow: true }).then(([tab]) => {
if (tab.id) {
browser.tabs.sendMessage(tab.id, {
superheroWalletApproved: true,
method: msg.method,
result: msg.params?.rpcMethodParams?.result,
type: 'result',
});
}
});
break;
case 'openPopup':
openPopup(popupType!, aepp!, popupProps).then((popupConfig) => {
sendResponse(popupConfig);
Expand Down
24 changes: 23 additions & 1 deletion src/content-scripts/inject.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,13 @@ import {

import type { IEthRpcMethodParameters } from '@/protocols/ethereum/types';
import type { BackgroundMethod } from '@/types';
import { ETH_RPC_ETHERSCAN_PROXY_METHODS, ETH_RPC_METHODS } from '@/protocols/ethereum/config';
import {
ETH_RPC_ETHERSCAN_PROXY_METHODS,
ETH_RPC_METHODS,
ETH_RPC_WALLET_EVENTS,
} from '@/protocols/ethereum/config';

const connectedDapps: Record<string, any> = {};

window.browser = require('webextension-polyfill');

Expand All @@ -33,6 +39,9 @@ const runContentScript = () => {
rpcMethodParams: params,
aepp: event.origin,
});
if (!connectedDapps[event.origin]) {
connectedDapps[event.origin] = event.source;
}
event.source.postMessage({
jsonrpc: '2.0',
result,
Expand Down Expand Up @@ -70,6 +79,19 @@ const runContentScript = () => {
},
false,
);
browser.runtime.onMessage.addListener(({ method, result }: any) => {
if (method === ETH_RPC_WALLET_EVENTS.chainChanged) {
Object.entries(connectedDapps).forEach(([origin, source]) => {
source.postMessage({
jsonrpc: '2.0',
result,
method,
superheroWalletApproved: true,
type: 'result',
}, origin as any);
});
}
});

/**
* Aex-2 Aepp communication
Expand Down
34 changes: 32 additions & 2 deletions src/offscreen/offscreen.ts
Original file line number Diff line number Diff line change
@@ -1,14 +1,44 @@
import '@/lib/initPolyfills';
import '@/protocols/registerAdapters';
import { watch } from 'vue';
import type { IBackgroundMessageData } from '@/types';
import type { EthRpcSupportedMethods } from '@/protocols/ethereum/types';

import { IS_FIREFOX, POPUP_METHODS } from '@/constants';
import { useWalletConnect } from '@/composables';
import { IS_FIREFOX, POPUP_METHODS, PROTOCOLS } from '@/constants';
import { useWalletConnect, useNetworks } from '@/composables';
import { handleEthereumRpcMethod } from '@/protocols/ethereum/libs/EthereumRpcMethodsHandler';
import { ETH_RPC_WALLET_EVENTS } from '@/protocols/ethereum/config';
import * as wallet from './wallet';
import { registerInPageContentScript, updateDynamicRules } from '../background/utils';

const { activeNetworkName, networks } = useNetworks();

watch(activeNetworkName, async (newNetworkName, oldNetworkName) => {
if (oldNetworkName && newNetworkName !== oldNetworkName) {
if (IS_FIREFOX) {
const [tab] = await browser.tabs.query({ active: true, lastFocusedWindow: true });
if (tab.id) {
browser.tabs.sendMessage(tab.id, {
superheroWalletApproved: true,
method: ETH_RPC_WALLET_EVENTS.chainChanged,
result: `0x${BigInt(networks.value[newNetworkName].protocols[PROTOCOLS.ethereum].chainId).toString(16)}`,
type: 'result',
});
}
} else {
browser.runtime.sendMessage<IBackgroundMessageData>({
target: 'background',
method: ETH_RPC_WALLET_EVENTS.chainChanged,
params: {
rpcMethodParams: {
result: `0x${BigInt(networks.value[newNetworkName].protocols[PROTOCOLS.ethereum].chainId).toString(16)}`,
},
},
});
}
}
});

// If browser is FF, load the redirectRule script because background is not loaded from the manifest
// in FF we have to use the offscreen.html as background page
if (IS_FIREFOX) {
Expand Down
4 changes: 4 additions & 0 deletions src/protocols/ethereum/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -121,3 +121,7 @@ export const ETH_RPC_METHODS = {
switchNetwork: 'wallet_switchEthereumChain',
revokePermissions: 'wallet_revokePermissions',
} as const;

export const ETH_RPC_WALLET_EVENTS = {
chainChanged: 'chainChanged',
} as const;
12 changes: 10 additions & 2 deletions src/protocols/ethereum/libs/EthereumRpcMethodsHandler.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,12 @@ import { ProtocolAdapterFactory } from '@/lib/ProtocolAdapterFactory';
import { EtherscanService } from '@/protocols/ethereum/libs/EtherscanService';
import { useEthNetworkSettings } from '@/protocols/ethereum/composables/ethNetworkSettings';
import { useEthFeeCalculation } from '@/protocols/ethereum/composables/ethFeeCalculation';
import { ETH_CONTRACT_ID, ETH_RPC_ETHERSCAN_PROXY_METHODS, ETH_RPC_METHODS } from '@/protocols/ethereum/config';
import {
ETH_CONTRACT_ID,
ETH_RPC_ETHERSCAN_PROXY_METHODS,
ETH_RPC_METHODS,
ETH_RPC_WALLET_EVENTS,
} from '@/protocols/ethereum/config';

import {
CONNECT_PERMISSIONS,
Expand Down Expand Up @@ -176,7 +181,10 @@ export async function handleEthereumRpcMethod(
}
return false;
}
if (Object.values(ETH_RPC_ETHERSCAN_PROXY_METHODS).includes(method)) {
if (
method !== ETH_RPC_WALLET_EVENTS.chainChanged
&& Object.values(ETH_RPC_ETHERSCAN_PROXY_METHODS).includes(method)
) {
const apiUrl = ethActiveNetworkPredefinedSettings.value.middlewareUrl;
const result = await new EtherscanService(apiUrl)
.fetchFromApi({
Expand Down
6 changes: 4 additions & 2 deletions src/protocols/ethereum/types.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import type { Dictionary, INetworkProtocolSettings, ObjectValues } from '@/types';
import { ETH_RPC_ETHERSCAN_PROXY_METHODS, ETH_RPC_METHODS } from '@/protocols/ethereum/config';
import { ETH_RPC_ETHERSCAN_PROXY_METHODS, ETH_RPC_METHODS, ETH_RPC_WALLET_EVENTS } from '@/protocols/ethereum/config';

/**
* Settings specific to this protocol.
Expand Down Expand Up @@ -34,8 +34,10 @@ export interface IEthRpcMethodParameters {
tag?: string;
value?: string;
chainId?: string;
result?: string;
}

export type EthRpcMethod = ObjectValues<typeof ETH_RPC_METHODS>;
export type EthRpcEtherscanProxyMethod = ObjectValues<typeof ETH_RPC_ETHERSCAN_PROXY_METHODS>;
export type EthRpcSupportedMethods = EthRpcMethod | EthRpcEtherscanProxyMethod;
export type ETHRpcWalletEvents = ObjectValues<typeof ETH_RPC_WALLET_EVENTS>;
export type EthRpcSupportedMethods = EthRpcMethod | EthRpcEtherscanProxyMethod | ETHRpcWalletEvents;

0 comments on commit 4e3b4a2

Please sign in to comment.