aboutsummaryrefslogtreecommitdiffstats
path: root/blockdb
diff options
context:
space:
mode:
authorWei-Ning Huang <w@dexon.org>2018-07-16 00:12:17 +0800
committerWei-Ning Huang <w@cobinhood.com>2018-07-16 11:06:14 +0800
commitaed24cf020bd11c3b20a7011b96c02e41894fa32 (patch)
tree720bc1542dd1edb7308c124a5265e21b3c01d08b /blockdb
downloaddexon-consensus-aed24cf020bd11c3b20a7011b96c02e41894fa32.tar
dexon-consensus-aed24cf020bd11c3b20a7011b96c02e41894fa32.tar.gz
dexon-consensus-aed24cf020bd11c3b20a7011b96c02e41894fa32.tar.bz2
dexon-consensus-aed24cf020bd11c3b20a7011b96c02e41894fa32.tar.lz
dexon-consensus-aed24cf020bd11c3b20a7011b96c02e41894fa32.tar.xz
dexon-consensus-aed24cf020bd11c3b20a7011b96c02e41894fa32.tar.zst
dexon-consensus-aed24cf020bd11c3b20a7011b96c02e41894fa32.zip
Initial implementation of DEXON consensus algorithm
Diffstat (limited to 'blockdb')
-rw-r--r--blockdb/interfaces.go59
-rw-r--r--blockdb/memory.go85
2 files changed, 144 insertions, 0 deletions
diff --git a/blockdb/interfaces.go b/blockdb/interfaces.go
new file mode 100644
index 0000000..4d35e2e
--- /dev/null
+++ b/blockdb/interfaces.go
@@ -0,0 +1,59 @@
+// Copyright 2018 The dexon-consensus-core Authors
+// This file is part of the dexon-consensus-core library.
+//
+// The dexon-consensus-core library is free software: you can redistribute it
+// and/or modify it under the terms of the GNU Lesser General Public License as
+// published by the Free Software Foundation, either version 3 of the License,
+// or (at your option) any later version.
+//
+// The dexon-consensus-core library is distributed in the hope that it will be
+// useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser
+// General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public License
+// along with the dexon-consensus-core library. If not, see
+// <http://www.gnu.org/licenses/>.
+
+package blockdb
+
+import (
+ "errors"
+
+ "github.com/dexon-foundation/dexon-consensus-core/common"
+ "github.com/dexon-foundation/dexon-consensus-core/core/types"
+)
+
+var (
+ // ErrBlockExists is the error when block eixsts.
+ ErrBlockExists = errors.New("block exists")
+ // ErrBlockDoesNotExist is the error when block does not eixsts.
+ ErrBlockDoesNotExist = errors.New("block does not exist")
+ // ErrValidatorDoesNotExist is the error when validator does not eixsts.
+ ErrValidatorDoesNotExist = errors.New("validator does not exist")
+)
+
+// BlockDatabase is the interface for a BlockDatabse.
+type BlockDatabase interface {
+ Reader
+ Writer
+ Deleter
+}
+
+// Reader defines the interface for reading blocks into DB.
+type Reader interface {
+ Has(hash common.Hash) bool
+ Get(hash common.Hash) (types.Block, error)
+ GetByValidatorAndHeight(vID types.ValidatorID, height uint64) (types.Block, error)
+}
+
+// Writer defines the interface for writing blocks into DB.
+type Writer interface {
+ Update(block types.Block) error
+ Put(block types.Block) error
+}
+
+// Deleter defines the interface for deleting blocks in the DB.
+type Deleter interface {
+ Delete(hash common.Hash)
+}
diff --git a/blockdb/memory.go b/blockdb/memory.go
new file mode 100644
index 0000000..fd62b71
--- /dev/null
+++ b/blockdb/memory.go
@@ -0,0 +1,85 @@
+// Copyright 2018 The dexon-consensus-core Authors
+// This file is part of the dexon-consensus-core library.
+//
+// The dexon-consensus-core library is free software: you can redistribute it
+// and/or modify it under the terms of the GNU Lesser General Public License as
+// published by the Free Software Foundation, either version 3 of the License,
+// or (at your option) any later version.
+//
+// The dexon-consensus-core library is distributed in the hope that it will be
+// useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser
+// General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public License
+// along with the dexon-consensus-core library. If not, see
+// <http://www.gnu.org/licenses/>.
+
+package blockdb
+
+import (
+ "github.com/dexon-foundation/dexon-consensus-core/common"
+ "github.com/dexon-foundation/dexon-consensus-core/core/types"
+)
+
+// MemBackendBlockDB is a memory bakcend BlockDB implementation.
+type MemBackendBlockDB struct {
+ blocksByHash map[common.Hash]*types.Block
+ blocksByValidator map[types.ValidatorID]map[uint64]*types.Block
+}
+
+// NewMemBackedBlockDB initialize a memory-backed block database.
+func NewMemBackedBlockDB() *MemBackendBlockDB {
+ return &MemBackendBlockDB{
+ blocksByHash: make(map[common.Hash]*types.Block),
+ blocksByValidator: make(map[types.ValidatorID]map[uint64]*types.Block),
+ }
+}
+
+// Has returns wheter or not the DB has a block identified with the hash.
+func (m *MemBackendBlockDB) Has(hash common.Hash) bool {
+ _, ok := m.blocksByHash[hash]
+ return ok
+}
+
+// Get returns a block given a hash.
+func (m *MemBackendBlockDB) Get(hash common.Hash) (types.Block, error) {
+ b, ok := m.blocksByHash[hash]
+ if !ok {
+ return types.Block{}, ErrBlockDoesNotExist
+ }
+ return *b, nil
+}
+
+// GetByValidatorAndHeight returns a block given validator ID and hash.
+func (m *MemBackendBlockDB) GetByValidatorAndHeight(
+ vID types.ValidatorID, height uint64) (types.Block, error) {
+ validatorBlocks, ok := m.blocksByValidator[vID]
+ if !ok {
+ return types.Block{}, ErrValidatorDoesNotExist
+ }
+ block, ok2 := validatorBlocks[height]
+ if !ok2 {
+ return types.Block{}, ErrBlockDoesNotExist
+ }
+ return *block, nil
+}
+
+// Put inserts a new block into the database.
+func (m *MemBackendBlockDB) Put(block types.Block) error {
+ if m.Has(block.Hash) {
+ return ErrBlockExists
+ }
+ return m.Update(block)
+}
+
+// Update updates a block in the database.
+func (m *MemBackendBlockDB) Update(block types.Block) error {
+ m.blocksByHash[block.Hash] = &block
+ return nil
+}
+
+// Delete deletes a block in the database.
+func (m *MemBackendBlockDB) Delete(hash common.Hash) {
+ delete(m.blocksByHash, hash)
+}