Skip to content

Commit

Permalink
Merge branch 'master' into npai/transfer-threshold-removal
Browse files Browse the repository at this point in the history
  • Loading branch information
nicholaspai authored Sep 27, 2023
2 parents 2a488fe + b2dbc25 commit d56c7c2
Show file tree
Hide file tree
Showing 3 changed files with 49 additions and 17 deletions.
6 changes: 4 additions & 2 deletions src/clients/ProfitClient.ts
Original file line number Diff line number Diff line change
Expand Up @@ -45,8 +45,9 @@ export const GAS_TOKEN_BY_CHAIN_ID: { [chainId: number]: string } = {
// Testnets:
5: WETH,
280: WETH,
421613: WETH,
80001: MATIC,
84531: WETH,
421613: WETH,
};
// TODO: Make this dynamic once we support chains with gas tokens that have different decimals.
const GAS_TOKEN_DECIMALS = 18;
Expand All @@ -68,8 +69,9 @@ const QUERY_HANDLERS: {
// Testnets:
5: relayFeeCalculator.EthereumQueries,
280: relayFeeCalculator.zkSyncGoerliQueries,
421613: relayFeeCalculator.ArbitrumQueries,
80001: relayFeeCalculator.PolygonQueries,
84531: relayFeeCalculator.BaseGoerliQueries,
421613: relayFeeCalculator.ArbitrumQueries,
};

const { PriceClient } = priceClient;
Expand Down
9 changes: 8 additions & 1 deletion src/common/Constants.ts
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,7 @@ export const DEFAULT_MIN_DEPOSIT_CONFIRMATIONS = {
// Testnets:
5: 0,
280: 0,
80001: 0,
84531: 0,
421613: 0,
};
Expand All @@ -76,8 +77,9 @@ export const MIN_DEPOSIT_CONFIRMATIONS: { [threshold: number | string]: { [chain
// Testnets:
5: 0,
280: 0,
421613: 0,
80001: 0,
84531: 0,
421613: 0,
},
100: {
1: 16, // Mainnet reorgs are rarely > 4 blocks in depth so this is a very safe buffer
Expand All @@ -90,6 +92,7 @@ export const MIN_DEPOSIT_CONFIRMATIONS: { [threshold: number | string]: { [chain
// Testnets:
5: 0,
280: 0,
80001: 0,
84531: 0,
421613: 0,
},
Expand All @@ -114,6 +117,7 @@ export const CHAIN_MAX_BLOCK_LOOKBACK = {
// Testnets:
5: 10000,
280: 10000,
80001: 10000,
84531: 10000,
421613: 10000,
};
Expand All @@ -129,6 +133,7 @@ export const BUNDLE_END_BLOCK_BUFFERS = {
// Testnets:
5: 0,
280: 0,
80001: 0,
84531: 0,
421613: 0,
};
Expand Down Expand Up @@ -163,6 +168,7 @@ export const MAX_REORG_DISTANCE: { [chainId: number]: number } = {
// Testnets:
5: 0,
280: 0,
80001: 0,
84531: 0,
421613: 0,
};
Expand Down Expand Up @@ -192,6 +198,7 @@ export const multicall3Addresses = {
288: "0xcA11bde05977b3631167028862bE2a173976CA11",
8453: "0xcA11bde05977b3631167028862bE2a173976CA11",
42161: "0xcA11bde05977b3631167028862bE2a173976CA11",
80001: "0xcA11bde05977b3631167028862bE2a173976CA11",
84531: "0xcA11bde05977b3631167028862bE2a173976CA11",
421613: "0xcA11bde05977b3631167028862bE2a173976CA11",
};
Expand Down
51 changes: 37 additions & 14 deletions src/finalizer/index.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import assert from "assert";
import { typeguards, utils as sdkUtils } from "@across-protocol/sdk-v2";
import { groupBy } from "lodash";
import {
Wallet,
Expand Down Expand Up @@ -28,6 +29,8 @@ import {
} from "../common";
import { ChainFinalizer, Withdrawal } from "./types";

const { isError, isEthersError } = typeguards;

config();
let logger: winston.Logger;

Expand Down Expand Up @@ -68,12 +71,9 @@ export async function finalize(
// input byte length.
const multicall2 = getMultisender(hubChainId, hubSigner);
const finalizationsToBatch: {
callData: Multicall2Call[];
withdrawals: Withdrawal[];
} = {
callData: [],
withdrawals: [],
};
callData: Multicall2Call;
withdrawal: Withdrawal;
}[] = [];

// For each chain, delegate to a handler to look up any TokensBridged events and attempt finalization.
for (const chainId of configuredChainIds) {
Expand Down Expand Up @@ -109,18 +109,41 @@ export async function finalize(
);
logger.debug({ at: "finalize", message: `Found ${callData.length} ${network} withdrawals for finalization.` });

finalizationsToBatch.callData.push(...callData);
finalizationsToBatch.withdrawals.push(...withdrawals);
const txns = callData.map((callData, i) => {
return { callData, withdrawal: withdrawals[i] };
});

finalizationsToBatch.push(...txns);
}

if (finalizationsToBatch.callData.length > 0) {
// Ensure each transaction would succeed in isolation.
const finalizations = await sdkUtils.filterAsync(finalizationsToBatch, async (finalization) => {
try {
// Note: We might want to slice these up in the future but I don't forsee us including enough events
// to approach the block gas limit.
const txn = await (await multicall2.aggregate(finalizationsToBatch.callData)).wait();
const { withdrawals = [], proofs = [] } = groupBy(finalizationsToBatch.withdrawals, ({ type }) => {
return type === "withdrawal" ? "withdrawals" : "proofs";
const { target: to, callData: data } = finalization.callData;
await multicall2.provider.estimateGas({ to, data });
return true;
} catch (err) {
const { l2ChainId, type, l1TokenSymbol, amount } = finalization.withdrawal;
const network = getNetworkName(l2ChainId);
logger.info({
at: "finalizer",
message: `Failed to estimate gas for ${network} ${amount} ${l1TokenSymbol} ${type}.`,
reason: isEthersError(err) ? err.reason : isError(err) ? err.message : "unknown error",
});
return false;
}
});

if (finalizations.length > 0) {
try {
// Note: If the sum of finalizations approaches the gas limit, consider slicing them up.
const callData = finalizations.map(({ callData }) => callData);
const txn = await (await multicall2.aggregate(callData)).wait();

const { withdrawals = [], proofs = [] } = groupBy(
finalizations.map(({ withdrawal }) => withdrawal),
({ type }) => (type === "withdrawal" ? "withdrawals" : "proofs")
);
proofs.forEach(({ l2ChainId, amount, l1TokenSymbol: symbol }) => {
const spokeChain = getNetworkName(l2ChainId);
logger.info({
Expand Down

0 comments on commit d56c7c2

Please sign in to comment.