Skip to content

Commit

Permalink
fix: deploy and setup contracts scripts
Browse files Browse the repository at this point in the history
  • Loading branch information
hopeyen committed Dec 13, 2024
1 parent bde1bf7 commit a43e9b8
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 42 deletions.
72 changes: 37 additions & 35 deletions contracts/script/SetUpEigenDA.s.sol
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,21 @@ import "forge-std/Test.sol";
import "forge-std/Script.sol";
import "forge-std/StdJson.sol";


// Helper function to create single-element arrays
function toArray(address element) pure returns (address[] memory) {
address[] memory arr = new address[](1);
arr[0] = element;
return arr;
}

function toArray(uint256 element) pure returns (uint256[] memory) {
uint256[] memory arr = new uint256[](1);
arr[0] = element;
return arr;
}


// # To load the variables in the .env file
// source .env
// # To deploy and verify our contract
Expand Down Expand Up @@ -113,17 +128,17 @@ contract SetupEigenDA is EigenDADeployer, EigenLayerUtils {
operatorETHAmounts[i] = 5 ether;
}

uint256[] memory clientPrivateKeys = stdJson.readUintArray(config_data, ".clientPrivateKeys");
address[] memory clients = new address[](clientPrivateKeys.length);
for (uint i = 0; i < clients.length; i++) {
clients[i] = vm.addr(clientPrivateKeys[i]);
}
uint256[] memory clientETHAmounts = new uint256[](clients.length);
// 0.5 eth each
for (uint i = 0; i < clientETHAmounts.length; i++) {
clientETHAmounts[i] = 0.5 ether;
}
uint256 clientPrivateKey = 0x0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcded;

// _allocate(
// IERC20(address(0)),
// // Inline array creation for clients
// toArray(vm.addr(clientPrivateKey)),
// // Inline array creation for amounts
// toArray(5 ether)
// );


vm.startBroadcast();

// Allocate eth to stakers, operators, dispserser clients
Expand All @@ -139,12 +154,6 @@ contract SetupEigenDA is EigenDADeployer, EigenLayerUtils {
operatorETHAmounts
);

_allocate(
IERC20(address(0)),
clients,
clientETHAmounts
);

// Allocate tokens to stakers
for (uint8 i = 0; i < numStrategies; i++) {
_allocate(
Expand Down Expand Up @@ -176,35 +185,28 @@ contract SetupEigenDA is EigenDADeployer, EigenLayerUtils {
}



// Register Reservations for client 0 and 1 as the eigenDACommunityMultisig
clientPrivateKeys[0] = 0x0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcded;
IPaymentVault.Reservation memory reservation = IPaymentVault.Reservation({
symbolsPerSecond: 452198,
startTimestamp: uint64(block.timestamp),
endTimestamp: uint64(block.timestamp + 1000000000),
quorumNumbers: hex"0001",
quorumSplits: hex"3232"
});
vm.broadcast(clientPrivateKeys[0]);
address reservedClient = address(uint160(uint256(keccak256(abi.encodePacked(clientPrivateKeys[0])))));
// vm.prank(eigenDACommunityMultisig);
address reservedClient = address(uint160(uint256(keccak256(abi.encodePacked(clientPrivateKey)))));
// vm.prank(msg.sender);
vm.broadcast(msg.sender);
paymentVault.setReservation(reservedClient, reservation);

vm.broadcast(clientPrivateKeys[1]);
address reservedClient1 = address(uint160(uint256(keccak256(abi.encodePacked(clientPrivateKeys[1])))));
// vm.prank(eigenDACommunityMultisig);
paymentVault.setReservation(reservedClient1, reservation);

// Deposit OnDemand for client 0 and 2
vm.broadcast(operatorPrivateKeys[0]);
address ondemandClient = address(uint160(uint256(keccak256(abi.encodePacked(operatorPrivateKeys[0])))));
vm.prank(ondemandClient);
paymentVault.depositOnDemand{value: 0.1 ether}(ondemandClient);
// vm.broadcast(operatorPrivateKeys[2]);
// address ondemandClient2 = address(uint160(uint256(keccak256(abi.encodePacked(operatorPrivateKeys[2])))));
// vm.prank(ondemandClient2);
// PaymentVault.depositOnDemand{value: 1 ether}(ondemandClient2);
// vm.broadcast(clientPrivateKey);
// address reservedClient1 = address(uint160(uint256(keccak256(abi.encodePacked(clientPrivateKey)))));
// paymentVault.setReservation(reservedClient1, reservation);

// // Deposit OnDemand for client 0 and 2
// vm.broadcast(clientPrivateKey);
// address ondemandClient = address(uint160(uint256(keccak256(abi.encodePacked(clientPrivateKey)))));
// // vm.prank(ondemandClient);
// paymentVault.depositOnDemand{value: 0.1 ether}(ondemandClient);

// Deposit stakers into EigenLayer and delegate to operators
for (uint256 i = 0; i < stakerPrivateKeys.length; i++) {
Expand Down
14 changes: 7 additions & 7 deletions inabox/deploy/deploy.go
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ func (env *Config) generateEigenDADeployConfig() EigenDADeployConfig {

operators := make([]string, 0)
stakers := make([]string, 0)
clients := make([]string, 0)
// clients := make([]string, 0)
maxOperatorCount := env.Services.Counts.NumMaxOperatorCount

numStrategies := len(env.Services.Stakes)
Expand Down Expand Up @@ -72,11 +72,11 @@ func (env *Config) generateEigenDADeployConfig() EigenDADeployConfig {
operators = append(operators, env.getKeyString(operatorName))
}

// 4 clients: with both, with reservations, with on-demand payments, without payments
for i := 0; i < 4; i++ {
clientName := fmt.Sprintf("client%d", i)
clients = append(clients, env.getKeyString(clientName))
}
// // 4 clients: with both, with reservations, with on-demand payments, without payments
// for i := 0; i < 4; i++ {
// clientName := fmt.Sprintf("client%d", i)
// clients = append(clients, env.getKeyString(clientName))
// }

config := EigenDADeployConfig{
UseDefaults: true,
Expand All @@ -85,7 +85,7 @@ func (env *Config) generateEigenDADeployConfig() EigenDADeployConfig {
StakerPrivateKeys: stakers,
StakerTokenAmounts: stakes,
OperatorPrivateKeys: operators,
ClientPrivateKeys: clients,
// ClientPrivateKeys: clients,
ConfirmerPrivateKey: env.getKeyString("batcher0"),
}

Expand Down

0 comments on commit a43e9b8

Please sign in to comment.