Skip to content

Commit

Permalink
wip(suite-desktop): expose trezor connect api over websocket
Browse files Browse the repository at this point in the history
  • Loading branch information
mroz22 committed Oct 28, 2024
1 parent 9027cf1 commit 1baefa1
Show file tree
Hide file tree
Showing 3 changed files with 88 additions and 2 deletions.
19 changes: 19 additions & 0 deletions packages/suite-desktop-core/src/app.ts
Original file line number Diff line number Diff line change
Expand Up @@ -195,6 +195,25 @@ const initUi = async ({
mainThreadEmitter,
});

mainThreadEmitter.on('focus-window', () => {
let mainWindow = mainWindowProxy.getInstance();
if (!mainWindow || mainWindow.isDestroyed()) {
logger.info('main', 'Main window destroyed, recreating');
mainWindow = createMainWindow(winBounds);
mainWindowProxy.setInstance(mainWindow);
}

app.dock?.show();
if (isMacOs()) app.show();
if (!mainWindow.isVisible()) mainWindow.show();
if (mainWindow.isMinimized()) mainWindow.restore();
mainWindow.focus();
});

mainThreadEmitter.on('blur-window', () => {
app.hide();
});

app.on('second-instance', () => {
// Someone tried to run a second instance, we should focus our window.
logger.info('main', 'Second instance detected, focusing main window');
Expand Down
2 changes: 2 additions & 0 deletions packages/suite-desktop-core/src/modules/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,8 @@ interface MainThreadMessages {
'module/request-interceptor': InterceptedEvent;
'module/reset-tor-circuits': Extract<InterceptedEvent, { type: 'CIRCUIT_MISBEHAVING' }>;
'module/tor-status-update': TorStatus;
'focus-window': void;
'blur-window': void;
}
export const mainThreadEmitter = new TypedEmitter<MainThreadMessages>();
export type MainThreadEmitter = typeof mainThreadEmitter;
Expand Down
69 changes: 67 additions & 2 deletions packages/suite-desktop-core/src/modules/trezor-connect.ts
Original file line number Diff line number Diff line change
@@ -1,13 +1,74 @@
import { ipcMain } from 'electron';
import { WebSocketServer } from 'ws';

import { isDevEnv } from '@suite-common/suite-utils';
import TrezorConnect from '@trezor/connect';
import { createIpcProxyHandler, IpcProxyHandlerOptions } from '@trezor/ipc-proxy';
import { app } from '../typed-electron';

import type { Module } from './index';
import type { Dependencies, Module } from './index';

export const SERVICE_NAME = '@trezor/connect';

export const init: Module = ({ store }) => {
const exposeConnectWsFlag = app.commandLine.hasSwitch('expose-connect-ws');

const exposeConnectWs = ({
mainThreadEmitter,
}: {
mainThreadEmitter: Dependencies['mainThreadEmitter'];
}) => {
const { logger } = global;

const wss = new WebSocketServer({
port: 8090,
});

wss.on('listening', () => {
logger.info(`${SERVICE_NAME}-ws`, 'Listening on ws://localhost:8090');
});

wss.on('connection', function connection(ws) {
ws.on('error', err => {
logger.error(`${SERVICE_NAME}-ws`, err.message);
});

ws.on('message', async function message(data) {
let message;
try {
message = JSON.parse(data.toString());
} catch (err) {
message = data.toString();
}
try {
if (message === 'handshake') {
ws.send('handshake');
return;
}
if (typeof message !== 'object' || !message.payload || !message.payload.method) {
logger.error(`${SERVICE_NAME}-ws`, 'invalid message');
return;
}

const { method, ...rest } = message.payload;
// focus renderer window
mainThreadEmitter.emit('focus-window');
// @ts-expect-error
const response = await TrezorConnect[method](rest);
ws.send(JSON.stringify(response));
} finally {
// blur renderer window
mainThreadEmitter.emit('blur-window');
}
});
});

// todo: hmmm am I allowed to use app here directly?
app.on('before-quit', () => {
wss.close();
});
};

export const init: Module = ({ store, mainThreadEmitter }) => {
const { logger } = global;
logger.info(SERVICE_NAME, `Starting service`);

Expand All @@ -28,6 +89,10 @@ export const init: Module = ({ store }) => {
const response = await TrezorConnect[method](...params);
await setProxy(true);

if (exposeConnectWsFlag || isDevEnv) {
exposeConnectWs({ mainThreadEmitter });
}

return response;
}

Expand Down

0 comments on commit 1baefa1

Please sign in to comment.