Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Bump forc to 0.56, rust sdk to 0.60, adapt predicate to new encoding #180

Merged
merged 29 commits into from
May 17, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
3946454
feat: add testnet deploy scripts
DefiCake Apr 27, 2024
f9c839e
feat: update testnet deploy scripts
DefiCake Apr 27, 2024
c265e61
chore: deploy testnet contracts
DefiCake Apr 27, 2024
bf5dd9e
chore: replace current devnet deployment with testnet deployment
DefiCake May 3, 2024
49d5d74
chore: deploy testnet instances
DefiCake May 3, 2024
bcdac29
chore: upgrade FuelMessagePortal for devnet
DefiCake May 7, 2024
fcd2164
chore: upgrade FuelChainState
DefiCake May 7, 2024
d274fe6
feat: use forc 0.56
DefiCake May 8, 2024
8a868b6
feat: add wip, adapt predicate to new sway encoding
DefiCake May 8, 2024
964c884
feat: add wip, predicate script
DefiCake May 9, 2024
1ccba7b
chore: cleanup and document script
DefiCake May 13, 2024
5e3b74d
test: remove base asset check from test
DefiCake May 13, 2024
d171ef7
test: remove asset balance check on sway bridge unit tests
DefiCake May 13, 2024
afd8c4a
chore: upgrade to forc 0.56.1
DefiCake May 13, 2024
e339b0d
chore: upgrade fuel-ts to 0.85
DefiCake May 13, 2024
47f17b6
chore: remove unused code
DefiCake May 13, 2024
bdf9d83
chore: remove unused code
DefiCake May 13, 2024
7f3b727
chore: apply forc fmt
DefiCake May 13, 2024
70e1c34
feat: update predicate root on contracts
DefiCake May 13, 2024
2da18ff
chore: add changeset
DefiCake May 13, 2024
cffc1a9
chore: apply cargo fmt
DefiCake May 13, 2024
5580c4c
Merge branch 'main' into deficake/bump-forc-0.56
DefiCake May 14, 2024
0fcb68f
test: fix predicate in solidity unit tests
DefiCake May 14, 2024
2a8d77e
chore: apply fmt
DefiCake May 14, 2024
90eb4e4
test: update predicate snapshots
DefiCake May 14, 2024
81a8cd8
doc: update script_asm explanation
DefiCake May 16, 2024
caebaf4
Update packages/message-predicates/contract-message-predicate/script_…
DefiCake May 17, 2024
f00dcc6
refactor: use constant at script_asm.rs
DefiCake May 17, 2024
f13adac
docs: fix typo
DefiCake May 17, 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
Next Next commit
feat: add testnet deploy scripts
  • Loading branch information
DefiCake committed May 7, 2024
commit 39464542bfcd2c481f40d0ba90ed201797e95f3f
39 changes: 39 additions & 0 deletions packages/solidity-contracts/deploy/testnet/001.chain_state.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
import type { HardhatRuntimeEnvironment } from 'hardhat/types';
import type { DeployFunction } from 'hardhat-deploy/dist/types';

import { FuelChainState__factory as FuelChainState } from '../../typechain';

const func: DeployFunction = async function (hre: HardhatRuntimeEnvironment) {
const {
ethers,
upgrades: { deployProxy, erc1967 },
deployments: { save, execute },
} = hre;
const [deployer] = await ethers.getSigners();

const contract = await deployProxy(new FuelChainState(deployer), [], {
initializer: 'initialize',
});
await contract.waitForDeployment();
const address = await contract.getAddress();
const implementation = await erc1967.getImplementationAddress(address);

console.log('Deployed FuelChainState at', address);
await save('FuelChainState', {
address,
abi: [...FuelChainState.abi],
implementation,
});

await execute(
'FuelChainState',
{ log: true, from: deployer.address },
'pause'
);

return true;
};

func.tags = ['state', 'chain-state', 'chain_state', 'FuelChainState'];
func.id = 'chain_state';
export default func;
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
import { MaxUint256 } from 'ethers';
import type { HardhatRuntimeEnvironment } from 'hardhat/types';
import type { DeployFunction } from 'hardhat-deploy/dist/types';

import { FuelMessagePortalV3__factory as FuelMessagePortal } from '../../typechain';

const func: DeployFunction = async function (hre: HardhatRuntimeEnvironment) {
const {
ethers,
upgrades: { deployProxy, erc1967 },
deployments: { get, save, execute },
} = hre;
const [deployer] = await ethers.getSigners();

const { address: fuelChainState } = await get('FuelChainState');

const contract = await deployProxy(
new FuelMessagePortal(deployer),
[fuelChainState],
{
initializer: 'initialize',
constructorArgs: [MaxUint256],
}
);
await contract.waitForDeployment();

const address = await contract.getAddress();
const implementation = await erc1967.getImplementationAddress(address);

console.log('Deployed FuelMessagePortal at', address);
await save('FuelMessagePortal', {
address,
abi: [...FuelMessagePortal.abi],
implementation,
});

await execute(
'FuelMessagePortal',
{ log: true, from: deployer.address },
'pause'
);

return true;
};

func.tags = ['portal', 'message_portal', 'FuelMessagePortal'];
func.id = 'fuel_message_portal';
export default func;
40 changes: 40 additions & 0 deletions packages/solidity-contracts/deploy/testnet/003.erc20_gateway_v2.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
import type { HardhatRuntimeEnvironment } from 'hardhat/types';
import type { DeployFunction } from 'hardhat-deploy/dist/types';

import { FuelERC20GatewayV2__factory as FuelERC20GatewayV2 } from '../../typechain';

const func: DeployFunction = async function (hre: HardhatRuntimeEnvironment) {
const {
ethers,
upgrades: { deployProxy, erc1967 },
deployments: { get, save },
} = hre;
const [deployer] = await ethers.getSigners();

const fuelMessagePortal = await get('FuelMessagePortal');

const contract = await deployProxy(
new FuelERC20GatewayV2(deployer),
[fuelMessagePortal.address],
{
initializer: 'initialize',
}
);
await contract.waitForDeployment();

const address = await contract.getAddress();
const implementation = await erc1967.getImplementationAddress(address);

console.log('Deployed FuelERC20GatewayV2 at', address);
await save('FuelERC20GatewayV2', {
address,
abi: [],
implementation,
});

return true;
};

func.tags = ['erc20', 'erc20_gateway', 'FuelERC20GatewayV2'];
func.id = 'fuel_erc20_gateway_v2';
export default func;
22 changes: 22 additions & 0 deletions packages/solidity-contracts/deploy/testnet/004.token.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
import type { HardhatRuntimeEnvironment } from 'hardhat/types';
import type { DeployFunction } from 'hardhat-deploy/dist/types';

/**
* @description Deployed for testing purposes
*/
const func: DeployFunction = async function (hre: HardhatRuntimeEnvironment) {
const {
ethers,
deployments: { deploy },
} = hre;

const [deployer] = await ethers.getSigners();

await deploy('Token', { from: deployer.address, log: true });

return true;
};

func.tags = ['token'];
func.id = 'token';
export default func;
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
import type { HardhatRuntimeEnvironment } from 'hardhat/types';
import type { DeployFunction } from 'hardhat-deploy/dist/types';

import { FuelChainState__factory } from '../../typechain';

const COMMITTER_ADDRESS = '0x6B956CcB32582E0e88136ff895BA77Dc52a68620';

const func: DeployFunction = async function (hre: HardhatRuntimeEnvironment) {
const { ethers, deployments } = hre;
const [deployer] = await ethers.getSigners();

const { address } = await deployments.get('FuelChainState');

const fuelChainState = FuelChainState__factory.connect(address, deployer);
const COMMITTER_ROLE = await fuelChainState.COMMITTER_ROLE();

await fuelChainState
.grantRole(COMMITTER_ROLE, COMMITTER_ADDRESS)
.then((tx) => tx.wait());

console.log('Granted role COMMITTER_ROLE to', COMMITTER_ADDRESS);

return true;
};

func.tags = ['portal', 'message_portal', 'FuelMessagePortal'];
func.id = 'fuel_message_portal';
export default func;
11 changes: 11 additions & 0 deletions packages/solidity-contracts/hardhat.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,17 @@ const config: HardhatUserConfig = {
deploy: ['deploy/devnet'],
chainId: 11155111,
},
testnet: {
url: RPC_URL,
accounts: CONTRACTS_DEPLOYER_KEY
? [CONTRACTS_DEPLOYER_KEY]
: {
mnemonic:
'test test test test test test test test test test test junk',
},
deploy: ['deploy/devnet'],
chainId: 11155111,
},
},
typechain: {
outDir: 'typechain',
Expand Down