neo-go

module
v0.78.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 3, 2020 License: MIT

README

logo

Go Node and SDK for the NEO blockchain.


codecov CircleCI GitHub release (latest SemVer) License

Overview

This project aims to be a full port of the original C# Neo project. A complete toolkit for the NEO blockchain, including:

This branch (master-2.x) is a stable version of the project compatible with Neo 2 (including cross-chain neox support), it only receives bug fixes and minor updates. For Neo 3 development version please refer to the master branch and releases after 0.90.0. Releases before 0.80.0 (0.7X.Y track) are made from this branch and only contain Neo 2 code.

Getting started

Installation

Go: 1.13+

Install dependencies.

neo-go uses GoModules as dependency manager:

make deps

How to setup a node

Docker

Each tagged build is built to docker hub and the :latest tag pointing at the latest tagged build.

By default the CMD is set to run a node on testnet, so to do this simply run:

 docker run -d --name neo-go -p 20332:20332 -p 20333:20333 cityofzion/neo-go

Which will start a node on testnet and expose the nodes port 20333 and 20332 for the JSON-RPC server.

Building

Build the neo-go CLI:

make build
Running

Quick start a NEO node on the private network. This requires the neo-privatenet Docker image running on your machine.

make run

To run the binary directly:

./bin/neo-go node

By default the node will run on the private network, to change his:

./bin/neo-go node --mainnet

Available network flags:

  • --mainnet, -m
  • --privnet, -p
  • --testnet, -t
Importing mainnet/testnet dump files

If you want to jump-start your mainnet or testnet node with chain archives provided by NGD follow these instructions:

$ 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 mode, after it ends the node can be started normally.

Smart contract development

Please refer to neo-go smart contract development workshop that shows some simple contracts that can be compiled/deployed/run using neo-go compiler, SDK and private network. For details on how Go code is translated to Neo VM bytecode and what you can and can not do in smart contract please refer to the compiler documentation.

Developer notes

Nodes have such features as Prometheus and Pprof in order to have additional information about them for debugging.

How to configure Prometheus or Pprof: In config/protocol.*.yml there is

  Prometheus:
    Enabled: true
    Port: 2112

where you can switch on/off and define port. Prometheus is enabled and Pprof is disabled by default.

Contributing

Feel free to contribute to this project after reading the contributing guidelines.

Before starting to work on a certain topic, create an new issue first, describing the feature/topic you are going to implement.

Contact

License

  • Open-source MIT

Directories

Path Synopsis
cli
vm
examples
events Module
nft-nd Module
nft-nd-nns Module
oracle Module
timer Module
pkg
core
Package core implements Neo ledger functionality.
Package core implements Neo ledger functionality.
core/mpt
Package mpt implements MPT (Merkle-Patricia Tree).
Package mpt implements MPT (Merkle-Patricia Tree).
encoding/base58
Package base58 wraps generic base58 encoder with NEO-specific checksumming.
Package base58 wraps generic base58 encoder with NEO-specific checksumming.
interop
Package interop contains smart contract API functions.
Package interop contains smart contract API functions.
interop/account
Package account provides getter functions for Account interop structure.
Package account provides getter functions for Account interop structure.
interop/asset
Package asset provides functions to work with regular UTXO assets (like NEO or GAS).
Package asset provides functions to work with regular UTXO assets (like NEO or GAS).
interop/attribute
Package attribute provides getters for transaction attributes.
Package attribute provides getters for transaction attributes.
interop/block
Package block provides getters for Neo Block structure.
Package block provides getters for Neo Block structure.
interop/blockchain
Package blockchain provides functions to access various blockchain data.
Package blockchain provides functions to access various blockchain data.
interop/contract
Package contract provides functions to work with contracts.
Package contract provides functions to work with contracts.
interop/crypto
Package crypto provides an interface to VM cryptographic instructions and syscalls.
Package crypto provides an interface to VM cryptographic instructions and syscalls.
interop/engine
Package engine provides access to VM execution metadata and allows to make contract calls.
Package engine provides access to VM execution metadata and allows to make contract calls.
interop/enumerator
Package enumerator provides functions to work with enumerators.
Package enumerator provides functions to work with enumerators.
interop/header
Package header contains functions working with block headers.
Package header contains functions working with block headers.
interop/input
Package input provides functions dealing with transaction inputs.
Package input provides functions dealing with transaction inputs.
interop/iterator
Package iterator provides functions to work with Neo iterators.
Package iterator provides functions to work with Neo iterators.
interop/output
Package output provides functions dealing with transaction outputs.
Package output provides functions dealing with transaction outputs.
interop/runtime
Package runtime provides various service functions related to execution environment.
Package runtime provides various service functions related to execution environment.
interop/storage
Package storage provides functions to access and modify contract's storage.
Package storage provides functions to access and modify contract's storage.
interop/transaction
Package transaction provides functions to work with transactions.
Package transaction provides functions to work with transactions.
interop/util
Package util contains some special useful functions that are provided by compiler and VM.
Package util contains some special useful functions that are provided by compiler and VM.
interop/witness
Package witness provides functions dealing with transaction's witnesses.
Package witness provides functions dealing with transaction's witnesses.
io
rpc
rpc/client
Package client implements NEO-specific JSON-RPC 2.0 client.
Package client implements NEO-specific JSON-RPC 2.0 client.
vm

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL