dcrd v1.4.0-rc3
Pre-releaseThis release of dcrd introduces a new consensus vote agenda which allows the
stakeholders to decide whether or not to activate changes needed to modify the
sequence lock handling which is required for providing full support for the
Lightning Network. For those unfamiliar with the voting process in Decred, this
means that all code in order to make the necessary changes is already included
in this release, however its enforcement will remain dormant until the
stakeholders vote to activate it.
It also contains smart fee estimation, performance enhancements for block relay
and processing, a major internal restructuring of how unspent transaction
outputs are handled, support for whitelisting inbound peers to ensure service
for your own SPV (Simplified Payment Verification) wallets, various updates to
the RPC server such as a new method to query the state of the chain and more
easily supporting external RPC connections over TLS, infrastructure
improvements, and other quality assurance changes.
The following Decred Change Proposals (DCP) describes the proposed changes in detail:
It is important for everyone to upgrade their software to this latest release
even if you don't intend to vote in favor of the agenda.
Downgrade Warning
The database format in v1.4.0 is not compatible with previous versions of the
software. This only affects downgrades as users upgrading from previous
versions will see a lengthy one time database migration.
Once this migration has been completed, it will no longer be possible to
downgrade to a previous version of the software without having to delete the
database and redownload the chain.
Notable Changes
Fix Lightning Network Sequence Locks Vote
In order to fully support the Lightning Network, the current sequence lock
consensus rules need to be modified. A new vote with the id fixlnseqlocks
is
now available as of this release. After upgrading, stakeholders may set their
preferences through their wallet or Voting Service Provider's (VSP) website.
Smart Fee Estimation (estimatesmartfee
)
A new RPC named estimatesmartfee
is now available which returns a suitable
fee rate for transactions to use in order to have a high probability of them
being mined within a specified number of confirmations. The estimation is based
on actual network usage and thus varies according to supply and demand.
This is important in the context of the Lightning Network (LN) and, more
generally, it provides services and users with a mechanism to choose how to
handle network congestion. For example, payments that are high priority might
be willing to pay a higher fee to help ensure the transaction is mined more
quickly, while lower priority payments might be willing to wait longer in
exchange for paying a lower fee. This estimation capability provides a way to
obtain a fee that will achieve the desired result with a high probability.
Support for Whitelisting Inbound Peers
When peers are whitelisted via the --whitelist
option, they will now be
allowed to connect even when they would otherwise exceed the maximum number of
peers. This is highly useful in cases where users have configured their wallet
to use SPV mode and only connect to dcrd instances that they control for
increased privacy and guaranteed service.
Several Speed Optimizations
Similar to previous releases, this release also contains several enhancements to
improve speed for the initial sync process, validation, and network operations.
In order to achieve these speedups, there is a lengthy one time database
migration, as previously mentioned, that typically takes anywhere from 30
minutes to an hour to complete depending on hardware.
Faster Tip Block Relay
Blocks that extend the current best chain are now relayed to the network
immediately after they pass the initial sanity and contextual checks, most
notably valid proof of work. This allows blocks to propagate more quickly
throughout the network, which in turn improves vote times.
UTXO Set Restructuring
The way the unspent transaction outputs are handled internally has been
overhauled to significantly decrease the time it takes to validate blocks and
transactions. While this has many benefits, probably the most important one
for most stakeholders is that votes can be cast more quickly which helps reduce
the number of missed votes.
RPC Server Changes
New Chain State Query RPC (getblockchaininfo
)
A new RPC named getblockchaininfo
is now available which can be used to query
the state of the chain including details such as its overall verification
progress during initial sync, the maximum supported block size, and that status
of consensus changes (deployments) which require stakeholder votes. See the
JSON-RPC API Documentation
for API details.
Removal of Vote Creation RPC (createrawssgen
)
The deprecated createrawssgen
, which was previously used to allow creating a
vote via RPC is no longer available. Votes are time sensitive and thus it does
not make sense to create them offline.
Updates to Block and Transaction RPCs
The getblock
, getblockheader
, getrawtransaction
, and
searchrawtransactions
RPCs now contain additional information such as the
extradata
field in the header, the expiry
field in transactions, and the
blockheight
and blockindex
of the block that contains a transaction if it
has been mined. See the JSON-RPC API Documentation
for API details.
Built-in Support for Enabling External TLS RPC Connections
A new command line parameter (--altdnsnames
) and environment variable
(DCRD_ALT_DNSNAMES
) can now be used before the first launch of drcd to specify
additional external IP addresses and DNS names to add during the certificate
creation that are permitted to connect to the RPC server via TLS. Previously,
a separate tool was required to accomplish this configuration.
Changelog
All commits since the last release may be viewed on GitHub here.
Protocol and network:
- chaincfg: Add checkpoints for 1.4.0 release (decred/dcrd#1547)
- chaincfg: Introduce agenda for fixlnseqlocks vote (decred/dcrd#1578)
- multi: Enable vote for DCP0004 (decred/dcrd#1579)
- peer: Add support for specifying ua comments (decred/dcrd#1413)
- blockmanager: Fast relay checked tip blocks (decred/dcrd#1443)
- multi: Latest consensus active from simnet genesis (decred/dcrd#1482)
- server: Always allow whitelisted inbound peers (decred/dcrd#1516)
Transaction relay (memory pool):
- blockmanager: handle txs in invalid blocks (decred/dcrd#1430)
- mempool: Remove potential negative locktime check (decred/dcrd#1455)
- mempool: Stake-related readability improvements (decred/dcrd#1456)
RPC:
- multi: Include additional fields on RPC tx results (decred/dcrd#1441)
- rpcserver: Allow scripthash addrs in createrawsstx (decred/dcrd#1444)
- rpcserver: Remove createrawssgen RPC (decred/dcrd#1448)
- rpcclient: support getchaintips RPC (decred/dcrd#1469)
- multi: Add getblockchaininfo rpc (decred/dcrd#1479)
- rpcserver: Adds ability to allow alternative dns names for TLS (decred/dcrd#1476)
- multi: Cleanup recent alt DNS names additions (decred/dcrd#1493)
- multi: Cleanup getblock and getblockheader RPCs (decred/dcrd#1497)
- multi: Return total chain work in RPC results (decred/dcrd#1498)
- rpcserver: Improve GenerateNBlocks error message (decred/dcrd#1507)
- rpcserver: Fix verify progress calculation (decred/dcrd#1508)
- rpcserver: Fix sendrawtransaction error code (decred/dcrd#1512)
- blockchain: Notify stake states after connected block (decred/dcrd#1515)
- rpcserver: bump version to 5.0. (decred/dcrd#1531)
- rpcclient: support getblockchaininfo RPC (decred/dcrd#1539)
- rpcserver: update block template reconstruction (decred/dcrd#1567)
dcrd command-line flags and configuration:
- config: add --maxsameip to limit # of conns to same IP (decred/dcrd#1517)
Documentation:
- docs: Update docs for versioned modules (decred/dcrd#1391)
- docs: Update for fees package (decred/dcrd#1540)
- docs: Revamp main README.md and update docs (decred/dcrd#1447)
- docs: Use relative versions in contrib checklist (decred/dcrd#1451)
- docs: Use the correct binary name (decred/dcrd#1461)
- docs: Add github pull request template (decred/dcrd#1474)
- docs: Use unix line ending in mod hierarchy gv (decred/dcrd#1487)
- docs: Add README badge and link for goreportcard (decred/dcrd#1492)
- sampleconfig: Fix proxy typo (decred/dcrd#1513)
Developer-related package and module changes:
- release: Bump module versions and deps (decred/dcrd#1541)
- build: Tidy module sums with go mod tidy (decred/dcrd#1408)
- blockchain: update BestState (decred/dcrd#1416)
- mempool: tweak trace logs (decred/dcrd#1429)
- blockchain: Correct best pool size on disconnect (decred/dcrd#1431)
- multi: Make use of new internal version package (decred/dcrd#1435)
- peer: Protect handlePongMsg with p.statsMtx (decred/dcrd#1438)
- limits: Make limits package internal (decred/dcrd#1436)
- indexers: Remove unneeded existsaddrindex iface (decred/dcrd#1439)
- blockchain: Reduce block availability assumptions (decred/dcrd#1442)
- peer: Provide immediate queue inventory func (decred/dcrd#1443)
- server: Add infrastruct for immediate inv relay (decred/dcrd#1443)
- blockchain: Add new tip block checked notification (decred/dcrd#1443)
- multi: remove chainState dependency in rpcserver (decred/dcrd#1417)
- mining: remove chainState dependency (decred/dcrd#1418)
- multi: remove chainState deps in server & cpuminer (decred/dcrd#1419)
- blockmanager: remove block manager chain state (decred/dcrd#1420)
- multi: move MinHighPriority into mining package (decred/dcrd#1421)
- multi: add BlkTmplGenerator (decred/dcrd#1422)
- multi: add cpuminerConfig (decred/dcrd#1423)
- multi: Move update blk time to blk templ generator (decred/dcrd#1454)
- multi: No stake height checks in check tx inputs (decred/dcrd#1457)
- blockchain: Separate tx input stake checks (decred/dcrd#1452)
- blockchain: Ensure no stake opcodes in tx sanity (decred/dcrd#1453)
- blockchain: Move finalized tx func to validation (decred/dcrd#1465)
- blockchain: Move unique coinbase func to validate (decred/dcrd#1466)
- blockchain: Store interrupt channel with state (decred/dcrd#1467)
- multi: Cleanup and optimize tx input check code (decred/dcrd#1468)
- blockmanager: Avoid duplicate header announcements (decred/dcrd#1473)
- dcrjson: additions for pay to contract hash (decred/dcrd#1260)
- multi: Break blockchain dependency on dcrjson (decred/dcrd#1488)
- chaincfg: Unexport internal errors (decred/dcrd#1489)
- multi: Cleanup the unsupported dcrwallet commands (decred/dcrd#1478)
- multi: Rename ThresholdState to NextThresholdState (decred/dcrd#1494)
- dcrjson: Add listtickets command (decred/dcrd#1267)
- multi: Add started and done reorg notifications (decred/dcrd#1495)
- blockchain: Remove unused CheckWorklessBlockSanity (decred/dcrd#1496)
- blockchain: Simplify block template checking (decred/dcrd#1499)
- blockchain: Only mark nodes modified when modified (decred/dcrd#1503)
- blockchain: Cleanup and optimize stake node logic (decred/dcrd#1504)
- blockchain: Separate full data context checks (decred/dcrd#1509)
- blockchain: Reverse utxo set semantics (decred/dcrd#1471)
- blockchain: Convert to direct single-step reorgs (decred/dcrd#1500)
- multi: Migration for utxo set semantics reversal (decred/dcrd#1520)
- blockchain: Make version 5 update atomic (decred/dcrd#1529)
- blockchain: Simplify force head reorgs (decred/dcrd#1526)
- secp256k1: Correct edge case in deterministic sign (decred/dcrd#1533)
- dcrjson: Add gettransaction txtype/ticketstatus (decred/dcrd#1276)
- txscript: Use ScriptBuilder more (decred/dcrd#1519)
- fees: Add estimator package (decred/dcrd#1434)
- multi: Integrate fee estimation (decred/dcrd#1434)
Testing and Quality Assurance:
- multi: Use temp directories for database tests (decred/dcrd#1404)
- multi: Only use module-scoped data in tests (decred/dcrd#1405)
- blockchain: Use temp dirs for fullblocks test (decred/dcrd#1406)
- database: Use module-scoped data in iface tests (decred/dcrd#1407)
- travis: Update for Go1.11 and module builds (decred/dcrd#1415)
- indexers: Use testable bucket for existsaddrindex (decred/dcrd#1440)
- txscript: group numeric encoding tests with their opcodes (decred/dcrd#1382)
- txscript: add p2sh opcode tests (decred/dcrd#1381)
- txscript: add stake opcode tests (decred/dcrd#1383)
- main: add address encoding magic constants test (decred/dcrd#1458)
- chaingen: Only revoke missed tickets once (decred/dcrd#1484)
- chaingen/fullblocktests: Add disapproval tests (decred/dcrd#1485)
- multi: Resurrect regression network (decred/dcrd#1480)
- multi: Use regression test network in unit tests (decred/dcrd#1481)
- main: move cert tests to a separated file (decred/dcrd#1502)
- mempool: Accept test mungers for create signed tx (decred/dcrd#1576)
- mempool: Implement test harness seq lock calc (decred/dcrd#1577)
Misc:
- release: Bump for 1.4 release cycle (decred/dcrd#1414)
- multi: Make changes suggested by Go 1.11 gofmt -s (decred/dcrd#1415)
- build: Remove dep toml and lock file (decred/dcrd#1460)
- docker: Update to go 1.11 (decred/dcrd#1463)
- build: Support MacOS sed for obtaining module list (decred/dcrd#1483)
- multi: Correct a few typos found by misspell (decred/dcrd#1490)
- multi: Address some golint complaints (decred/dcrd#1491)
- multi: Remove unused code (decred/dcrd#1505)
- release: Bump siphash version to v1.2.1 (decred/dcrd#1538)
- release: Bump module versions and deps (decred/dcrd#1541)
- Fix required version of stake module (decred/dcrd#1549)
- release: Tidy module files with published versions (decred/dcrd#1543)
- mempool: Fix required version of mining module (decred/dcrd#1551)
Code Contributors (alphabetical order):
- Corey Osman
- Dave Collins
- David Hill
- Dmitry Fedorov
- Donald Adu-Poku
- ggoranov
- githubsands
- J Fixby
- Jonathan Chappelow
- Josh Rickmar
- Matheus Degiovani
- Sarlor
- zhizhongzhiwai