Hot Pocket Consensus Engine
What's here?
In development
A C++ version of hotpocket designed for production envrionments, original prototype here: https://github.com/codetsunami/hotpocket
Libraries
- Crypto - Libsodium https://github.com/jedisct1/libsodium
- Websockets - Server: Websocketd (forked) | Client: Websocat | Pipe: netcat (OpenBSD)
- RapidJSON - http://rapidjson.org
- jsoncons (for BSON) - https://github.com/danielaparker/jsoncons
- P2P Protocol - https://google.github.io/flatbuffers
- Fuse filesystem - https://github.com/libfuse/libfuse
- Boost - https://www.boost.org
Steps to setup Hot Pocket (For Ubuntu/Debian)
Install CMAKE 3.16
- Download and extract cmake-3.16.0-rc3-Linux-x86_64.tar.gz
- Navigate into the extracted directory in a terminal.
- Run
sudo cp -r bin/* /usr/local/bin/ - Run
sudo cp -r share/* /usr/local/share/
Install Libsodium
Instructions are based on this.
- Download and extract Libsodium 1.0.18 from here.
- Navigate to the extracted libsodium directory in a terminal.
- Run
./configure && make && make check - Run
sudo make install
Install Boost
Following Instructions are based on Boost getting started
- Download and extract boost 1.71 package from here.
- Navigate to the extracted boost directory in a terminal.
- Run
./bootstrap.sh - Run
sudo ./b2 install(This will compile and install boost libraries into your/usr/local/lib)
Install RapidJSON
- Download and extract RapidJSON 1.1 source from here.
- Navigate to the extracted directory.
- Run
sudo cp -r include/rapidjson /usr/local/include/
Install jsoncons
- Download and extract jsoncons v0.153.3 source from here.
- Navigate to the extracted directory.
- Run
sudo cp -r include/jsoncons /usr/local/include/ - Run
sudo mkdir -p /usr/local/include/jsoncons_ext/ && sudo cp -r include/jsoncons_ext/bson /usr/local/include/jsoncons_ext/
Install FlatBuffers
Instructions are based on this.
- Clone the git respository into a new directory from here.
- Build with CMake
git clone https://github.com/google/flatbuffers.git
cd flatbuffers
cmake -G "Unix Makefiles"
make
- Run
sudo cp -r include/flatbuffers /usr/local/include/ - Run
sudo snap install flatbuffers --edge
Compiling FlatBuffers message definitions
Example: When you make a change to p2pmsg_content_.fbc defnition file, you need to run this:
flatc -o src/msg/fbuf/ --gen-mutable --cpp src/msg/fbuf/p2pmsg_content.fbs
Install libfuse
sudo apt-get install -y meson ninja-build pkg-config- Download libfuse 3.8 and extract.
mkdir build; cd buildmeson .. && ninjasudo ninja install
Run ldconfig
sudo ldconfig
This will update your linker library cache and avoid potential issues when running your compiled C++ program which links to newly installed libraries.
Build and run Hot Pocket
- Navigate to hotpocket repo root.
- Run
cmake .(You only have to do this once) - Run
make(Hot Pocket binary will be created as./build/hpcore) - Refer to Running Hot Pocket in the Wiki.
Refer to Hot Pocket Wiki for more info.
Code structure
Code is divided into subsystems via namespaces.
conf:: Handles contract configuration. Loads and holds the central configuration object. Used by most of the subsystems.
crypto:: Handles cryptographic activities. Wraps libsodium and offers convenience functions.
sc:: Handles smart contract process execution and managing user/SC I/O and npl I/O. Makes use of usr, p2p and hpfs.
usr:: Handles user connections. Makes use of crypto and comm.
p2p:: Handles peer-to-peer connections and message exchange between nodes. Makes use of crypto and comm.
cons:: Handles consensus and proposal rounds. Makes use of usr, p2p and sc
comm:: Handles generic web sockets communication functionality. Mainly acts as a wrapper for websocketd/websocat.
util:: Contains shared data structures/helper functions used by multiple subsystems.
hpfs:: hpfs state management client helpers.