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
- Disable
NO_SLOW
as an option.
- Allow to set
NO_XPUB
to disable extended public keys.
- Move
/dbstats
and/mempool
to slow endpoints section.
- Cull old transactions from mempool automatically.
- Dummy release: update upstream LTS Haskell dependency in
stack.yaml
file.
- Metric to track time to import a new block.
- Parameter
no_compact
allowed for backwards compatiblity.
- Parameter
noCompact
corrected formultiaddr
endpoint.
- Prune obsolete transactions from outgoing peer requests.
- Remove unnecessary module imports.
- Only sync mempool once for each peer.
- Dummy release to bump upstream dependency on
haskoin-node
.
- Dummy release to bump upstream dependency on
statsd-rupp
.
- Allow to toggle RocksDB Bloom filters off.
- Correct command-line option behaviour for some rarely-used parametres.
- Lock Redis before checking if the database needs to be pruned, rather than after.
- Lock xpub in Redis to avoid computing derivations multiple times.
- Rename redis-min-gap to redis-min-addrs to match environment config variable.
- Fix Redis bug where old keys weren't pruned quickly enough.
- Remove Nomad-specific environment variable parsing for statsd.
- Use default GHC garbage collector.
- Compile with GHC 9.8.2.
- Enable optimisations.
- Use an optimised topological sort for importing transactions in bulk.
- Use default optimisation settings.
- Use default RocksDB parameters.
- Bump upstream dependencies.
- Test suite now working again.
- Bump upstream dependencies.
- Transactions received via POST are just forwarded to every peer without delay or validation.
- Bump dependency on NQE to resolve async issue.
- Fix comparison function for unspent outputs.
- Avoid deprecated
param
function from Scotty.
- Correct web exception output format (JSON).
- Correct block path parsing order.
- Upgrade
scotty
dependency and fix incompatibilities.
- Add cache height stats.
- Add database iterator stats.
- Detect xpub gap more strictly.
- Use statsd-rupp instead of ekg-stats.
- All stat reporting keys changed.
- Remove unsafeInterleaveIO from Web.hs.
- Remove unnecessary WAI middlewares.
- Remove server and client error reporting per endpoint.
- Code refactoring and simplification.
- Improve logging output.
- Do not impose time limits on REST API responses.
- Remove loop in Blockchain.info unspents function.
- Correct documentation for /blockchain/rawblock endpoint.
- Fix no match in record selector address for coinbases.
- Add compatibility with latest nightly LTS Haskell.
- Compatibility with latest haskoin-core and haskoin-node packages.
- Use DuplicateRecordFields and OverloadedRecordDot language extensions.
- Modernize package in a backwards-incompatible manner.
- Refactor package extensively.
- Revert to older LTS Haskell to attempt to resolve memory leak.
- Remove unnecessary lock release.
- Be more aggressive caching individual transactions.
- Introduce a periodic cache mempool sync task.
- Perform health check in separate thread.
- Do not sync mempool to Redis if node is not up-to-date.
- Improve caching ingestion performance.
- Fee field added to Blockchain.info-style export-history endpoint.
- Bump version due to Git mistake.
- IPv6 peer support.
- Correct lazy bytestring deserialization algorithm for web client.
- Simplify function in Cache module.
- Bump depenedencies.
- Spenders now embedded into tx objects in database for performance.
- Use faster IORef instead of slow TVar when ingesting.
- Use mutable hash tables when ingesting.
- Allow to disable unscalable API endpoints.
- Allow to set query timeouts.
- Off-by-one error when importing change addresses to cache.
- Add change addresses to cache when necessary.
- Correct fee calculation for blocks that do not claim all rewards.
- Correct scale of cache pruning code.
- Always prune to 80% of max cache size.
- Avoid doing a hissy fit on transient cache issue.
- Prune a little more cache to allow for new keys.
- Prune cache more often.
- Return empty addresses in xpub balances call.
- Avoid notifying same transactions in mempool.
- Use better Fourmolu format.
- Be more precise when counting retrieved items.
- Avoid transactions duplicated in xpub data.
- Refactor some functions to make them more robust.
- Optimisations for various Blockchain endpoints.
- More accurate item counts for various web endpoints.
- Record cache index time just once per xpub.
- Add suffix cached to cache entries to avoid conflicts with data entries.
- Bring dots back and avoid stats hacks.
- Fix typo.
- Replace dots for underscores in metrics.
- Automatic formatting.
- Improve cache debug logging.
- Add item count to 'all' query metrics.
- Improve metrics.
- Get lock before importing transactions to cache.
- Make cache updates lightweight.
- Fix idempotent transaction elimination bug.
- Configurable Blockchain price URLs.
- Reuse HTTP connections with wreq sessions.
- Upstream improvements on Base58 performance.
- Fixed recursion bug in Blockchain format conversion function.
- Correct notifications subsystem.
- Correct internal dependency.
- Correct output freeing algorithm.
- Report errors freeing outputs.
- Report all deleted mempool transactions.
- Crash on certain data corruption.
- Always have a previous output object in Blockchain inputs.
- WebSocket support.
- Testnet4 support.
- Dummy version increase to signal upstream update of Haskoin Core.
- Correct test that was reversed in previous version.
- Mempool is no longer synced by default to fix public Bitcoin Core regression.
- Put derivations stat inside database.
- Added counters for database retrievals.
- Added counter for xpub derivations.
- Removed some buggy or unnecessary stats.
- Improve web server statistics.
- Endpoint to delete an xpub from cache.
- Debugging when reverting block.
- Negative (headers - blocks) diff shown incorrectly.
- Infinite loop when removing a block's coinbase transaction.
- Blockchain.info endpoint:
q/pubkeyhash/:addr
. - Blockchain.info endpoint:
q/getsentbyaddress/:addr
. - Blockchain.info endpoint:
q/pubkeyaddr/:addr
. - Configurable request body limit size.
- Return output in satoshi for some endpoints.
- Return 404 in case of bad address.
- Blockchain.info endpoint:
q/addresstohash/:addr
. - Blockchain.info endpoint:
q/addrpubkey/:pubkey
. - Blockchain.info endpoint:
q/hashpubkey/:pubkey
. - Blockchain.info endpoint:
q/getblockcount
. - Blockchain.info endpoint:
q/latesthash
. - Blockchain.info endpoint:
q/bcperblock
. - Blockchain.info endpoint:
q/txtotalbtcoutput/:txid
. - Blockchain.info endpoint:
q/txtotalbtcinput/:txid
. - Blockchain.info endpoint:
q/txfee/:txid
. - Blockchain.info endpoint:
q/txresult/:txhash/:addr
. - Blockchain.info endpoint:
q/getreceivedbyaddress/:addr
. - Blockchain.info endpoint:
q/addressbalance/:addr
. - Blockchain.info endpoint:
q/addressfirstseen/:addr
. - Support xpubs in
blockchain/rawaddr
endpoint.
- Various latest blocks endpoint fixes.
- Allow empty parameters in Blockchain.info POST requests.
- Upstream fixes for unknown inv types.
- Fix limits for legacy endpoints.
- Alias for Blockchain.info raw address endpoint.
- Fix unknown message types without payload upstream.
- Randomise peer timeouts upstream.
- Fix binary search algorithm for blocks upstream.
- Add Blockchain.info latest block endpoint.
- Add Blockchain.info unconfirmed-transactions endpoint.
- Add Blockchain.info blocks for one day endpoint.
- Fix special case for zero limit.
- Fix cache bug when too many transactions in mempool.
- Use rationals for Blockchain.info export-history endpoint arithmetics.
- Support for Blockchain.info export-history endpoint.
- Use strict bytestring decoder for HTTP API client.
- Use Base58 addresses by default in Blockchain.info balance querios.
- Errors should also contain CORS headers.
- Blockchain.info raw address limit should use
limit
parametre and notn
.
- Stream multiple transactions when requested.
- Fix missing unspent outputs.
- Remove unnecessary performance optimisations.
- Reduce balance retrievals for xpubs.
- Hack UTXO ordering to avoid unwanted behaviours.
- Do not merge conduits when there are too many.
- Data type for RequestTooLarge was missing.
- Log HTTP request bodies.
- Remove web request timeout.
- Do not ignore unknown start tx anchors in conduits.
- Use fast transaction counting in cache.
- Use WAI middlewares to manage stats.
- Do not use lazy parsers for incoming data that may throw exceptions.
- Do not allow incoming POST requests of unlimited body size.
- Limit number of simultaneous xpubs being cached.
- Improve conduit merging algorithm.
- Timeouts and token bucket for web requests.
- Configurable price fetch interval.
- Fix web.all stat.
- Simplify stats.
- Implement Blockchain.info block height.
- Implement Blockchain.info raw address.
- Implement Blockchain.info balances.
- Make Blockchain.info unspent endpoint more efficient.
- Make Blockchain.info xpubs endpoint more efficient.
- Use compact JSON serialization by default everywhere.
- Fix serialization bug with unspents.
- Fix serialization bug for health check.
- Fix serialization bugs for web data types.
- Support for legacy block endpoints.
- Serialization now uses bytes library and does interleaved IO.
- Allow comma-separated values in multiaddr.
- Throw error when offset exceeded instead of truncating it.
- Do not compute balances separately for loose addresses when part of an xpub.
- Do not fetch entire transaction list for loose addresses.
- Transaction count in wallet object is just a synonym for filtered tx count.
- Use conduits to prevent over-fetching transactions from database.
- Make hex value encoding compatible with Java BigInteger decoder.
- Allow negative confirmations for compatibility with old API.
- Filters for transactions in multiaddr endpoint.
- Release to fix unintentional upload.
- Using a tx_index that results in a txid conflict returns a 409 - Conflict.
- Numeric txid now 53 bits long and doesn't return transactions when hashes collide.
- Do not overcount statistics.
- Transaction index now simply encodes txid as a long number (sorry JS users).
- Optimise encoding of JSON data for Blockchain.info API.
- Narrow down the balance for transactions to onlyShow set.
- Make unspent algorithm more efficient.
- Support for Blockchain.info API unspent endpoint.
- Fix RBF transactions on Blockchain.info API.
- No more pruning of old mempool transactions.
- Correct error computing wallet balances.
- Use whole active set when computing results for multiaddr.
- Compute correct count of transactions for wallet.
- Caching mempool is not much slower when pruning, so reversing that change.
- Only prune mempool every ten minutes or so.
- No more cache eviction endpoint.
- More metrics for cache.
- Support HTTP GET for multiaddr endpoint.
- Prefix 'app.' in statsd when using Nomad variables.
- Statsd support and pleny of statistics.
- Removed use of sync lock for importing xpubs in cache due to volume.
- New options to control cache lock retry count and delay.
- Cache xpubs asyncrhonously.
- Mempool syncs fully every refresh cycle.
- Delete more than 1000 xpubs from Redis if needed.
- Attempt to get lock ten times in order to index a new xpub.
- Fix best block not set.
- Do not update cache best block if it is higher.
- Always respond to cache pings to avoid getting stuck.
- Be more careful about importing blocks to the cache.
- Reduce excessive cache logging.
- Correct bad arithmetics in cache cooldown.
- Debug log cache cooldown.
- Unlimited retry lock acquisition now works.
- Make locking tighter
- Reduce the number of things that cache do when pinged.
- Avoid filling the cache actor mailbox with pings.
- Correct a typo in cache code.
- Improve cache mempool sync algorithm.
- Make cache cooldown a number.
- Log every non-successful query.
- Use Redis TTL for cache cooldown.
- Mempool no longer gets saved in cache when node is not in sync.
- Change source of price data to https://blockchain.info/ticker.
- Do not expose Paths_haskoin_store module explicitly.
- Blockchain.info API compatibility for multiaddr and rawtx endpoints.
- Segwit fields are no longer omitted on incompatible networks.
- Upgrade Haskoin Core to support higher version on witness addresses.
- Fix block search by timestamp.
- Disable low latency garbage collector by default.
- Use GHC 8.10 and its low latency garbage collector.
- Optimise algorithm for fork safety check.
- Support for Bitcoin Cash hard fork.
- Configurable cache refresh time.
- Now request mempool when connecting even if already in sync.
- Add a delay to mempool sync to allow for block headers to catch up.
- Attempt to sync mempool whenever syncing is done or a new peer connects.
- Correct logic error when deleting superseded transactions.
- Simplify multiple algorithms to hopefully solve corruption bug.
- Allow to disable mempool transaction indexing via command line.
- Better locking around caching operations.
- Have a global cooldown on cache mempool updates.
- Fix address unspent retrieval using correct column family.
- Add support for column families and prefixes breaking database backwards compatibility.
- Fix another place where mempool sorting was wrong.
- Fix wrong sorting of mempool transactions in database.
- Do not use STM transactions because it is impossible to reason about preloading.
- Make importing blocks after mempool is populated faster.
- Reduce frequency of cache mempool updates.
- Remove cache lock retries.
- Do not use lock when caching a new xpub.
- Use new RocksDB Haskell bindings.
- Make headers - blocks diff configurable in health check.
- Simplify locking in cache.
- Minor refactoring.
- Only send one mempool message ever.
- Fix block heights endpoint URL.
- Remove asynchronous database retrieval permanently due to instability.
- Preload memory before freeing outputs.
- Asynchronous preloading only for blocks.
- Disable asynchronous preloading to prevent segmentation fault error.
- No more upper limit for mempool call.
- Health check uses minimum between last block and mempool tx.
- Pending mempool transactions health check.
- No more upper limit for mempool call.
- New format for health check.
- Upload with updated Cabal files.
- Fix outputs showing up as both spent and unspent.
- Simplify data structures used to hold uncommitted changes.
- Split StoreRead class in two.
- Improve pre-loading algorithms.
- Fix command line argument mappings to env vars.
- Do not complain when deleting non-existent unconfirmed txs.
- Fix corruption bug when deleting transactions during some reorgs.
- Fix tests on data package.
- Rename upstream address string functions.
- Concurrently load dependencies when importing transaction data.
- Import each transaction using STM.
- Rework logging.
- Refactor all block chain importing algorithms.
- Use peer locking when importing data.
- Change license to MIT.
- Make max peer count configurable.
- Prevent premature peer timeouts when importing blocks.
- Add Haskell web client code to data library.
- Use type-safe definitions for web paths and parameters.
- Support JSON pretty encoding and enable by default for some endpoints.
- Allow environment variables for configuration.
- Change command-line arguments to better fit GNU style.
- Refactor code to manipulate address balances.
- Improve logging.
- Rate-limit mempool importing.
- Do not add xpubs to cache if node not in sync.
- Do not import transactions to cache if no xpubs in cache.
- Refactor transaction importing logic extremely.
- Refactor memory database and writer.
- Fix BTC double-count transaction bug.
- Add missing xpub derive parameter to xpub evict documentation.
- Limit mempool API endpoint list.
- Raw JSON values are now wrapped in an object with a result property.
- Better logging when importing transactions into mempool.
- Transaction limit by block height works now.
- Revert concurrent retrieval changes from 0.29.1 and 0.29.0 to solve stability issues.
- Bitcoin Cash (BCH) replaces BTC as default network in CLI.
- Peer discovery enabled automatically if no peers specified in CLI.
- Use separate Stack configuration file for data package.
- Increase timeouts for manager and chain health checks.
- Perform xpub operations concurrently.
- BlockTx renamed to TxRef.
- Remove unnecessary monad transformers to simplify import code.
- Retrieve balances and unspent outputs concurrently when importing.
- Coin instance for Unspent in data package.
- Change the way that limits, start, and offset values are handled.
- Fix incorrect limit responses.
- Complete support for offset.
- Improve monad stack for cache.
- Support for offset in all endpoints where it makes sense.
- Sort after using the nub function or use Data.List.nub in exceptional cases.
- Don't do certain validity checks on confirmed transactions.
- Do not crash when syncing the blockchain from scratch on a populated cache.
- Replace nub function everywhere with faster version written using hash sets.
- Fix shared cache locking.
- Simplify cache block import code.
- Improve cache import performance.
- Do not call zadd or zrem in Redis with incorrect argument count.
- Do not use slow Transaction type in Logic.
- Improve logging while importing blocks.
- Better transaction import algorithm.
- Add information to some binary types for feature parity with JSON.
- Hide segwit data on non-segwit networks.
- Fix work which now always serialises as a number literal.
- Fix version display on health check.
- Fix wrong version of Haskoin Store Data dependency.
- Improve code organisation.
- Split data definitions and serialisation into its own package.
- Use mocking to simulate peers instead of connecting to the network while testing.
- Depend on latest version of Haskoin Core for faster JSON serialisation.
- Clean up confusing JSON encoding/decoding codebase.
- Implement faster JSON encoding using toEncoding from the Aeson library.
- Do not read full mempool so often from cache code.
- Depend on latest Haskoin Node that fixes debugging regression.
- Reduce non-debug log verbosity.
- Better Haskoin Node logging.
- Use set peer timeout instead of constant in block store.
- Allow setting peer timeouts in command line.
- Bump Haskoin Node dependency to fix another premature timeout condition.
- Touch syncing peer whenever we process one of its blocks to avoid premature timeout.
- Better algorithm to avoid importing transaction multiple times in cache.
- Depend on latest Haskoin Node.
- Do not storm the cache with mempool transactions.
- Do not ignore deleted incoming transactions.
- Do not do RBF checks when replacing a mempool transaction with a confirmed one.
- Streamline mempool transaction importing.
- Fix transactions not recorded in cache mempool set.
- Fix transactions being downloaded multiple times.
- Do not store orphan transactions in database.
- Use sets for incoming transactions instead of lists.
- Do not do anything to the cache if there are no xpubs in it.
- Wiping mempool fixed.
- Chunk transactions to be deleted from mempool.
- Mempool improvements.
- Ability to wipe mempool at start.
- Improvements to mempool processing code.
- Tighten the locking loop to avoid slow cache building.
- Wrong error in cache when acquiring lock.
- Add extra debug logging for cache code.
- Fix a bug with xpub growing algorithm.
- Use locks instead of transactions to update cache.
- Reduce contention when many instances of Haskoin Store share a cache.
- Allow retrieving xpub data without using cache.
- Allow xpub eviction from cache via API.
- Clarify cache address addition code.
- Balances were incorrectly computed in cache when new transactions arrived.
- Support for Redis transactions.
- Use a smaller initial gap for empty xpubs.
- Remove custom JSON encoding class.
- Refactor and code simplification.
- Cache was being completely pruned.
- Cache now prunes correctly.
- Bug was making cache get stuck when pruning.
- More efficient algorithms for caching and cache misses.
- Better debug logging of cache hits and misses.
- More debug logging for cache hits.
- Bug using maximum against empty list.
- Extreme code refactoring.
- Move all code to Haskoin and drop Network from modules.
- Use Redis pipelining when importing multiple transactions into cache.
- Implement configurable LRU for Redis cache.
- Import xpubs directly into cache from web worker thread when a key is requested.
- Only expose a few modules to external API.
- Improve build configuration.
- Use minimum used addresses instead of minimum index for xpub cache decision.
- Fix missing xpub unspent outputs when using cache.
- Only store xpubs in cache if they have more than a threshold addresses used.
- Fix shared cache case where head is set beyond header chain by another node.
- Fix bug where best head was not being registered in cache.
- Fix best head in cache being decoded incorrectly.
- Complete support for Redis xpub cache.
- Latest version of secp256k1-haskell works with Debian 9.
- Fix output of web API calls when issuing limits with offsets.
- Massive refactoring of entire codebase.
- Work in progress Redis caching for extended public keys.
- Filter xpub address balances on web API to show only addresses that have been used.
- Remove paths and addresses from xpub summary.
- Refactor code greatly.
- Depend on new Haskoin Store package to avoid missing tx broadcasts.
- Merge StoreStream class into StoreRead.
- Move former streaming functions to use lists instead of conduits.
- Remove excessively verbose debugging.
- Set minimum version bounds for some dependencies.
- Now compatible with GHC 8.8.
- Extended key caching system using Redis.
- Massively refactored codebase.
- Less verbose debug logging.
- Removed conduits for faster queries.
- Use a parallel strategy to compute key derivations.
- Do not fail health check upon transaction timeout while syncing.
- Do not use conduits for xpub balance streams.
- Multiple minor refactorings.
- Minor refactor to block import code.
- Minor fix to transaction timeout check.
- Clarify and correct health check algorithm.
- Add address transactions to cache.
- Improve multi-address transaction retrieval algorithms.
- Cache-Control header turned out to be unnecessary.
- Fix some minor errors in web module.
- Set Cache-Control header to no-cache.
- Store mempool in single key/value pair.
- Do not stream mempool.
- Disable timeout checks for testnets.
- Endpoint to locate a block by unix timestamp.
- No more persistence for peers due to dependency on newest haskoin-node.
- Transaction and block timeouts for health check.
- Raw blocks.
- Missing tranasctions on xpub listings.
- Follow Stack advise removing
-O2
GHC option.
- Compatibility with SegWit on extended public key endpoints.
- Fix syncing peer not reset after timeout.
- Use simpler monad for streaming data.
- Bump Haskoin Node to fix peers not stored and excessively verbose logging.
- Configurable HTTP request logging. Disabled by default.
- Fix for memory leak.
- Remove transaction count from xpub summary object.
- Simplified limits and start point handling on web API.
- Made transaction streaming algorithm faster for xpub transactions.
- Extended public key summary output contains all addresses that have received transactions.
- Fine-grained control for maximum limits via command line options.
- Transaction hash as starting point.
- Block hash as starting point.
- Timestamp as starting point.
- Configurable xpub gap limit.
- Transaction count added to xpub summary.
- UTXO count added to xpub summary.
- Mempool endpoint now has no limits or offsets and always returns full list.
- Extended public key summary output no longer includes any transactions.
- Offsets not allowed for transaction lists involving multiple addresses or xpubs.
- Confusing block position parameter no longer part of web API.
- Stream address balances and unspent outputs.
- Add configurable max value for limit and offset which defaults at 10000.
- When posting a transaction to the network, timeout is now five seconds.
- Improve error message when transaction post timeout reached.
- Remove obsolete
not found
error for transaction post. - Endpoints for retrieving blocks now do streaming for better performance.
- Improve Swagger API documentation.
- Endpoints for retrieving block transactions.
- Endpoint for retrieving set of latest blocks.
- Use standardized JSON and binary serialization schemes for raw transaction endpoints.
- Now logging info messages too by default.
- Consolidated web logging in middleware.
- UUIDs for web requests.
- Remove concurrency from xpub balance requests to prevent RocksDB segfaults.
- Remove concurrency from requests using iterators to prevent RocksDB from segfaulting.
- Debugging information for web API.
- Debugging disabled by default (use
--debug
to enable).
- Cache mempool transactions.
- Improve initial syncing performance.
- Orphan transaction support.
- Full address balance cache in RocksDB.
- Full unspent output cache in RocksDB.
- Significantly refactor code.
- Move web stuff to its own module.
- Change types related to databases.
- Make xpub balance, transaction and unspent queries fetch data in parallel.
- Internal data types to support orphan transactions.
- Do not spam block actor with pings.
- Fix balance/unspent cache not reverting when importing fails.
- Fix transaction sorting algorithm not including transaction position information.
- Fix conflicting mempool transaction preventing block from importing.
- Fix duplicate coinbase transaction id bug.
- Removed
PreciseUnixTime
data type.
- Use 64 bits for Unix time representation.
- Data model now uses simplified Unix time representation.
- Last external/change index information to xpub summary object.
- Endpoint for xpub summaries.
- Endpoints for full transactions.
- Ability to query by offset/limit.
- More API documentation.
- Debug information for
publishTx
.
- Transaction publishing no longer requests mempool.
- Fixed serialization for
TxId
freezing the entire program by infinitely recursing.
- Enable full threading again as it was deemed not responsible for the freezing behaviour.
- Enable threading but leave it at a single thread to be able to open more than 1024 files.
- Target LTS Haskell 13.20 and disable threading in new attempt to fix freezing bug.
- Remove
-O2
.
- Target LTS Haskell 12.26 to attempt to fix freezing bug.
- Extra debugging around code that freezes.
- Bump dependency on
haskoin-node
.
- Dump slow protobuf serialization.
- Add custom serialization.
- Extra debug logging.
- Bump
haskoin-core
andhaskoin-node
.
- Bump
haskoin-node
instack.yaml
. - Do not send empty
getdata
messages.
- Primitive content negotiation for web exceptions.
- Protobuf support for errors.
- Protobuf support for tranasction ids.
- Protobuf format changed in non-backwards-compatible manner for transaction ids.
- Support for binary serialization using Protocol Buffers.
- New endpoints for binary raw transactions (not hex-encoded).
- Services field now a hex string instead of a number to avoid overflowing signed 64-bit integer.
- Flatten list of block data objects when responding to request for multiple block heights.
- Errors now reported in plain text without container JSON object.
- Transaction broadcasts are responded to with transaction id in plaintext hex (no JSON).
- Remove database snapshots to improve performance.
- Fix duplicate mempool transaction announcements in event stream.
- Removed latest block time check.
- Improve post transactions endpoint.
- Fix bug where transaction lists from multiple addresses would sort incorrectly.
- Address gap reduced to 20.
- Remove addresses from transaction lists.
- No longer use container objects for xpub transactions.
- Permissive CORS headers to allow queries from any domain.
- Improved documentation using real-world examples from the BCH testnet.
- HTTP JSON API switch to turn off transaction list when retrieving blocks.
- Total block fees.
- Total block outputs.
- Block subsidy.
- Do not consider the blocks less one block away from headers as out of sync in health check.
- Health check now returns HTTP 503 when not OK or out of sync.
- Version to health check output.
- Block weight for segwit.
- Transaction weight for segwit.
- Health check endpoint.
- Limits and skips.
- Add timestamps to transactions.
- Add transaction count to address balance object.
- Add Merkle root to block data.
- Total funds received by an address now shows up in balance.
- Balances for any address that ever had funds show up in xpub endpoints.
- Data model update.
- Performance improvement for xpub calls.
- Transactions are returned in reverse mempool/block order (highest or most recent first).
- Balance objects do not get deleted from database ever.
- Reduce number of coinbase checks to 10,000 ancestors.
- Further optimize coinbase after height checks.
- Impose restrictions on recursion for coinbase after height checks.
- Check whether a transaction can be traced back to a coinbase after certain height.
- Delete transactions in reverse topological order when reverting a block.
- Do not fail silently when importing orphan transactions into the mempool.
- Dummy release to bump haskoin-node in stack.yaml.
- Correct bug where coinbase transactions weren't properly flagged.
- Compatibility with Bitcoin Cash hard fork.
- Various bug fixes.
- Address balance cache in memory.
- Simplify data model further.
- Fix bug importing outputs with UTXO cache.
- Unspent balances cannot be negative.
- Add UTXO cache in memory.
- Get transactions with witness data in segwit networks.
- Paths for derivations in xpubs is a list and no longer a string.
- Various bug fixes.
- Remove extended public key itself from output of relevant endpoints to save bandwidth.
- Fix bug when deleting coinbase transactions.
- Extended public key API support.
- Generate events for mempool transactions.
- Respond with entire block data when querying blocks by height.
- Do not import transactions to mempool while not synced.
- Only sync mempool against a single peer.
- Allow duplicate transactions to fix re-introduced sync bug.
- Update dependencies.
- Keep orphan blocks and deleted transactions in database.
- Add a
mainchain
field for block data and adeleted
field for transactions. - Stream records for performance.
- Show witness data for transaction inputs in SegWit network.
- Support RBF in SegWit network.
- Refactor all data access code away from actor.
- Refactor import logic away from actor.
- Abstract data access using typeclasses.
- Implement data access using clean layered architecture.
- Make most of import logic code pure.
- Database now in
db
as opposed toblocks
directory. - Use latest
haskoin-node
.
- Remove some data from peer information output.
- Remove full transaction from address transaction data.
- Remove limits from address transaction data.
- Remove block data from previous output.
- Remove spender from JSON response when output not spent.
- Remove block hash from block reference.
- Do not send transaction notifications if a block is being imported.
- Peer information endpoint.
- Update
haskoin-node
.
- Fix tests
- Documentation everywhere.
- Ability to retrieve address transactions.
- New versions of NQE and Haskoin Node upstream.
- Improve and simplify API.
- Multi-element endpoints return arrays of arrays.
- Database snapshots for all queries are now mandatory.
- Retrieving unspent and spent outputs for an address.
- Redundant API endpoints for multiple elements.
- Fix a bug with transaction notifications.
- Improve handling orphan transactions.
- Specify dependencies better.
- Dependency
secp256k1
is nowsecp256k1-haskell
.
- New
CHANGELOG.md
file. - Bitcoin (BTC) and Bitcoin Cash (BCH) compatibility.
- RocksDB database.
- Mempool support.
- HTTP streaming for events.
- CashAddr support.
- Bech32 support.
- Rate limits.
- Split out of former
haskoin
repository. - Use hpack and
package.yaml
.
- Removed Stylish Haskell configuration file.
- Remvoed
haskoin-core
andhaskoin-wallet
packages from this repository.