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

feat: introduce zeus templates #790

Merged
merged 58 commits into from
Nov 1, 2024
Merged

feat: introduce zeus templates #790

merged 58 commits into from
Nov 1, 2024

Conversation

nadir-akhtar
Copy link
Contributor

@nadir-akhtar nadir-akhtar commented Oct 2, 2024

zeus-templates

The PR introduces a new dependency, zeus-templates, to improve developing, testing, and reviewing scripts with Zeus.

zeus-templates provides two abstract contracts for building scripts:

  • EOABuilder: An EOA performing a deploy, returning a Deployment object.
  • MultisigBuilder: A multisig performing some direct action (e.g. sending tokens, acting as a role on a contract), returning a Safe MetaTransactionData object.
    • Note that every MultisigBuilder script transforms calls into MultiSendCallOnly calls, meaning any number of calls (not accounting for gas) can be batched into one transaction by a multisig.

Furthermore, script/releases/v0.1-eigenpod-example/ contains an example set of scripts inheriting and implementing functions for each aforementioned abstract contract. These scripts are purely for demonstration.

  • 1-eoa.s.sol: Deploys two contracts, EigenPod and EigenPodManager.
  • 2-multisig.s.sol: Queues up a transaction in the Timelock for execution after a delay.
  • 3-multisig.s.sol: Executes the previously queued transaction in the timelock, as well as renounces ownership from EigenPodManager.

See the READMEs in each directory for more detail.

Note: as part of migrating our scripting / deployment flow to Zeus, many files within the script directory were removed. The ones remain are only there for ensuring that integration and other tests continue to work as expected. As we transition to Zeus, these remaining files are intended to be removed as well.

@nadir-akhtar nadir-akhtar changed the base branch from dev to alex/deploy-refactor October 2, 2024 19:59
Copy link

github-actions bot commented Oct 3, 2024

Reading tracefile ./lcov.info.pruned
                                             |Lines      |Functions|Branches  
Filename                                       |Rate    Num|Rate  Num|Rate   Num
================================================================================
[src/contracts/]
core/AVSDirectory.sol                          |85.2%    27|88.9%   9|    -    0
core/DelegationManager.sol                     |96.5%   198|92.3%  39|    -    0
core/RewardsCoordinator.sol                    |93.0%   128|84.8%  33|    -    0
core/StrategyManager.sol                       |97.6%    83| 100%  24|    -    0
libraries/BeaconChainProofs.sol                | 100%    22| 100%  11|    -    0
libraries/BytesLib.sol                         | 0.0%   156| 0.0%  14|    -    0
libraries/EIP1271SignatureUtils.sol            | 100%     3| 100%   1|    -    0
libraries/Endian.sol                           | 100%     2| 100%   1|    -    0
libraries/Merkle.sol                           | 100%    38| 100%   5|    -    0
libraries/StructuredLinkedList.sol             | 0.0%    45| 0.0%  19|    -    0
permissions/Pausable.sol                       |95.7%    23|90.9%  11|    -    0
permissions/PauserRegistry.sol                 | 100%    12| 100%   6|    -    0
pods/EigenPod.sol                              | 100%   122|96.2%  26|    -    0
pods/EigenPodManager.sol                       | 100%    75|92.9%  14|    -    0
strategies/EigenStrategy.sol                   | 0.0%    10| 0.0%   5|    -    0
strategies/StrategyBase.sol                    |90.9%    44|78.9%  19|    -    0
strategies/StrategyBaseTVLLimits.sol           | 100%    12| 100%   6|    -    0
strategies/StrategyFactory.sol                 | 100%    35| 100%   9|    -    0
token/BackingEigen.sol                         |83.3%    30|69.2%  13|    -    0
token/Eigen.sol                                |45.0%    40|61.5%  13|    -    0
utils/UpgradeableSignatureCheckingUtils.sol    | 0.0%     6| 0.0%   4|    -    0
================================================================================
                                       Total:|75.6%  1111|76.2% 282|    -    0

@nadir-akhtar nadir-akhtar requested a review from wadealexc October 4, 2024 16:26
@nadir-akhtar nadir-akhtar marked this pull request as ready for review October 4, 2024 18:22

vm.stopBroadcast();

return _deployments;
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do we need to return this if it's in a state variable the parent method has access to?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  1. I prefer explicitly returning up values rather than implicitly modifying state variables.
  2. I actually meant to have this not be in the parent contract 😅 and instead have every contract inheriting EOADeployer define their own _deployments array local to their own contract to avoid 1).

Will update this in the templates branch and this PR

Comment on lines 52 to 55
function setUp() public {
(Addresses memory addrs, Environment memory env, Params memory params) = _readConfigFile("script/configs/zipzoop.json");
_deploy(addrs, env, params);
}
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is this for testing purposes? (if so, that's fine - just wondering!)

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yep. Though one big concern with this is that it actually modifies the state variable to call _deploy() twice even when not running the tests specifically -- wondering if it makes more sense to separate out tests into a different file, or to simply not use setUp()


MultisigCall[] internal _executorCalls;

function queue(Addresses memory addrs, Environment memory env, Params memory params) public override returns (MultisigCall[] memory) {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Weird that this method in particular is public rather than the internal pattern the other two scripts use

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ah, i see now why it's public, used in script 3.

eesh, that feels like a weird pattern!

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

2 main reasons:

  1. this is the only time we do this pattern (deploy a script and call it from another script)
  2. deploys/calls like this should be minimized because then you have to be careful how/when you use start/stop broadcast

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

would much rather make this an inheritance relationship somehow

Comment on lines 30 to 48
_multisigCalls.append({
to: addrs.timelock,
value: 0,
data: abi.encodeWithSelector(
ITimelock.executeTransaction.selector,
executorCalldata
)
});

// after queued transaction, renounce ownership from eigenPodManager
_multisigCalls.append({
to: addrs.eigenPodManager.proxy,
value: 0,
data: abi.encodeWithSelector(
EigenPodManager(addrs.eigenPodManager.proxy).renounceOwnership.selector
)
});

return _multisigCalls;
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Kind of a strange mix:

  • when we write the queue script, we don't worry about the ops flow and the fact that we'll be calling queueTransaction is abstracted away
  • when we write the execute, we do worry about the ops flow and explicitly call executeTransaction

This distinction doesn't feel apparent given the structure of the code/templates.

@nadir-akhtar nadir-akhtar changed the base branch from alex/deploy-refactor to dev October 31, 2024 22:11
@wadealexc wadealexc changed the title Nadir/deploy refactor feat: introduce zeus templates Nov 1, 2024
Copy link
Collaborator

@wadealexc wadealexc left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM!

@nadir-akhtar nadir-akhtar merged commit 957eb2d into dev Nov 1, 2024
16 of 18 checks passed
@nadir-akhtar nadir-akhtar deleted the nadir/deploy-refactor branch November 1, 2024 17:49
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants