From 5d4612c6c624c3dc18f9a5657936034ac9d9d8dd Mon Sep 17 00:00:00 2001 From: Cassandra Heart Date: Fri, 7 Jun 2024 03:53:15 -0500 Subject: [PATCH] update version info + readme --- README.md | 91 ++++++++++++------------------------------ node/app/db_console.go | 44 ++++++++++---------- node/config/version.go | 8 ++-- node/main.go | 42 +++++++++---------- node/p2p/blossomsub.go | 2 +- 5 files changed, 73 insertions(+), 114 deletions(-) diff --git a/README.md b/README.md index 88e24b9..0c16c33 100644 --- a/README.md +++ b/README.md @@ -1,31 +1,40 @@ -# Quilibrium - Aurora +# Quilibrium - Betelgeuse Quilibrium is a decentralized alternative to platform as a service providers. -This release, mirrored to GitHub, is the Dawn release, which contains the -initial application, the MPC Powers-of-Tau Ceremony. Documentation for the +This release is part of the phases of the Dusk release, which finalizes with +the full permissionless mainnet in version 2.0. Documentation for the underlying technology can be found at https://www.quilibrium.com/ ## Quick Start -All commands are to be run in the `node/` folder. +Running production nodes from source is no longer recommended given build complexity. Please refer to our release information to obtain the latest version. -If you have a voucher from the offline ceremony, first run: +## Running From Source - GOEXPERIMENT=arenas go run ./... -import-priv-key `cat /path/to/voucher.hex` +Builds are now a hybrid of Rust and Go, so you will need both go 1.22 and latest Rust + Cargo. -If you do not, or have already run the above, run: +### VDF - GOEXPERIMENT=arenas go run ./... +The VDF implementation is now in Rust, and requires GMP to build. On Mac, you can install GMP with brew (`brew install gmp`). On Linux, you will need to find the appropriate package for your distro. -## Peer ID +Install the go plugin for uniffi-rs: -In order to find the peer id of a running node, execute the following command from the `node/` folder: + cargo install uniffi-bindgen-go --git https://github.com/NordSecurity/uniffi-bindgen-go --tag v0.2.1+v0.25.0 - GOEXPERIMENT=arenas go run ./... -peer-id +Be sure to follow the PATH export given by the installer. -The peer id will be printed to stdout. +Build the Rust VDF implementation by navigating to the vdf folder, and run `./generate.sh`. -## EXPERIMENTAL – gRPC/REST Support +### Node + +Because of the Rust interop, be sure you follow the above steps for the VDF before proceeding to this. Navigate to the node folder, and run (making sure to update the path for the repo): + + CGO_LDFLAGS="-L/path/to/ceremonyclient/target/release -lvdf -ldl -lm" \ + CGO_ENABLED=1 \ + GOEXPERIMENT=arenas \ + go run ./... --signature-check=false + +## gRPC/REST Support If you want to enable gRPC/REST, add the following entries to your config.yml: @@ -40,52 +49,11 @@ access via firewall or only query via localhost. In order to query the token balance of a running node, execute the following command from the `node/` folder: - GOEXPERIMENT=arenas go run ./... -balance + ./node-$version-$platform -balance -The confirmed token balance will be printed to stdout in QUILs. +The accumulated token balance will be printed to stdout in QUILs. -Note that this feature requires that [gRPC support](#experimental--grpcrest-support) is enabled. - -## Stats Collection - -In order to opt-in to stats collection about the health of the network, edit your `config.yml` in the `node/.config` directory to have a new section under `engine`: - -```yml - -engine: - statsMultiaddr: "/dns/stats.quilibrium.com/tcp/443" - -``` - -## Purpose - -The ceremony application provides a secure reference string (SRS) from which -KZG proofs can be constructed for the network. This yields applicability for a -number of proof systems, in particular for the release after Dawn, the ability -to provide proofs of execution, and proofs of data availability for the network. - -### Rewards - -For participating in a round of the ceremony, nodes will be allocated: - - reward = 161 * log_2(participant_count) QUIL - -### Basic Flow - -Rounds of the ceremony follow the following order: - -- OPEN: Nodes can join in for the round, deferring preference to nodes that -could not join in on the prior round -- IN PROGRESS: The MPC ceremony round is in progress, nodes are engaging in a -logarithmic collection of Multiplication-to-Add Oblivious Transfer circuits, -each sub round producing a new collection of values, until the sub rounds have -completed, producing a collection of public G1 and G2 BLS48-581 points for each -peer. -- FINALIZING: The collection of points are broadcasted, and added together, -producing a singular ceremony transcript contribution. -- VALIDATING: The updated ceremony transcript is validated against the -predecessor, and is confirmed to be the new state, issuing rewards to the -participant set. The next round can begin. +Note that this feature requires that [gRPC support](#grpcrest-support) is enabled. ## Community Section @@ -108,15 +76,6 @@ impossible to achieve otherwise - Error wrapping matching function names - Interface composition and dependency injection with Wire -## Minimum System Requirements - -For the Dawn phase, a server must have a minimum of 16GB of RAM, preferably -32 GB, 250GB of storage, preferably via SSD, and 50MBps symmetric bandwidth. -For Intel/AMD, the baseline processor is a Skylake processor @ 3.4GHz with 12 -dedicated cores. For ARM, the M1 line of Apple is a good reference. - -With Dusk, these minimum requirements will reduce significantly. - ## License + Interpretation Significant portions of Quilibrium's codebase depends on GPL-licensed code, diff --git a/node/app/db_console.go b/node/app/db_console.go index f1bdbdc..8321ed2 100644 --- a/node/app/db_console.go +++ b/node/app/db_console.go @@ -869,26 +869,26 @@ func logoVersion(width int) string { out += " ..---'''' ''''---..\n" out += " .---'' ''---.\n" out += " .-' '-.\n" - out += " ..-' ..--'''''''''''%######################\n" - out += " .' .--'' #################\n" - out += " .'' ..-' ###############\n" - out += " ' ' ##############\n" - out += " '' .'' ############&\n" - out += " ' '' ############\n" - out += " ' ' ########## &###########\n" - out += " ' ' ############## ###########\n" - out += " ' ' ############## ##########&\n" - out += " ' ' ############## ##########\n" - out += "' ' ########## ##########\n" - out += "' ' ##########\n" - out += "' ' &#########\n" - out += "' ' ####### ####### ##########\n" - out += "' ' &######################### ##########\n" - out += " ' ' ##############% ############## &##########\n" - out += " ' ' &############## ############### ##########\n" - out += " ' ' ############### ##############% ###########\n" - out += " ' '. ########## ############### ########\n" - out += " '. . ##### ##############% ####\n" + out += " ..-' ..--''''''''''''''--.. '-..\n" + out += " .' .--'' ''--. ''.\n" + out += " .'' ..-' ''-. '.\n" + out += " ' ' ''. '.\n" + out += " '' .'' '. '\n" + out += " ' '' '. '\n" + out += " ' ' ########## . '\n" + out += " ' ' ############## ' '\n" + out += " ' ' ############## ' '\n" + out += " ' ' ############## ' '\n" + out += "' ' ########## ' '\n" + out += "' ' ' '\n" + out += "' ' ' '\n" + out += "' ' ####### ####### ' '\n" + out += "' ' &######################### ' '\n" + out += "' ' ##############% ############## ' '\n" + out += " ' ' &############## ############### ' '\n" + out += " ' ' ############### ##############% '. '\n" + out += " ' '. ########## ############### '-. '\n" + out += " '. . ##### ##############% '-.'\n" out += " ' '. ###############\n" out += " '. '.. ##############%\n" out += " '. '-. ###############\n" @@ -899,11 +899,11 @@ func logoVersion(width int) string { out += " ''---.. ...---'' ##\n" out += " ''----------''\n" out += " \n" - out += " Quilibrium Node - v" + config.GetVersionString() + " – Nebula\n" + out += " Quilibrium Node - v" + config.GetVersionString() + " – Betelgeuse\n" out += " \n" out += " DB Console\n" } else { - out = "Quilibrium Node - v" + config.GetVersionString() + " – Nebula - DB Console\n" + out = "Quilibrium Node - v" + config.GetVersionString() + " – Betelgeuse - DB Console\n" } return out } diff --git a/node/config/version.go b/node/config/version.go index b9289de..dc7653c 100644 --- a/node/config/version.go +++ b/node/config/version.go @@ -6,15 +6,15 @@ import ( ) func GetMinimumVersionCutoff() time.Time { - return time.Date(2024, time.May, 28, 3, 0, 0, 0, time.UTC) + return time.Date(2024, time.May, 8, 5, 0, 0, 0, time.UTC) } func GetMinimumVersion() []byte { - return []byte{0x01, 0x04, 0x12} + return []byte{0x01, 0x04, 0x13} } func GetVersion() []byte { - return []byte{0x01, 0x04, 0x12} + return []byte{0x01, 0x04, 0x13} } func GetVersionString() string { @@ -29,5 +29,5 @@ func FormatVersion(version []byte) string { } func GetPatchNumber() byte { - return 0x02 + return 0x00 } diff --git a/node/main.go b/node/main.go index e77edfe..cee5ef4 100644 --- a/node/main.go +++ b/node/main.go @@ -845,26 +845,26 @@ func printLogo() { fmt.Println(" ..---'''' ''''---..") fmt.Println(" .---'' ''---.") fmt.Println(" .-' '-.") - fmt.Println(" ..-' ..--'''''''''''%######################") - fmt.Println(" .' .--'' #################") - fmt.Println(" .'' ..-' ###############") - fmt.Println(" ' ' ##############") - fmt.Println(" '' .'' ############&") - fmt.Println(" ' '' ############") - fmt.Println(" ' ' ########## &###########") - fmt.Println(" ' ' ############## ###########") - fmt.Println(" ' ' ############## ##########&") - fmt.Println(" ' ' ############## ##########") - fmt.Println("' ' ########## ##########") - fmt.Println("' ' ##########") - fmt.Println("' ' &#########") - fmt.Println("' ' ####### ####### ##########") - fmt.Println("' ' &######################### ##########") - fmt.Println(" ' ' ##############% ############## &##########") - fmt.Println(" ' ' &############## ############### ##########") - fmt.Println(" ' ' ############### ##############% ###########") - fmt.Println(" ' '. ########## ############### ########") - fmt.Println(" '. . ##### ##############% ####") + fmt.Println(" ..-' ..--''''''''''''''--.. '-..") + fmt.Println(" .' .--'' ''--. ''.") + fmt.Println(" .'' ..-' ''-. '.") + fmt.Println(" ' ' ''. '.") + fmt.Println(" '' .'' '. '") + fmt.Println(" ' '' '. '") + fmt.Println(" ' ' ########## . '") + fmt.Println(" ' ' ############## ' '") + fmt.Println(" ' ' ############## ' '") + fmt.Println(" ' ' ############## ' '") + fmt.Println("' ' ########## ' '") + fmt.Println("' ' ' '") + fmt.Println("' ' ' '") + fmt.Println("' ' ####### ####### ' '") + fmt.Println("' ' &######################### ' '") + fmt.Println("' ' ##############% ############## ' '") + fmt.Println(" ' ' &############## ############### ' '") + fmt.Println(" ' ' ############### ##############% '. '") + fmt.Println(" ' '. ########## ############### '-. '") + fmt.Println(" '. . ##### ##############% '-.'") fmt.Println(" ' '. ###############") fmt.Println(" '. '.. ##############%") fmt.Println(" '. '-. ###############") @@ -883,5 +883,5 @@ func printVersion() { patchString = fmt.Sprintf("-p%d", patch) } fmt.Println(" ") - fmt.Println(" Quilibrium Node - v" + config.GetVersionString() + patchString + " – Nebula") + fmt.Println(" Quilibrium Node - v" + config.GetVersionString() + patchString + " – Betelgeuse") } diff --git a/node/p2p/blossomsub.go b/node/p2p/blossomsub.go index 4d2a2d2..4421c32 100644 --- a/node/p2p/blossomsub.go +++ b/node/p2p/blossomsub.go @@ -61,7 +61,7 @@ var BITMASK_ALL = []byte{ // While we iterate through these next phases, we're going to aggressively // enforce keeping updated. This will be achieved through announce strings // that will vary with each update -var ANNOUNCE_PREFIX = "quilibrium-1.4.18-nebula-" +var ANNOUNCE_PREFIX = "quilibrium-1.4.19-betelgeuse-" func getPeerID(p2pConfig *config.P2PConfig) peer.ID { peerPrivKey, err := hex.DecodeString(p2pConfig.PeerPrivKey)