Cryptcheck relies on compiling a very unsecure version of OpenSSL.
When manipulating such library, you need to be sure of what you are doing to
never deploy it on a production grade system.
Particularly, be sure to never hit make install
during a manual build.
Build process can be quiet hard, because relying on number of tricks to be able
to use this weakened library not globally install on your system.
LD_LIBRARY_PATH
, C_INCLUDE_PATH
, LIBRARY_PATH
and other environment
variables are used to inject what is needed during build process and at runtime
to override system headers and libraries.
Build process is at this time not garanteed to be reproductible.
Because of above tricks, error can happen and you need to understand GNU
internals and debug tools like strace
to spot the cause of the trouble and to
fix it.
Given Makefiles are more generic guidelines and build recipes than fully
automated build.
Because of the need of a weakened Ruby build, you need
rbenv
on your system to isolate this Ruby
version from your eventual system version.
See there readme and wiki for setup process. TL;DR;
export RBENV_ROOT="${HOME}/.rbenv"
export PATH="${RBENV_ROOT}/bin:${PATH}"
apt install -y autoconf bison build-essential libssl-dev libyaml-dev libreadline6-dev zlib1g-dev libncurses5-dev libffi-dev libgdbm3 libgdbm-dev
git clone https://github.com/rbenv/rbenv "${RBENV_ROOT}"
mkdir -p "${RBENV_ROOT}/plugins"
git clone https://github.com/rbenv/ruby-build "${RBENV_ROOT}/plugins/ruby-build"
eval "$(rbenv init -)"
Goal is to build the weakened OpenSSL library, then a custom Ruby version based on it.
git clone https://git.imirhil.fr/aeris/cryptcheck
cd cryptcheck
make
make install-rbenv-cryptcheck
git clone https://git.imirhil.fr/aeris/cryptcheck-rails
cd cryptcheck-rails
rbenv local 2.3.3-cryptcheck
export LD_LIBRARY_PATH=../cryptcheck/lib
bundle install
You need a MongoDB and a Redis server.
apt install -y mongodb-server redis-server
export LD_LIBRARY_PATH=../cryptcheck/lib
bin/guard -i
export LD_LIBRARY_PATH=../cryptcheck/lib
bin/sidekiq