mirror of
https://github.com/kaspanet/kaspad.git
synced 2025-05-22 14:56:44 +00:00

* [NOD-1590] Moved all finality logic to FinalityManager * [NOD-1590] Add finality store * [NOD-1590] Implement optimized finalityPoint calculation mechanism * [NOD-1590] Add comments * [NOD-1590] Add finalityStore to consensus object, and TestConsensus * [NOD-1590] Added logs to finalityPoint calculation
108 lines
3.7 KiB
Go
108 lines
3.7 KiB
Go
package blockvalidator
|
|
|
|
import (
|
|
"math/big"
|
|
"time"
|
|
|
|
"github.com/kaspanet/kaspad/domain/consensus/model"
|
|
"github.com/kaspanet/kaspad/domain/consensus/model/externalapi"
|
|
"github.com/kaspanet/kaspad/util"
|
|
)
|
|
|
|
// blockValidator exposes a set of validation classes, after which
|
|
// it's possible to determine whether either a block is valid
|
|
type blockValidator struct {
|
|
powMax *big.Int
|
|
skipPoW bool
|
|
genesisHash *externalapi.DomainHash
|
|
enableNonNativeSubnetworks bool
|
|
powMaxBits uint32
|
|
maxBlockSize uint64
|
|
mergeSetSizeLimit uint64
|
|
maxBlockParents model.KType
|
|
timestampDeviationTolerance int
|
|
targetTimePerBlock time.Duration
|
|
|
|
databaseContext model.DBReader
|
|
difficultyManager model.DifficultyManager
|
|
pastMedianTimeManager model.PastMedianTimeManager
|
|
transactionValidator model.TransactionValidator
|
|
ghostdagManager model.GHOSTDAGManager
|
|
dagTopologyManager model.DAGTopologyManager
|
|
dagTraversalManager model.DAGTraversalManager
|
|
coinbaseManager model.CoinbaseManager
|
|
mergeDepthManager model.MergeDepthManager
|
|
pruningStore model.PruningStore
|
|
reachabilityManager model.ReachabilityManager
|
|
|
|
blockStore model.BlockStore
|
|
ghostdagDataStore model.GHOSTDAGDataStore
|
|
blockHeaderStore model.BlockHeaderStore
|
|
blockStatusStore model.BlockStatusStore
|
|
reachabilityStore model.ReachabilityDataStore
|
|
}
|
|
|
|
// New instantiates a new BlockValidator
|
|
func New(powMax *big.Int,
|
|
skipPoW bool,
|
|
genesisHash *externalapi.DomainHash,
|
|
enableNonNativeSubnetworks bool,
|
|
maxBlockSize uint64,
|
|
mergeSetSizeLimit uint64,
|
|
maxBlockParents model.KType,
|
|
timestampDeviationTolerance int,
|
|
targetTimePerBlock time.Duration,
|
|
|
|
databaseContext model.DBReader,
|
|
|
|
difficultyManager model.DifficultyManager,
|
|
pastMedianTimeManager model.PastMedianTimeManager,
|
|
transactionValidator model.TransactionValidator,
|
|
ghostdagManager model.GHOSTDAGManager,
|
|
dagTopologyManager model.DAGTopologyManager,
|
|
dagTraversalManager model.DAGTraversalManager,
|
|
coinbaseManager model.CoinbaseManager,
|
|
mergeDepthManager model.MergeDepthManager,
|
|
reachabilityManager model.ReachabilityManager,
|
|
|
|
pruningStore model.PruningStore,
|
|
|
|
blockStore model.BlockStore,
|
|
ghostdagDataStore model.GHOSTDAGDataStore,
|
|
blockHeaderStore model.BlockHeaderStore,
|
|
blockStatusStore model.BlockStatusStore,
|
|
reachabilityStore model.ReachabilityDataStore,
|
|
) model.BlockValidator {
|
|
|
|
return &blockValidator{
|
|
powMax: powMax,
|
|
skipPoW: skipPoW,
|
|
genesisHash: genesisHash,
|
|
enableNonNativeSubnetworks: enableNonNativeSubnetworks,
|
|
powMaxBits: util.BigToCompact(powMax),
|
|
maxBlockSize: maxBlockSize,
|
|
mergeSetSizeLimit: mergeSetSizeLimit,
|
|
maxBlockParents: maxBlockParents,
|
|
|
|
timestampDeviationTolerance: timestampDeviationTolerance,
|
|
targetTimePerBlock: targetTimePerBlock,
|
|
databaseContext: databaseContext,
|
|
difficultyManager: difficultyManager,
|
|
pastMedianTimeManager: pastMedianTimeManager,
|
|
transactionValidator: transactionValidator,
|
|
ghostdagManager: ghostdagManager,
|
|
dagTopologyManager: dagTopologyManager,
|
|
dagTraversalManager: dagTraversalManager,
|
|
coinbaseManager: coinbaseManager,
|
|
mergeDepthManager: mergeDepthManager,
|
|
reachabilityManager: reachabilityManager,
|
|
|
|
pruningStore: pruningStore,
|
|
blockStore: blockStore,
|
|
ghostdagDataStore: ghostdagDataStore,
|
|
blockHeaderStore: blockHeaderStore,
|
|
blockStatusStore: blockStatusStore,
|
|
reachabilityStore: reachabilityStore,
|
|
}
|
|
}
|