mirror of
https://github.com/kaspanet/kaspad.git
synced 2025-05-20 13:56:45 +00:00

* [NOD-1461] Split blockValidator and TransactionValidator. * [NOD-1461] Remove feeDataStore. * [NOD-1461] Move tips out of ConsensusStateManager and into DAGTopologyManager. * [NOD-1461] Add UTXODiffManager. * [NOD-1461] Add RestoreDiffFromVirtual. * [NOD-1461] Add AcceptanceManager. * [NOD-1461] Replace SetTips with AddTip. * [NOD-1461] Fix merge errors. * [NOD-1461] Rename CoinbaseData to DomainCoinbaseData.
76 lines
2.7 KiB
Go
76 lines
2.7 KiB
Go
package blockprocessor
|
|
|
|
import (
|
|
"github.com/kaspanet/kaspad/domain/consensus/database"
|
|
"github.com/kaspanet/kaspad/domain/consensus/model"
|
|
"github.com/kaspanet/kaspad/domain/consensus/model/externalapi"
|
|
"github.com/kaspanet/kaspad/domain/dagconfig"
|
|
)
|
|
|
|
// blockProcessor is responsible for processing incoming blocks
|
|
// and creating blocks from the current state
|
|
type blockProcessor struct {
|
|
dagParams *dagconfig.Params
|
|
databaseContext *database.DomainDBContext
|
|
|
|
consensusStateManager model.ConsensusStateManager
|
|
pruningManager model.PruningManager
|
|
blockValidator model.BlockValidator
|
|
dagTopologyManager model.DAGTopologyManager
|
|
reachabilityTree model.ReachabilityTree
|
|
difficultyManager model.DifficultyManager
|
|
ghostdagManager model.GHOSTDAGManager
|
|
pastMedianTimeManager model.PastMedianTimeManager
|
|
acceptanceDataStore model.AcceptanceDataStore
|
|
blockMessageStore model.BlockStore
|
|
blockStatusStore model.BlockStatusStore
|
|
}
|
|
|
|
// New instantiates a new BlockProcessor
|
|
func New(
|
|
dagParams *dagconfig.Params,
|
|
databaseContext *database.DomainDBContext,
|
|
consensusStateManager model.ConsensusStateManager,
|
|
pruningManager model.PruningManager,
|
|
blockValidator model.BlockValidator,
|
|
dagTopologyManager model.DAGTopologyManager,
|
|
reachabilityTree model.ReachabilityTree,
|
|
difficultyManager model.DifficultyManager,
|
|
pastMedianTimeManager model.PastMedianTimeManager,
|
|
ghostdagManager model.GHOSTDAGManager,
|
|
acceptanceDataStore model.AcceptanceDataStore,
|
|
blockMessageStore model.BlockStore,
|
|
blockStatusStore model.BlockStatusStore) model.BlockProcessor {
|
|
|
|
return &blockProcessor{
|
|
dagParams: dagParams,
|
|
databaseContext: databaseContext,
|
|
pruningManager: pruningManager,
|
|
blockValidator: blockValidator,
|
|
dagTopologyManager: dagTopologyManager,
|
|
reachabilityTree: reachabilityTree,
|
|
difficultyManager: difficultyManager,
|
|
pastMedianTimeManager: pastMedianTimeManager,
|
|
ghostdagManager: ghostdagManager,
|
|
|
|
consensusStateManager: consensusStateManager,
|
|
acceptanceDataStore: acceptanceDataStore,
|
|
blockMessageStore: blockMessageStore,
|
|
blockStatusStore: blockStatusStore,
|
|
}
|
|
}
|
|
|
|
// BuildBlock builds a block over the current state, with the transactions
|
|
// selected by the given transactionSelector
|
|
func (bp *blockProcessor) BuildBlock(coinbaseData *externalapi.DomainCoinbaseData,
|
|
transactions []*externalapi.DomainTransaction) (*externalapi.DomainBlock, error) {
|
|
|
|
return nil, nil
|
|
}
|
|
|
|
// ValidateAndInsertBlock validates the given block and, if valid, applies it
|
|
// to the current state
|
|
func (bp *blockProcessor) ValidateAndInsertBlock(block *externalapi.DomainBlock) error {
|
|
return nil
|
|
}
|