aboutsummaryrefslogtreecommitdiffstats
path: root/core/db/interfaces.go
blob: ebbbbd47517a5f02dbf6a5d3403f4cf091e17915 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
// Copyright 2018 The dexon-consensus Authors
// This file is part of the dexon-consensus library.
//
// The dexon-consensus 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 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 library. If not, see
// <http://www.gnu.org/licenses/>.

package db

import (
    "errors"
    "fmt"

    "github.com/dexon-foundation/dexon-consensus/common"
    "github.com/dexon-foundation/dexon-consensus/core/crypto/dkg"
    "github.com/dexon-foundation/dexon-consensus/core/types"
)

var (
    // ErrBlockExists is the error when block eixsts.
    ErrBlockExists = errors.New("block exists")
    // ErrBlockDoesNotExist is the error when block does not eixst.
    ErrBlockDoesNotExist = errors.New("block does not exist")
    // ErrIterationFinished is the error to check if the iteration is finished.
    ErrIterationFinished = errors.New("iteration finished")
    // ErrEmptyPath is the error when the required path is empty.
    ErrEmptyPath = fmt.Errorf("empty path")
    // ErrClosed is the error when using DB after it's closed.
    ErrClosed = fmt.Errorf("db closed")
    // ErrNotImplemented is the error that some interface is not implemented.
    ErrNotImplemented = fmt.Errorf("not implemented")
    // ErrInvalidCompactionChainTipHeight means the newly updated height of
    // the tip of compaction chain is invalid, usually means it's smaller than
    // current cached one.
    ErrInvalidCompactionChainTipHeight = fmt.Errorf(
        "invalid compaction chain tip height")
    // ErrDKGPrivateKeyExists raised when attempting to save DKG private key
    // that already saved.
    ErrDKGPrivateKeyExists = errors.New("dkg private key exists")
    // ErrDKGPrivateKeyDoesNotExist raised when the DKG private key of the
    // requested round does not exists.
    ErrDKGPrivateKeyDoesNotExist = errors.New("dkg private key does not exists")
)

// Database is the interface for a Database.
type Database interface {
    Reader
    Writer

    // Close allows database implementation able to
    // release resource when finishing.
    Close() error
}

// Reader defines the interface for reading blocks into DB.
type Reader interface {
    HasBlock(hash common.Hash) bool
    GetBlock(hash common.Hash) (types.Block, error)
    GetAllBlocks() (BlockIterator, error)

    // GetCompactionChainTipInfo returns the block hash and finalization height
    // of the tip block of compaction chain. Empty hash and zero height means
    // the compaction chain is empty.
    GetCompactionChainTipInfo() (common.Hash, uint64)

    // DKG Private Key related methods.
    HasDKGPrivateKey(round uint64) (bool, error)
    GetDKGPrivateKey(round uint64) (dkg.PrivateKey, error)
}

// Writer defines the interface for writing blocks into DB.
type Writer interface {
    UpdateBlock(block types.Block) error
    PutBlock(block types.Block) error
    PutCompactionChainTipInfo(common.Hash, uint64) error
    PutDKGPrivateKey(uint64, dkg.PrivateKey) error
}

// BlockIterator defines an iterator on blocks hold
// in a DB.
type BlockIterator interface {
    NextBlock() (types.Block, error)
}