All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog and this project adheres to Semantic Versioning.
- Tickle a peer whenever a message is received.
- Correct log messages from peer manager.
- Peers timeout more aggressively.
- Update LTS Haskell & upstream dependencies.
- Add compatibility with latest LTS Haskell.
- Make compatible with latest haskoin-core.
- Use DuplicateRecordFields and OverloadedRecordDot.
- Simplify pub/sub queues.
- Multiple refactoring passes.
- Set default port for peers where it is unset.
- Support setting up and connecting to IPv6 peers.
- Reduce verbosity on incoming header decode test.
- Show appropriate error message upon receiving empty headers.
- Display more details about invalid incoming headers.
- Do not connect to more than the maximum number of peers.
- Display message command that disconnects a peer.
- Correct disconnect timeout algorithm bug.
- Add randomised timeouts to avoid disconnecting all peers.
- Do not start chain actor until database initialized.
- Depend on haskoin-core-0.17.3.
- Support for Bitcoin Cash November 2020 hard fork.
- BlockHeaders instance for ReaderT Chain.
- Add support for column families.
- Use new Haskell bindings for RocksDB.
- Correct flawed peer locking logic in Chain actor.
- Massively refactor everything in a non-backwards-compatible way.
- Use MIT license.
- Bump haskoin-core.
- Bump secp256k1-haskell.
- Fix getting stuck on a single peer.
- Depend on Haskoin Store 0.13.3.
- Better code organisation.
- Add a test suite that simulates network instead of connecting to real one.
- Revert including multiline decoding error text in logs.
- Include header decoding error text in logs.
- Improve logging.
- Set peer too old time
- Disconnect old peers after 48 hours instead of 30 minutes.
- Move modules out of Network.Haskoin namespace.
- Add better and more logging.
- Change Manager module name and related values to PeerManager.
- Remove unnecessary logging.
- Better log messages.
- Less verbose debug logging.
- Better log messages.
- More aggressive peer discovery.
- Peers are disconnected automatically after awhile.
- Lower bound versions for some dependencies.
- Update to support new
NetworkAddress
data structure fromhaskoin-core
.
- No longer support storing peers in db as performance tradeoff doesn't justify it.
- Really store peers in db.
- Demote some logging to debug level.
- Add
-O2
optimisations to GHC.
- Increase debugging information where application freezes.
- Increase debugging information.
- Increase version of haskoin-core to 0.9.0.
- Fix some tests.
- More debugging.
- Be defensive against duplicate peers.
- Increase interval between housekeeping pings.
- Replace peers in database atomically.
- Randomize known peers instead of keeping scores.
- Simplify peer management code to avoid freezes.
- Merge logic for chain and manager.
- Do not record new peers in database when peer discovery is disabled.
- Don't spam best block events.
- Correct display of milliseconds in log.
- Correct bug when receiving headers from unknown peer.
- Simplify chain syncing code.
- Peer dies immediately when receiving a bad message.
- Keep track of last synced header from a peer to avoid endless loops on large reorgs.
- Use an STM listener instead of a publisher for the node API.
- Expose
ChainMessage
andManagerMessage
types fromHaskoin.Node
module.
- Corrected documentation for
killPeer
function. - Leave time out of logic code.
- Peers are now killed directly instead of through peer manager.
- Chain no longer needs peer manager.
- Compatibility with base 4.12.
- Update base to 4.9.
- Allow to easily obtain a peer's publisher.
- Versioning for chain and peer database.
- Automatic purging of chain and peer database when version changes.
- Add extra timers.
- Add publishers to every peer.
- Full reimplementation of node API.
- Simplify peer selection and management.
- Merge manager and peer events.
- Rename configuration variables for node.
- Separate logic from actors for peer manager and chain.
- Remove irrelevant fields from peer information.
- Remove unreliable peer block head tracking.
- Remove dependency on deprecated binary conduits.
- Remove Bloom filter support from manager.
- Remove unreliable peer request tracking code.
- Remove separate manager events.
- Fix bug where peer height did not update in certain cases.
- Documentation everywhere.
- Make compatible with NQE 0.5.
- Use supervisor only in peer manager.
- API quality of life changes.
- Exposed module is now only
Haskoin.Node
.
- No more direct access to internals.
- Improve dependency definitions.
- Dependency
sec256k1
changes tosecp256k1-haskell
.
- New
CHANGELOG.md
file. - Use
nqe
for concurrency. - Peer discovery.
- RocksDB peer and block header storage.
- Support for Merkle blocks.
- Split out of former
haskoin
repository. - Use hpack and
package.yaml
. - Old
haskoin-node
package now renamed toold-haskoin-node
and deprecated.
- Removed Old Haskoin Node package completely.
- Removed Stylish Haskell configuration file.
- Remvoed
haskoin-core
andhaskoin-wallet
packages from this repository.