Skip to content

Commit

Permalink
Merge branch 'new-tx-template-example' of github.com:OneKeyHQ/app-mon…
Browse files Browse the repository at this point in the history
…orepo into new-tx-template-example
  • Loading branch information
franco-chan committed Dec 25, 2024
2 parents 601f771 + f8426d3 commit 87b849c
Show file tree
Hide file tree
Showing 5 changed files with 49 additions and 13 deletions.
13 changes: 13 additions & 0 deletions packages/kit-bg/src/services/ServiceSend.ts
Original file line number Diff line number Diff line change
Expand Up @@ -158,6 +158,19 @@ class ServiceSend extends ServiceBase {
...params,
customRpcInfo,
});

try {
const verified = await vault.verifyTxId({
txid: result.txid,
signedTx: result,
});
if (!verified) {
throw new Error('Invalid txid');
}
} catch (error) {
throw new Error('Invalid txid');
}

txid = result.txid;
}

Expand Down
7 changes: 7 additions & 0 deletions packages/kit-bg/src/vaults/base/VaultBase.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1419,4 +1419,11 @@ export abstract class VaultBase extends VaultBaseChainOnly {
): Promise<IEncodedTx> {
throw new NotImplemented();
}

async verifyTxId(params: {
txid: string;
signedTx: ISignedTxPro;
}): Promise<boolean> {
return Promise.resolve(true);
}
}
16 changes: 16 additions & 0 deletions packages/kit-bg/src/vaults/impls/evm/Vault.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1232,13 +1232,29 @@ export default class Vault extends VaultBase {
}
const client = new ClientEvm(rpcUrl);
const txid = await client.broadcastTransaction(signedTx.rawTx);

return {
...signedTx,
txid,
encodedTx: signedTx.encodedTx,
};
}

override async verifyTxId(params: {
txid: string;
signedTx: ISignedTxPro;
}): Promise<boolean> {
const { signedTx, txid } = params;

if (typeof txid !== 'string') {
return false;
}

const recoveredTxid = ethers.utils.keccak256(signedTx.rawTx);

return recoveredTxid.toLowerCase() === txid.toLowerCase();
}

// RPC Client
async getRpcClient() {
const rpcInfo =
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -70,26 +70,22 @@ function SendConfirmFromSwap() {
const isLastTx = i === len - 1;

const result: ISendTxOnSuccessData[] = await new Promise((resolve) => {
navigationToNext.current = true;
appNavigation.push(EModalSendRoutes.SendConfirm, {
...route.params,
popStack: false,
unsignedTxs: [unsignedTx],
onSuccess: (data: ISendTxOnSuccessData[]) => {
navigationToNext.current = false;
if (isLastTx) {
appNavigation.pop();
onSuccess?.(data);
}
resolve(data);
},
onFail: (error: Error) => {
navigationToNext.current = false;
appNavigation.pop();
onFail?.(error);
},
onCancel: () => {
navigationToNext.current = false;
appNavigation.pop();
onCancel?.();
},
Expand Down Expand Up @@ -127,6 +123,7 @@ function SendConfirmFromSwap() {
networkId,
encodedTxs: encodedTxList,
});
navigationToNext.current = true;
if (multiTxsFeeResult.txFees.length === unsignedTxs.length) {
await handleConfirmMultiTxsOnHwOrExternal(multiTxsFeeResult);
} else {
Expand All @@ -140,8 +137,9 @@ function SendConfirmFromSwap() {
}
}

navigationToNext.current = true;

if (!batchEstimateButSingleConfirm) {
navigationToNext.current = true;
action = StackActions.replace(EModalSendRoutes.SendConfirm, {
...route.params,
// @ts-ignore
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -225,10 +225,10 @@ const SwapSlippageCustomContent = ({
const SwapSettingsDialogContent = () => {
const intl = useIntl();
const { slippageItem } = useSwapSlippagePercentageModeInfo();
const [{ swapEnableRecipientAddress }, setSettings] = useSettingsAtom();
const [{ swapEnableRecipientAddress }, setNoPersistSettings] =
useSettingsAtom();
const [{ swapBatchApproveAndSwap }, setPersistSettings] =
useSettingsPersistAtom();
const [, setNoPersistSettings] = useSettingsAtom();
const rightTrigger = useMemo(
() => (
<SegmentControl
Expand Down Expand Up @@ -308,14 +308,16 @@ const SwapSettingsDialogContent = () => {
})}
value={swapEnableRecipientAddress}
onChange={(v) => {
setSettings((s) => ({
...s,
swapEnableRecipientAddress: v,
}));
if (!v) {
if (v) {
setNoPersistSettings((s) => ({
...s,
swapEnableRecipientAddress: v,
}));
} else {
setNoPersistSettings((s) => ({
...s,
swapToAnotherAccountSwitchOn: false,
swapEnableRecipientAddress: v,
swapToAnotherAccountSwitchOn: v,
}));
}
}}
Expand Down

0 comments on commit 87b849c

Please sign in to comment.