2018-02-14 11:04:34 -08:00
|
|
|
package server
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
"github.com/spf13/cobra"
|
|
|
|
"github.com/spf13/viper"
|
|
|
|
|
|
|
|
"github.com/tendermint/abci/server"
|
2018-02-21 01:57:51 -08:00
|
|
|
abci "github.com/tendermint/abci/types"
|
2018-02-14 11:04:34 -08:00
|
|
|
|
|
|
|
tcmd "github.com/tendermint/tendermint/cmd/tendermint/commands"
|
|
|
|
"github.com/tendermint/tendermint/node"
|
|
|
|
"github.com/tendermint/tendermint/proxy"
|
|
|
|
"github.com/tendermint/tendermint/types"
|
|
|
|
cmn "github.com/tendermint/tmlibs/common"
|
2018-02-21 01:57:51 -08:00
|
|
|
"github.com/tendermint/tmlibs/log"
|
2018-02-14 11:04:34 -08:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
flagWithTendermint = "with-tendermint"
|
|
|
|
flagAddress = "address"
|
|
|
|
)
|
|
|
|
|
2018-04-05 03:24:53 -07:00
|
|
|
// AppCreator lets us lazily initialize app, using home dir
|
2018-02-21 09:56:04 -08:00
|
|
|
// and other flags (?) to start
|
2018-04-05 03:24:53 -07:00
|
|
|
type AppCreator func(string, log.Logger) (abci.Application, error)
|
2018-02-21 09:56:04 -08:00
|
|
|
|
2018-02-14 12:53:06 -08:00
|
|
|
// StartCmd runs the service passed in, either
|
2018-02-14 11:04:34 -08:00
|
|
|
// stand-alone, or in-process with tendermint
|
2018-04-05 03:24:53 -07:00
|
|
|
func StartCmd(app AppCreator, ctx *Context) *cobra.Command {
|
2018-02-14 12:53:06 -08:00
|
|
|
start := startCmd{
|
2018-03-17 17:42:18 -07:00
|
|
|
appCreator: app,
|
2018-04-04 04:39:13 -07:00
|
|
|
context: ctx,
|
2018-02-14 11:04:34 -08:00
|
|
|
}
|
|
|
|
cmd := &cobra.Command{
|
|
|
|
Use: "start",
|
|
|
|
Short: "Run the full node",
|
|
|
|
RunE: start.run,
|
|
|
|
}
|
|
|
|
// basic flags for abci app
|
|
|
|
cmd.Flags().Bool(flagWithTendermint, true, "run abci app embedded in-process with tendermint")
|
|
|
|
cmd.Flags().String(flagAddress, "tcp://0.0.0.0:46658", "Listen address")
|
|
|
|
|
|
|
|
// AddNodeFlags adds support for all
|
|
|
|
// tendermint-specific command line options
|
|
|
|
tcmd.AddNodeFlags(cmd)
|
|
|
|
return cmd
|
|
|
|
}
|
|
|
|
|
2018-02-14 12:53:06 -08:00
|
|
|
type startCmd struct {
|
2018-04-05 03:24:53 -07:00
|
|
|
appCreator AppCreator
|
2018-04-04 04:39:13 -07:00
|
|
|
context *Context
|
2018-02-14 11:04:34 -08:00
|
|
|
}
|
|
|
|
|
2018-02-14 12:53:06 -08:00
|
|
|
func (s startCmd) run(cmd *cobra.Command, args []string) error {
|
2018-02-14 11:04:34 -08:00
|
|
|
if !viper.GetBool(flagWithTendermint) {
|
2018-04-04 04:39:13 -07:00
|
|
|
s.context.Logger.Info("Starting ABCI without Tendermint")
|
2018-02-14 11:04:34 -08:00
|
|
|
return s.startStandAlone()
|
|
|
|
}
|
2018-04-04 04:39:13 -07:00
|
|
|
s.context.Logger.Info("Starting ABCI with Tendermint")
|
2018-02-14 11:04:34 -08:00
|
|
|
return s.startInProcess()
|
|
|
|
}
|
|
|
|
|
2018-02-14 12:53:06 -08:00
|
|
|
func (s startCmd) startStandAlone() error {
|
2018-02-21 09:56:04 -08:00
|
|
|
// Generate the app in the proper dir
|
2018-02-14 11:04:34 -08:00
|
|
|
addr := viper.GetString(flagAddress)
|
2018-02-21 09:56:04 -08:00
|
|
|
home := viper.GetString("home")
|
2018-04-04 04:39:13 -07:00
|
|
|
app, err := s.appCreator(home, s.context.Logger)
|
2018-02-21 09:56:04 -08:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
svr, err := server.NewServer(addr, "socket", app)
|
2018-02-14 11:04:34 -08:00
|
|
|
if err != nil {
|
|
|
|
return errors.Errorf("Error creating listener: %v\n", err)
|
|
|
|
}
|
2018-04-04 04:39:13 -07:00
|
|
|
svr.SetLogger(s.context.Logger.With("module", "abci-server"))
|
2018-02-14 11:04:34 -08:00
|
|
|
svr.Start()
|
|
|
|
|
|
|
|
// Wait forever
|
|
|
|
cmn.TrapSignal(func() {
|
|
|
|
// Cleanup
|
|
|
|
svr.Stop()
|
|
|
|
})
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2018-02-14 12:53:06 -08:00
|
|
|
func (s startCmd) startInProcess() error {
|
2018-04-04 04:39:13 -07:00
|
|
|
cfg := s.context.Config
|
2018-02-21 09:56:04 -08:00
|
|
|
home := cfg.RootDir
|
2018-04-04 04:39:13 -07:00
|
|
|
app, err := s.appCreator(home, s.context.Logger)
|
2018-02-21 09:56:04 -08:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2018-02-14 11:04:34 -08:00
|
|
|
// Create & start tendermint node
|
|
|
|
n, err := node.NewNode(cfg,
|
|
|
|
types.LoadOrGenPrivValidatorFS(cfg.PrivValidatorFile()),
|
2018-02-21 09:56:04 -08:00
|
|
|
proxy.NewLocalClientCreator(app),
|
2018-02-14 11:04:34 -08:00
|
|
|
node.DefaultGenesisDocProviderFunc(cfg),
|
|
|
|
node.DefaultDBProvider,
|
2018-04-04 04:39:13 -07:00
|
|
|
s.context.Logger.With("module", "node"))
|
2018-02-14 11:04:34 -08:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
err = n.Start()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Trap signal, run forever.
|
|
|
|
n.RunForever()
|
|
|
|
return nil
|
|
|
|
}
|