mirror of
https://github.com/kaspanet/kaspad.git
synced 2025-03-30 15:08:33 +00:00

* Add mass limit to mempool * Pass only params instead of multiple configuration options * Remove acceptNonStd from mempool constructor * Remove acceptNonStd from mempool constructor * Fix test compilation
46 lines
1.3 KiB
Go
46 lines
1.3 KiB
Go
package domain
|
|
|
|
import (
|
|
"github.com/kaspanet/kaspad/domain/consensus"
|
|
"github.com/kaspanet/kaspad/domain/consensus/model/externalapi"
|
|
"github.com/kaspanet/kaspad/domain/dagconfig"
|
|
"github.com/kaspanet/kaspad/domain/miningmanager"
|
|
infrastructuredatabase "github.com/kaspanet/kaspad/infrastructure/db/database"
|
|
)
|
|
|
|
// Domain provides a reference to the domain's external aps
|
|
type Domain interface {
|
|
MiningManager() miningmanager.MiningManager
|
|
Consensus() externalapi.Consensus
|
|
}
|
|
|
|
type domain struct {
|
|
miningManager miningmanager.MiningManager
|
|
consensus externalapi.Consensus
|
|
}
|
|
|
|
func (d domain) Consensus() externalapi.Consensus {
|
|
return d.consensus
|
|
}
|
|
|
|
func (d domain) MiningManager() miningmanager.MiningManager {
|
|
return d.miningManager
|
|
}
|
|
|
|
// New instantiates a new instance of a Domain object
|
|
func New(dagParams *dagconfig.Params, db infrastructuredatabase.Database, isArchivalNode bool) (Domain, error) {
|
|
consensusFactory := consensus.NewFactory()
|
|
consensusInstance, err := consensusFactory.NewConsensus(dagParams, db, isArchivalNode)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
miningManagerFactory := miningmanager.NewFactory()
|
|
miningManager := miningManagerFactory.NewMiningManager(consensusInstance, dagParams)
|
|
|
|
return &domain{
|
|
consensus: consensusInstance,
|
|
miningManager: miningManager,
|
|
}, nil
|
|
}
|