[BREAKGLASS] Append-only mirror of github.com/seedhammer/dcrd
Go to file
SeedHammer 0d633fcd00
Some checks failed
Build and Test / Go CI (1.21) (push) Has been cancelled
Build and Test / Go CI (1.22) (push) Has been cancelled
secp256k1: add support for resource constrained environments (TinyGo)
The pre-computed table for speeding up ScalarBaseMultNonConst is
several hundred kilobytes in the binary and even more when unpacked
into working memory. Special-case ScalarBaseMultNonConst to fall back to
ScalarMultNonConst when the 'tinygo' tag is specified, which is true
when building a Go program with TinyGo.
2024-03-19 16:05:24 +00:00
.github build: Test against Go 1.22. 2024-02-09 13:39:47 -06:00
addrmgr multi: Wrap errors for better errors.Is/As support. 2023-08-25 16:31:11 -05:00
bech32 multi: Cleanup superfluous trailing newlines. 2023-08-25 12:39:15 -05:00
blockchain multi: Cleanup superfluous trailing newlines. 2023-08-25 12:39:15 -05:00
certgen multi: Wrap errors for better errors.Is/As support. 2023-08-25 16:31:11 -05:00
chaincfg multi: Remove a bunch of dup words in comments. 2023-08-23 14:13:51 -05:00
cmd multi: Wrap errors for better errors.Is/As support. 2023-08-25 16:31:11 -05:00
connmgr multi: Consolidate waitgroup logic. 2023-10-28 01:48:52 -05:00
container/apbf apbf: Prepare v1.0.1. 2023-02-24 13:56:47 -06:00
contrib docker: Update image to golang:1.22.1-alpine3.19. 2024-03-11 17:35:50 -05:00
crypto build: Add dupword linter. 2023-08-25 12:35:55 -05:00
database database: Use TempDir to create temp test dirs. 2023-06-15 15:05:45 -05:00
dcrec secp256k1: add support for resource constrained environments (TinyGo) 2024-03-19 16:05:24 +00:00
dcrjson multi: Remove a bunch of dup words in comments. 2023-08-23 14:13:51 -05:00
dcrutil dcrutil: Use os.UserHomeDir in appDataDir. 2023-10-04 19:08:13 -05:00
docs docs: Add release notes for v1.8.1. 2023-10-08 23:01:00 -05:00
gcs multi: Remove a bunch of dup words in comments. 2023-08-23 14:13:51 -05:00
hdkeychain hdkeychain: Prepare v3.1.1. 2023-06-08 12:48:14 -05:00
internal netsync: Export opaque peer and require it in API. 2023-10-28 01:51:49 -05:00
lru multi: Go 1.19 doc comment formatting. 2022-07-30 04:08:58 -05:00
math/uint256 multi: Remove a bunch of dup words in comments. 2023-08-23 14:13:51 -05:00
peer peer: provide better debug for queued nil messages 2023-11-13 10:47:44 -06:00
rpc/jsonrpc/types multi: Remove a bunch of dup words in comments. 2023-08-23 14:13:51 -05:00
rpcclient multi: Wrap errors for better errors.Is/As support. 2023-08-25 16:31:11 -05:00
sampleconfig sampleconfig: Use embed with external files. 2023-09-18 03:32:50 -05:00
txscript multi: Wrap errors for better errors.Is/As support. 2023-08-25 16:31:11 -05:00
wire wire: Mark legacy message types as deprecated. 2023-12-20 15:37:22 -06:00
.dockerignore docker: Add dockerfiles for running dcrd nodes. 2018-07-07 05:33:53 -05:00
.gitignore main: Update .gitignore for Go1.18. 2022-03-10 11:32:01 -06:00
.golangci.yml build: Add errorlint linter. 2023-08-28 14:53:30 -05:00
blockdb.go blockchain: Move package to internal. 2022-05-30 15:32:41 -05:00
cert_test.go multi: Don't use deprecated ioutil package. 2021-09-01 06:09:37 -05:00
CHANGES multi: Use https links where available. 2019-06-18 14:20:06 -05:00
config_test.go main: improve test flag handling 2023-06-28 20:18:44 -05:00
config.go sampleconfig: Use embed with external files. 2023-09-18 03:32:50 -05:00
dcrd.go main: Add read header timeout to profile server. 2023-09-21 11:27:27 -05:00
doc.go config: Minor description consistency cleanup. 2022-12-05 14:11:05 -06:00
go.mod main: Use release version of dcrtest framework. 2023-06-09 12:22:00 -05:00
go.sum main: Use release version of dcrtest framework. 2023-06-09 12:22:00 -05:00
ipc.go server: Add bound addresses IPC events 2022-11-23 13:26:07 -06:00
LICENSE main: Update license to 2024. 2024-02-07 10:50:28 -06:00
lint.sh build: Correct missing shebang in lint script. 2023-07-25 15:57:50 -05:00
log.go main: Tweak runtime GC params for Go 1.19. 2022-11-17 09:26:58 -06:00
networkparams_test.go multi: Go 1.19 doc comment formatting. 2022-07-30 04:08:58 -05:00
params.go chaincfg: Start v3 module dev cycle. 2020-01-29 13:24:14 -06:00
README.md docs: Update README.md to required Go 1.21/1.22. 2024-02-09 13:39:47 -06:00
require.go main: Don't include requires in build. 2023-06-09 12:24:01 -05:00
rpcadaptors.go mempool: Remove ProcessTransaction rate limit. 2022-06-29 13:07:06 -05:00
run_tests.sh build: Move lint logic to its own script. 2023-07-24 12:24:38 -05:00
SECURITY.md docs: Add SECURITY.md file. 2021-08-25 03:45:36 -05:00
server.go server: Update required minimum protocol version. 2024-02-19 17:38:20 -06:00
service_windows.go multi: Wrap errors for better errors.Is/As support. 2023-08-25 16:31:11 -05:00
signal_syscall.go main: Remove old style build constraints. 2022-12-05 09:04:01 -06:00
signal.go main: Convert signal handling to use context. 2019-04-01 14:09:07 -05:00
upnp.go build: update golangci-lint to v1.44.1 2022-02-18 12:48:40 -06:00

dcrd

Build Status ISC License Doc Go Report Card

Decred Overview

Decred 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 Decred without the input of the community. A unit of the currency is called a decred (DCR).

https://decred.org

Latest Downloads

https://decred.org/downloads/

Core software:

  • dcrd: a Decred full node daemon (this)
  • dcrwallet: a CLI Decred wallet daemon
  • dcrctl: a CLI client for dcrd and dcrwallet

Bundles:

What is dcrd?

dcrd is a full node implementation of Decred written in Go (golang).

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

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

It important to note that dcrd does NOT include wallet functionality. Users who desire a wallet will need to use dcrwallet(CLI) or Decrediton(GUI).

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 Decred cryptocurrency.

The full node distinction is important, since full nodes are not the only type of software participating in the Decred 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 dcrd?

As described in the previous section, the Decred 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 dcrd 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 dcrd 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 dcrwallet (CLI) and Decrediton (GUI). It is also ideal for businesses and services that need the most reliable and accurate data about transactions.

  • 16 GB disk space (as of April 2022, increases over time, ~2 GB/yr)
  • 2 GB memory (RAM)
  • ~150 MB/day download, ~1.5 GB/day upload
    • Plus one-time initial download of the entire block chain
  • Windows 10 (server preferred), macOS, Linux
  • High uptime

Getting Started

So, you've decided to help the network by running a full node. Great! Running dcrd is simple. All you need to do is install dcrd 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 9108.

Installing and updating

Binaries (Windows/Linux/macOS)

Binary releases are provided for common operating systems and architectures. The easiest method is to download Decrediton from the link below, which will include dcrd. Advanced users may prefer the Command-line app suite, which includes dcrd and dcrwallet.

https://decred.org/downloads/

  • How to verify binaries before installing: https://docs.decred.org/advanced/verifying-binaries/
  • How to install the CLI Suite: https://docs.decred.org/wallets/cli/cli-installation/
  • How to install Decrediton: https://docs.decred.org/wallets/decrediton/decrediton-setup/

Build from source (all platforms)

Install Dependencies
  • Go 1.21 or 1.22

    Installation instructions can be found here: https://golang.org/doc/install. Ensure Go was installed properly and is a supported version:

    $ go version
    $ go env GOROOT GOPATH
    

    NOTE: GOROOT and GOPATH must not be on the same path. Since Go 1.8 (2016), GOROOT and GOPATH are set automatically, and you do not need to change them. However, you still need to add $GOPATH/bin to your PATH in order to run binaries installed by go get and go install (On Windows, this happens automatically).

    Unix example -- add these lines to .profile:

    PATH="$PATH:/usr/local/go/bin"  # main Go binaries ($GOROOT/bin)
    PATH="$PATH:$HOME/go/bin"       # installed Go projects ($GOPATH/bin)
    
  • Git

    Installation instructions can be found at https://git-scm.com or https://gitforwindows.org.

    $ git version
    
Windows Example
PS> git clone https://github.com/decred/dcrd $env:USERPROFILE\src\dcrd
PS> cd $env:USERPROFILE\src\dcrd
PS> go install . .\cmd\...
PS> dcrd -V

Run the dcrd executable now installed in "$(go env GOPATH)\bin".

Unix Example

This assumes you have already added $GOPATH/bin to your $PATH as described in dependencies.

$ git clone https://github.com/decred/dcrd $HOME/src/dcrd
$ git clone https://github.com/decred/dcrctl $HOME/src/dcrctl
$ (cd $HOME/src/dcrd && go install . ./...)
$ (cd $HOME/src/dcrctl && go install)
$ dcrd -V

Run the dcrd executable now installed in $GOPATH/bin.

Building and Running OCI Containers (aka Docker/Podman)

The project does not officially provide container images. However, all of the necessary files to build your own lightweight non-root container image based on scratch from the latest source code are available in contrib/docker.

It is also worth noting that, to date, most users typically prefer to run dcrd directly, without using a container, for at least a few reasons:

  • dcrd is a static binary that does not require root privileges and therefore does not suffer from the usual deployment issues that typically make containers attractive
  • It is harder and more verbose to run dcrd from a container as compared to normal:
    • dcrd is designed to automatically create a working default configuration which means it just works out of the box without the need for additional configuration for almost all typical users
    • The blockchain data and configuration files need to be persistent which means configuring and managing a docker data volume
    • Running non-root containers with docker requires special care in regards to permissions

Running Tests

All tests and linters may be run using the script run_tests.sh. Generally, Decred only supports the current and previous major versions of Go.

./run_tests.sh

Contact

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

https://decred.org/community/

Issue Tracker

The integrated github issue tracker is used for this project.

Documentation

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

License

dcrd is licensed under the copyfree ISC License.