-
Notifications
You must be signed in to change notification settings - Fork 56
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: james-a-morris <[email protected]>
- Loading branch information
1 parent
e8921d7
commit 74e2db4
Showing
20 changed files
with
5,681 additions
and
8 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
// SPDX-License-Identifier: BUSL-1.1 | ||
|
||
// Arbitrum only supports v0.8.19 | ||
// See https://docs.arbitrum.io/for-devs/concepts/differences-between-arbitrum-ethereum/solidity-support#differences-from-solidity-on-ethereum | ||
pragma solidity ^0.8.19; | ||
|
||
import "./Arbitrum_SpokePool.sol"; | ||
|
||
/** | ||
* @notice AVM specific SpokePool. Uses AVM cross-domain-enabled logic to implement admin only access to functions. | ||
* @custom:security-contact [email protected] | ||
*/ | ||
contract AlephZero_SpokePool is Arbitrum_SpokePool { | ||
/// @custom:oz-upgrades-unsafe-allow constructor | ||
constructor( | ||
address _wrappedNativeTokenAddress, | ||
uint32 _depositQuoteTimeBuffer, | ||
uint32 _fillDeadlineBuffer, | ||
IERC20 _l2Usdc, | ||
ITokenMessenger _cctpTokenMessenger | ||
) | ||
Arbitrum_SpokePool( | ||
_wrappedNativeTokenAddress, | ||
_depositQuoteTimeBuffer, | ||
_fillDeadlineBuffer, | ||
_l2Usdc, | ||
_cctpTokenMessenger | ||
) | ||
{} // solhint-disable-line no-empty-blocks | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,252 @@ | ||
// SPDX-License-Identifier: MIT | ||
pragma solidity ^0.8.0; // Bumped version | ||
|
||
/** | ||
* This contract has been copied from the MD1/Multicall repository. | ||
* @dev https://github.com/mds1/multicall/blob/ebd8b64457454fc10037b3a3ea858f9c08dad4d3/src/Multicall3.sol | ||
* @dev changelog: pragma solidity ^0.8.12 -> pragma solidity ^0.8.0 | ||
**/ | ||
|
||
/// @title Multicall3 | ||
/// @notice Aggregate results from multiple function calls | ||
/// @dev Multicall & Multicall2 backwards-compatible | ||
/// @dev Aggregate methods are marked `payable` to save 24 gas per call | ||
/// @author Michael Elliot <[email protected]> | ||
/// @author Joshua Levine <[email protected]> | ||
/// @author Nick Johnson <[email protected]> | ||
/// @author Andreas Bigger <[email protected]> | ||
/// @author Matt Solomon <[email protected]> | ||
contract Multicall3 { | ||
struct Call { | ||
address target; | ||
bytes callData; | ||
} | ||
|
||
struct Call3 { | ||
address target; | ||
bool allowFailure; | ||
bytes callData; | ||
} | ||
|
||
struct Call3Value { | ||
address target; | ||
bool allowFailure; | ||
uint256 value; | ||
bytes callData; | ||
} | ||
|
||
struct Result { | ||
bool success; | ||
bytes returnData; | ||
} | ||
|
||
/// @notice Backwards-compatible call aggregation with Multicall | ||
/// @param calls An array of Call structs | ||
/// @return blockNumber The block number where the calls were executed | ||
/// @return returnData An array of bytes containing the responses | ||
function aggregate(Call[] calldata calls) public payable returns (uint256 blockNumber, bytes[] memory returnData) { | ||
blockNumber = block.number; | ||
uint256 length = calls.length; | ||
returnData = new bytes[](length); | ||
Call calldata call; | ||
for (uint256 i = 0; i < length; ) { | ||
bool success; | ||
call = calls[i]; | ||
(success, returnData[i]) = call.target.call(call.callData); | ||
require(success, "Multicall3: call failed"); | ||
unchecked { | ||
++i; | ||
} | ||
} | ||
} | ||
|
||
/// @notice Backwards-compatible with Multicall2 | ||
/// @notice Aggregate calls without requiring success | ||
/// @param requireSuccess If true, require all calls to succeed | ||
/// @param calls An array of Call structs | ||
/// @return returnData An array of Result structs | ||
function tryAggregate(bool requireSuccess, Call[] calldata calls) | ||
public | ||
payable | ||
returns (Result[] memory returnData) | ||
{ | ||
uint256 length = calls.length; | ||
returnData = new Result[](length); | ||
Call calldata call; | ||
for (uint256 i = 0; i < length; ) { | ||
Result memory result = returnData[i]; | ||
call = calls[i]; | ||
(result.success, result.returnData) = call.target.call(call.callData); | ||
if (requireSuccess) require(result.success, "Multicall3: call failed"); | ||
unchecked { | ||
++i; | ||
} | ||
} | ||
} | ||
|
||
/// @notice Backwards-compatible with Multicall2 | ||
/// @notice Aggregate calls and allow failures using tryAggregate | ||
/// @param calls An array of Call structs | ||
/// @return blockNumber The block number where the calls were executed | ||
/// @return blockHash The hash of the block where the calls were executed | ||
/// @return returnData An array of Result structs | ||
function tryBlockAndAggregate(bool requireSuccess, Call[] calldata calls) | ||
public | ||
payable | ||
returns ( | ||
uint256 blockNumber, | ||
bytes32 blockHash, | ||
Result[] memory returnData | ||
) | ||
{ | ||
blockNumber = block.number; | ||
blockHash = blockhash(block.number); | ||
returnData = tryAggregate(requireSuccess, calls); | ||
} | ||
|
||
/// @notice Backwards-compatible with Multicall2 | ||
/// @notice Aggregate calls and allow failures using tryAggregate | ||
/// @param calls An array of Call structs | ||
/// @return blockNumber The block number where the calls were executed | ||
/// @return blockHash The hash of the block where the calls were executed | ||
/// @return returnData An array of Result structs | ||
function blockAndAggregate(Call[] calldata calls) | ||
public | ||
payable | ||
returns ( | ||
uint256 blockNumber, | ||
bytes32 blockHash, | ||
Result[] memory returnData | ||
) | ||
{ | ||
(blockNumber, blockHash, returnData) = tryBlockAndAggregate(true, calls); | ||
} | ||
|
||
/// @notice Aggregate calls, ensuring each returns success if required | ||
/// @param calls An array of Call3 structs | ||
/// @return returnData An array of Result structs | ||
function aggregate3(Call3[] calldata calls) public payable returns (Result[] memory returnData) { | ||
uint256 length = calls.length; | ||
returnData = new Result[](length); | ||
Call3 calldata calli; | ||
for (uint256 i = 0; i < length; ) { | ||
Result memory result = returnData[i]; | ||
calli = calls[i]; | ||
(result.success, result.returnData) = calli.target.call(calli.callData); | ||
assembly { | ||
// Revert if the call fails and failure is not allowed | ||
// `allowFailure := calldataload(add(calli, 0x20))` and `success := mload(result)` | ||
if iszero(or(calldataload(add(calli, 0x20)), mload(result))) { | ||
// set "Error(string)" signature: bytes32(bytes4(keccak256("Error(string)"))) | ||
mstore(0x00, 0x08c379a000000000000000000000000000000000000000000000000000000000) | ||
// set data offset | ||
mstore(0x04, 0x0000000000000000000000000000000000000000000000000000000000000020) | ||
// set length of revert string | ||
mstore(0x24, 0x0000000000000000000000000000000000000000000000000000000000000017) | ||
// set revert string: bytes32(abi.encodePacked("Multicall3: call failed")) | ||
mstore(0x44, 0x4d756c746963616c6c333a2063616c6c206661696c6564000000000000000000) | ||
revert(0x00, 0x64) | ||
} | ||
} | ||
unchecked { | ||
++i; | ||
} | ||
} | ||
} | ||
|
||
/// @notice Aggregate calls with a msg value | ||
/// @notice Reverts if msg.value is less than the sum of the call values | ||
/// @param calls An array of Call3Value structs | ||
/// @return returnData An array of Result structs | ||
function aggregate3Value(Call3Value[] calldata calls) public payable returns (Result[] memory returnData) { | ||
uint256 valAccumulator; | ||
uint256 length = calls.length; | ||
returnData = new Result[](length); | ||
Call3Value calldata calli; | ||
for (uint256 i = 0; i < length; ) { | ||
Result memory result = returnData[i]; | ||
calli = calls[i]; | ||
uint256 val = calli.value; | ||
// Humanity will be a Type V Kardashev Civilization before this overflows - andreas | ||
// ~ 10^25 Wei in existence << ~ 10^76 size uint fits in a uint256 | ||
unchecked { | ||
valAccumulator += val; | ||
} | ||
(result.success, result.returnData) = calli.target.call{ value: val }(calli.callData); | ||
assembly { | ||
// Revert if the call fails and failure is not allowed | ||
// `allowFailure := calldataload(add(calli, 0x20))` and `success := mload(result)` | ||
if iszero(or(calldataload(add(calli, 0x20)), mload(result))) { | ||
// set "Error(string)" signature: bytes32(bytes4(keccak256("Error(string)"))) | ||
mstore(0x00, 0x08c379a000000000000000000000000000000000000000000000000000000000) | ||
// set data offset | ||
mstore(0x04, 0x0000000000000000000000000000000000000000000000000000000000000020) | ||
// set length of revert string | ||
mstore(0x24, 0x0000000000000000000000000000000000000000000000000000000000000017) | ||
// set revert string: bytes32(abi.encodePacked("Multicall3: call failed")) | ||
mstore(0x44, 0x4d756c746963616c6c333a2063616c6c206661696c6564000000000000000000) | ||
revert(0x00, 0x84) | ||
} | ||
} | ||
unchecked { | ||
++i; | ||
} | ||
} | ||
// Finally, make sure the msg.value = SUM(call[0...i].value) | ||
require(msg.value == valAccumulator, "Multicall3: value mismatch"); | ||
} | ||
|
||
/// @notice Returns the block hash for the given block number | ||
/// @param blockNumber The block number | ||
function getBlockHash(uint256 blockNumber) public view returns (bytes32 blockHash) { | ||
blockHash = blockhash(blockNumber); | ||
} | ||
|
||
/// @notice Returns the block number | ||
function getBlockNumber() public view returns (uint256 blockNumber) { | ||
blockNumber = block.number; | ||
} | ||
|
||
/// @notice Returns the block coinbase | ||
function getCurrentBlockCoinbase() public view returns (address coinbase) { | ||
coinbase = block.coinbase; | ||
} | ||
|
||
/// @notice Returns the block difficulty | ||
function getCurrentBlockDifficulty() public view returns (uint256 difficulty) { | ||
difficulty = block.difficulty; | ||
} | ||
|
||
/// @notice Returns the block gas limit | ||
function getCurrentBlockGasLimit() public view returns (uint256 gaslimit) { | ||
gaslimit = block.gaslimit; | ||
} | ||
|
||
/// @notice Returns the block timestamp | ||
function getCurrentBlockTimestamp() public view returns (uint256 timestamp) { | ||
timestamp = block.timestamp; | ||
} | ||
|
||
/// @notice Returns the (ETH) balance of a given address | ||
function getEthBalance(address addr) public view returns (uint256 balance) { | ||
balance = addr.balance; | ||
} | ||
|
||
/// @notice Returns the block hash of the last block | ||
function getLastBlockHash() public view returns (bytes32 blockHash) { | ||
unchecked { | ||
blockHash = blockhash(block.number - 1); | ||
} | ||
} | ||
|
||
/// @notice Gets the base fee of the given block | ||
/// @notice Can revert if the BASEFEE opcode is not implemented by the given chain | ||
function getBasefee() public view returns (uint256 basefee) { | ||
basefee = block.basefee; | ||
} | ||
|
||
/// @notice Returns the chain id | ||
function getChainId() public view returns (uint256 chainid) { | ||
chainid = block.chainid; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
import { DeployFunction } from "hardhat-deploy/types"; | ||
import { HardhatRuntimeEnvironment } from "hardhat/types"; | ||
import { deployNewProxy, getSpokePoolDeploymentInfo } from "../utils/utils.hre"; | ||
import { FILL_DEADLINE_BUFFER, L2_ADDRESS_MAP, QUOTE_TIME_BUFFER, WAZERO, ZERO_ADDRESS } from "./consts"; | ||
|
||
const func: DeployFunction = async function (hre: HardhatRuntimeEnvironment) { | ||
const { hubPool, spokeChainId } = await getSpokePoolDeploymentInfo(hre); | ||
|
||
const initArgs = [ | ||
0, | ||
L2_ADDRESS_MAP[spokeChainId].l2GatewayRouter, | ||
// Set hub pool as cross domain admin since it delegatecalls the Adapter logic. | ||
hubPool.address, | ||
hubPool.address, | ||
]; | ||
|
||
const constructorArgs = [ | ||
WAZERO[spokeChainId], | ||
QUOTE_TIME_BUFFER, | ||
FILL_DEADLINE_BUFFER, | ||
ZERO_ADDRESS, | ||
// L2_ADDRESS_MAP[spokeChainId].cctpTokenMessenger, | ||
// For now, we are not using the CCTP bridge and can disable by setting | ||
// the cctpTokenMessenger to the zero address. | ||
ZERO_ADDRESS, | ||
]; | ||
await deployNewProxy("AlephZero_SpokePool", constructorArgs, initArgs); | ||
}; | ||
module.exports = func; | ||
func.tags = ["AlephZeroSpokePool", "alephzero"]; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
import { DeployFunction } from "hardhat-deploy/types"; | ||
import { HardhatRuntimeEnvironment } from "hardhat/types"; | ||
|
||
const func: DeployFunction = async function (hre: HardhatRuntimeEnvironment) { | ||
const { deployer } = await hre.getNamedAccounts(); | ||
|
||
// @note if deploying this contract on a chain like Linea that only supports up to | ||
// solc 0.8.19, the hardhat.config solc version needs to be overridden and this | ||
// contract needs to be recompiled. | ||
await hre.deployments.deploy("Multicall3", { | ||
contract: "Multicall3", | ||
from: deployer, | ||
log: true, | ||
skipIfAlreadyDeployed: true, | ||
args: [], | ||
}); | ||
}; | ||
module.exports = func; | ||
func.tags = ["Multicall3"]; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
41455 |
Oops, something went wrong.