Skip to content

Commit

Permalink
chore(suite): separate popup logic from @suite-common/connect-init
Browse files Browse the repository at this point in the history
  • Loading branch information
martykan committed Dec 16, 2024
1 parent 0b11679 commit 39c0b79
Show file tree
Hide file tree
Showing 13 changed files with 186 additions and 103 deletions.
27 changes: 27 additions & 0 deletions packages/suite-desktop-connect-popup/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
{
"name": "@trezor/suite-desktop-connect-popup",
"version": "1.0.0",
"private": true,
"license": "See LICENSE.md in repo root",
"sideEffects": false,
"main": "src/index",
"scripts": {
"type-check": "yarn g:tsc --build tsconfig.json"
},
"dependencies": {
"@reduxjs/toolkit": "1.9.5",
"@suite-common/redux-utils": "workspace:*",
"@suite-common/suite-types": "workspace:*",
"@suite-common/test-utils": "workspace:*",
"@suite-common/wallet-core": "workspace:*",
"@trezor/connect": "workspace:*",
"@trezor/env-utils": "workspace:^",
"@trezor/suite-desktop-api": "workspace:*",
"@trezor/urls": "workspace:*",
"@trezor/utils": "workspace:*"
},
"devDependencies": {
"redux-mock-store": "^1.5.4",
"redux-thunk": "^2.4.2"
}
}
7 changes: 7 additions & 0 deletions packages/suite-desktop-connect-popup/redux.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
import { AsyncThunkAction } from '@reduxjs/toolkit';

declare module 'redux' {
export interface Dispatch {
<TThunk extends AsyncThunkAction<any, any, any>>(thunk: TThunk): ReturnType<TThunk>;
}
}
99 changes: 99 additions & 0 deletions packages/suite-desktop-connect-popup/src/connectPopupThunks.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,99 @@
import { createThunk } from '@suite-common/redux-utils';
import TrezorConnect, { ERRORS } from '@trezor/connect';
import { createDeferred } from '@trezor/utils';
import { selectDevice } from '@suite-common/wallet-core';
import { desktopApi } from '@trezor/suite-desktop-api';
import { serializeError } from '@trezor/connect/src/constants/errors';

const CONNECT_POPUP_MODULE = '@common/connect-popup';

export const connectPopupCallThunk = createThunk(
`${CONNECT_POPUP_MODULE}/callThunk`,
async (
{
id,
method,
payload,
processName,
origin,
}: {
id: number;
method: string;
payload: any;
processName?: string;
origin?: string;
},
{ dispatch, getState, extra },
) => {
try {
const device = selectDevice(getState());

if (!device) {
console.error('Device not found');

// TODO: wait for device selection and continue
throw ERRORS.TypedError('Device_NotFound');
}

// @ts-expect-error: method is dynamic
const methodInfo = await TrezorConnect[method]({
...payload,
__info: true,
});
if (!methodInfo.success) {
throw methodInfo;
}

const confirmation = createDeferred();
dispatch(extra.actions.lockDevice(true));
dispatch(
extra.actions.openModal({
type: 'connect-popup',
onCancel: () => confirmation.reject(ERRORS.TypedError('Method_Cancel')),
onConfirm: () => confirmation.resolve(),
method: methodInfo.payload.info,
processName,
origin,
}),
);
await confirmation.promise;
dispatch(extra.actions.lockDevice(false));

// @ts-expect-error: method is dynamic
const response = await TrezorConnect[method]({
device: {
path: device.path,
instance: device.instance,
state: device.state,
},
...payload,
});

dispatch(extra.actions.onModalCancel());

desktopApi.connectPopupResponse({
...response,
id,
});
} catch (error) {
console.error('connectPopupCallThunk', error);
desktopApi.connectPopupResponse({
success: false,
payload: serializeError(error),
id,
});
}
},
);

export const connectPopupInitThunk = createThunk(
`${CONNECT_POPUP_MODULE}/initPopupThunk`,
async (_, { dispatch }) => {
if (desktopApi.available && (await desktopApi.connectPopupEnabled())) {
desktopApi.on('connect-popup/call', params => {
dispatch(connectPopupCallThunk(params));
});
desktopApi.connectPopupReady();
}
},
);
1 change: 1 addition & 0 deletions packages/suite-desktop-connect-popup/src/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
export * from './connectPopupThunks';
23 changes: 23 additions & 0 deletions packages/suite-desktop-connect-popup/tsconfig.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
{
"extends": "../../tsconfig.base.json",
"compilerOptions": { "outDir": "libDev" },
"references": [
{
"path": "../../suite-common/redux-utils"
},
{
"path": "../../suite-common/suite-types"
},
{
"path": "../../suite-common/test-utils"
},
{
"path": "../../suite-common/wallet-core"
},
{ "path": "../connect" },
{ "path": "../env-utils" },
{ "path": "../suite-desktop-api" },
{ "path": "../urls" },
{ "path": "../utils" }
]
}
1 change: 1 addition & 0 deletions packages/suite/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,7 @@
"@trezor/suite-analytics": "workspace:*",
"@trezor/suite-data": "workspace:*",
"@trezor/suite-desktop-api": "workspace:*",
"@trezor/suite-desktop-connect-popup": "workspace:*",
"@trezor/suite-storage": "workspace:*",
"@trezor/theme": "workspace:*",
"@trezor/type-utils": "workspace:*",
Expand Down
3 changes: 2 additions & 1 deletion packages/suite/src/actions/suite/initAction.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import {
} from '@suite-common/wallet-core';
import { periodicCheckTokenDefinitionsThunk } from '@suite-common/token-definitions';
import { desktopApi } from '@trezor/suite-desktop-api';
import * as trezorConnectPopupActions from '@trezor/suite-desktop-connect-popup';
import { isDesktop } from '@trezor/env-utils';

import * as routerActions from 'src/actions/suite/routerActions';
Expand Down Expand Up @@ -115,7 +116,7 @@ export const init = () => async (dispatch: Dispatch, getState: GetState) => {

// 14. init connect popup handler
if (isDesktop()) {
dispatch(trezorConnectActions.connectPopupInitThunk());
dispatch(trezorConnectPopupActions.connectPopupInitThunk());
}

// 15. backend connected, suite is ready to use
Expand Down
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import { connectPopupCallThunk } from '@trezor/suite-desktop-connect-popup';
import {
authorizeDeviceThunk,
deviceActions,
Expand All @@ -15,7 +16,6 @@ import { UI } from '@trezor/connect';
import { isDeviceAcquired } from '@suite-common/suite-utils';
import { DiscoveryStatus } from '@suite-common/wallet-constants';
import { createMiddlewareWithExtraDeps } from '@suite-common/redux-utils';
import { connectPopupCallThunk } from '@suite-common/connect-init';

import { SUITE, ROUTER, MODAL } from 'src/actions/suite/constants';
import * as walletSettingsActions from 'src/actions/settings/walletSettingsActions';
Expand Down
3 changes: 3 additions & 0 deletions packages/suite/tsconfig.json
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,9 @@
{ "path": "../suite-analytics" },
{ "path": "../suite-data" },
{ "path": "../suite-desktop-api" },
{
"path": "../suite-desktop-connect-popup"
},
{ "path": "../suite-storage" },
{ "path": "../theme" },
{ "path": "../type-utils" },
Expand Down
1 change: 0 additions & 1 deletion suite-common/connect-init/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@
"@suite-common/wallet-core": "workspace:*",
"@trezor/connect": "workspace:*",
"@trezor/env-utils": "workspace:^",
"@trezor/suite-desktop-api": "workspace:*",
"@trezor/urls": "workspace:*",
"@trezor/utils": "workspace:*"
},
Expand Down
98 changes: 2 additions & 96 deletions suite-common/connect-init/src/connectInitThunks.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,16 +3,13 @@ import TrezorConnect, {
BLOCKCHAIN_EVENT,
DEVICE,
DEVICE_EVENT,
ERRORS,
TRANSPORT_EVENT,
UI_EVENT,
} from '@trezor/connect';
import { DATA_URL } from '@trezor/urls';
import { createDeferred, getSynchronize } from '@trezor/utils';
import { deviceConnectThunks, selectDevice } from '@suite-common/wallet-core';
import { getSynchronize } from '@trezor/utils';
import { deviceConnectThunks } from '@suite-common/wallet-core';
import { isDesktop, isNative } from '@trezor/env-utils';
import { desktopApi } from '@trezor/suite-desktop-api';
import { serializeError } from '@trezor/connect/src/constants/errors';

import { cardanoConnectPatch } from './cardanoConnectPatch';

Expand Down Expand Up @@ -167,94 +164,3 @@ export const connectInitThunk = createThunk(
}
},
);

export const connectPopupCallThunk = createThunk(
`${CONNECT_INIT_MODULE}/callThunk`,
async (
{
id,
method,
payload,
processName,
origin,
}: {
id: number;
method: string;
payload: any;
processName?: string;
origin?: string;
},
{ dispatch, getState, extra },
) => {
try {
const device = selectDevice(getState());

if (!device) {
console.error('Device not found');

// TODO: wait for device selection and continue
throw ERRORS.TypedError('Device_NotFound');
}

// @ts-expect-error: method is dynamic
const methodInfo = await TrezorConnect[method]({
...payload,
__info: true,
});
if (!methodInfo.success) {
throw methodInfo;
}

const confirmation = createDeferred();
dispatch(extra.actions.lockDevice(true));
dispatch(
extra.actions.openModal({
type: 'connect-popup',
onCancel: () => confirmation.reject(ERRORS.TypedError('Method_Cancel')),
onConfirm: () => confirmation.resolve(),
method: methodInfo.payload.info,
processName,
origin,
}),
);
await confirmation.promise;
dispatch(extra.actions.lockDevice(false));

// @ts-expect-error: method is dynamic
const response = await TrezorConnect[method]({
device: {
path: device.path,
instance: device.instance,
state: device.state,
},
...payload,
});

dispatch(extra.actions.onModalCancel());

desktopApi.connectPopupResponse({
...response,
id,
});
} catch (error) {
console.error('connectPopupCallThunk', error);
desktopApi.connectPopupResponse({
success: false,
payload: serializeError(error),
id,
});
}
},
);

export const connectPopupInitThunk = createThunk(
`${CONNECT_INIT_MODULE}/initPopupThunk`,
async (_, { dispatch }) => {
if (desktopApi.available && (await desktopApi.connectPopupEnabled())) {
desktopApi.on('connect-popup/call', params => {
dispatch(connectPopupCallThunk(params));
});
desktopApi.connectPopupReady();
}
},
);
3 changes: 0 additions & 3 deletions suite-common/connect-init/tsconfig.json
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,6 @@
{ "path": "../wallet-core" },
{ "path": "../../packages/connect" },
{ "path": "../../packages/env-utils" },
{
"path": "../../packages/suite-desktop-api"
},
{ "path": "../../packages/urls" },
{ "path": "../../packages/utils" }
]
Expand Down
21 changes: 20 additions & 1 deletion yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -9422,7 +9422,6 @@ __metadata:
"@suite-common/wallet-core": "workspace:*"
"@trezor/connect": "workspace:*"
"@trezor/env-utils": "workspace:^"
"@trezor/suite-desktop-api": "workspace:*"
"@trezor/urls": "workspace:*"
"@trezor/utils": "workspace:*"
redux-mock-store: "npm:^1.5.4"
Expand Down Expand Up @@ -12363,6 +12362,25 @@ __metadata:
languageName: unknown
linkType: soft

"@trezor/suite-desktop-connect-popup@workspace:*, @trezor/suite-desktop-connect-popup@workspace:packages/suite-desktop-connect-popup":
version: 0.0.0-use.local
resolution: "@trezor/suite-desktop-connect-popup@workspace:packages/suite-desktop-connect-popup"
dependencies:
"@reduxjs/toolkit": "npm:1.9.5"
"@suite-common/redux-utils": "workspace:*"
"@suite-common/suite-types": "workspace:*"
"@suite-common/test-utils": "workspace:*"
"@suite-common/wallet-core": "workspace:*"
"@trezor/connect": "workspace:*"
"@trezor/env-utils": "workspace:^"
"@trezor/suite-desktop-api": "workspace:*"
"@trezor/urls": "workspace:*"
"@trezor/utils": "workspace:*"
redux-mock-store: "npm:^1.5.4"
redux-thunk: "npm:^2.4.2"
languageName: unknown
linkType: soft

"@trezor/suite-desktop-core@workspace:packages/suite-desktop-core":
version: 0.0.0-use.local
resolution: "@trezor/suite-desktop-core@workspace:packages/suite-desktop-core"
Expand Down Expand Up @@ -12589,6 +12607,7 @@ __metadata:
"@trezor/suite-analytics": "workspace:*"
"@trezor/suite-data": "workspace:*"
"@trezor/suite-desktop-api": "workspace:*"
"@trezor/suite-desktop-connect-popup": "workspace:*"
"@trezor/suite-storage": "workspace:*"
"@trezor/theme": "workspace:*"
"@trezor/type-utils": "workspace:*"
Expand Down

0 comments on commit 39c0b79

Please sign in to comment.