2016-08-29 19:09:57 -07:00
|
|
|
package command
|
|
|
|
|
|
|
|
import (
|
|
|
|
"strings"
|
|
|
|
|
2017-02-09 18:19:34 -05:00
|
|
|
"github.com/hashicorp/consul/command/base"
|
2017-02-15 13:30:07 -08:00
|
|
|
"github.com/mitchellh/cli"
|
2016-08-29 19:09:57 -07:00
|
|
|
)
|
|
|
|
|
|
|
|
// OperatorCommand is used to provide various low-level tools for Consul
|
|
|
|
// operators.
|
|
|
|
type OperatorCommand struct {
|
2017-02-09 18:19:34 -05:00
|
|
|
base.Command
|
2016-08-29 19:09:57 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
func (c *OperatorCommand) Help() string {
|
|
|
|
helpText := `
|
2017-02-15 13:30:07 -08:00
|
|
|
Usage: consul operator <subcommand> [options]
|
2016-08-29 19:09:57 -07:00
|
|
|
|
|
|
|
Provides cluster-level tools for Consul operators, such as interacting with
|
|
|
|
the Raft subsystem. NOTE: Use this command with extreme caution, as improper
|
|
|
|
use could lead to a Consul outage and even loss of data.
|
|
|
|
|
2016-11-16 09:04:37 +00:00
|
|
|
If ACLs are enabled then a token with operator privileges may be required in
|
2016-08-29 19:09:57 -07:00
|
|
|
order to use this command. Requests are forwarded internally to the leader
|
|
|
|
if required, so this can be run from any Consul node in a cluster.
|
|
|
|
|
|
|
|
Run consul operator <subcommand> with no arguments for help on that
|
|
|
|
subcommand.
|
|
|
|
`
|
|
|
|
return strings.TrimSpace(helpText)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *OperatorCommand) Run(args []string) int {
|
2017-02-15 13:30:07 -08:00
|
|
|
return cli.RunResultHelp
|
2016-08-29 19:09:57 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// Synopsis returns a one-line description of this command.
|
|
|
|
func (c *OperatorCommand) Synopsis() string {
|
|
|
|
return "Provides cluster-level tools for Consul operators"
|
|
|
|
}
|