From 304d66e807bb5bc391661a530ac1818cc94beff0 Mon Sep 17 00:00:00 2001 From: ByteZhang Date: Thu, 31 Oct 2024 15:20:09 +0800 Subject: [PATCH] fix: ton provider (#242) --- packages/core/src/versionInfo.ts | 2 +- .../example/components/chains/ton/example.tsx | 4 + .../src/injectWeb3Provider.ts | 5 +- .../src/OnekeyTonProvider.ts | 99 +++++++++++++------ 4 files changed, 76 insertions(+), 34 deletions(-) diff --git a/packages/core/src/versionInfo.ts b/packages/core/src/versionInfo.ts index 81a88ad6..b6c75267 100644 --- a/packages/core/src/versionInfo.ts +++ b/packages/core/src/versionInfo.ts @@ -1,5 +1,5 @@ -const version = '2.1.10'; +const version = '2.1.11'; const versionBuild = '2020-0101-1'; export default { diff --git a/packages/example/components/chains/ton/example.tsx b/packages/example/components/chains/ton/example.tsx index 68d955b6..fdd79d42 100644 --- a/packages/example/components/chains/ton/example.tsx +++ b/packages/example/components/chains/ton/example.tsx @@ -48,6 +48,10 @@ export function Example() { {userFriendlyAddress &&

userFriendlyAddress: {userFriendlyAddress}

} {rawAddress &&

rawAddress: {rawAddress}

} + {wallet?.account &&

Wallet Account PublicKey: {wallet?.account.publicKey}

} + {wallet?.account &&

Wallet Account Chain: {wallet?.account.chain}

} + {wallet?.account &&

Wallet Account WalletStateInit: {wallet?.account.walletStateInit}

} + {wallet?.device?.appName &&

Wallet AppName: {wallet?.device?.appName}

} {wallet?.device?.appVersion &&

Wallet appVersion: {wallet?.device?.appVersion}

} {wallet?.device?.platform &&

Wallet platform: {wallet?.device?.platform}

} diff --git a/packages/providers/inpage-providers-hub/src/injectWeb3Provider.ts b/packages/providers/inpage-providers-hub/src/injectWeb3Provider.ts index 9d1a1066..c95d094a 100644 --- a/packages/providers/inpage-providers-hub/src/injectWeb3Provider.ts +++ b/packages/providers/inpage-providers-hub/src/injectWeb3Provider.ts @@ -20,7 +20,7 @@ import { import { ProviderSui, registerSuiWallet } from '@onekeyfe/onekey-sui-provider'; import { ProviderWebln } from '@onekeyfe/onekey-webln-provider'; import { ProviderScdo } from '@onekeyfe/onekey-scdo-provider'; -import { ProviderTon } from '@onekeyfe/onekey-ton-provider'; +import { createTonProviderOpenMask, ProviderTon } from '@onekeyfe/onekey-ton-provider'; import { ProviderNostr } from '@onekeyfe/onekey-nostr-provider'; import { ProviderBtc, ProviderBtcWallet } from '@onekeyfe/onekey-btc-provider'; import { ProviderAlgo } from '@onekeyfe/onekey-algo-provider'; @@ -211,7 +211,8 @@ function injectWeb3Provider(): unknown { tonconnect, }); defineWindowProperty('openmask', { - tonconnect, + // eslint-disable-next-line @typescript-eslint/no-unsafe-call + tonconnect: createTonProviderOpenMask(tonconnect), }); defineWindowProperty('unisat', btc); defineWindowProperty('scdo', scdo); diff --git a/packages/providers/onekey-ton-provider/src/OnekeyTonProvider.ts b/packages/providers/onekey-ton-provider/src/OnekeyTonProvider.ts index 52b7dad1..215543f9 100644 --- a/packages/providers/onekey-ton-provider/src/OnekeyTonProvider.ts +++ b/packages/providers/onekey-ton-provider/src/OnekeyTonProvider.ts @@ -14,7 +14,7 @@ import { TonProofItem, WalletEvent, WalletResponse, - WalletResponseSuccess + WalletResponseSuccess, } from '@tonconnect/protocol'; import { AccountInfo, @@ -45,7 +45,7 @@ export type TonRequest = { type JsBridgeRequest = { [K in keyof TonRequest]: ( - params: Parameters + params: Parameters, ) => Promise>>>; }; @@ -74,22 +74,54 @@ function isWalletEventMethodMatch({ method, name }: { method: string; name: stri return method === `wallet_events_${name}`; } +export function createTonProviderOpenMask(originalProvider: ProviderTon) { + return createTonProvider( + originalProvider, + { + appName: 'openmask', + appVersion: '0.21.1', + }, + { + name: 'OpenMask', + image: + 'https://raw.githubusercontent.com/OpenProduct/openmask-extension/main/public/openmask-logo-288.png', + about_url: 'https://www.openmask.app/', + }, + ); +} + +export function createTonProvider( + originalProvider: ProviderTon, + customDeviceInfo: Partial, + customWalletInfo: Partial, +): ProviderTon { + return new Proxy(originalProvider, { + get(target, prop, receiver) { + if (prop === 'deviceInfo') { + return { ...target.deviceInfo, ...customDeviceInfo }; + } + if (prop === 'walletInfo') { + return { ...target.walletInfo, ...customWalletInfo }; + } + // eslint-disable-next-line @typescript-eslint/no-unsafe-return + return Reflect.get(target, prop, receiver); + }, + }); +} + export class ProviderTon extends ProviderTonBase implements IProviderTon { private _accountInfo: AccountInfo | null = null; deviceInfo: DeviceInfo = { platform: this._getPlatform(), - appName: 'OneKey', + appName: 'onekey', appVersion: '0.0.0', maxProtocolVersion: 2, - features: [ - { name: 'SendTransaction', maxMessages: 4 }, - { name: 'SignData' }, - ], + features: [{ name: 'SendTransaction', maxMessages: 4 }, { name: 'SignData' }], }; walletInfo?: WalletInfo = { name: 'OneKey', - image: 'https://uni.onekey-asset.com/static/logo/onekey.png', + image: 'https://common.onekey-asset.com/logo/onekey-x288.png', about_url: 'https://onekey.so', }; protocolVersion = 2; @@ -101,7 +133,7 @@ export class ProviderTon extends ProviderTonBase implements IProviderTon { bridge: props.bridge || getOrCreateExtInjectedJsBridge({ timeout: props.timeout }), }); - void this._getDeviceInfo(); + // void this._getDeviceInfo(); this._registerEvents(); } @@ -209,34 +241,37 @@ export class ProviderTon extends ProviderTonBase implements IProviderTon { private _id = 0; async _connect(protocolVersion?: number, message?: ConnectRequest): Promise { const id = ++this._id; - const isGetTonAddr = !message || (message && message.items.some((item) => item.name === "ton_addr")); - const proofItem = message && message.items.find((item) => item.name === "ton_proof") as (TonProofItem | undefined); + const isGetTonAddr = + !message || (message && message.items.some((item) => item.name === 'ton_addr')); + const proofItem = + message && + (message.items.find((item) => item.name === 'ton_proof') as TonProofItem | undefined); const items = [] as ConnectItemReply[]; if (isGetTonAddr) { if (this._accountInfo) { items.push({ - name: "ton_addr", + name: 'ton_addr', ...this._accountInfo, }); } else { const result = await this._callBridge({ method: 'connect', - params: (protocolVersion && message) ? [protocolVersion, message] : [], + params: protocolVersion && message ? [protocolVersion, message] : [], }); - + if (!result) { return { - event: "connect_error", + event: 'connect_error', id, payload: { code: CONNECT_EVENT_ERROR_CODES.UNKNOWN_ERROR, - message: ConnectEventErrorMessage.UNKNOWN_ERROR - } - } + message: ConnectEventErrorMessage.UNKNOWN_ERROR, + }, + }; } items.push({ - name: "ton_addr", + name: 'ton_addr', ...result, }); this._handleConnected(result, { emit: true }); @@ -246,26 +281,28 @@ export class ProviderTon extends ProviderTonBase implements IProviderTon { if (proofItem) { const result = await this._callBridge({ method: 'signProof', - params: [{ - payload: proofItem.payload, - }], + params: [ + { + payload: proofItem.payload, + }, + ], }); if (!result) { return { - event: "connect_error", + event: 'connect_error', id, payload: { code: CONNECT_EVENT_ERROR_CODES.UNKNOWN_ERROR, - message: ConnectEventErrorMessage.UNKNOWN_ERROR - } - } + message: ConnectEventErrorMessage.UNKNOWN_ERROR, + }, + }; } items.push({ - name: "ton_proof", + name: 'ton_proof', proof: { ...result, payload: proofItem.payload, - } + }, }); } @@ -289,7 +326,7 @@ export class ProviderTon extends ProviderTonBase implements IProviderTon { async send(message: AppRequest): Promise> { const id = message.id; - + let res: unknown; const params = message.params.map((p) => { if (typeof p === 'string') { @@ -311,7 +348,7 @@ export class ProviderTon extends ProviderTonBase implements IProviderTon { code: SEND_TRANSACTION_ERROR_CODES.METHOD_NOT_SUPPORTED, message: SendTransactionErrorMessage.METHOD_NOT_SUPPORTED, }, - } + }; } if (res === undefined) { @@ -321,7 +358,7 @@ export class ProviderTon extends ProviderTonBase implements IProviderTon { code: SEND_TRANSACTION_ERROR_CODES.UNKNOWN_ERROR, message: SendTransactionErrorMessage.UNKNOWN_ERROR, }, - } + }; } return {