Skip to content

Commit

Permalink
feat: add l1 to l2 bridge
Browse files Browse the repository at this point in the history
  • Loading branch information
jakim929 committed Jan 10, 2025
1 parent 6f8c7ff commit 43974d2
Show file tree
Hide file tree
Showing 35 changed files with 1,742 additions and 503 deletions.
492 changes: 492 additions & 0 deletions packages/cli/src/abi/l1StandardBridgeAbi.ts

Large diffs are not rendered by default.

440 changes: 440 additions & 0 deletions packages/cli/src/abi/multicall3Abi.ts

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion packages/cli/src/actions/deployCreateXCreate2.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import {zodSupportedNetwork} from '@/superchain-registry/fetchChainList';
import {zodSupportedNetwork} from '@/superchain-registry/fetchSuperchainRegistryChainList';
import {zodPrivateKey} from '@/validators/schemas';
import {option} from 'pastel';

Expand Down
2 changes: 1 addition & 1 deletion packages/cli/src/actions/verifyContract.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import {zodSupportedNetwork} from '@/superchain-registry/fetchChainList';
import {zodSupportedNetwork} from '@/superchain-registry/fetchSuperchainRegistryChainList';
import {zodAddress} from '@/validators/schemas';

import {option} from 'pastel';
Expand Down
16 changes: 11 additions & 5 deletions packages/cli/src/bridge-wizard/BridgeWizard.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,12 @@ import {
useBridgeWizardStore,
} from '@/bridge-wizard/bridgeWizardStore';
import {EnterAmount} from '@/bridge-wizard/EnterAmount';
import {EnterRecipient} from '@/bridge-wizard/EnterRecipient';
import {SelectChains} from '@/bridge-wizard/SelectChains';
import {SelectNetwork} from '@/bridge-wizard/SelectNetwork';
import BridgeEntrypoint from '@/commands/bridge';
import {useSaveWizardProgress} from '@/hooks/useSaveWizardProgress';
import {SupportedNetwork} from '@/superchain-registry/fetchSuperchainRegistryChainList';
import {Box, Text} from 'ink';

type StepStatus = 'done' | 'current' | 'upcoming';
Expand Down Expand Up @@ -73,11 +76,13 @@ const WizardProgressForStep = ({stepId}: {stepId: BridgeWizardStepId}) => {
const WizardProgress = () => {
const {steps, wizardState} = useBridgeWizardStore();
if (wizardState.stepId === 'completed') {
return (
<Box>
<Text>Completed</Text>
</Box>
);
const options = {
network: wizardState.network as SupportedNetwork,
chains: wizardState.chains,
amount: wizardState.amount,
recipient: wizardState.recipient,
};
return <BridgeEntrypoint options={options} />;
}
return (
<Box flexDirection="column">
Expand Down Expand Up @@ -109,6 +114,7 @@ export const BridgeWizard = () => {
<WizardProgress />

<Box flexDirection="column">
{stepId === 'enter-recipient' && <EnterRecipient />}
{stepId === 'select-network' && <SelectNetwork />}
{stepId === 'select-chains' && <SelectChains />}
{stepId === 'enter-amount' && <EnterAmount />}
Expand Down
4 changes: 2 additions & 2 deletions packages/cli/src/bridge-wizard/EnterAmount.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -45,10 +45,10 @@ export const EnterAmount = () => {

const {data: balance, isLoading: isLoadingBalance} = useBalance(
wizardState.network,
wizardState.address,
wizardState.recipient,
);

const numChains = wizardState.chainIds.length;
const numChains = wizardState.chains.length;

return (
<Box flexDirection="column" gap={1}>
Expand Down
58 changes: 0 additions & 58 deletions packages/cli/src/bridge-wizard/EnterPrivateKey.tsx

This file was deleted.

47 changes: 47 additions & 0 deletions packages/cli/src/bridge-wizard/EnterRecipient.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
import {Box, Text} from 'ink';
import {TextInput} from '@inkjs/ui';

import {useBridgeWizardStore} from '@/bridge-wizard/bridgeWizardStore';
import {useState} from 'react';
import {isAddress} from 'viem';
import {zodAddress} from '@/validators/schemas';

export const EnterRecipient = () => {
const {submitEnterRecipient} = useBridgeWizardStore();

const [errorMessage, setErrorMessage] = useState<string>('');
const [resetKey, setResetKey] = useState(0);

return (
<Box flexDirection="column">
<Box>
<Text>Enter the recipient address:</Text>
</Box>
<TextInput
key={resetKey}
onSubmit={address => {
if (!isAddress(address)) {
setErrorMessage('Invalid address: must start with 0x');
setResetKey(prev => prev + 1);
return;
}

const result = zodAddress.safeParse(address);

if (!result.success) {
setErrorMessage(result.error.message);
setResetKey(prev => prev + 1);
return;
}

submitEnterRecipient({recipient: result.data});
}}
/>
{errorMessage && (
<Box>
<Text color="red">{errorMessage ? `❌ ${errorMessage}` : ' '}</Text>
</Box>
)}
</Box>
);
};
15 changes: 7 additions & 8 deletions packages/cli/src/bridge-wizard/SelectChains.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import {useBridgeWizardStore} from '@/bridge-wizard/bridgeWizardStore';
import {useChainConfig} from '@/queries/chainConfig';
import {useSuperchainRegistryChainList} from '@/queries/superchainRegistryChainList';
import {MultiSelect, Spinner} from '@inkjs/ui';
import {Box, Text} from 'ink';
import {useState} from 'react';
Expand All @@ -15,7 +15,7 @@ export const SelectChains = () => {
data: chains,
isLoading: isLoadingChains,
error: loadChainsError,
} = useChainConfig();
} = useSuperchainRegistryChainList();

const [errorMessage, setErrorMessage] = useState<string | null>(null);

Expand Down Expand Up @@ -67,16 +67,15 @@ export const SelectChains = () => {
.filter(chain => chain.parent.chain === wizardState.network)
.map(chain => ({
label: `${chain.name} (${chain.chainId})`,
value: chain.chainId.toString(),
value: chain.identifier.split('/')[1]!,
}))}
onSubmit={chainIdStrs => {
if (chainIdStrs.length === 0) {
onSubmit={chainNames => {
if (chainNames.length === 0) {
setErrorMessage('You must select at least one chain');
return;
}
submitSelectChains({
chainIds: chainIdStrs.map(Number),
});

submitSelectChains({chains: chainNames});
}}
/>
{errorMessage && <Text color="red">{errorMessage}</Text>}
Expand Down
2 changes: 1 addition & 1 deletion packages/cli/src/bridge-wizard/SelectNetwork.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import {useBridgeWizardStore} from '@/bridge-wizard/bridgeWizardStore';
import {SupportedNetwork} from '@/utils/superchainRegistry';
import {SupportedNetwork} from '@/superchain-registry/fetchSuperchainRegistryChainList';
import {Select} from '@inkjs/ui';
import {Box, Text} from 'ink';

Expand Down
119 changes: 0 additions & 119 deletions packages/cli/src/bridge-wizard/bridgeWizardSteps.ts

This file was deleted.

27 changes: 13 additions & 14 deletions packages/cli/src/bridge-wizard/bridgeWizardStore.ts
Original file line number Diff line number Diff line change
@@ -1,34 +1,33 @@
import {defineWizard, InferStepId} from '@/wizard-builder/defineWizard';
import {z} from 'zod';
import {formatEther} from 'viem';
import {Address as ZodAddress} from 'abitype/zod';
import {createWizardStore} from '@/wizard-builder/createWizardStore';
import {zodAddress} from '@/validators/schemas';

const bridgeWizard = defineWizard()
.addStep({
id: 'select-network',
id: 'enter-recipient',
schema: z.object({
network: z.string(),
recipient: zodAddress,
}),
title: 'Select Network',
getSummary: state => `${state.network}`,
title: 'Enter Recipient',
getSummary: () => '',
})
.addStep({
id: 'enter-private-key',
id: 'select-network',
schema: z.object({
privateKey: z.string(),
address: ZodAddress,
network: z.string(),
}),
title: 'Enter Private Key',
getSummary: state => `${state.address}`,
title: 'Select Network',
getSummary: state => `${state.network}`,
})
.addStep({
id: 'select-chains',
schema: z.object({
chainIds: z.array(z.number()),
chains: z.array(z.string()),
}),
title: 'Select Chains',
getSummary: state => `${state.chainIds.join(', ')}`,
getSummary: state => `${state.chains.join(', ')}`,
})
.addStep({
id: 'enter-amount',
Expand All @@ -39,9 +38,9 @@ const bridgeWizard = defineWizard()
getSummary: state => {
const perChainAmount = Number(formatEther(state.amount)).toFixed(2);
const totalAmount = Number(
formatEther(state.amount * BigInt(state.chainIds.length)),
formatEther(state.amount * BigInt(state.chains.length)),
).toFixed(2);
return `${perChainAmount} ETH × ${state.chainIds.length} chains = ${totalAmount} ETH total`;
return `${perChainAmount} ETH × ${state.chains.length} chains = ${totalAmount} ETH total`;
},
})
.build();
Expand Down
Loading

0 comments on commit 43974d2

Please sign in to comment.