The Velo C Certificate Library is a low-level C library that provides interfaces and implementations for certificate building, signing, verifying, and parsing. Certificates are the backbone of the Velo ledger.
The vc-toolchain
project needs to be installed in the
/opt/vctoolchain
subdirectory. If a different installation directory is used,
then the TOOLCHAIN_DIR
environment variable should be set to that directory
instead. The Velo Portable Runtime and Velo C Crypto
libraries are required to link against this library and to run the test cases.
The default build target will just build the vccert release library for each
supported platform. To run unit tests, use the test
build target. This will
build both the release and the checked libraries for the current host. The
test
build target depends on Google Test. The location of the Google Test
source distribution must be included in the GTEST_DIR
environment variable.
For instance:
#build just the release libraries
make
#build with unit tests - also builds checked libraries
GTEST_DIR="path/to/google/test" make test
The resulting library will be available under the build
subdirectory, which
will be created as part of the build process.
This library also supports model checking via CBMC. To run the
model checks, use the following build target. Note that the cbmc
executable
must be in the current PATH
.
#run model checks
make model-check
It is recommended that this project be built downstream of the vpr
and
vccrypt
libraries. It should be built upstream of any libraries that depend
on it in the build pipeline. Additionally, all three of the supported build
targets, make
, make model-check
, and make test
should be run as described
in the previous section. If any of these build targets fail, then the build
should be considered a failure.