Categorygithub.com/UtopiaCoinOrg/ucd
modulepackage
0.0.0-20191129015703-b51e6e604d8f
Repository: https://github.com/utopiacoinorg/ucd.git
Documentation: pkg.go.dev

# README

ucd

Build Status ISC License GoDoc Go Report Card

Utopia Overview

Utopia is a blockchain-based cryptocurrency with a strong focus on community input, open governance, and sustainable funding for development. It utilizes a hybrid proof-of-work and proof-of-stake mining system to ensure that a small group cannot dominate the flow of transactions or make changes to Utopia without the input of the community. A unit of the currency is called a utopia (UC).

https://utopia.org

Latest Downloads

https://utopia.org/downloads

What is ucd?

ucd is a full node implementation of Utopia written in Go (golang).

It acts as a fully-validating chain daemon for the Utopia cryptocurrency. ucd maintains the entire past transactional ledger of Utopia and allows relaying of transactions to other Utopia nodes around the world.

This software is currently under active development. It is extremely stable and has been in production use since February 2016.

The software was originally forked from btcd, which is a bitcoin full node implementation that is still under active development. To gain the benefit of btcd's ongoing upgrades, including improved peer and connection handling, database optimization, and other blockchain related technology improvements, ucd is continuously synced with the btcd codebase.

What is a full node?

The term 'full node' is short for 'fully-validating node' and refers to software that fully validates all transactions and blocks, as opposed to trusting a 3rd party. In addition to validating transactions and blocks, nearly all full nodes also participate in relaying transactions and blocks to other full nodes around the world, thus forming the peer-to-peer network that is the backbone of the Utopia cryptocurrency.

The full node distinction is important, since full nodes are not the only type of software participating in the Utopia peer network. For instance, there are 'lightweight nodes' which rely on full nodes to serve the transactions, blocks, and cryptographic proofs they require to function, as well as relay their transactions to the rest of the global network.

Why run ucd?

As described in the previous section, the Utopia cryptocurrency relies on having a peer-to-peer network of nodes that fully validate all transactions and blocks and then relay them to other full nodes.

Running a full node with ucd contributes to the overall security of the network, increases the available paths for transactions and blocks to relay, and helps ensure there are an adequate number of nodes available to serve lightweight clients, such as Simplified Payment Verification (SPV) wallets.

Without enough full nodes, the network could be unable to expediently serve users of lightweight clients which could force them to have to rely on centralized services that significantly reduce privacy and are vulnerable to censorship.

In terms of individual benefits, since ucd fully validates every block and transaction, it provides the highest security and privacy possible when used in conjunction with a wallet that also supports directly connecting to it in full validation mode, such as ucwallet (CLI) and Utopiaiton (GUI).

Minimum Recommended Specifications (ucd only)

  • 10 GB disk space (as of September 2018, increases over time)
  • 1GB memory (RAM)
  • ~150MB/day download, ~1.5GB/day upload
    • Plus one-time initial download of the entire block chain
  • Windows 7/8.x/10 (server preferred), macOS, Linux
  • High uptime

Getting Started

So, you've decided to help the network by running a full node. Great! Running ucd is simple. All you need to do is install ucd on a machine that is connected to the internet and meets the minimum recommended specifications, and launch it.

Also, make sure your firewall is configured to allow inbound connections to port 10508.

Installing and updating

Binaries (Windows/Linux/macOS)

Binary releases are provided for common operating systems and architectures:

https://utopia.org/downloads

Build from source (all platforms)

Building or updating from source requires the following build dependencies:

To build and install from a checked-out repo, run go install . ./cmd/... in the repo's root directory. Some notes:

  • Set the GO111MODULE=on environment variable if building from within GOPATH.

  • The ucd executable will be installed to $GOPATH/bin. GOPATH defaults to $HOME/go (or %USERPROFILE%\go on Windows) if unset.

Example of obtaining and building from source on Windows 10:

PS> git clone https://github.com/UtopiaCoinOrg/ucd $env:USERPROFILE\src\ucd
PS> cd $env:USERPROFILE\src\ucd
PS> go install . .\cmd\...
PS> & "$(go env GOPATH)\bin\ucd" -V

Docker

Running ucd

You can run a utopia node from inside a docker container. To build the image yourself, use the following command:

docker build -t utopia/ucd .

Or you can create an alpine based image (requires Docker 17.05 or higher):

docker build -t utopia/ucd:alpine -f Dockerfile.alpine .

You can then run the image using:

docker run utopia/ucd

You may wish to use an external volume to customise your config and persist the data in an external volume:

docker run --rm -v /home/user/ucdata:/root/.ucd/data utopia/ucd

For a minimal image, you can use the utopia/ucd:alpine tag. This is typically a more secure option while also being a much smaller image.

You can run ucctl from inside the image. For example, run an image (mounting your data from externally) with:

docker run --rm -ti --name=ucd-1 -v /home/user/.ucd:/root/.ucd \
  utopia/ucd:alpine

And then run ucctl commands against it. For example:

docker exec -ti ucd-1 ucctl getbestblock

Running Tests

All tests and linters may be run in a docker (or podman) container using the script run_tests.sh by specifying either docker or podman as the first parameter. This script defaults to using the current latest supported version of Go, but it also respects the GOVERSION environment variable set to the major version of Go to allow testing on a previous version of Go. Generally, Utopia only supports the current and previous major versions of Go.

./run_tests.sh docker

To run the tests locally without docker on the latest supported version of Go:

./run_tests.sh

To run the tests locally without docker on Go 1.11:

GOVERSION=1.11 ./run_tests.sh

Contact

If you have any further questions you can find us at:

https://utopia.org/community

Issue Tracker

The integrated github issue tracker is used for this project.

Documentation

The documentation for ucd is a work-in-progress. It is located in the docs folder.

License

ucd is licensed under the copyfree ISC License.

# Packages

Package addrmgr implements concurrency safe Utopia address manager.
Package bech32 provides a Go implementation of the bech32 format specified in BIP 173.
Package blockchain implements Utopia block handling and chain selection rules.
Package certgen includes a common base for creating a new TLS certificate key pair.
Package chaincfg defines chain configuration parameters.
No description provided by the author
Package connmgr implements a generic Utopia network connection manager.
Package database provides a block and metadata storage database.
Package fees provides utopia-specific methods for tracking and estimating fee rates for new transactions to be mined into the network.
Package gcs provides an API for building and using a Golomb-coded set filter.
Package hdkeychain provides an API for Utopia hierarchical deterministic extended keys (based on BIP0032).
Package lru implements a generic least-recently-used cache with near O(1) perf.
Package mempool provides a policy-enforced pool of unmined Utopia transactions.
Package mining includes all mining and policy types, and will house all mining code in the future.
Package peer provides a common base for creating and managing Utopia network peers.
No description provided by the author
Package rpcclient implements a websocket-enabled Utopia JSON-RPC client.
Package rpctest provides a ucd-specific RPC testing harness crafting and executing integration tests by driving a `ucd` instance via the `RPC` interface.
Package sampleconfig provides a single constant that contains the contents of the sample configuration file for ucd.
Package txscript implements the Utopia transaction script language.
No description provided by the author
Package ucjson provides infrastructure for working with Utopia JSON-RPC APIs.
Package ucutil provides utopia-specific convenience functions and types.
Package wire implements the Utopia wire protocol.

# Functions

Discover searches the local network for a UPnP router returning a NAT for the network if so, nil if not.
SortParentsByVotes takes a list of block header hashes and sorts them by the number of votes currently available for them in the votes map of mempool.
UpdateExtraNonce updates the extra nonce in the coinbase script of the passed block by regenerating the coinbase script with the passed value and block height.

# Constants

ErrCheckConnectBlock indicates that a newly created block template failed blockchain.CheckBlockSanity.
ErrCheckConnectBlock indicates that a newly created block template failed blockchain.CheckConnectBlock.
ErrCoinbaseLengthOverflow indicates that a coinbase length was overflowed, probably of a result of incrementing extranonce.
ErrCreatingCoinbase indicates that there was a problem generating the coinbase.
ErrFailedToGetGeneration specifies that the current generation for a block could not be obtained from blockchain.
ErrFetchTxStore indicates a transaction store failed to fetch.
ErrFraudProofIndex indicates that there was an error finding the index for a fraud proof.
ErrGetStakeDifficulty indicates that the current stake difficulty could not be obtained.
ErrGettingDifficulty indicates that there was an error getting the PoW difficulty.
ErrGettingMedianTime indicates that the server was unable to get the median adjusted time for the network.
ErrGetStakeDifficulty indicates that the current top block of the blockchain could not be obtained.
ErrNotEnoughVoters indicates that there were not enough voters to build a block on top of HEAD.
ErrTransactionAppend indicates there was a problem adding a msgtx to a msgblock.

# Variables

ErrClientQuit describes the error where a client send is not processed due to the client having already been disconnected or dropped.
ErrInvalidLongPoll is an internal error code to indicate that longpollid is not formated properly.
ErrRPCNoWallet is an error returned to RPC clients when the provided command is recognized as a wallet command.
ErrRPCUnimplemented is an error returned to RPC clients when the provided command is recognized, but not implemented.

# Structs

BgBlkTmplGenerator provides facilities for asynchronously generating block templates in response to various relevant events and allowing clients to subscribe for updates when new templates are generated as well as access the most recently-generated template in a concurrency-safe manner.
BlkTmplGenerator generates block templates based on a given mining policy and a transactions source.
BlockTemplate houses a block that has yet to be solved along with additional details about the fees and the number of signature operations for each transaction in the block.
CPUMiner provides facilities for solving blocks (mining) using the CPU in a concurrency-safe manner.
No description provided by the author
MiningRuleError identifies a rule violation.
StakeDifficultyNtfnData is the data that is used to generate stake difficulty notifications.
TemplateSubscription defines a subscription to receive block template updates from the background block template generator.
WinningTicketsNtfnData is the data that is used to generate winning ticket notifications (which indicate a block and the tickets eligible to vote on it).

# Interfaces

NAT is an interface representing a NAT traversal options for example UPNP or NAT-PMP.
PeerNotifier provides an interface for server peer notifications.

# Type aliases

MiningErrorCode identifies a kind of error.