3667# Changelog
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.
- Match entity schema name with delegate username (4e85a744, @air1one)
- Reject long form signature lengths (8f8976de, @alessiodf)
- Validate payload call id for all requests (4565eba2, @alessiodf)
- Check client-side graceful disconnection payload (c6d74215, @alessiodf)
- Ensure asset recipientId and amount are strings (29eaf104, @alessiodf)
- Validate incoming message json (ae8dcd73, @alessiodf)
- Count props in p2p.peer.postTransactions payload (021d18aa, @alessiodf)
- Reset maxPayload on ws message (f1bf1956, @air1one)
- Reduce getBlocksTimeout to 30 sec (93701759, @air1one)
- Limit peers returned by getPeers (4c79c455, @air1one)
- TrustProxy option based on env (fff3ecb0, @air1one)
- Custom validation for getCommonBlocks (2b393635, @alessiodf)
- Add listeners on 'connecting' event (b5625926, @alessiodf)
- Add index on blocks.generator_public_key, blocks.height (6fb4ab90, @alessiodf)
- Always broadcast last block (c291166f, @air1one)
- Terminate and ban on error (eecc40ce, @air1one)
- Parse without base64ToBinaryReplacer on error (8e41f069, @alessiodf)
- Strict greater than (8006a8da, @air1one)
- Enable trustProxy option (850ade02, @air1one)
- Return [] if asked higher blocks than current (312899c9, @air1one)
- Check that message is a string (5e1c5a33, @air1one)
- Ban if not authorized on internal (dd96ee49, @air1one)
- Htlc lock recipientId is required (380fb5b6, @air1one)
- Destroy connection after terminate (#4065) (a853d63f, @air1one)
2.7.0 - 2020-09-23
- AIP36 (#3836) (36c1ca76, @air1one)
- AIP36 delegate entity (#3877) (9f2eb629, @air1one)
- Add missing return type to this.queue (#3817) (511e5755, @deanpress)
- Fix entity register bootstrap method (#3850) (bd5b1ad0, @air1one)
- Remove duplicates entity resigned/isResigned (#3858) (90bf42de, @air1one)
- Entity name only unique by type (#4008) (3b12c703, @air1one)
- Ignore random type errors thrown by lowdb on build (#4017) (785680c0, @deanpress)
- Delegate check only needed on entity register (#4024) (64b63b54, @air1one)
- Rate limit and peer broadcast (#4054) (6988cdd4, @air1one)
- Add AIP36 milestone for devnet (#3845) (1da58ebb, @air1one)
- Remove obsolete magistrate endpoints (AIP36) (#3847) (219a9408, @air1one)
- Accept peers in the 2.7 range (#3848) (aab40895, @faustbrian)
- Remove bridgechain from AIP36 entities (#3937) (085ab675, @air1one)
- Add devnet exception (#3967) (78c49b4a, @air1one)
- Throw more specific multi-signature exceptions (#3976) (48e67e51, @faustbrian)
- More flexible entity types / sub-types + fees update (#3986) (06261f99, @air1one)
- Activate all entity types + re-allocate entity type enum (#4020) (649aeace, @air1one)
- Custom entity fees for register/update/resign (#4029) (ed835c29, @air1one)
- Add devnet exception (#4031) (5da4f4df, @air1one)
- AIP36 milestone for mainnet (#4053) (ec8cbb94, @air1one)
2.6.57 - 2020-09-17
- Only verify peer blocks < our height (c968e69d, @air1one)
- Stricter multipayment tx check (620027df, @air1one)
- Initialize maxPayload on connection create (3ac3eb17, @air1one)
2.6.54 - 2020-09-09
- Verify peer claimed state (24a8b044, @air1one)
- Use head from utils (da13465e, @air1one)
2.6.52 - 2020-08-11
- Discard zero-padded R/S (#3950) (9f197fa1, @air1one)
- Check sig length value vs r/s length (#3950) (c2d3f2e5, @air1one)
- Find by address / public key before username (#3950) (ddd19cc2, @air1one)
2.6.49 - 2020-07-22
- Use bundled file for
browser
field (#3904) (20d66cf3, @luciorubeens) - Reduce download block size when getting no block (#3905) (e2232875, @air1one)
- Ping ports using head (#3905) (db226bd3, @air1one)
- Stricter rate limit for getBlocks (#3905) (df7a3aa1, @air1one)
- Allow to discard possibly invalid txs from pool (#3905) (0450ee84, @air1one)
- Check sig length vs R and S length (#3905) (1b0863c3, @air1one)
- Check that R and S is positive (#3905) (0783ec08, @air1one)
2.6.42 - 2020-06-29
- Add rollup config for browsers (#3830) (da0d8d5a, @luciorubeens)
- Update
bcrypto
dependency to v5 (#3823) (0b510429, @faustbrian)
- Use incremental timestamps for
make:block
(#3818) (4612cd24, @deanpress)
2.6.39 - 2020-06-17
- Block schema violation (#3806)
2.6.38 - 2020-05-27
- Discard late-forged blocks from forger (#3746)
2.6.37 - 2020-05-12
- Custom validation for
postBlock
incore-p2p
worker (#3695)
2.6.36 - 2020-05-04
- Update vote balance with htlc locked balance on vote transactions (#3669)
- Use sorted array (instead of tree) for storing transactions by fee and nonce (#3678)
2.6.34 - 2020-04-28
- Create a unique round ID for elasticsearch (#3659)
- Update @arkecosystem/utils dependency (#3665)
- Use tree memory structure to sort by fee and by sender nonce (core-transaction-pool) (#3667)
2.6.31 - 2020-03-25
- Allow transition to fork from idle (#3614)
2.6.30 - 2020-03-19
- Optimize database adding indexes (#3605)
- Restrict some api sorting and filtering parameters that are not needed (#3605)
2.6.29 - 2020-03-13
Re-release for NPM.
2.6.28 - 2020-03-13
- Reset missedBlocks before await call (#3598)
2.6.27 - 2020-03-12
2.6.25 - 2020-03-09
Fix block apply issue where in some cases transaction could be applied twice to recipient in transaction pool (#3590)
2.6.24 - 2020-03-04
- add missing transactions.type_group index (#3573)
2.6.21 - 2020-03-04
- Set height 1 on config manager for processing genesis block (blockchain replay) (#3561)
- Handle multiple installations of jemalloc (#3562)
- jemalloc compatibility for ubuntu 16.04 (#3567)
- Always call applyToRecipient (#3570)
- Allow multiple ports in bridgechain schema (#3504)
- Allow to resign business only when bridgechains are resigned (#3524)
- Make bridgechain genesis hash only unique per wallet (#3523)
- Add exceptions for business resignation (#3551)
- No default addonBytes for magistrate transactions (#3560)
- Use jemalloc as the memory allocator (#3541)
2.6.11 - 2020-02-26
- Only accept valid http path (SC http server) (#3537)
2.6.10 - 2020-02-20
- Disable permessage-deflate (#3518)
2.6.9 - 2020-02-19
- Check for missed blocks before applying round (#3507)
- Make app.js optional as initially intended (#3510)
- Multisig legacy allow signatures property (#3489)
- Remove pm2 from docker (#3505)
- Use findByPublicKey to set both publickey and address on the multisig wallet (#3498)
- Remove long dependency (#3502)
2.6.1 - 2020-02-11
- Update
@arkecosystem/exchange-json-rpc
2.6.0 - 2020-02-11
- Expose
isValidPeer
via ajv format rule (#2960) - Implement AIP 102 (#2773)
- Implement AIP 103 (#2858)
- Implement MultiPayment (AIP11) (#2669)
- Implement nonces (#2573)
- Multi Signature support for WIF (#2979)
- Transaction type dependencies (#2859)
- Add nonce to wallet transformer (#2760)
- Allow easy retrieval of first and last block (#2641)
- Allow retrieval of raw blocks and transactions (#2616)
- Endpoints for locks/businesses/bridgechains (#2940)
- Find htlc unlock transactions (#2976)
- Include core version in node/configuration (#2855)
- Search transactions by asset (#2618)
- Enforce transactions' nonce order from blockProcessor (#2873)
- Change minimum version via milestone (#2869)
- Use compression on the p2p level (#2886)
- Add support for transaction nonces (#2925)
- Attributes getter/setter for wallet (#2839)
- Wallet Manager indexes (#2845)
- Register wallet attributes before accessing them (#2867)
- Allow CLI command configurations (#2972)
- Allow passing height to
configManager.isNewMilestone
(#3001) - Expose transaction height, blockId and generatorPublicKey during bootstrap (#3096)
- Add
/transactions/schemas
endpoint (#3083) - Implement businesses/bridgechains endpoint (#3119)
- Implement throttling on outgoing p2p communication (#3170)
- Implement Address.fromWIF method (#3228)
- Always deserialize vendor field ([b537d6f327e939ff40b680ea7d558e8fdb3ac921])
- Basic validation on incoming p2p data + terminate socket on error (#3037)
- Clone webhook before mutating it (#2863)
- Delete existing payload processor db (#2864)
- Do not sort transactions in forger / update purgeByBlock logic for handling nonces (#2678)
- HTLC refund handler to use performGenericWalletChecks (#2944)
- Move wallet manager "zero balance" check to transaction handlers (#2896)
- Multipayment balance / vote balance (#2838)
- Range selection in pool's getTransactions() (#2952)
/wallets/{id}/transactions
search parameters (#2923)- Return block timestamp for v2 transactions (#2906)
- Return count of filtered peers (#2814)
- Clear queue on invalid block (#2897)
- Do not reset
noBlockCounter
whendownloadBlocks
succeeds (#2968) - Only shift milestoneHeights[] if at that height (#2904)
- Round deletion during rollback (#2970)
- Prefix table names with schema (#2830)
- Store vendor field in bytea (#3048)
- Add missing typeGroup and emit StateStarting (#2932)
- Use correct IV length for encryption (#3036)
- Disconnect if api reports different network (#2909)
- Don't cause suspensions for unresponsive plugins ([34749bf84bcec3fecd0098c0d42f52deb1f6ba4a])
- Fix the genesis block id during verify (#2809)
- Export/import transactions type_group (#2996)
- Remove bogus skipRoundRows (#2973)
buildDelegateRanking
called too early (#2921)buildVoteBalances
called too early (#2920)- Differentiate between wallets and delegates (#2854)
- Index recipient wallets during bootstrap (#2947)
- Copy vote target into temp wallet manager ([1209a36366c8fd3ba31fab2463011b7ce1a7d844])
- Sort by fee, nonce (#2937)
- Implement Delegate resignation (#3045)
- Reject delegate resignation if not enough active delegates (#2919)
- Update wallet nonce when applying v1 transaction (#2959)
- Use supply calculator in delegate approval calculation (#2918)
- Cast params in condition checks (#2887)
- Add legacy multisignature schema (#3040)
- Ensure only one signature per participant (#2889)
- Handle mainnet address exceptions (#3055)
- HTLC lock buffer allocation (#2936)
- Legacy multi signature verification (#2898)
- Run ajv validator again when encountering exceptions (#3008)
- Use
anyOf
for transactions schema (#2894) - Use 2 bytes to store number of payments (#2928)
- Use strict comparison to decide if a transaction should be enabled (#3087)
- Include typeGroup in
/transactions/fees
and/node/fees
endpoints (#3193) - Add missing offset handling to /api/peers (#3075)
- Use numerics for typeGroups in /transactions/types (#3112)
- Add transactions back to pool only after reverting all blocks (#3138)
- Pass IBlockData to processBlocks instead of IBlock (#3426)
- Don't assume blocksInCurrentRound is defined (#3341)
- Set last height before initializing last block to use correct milestones (#3109)
- Don't swallow BIP38 errors (#3271)
- Use the request origin to avoid 404s (#3071)
- Raise
getCommonBlocks
rate limit (#3069) - Return error when app is not ready (#3171)
- Uncaught IPC timeout (#3140)
- Support nonces and chunk transactions before broadcast (#3081)
- Create new wallet if not found (#3086)
- Wallet-manager fallback to database wallet manager findByIndex() when no "local" match (#3256)
- Throw if transaction key is already taken (#3095)
- Update sender's wallet after validation (#3291)
- Prevent snapshot commands from running if core is running (#3196)
- Remove password flag constraint for core:forger command (#3270)
- Properly implement block size limit (#3154)
- Strengthen schema validation checks (#3062)
- Log the reason for discarding a block (#2903)
- Accept prerelease version (#2911)
- Add
round.missed
event (#3011) - Do not temporary increment/decrement nonce when checking transaction validity (#2587)
- Increase transaction type size (#2861)
- Reject V1 transactions after milestone (#2879)
- Remove
vendorFieldHex
(#3014) - Remove asset migration heuristic (#2999)
- Return all registered transaction types (#2878)
- Strengthen a nonce check in performGenericWalletChecks() (#2949)
- Add default transaction fees (#2842)
- Add
vendorField
andtimestamp
to/locks
endpoint (#3005) - Integrate hapi-pagination to replace fork (#2994)
- Use pagination configuration limit ([032caa1b990e91937e4bc1561bc1aeaeca9e37d9])
- Break loop if block contains v1 transaction (#2914)
- Add nonce column (#2844)
- Emit
forging.missing
earlier (#2893) - Emit missing
transaction.reverted
event and remove obsolete ones (#2895) - Cleanup socket errors (#3056)
- Increase network timeouts (#2828)
- Make peer reply errors less verbose (#2962)
- Share rate limiter between workers (#2912)
- Expose current block for transaction handlers (#2856)
- Clear cached transaction ids after accepting block (#2916)
- Don't accept expired v1 transactions (#2948)
- Bootstrap transactions in batches (#2997)
- Elaborate the unexpected nonce error (#2943)
- HTLC implementation (#2915)
- Make handler functions asynchronous (#2865)
- Use default heap size regardless of available memory (#2998)
- Change maximum recipients of multipayment via milestone (#2961)
- Export abstract builder for use by plugins (#2721)
- Fallback to ECDSA signature for version 2 transactions (#2584)
- Make error more verbose (#2938)
- Move base58 functions to utils (#2675)
- ECDSA Signature deserialization for v2 transactions (#2877)
- Remove unnecessary check from validateTransactions() (#2951)
- Fallback to core typegroup if querying by type (#3147)
- Integrate hapi-pagination to replace fork (#3034)
- Sort peers by height, latency (#3078)
- Add
stateBuilder.finished
to ApplicationEvents (#3084) - Make deserializers static (#3234)
- Fix genesis and exception transactions cache (#3296)
- Overwrite arrays when merging milestones (#3108)
- Avoid O(m*n) when filtering pool txs and simplify the code (#2941)
- Ditch unnecessary reindex() in multi-payment bootstrap (#3022)
- Keep genesis block instance in-memory ([7a73aef8b29d40572d1524cf8b1bafbffa3b0964])
- Use lodash to efficiently remove forged transactions (#2942)
- Add index on transactions.type (#3043)
- Speed up nonce checks at DB level (#2910)
- Make address network byte check part of serde (#3000)
- Memoize base58 de/encoding (#3015)
- Replace bignumber.js with native BigInt (#3010)
- Replace bs58check with bstring (#2673)
2.5.38 - 2020-01-21
Rerelease of 2.5.37 due to some npm issues.
2.5.37 - 2020-01-21
- Remove banning when peer opens multiple sockets (#3409)
2.5.36 - 2020-01-21
- Discard blocks containing too many transactions (#3404)
- Disconnect when multiple sockets are opened from same IP (#3404)
- Handle invalid WS opcodes (#3404)
- Disconnect for p2p SocketCluster events that do not have a handler (#3404)
- Handle payload with additional properties (#3404)
2.5.31 - 2019-12-19
- Handle disconnect packets (#3354)
2.5.30 - 2019-12-09
2.5.28 - 2019-11-05
- Prepare for upcoming 2.6 release (#3208)
2.5.26 - 2019-10-07
- Integrate hapi-pagination to replace fork (#3030)
2.5.25 - 2019-09-19
- Terminate connection when not authorized (#2945)
2.5.24 - 2019-09-04
- Cast params in webhook condition checks (#2887)
- Drop connections with malformed messages (#2907)
- Terminate blocked client connections (#2907)
- Use
anyOf
for transactions schema (#2894) - Use compression on the p2p level (#2886)
2.5.17 - 2019-08-06
- Differentiate between wallets and delegates (#2854)
- Clone webhook before mutating it (#2863)
- Delete existing db (#2864)
2.5.14 - 2019-07-30
- Add content-type header for all requests (#2840)
- Return data directly if cache is disabled in
core-api
(#2831) - Internal server error caused by invalid orderBy field in
core-api
(#2847) - Peer discovery limit (#2850)
- Lookup delegates by key to improve performance (#2837)
- Add ntp and google servers for ntpd to docker image (#2823)
- Improve performance of transactions endpoint in
core-p2p
(#2848)
2.5.7 - 2019-07-16
- Accepted versions (#2802)
- Fix the genesis block id during verification of snapshots (#2809)
- Average fee and wallet transaction retrieval in
@arkecosystem/core-exchange-json-rpc
(1.0.3)
- Export dist/index.js for cjs and umd in
@arkecosystem/crypto
(#2807) - Update dependencies to their latest versions (#2808)
- Lookup wallets by keys for improved performance (#2810)
2.5.1 - 2019-07-11
- SSL functionality of core-api (#2800)
2.5.0 - 2019-07-11
- Allow retrieval of raw blocks and transactions via API (#2616)
- Search transactions by asset via API (#2618)
- Allow easy retrieval of first and last block (#2641)
- Make it configurable whether to use estimates for
core-api
(#2772)
- Impose the same rate limit as the public API (#2717)
- Add option to configure request timeouts for webhooks(#2710)
- Use CORE_API_DISABLED variable in defaults (#2711)
- Always attempt to download blocks after start (#2746)
- Possible database corruption when writing and deleting blocks (#2707)
- Forget peer when socket is disconnected (#2720)
- Off-by-one error when fetching blocks from peer (#2733)
- Check for user confirmation in snapshot commands (#2734)
- Grant access if the whitelist is empty (#2748)
- Do not purge transactions when a block is not accepted (#2751)
- Previous round order calculation (#2754)
- Revert accepted blocks when saveBlocks fails (#2761)
- Do not restore genesis block with wrong id (#2759)
- Dvoid iterating on non-iterable peerBlocks (#2763)
- Correct estimate if less than limit rows (#2764)
- Try harder to return the requested number of transactions (#2765)
- Reject future and expired transaction timestamps (#2757)
- Delete last block if deserialization fails (#2770)
- Raise bignumber maximum (#2777)
- Allow future timestamps up to 3600 + blocktime seconds (#2787)
- Handle null url and malformed JSON payloads (#2797)
- BREAKING: Treat and return BigInt values as strings (affects core-api) (#2739)
- Download serialized blocks to improve performance (#2743)
- Better peer block header check to improve performance (#2719)
- Exit on unexpected database errors (#2744, [#2755])
- Block peers when the rate limit is exceeded (#2745)
- Delay peer discovery until after state initialization is done (#2727)
- Improved P2P rate limiting (#2729)
- Only fetch block headers when verifying peers (#2728)
- Only look for new peers when below minimum peers (#2714)
- Always keep the Wallet API enabled (#2715)
- Respect the whitelist of the public API (#2718)
- Add foreign key on transactions block id (#2671)
- Remove the id column from rounds (#2723)
- Discover new peers sooner (#2771)
- Enforce chained blocks at database level (#2753)
- Increase timeout, check time left in slot (#2788)
- Refresh peer ports (#2784)
- Remove blockSender (#2756)
- Removed the
ark-node
legacy API known asv1
(#2577)
2.4.15 - 2019-07-09
- Backport various bug fixes from 2.5 (#2782)
2.4.14 - 2019-07-02
- Try harder to return the requested number of transactions (#2766)
2.4.13 - 2019-06-26
- Do not purge transactions when a block is not accepted (#2751)
2.4.12 - 2019-06-14
- Cache genesis transaction ids for improved performance (#2699)
- Take milestones into account when downloading blocks in parallel (#2700)
2.4.1 - 2019-06-13
2.4.0 - 2019-06-12
All changes listed in this section are things that either alter how certain data in core is treated and processed or changes to the public API of a package.
As we move towards 2.6 and the completion of AIP11, AIP18 and AIP29 there will be various breaking changes. The main concern of most developers will be breaking changes to @arkecosystem/crypto
so go through the commits listed below and make sure you adjust everything in your application that is affected by a change.
The JSON-RPC we offer, formerly known as @arkecosystem/core-json-rpc
, has received a rework to turn it into a real RPC that is easier to use and maintain.
The biggest change is that it now offers programmatic use to make integration into ARK Core easier while simultaneously allowing it to run as a standalone application detached from a relay.
Standalone https://github.com/ArkEcosystem/exchange-json-rpc
ARK Core Plugin https://github.com/ArkEcosystem/core/tree/develop/packages/core-exchange-json-rpc
The
@arkecosystem/core-json-rpc
plugin has been deprecated and replaced by@arkecosystem/core-exchange-json-rpc
because of different those 2 plugins work under the hood and their dependencies.
A few smaller improvements to how peers and faulty responses are being handled have also been made which should smoothen the experience without having to manually retry requests.
The Exchange JSON-RPC uses SQLite under the hood to store all data. In previous versions it was using https://github.com/mapbox/node-sqlite3 which was known to cause random build issues for ARK Core and sometimes needed a dozen retries before it finally compiled.
That dependency has been replaced with https://github.com/JoshuaWise/better-sqlite3 which is the same that ARK Core uses for its transaction pool. It provides better performance, receives updates and fixes when needed and build errors are a thing of the past.
If you've been using the JSON-RPC in the past together with ARK Core the migration to the Exchange JSON-RPC is as simple as following the steps at https://docs.ark.io/releases/v2.4/migrating_2.3_2.4.html#step-5-update-core-json-rpc-to-core-exchange-json-rpc.
- The Exchange JSON-RPC is only maintained for exchanges, as the name suggests. We do not offer any support or guidance unless you are an Exchange in which case you most likely will already be in touch with us.
- Do not use the Exchange JSON-RPC unless you are forced too and have no other options. The Public API provides much greater capabilities of searching and filtering data.
- Implement in
@arkecosystem/core-state
to manage the state of in-memory data (#2479) - Implement a blockchain replay command (#2526)
- Save blocks in batches during sync (#2500)
- Implement v2/node/fees endpoint (#2393)
- Allow setting a vendor field for transactions created via
@arkecosystem/core-json-rpc
(#2425) - Limit the number of accepted peers per subnet (#2507)
- BREAKING: Implement WebSockets with SocketCluster (#2273)
- Parallel block download (#2433)
- In-memory storage for last N blocks and transactions (#2492)
- BREAKING: Switch transaction expiration from seconds to chain height (#2461)
- Require the user to choose a snapshot if the blocks flag is missing in
@arkecosystem/core
commands (#2522) - BREAKING: Implement Block.fromHex, Block.fromBytes and Block.fromData methods in
@arkecosystem/crypto
(#2377) - BREAKING: Implement BlockFactory in
@arkecosystem/crypto
(#2429) - BREAKING: Implement TransactionFactory in
@arkecosystem/crypto
(#2437) - Integrate end-to-end tests (#2468)
- Initial Implementation of
core-wallet-api
(#2544) - Accept block height to list block transactions in
core-api
(#2567) - Functional test matchers for
core-jest-matchers
(#2562) - Don't trust headers and verify config and plugin connectivity of peers (#2559, #2553, #2552)
- Proxy API calls to core-api until fully developed (#2558)
- Add database configuration command to CLI (#2557, #2563)
- Add command to generate network configuration CLI (#2582)
- Initial implementation of
core-explorer
(#2604)
- Insert the genesis block as soon as the database is ready (#2376)
- BREAKING: Purge invalid transactions after a milestone change (#2499)
- Use public API to auto-configure
@arkecosystem/core-tester-cli
(#2517) - Parse only the last line of pm2 stdout to avoid parsing faulty input (#2484)
- Delete bad rounds after unclean shutdown (#2581)
- Divide blocks into smaller chunks for batch processing (#2586)
- Remove forged transactions from pool before discarding block (#2555)
- BREAKING: Make transaction amount required (#2574)
- Various sync issues with devnet and mainnet (#2565)
- Do not suspend peer for
AppNotReady
(#2590) - Allow use of old and new block IDs via
core-json-rpc
(#2593) - Assign calculated delegate ranks from temp wallets to prevent wrong ranks on boot (#2611)
- Camelize block keys before bignum transformation for snapshots (#2615)
- Deserialize transactions before they leave the pool to remove bad ones (#2622)
- Require all properties in schema and handle 404 resources for
core-webhooks
(#2634) - Check if transactions can still be applied before forging (#2635)
- Off by one error in transaction confirmations via API (#2645)
- Set the correct channel if core was directly installed with
@next
(#2646) - Invalid orderBy causes
Internal Server Error
via API ([#2653) - Avoid trying to INSERT duplicates in rounds via
core-snapshots
(#2651) - Handle failing optional plugins gracefully (#2657)
- Correctly purge invalid transactions from disk on start (#2665)
- Don't append duplicate rounds rows to a snapshot (#2662)
- Use temporary wallets for transaction validation (#2666)
- Correctly display second signature if available via
core-api
(#2670) - Missing block confirmations on v2 API endpoints (#2674)
- Delay transaction purge on start until after StateBuilder finished (#2685)
- Check claimed state of peer (#2686)
- Ignore overheight blocks and keep forging (#2687)
- BREAKING: Always use crypto identities to work with keys and addresses (#2443)
- BREAKING: Enforce BigNumber for satoshi based values (#2391)
- BREAKING: Move in-memory wallet logic to core-state (#2489)
- BREAKING: Replace bignumify with Utils.BigNumber.make (#2416)
- Replace Joi with AJV for internal validation (#2426)
- BREAKING: Bind plugin options before registering the plugin (#2375)
- BREAKING: Extend the node.js event emitter (#2440)
- BREAKING: Move the wallet interfaces to
@arkecosystem/core-state
(#2515) - Remove height difference ban for peers (#2360)
- BREAKING: Simplify the transaction pool by not using insertion order (#2495)
- BREAKING: Drop no longer needed pagination from
@arkecosystem/core-webhooks
(#2424) - BREAKING: Extract transaction signing and utils out of the model in
@arkecosystem/crypto
(#2514) - BREAKING: Extract transaction verification out of the model in
@arkecosystem/crypto
(#2506) - BREAKING: Make all
Slots.*
methods static in@arkecosystem/crypto
(#2473) - BREAKING: Move interfaces, types and models in
@arkecosystem/crypto
(#2379) - Move mainnet exceptions to config in
@arkecosystem/crypto
(#2529) - BREAKING: Remove extraneous Client class in
@arkecosystem/crypto
(#2417) - BREAKING: Split the
Crypto
class intoHash
andTransaction
in@arkecosystem/crypto
(#2444) - Invalidate blocks with expired transactions (#2528)
- Transaction type agnostic wallet bootstrap to support AIP29 (#2539)
- Return all schema errors in hapi-ajv (#2571)
- Remove timeout banning (#2597)
- Use dayjs as it now has official UTC support (#2592)
- Require a minimum of 0 as pubKeyHash (#2628)
- BREAKING: Replaced
@arkecosystem/core-json-rpc
with@arkecosystem/core-exchange-json-rpc
(Use@arkecosystem/core-exchange-json-rpc
programmatically) (#2643) - Expire transactions that don't have an expiration (#2672)
- BREAKING: Remove unused methods to get/set/reset height from
Slots
(#2467) - Remove peer caching (#2606)
- Remove peer banning (#2612)
- Remove coldstart period (#2619)
- Remove whitelist access log (#2655)
2.3.23 - 2019-05-21
- Allow the use of old and new block IDs via
core-json-rpc
(#2593)
2.3.22 - 2019-05-02
- Return transaction timestamp instead of block timestamp for
/v2/*
endpoints incore-api
(#2513)- Note that the transaction timestamp can be misleading as a transaction can be signed hours or days before it gets forged which is why you should rely on the block timestamp because that is the point in time when the blockchain becomes aware of a transaction.
2.3.21 - 2019-04-30
- Avoid getting stuck on a peer by picking a random one each time (JSON-RPC) (#2491)
- Fix the asset import and include
rounds
in the snapshot to avoid issues with the peer verifier (#2502) - Accept requests to /transactions regardless of suspension (only caused issues for nodes that are completely locked down behind a firewall with no incoming connections) (#2503)
2.3.18 - 2019-04-26
- Reset unfinished round after importing a snapshot (#2486)
- Update the height of the crypto config manager for milestones in the forger (only caused an issue for split setups) (#2487)
2.3.16 - 2019-04-25
- Initialise the crypto config manager with the latest height on boot (#2482)
2.3.15 - 2019-04-25
Fix release of 2.3.14
due to npm connectivity issues.
2.3.14 - 2019-04-25
- Added missing mainnet exceptions for transactions with invalid recipients (#2471)
- Remove support for old release channels from the 2.2 development period (#2476)
2.3.12 - 2019-04-24
- Use correct genesis block instead to verify snapshots (#2462)
- Don't pass suffix flag to bip38 and bip39 commands (#2464)
2.3.1 - 2019-04-23
- Deserialize type > 0 with vendor field instead of skipping it (#2459)
2.3.0 - 2019-04-23
- Removed the
wallets
table from the database (#2209)- Core 2.0 has been fully reliant on in-memory wallets since the 2.0 release. This only removes the dumping of wallets into the database as it is wasted space and doesn't serve any purpose.
- If you have applications that rely on the database you should migrate them as soon as possible to using the API as only that data is provided in real-time.
- Replace SQLite3 with lowdb in
core-webhooks
(#2124)- This significantly reduces the size of the package and it's dependencies.
- This requires you to recreate your webhooks as the storage method changed.
- Replaced
core-logger-winston
withcore-logger-pino
(#2134)- This significantly improves performance of logging when it occurs a lot in situations like syncing or rollbacks.
- Rewrote
core-tester-cli
from scratch (#2133) - Merged
core-debugger-cli
intocore-tester-cli
and deprecated it (#2133) - Use the node.js
EventEmitter
fromevents
instead ofeventemitter3
(#2329)
- Implement AIP29 (#2122)
- Search delegates by their username in
core-api
(#2143) - Implemented the
ark reinstall
command incore
(#2192) - Added the
--force
flag to theark update
command incore
(#2190) - Added more parameters for delegate searches in
core-api
(#2184) - Added restart flags to the
ark update
command incore
(#2218) - Added the
make:block
command tocore-tester-cli
to create blocks (#2221) - Added the
core-error-tracker-rollbar
package (#2287) - Added the
core-error-tracker-raygun
package (#2288) - Added the
core-error-tracker-airbrake
package (#2289) - Added the
core-logger-signale
package (#2343) - Added more events for blocks and the transaction pool (#2321)
- Return
slip44
andwif
viav2/node/configuration
(#2388) - Added an
asset
column to thetransactions
table (#2236)
- Properly sort peers by their version (#2229)
- Memory leak in the monitoring process of
core-forger
(#2341) - Handle dynamic round sizes with milestones (#2370)
- Validate that a transaction recipient is on the same network (#2394)
- Handle empty
rows
inmapBlocksToTransactions
(#2404) - Prevent indexing/creating of ghost wallets (#2405)
- Refuse transactions from senders with pending second signature registrations and do not rollback when refusing a block (#2458)
- Increased the vendor field length to 255 bytes (#2159)
- Replaced
micromatch
withnanomatch
to improve performance (#2165) - Replaced
axios
withgot
to resolve known timeout issues withaxios
(#2203) - Switch block id to full SHA256 (#2156)
- Removed dead fast rebuild code that hasn't been used since 2.0 release (#2210)
2.2.2 - 2019-03-19
- Remove
/api/v2/delegates/{id}/voters/balances
endpoint ([#2265])
2.2.0 - 2019-03-11
- Implement a CLI with @oclif to replace commander (#2100)
- Add sorting to voters endpoint (#2103)
- Validate GET replies from other peers (#2102)
- Pass query to findAllByVote method (#2142)
- Fetch list of peers from at least a few others (#2152)
- Pass the base flags for programmatic calls in
core-tester-cli
(#2108) - Reduce complexity and fix wrong offset handling in
core-elasticsearch
(#2108) - Stuck at not ready to accept new block (#2139)
- Properly sort BigNumber values (#2144)
- Properly update wallet balances if a vote transaction is reverted (#2207)
- Invalid transactions after a rollback because block timestamps were used as transaction timestamp (#2217)
- Replaced lodash.sortBy/orderBy with faster implementations (#2106)
- Improve fork handling in updatePeersOnMissingBlocks (#2125)
- Throw an error if the peers or plugins file are missing (#2135)
- Improve selection of peer for downloading blocks (#2137)
- Merge core-snapshot-cli commands into core (#2149)
2.1.2 - 2019-02-13
- Fix quorum related issues
- Limit payload size
- Remove
signatures
from transaction payload
2.1.1 - 2019-02-12
- Configuration endpoint does not show dynamic fees (#2082)
- Return the correct supply for the legacy API (#2083)
2.1.0 - 2019-02-11
- Added a
milestoneHash
identifier to use for peer banning (#1837) - Added TypeScript declarations for
core-logger
(#1833) - Added TypeScript declarations for
core-logger-winston
(#1887) - Added TypeScript declarations for
core-container
(#1891) - Added TypeScript declarations for
core-database
(#1901, #1905) - Added TypeScript declarations for
core-transaction-pool
(#1906) - Added TypeScript declarations for
core-blockchain
(#1943) - Added TypeScript declarations for
core-snapshots
(#1947) - Added TypeScript declarations for
core-api
(#1948) - Added TypeScript declarations for
crypto
(#1917) - Added the
core-jest-matchers
package (#1926) - Added the
core-interfaces
package (#1924) - Return the transaction expiration time via API (#1927)
- Added the ability to disable the public API cache (#1930)
- Return the vote of a wallet via public API (#2009)
- Upgrade script for 2.1 (#1999)
- Installation script for deb/rpm distros (#2016)
- Case specific errors for
crypto
(#2038)
- Migrated from JavaScript to TypeScript (#1625)
- Moved the
peers.json
configuration intocore-p2p
(#1625) - Merged
core-transaction-pool-mem
intocore-transaction-pool
(#1625) - Use a faster alternative to derive an estimate (#1655)
- Reworked crypto configuration to make it simpler (#1733)
- Moved the dynamic fees configuration into
core-transaction-pool
(#1733) - Periodically check for new peers instead of retrying until finding some (#1738)
- Adjusted some banning times for peers to make network recovery smoother (#1730)
- Simplified configuration by further separating network and core (#1733)
- Take the
minFeeBroadcast
value into account for fee statistics (#1873) - Only allow vendor fields for type 0 and 6 transactions (#1931)
- Improved the network quorum details and feedback (#1898)
- Only return errors when broadcast and pool fees are too low (#1940)
- Improved performance of BIP38 (#1941)
- Cleaned up the logic of block processing (#1953)
- Cleaned up the logic of serialise/deserialise in crypto (#1969)
- Replaced all ARK naming with CORE (#1970)
- Use system paths for data and configuration (#1987)
- Increased the maximum transaction age to 6 hours (#1996)
- Replaced progress bars with logging to reduce noise (#2044)
- Replaced commander.js with @oclif in
core-debugger-cli
(#2049) - Replaced commander.js with @oclif in
core-snapshots-cli
(#2050) - Replaced commander.js with @oclif in
core-tester-cli
(#2051) - Moved docker files from
docker/*
todocker/development/*
(#2053) - Moved the genesis blocks from the
core
configuration to the network configuration incrypto
(#2052) - Separate business-logic from data-layer logic (#2055)
- Resolved an issue with the
resolveOptions
method that would result in options being resolved for plugins that are not registered in the container (#1625) - Malformed condition for filtering peers (#1689)
- Use the correct pagination schema for the v2 public API (#1717)
- Ensure that delegate searches can handle undefined values (#1831)
- Mark semantically invalid versions as invalid overall (#1836)
- Ordering of delegates via public API (#1731)
- Handle webhooks that have no conditions (#1869)
- Validate the network byte on transactions (#1853)
- Use correct schemas for address, public key and username validation in the public API (#1954)
- Populate the last block of all delegates (#1919)
- Return the transaction forging timestamp instead of signing timestamp (#1957)
- Mark cold wallets as not found in the legacy API (#1955)
- A malformed condition that resulted in wrong peer lists (#1939)
- Properly verify block slot timestamps (#1985)
- Return fixed peer states for v1 and v2 API responses ([#2027])
- Validate IP ranges to detect loopbacks (#2045)
- https://github.com/ARKEcosystem/security-vulnerabilities/blob/master/core/core-sv-010.md (#2046)
- Check if the blockchain state storage is available before performing fork checks (#2047)
- Gracefully handle a corrupted cached
peers.json
file (#2061) - Always sort transactions by sequence and the requested field to make API sorting deterministic (#2058)
- Disallow multiple registrations for same delegate (#2080)
- Remove already forged transactions from the pool (#2659)
- Removed the
transactionsFromIds
P2P endpoint (#1911) - Removed the
validator
andrules
fron@arkecosystem/crypto
(#2021) - Ended support for the legacy multisignatures from the previous LISK fork (#2057)
2.0.19 - 2019-01-31
- https://github.com/ARKEcosystem/security-vulnerabilities/blob/master/core/core-sv-009.md
- https://github.com/ARKEcosystem/security-vulnerabilities/blob/master/core/core-sv-010.md
2.0.18 - 2019-01-28
2.0.17 - 2019-01-15
- https://github.com/ARKEcosystem/security-vulnerabilities/blob/master/core/core-sv-008.md
- https://github.com/ARKEcosystem/security-vulnerabilities/blob/master/core/core-sv-007.md
2.0.16 - 2018-12-17
- Prevent the list of peers to become too short. This is related to the nodes running behind a firewall.
Closed security vulnerabilities:
2.0.15 - 2018-12-11
- Ensure no local peers are enlisted and that the IP of the TCP connection is used (#1695)
2.0.14 - 2018-12-10
- Reset last downloaded block when block is discarded (#1692)
2.0.13 - 2018-12-07
- Ensure safe integer range for block height lookups via API (#1673)
2.0.12 - 2018-12-06
- Perform second-signature checks in the
canApply
logic of multi-signatures (#1658) - return the encoded WIF for BIP38 wallets instead of the encrypted WIF (#1653)
2.0.11 - 2018-12-05
- Store executed migrations in the database (#1648)
2.0.1 - 2018-12-05
- Retrieve blocks via height or ID per public API (#1626)
- Improved performance for block and transaction queries by adding more indices on critical columns (#1636, #1638, #1634)
- Take milestones into account for supply calculations (#1640)
- Use the raw transaction data in
acceptChainedBlock
to avoid timestamp mismatches and second signature double spend errors (#1564) - Return the correct peer count for the v2 public API (#1563)
2.0.0 - 2018-12-03
- Initial Release