-
Notifications
You must be signed in to change notification settings - Fork 1.3k
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
Implementation ideas for IBFT2 block validation support #1430
Comments
It's certainly feasible the concerns I have are around long term maintainability. The more things we add the harder it is to keep up to date with upstream. I personally think that long term migrating/re-genesis-ing networks to be qbft only is more sustainable. That said if we're going to add support for ibft2 we would need a bunch of tests added into https://github.com/ConsenSys/quorum-acceptance-tests to ensure that we don't break it going forward. |
@antonydenyer I agree re-genesising networks to be qbft would be easier solution, however I think it will not work for some cases, where the private key of a validator in the past is not known anymore (e.g. when this validator does not participate in the chain anymore or private key was lost, etc.). Such chains will not have possibility to migrate to qbft and will be stuck with ibft2. What do you think about that? I very much agree that such a case if implemented must have tests written, I have no experience with Gauge yet, but I could start with pull request and implementation first and as a next point try to create some tests for that, maybe with somebody's assistance. I would appreciate if I could get an answer for my question about submitting chain params to |
(From a colleague) The main changes were in how to represent empty data and numbers. You can compare the extra data encoding by looking at https://github.com/hyperledger/besu/blob/main/consensus/ibft/src/main/java/org/hyperledger/besu/consensus/ibft/IbftExtraDataCodec.java |
@antonydenyer Thank you for reply. That's exactly what I've checked and created afterwards a list of differences in the first message :) The main issue I faced was how to pass chain params with potentially new |
hello, can you review and sign the cla? |
QBFT algorithm seems the preferred one to be used among IBFT, IBFT2 and QBFT on both Besu and GoQuorum clients. However there are no plans to add support for IBFT2 in GoQuorum as mentioned in this issue #1377. So I'd thought it would be nice idea to add support to GoQuorum for only block verification of IBFT2 chains that have switched to QBFT. I did some analysis and found out that BFT specific extra data which is stored per block has the same structure for IBFT2 and QBFT consensuses, however RLP encoding differs for some cases, therefore block hash would differ and validation during the sync would fail. As a conclusion by just introducing an IBFT2 block extra data encoder/decoder will make it possible to sync and validate IBFT2 blocks on GoQuorum.
Here are the differences that I found out:
0x00
, QBFT represents it as null value (according to Ethereum conventions).0
as0x00000000
,1
as0x00000001
), QBFT represents it as scalar according to Ethereum conventions (0
as0x
,1
as0x01
).<Vanity>, <Validators>, <Vote>, <Round>
or<Vanity>, <Validators>, <Vote>
structures are used), whereas QBFT puts zero as default for round number and empty list for seals in such cases. However on IBFT2 the full extra data is used for genesis block hash calculation.I have made some changes to client to make QBFT extra data encoder/decoder behave as IBFT2 one and I have run it for IBFT2 chain which was successfully synced. The changes I've done can be found in this commit. It has to be mentioned that I'm a complete beginner in Go and this commit is just a proof of concept, however any comments are welcome :)
The proper solution would be to have some param in chain spec like
useIBFT2ExtraDataValidationUntilBlock
, that will enable this logic until some block which would be the block when IBFT2 chain have switched consensus to QBFT. But before starting to implement this, I wanted to gather opinions of more experienced devs here whether it makes sense and that I haven't missed anything. Also already implementation related question: What is the better way to submit chain params toQBFTFilteredHeader
function that is used in theHash
function? (which is used in many places and adding extra argument for chain params to it would not be that convenient)This approach of course does not enable mining on IBFT2 chain however I think it's a good solution for chains that have switched from IBFT2 to QBFT (where mining could be possible already) and requires much less effort to implement.
Thank you very much and I'm looking forward to your feedback!
The text was updated successfully, but these errors were encountered: