-
Notifications
You must be signed in to change notification settings - Fork 11.9k
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
Extend Governor with parameterized votes #3043
Conversation
contracts/governance/compatibility/GovernorCompatibilityBravo.sol
Outdated
Show resolved
Hide resolved
Thank you @apbendi! I agree that "data" is a bad name, I am thinking what we're adding here are "parameters" for the vote. So I'd go with "params", or if we want to tie it into the "counting" concept it could be "counting parameters". What do you think? Have you tried to implement something like #2929 on top of these changes? It would be good to see if it actually works well for that purpose. What I think is missing is a virtual function |
Thanks for the quick reply @frangio!
This seems reasonable, and certainly an improvement over
I'm actively working on this, yes. Can give you some impressions as I get a little further.
Makes sense. I will add this? Also, any opinion on this. Thanks! |
Please do! We want to make sure it serves the intended purpose. One more thing I wanted to suggest is just adding a single new function with both reason and params, so as not to explode the number of functions. We've also found that memory parameters in external/public functions contribute to bytecode size quite a bit, so adding the one function rather than two will be better in that sense. |
hey @frangio, I believe I've addressed all feedback. I'm thinking I can take this PR out of Draft if that works for you. Would you like me to squash everything back to one commit? Also can you help me understand the codecov CI failure I'm seeing— looks like maybe the code coverage of the diff is not high enough, is that right? |
Sorry @apbendi I was actually waiting to hear back about your experience implementing the fractional votes before moving forward with this. Just want to make sure we're on the right track with this PR. |
Ahh ok, good to know. We have a bit of a chicken/egg problem because I didn't want to go too far with my implementation before knowing the approach would be accepted 😅 I'll try to break us out of this infinite loop by pushing mine forward a bit soon so I have more concrete feedback to give! |
Hello @apbendi, I'm joining the conversation to discuss possible additions to this PR. When a vote is cast there are basically 3 things happening:
Operation 1 is done in the "Votes" modules, usually, be checking the snapshotted balance of a Comp-like token While your PR proposes to pass an additional "params" to the Counting module, I personally believe it should also be passed to the Votes module. I created this commit showing how I would do that, and how I think it could be used for voting with non-snapshotted NFT contracts. What do you think? |
I also think we may want a |
Hi @Amxx 👋 Great idea! I was going to ask for an example of when this data my needed by Votes module, but your ERC721 implementation provided a perfect example :) I see no issue with this approach. How would you like to go about handling the merge dependencies here? Shall I rebase this branch to master and apply just the
I have no issue with this, and believe I may have included originally but removed it based on this comment. Only one follow up question: are there any concerns about contract size constraints? |
You can fast forward your branch to my commit, or just apply it. Whatever works best for you. For the size constraints, it could become an issue ... but I'd argue that as long as the mock can be deployed, that is good. In the worst case, we should probably cut revert strings before we remove features. |
Cool, so do we want to include the ERC721 voting implementation in this PR?
Fair enough, I guess one consideration I was thinking about is how much space implementers of custom extensions might need. |
@frangio what do you think? |
No I wouldn't include that yet. We should have a small mock for testing the params though. |
Thank you a lot @apbendi IMO yes, we should re add |
When we get to it, we'll have to add a breaking change notice (internal module interface + override change) |
Hey @frangio and @Amxx, I've created a Mock and used it to test usage of the Governance extension parameters. I've also implemented A couple of additional questions:
|
Ohh the event. That's annoying. Adding params to For the changelog just a description in Unreleased, yes. Mock and tests look good. |
Another idea to avoid having to merge data from two separate events: emit the current I think this is better. It drops compatibility with GovernorBravo events but that doesn't make any sense when you introduce params because the vote can't be interpreted unless you know them. |
Can you add a mention of This is looking good to me. I'd like @Amxx to give this a review as well, but I don't really have further comments. I will want to get some external feedback before releasing this but I'm ready to merge it after these last few comments are resolved. |
… breaking changes
hey @frangio and @Amxx, thanks again for your patience. I'm back from ETHDenver, recovered from Covid, and finally had a chance to address your latest comments. I believe everything has been resolved. Please let me know if anything else is needed before this can be merged. Can't say it enough: really appreciate your feedback through this process! |
hey @frangio friendly bump on this PR :) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM. Thank you for the patience and working with us!
This PR lays the groundwork for a future implementation of #2929, along with other potentially useful Governance extensions, by making the
_castVote
interface more flexible. In particular, this PR follows @frangio's suggestion and adds adata
parameter to the internal, virtual_castVote
method signature, along with associatedcountVote
methods.The idea is this
data
field can be used to encode arbitrary data about the vote in question, enabling many interesting voting mechanisms via Governor extension. It can be coupled with a reporting of which kind of standardized voting mechanisms are supported in theCOUNTING_MODE
function.I'm opening this PR as draft for two reasons:
data
as a parameter name andWithData
for method extensions seems very generic. I think we can do better but I don't have any great ideas. One possibility would becountingContext
,countingData
, or something like this. Any ideas?PR Checklist