2018-01-28 18:05:06 +00:00
|
|
|
<p align="center">
|
2022-12-21 10:59:16 +00:00
|
|
|
<picture>
|
|
|
|
<source media="(prefers-color-scheme: dark)" srcset="./.github/logo_dark.png">
|
|
|
|
<source media="(prefers-color-scheme: light)" srcset="./.github/logo_light.png">
|
|
|
|
<img src="./.github/logo_light.png" width="300px" alt="NeoGo logo">
|
|
|
|
</picture>
|
2018-01-28 18:05:06 +00:00
|
|
|
</p>
|
|
|
|
<p align="center">
|
2021-08-02 17:08:39 +00:00
|
|
|
<b>Go</b> Node and SDK for the <a href="https://neo.org">Neo</a> blockchain.
|
2018-01-28 18:05:06 +00:00
|
|
|
</p>
|
|
|
|
|
2019-08-21 17:31:48 +00:00
|
|
|
<hr />
|
|
|
|
|
|
|
|
[![codecov](https://codecov.io/gh/nspcc-dev/neo-go/branch/master/graph/badge.svg)](https://codecov.io/gh/nspcc-dev/neo-go)
|
2023-08-30 13:46:04 +00:00
|
|
|
[![GithubWorkflows Tests](https://github.com/nspcc-dev/neo-go/actions/workflows/tests.yml/badge.svg)](https://github.com/nspcc-dev/neo-go/actions/workflows/tests.yml)
|
2019-08-21 17:31:48 +00:00
|
|
|
[![Report](https://goreportcard.com/badge/github.com/nspcc-dev/neo-go)](https://goreportcard.com/report/github.com/nspcc-dev/neo-go)
|
2019-09-17 15:12:32 +00:00
|
|
|
[![GoDoc](https://godoc.org/github.com/nspcc-dev/neo-go?status.svg)](https://godoc.org/github.com/nspcc-dev/neo-go)
|
2019-08-21 17:31:48 +00:00
|
|
|
![GitHub release (latest SemVer)](https://img.shields.io/github/v/release/nspcc-dev/neo-go?sort=semver)
|
|
|
|
![License](https://img.shields.io/github/license/nspcc-dev/neo-go.svg?style=popout)
|
2018-01-29 07:42:49 +00:00
|
|
|
|
2018-01-28 18:05:06 +00:00
|
|
|
# Overview
|
2018-01-31 12:50:11 +00:00
|
|
|
|
2022-12-06 18:30:51 +00:00
|
|
|
NeoGo is a complete platform for distributed application development built on
|
|
|
|
top of and compatible with the [Neo project](https://github.com/neo-project).
|
|
|
|
This includes, but not limited to (see documentation for more details):
|
2018-02-01 17:40:04 +00:00
|
|
|
|
2019-11-27 13:11:43 +00:00
|
|
|
- [Consensus node](docs/consensus.md)
|
2020-04-09 16:45:46 +00:00
|
|
|
- [RPC node & client](docs/rpc.md)
|
|
|
|
- [CLI tool](docs/cli.md)
|
|
|
|
- [Smart contract compiler](docs/compiler.md)
|
2022-12-06 18:30:51 +00:00
|
|
|
- [Neo virtual machine](docs/vm.md)
|
2021-03-22 18:13:29 +00:00
|
|
|
- [Smart contract examples](examples/README.md)
|
2021-04-07 18:27:42 +00:00
|
|
|
- [Oracle service](docs/oracle.md)
|
2021-04-07 18:42:26 +00:00
|
|
|
- [State validation service](docs/stateroots.md)
|
2020-04-09 16:45:46 +00:00
|
|
|
|
2022-12-06 18:30:51 +00:00
|
|
|
The protocol implemented here is Neo N3-compatible, however you can also find
|
|
|
|
an implementation of the Neo Legacy protocol in the [**master-2.x**
|
2020-04-09 16:45:46 +00:00
|
|
|
branch](https://github.com/nspcc-dev/neo-go/tree/master-2.x) and releases
|
2021-08-02 17:08:39 +00:00
|
|
|
before 0.80.0 (**0.7X.Y** track).
|
2018-02-01 17:40:04 +00:00
|
|
|
|
2018-03-25 14:03:38 +00:00
|
|
|
# Getting started
|
2018-01-31 11:51:02 +00:00
|
|
|
|
2018-03-25 14:03:38 +00:00
|
|
|
## Installation
|
2018-01-31 11:51:02 +00:00
|
|
|
|
2021-03-18 09:33:42 +00:00
|
|
|
NeoGo is distributed as a single binary that includes all the functionality
|
|
|
|
provided (but smart contract compiler requires Go compiler to operate). You
|
|
|
|
can grab it from [releases
|
|
|
|
page](https://github.com/nspcc-dev/neo-go/releases), use a Docker image (see
|
|
|
|
[Docker Hub](https://hub.docker.com/r/nspccdev/neo-go) for various releases of
|
|
|
|
NeoGo, `:latest` points to the latest release) or build yourself.
|
2018-04-16 08:41:23 +00:00
|
|
|
|
|
|
|
### Building
|
|
|
|
|
2024-03-04 14:49:01 +00:00
|
|
|
Building NeoGo requires Go 1.20+ and `make`:
|
2018-02-01 18:06:17 +00:00
|
|
|
|
|
|
|
```
|
2022-12-06 18:30:51 +00:00
|
|
|
make
|
2018-02-01 18:06:17 +00:00
|
|
|
```
|
2018-02-01 17:40:04 +00:00
|
|
|
|
2022-12-06 18:30:51 +00:00
|
|
|
The resulting binary is `bin/neo-go`. Notice that using some random revision
|
|
|
|
from the `master` branch is not recommended (it can have any number of
|
|
|
|
incompatibilities and bugs depending on the development stage), please use
|
|
|
|
tagged released versions.
|
2020-04-27 13:24:21 +00:00
|
|
|
|
2021-11-01 09:02:43 +00:00
|
|
|
#### Building on Windows
|
|
|
|
|
|
|
|
To build NeoGo on Windows platform we recommend you to install `make` from [MinGW
|
2022-04-20 18:30:09 +00:00
|
|
|
package](https://osdn.net/projects/mingw/). Then, you can build NeoGo with:
|
2021-11-01 09:02:43 +00:00
|
|
|
|
|
|
|
```
|
2022-12-06 18:30:51 +00:00
|
|
|
make
|
2021-11-01 09:02:43 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
The resulting binary is `bin/neo-go.exe`.
|
|
|
|
|
2021-03-18 09:33:42 +00:00
|
|
|
## Running a node
|
2018-01-28 18:37:03 +00:00
|
|
|
|
2024-06-06 12:06:10 +00:00
|
|
|
Before running a Neo node, you need to generate the necessary configuration files
|
|
|
|
for the network you wish to connect to, such as a local network (`privnet`), or
|
|
|
|
a public network like `mainnet` or `testnet`. NeoGo stores network configuration
|
|
|
|
files in a directory (`./config` by default) and allows you to easily switch
|
|
|
|
between them using network flags.
|
2018-01-28 18:37:03 +00:00
|
|
|
|
2024-06-06 12:06:10 +00:00
|
|
|
### Initial Setup
|
2018-03-03 07:16:05 +00:00
|
|
|
|
2024-06-06 12:06:10 +00:00
|
|
|
First, generate the configuration files for all available networks:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
./bin/neo-go config generate --all
|
2018-02-01 17:40:04 +00:00
|
|
|
```
|
2024-06-06 12:06:10 +00:00
|
|
|
|
|
|
|
This command will create configuration files for each network in
|
|
|
|
the `./config` directory. You need to run this step only once before the first run.
|
|
|
|
|
|
|
|
### Starting the Node
|
|
|
|
|
|
|
|
To start a Neo node on a private network, use:
|
|
|
|
|
|
|
|
```bash
|
2019-09-02 13:43:44 +00:00
|
|
|
./bin/neo-go node
|
2018-02-01 17:40:04 +00:00
|
|
|
```
|
2018-02-01 08:00:42 +00:00
|
|
|
|
2022-04-20 18:30:09 +00:00
|
|
|
Or specify a different network with an appropriate flag like this:
|
2018-02-01 08:00:42 +00:00
|
|
|
|
2018-02-01 17:40:04 +00:00
|
|
|
```
|
2018-03-25 14:03:38 +00:00
|
|
|
./bin/neo-go node --mainnet
|
2018-02-01 17:40:04 +00:00
|
|
|
```
|
2018-02-01 08:00:42 +00:00
|
|
|
|
2018-03-25 14:03:38 +00:00
|
|
|
Available network flags:
|
|
|
|
- `--mainnet, -m`
|
|
|
|
- `--privnet, -p`
|
|
|
|
- `--testnet, -t`
|
2018-01-31 11:51:02 +00:00
|
|
|
|
2022-04-20 18:30:09 +00:00
|
|
|
To run a consensus/committee node, refer to [consensus
|
2021-07-14 20:07:34 +00:00
|
|
|
documentation](docs/consensus.md).
|
|
|
|
|
2022-12-06 18:30:51 +00:00
|
|
|
If you're running a node on Windows, please turn off or configure Windows
|
|
|
|
Firewall appropriately (allowing inbound connections to the P2P port).
|
|
|
|
|
2021-03-18 09:33:42 +00:00
|
|
|
### Docker
|
|
|
|
|
2022-04-20 18:30:09 +00:00
|
|
|
By default, the `CMD` is set to run a node on `privnet`. So, to do this, simply run:
|
2021-03-18 09:33:42 +00:00
|
|
|
|
|
|
|
```bash
|
|
|
|
docker run -d --name neo-go -p 20332:20332 -p 20331:20331 nspccdev/neo-go
|
|
|
|
```
|
|
|
|
|
|
|
|
Which will start a node on `privnet` and expose node's ports `20332` (P2P
|
|
|
|
protocol) and `20331` (JSON-RPC server).
|
|
|
|
|
|
|
|
### Importing mainnet/testnet dump files
|
2020-04-27 13:24:21 +00:00
|
|
|
|
|
|
|
If you want to jump-start your mainnet or testnet node with [chain archives
|
2022-04-20 18:30:09 +00:00
|
|
|
provided by NGD](https://sync.ngd.network/), follow these instructions:
|
2020-04-27 13:24:21 +00:00
|
|
|
```
|
|
|
|
$ wget .../chain.acc.zip # chain dump file
|
|
|
|
$ unzip chain.acc.zip
|
|
|
|
$ ./bin/neo-go db restore -m -i chain.acc # for testnet use '-t' flag instead of '-m'
|
|
|
|
```
|
|
|
|
|
|
|
|
The process differs from the C# node in that block importing is a separate
|
2022-04-20 18:30:09 +00:00
|
|
|
mode. After it ends, the node can be started normally.
|
2020-04-27 13:24:21 +00:00
|
|
|
|
2021-03-18 09:33:42 +00:00
|
|
|
## Running a private network
|
|
|
|
|
|
|
|
Refer to [consensus node documentation](docs/consensus.md).
|
|
|
|
|
2020-05-18 21:17:05 +00:00
|
|
|
## Smart contract development
|
|
|
|
|
2022-12-06 18:30:51 +00:00
|
|
|
Please refer to [NeoGo smart contract development
|
2020-05-18 21:17:05 +00:00
|
|
|
workshop](https://github.com/nspcc-dev/neo-go-sc-wrkshp) that shows some
|
2022-12-06 18:30:51 +00:00
|
|
|
simple contracts that can be compiled/deployed/run using NeoGo compiler, SDK
|
2022-04-20 18:30:09 +00:00
|
|
|
and a private network. For details on how Go code is translated to Neo VM
|
|
|
|
bytecode and what you can and can not do in a smart contract, please refer to the
|
2020-05-18 21:17:05 +00:00
|
|
|
[compiler documentation](docs/compiler.md).
|
|
|
|
|
2022-12-06 18:30:51 +00:00
|
|
|
Refer to [examples](examples/README.md) for more Neo smart contract examples
|
2021-03-22 18:13:29 +00:00
|
|
|
written in Go.
|
|
|
|
|
2021-03-18 13:09:34 +00:00
|
|
|
## Wallets
|
|
|
|
|
2022-12-06 18:30:51 +00:00
|
|
|
NeoGo wallet is just a
|
2021-03-18 13:09:34 +00:00
|
|
|
[NEP-6](https://github.com/neo-project/proposals/blob/68398d28b6932b8dd2b377d5d51bca7b0442f532/nep-6.mediawiki)
|
2022-12-06 18:30:51 +00:00
|
|
|
file that is used by CLI commands to sign various things. CLI commands are not
|
|
|
|
a direct part of the node, but rather a part of the NeoGo binary, their
|
|
|
|
implementations use RPC to query data from the blockchain and perform any
|
|
|
|
required actions. It's not required to open a wallet on an RPC node (unless
|
|
|
|
your node provides some service for the network like consensus or oracle nodes
|
|
|
|
do).
|
|
|
|
|
|
|
|
## Monitoring
|
|
|
|
NeoGo provides [Prometheus](https://prometheus.io/docs/guides/go-application) and
|
|
|
|
[Pprof](https://golang.org/pkg/net/http/pprof/) services that can be enabled
|
|
|
|
in the node in order to provide additional monitoring and debugging data.
|
|
|
|
|
|
|
|
Configuring any of the two services is easy, add the following section (`Pprof`
|
|
|
|
instead of `Prometheus` if you need that) to the respective `config/protocol.*.yml`:
|
2019-12-04 06:56:10 +00:00
|
|
|
```
|
|
|
|
Prometheus:
|
|
|
|
Enabled: true
|
2022-12-06 18:30:51 +00:00
|
|
|
Addresses:
|
|
|
|
- ":2112"
|
2019-12-04 06:56:10 +00:00
|
|
|
```
|
|
|
|
where you can switch on/off and define port. Prometheus is enabled and Pprof is disabled by default.
|
|
|
|
|
2020-04-27 13:24:21 +00:00
|
|
|
## Contributing
|
2018-01-31 11:51:02 +00:00
|
|
|
|
2018-02-24 07:23:02 +00:00
|
|
|
Feel free to contribute to this project after reading the
|
2020-04-09 16:45:46 +00:00
|
|
|
[contributing guidelines](CONTRIBUTING.md).
|
2018-02-01 17:40:04 +00:00
|
|
|
|
2022-04-20 18:30:09 +00:00
|
|
|
Before starting to work on a certain topic, create a new issue first
|
2019-02-13 18:01:10 +00:00
|
|
|
describing the feature/topic you are going to implement.
|
2018-01-29 07:11:08 +00:00
|
|
|
|
2018-01-31 10:58:19 +00:00
|
|
|
# Contact
|
2018-02-01 17:40:04 +00:00
|
|
|
|
2021-06-10 20:10:38 +00:00
|
|
|
- [@AnnaShaleva](https://github.com/AnnaShaleva) on GitHub
|
2023-11-22 08:17:09 +00:00
|
|
|
- [@roman-khimov](https://github.com/roman-khimov) on GitHub
|
2022-12-06 18:30:51 +00:00
|
|
|
- Reach out to us on the [Neo Discord](https://discordapp.com/invite/R8v48YA) channel
|
2018-01-31 12:50:11 +00:00
|
|
|
|
|
|
|
# License
|
2018-02-01 17:40:04 +00:00
|
|
|
|
2020-04-09 16:45:46 +00:00
|
|
|
- Open-source [MIT](LICENSE.md)
|