You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
61 lines
1.9 KiB
61 lines
1.9 KiB
package blockproposal
|
|
|
|
import (
|
|
"github.com/ethereum/go-ethereum/rpc"
|
|
msg_pb "github.com/harmony-one/harmony/api/proto/message"
|
|
"github.com/harmony-one/harmony/internal/utils"
|
|
)
|
|
|
|
// Service is a block proposal service.
|
|
type Service struct {
|
|
stopChan chan struct{}
|
|
stoppedChan chan struct{}
|
|
readySignal chan struct{}
|
|
commitSigsChan chan []byte
|
|
messageChan chan *msg_pb.Message
|
|
waitForConsensusReady func(readySignal chan struct{}, commitSigsChan chan []byte, stopChan chan struct{}, stoppedChan chan struct{})
|
|
}
|
|
|
|
// New returns a block proposal service.
|
|
func New(readySignal chan struct{}, commitSigsChan chan []byte, waitForConsensusReady func(readySignal chan struct{}, commitSigsChan chan []byte, stopChan chan struct{}, stoppedChan chan struct{})) *Service {
|
|
return &Service{readySignal: readySignal, commitSigsChan: commitSigsChan, waitForConsensusReady: waitForConsensusReady}
|
|
}
|
|
|
|
// StartService starts block proposal service.
|
|
func (s *Service) StartService() {
|
|
s.stopChan = make(chan struct{})
|
|
s.stoppedChan = make(chan struct{})
|
|
|
|
s.Init()
|
|
s.Run(s.stopChan, s.stoppedChan)
|
|
}
|
|
|
|
// Init initializes block proposal service.
|
|
func (s *Service) Init() {
|
|
}
|
|
|
|
// Run runs block proposal.
|
|
func (s *Service) Run(stopChan chan struct{}, stoppedChan chan struct{}) {
|
|
s.waitForConsensusReady(s.readySignal, s.commitSigsChan, s.stopChan, s.stoppedChan)
|
|
}
|
|
|
|
// StopService stops block proposal service.
|
|
func (s *Service) StopService() {
|
|
utils.Logger().Info().Msg("Stopping block proposal service.")
|
|
s.stopChan <- struct{}{}
|
|
<-s.stoppedChan
|
|
utils.Logger().Info().Msg("Role conversion stopped.")
|
|
}
|
|
|
|
// NotifyService notify service
|
|
func (s *Service) NotifyService(params map[string]interface{}) {}
|
|
|
|
// SetMessageChan sets up message channel to service.
|
|
func (s *Service) SetMessageChan(messageChan chan *msg_pb.Message) {
|
|
s.messageChan = messageChan
|
|
}
|
|
|
|
// APIs for the services.
|
|
func (s *Service) APIs() []rpc.API {
|
|
return nil
|
|
}
|
|
|