-
Notifications
You must be signed in to change notification settings - Fork 6
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: Documentation and CI configuration for Solidity #36
Conversation
06e640b
to
1cad5b5
Compare
* feat: Add scaffolding for Plonk verification in Solidity * feat: Add Plonk contract * tests: Add more negative Solidity testing * feat: Add Rust program for Solidity contract generating * chore: Update Cargo.lock * chore: Update Plonk contract according to 'e48c01ec' tag of Sphinx * chore: Formatting * feat: Introduce downloading from our AWS private bucket * feat: Update Foundry project to use sphinx-contracts dependency * chore: Rename SP1 -> Sphinx
Signed-off-by: Thomas Chataigner <[email protected]>
Signed-off-by: Thomas Chataigner <[email protected]>
Signed-off-by: Thomas Chataigner <[email protected]>
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.
Looks good! A few comments and typos/nits inline below.
I think the big question relating to the release workflow is how we'll handle accessing the sphinx-contracts
repository. We can discuss that outside of this PR though
Our Light Client is able to produce SNARK proofs that can be verified on-chain. This section will cover how to run the | ||
benchmarks for the on-chain verification. | ||
|
||
To be able to execute such tests our repository contains a project called `solidity` is based |
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.
To be able to execute such tests our repository contains a project called `solidity` is based | |
To be able to execute such tests our repository contains a project called `solidity` that is based |
Make sure that you have properly set up the `sphinx-contracts` submodule. If you haven't done so, you can do it by | ||
running the following command: |
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.
Something to keep in mind: sphinx-contracts
is still a private repository, so there's the question of how we'll handle access to it and how to deal with it in the released source.
In the released source, we can vendor in the repository and make sure it's included in its entirety at the right commit. Alternatively, we just ensure to give access to everyone relevant to the repository, which we will probably need to do anyway
|
||
> **Note** | ||
> | ||
> You might be encountering issue with updating `sphinx-contracts` Foundry dependency, in this case try manually |
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.
> You might be encountering issue with updating `sphinx-contracts` Foundry dependency, in this case try manually | |
> You might be encountering issue when updating the `sphinx-contracts` Foundry dependency, in this case try manually |
* feat: Update Sphinx and replace Groth16 with Plonk (#23) * feat: Solidity verification of light client proofs with Plonk (#28) * feat: Add scaffolding for Plonk verification in Solidity * feat: Add Plonk contract * tests: Add more negative Solidity testing * feat: Add Rust program for Solidity contract generating * chore: Update Cargo.lock * chore: Update Plonk contract according to 'e48c01ec' tag of Sphinx * chore: Formatting * feat: Introduce downloading from our AWS private bucket * feat: Update Foundry project to use sphinx-contracts dependency * chore: Rename SP1 -> Sphinx * chore: Add README for Solidity verification * feat: Add CI configuration for Solidity * ci: solidity tests on all PR Signed-off-by: Thomas Chataigner <[email protected]> * chore: update programs Signed-off-by: Thomas Chataigner <[email protected]> * docs: move documentation to mdBook Signed-off-by: Thomas Chataigner <[email protected]> --------- Signed-off-by: Thomas Chataigner <[email protected]> Co-authored-by: wwared <[email protected]> Co-authored-by: Thomas Chataigner <[email protected]>
* feat: Update Sphinx and replace Groth16 with Plonk (#23) * feat: Solidity verification of light client proofs with Plonk (#28) * feat: Add scaffolding for Plonk verification in Solidity * feat: Add Plonk contract * tests: Add more negative Solidity testing * feat: Add Rust program for Solidity contract generating * chore: Update Cargo.lock * chore: Update Plonk contract according to 'e48c01ec' tag of Sphinx * chore: Formatting * feat: Introduce downloading from our AWS private bucket * feat: Update Foundry project to use sphinx-contracts dependency * chore: Rename SP1 -> Sphinx * chore: Add README for Solidity verification * feat: Add CI configuration for Solidity * ci: solidity tests on all PR Signed-off-by: Thomas Chataigner <[email protected]> * chore: update programs Signed-off-by: Thomas Chataigner <[email protected]> * docs: move documentation to mdBook Signed-off-by: Thomas Chataigner <[email protected]> --------- Signed-off-by: Thomas Chataigner <[email protected]> Co-authored-by: wwared <[email protected]> Co-authored-by: Thomas Chataigner <[email protected]>
This PR aims to fix #34 (at least partially because the final documentation needs to be properly integrated into mdbook which is currently only in
dev
branch) by introducing README with basic information about Solidity verification of proofs generated by inclusion and epoch-change programs as well as CI configuration for Foundry testing