feat: Foundry, added some more deployments (#558)
* Added some more deployments * Rename WETH9 to WETH9V06 * Set to 0.6.x * fix typo
This commit is contained in:
@@ -14,10 +14,10 @@
|
|||||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
// solhint-disable
|
// solhint-disable
|
||||||
pragma solidity ^0.6;
|
pragma solidity ^0.6.0;
|
||||||
|
|
||||||
|
|
||||||
contract WETH9 {
|
contract WETH9V06 {
|
||||||
string public name = "Wrapped Ether";
|
string public name = "Wrapped Ether";
|
||||||
string public symbol = "WETH";
|
string public symbol = "WETH";
|
||||||
uint8 public decimals = 18;
|
uint8 public decimals = 18;
|
||||||
@@ -30,7 +30,7 @@ contract WETH9 {
|
|||||||
mapping (address => uint) public balanceOf;
|
mapping (address => uint) public balanceOf;
|
||||||
mapping (address => mapping (address => uint)) public allowance;
|
mapping (address => mapping (address => uint)) public allowance;
|
||||||
|
|
||||||
fallback() external payable {
|
receive() external payable {
|
||||||
deposit();
|
deposit();
|
||||||
}
|
}
|
||||||
function deposit() public payable {
|
function deposit() public payable {
|
||||||
@@ -38,7 +38,7 @@
|
|||||||
},
|
},
|
||||||
"config": {
|
"config": {
|
||||||
"publicInterfaceContracts": "DummyERC20Token,ERC20Token,WETH9,ZRXToken,DummyNoReturnERC20Token,DummyMultipleReturnERC20Token",
|
"publicInterfaceContracts": "DummyERC20Token,ERC20Token,WETH9,ZRXToken,DummyNoReturnERC20Token,DummyMultipleReturnERC20Token",
|
||||||
"abis": "./test/generated-artifacts/@(DummyERC20Token|DummyMultipleReturnERC20Token|DummyNoReturnERC20Token|ERC20Token|IERC20Token|IERC20TokenV06|IEtherToken|IEtherTokenV06|LibERC20Token|LibERC20TokenV06|MintableERC20Token|TestLibERC20Token|TestLibERC20TokenTarget|UnlimitedAllowanceERC20Token|UntransferrableDummyERC20Token|WETH9|ZRXToken).json",
|
"abis": "./test/generated-artifacts/@(DummyERC20Token|DummyMultipleReturnERC20Token|DummyNoReturnERC20Token|ERC20Token|IERC20Token|IERC20TokenV06|IEtherToken|IEtherTokenV06|LibERC20Token|LibERC20TokenV06|MintableERC20Token|TestLibERC20Token|TestLibERC20TokenTarget|UnlimitedAllowanceERC20Token|UntransferrableDummyERC20Token|WETH9|WETH9V06|ZRXToken).json",
|
||||||
"abis:comment": "This list is auto-generated by contracts-gen. Don't edit manually."
|
"abis:comment": "This list is auto-generated by contracts-gen. Don't edit manually."
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
|
|||||||
@@ -21,6 +21,7 @@ import * as TestLibERC20TokenTarget from '../test/generated-artifacts/TestLibERC
|
|||||||
import * as UnlimitedAllowanceERC20Token from '../test/generated-artifacts/UnlimitedAllowanceERC20Token.json';
|
import * as UnlimitedAllowanceERC20Token from '../test/generated-artifacts/UnlimitedAllowanceERC20Token.json';
|
||||||
import * as UntransferrableDummyERC20Token from '../test/generated-artifacts/UntransferrableDummyERC20Token.json';
|
import * as UntransferrableDummyERC20Token from '../test/generated-artifacts/UntransferrableDummyERC20Token.json';
|
||||||
import * as WETH9 from '../test/generated-artifacts/WETH9.json';
|
import * as WETH9 from '../test/generated-artifacts/WETH9.json';
|
||||||
|
import * as WETH9V06 from '../test/generated-artifacts/WETH9V06.json';
|
||||||
import * as ZRXToken from '../test/generated-artifacts/ZRXToken.json';
|
import * as ZRXToken from '../test/generated-artifacts/ZRXToken.json';
|
||||||
export const artifacts = {
|
export const artifacts = {
|
||||||
ERC20Token: ERC20Token as ContractArtifact,
|
ERC20Token: ERC20Token as ContractArtifact,
|
||||||
@@ -34,6 +35,7 @@ export const artifacts = {
|
|||||||
IERC20TokenV06: IERC20TokenV06 as ContractArtifact,
|
IERC20TokenV06: IERC20TokenV06 as ContractArtifact,
|
||||||
IEtherTokenV06: IEtherTokenV06 as ContractArtifact,
|
IEtherTokenV06: IEtherTokenV06 as ContractArtifact,
|
||||||
LibERC20TokenV06: LibERC20TokenV06 as ContractArtifact,
|
LibERC20TokenV06: LibERC20TokenV06 as ContractArtifact,
|
||||||
|
WETH9V06: WETH9V06 as ContractArtifact,
|
||||||
DummyERC20Token: DummyERC20Token as ContractArtifact,
|
DummyERC20Token: DummyERC20Token as ContractArtifact,
|
||||||
DummyMultipleReturnERC20Token: DummyMultipleReturnERC20Token as ContractArtifact,
|
DummyMultipleReturnERC20Token: DummyMultipleReturnERC20Token as ContractArtifact,
|
||||||
DummyNoReturnERC20Token: DummyNoReturnERC20Token as ContractArtifact,
|
DummyNoReturnERC20Token: DummyNoReturnERC20Token as ContractArtifact,
|
||||||
|
|||||||
@@ -19,4 +19,5 @@ export * from '../test/generated-wrappers/test_lib_erc20_token_target';
|
|||||||
export * from '../test/generated-wrappers/unlimited_allowance_erc20_token';
|
export * from '../test/generated-wrappers/unlimited_allowance_erc20_token';
|
||||||
export * from '../test/generated-wrappers/untransferrable_dummy_erc20_token';
|
export * from '../test/generated-wrappers/untransferrable_dummy_erc20_token';
|
||||||
export * from '../test/generated-wrappers/weth9';
|
export * from '../test/generated-wrappers/weth9';
|
||||||
|
export * from '../test/generated-wrappers/weth9v06';
|
||||||
export * from '../test/generated-wrappers/zrx_token';
|
export * from '../test/generated-wrappers/zrx_token';
|
||||||
|
|||||||
@@ -25,6 +25,7 @@
|
|||||||
"test/generated-artifacts/UnlimitedAllowanceERC20Token.json",
|
"test/generated-artifacts/UnlimitedAllowanceERC20Token.json",
|
||||||
"test/generated-artifacts/UntransferrableDummyERC20Token.json",
|
"test/generated-artifacts/UntransferrableDummyERC20Token.json",
|
||||||
"test/generated-artifacts/WETH9.json",
|
"test/generated-artifacts/WETH9.json",
|
||||||
|
"test/generated-artifacts/WETH9V06.json",
|
||||||
"test/generated-artifacts/ZRXToken.json"
|
"test/generated-artifacts/ZRXToken.json"
|
||||||
],
|
],
|
||||||
"exclude": ["./deploy/solc/solc_bin"]
|
"exclude": ["./deploy/solc/solc_bin"]
|
||||||
|
|||||||
@@ -34,27 +34,18 @@ import "src/transformers/bridges/BridgeProtocols.sol";
|
|||||||
import "src/transformers/bridges/EthereumBridgeAdapter.sol";
|
import "src/transformers/bridges/EthereumBridgeAdapter.sol";
|
||||||
import "src/IZeroEx.sol";
|
import "src/IZeroEx.sol";
|
||||||
|
|
||||||
/*
|
|
||||||
This test must be run in forked mode
|
|
||||||
e.g forge test -vvvv -m 'testBasicSwap' -f ETH_RPC_URL
|
|
||||||
It is also helpful to have an Etherscan API key exported
|
|
||||||
export ETHERSCAN_API_KEY=
|
|
||||||
as Foundry will fetch source code and names
|
|
||||||
*/
|
|
||||||
|
|
||||||
contract BasicSwapTest is
|
contract BasicSwapTest is
|
||||||
Test,
|
Test,
|
||||||
ForkUtils,
|
ForkUtils,
|
||||||
TestUtils
|
TestUtils
|
||||||
{
|
{
|
||||||
DeployZeroEx deployer;
|
DeployZeroEx.ZeroExDeployed zeroExDeployed;
|
||||||
|
|
||||||
function setUp()
|
function setUp()
|
||||||
public
|
public
|
||||||
{
|
{
|
||||||
deployer = new DeployZeroEx();
|
zeroExDeployed = new DeployZeroEx().deployZeroEx();
|
||||||
deployer.deployZeroEx();
|
|
||||||
vm.deal(address(this), 1e19);
|
vm.deal(address(this), 1e19);
|
||||||
vm.deal(address(deployer.IZERO_EX().getTransformWallet()), 1e19);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function testTransformERC20()
|
function testTransformERC20()
|
||||||
@@ -64,25 +55,24 @@ contract BasicSwapTest is
|
|||||||
emit log_string(" --Building Up Transformations--");
|
emit log_string(" --Building Up Transformations--");
|
||||||
ITransformERC20Feature.Transformation[] memory transformations = new ITransformERC20Feature.Transformation[](1);
|
ITransformERC20Feature.Transformation[] memory transformations = new ITransformERC20Feature.Transformation[](1);
|
||||||
|
|
||||||
emit log_named_address(" Finding TransformerDeployer nonce @", address(deployer.transformerDeployer()));
|
emit log_named_address(" Finding TransformerDeployer nonce @", address(zeroExDeployed.transformerDeployer));
|
||||||
emit log_named_uint(
|
emit log_named_uint(
|
||||||
" Deployer nonce",
|
" Deployer nonce",
|
||||||
_findTransformerNonce(
|
_findTransformerNonce(
|
||||||
address(deployer.wethTransformer()),
|
address(zeroExDeployed.transformers.wethTransformer),
|
||||||
address(deployer.transformerDeployer())
|
address(zeroExDeployed.transformerDeployer)
|
||||||
));
|
));
|
||||||
transformations[0].deploymentNonce = _findTransformerNonce(address(deployer.wethTransformer()),address(deployer.transformerDeployer()));
|
transformations[0].deploymentNonce = _findTransformerNonce(address(zeroExDeployed.transformers.wethTransformer),address(zeroExDeployed.transformerDeployer));
|
||||||
transformations[0].data = abi.encode(LibERC20Transformer.ETH_TOKEN_ADDRESS, 1e18);
|
transformations[0].data = abi.encode(LibERC20Transformer.ETH_TOKEN_ADDRESS, 1e18);
|
||||||
IZeroEx zrx = deployer.IZERO_EX();
|
|
||||||
|
|
||||||
emit log_string(" ---Calling TransformERC20()---");
|
emit log_string(" ---Calling TransformERC20()---");
|
||||||
uint256 balanceETHBefore = address(this).balance;
|
uint256 balanceETHBefore = address(this).balance;
|
||||||
uint256 balanceWETHBefore = deployer.weth().balanceOf(address(this));
|
uint256 balanceWETHBefore = zeroExDeployed.weth.balanceOf(address(this));
|
||||||
zrx.transformERC20{value: 1e18}(
|
zeroExDeployed.zeroEx.transformERC20{value: 1e18}(
|
||||||
// input token
|
// input token
|
||||||
IERC20TokenV06(LibERC20Transformer.ETH_TOKEN_ADDRESS),
|
IERC20TokenV06(LibERC20Transformer.ETH_TOKEN_ADDRESS),
|
||||||
// output token
|
// output token
|
||||||
IERC20TokenV06(address(deployer.weth())),
|
IERC20TokenV06(address(zeroExDeployed.weth)),
|
||||||
// input token amount
|
// input token amount
|
||||||
1e18,
|
1e18,
|
||||||
// min output token amount
|
// min output token amount
|
||||||
@@ -90,12 +80,12 @@ contract BasicSwapTest is
|
|||||||
// list of transform
|
// list of transform
|
||||||
transformations
|
transformations
|
||||||
);
|
);
|
||||||
assert(deployer.weth().balanceOf(address(this)) == 1e18);
|
assert(zeroExDeployed.weth.balanceOf(address(this)) == 1e18);
|
||||||
emit log_string(" Successful Transformation Complete");
|
emit log_string(" Successful Transformation Complete");
|
||||||
emit log_named_uint(" ETH BALANCE BEFORE:", balanceETHBefore);
|
emit log_named_uint(" ETH BALANCE BEFORE:", balanceETHBefore);
|
||||||
emit log_named_uint(" ETH BALANCE AFTER:", address(this).balance);
|
emit log_named_uint(" ETH BALANCE AFTER:", address(this).balance);
|
||||||
emit log_named_uint(" WETH BALANCE BEFORE:", balanceWETHBefore);
|
emit log_named_uint(" WETH BALANCE BEFORE:", balanceWETHBefore);
|
||||||
emit log_named_uint(" WETH BALANCE AFTER:", deployer.weth().balanceOf(address(this)));
|
emit log_named_uint(" WETH BALANCE AFTER:", zeroExDeployed.weth.balanceOf(address(this)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -32,8 +32,11 @@ import "src/features/BatchFillNativeOrdersFeature.sol";
|
|||||||
import "src/features/FundRecoveryFeature.sol";
|
import "src/features/FundRecoveryFeature.sol";
|
||||||
import "src/features/TransformERC20Feature.sol";
|
import "src/features/TransformERC20Feature.sol";
|
||||||
import "src/features/OtcOrdersFeature.sol";
|
import "src/features/OtcOrdersFeature.sol";
|
||||||
|
import "src/features/MetaTransactionsFeature.sol";
|
||||||
|
import "src/features/nft_orders/ERC1155OrdersFeature.sol";
|
||||||
|
import "src/features/nft_orders/ERC721OrdersFeature.sol";
|
||||||
import "src/features/UniswapFeature.sol";
|
import "src/features/UniswapFeature.sol";
|
||||||
import "src/features/UniswapV3Feature.sol";
|
import "src/features/multiplex/MultiplexFeature.sol";
|
||||||
import "src/external/TransformerDeployer.sol";
|
import "src/external/TransformerDeployer.sol";
|
||||||
import "src/external/FeeCollectorController.sol";
|
import "src/external/FeeCollectorController.sol";
|
||||||
import "src/transformers/WethTransformer.sol";
|
import "src/transformers/WethTransformer.sol";
|
||||||
@@ -41,143 +44,178 @@ import "src/transformers/FillQuoteTransformer.sol";
|
|||||||
import "src/transformers/PayTakerTransformer.sol";
|
import "src/transformers/PayTakerTransformer.sol";
|
||||||
import "src/transformers/AffiliateFeeTransformer.sol";
|
import "src/transformers/AffiliateFeeTransformer.sol";
|
||||||
import "src/transformers/PositiveSlippageFeeTransformer.sol";
|
import "src/transformers/PositiveSlippageFeeTransformer.sol";
|
||||||
import "./WETH_6_5.sol";
|
import "src/transformers/bridges/IBridgeAdapter.sol";
|
||||||
//import "../erc20/contracts/src/v06/IEtherTokenV06.sol";
|
import "src/transformers/bridges/EthereumBridgeAdapter.sol";
|
||||||
|
|
||||||
|
import "@0x/contracts-erc20/contracts/src/v06/IEtherTokenV06.sol";
|
||||||
|
import "@0x/contracts-erc20/contracts/src/v06/WETH9V06.sol";
|
||||||
|
|
||||||
|
|
||||||
contract DeployZeroEx is Test {
|
contract DeployZeroEx is Test {
|
||||||
ZeroEx public ZERO_EX = ZeroEx(0xDef1C0ded9bec7F1a1670819833240f027b25EfF);
|
ZeroEx public ZERO_EX = ZeroEx(0xDef1C0ded9bec7F1a1670819833240f027b25EfF);
|
||||||
IZeroEx public IZERO_EX = IZeroEx(0xDef1C0ded9bec7F1a1670819833240f027b25EfF);
|
IZeroEx public IZERO_EX = IZeroEx(address(ZERO_EX));
|
||||||
|
address VANITY_DEPLOYER_ADDRESS = 0xe750ad66DE350F8110E305fb78Ec6A9f594445E3;
|
||||||
|
bytes deployerBytecode = hex"608060405234801561001057600080fd5b506040516103da3803806103da83398101604081905261002f91610077565b8060405161003c9061006a565b610046919061011f565b604051809103906000f080158015610062573d6000803e3d6000fd5b505050610198565b6101f5806101e583390190565b600060208284031215610088578081fd5b81516001600160401b038082111561009e578283fd5b818401915084601f8301126100b1578283fd5b8151818111156100c3576100c3610182565b604051601f8201601f19908116603f011681019083821181831017156100eb576100eb610182565b81604052828152876020848701011115610103578586fd5b610114836020830160208801610152565b979650505050505050565b600060208252825180602084015261013e816040850160208701610152565b601f01601f19169190910160400192915050565b60005b8381101561016d578181015183820152602001610155565b8381111561017c576000848401525b50505050565b634e487b7160e01b600052604160045260246000fd5b603f806101a66000396000f3fe6080604052600080fdfea26469706673582212201bd8b1a777b100d67435ca4bb0b2fdccb13a2c2dde019b227bb553ff9a95bd4464736f6c63430008020033608060405234801561001057600080fd5b506040516101f53803806101f583398101604081905261002f916100c9565b60008151602083016000f090506001600160a01b0381166100865760405162461bcd60e51b815260206004820152600d60248201526c1111541313d657d19052531151609a1b604482015260640160405180910390fd5b6040516001600160a01b03821681527ff40fcec21964ffb566044d083b4073f29f7f7929110ea19e1b3ebe375d89055e9060200160405180910390a150506101a8565b600060208083850312156100db578182fd5b82516001600160401b03808211156100f1578384fd5b818501915085601f830112610104578384fd5b81518181111561011657610116610192565b604051601f8201601f19908116603f0116810190838211818310171561013e5761013e610192565b816040528281528886848701011115610155578687fd5b8693505b828410156101765784840186015181850187015292850192610159565b8284111561018657868684830101525b98975050505050505050565b634e487b7160e01b600052604160045260246000fd5b603f806101b66000396000f3fe6080604052600080fdfea2646970667358221220fbca036a163ed7f008cefa7c834d98d25109a456a051d41d9c89d55d7185d12b64736f6c63430008020033";
|
||||||
|
|
||||||
address[] transformerSigners = [
|
address[] transformerSigners = [
|
||||||
address(this)
|
address(this)
|
||||||
];
|
];
|
||||||
|
|
||||||
|
bool isDeployed = false;
|
||||||
|
|
||||||
|
struct Features {
|
||||||
WETH9 public weth;
|
NativeOrdersFeature nativeOrdersFeature;
|
||||||
|
BatchFillNativeOrdersFeature batchFillNativeOrdersFeature;
|
||||||
TransformerDeployer public transformerDeployer;
|
OtcOrdersFeature otcOrdersFeature;
|
||||||
FeeCollectorController public feeCollectorController;
|
UniswapFeature uniswapFeature;
|
||||||
WethTransformer public wethTransformer;
|
// UniswapV3Feature
|
||||||
TransformERC20Feature public transformERC20;
|
FundRecoveryFeature fundRecoveryFeature;
|
||||||
NativeOrdersFeature public nativeOrders;
|
TransformERC20Feature transformERC20Feature;
|
||||||
BatchFillNativeOrdersFeature public batchFillNativeOrders;
|
MetaTransactionsFeature metaTransactionsFeature;
|
||||||
OtcOrdersFeature public otcOrders;
|
ERC1155OrdersFeature erc1155OrdersFeature;
|
||||||
UniswapFeature public uniswap;
|
ERC721OrdersFeature erc721OrdersFeature;
|
||||||
FundRecoveryFeature public fundRecovery;
|
MultiplexFeature multiplexFeature;
|
||||||
|
}
|
||||||
//get bytecode of a contract
|
|
||||||
function getCode(address _addr) public view returns (bytes memory o_code) {
|
struct Transformers {
|
||||||
assembly {
|
FillQuoteTransformer fillQuoteTransformer;
|
||||||
// retrieve the size of the code
|
WethTransformer wethTransformer;
|
||||||
let size := extcodesize(_addr)
|
AffiliateFeeTransformer affiliateFeeTransformer;
|
||||||
// allocate output byte array
|
PayTakerTransformer payTakerTransformer;
|
||||||
// by using o_code = new bytes(size)
|
}
|
||||||
o_code := mload(0x40)
|
|
||||||
// new "memory end" including padding
|
struct ZeroExDeployed {
|
||||||
mstore(0x40, add(o_code, and(add(add(size, 0x20), 0x1f), not(0x1f))))
|
IZeroEx zeroEx;
|
||||||
// store length in memory
|
|
||||||
mstore(o_code, size)
|
TransformerDeployer transformerDeployer;
|
||||||
// actually retrieve the code, this needs assembly
|
FeeCollectorController feeCollectorController;
|
||||||
extcodecopy(_addr, add(o_code, 0x20), 0, size)
|
IStaking staking; // address(0)
|
||||||
}
|
// Features
|
||||||
|
Features features;
|
||||||
|
|
||||||
|
// Transformers
|
||||||
|
Transformers transformers;
|
||||||
|
|
||||||
|
IEtherTokenV06 weth;
|
||||||
|
}
|
||||||
|
|
||||||
|
ZeroExDeployed ZERO_EX_DEPLOYED;
|
||||||
|
|
||||||
|
function getDeployedZeroEx()
|
||||||
|
public
|
||||||
|
returns (ZeroExDeployed memory)
|
||||||
|
{
|
||||||
|
if (!isDeployed) {
|
||||||
|
deployZeroEx();
|
||||||
|
}
|
||||||
|
return ZERO_EX_DEPLOYED;
|
||||||
|
}
|
||||||
|
|
||||||
|
function logDeployedZeroEx()
|
||||||
|
public
|
||||||
|
{
|
||||||
|
emit log_string("--- Deployed ZeroEx ---");
|
||||||
|
emit log_named_address("ZeroEx", address(ZERO_EX));
|
||||||
|
emit log_named_address("TransformerDeployer", address(ZERO_EX_DEPLOYED.transformerDeployer));
|
||||||
|
emit log_named_address("FeeCollectorController", address(ZERO_EX_DEPLOYED.feeCollectorController));
|
||||||
|
emit log_named_address("Staking", address(ZERO_EX_DEPLOYED.staking));
|
||||||
|
|
||||||
|
emit log_string("----- Features -----");
|
||||||
|
emit log_named_address("NativeOrdersFeature", address(ZERO_EX_DEPLOYED.features.nativeOrdersFeature));
|
||||||
|
emit log_named_address("BatchFillNativeOrdersFeature", address(ZERO_EX_DEPLOYED.features.batchFillNativeOrdersFeature));
|
||||||
|
emit log_named_address("OtcOrdersFeature", address(ZERO_EX_DEPLOYED.features.otcOrdersFeature));
|
||||||
|
emit log_named_address("UniswapFeature", address(ZERO_EX_DEPLOYED.features.uniswapFeature));
|
||||||
|
emit log_named_address("FundRecoveryFeature", address(ZERO_EX_DEPLOYED.features.fundRecoveryFeature));
|
||||||
|
emit log_named_address("MetaTransactionsFeature", address(ZERO_EX_DEPLOYED.features.metaTransactionsFeature));
|
||||||
|
emit log_named_address("ERC1155OrdersFeature", address(ZERO_EX_DEPLOYED.features.erc1155OrdersFeature));
|
||||||
|
emit log_named_address("ERC721OrdersFeature", address(ZERO_EX_DEPLOYED.features.erc721OrdersFeature));
|
||||||
|
emit log_named_address("TransformERC20Feature", address(ZERO_EX_DEPLOYED.features.transformERC20Feature));
|
||||||
|
emit log_named_address("MultiplexFeature", address(ZERO_EX_DEPLOYED.features.multiplexFeature));
|
||||||
|
|
||||||
|
emit log_string("----- Transformers -----");
|
||||||
|
emit log_named_address("FillQuoteTransformer", address(ZERO_EX_DEPLOYED.transformers.fillQuoteTransformer));
|
||||||
|
emit log_named_address("WethTransformer", address(ZERO_EX_DEPLOYED.transformers.wethTransformer));
|
||||||
|
emit log_named_address("AffiliateFeeTransformer", address(ZERO_EX_DEPLOYED.transformers.affiliateFeeTransformer));
|
||||||
|
emit log_named_address("PayTakerTransformer", address(ZERO_EX_DEPLOYED.transformers.payTakerTransformer));
|
||||||
|
|
||||||
|
emit log_string("----- Other -----");
|
||||||
|
emit log_named_address("WETH", address(ZERO_EX_DEPLOYED.weth));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function deployZeroEx()
|
function deployZeroEx()
|
||||||
public
|
public
|
||||||
|
returns (ZeroExDeployed memory)
|
||||||
{
|
{
|
||||||
emit log_string("-----Deploying ZeroEx (Foundry VM)-----");
|
if (isDeployed) {
|
||||||
emit log_string(" Deploying WETH9....");
|
return ZERO_EX_DEPLOYED;
|
||||||
weth = new WETH9();
|
}
|
||||||
emit log_named_address(" Deployed WETH9 @", address(weth));
|
|
||||||
|
ZERO_EX_DEPLOYED.weth = IEtherTokenV06(address(new WETH9V06()));
|
||||||
|
InitialMigration initialMigration = new InitialMigration(address(this));
|
||||||
|
// Append the required ZeroEx constructor arguments (address bootstrapper)
|
||||||
|
bytes memory zeroExDeploycode = abi.encodePacked(
|
||||||
|
type(ZeroEx).creationCode,
|
||||||
|
abi.encode(initialMigration)
|
||||||
|
);
|
||||||
|
// Append the required deployer code constructor arguments (bytes initCode)
|
||||||
|
bytes memory deployerDeploycode = abi.encodePacked(
|
||||||
|
deployerBytecode,
|
||||||
|
abi.encode(zeroExDeploycode)
|
||||||
|
);
|
||||||
// HERE BE DRAGONS, feel free to ignore this for now
|
// HERE BE DRAGONS, feel free to ignore this for now
|
||||||
// We want to deploy the ZeroEx contract, at 0xDef1C0ded9bec7F1a1670819833240f027b25EfF
|
// We want to deploy the ZeroEx contract, at 0xDef1C0ded9bec7F1a1670819833240f027b25EfF
|
||||||
|
|
||||||
// We use a special mechanism to deploy the ZeroEx contract.
|
// We use a special mechanism to deploy the ZeroEx contract.
|
||||||
|
|
||||||
emit log_string(" Deploying ep/InitialMigration...");
|
|
||||||
InitialMigration initialMigration = InitialMigration(deployCode(
|
|
||||||
"foundry-artifacts/InitialMigration.sol/InitialMigration.json",
|
|
||||||
abi.encode(address(this))
|
|
||||||
));
|
|
||||||
emit log_named_address(" Deployed InitialMigration @", address(initialMigration));
|
|
||||||
// Must occur from this address as the first transaction
|
// Must occur from this address as the first transaction
|
||||||
hoax(0xe750ad66DE350F8110E305fb78Ec6A9f594445E3);
|
|
||||||
// Special Deployer code
|
|
||||||
bytes memory deployerBytecode = hex"608060405234801561001057600080fd5b506040516103da3803806103da83398101604081905261002f91610077565b8060405161003c9061006a565b610046919061011f565b604051809103906000f080158015610062573d6000803e3d6000fd5b505050610198565b6101f5806101e583390190565b600060208284031215610088578081fd5b81516001600160401b038082111561009e578283fd5b818401915084601f8301126100b1578283fd5b8151818111156100c3576100c3610182565b604051601f8201601f19908116603f011681019083821181831017156100eb576100eb610182565b81604052828152876020848701011115610103578586fd5b610114836020830160208801610152565b979650505050505050565b600060208252825180602084015261013e816040850160208701610152565b601f01601f19169190910160400192915050565b60005b8381101561016d578181015183820152602001610155565b8381111561017c576000848401525b50505050565b634e487b7160e01b600052604160045260246000fd5b603f806101a66000396000f3fe6080604052600080fdfea26469706673582212201bd8b1a777b100d67435ca4bb0b2fdccb13a2c2dde019b227bb553ff9a95bd4464736f6c63430008020033608060405234801561001057600080fd5b506040516101f53803806101f583398101604081905261002f916100c9565b60008151602083016000f090506001600160a01b0381166100865760405162461bcd60e51b815260206004820152600d60248201526c1111541313d657d19052531151609a1b604482015260640160405180910390fd5b6040516001600160a01b03821681527ff40fcec21964ffb566044d083b4073f29f7f7929110ea19e1b3ebe375d89055e9060200160405180910390a150506101a8565b600060208083850312156100db578182fd5b82516001600160401b03808211156100f1578384fd5b818501915085601f830112610104578384fd5b81518181111561011657610116610192565b604051601f8201601f19908116603f0116810190838211818310171561013e5761013e610192565b816040528281528886848701011115610155578687fd5b8693505b828410156101765784840186015181850187015292850192610159565b8284111561018657868684830101525b98975050505050505050565b634e487b7160e01b600052604160045260246000fd5b603f806101b66000396000f3fe6080604052600080fdfea2646970667358221220fbca036a163ed7f008cefa7c834d98d25109a456a051d41d9c89d55d7185d12b64736f6c63430008020033";
|
|
||||||
// Grab the bytecode of the ZeroEx artifact
|
|
||||||
bytes memory zeroExBytecode = vm.getCode("foundry-artifacts/ZeroEx.sol/ZeroEx.json");
|
|
||||||
// Append the required ZeroEx constructor arguments (address bootstrapper)
|
|
||||||
bytes memory zeroExDeploycode = abi.encodePacked(zeroExBytecode, abi.encode(initialMigration));
|
|
||||||
// Append the required deployer code constructor arguments (bytes initCode)
|
|
||||||
bytes memory deployerDeploycode = abi.encodePacked(deployerBytecode, abi.encode(zeroExDeploycode));
|
|
||||||
// The address is technically emitted in an event, but we know we did it correctly
|
// The address is technically emitted in an event, but we know we did it correctly
|
||||||
//│ │ ├─ emit topic 0: 0xf40fcec21964ffb566044d083b4073f29f7f7929110ea19e1b3ebe375d89055e
|
//│ │ ├─ emit topic 0: 0xf40fcec21964ffb566044d083b4073f29f7f7929110ea19e1b3ebe375d89055e
|
||||||
//│ │ │ data: 0x000000000000000000000000def1c0ded9bec7f1a1670819833240f027b25eff
|
//│ │ │ data: 0x000000000000000000000000def1c0ded9bec7f1a1670819833240f027b25eff
|
||||||
emit log_string(" Deploying ExchangeProxy....");
|
hoax(VANITY_DEPLOYER_ADDRESS);
|
||||||
assembly {
|
assembly {
|
||||||
pop(create(0, add(deployerDeploycode, 0x20), mload(deployerDeploycode)))
|
pop(create(0, add(deployerDeploycode, 0x20), mload(deployerDeploycode)))
|
||||||
}
|
}
|
||||||
emit log_named_address(" Deployed ExchangeProxy @", address(ZERO_EX));
|
// Staking = address(0);
|
||||||
|
ZERO_EX_DEPLOYED.staking = IStaking(address(0));
|
||||||
emit log_string(" Deploying deployer/TransformerDeployer...");
|
ZERO_EX_DEPLOYED.transformerDeployer = new TransformerDeployer(
|
||||||
transformerDeployer = new TransformerDeployer(
|
|
||||||
transformerSigners
|
transformerSigners
|
||||||
);
|
);
|
||||||
emit log_named_address(" Deployed TransformerDeployer @", address(transformerDeployer));
|
ZERO_EX_DEPLOYED.feeCollectorController = new FeeCollectorController(
|
||||||
|
IEtherTokenV06(ZERO_EX_DEPLOYED.weth),
|
||||||
emit log_string(" Deploying controller/FeeCollectorController...");
|
IStaking(ZERO_EX_DEPLOYED.staking)
|
||||||
feeCollectorController = new FeeCollectorController(
|
|
||||||
IEtherTokenV06(address(weth)),
|
|
||||||
IStaking(0)
|
|
||||||
);
|
);
|
||||||
emit log_named_address(" Deployed FeeCollectorController @", address(feeCollectorController));
|
|
||||||
|
|
||||||
emit log_string(" Deploying Transformers/WethTransformer...");
|
|
||||||
wethTransformer = WethTransformer(transformerDeployer.deploy(
|
|
||||||
abi.encodePacked(
|
|
||||||
// Deploy the WethTransformer code
|
|
||||||
type(WethTransformer).creationCode,
|
|
||||||
// WethTransformer takes WETH address as a constructor argument
|
|
||||||
abi.encode(address(weth))
|
|
||||||
)
|
|
||||||
));
|
|
||||||
emit log_named_address(" Deployed WethTransformer @", address(wethTransformer));
|
|
||||||
|
|
||||||
|
// Features
|
||||||
emit log_string("-----(Deploying Features)-----");
|
ZERO_EX_DEPLOYED.features.transformERC20Feature = new TransformERC20Feature();
|
||||||
|
ZERO_EX_DEPLOYED.features.nativeOrdersFeature = new NativeOrdersFeature(
|
||||||
transformERC20 = new TransformERC20Feature();
|
|
||||||
emit log_named_address(" TransformERC20Feature @", address(transformERC20));
|
|
||||||
nativeOrders = new NativeOrdersFeature(
|
|
||||||
address(ZERO_EX), // EP address
|
address(ZERO_EX), // EP address
|
||||||
IEtherTokenV06(address(weth)), // WETH address
|
ZERO_EX_DEPLOYED.weth,
|
||||||
IStaking(address(0)), // staking address
|
ZERO_EX_DEPLOYED.staking,
|
||||||
feeCollectorController, // feeCollectorController address
|
ZERO_EX_DEPLOYED.feeCollectorController, // feeCollectorController address
|
||||||
uint32(0) // protocolFeeMultiplier
|
uint32(0) // protocolFeeMultiplier
|
||||||
);
|
);
|
||||||
emit log_named_address(" NativeOrdersFeature @", address(nativeOrders));
|
ZERO_EX_DEPLOYED.features.batchFillNativeOrdersFeature = new BatchFillNativeOrdersFeature(
|
||||||
batchFillNativeOrders = new BatchFillNativeOrdersFeature(
|
|
||||||
address(ZERO_EX)
|
address(ZERO_EX)
|
||||||
);
|
);
|
||||||
emit log_named_address(" BatchFillNativeOrdersFeature @", address(batchFillNativeOrders));
|
ZERO_EX_DEPLOYED.features.otcOrdersFeature = new OtcOrdersFeature(
|
||||||
otcOrders = new OtcOrdersFeature(
|
|
||||||
address(ZERO_EX),
|
address(ZERO_EX),
|
||||||
IEtherTokenV06(address(weth))
|
ZERO_EX_DEPLOYED.weth
|
||||||
);
|
);
|
||||||
emit log_named_address(" OtcOrdersFeature @", address(otcOrders));
|
ZERO_EX_DEPLOYED.features.uniswapFeature = new UniswapFeature(ZERO_EX_DEPLOYED.weth);
|
||||||
uniswap = new UniswapFeature(
|
ZERO_EX_DEPLOYED.features.fundRecoveryFeature = new FundRecoveryFeature();
|
||||||
IEtherTokenV06(address(weth))
|
ZERO_EX_DEPLOYED.features.metaTransactionsFeature = new MetaTransactionsFeature(address(ZERO_EX));
|
||||||
|
ZERO_EX_DEPLOYED.features.erc1155OrdersFeature = new ERC1155OrdersFeature(address(ZERO_EX), ZERO_EX_DEPLOYED.weth);
|
||||||
|
ZERO_EX_DEPLOYED.features.erc721OrdersFeature = new ERC721OrdersFeature(address(ZERO_EX), ZERO_EX_DEPLOYED.weth);
|
||||||
|
ZERO_EX_DEPLOYED.features.multiplexFeature = new MultiplexFeature(
|
||||||
|
address(ZERO_EX),
|
||||||
|
ZERO_EX_DEPLOYED.weth,
|
||||||
|
ILiquidityProviderSandbox(address(0)),
|
||||||
|
address(0), // uniswapFactory
|
||||||
|
address(0), // sushiswapFactory
|
||||||
|
bytes32(0), // uniswapPairInitCodeHash
|
||||||
|
bytes32(0) // sushiswapPairInitCodeHash
|
||||||
);
|
);
|
||||||
emit log_named_address(" UniswapFeature @", address(uniswap));
|
|
||||||
fundRecovery = new FundRecoveryFeature();
|
|
||||||
emit log_named_address(" FundRecoveryFeature @", address(fundRecovery));
|
|
||||||
|
|
||||||
emit log_string("-----(Initial Migration)-----");
|
|
||||||
emit log_named_address(" Performing Initial Migration On", address(ZERO_EX));
|
|
||||||
emit log_string(" Initializing ZeroEx...");
|
|
||||||
initialMigration.initializeZeroEx(
|
initialMigration.initializeZeroEx(
|
||||||
payable(address(this)),
|
payable(address(this)),
|
||||||
ZERO_EX,
|
ZERO_EX,
|
||||||
@@ -186,48 +224,99 @@ contract DeployZeroEx is Test {
|
|||||||
ownable: new OwnableFeature()
|
ownable: new OwnableFeature()
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
emit log_string(" Successfully initialized ZeroEx!");
|
IZERO_EX.migrate(
|
||||||
|
address(ZERO_EX_DEPLOYED.features.batchFillNativeOrdersFeature),
|
||||||
|
abi.encodeWithSelector(BatchFillNativeOrdersFeature.migrate.selector),
|
||||||
|
address(this)
|
||||||
|
);
|
||||||
|
IZERO_EX.migrate(
|
||||||
|
address(ZERO_EX_DEPLOYED.features.transformERC20Feature),
|
||||||
|
abi.encodeWithSelector(TransformERC20Feature.migrate.selector, address(ZERO_EX_DEPLOYED.transformerDeployer)),
|
||||||
|
address(this)
|
||||||
|
);
|
||||||
|
IZERO_EX.migrate(
|
||||||
|
address(ZERO_EX_DEPLOYED.features.nativeOrdersFeature),
|
||||||
|
abi.encodeWithSelector(NativeOrdersFeature.migrate.selector),
|
||||||
|
address(this)
|
||||||
|
);
|
||||||
|
IZERO_EX.migrate(
|
||||||
|
address(ZERO_EX_DEPLOYED.features.otcOrdersFeature),
|
||||||
|
abi.encodeWithSelector(OtcOrdersFeature.migrate.selector),
|
||||||
|
address(this)
|
||||||
|
);
|
||||||
|
IZERO_EX.migrate(
|
||||||
|
address(ZERO_EX_DEPLOYED.features.uniswapFeature),
|
||||||
|
abi.encodeWithSelector(UniswapFeature.migrate.selector),
|
||||||
|
address(this)
|
||||||
|
);
|
||||||
|
IZERO_EX.migrate(
|
||||||
|
address(ZERO_EX_DEPLOYED.features.fundRecoveryFeature),
|
||||||
|
abi.encodeWithSelector(FundRecoveryFeature.migrate.selector),
|
||||||
|
address(this)
|
||||||
|
);
|
||||||
|
IZERO_EX.migrate(
|
||||||
|
address(ZERO_EX_DEPLOYED.features.metaTransactionsFeature),
|
||||||
|
abi.encodeWithSelector(MetaTransactionsFeature.migrate.selector),
|
||||||
|
address(this)
|
||||||
|
);
|
||||||
|
IZERO_EX.migrate(
|
||||||
|
address(ZERO_EX_DEPLOYED.features.erc1155OrdersFeature),
|
||||||
|
abi.encodeWithSelector(ERC1155OrdersFeature.migrate.selector),
|
||||||
|
address(this)
|
||||||
|
);
|
||||||
|
IZERO_EX.migrate(
|
||||||
|
address(ZERO_EX_DEPLOYED.features.erc721OrdersFeature),
|
||||||
|
abi.encodeWithSelector(ERC721OrdersFeature.migrate.selector),
|
||||||
|
address(this)
|
||||||
|
);
|
||||||
|
IZERO_EX.migrate(
|
||||||
|
address(ZERO_EX_DEPLOYED.features.multiplexFeature),
|
||||||
|
abi.encodeWithSelector(MultiplexFeature.migrate.selector),
|
||||||
|
address(this)
|
||||||
|
);
|
||||||
|
|
||||||
|
// Transformers
|
||||||
|
ZERO_EX_DEPLOYED.transformers.wethTransformer = WethTransformer(
|
||||||
|
ZERO_EX_DEPLOYED.transformerDeployer.deploy(
|
||||||
|
abi.encodePacked(
|
||||||
|
// Deploy the WethTransformer code
|
||||||
|
type(WethTransformer).creationCode,
|
||||||
|
// WethTransformer takes WETH address as a constructor argument
|
||||||
|
abi.encode(address(ZERO_EX_DEPLOYED.weth))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
// Deploy the FQT, NOTE: No bridge adapter in tests
|
||||||
|
ZERO_EX_DEPLOYED.transformers.fillQuoteTransformer = FillQuoteTransformer(
|
||||||
|
ZERO_EX_DEPLOYED.transformerDeployer.deploy(
|
||||||
|
abi.encodePacked(
|
||||||
|
// Deploy the FQT code
|
||||||
|
type(FillQuoteTransformer).creationCode,
|
||||||
|
// FQT takes a BridgeAdapter and ZeroEx
|
||||||
|
abi.encode(
|
||||||
|
address(0), // Note: No BridgeAdapter in tests
|
||||||
|
INativeOrdersFeature(address(ZERO_EX))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
emit log_named_address(" Migrating Features On", address(ZERO_EX));
|
ZERO_EX_DEPLOYED.transformers.affiliateFeeTransformer = AffiliateFeeTransformer(
|
||||||
IZERO_EX.migrate(
|
ZERO_EX_DEPLOYED.transformerDeployer.deploy(
|
||||||
address(batchFillNativeOrders),
|
type(AffiliateFeeTransformer).creationCode
|
||||||
abi.encodeWithSelector(batchFillNativeOrders.migrate.selector),
|
)
|
||||||
address(this)
|
|
||||||
);
|
);
|
||||||
emit log_string(" BatchFillNativeOrdersFeature migration successful");
|
|
||||||
IZERO_EX.migrate(
|
|
||||||
address(transformERC20),
|
|
||||||
abi.encodeWithSelector(transformERC20.migrate.selector, address(transformerDeployer)),
|
|
||||||
address(this)
|
|
||||||
);
|
|
||||||
emit log_string(" TransformERC20Feature migration successful");
|
|
||||||
IZERO_EX.migrate(
|
|
||||||
address(nativeOrders),
|
|
||||||
abi.encodeWithSelector(nativeOrders.migrate.selector),
|
|
||||||
address(this)
|
|
||||||
);
|
|
||||||
emit log_string(" NativeOrdersFeature migration successful");
|
|
||||||
IZERO_EX.migrate(
|
|
||||||
address(otcOrders),
|
|
||||||
abi.encodeWithSelector(otcOrders.migrate.selector),
|
|
||||||
address(this)
|
|
||||||
);
|
|
||||||
emit log_string(" OtcOrdersFeature migration successful");
|
|
||||||
IZERO_EX.migrate(
|
|
||||||
address(uniswap),
|
|
||||||
abi.encodeWithSelector(uniswap.migrate.selector),
|
|
||||||
address(this)
|
|
||||||
);
|
|
||||||
emit log_string(" UniswapFeature migration successful");
|
|
||||||
IZERO_EX.migrate(
|
|
||||||
address(fundRecovery),
|
|
||||||
abi.encodeWithSelector(fundRecovery.migrate.selector),
|
|
||||||
address(this)
|
|
||||||
);
|
|
||||||
emit log_string(" FundRecoveryFeature migration successful");
|
|
||||||
|
|
||||||
emit log_string(" Deployment and Migration complete!");
|
ZERO_EX_DEPLOYED.transformers.payTakerTransformer = PayTakerTransformer(
|
||||||
|
ZERO_EX_DEPLOYED.transformerDeployer.deploy(
|
||||||
|
type(PayTakerTransformer).creationCode
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
ZERO_EX_DEPLOYED.zeroEx = IZERO_EX;
|
||||||
|
isDeployed = true;
|
||||||
|
logDeployedZeroEx();
|
||||||
|
return ZERO_EX_DEPLOYED;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user