Skip to content
Merged
Show file tree
Hide file tree
Changes from 9 commits
Commits
Show all changes
44 commits
Select commit Hold shift + click to select a range
307845a
feat(wip): foundry init, add interface for CrossChainDeployAdapter
stonecharioteer Jan 16, 2024
716c3de
feat(wip): update computeContractAddress fn definition
stonecharioteer Jan 16, 2024
6b217ae
fix(wip): typo with interfaces, don't use {}
stonecharioteer Jan 16, 2024
8e33f39
fix(wip): fix deploy interface definition
stonecharioteer Jan 16, 2024
fd7434c
feat: add CrossChainDeployScript.sol, update the interface with the d…
stonecharioteer Jan 19, 2024
4c2d7a6
chore: rename CrosschainDeployScript file and contract for consistenc…
stonecharioteer Jan 19, 2024
bd519d5
feat(wip): fix function calls and type for callData
stonecharioteer Jan 19, 2024
3636d7a
chore(wip): remove FIXME
stonecharioteer Jan 19, 2024
40f2c07
feat(wip): update justfile with some more planned tools
stonecharioteer Jan 19, 2024
88bc0b1
feat(wip): add `value` to `deploy` call so that it gets the payment.
stonecharioteer Jan 19, 2024
ea929d5
feat(wip): track deployment targets using an array and store the avai…
stonecharioteer Jan 25, 2024
70206c9
feat(wip): cleanup docstrings, fix typos
stonecharioteer Jan 25, 2024
fe7a0da
feat(wip): implement computeAddressForChain
stonecharioteer Jan 25, 2024
06773c5
feat(wip): map constructorArgs and initDatas separately as well
stonecharioteer Jan 25, 2024
367fbb9
feat(wip): use arrays to store a list of constructor args and init da…
stonecharioteer Jan 25, 2024
be4c339
feat(wip): remove unused domain IDs from the constructor
stonecharioteer Jan 25, 2024
60dedd4
chore(wip): remove unnecessary custom error situation
stonecharioteer Jan 29, 2024
444eba6
feat(wip): add generateSalt
stonecharioteer Jan 29, 2024
8b12528
chore(wip): move deployment target check to modifier
stonecharioteer Jan 29, 2024
456569e
fix(wip): use generateSalt instead of asking users to provide the salt
stonecharioteer Jan 29, 2024
fd883f4
fix(wip): increment randomness counter
stonecharioteer Jan 29, 2024
f219167
feat(wip): fix function signature for computeContractAddress, and cal…
stonecharioteer Jan 29, 2024
7df5ba6
chore(wip): purge the deployment targets after deploying
stonecharioteer Jan 29, 2024
b4685f3
fix(wip): rename functions for uniformity, fix array reset syntax to …
stonecharioteer Jan 31, 2024
25a70c2
chore(wip): update justfile to use forge's native `watch` flag
stonecharioteer Jan 31, 2024
4c62035
feat(wip): add unit tests and a mock for adapter
stonecharioteer Jan 31, 2024
1919e87
docs(wip): Update README to show how to use this, and also add some d…
stonecharioteer Jan 31, 2024
3ce7924
feat(wip): add integration test, test steps to justfile
stonecharioteer Jan 31, 2024
b6998f8
feat(wip): add support for .env file for the justfile and use it for …
stonecharioteer Jan 31, 2024
b4b6ca5
chore: update justfile to not use private key for integration tests.
stonecharioteer Jan 31, 2024
f82c1e5
feat(wip): fix argument for constructor and initdata
stonecharioteer Feb 1, 2024
b124e3c
feat(wip): fix argument for constructor and initdata
stonecharioteer Feb 1, 2024
e57869d
feat(wip): Move reset steps into a new function so users can choose t…
stonecharioteer Feb 2, 2024
ed494e0
feat(wip): add `vm.expectCall` to ensure contract calls
stonecharioteer Feb 5, 2024
b926e2c
feat(wip): Add multiple deployment targets & args
stonecharioteer Feb 6, 2024
05912cd
docs(wip): update README to show how to encode arguments
stonecharioteer Feb 6, 2024
5105657
Update README.md
stonecharioteer Feb 7, 2024
63bbcb4
docs(wip): update with installation instructions
stonecharioteer Feb 7, 2024
45ccc31
docs(wip): update with link to forge install docs
stonecharioteer Feb 7, 2024
59eafcf
docs(wip): update the usage example to show how to inherit from this …
stonecharioteer Feb 7, 2024
749ef6a
fix: warnings and stack too deep errors. move contract name to deploy…
mpetrunic Feb 8, 2024
73fdcda
update readme
mpetrunic Feb 8, 2024
2581da3
add env, remove contract address calculation, add link to sygma explorer
mpetrunic Feb 8, 2024
e2ef7f5
more unit tests
mpetrunic Feb 8, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
34 changes: 34 additions & 0 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
name: test

on: workflow_dispatch

env:
FOUNDRY_PROFILE: ci

jobs:
check:
strategy:
fail-fast: true

name: Foundry project
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
submodules: recursive

- name: Install Foundry
uses: foundry-rs/foundry-toolchain@v1
with:
version: nightly

- name: Run Forge build
run: |
forge --version
forge build --sizes
id: build

- name: Run Forge tests
run: |
forge test -vvv
id: test
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -12,3 +12,6 @@ Cargo.lock

# MSVC Windows builds of rustc generate these, which store debugging information
*.pdb

# editor specifics
.vscode/
3 changes: 3 additions & 0 deletions .gitmodules
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
[submodule "lib/forge-std"]
path = lib/forge-std
url = https://github.com/foundry-rs/forge-std
10 changes: 9 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1 +1,9 @@
# foundry-multichain-deploy
# foundry-multichain-deploy

Provides `foundry` tooling for the multichain deployment contract built atop of Sygma. See [ChainSafe/hardhat-plugin-multichain-deploy]("https://github.com/ChainSafe/hardhat-plugin-multichain-deploy") for more details.

## Development

[Install foundry](https://book.getfoundry.sh/getting-started/installation) and [`just`](https://github.com/casey/just).

Check the `justfile` for more instructions on how to run this project. Run `just --list` to see all the options.
6 changes: 6 additions & 0 deletions foundry.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
[profile.default]
src = "src"
out = "out"
libs = ["lib"]

# See more config options https://github.com/foundry-rs/foundry/blob/master/crates/config/README.md#all-options
33 changes: 33 additions & 0 deletions justfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
set shell:=["bash", "-uc"]


# build the contracts
build:
forge build

# format source
fmt:
forge fmt


# watches the directory for changes and rebuilds. Needs `watchexec` - https://github.com/watchexec/watchexec. This is useful when developing contracts.
watch-build:
watchexec just fmt build

deploy-anvil: build
echo "Unimplemented" >&2
exit 1

deploy-sepolia: build
echo "Unimplemented" >&2
exit 1


# Builds locally using docker (useful for debugging dependency issues)
docker-build:
echo "Unimplemented" >&2
exit 1

docker-test: docker-build
echo "Unimplemented" >&2
exit 1
1 change: 1 addition & 0 deletions lib/forge-std
Submodule forge-std added at 36c303
54 changes: 54 additions & 0 deletions src/CrosschainDeployScript.sol
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
// SPDX-License-Identifier: LGPL-3.0-only

pragma solidity 0.8.20;

import {Script} from "forge-std/Script.sol";
import {ICrosschainDeployAdapter} from "./interfaces/CrosschainDeployAdapterInterface.sol";

/**
* @title Provides a script to allow users to call the multichain deployment contract defined in `CrossChainDeployAdapter` from chainsafe/hardhat-plugin-multichain-deploy, passing it the contract bytecode and constructor arguments.
* @author ChainSafe Systems
*/
contract CrosschainDeployScript is Script {
Comment thread
mpetrunic marked this conversation as resolved.
// this is the address of the original contract defined in chainsafe/hardhat-plugin-multichain-deploy
// this address is the same across all chains
address private constant CROSS_CHAIN_DEPLOY_CONTRACT_ADDRESS = 0x85d62AD850B322152BF4ad9147bfBF097DA42217;

/**
* @notice this function takes in the contract string, in the form that
* @notice `forge`'s `getCode` takes it, along with some other parameters and passes
* @notice it along to the `deploy` function of the `CrossChainDeployAdapter`
* @notice contract.
* @param contractString Contract name in the form of `ContractFile.sol`, if the name of the contract and the file are the same, or `ContractFile.sol:ContractName` if they are different.
* @param gasLimit Contract deploy and init gas.
* @param salt Entropy for contract address generation.
* @param isUniquePerChain True to have unique addresses on every chain.
* @param constructorArgs Bytes to add to the deployBytecode, or empty, one per chain.
* @param initDatas Bytes to send to the contract after deployment, or empty, one per chain.
* @param destinationDomainIDs Sygma Domain IDs of target chains.
*
* Users call this function and pass only the function call string as
* `MyContract.sol:MyContract`. The function call string is then parsed
* and the `callData` and `bytesCode` are extracted from it.
* and the contract is deployed on the other chains.
*/
function deployContractOnOtherChains(
Comment thread
mpetrunic marked this conversation as resolved.
Outdated
string calldata contractString,
uint256 gasLimit,
bytes32 salt,
bool isUniquePerChain,
bytes[] memory constructorArgs,
bytes[] memory initDatas,
uint8[] memory destinationDomainIDs
) public payable {
// We use the contractString to get the bytecode of the contract,
// reference: https://book.getfoundry.sh/cheatcodes/get-code
bytes memory deployByteCode = vm.getCode(contractString);
uint256[] memory fees = ICrosschainDeployAdapter(CROSS_CHAIN_DEPLOY_CONTRACT_ADDRESS).calculateDeployFee(
deployByteCode, gasLimit, salt, isUniquePerChain, constructorArgs, initDatas, destinationDomainIDs
);
ICrosschainDeployAdapter(CROSS_CHAIN_DEPLOY_CONTRACT_ADDRESS).deploy(
deployByteCode, gasLimit, salt, isUniquePerChain, constructorArgs, initDatas, destinationDomainIDs, fees
);
}
}
36 changes: 36 additions & 0 deletions src/interfaces/CrosschainDeployAdapterInterface.sol
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
// SPDX-License-Identifier: LGPL-3.0-only

pragma solidity 0.8.20;

/**
* @title Provides an interface to the CrosschainDeployAdapter from chainsafe/hardhat-plugin-multichain-deploy
* @author ChainSafe Systems.
* @notice The original contract in question is intended to be used with the Bridge contract and Permissionless Generic Handler
*/
interface ICrosschainDeployAdapter {
function deploy(
bytes calldata deployBytecode,
uint256 gasLimit,
bytes32 salt,
bool isUniquePerChain,
bytes[] memory constructorArgs,
bytes[] memory initDatas,
uint8[] memory destinationDomainIDs,
uint256[] memory fees
) external payable;

function computeContractAddressForChain(address sender, bytes32 salt, bool isUniquePerChain)
external
view
returns (address);

function calculateDeployFee(
bytes calldata deployBytecode,
uint256 gasLimit,
bytes32 salt,
bool isUniquePerChain,
bytes[] memory constructorArgs,
bytes[] memory initDatas,
uint8[] memory destinationDomainIds
) external view returns (uint256[] memory fees);
}