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

Bring back reproducible builds #401

Open
lyoshenka opened this issue Apr 5, 2021 · 2 comments
Open

Bring back reproducible builds #401

lyoshenka opened this issue Apr 5, 2021 · 2 comments

Comments

@lyoshenka
Copy link
Member

As a security-conscious user, I need to be able to build lbrycrd from source and be confident that it matches the official release. This is critical to ensure that all nodes remain in consensus.

Requirements:

  • must be able to create a byte-for-byte reproducible build of the lbrycrd binaries by running a single script
  • instructions for this script must be in readme.md. it must be clear that this is the official way to build lbrycrd. other ways to build can be listed, but it must be clear that they are not for production use and cannot be guaranteed to remain in consensus.
  • our CI must use this script to build our releases. it must do basically nothing else but run that script.
  • the script should take care of dependency checking and installation, erroring if dependencies are not met, etc.
  • its acceptable to use Docker, but not any pre-existing images. if an image is being used, creating that image should be part of the reproducible build script.
  • for v1, must work on linux at least. for v2, must work on windows and mac as well.
@BrannonKing
Copy link
Member

We'll have to set the SOURCE_DATE_EPOCH and whatever the equivalent is for CLANG and the cross compiler. We also need to modify the code to ensure that we aren't running with an incompatible version of ICU and that Boost was built with the ICU backend.

@juanpc2018
Copy link

juanpc2018 commented Aug 22, 2022

byte-for-byte reproducible build

is Near impossible,
unless you have exactly the same version of everything the developer used to make the build.
all libraries, OS, dependencies, etc...

also read:
Reflections on Trusting Trust, by Ken Thompson:
https://www.youtube.com/results?search_query=Reflections+on+Trusting+Trust%2C+by+Ken+Thompson

thats why people with that level of paranoia buy these:
https://www.youtube.com/results?search_query=talos+ii+raptor

The docker image is the "same"...
personally i dont like docker,
i think is much better a real image .vhd / .vhdx
VirtualBox, qemu, kvm, vmware, proxmox, parallels, etc...

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

No branches or pull requests

3 participants