From a113bac84a26e19330cc8f9971becee47728ab63 Mon Sep 17 00:00:00 2001 From: Anna Shaleva Date: Wed, 6 Mar 2024 17:24:24 +0300 Subject: [PATCH] README: update documentation according to dBFT API refactoring Also add a record to CHANGELOG.md. A part of #84. Signed-off-by: Anna Shaleva --- CHANGELOG.md | 1 + README.md | 17 +++++++++-------- 2 files changed, 10 insertions(+), 8 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 155c6115..4e331e11 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -13,6 +13,7 @@ Behaviour changes: * rename `InitializeConsensus` dBFT method to `Reset` (#95) * drop outdated dBFT `Service` interface (#95) * move all default implementations to `internal` package (#97) + * remove unused APIs of dBFT and payload interfaces (#104) Improvements: * add MIT License (#78, #79) diff --git a/README.md b/README.md index 10a490d6..99b4faba 100644 --- a/README.md +++ b/README.md @@ -14,18 +14,19 @@ in `config.go`. 2. `dbft` package contains `PrivateKey`/`PublicKey` interfaces which permits usage of one's own cryptography for signing blocks on `Commit` stage. Refer to `identity.go` for `PrivateKey`/`PublicKey` description. No default implementation is provided. -3. `dbft` package contains `Hash`/`Address` interfaces which permits usage of one's own -hash/address implementation without additional overhead on conversions. Instantiate dBFT with -custom hash/address implementation that matches requirements specified in the corresponding -documentation. Refer to `identity.go` for `Hash`/`Address` description. No default implementation is +3. `dbft` package contains `Hash` interface which permits usage of one's own +hash implementation without additional overhead on conversions. Instantiate dBFT with +custom hash implementation that matches requirements specified in the corresponding +documentation. Refer to `identity.go` for `Hash` description. No default implementation is provided. 4. `dbft` package contains `Block` and `Transaction` abstractions located at the `block.go` and -`transaction.go` files. Every block must be able to be signed and verified as well as implement setters -and getters for main fields. `Transaction` is an entity which can be hashed. Two entities having +`transaction.go` files. Every block must be able to be signed and verified as well as implement getters +for main fields. `Transaction` is an entity which can be hashed. Two entities having equal hashes are considered equal. No default implementation is provided. 5. `dbft` contains generic interfaces for payloads. No default implementation is provided. -6. `timer` contains default time provider. It should make it easier to write tests -concerning dBFT's time depending behaviour. +6. `dbft` contains generic interfaces for time-related operations (`Timer` and `HV`). `timer` package contains +default time and height-view providers, it contains minimal required timer functionality and may safely be used in +production code. It should make it easier to write tests concerning dBFT's time depending behaviour. 7. `internal` contains an example of custom identity types and payloads implementation used to implement an example of dBFT's usage with 6-node consensus. Refer to `internal` subpackages for type-specific dBFT implementation and tests. Refer to `internal/simulation` for an example of dBFT library usage.