This project provides a unified interface for the Chia Blockchain carbon Core Registry applications. These applications include:
This API application is meant to run 24-7. Users of the Core Registry API will likely also want to run a Climate Wallet on a desktop computer or laptop. For a user interface, use the Core Registry UI application, either in a web browser or locally.
The simplest way to run the Core Registry API application is to run on the same machine as a Chia Full Node, Chia Wallet, Datalayer, and Datalayer HTTP services. Core Registry API communicates with the Chia services over an RPC interface. The RPC interface uses certificates to authenticate, which will work automatically when the Core Registry API application is run as the same user on the same machine as the Chia services. To run Core Registry API on a separate machine from Chia, a public certificate from the Chia node most be used to authenticate (not yet documented).
Releases are tagged in Github and binaries are built for Windows, MacOS, and Linux. ARM binaries are available for Debian versions of Linux only.
A binary executable file that can run on all Linux distributions on x86 or arm64 hardware can be found for each tagged release.
The Core Registry API can be installed with apt
. Both ARM and x86 versions can be installed this way.
- Start by updating apt and allowing repository download over HTTPS:
sudo apt-get update
sudo apt-get install ca-certificates curl gnupg
- Add Chia's official GPG Key (if you have installed Chia with
apt
, you'll have this key already and will get a message about overwriting the existing key, which is safe to do):
curl -sL https://repo.chia.net/FD39E6D3.pubkey.asc | sudo gpg --dearmor -o /usr/share/keyrings/chia.gpg
- Use the following command to setup the repository.
echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/chia.gpg] https://repo.chia.net/climate-tokenization/debian/ stable main" | sudo tee /etc/apt/sources.list.d/climate-tokenization.list > /dev/null
- Install Core Registry API
sudo apt-get update
sudo apt-get install core-registry-api
- Start Core Registry API with systemd
sudo systemctl start core-registry-api@<USERNAME>
For <USERNAME>
, enter the user that Chia runs as (the user with the .chia
directory in their home directory). For example, if the ubuntu
is where Chia runs, start Core Registry API with systemctl start core-registry-api@ubuntu
.
- Set Core Registry API to run at boot
sudo systemctl enable core-registry-api@<USERNAME>
Experimental code is released with a "release candidate" naming convention and can be found on the releases page with -rc
in the version number. Not all of the release candidates will be stable and caution should be used.
Release candidates can be installed via apt
using the instructions (above)[#debian-based-linux-distros-ubuntu-mint-etc] except replace step 3 with the following:
echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/chia.gpg] https://repo.chia.net/climate-tokenization-test/debian/ stable main" | sudo tee /etc/apt/sources.list.d/climate-tokenization-test.list > /dev/null
If both the stable and release-candidate repos are added, apt
can switch between versions installed using by appending =<version-number>
to the install command:
apt install core-registry-api=1.0.39
apt install core-registry-api=1.0.39-rc3
apt install core-registry-api=1.0.1
Without specifying the version number, apt
will install the latest release candidate if it exists, which might not always be desired.
To configure the services in the unified Core Registry API, please see the documentation of the individual applications listed at the top of this README.
All branches should be created from the develop
branch and not from main
. All pull requests should be made against the develop
branch, unless it is a new release. The develop
branch will be merged into the main
branch to create a release. Automation in the CI will create the release and attach the installation files to it automatically whenever code is merged to main
. Additionally, the changelog will automatically be updated in the main
branch. Therefore, the main
branch should always be a representation of the latest released code.
This repo uses a commit convention. A typical commit message might read:
fix: correct home screen layout
The first part of this is the commit "type". The most common types are "feat" for new features, and "fix" for bugfixes. Using these commit types helps us correctly manage our version numbers and changelogs. Since our release process calculates new version numbers from our commits it is very important to get this right.
feat
is for introducing a new featurefix
is for bug fixesdocs
for documentation only changesstyle
is for code formatting onlyrefactor
is for changes to code which should not be detectable by users or testersperf
is for a code change that improves performancetest
is for changes which only touch test files or related toolingbuild
is for changes which only touch our develop/release toolsci
is for changes to the continuous integration files and scriptschore
is for changes that don't modify code, like a version bumprevert
is for reverting a previous commit After the type and scope there should be a colon. The "subject" of the commit follows. It should be a short indication of the change. The commit convention prefers that this is written in the present-imperative tense.
This project mostly adheres to semantic versioning. The version specified in package.json
will be used by the ci to create the new release in Github so it is important to set that correctly. The major version (version 1.0, 2.0, etc) should only be changed when the data model changes and the API goes from v1 to v2. Minor version changes (version 1.2 to 1.3, etc) are for breaking or substantial changes, usually requiring some action on the user's part.
The version of Chia that Core Registry has been tested up to is controlled in package.json by the chiaVersion
field, which automatically will build into a badge when the CI runs.