Home

Awesome

Ergo

Welcome to the official repository for the Ergo Platform. This repository contains the reference client, also known as the node, for Ergo. Ergo is a cryptocurrency protocol that has been designed to offer a secure environment for peer-to-peer transactions. It supports programmable scarce money (Ergo) and a wide range of financial tools.

The reference client is primarily written in Scala. While certain components of the protocol are implemented in other languages (for instance, sigma-rust is a Rust-based implementation of the ErgoScript cryptocurrency scripting language), the reference client provides the most complete and comprehensive implementation of the Ergo protocol.

Key Features of Ergo

Ergo, while sharing some commonalities with Bitcoin as a UTXO Proof-of-Work cryptocurrency, stands out due to its unique design and features. It has been built from the ground up, introducing several innovative elements:

Specifications

More papers can be found at docs.ergoplatform.com/documents.

Security Assumptions

The Ergo client operates under certain assumptions about its environment:

Building and Running the Node and UI

For instructions on how to build and run the node and UI, refer to the official documentation.

By default, the node processes all blocks from the genesis block. However, there are other options available that may be more suitable for hardware with limited resources.


ergo {
  ...
  node.utxo.utxoBootstrap = true
  ...
}

ergo{
  ...
  node.nipopow.nipopowBootstrap = true
  node.utxo.utxoBootstrap = true
  ...
}
ergo {
   ...
   node.stateType = "digest"
   node.blocksToKeep = 2160 # store and process last three days only
   node.nipopow.nipopowBootstrap = true   # compatible with NiPoPoWs 
   ...
}

For more detailed information on different modes of node operation, please visit docs.ergoplatform.com/node/modes.

Testing Procedures

Ergo utilizes three types of tests:

  1. Unit and property tests: These can be run using the sbt test command.
  2. Integration tests: These tests require Docker to be installed. Run them with the sudo sbt it:test command.
  3. Bootstrapping tests: These tests are time-consuming as they verify that the node is syncing with the main network in various modes. Docker is also required for these tests. Run them with the sudo sbt it2:test command.

Setting up the Project in an IDE

You can use either IntelliJ IDEA (Community or Ultimate edition) or VSCode with the Metals extension.

Ensure that the project can be built with sbt before opening it in an IDE. You may need to resolve any dependency errors first.

To open the project in IntelliJ IDEA, select File / Open and navigate to the project folder. This will initiate the Project Import Wizard, which uses the SBT configuration (build.sbt file) to generate the project configuration files for IDEA. You can view the project configuration in the File / Project Structure... dialog. If the import is successful, you should be able to compile the project in the IDE.

Modules

This repository has modular structure, so only parts which are needed for an application could be used:

Using IntelliJ IDEA be sure to set Build Tools / sbt -> sbt shell / use for / builds, to avoid compilation errors

Contributing to Ergo

Ergo is an open-source project and we welcome contributions from developers and testers! Join the discussion over Ergo Discord in #development channel, or Telegram: https://t.me/ErgoDevelopers. Please also check out our Contributing documentation.

Frequently Asked Questions

For common queries, please refer to our Frequently Asked Questions page.