Unless explicitly stated otherwise, all commands detailed in next sections are to be run from the top level directory of coincenter
repository.
If you don't want to build coincenter
locally, you can just download the public docker image, corresponding to the latest version of branch main
.
docker run -t sjanel/coincenter -h
Docker image does not contain additional data
directory needed by coincenter
(see Configuration)
To bind your 'data' directory from host to the docker container, you can use --mount
option:
docker run --mount type=bind,source=<path-to-data-dir-on-host>,target=/app/data sjanel/coincenter
This is a C++20 project.
It's still currently (as of beginning of 2023) not fully supported by most compilers (MSVC does, GCC is very close, see here).
But they have partial support which is sufficient to build coincenter
.
The following compilers are known to compile coincenter
(and are tested in the CI):
- GCC version >= 12
- Clang version >= 18
- MSVC version >= 19.39
Other compilers have not been tested.
In addition, the basic minimum requirements are:
- Git
- CMake >= 3.15
- curl >= 7.58.0 (it may work with an earlier version, it's just the minimum tested on Ubuntu 18)
- openssl >= 1.1.0
Provided that your distribution is sufficiently recent, meta package build-essential
should provide gcc
with the correct version.
Otherwise you can still force it:
sudo apt update
sudo apt install build-essential ninja-build zlib1g-dev libcurl4-openssl-dev libssl-dev cmake git ca-certificates
You can refer to the provided Dockerfile for more information.
With ninja
generator for instance:
sudo apk add --update --upgrade g++ libc-dev zlib-dev openssl-dev curl-dev cmake ninja git ca-certificates
You can refer to the provided Dockerfile for more information.
The vcpkg manifest vcpkg.json defines needed dependencies. You can install them manually with (optional, it will be done automatically by cmake at configure time):
vcpkg install
From this step, the dependencies can be found by cmake
with find_package
by giving the toolchain file of vcpkg
at configure time:
cmake -DCMAKE_TOOLCHAIN_FILE="<vcpkg-root-dir>/scripts/buildsystems/vcpkg.cmake" <usual-cmake-arguments>
You can refer to the Windows workflow and the vcpkg install page for more information.
It's very similar than with vcpkg. The build process is described in details in this page.
# If not already done - add profile to your system
conan profile detect --force
# install libraries defined in conanfile.txt
conan install . --output-folder=build --build=missing
If your cmake version is >= 3.23, then simply run:
cmake -S . -B build --preset conan-release
coincenter
uses various external open source libraries.
In all cases, they do not need to be installed. If they are not found at configure time, cmake
will fetch sources and compile them automatically.
If you are building frequently coincenter
you can install them to speed up its compilation.
Library | Description | License |
---|---|---|
amc | High performance C++ containers (maintained by me) | MIT |
googletest | Google Testing and Mocking Framework | BSD-3-Clause License |
json serialization | Extremely fast, in memory, JSON and interface library for modern C++ | MIT |
spdlog | Fast C++ logging library | MIT |
prometheus-cpp | Prometheus Client Library for Modern C++ | MIT |
jwt-cpp | Creating and validating json web tokens in C++ | MIT |
This project can be easily built with cmake.
The minimum tested version is cmake 3.15
, but it's recommended that you use the latest available one.
Option | Default | Description |
---|---|---|
CCT_ENABLE_TESTS |
ON if main project |
Build and launch unit tests |
CCT_BUILD_EXEC |
ON if main project |
Build an executable instead of a static library |
CCT_ENABLE_ASAN |
ON if Debug mode |
Compile with AddressSanitizer |
CCT_ENABLE_CLANG_TIDY |
ON if Debug mode and clang-tidy is found in PATH |
Compile with clang-tidy checks |
CCT_ENABLE_PROTO |
ON |
Compile with protobuf support |
Example on Linux: to compile it in Release
mode and ninja
generator
mkdir -p build
cd build
cmake -GNinja -DCMAKE_BUILD_TYPE=Release ..
ninja
On Windows, you can use your preferred IDE to build coincenter
(Visual Studio Code, Visual Studio 2022, etc), or build it from command line, with generator -G "Visual Studio 17 2022"
for instance. Refer to the GitHub Windows workflow to have the detailed installation steps.
coincenter can also be used as a sub project, such as a trading bot for instance. It is the case by default if built as a sub-module in cmake
.
To build your cmake
project with coincenter library, you can do it with FetchContent
:
include(FetchContent)
FetchContent_Declare(
coincenter
GIT_REPOSITORY https://github.com/sjanel/coincenter.git
GIT_TAG main
)
FetchContent_MakeAvailable(coincenter)
Then, a static library named coincenter
is defined and you can link it as usual:
target_link_libraries(<MyProgram> PRIVATE coincenter)
You can build coincenter
with prometheus-cpp if needed.
If you have it installed on your machine, cmake
will link coincenter with it. Otherwise you can still activate cmake
flag CCT_BUILD_PROMETHEUS_FROM_SRC
(default to OFF) to build it automatically from sources with FetchContent
.
A Docker image is hosted in the public Docker hub registry with the name sjanel/coincenter, corresponding to latest successful build of main
branch by the CI.
It is built in two flavors:
- Ubuntu based (default)
- Alpine based (tagged
alpine
for the latest version and fixed versions with-alpine
suffixes)
You can create your own Docker image of coincenter
.
Build options (all optional):
CMake build mode
BUILD_MODE
(default: Release)
Compile and launch tests
BUILD_TEST
(default: 0)
Activate Address Sanitizer
BUILD_ASAN
(default: 0)
Compile with prometheus-cpp to support metric export to Prometheus
BUILD_WITH_PROMETHEUS
(default: 1)
docker build --build-arg BUILD_MODE=Release -t local-coincenter .
docker run -ti -e "TERM=xterm-256color" local-coincenter --help
Tests are compiled only if coincenter
is built as a main project by default. You can set cmake
flag CCT_ENABLE_TESTS
to 1 or 0 to change this behavior.
Note that exchanges API are also unit tested. If no private key is found, only public exchanges will be tested, private exchanges will be skipped and unit test will not fail.