mirror of
https://source.quilibrium.com/quilibrium/ceremonyclient.git
synced 2025-01-26 15:47:11 +00:00
96 lines
2.3 KiB
Go
96 lines
2.3 KiB
Go
//go:build wireinject
|
|
// +build wireinject
|
|
|
|
package app
|
|
|
|
import (
|
|
"github.com/google/wire"
|
|
"go.uber.org/zap"
|
|
"source.quilibrium.com/quilibrium/monorepo/node/config"
|
|
"source.quilibrium.com/quilibrium/monorepo/node/consensus"
|
|
ceremonyConsensus "source.quilibrium.com/quilibrium/monorepo/node/consensus/ceremony"
|
|
"source.quilibrium.com/quilibrium/monorepo/node/consensus/master"
|
|
"source.quilibrium.com/quilibrium/monorepo/node/execution/ceremony"
|
|
"source.quilibrium.com/quilibrium/monorepo/node/keys"
|
|
"source.quilibrium.com/quilibrium/monorepo/node/p2p"
|
|
"source.quilibrium.com/quilibrium/monorepo/node/store"
|
|
)
|
|
|
|
func logger() *zap.Logger {
|
|
log, err := zap.NewProduction()
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
return log
|
|
}
|
|
|
|
var loggerSet = wire.NewSet(
|
|
logger,
|
|
)
|
|
|
|
var keyManagerSet = wire.NewSet(
|
|
wire.FieldsOf(new(*config.Config), "Key"),
|
|
keys.NewFileKeyManager,
|
|
wire.Bind(new(keys.KeyManager), new(*keys.FileKeyManager)),
|
|
)
|
|
|
|
var storeSet = wire.NewSet(
|
|
wire.FieldsOf(new(*config.Config), "DB"),
|
|
store.NewPebbleDB,
|
|
store.NewPebbleClockStore,
|
|
store.NewPebbleKeyStore,
|
|
store.NewPebbleDataProofStore,
|
|
wire.Bind(new(store.ClockStore), new(*store.PebbleClockStore)),
|
|
wire.Bind(new(store.KeyStore), new(*store.PebbleKeyStore)),
|
|
wire.Bind(new(store.DataProofStore), new(*store.PebbleDataProofStore)),
|
|
)
|
|
|
|
var pubSubSet = wire.NewSet(
|
|
wire.FieldsOf(new(*config.Config), "P2P"),
|
|
p2p.NewBlossomSub,
|
|
wire.Bind(new(p2p.PubSub), new(*p2p.BlossomSub)),
|
|
)
|
|
|
|
var dataConsensusSet = wire.NewSet(
|
|
wire.FieldsOf(new(*config.Config), "Engine"),
|
|
ceremonyConsensus.NewCeremonyDataClockConsensusEngine,
|
|
wire.Bind(
|
|
new(consensus.DataConsensusEngine),
|
|
new(*ceremonyConsensus.CeremonyDataClockConsensusEngine),
|
|
),
|
|
)
|
|
|
|
var engineSet = wire.NewSet(
|
|
ceremony.NewCeremonyExecutionEngine,
|
|
)
|
|
|
|
var consensusSet = wire.NewSet(
|
|
master.NewMasterClockConsensusEngine,
|
|
wire.Bind(
|
|
new(consensus.ConsensusEngine),
|
|
new(*master.MasterClockConsensusEngine),
|
|
),
|
|
)
|
|
|
|
func NewNode(*config.Config) (*Node, error) {
|
|
panic(wire.Build(
|
|
loggerSet,
|
|
keyManagerSet,
|
|
storeSet,
|
|
pubSubSet,
|
|
engineSet,
|
|
dataConsensusSet,
|
|
consensusSet,
|
|
newNode,
|
|
))
|
|
}
|
|
|
|
func NewDBConsole(*config.Config) (*DBConsole, error) {
|
|
panic(wire.Build(loggerSet, storeSet, newDBConsole))
|
|
}
|
|
|
|
func NewClockStore(*config.Config) (store.ClockStore, error) {
|
|
panic(wire.Build(loggerSet, storeSet))
|
|
}
|