From 92c369c95ed944deaa1ff498a0a9be873b27c873 Mon Sep 17 00:00:00 2001 From: Mahmood Ali Date: Wed, 31 Jul 2019 03:19:15 -0500 Subject: [PATCH] Only warn against BootstrapExpect set in CLI flag If server.enabled is false, we ought to ignore all other values in the server stanza. However, I opted to preserve current error when `--bootstrap-expect` is passed to the CLI when server is not enabled, to maintain current behavior. --- command/agent/command.go | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/command/agent/command.go b/command/agent/command.go index 34567c0e280..06ac403912e 100644 --- a/command/agent/command.go +++ b/command/agent/command.go @@ -270,14 +270,14 @@ func (c *Command) readConfig() *Config { config.PluginDir = filepath.Join(config.DataDir, "plugins") } - if !c.isValidConfig(config) { + if !c.isValidConfig(config, cmdConfig) { return nil } return config } -func (c *Command) isValidConfig(config *Config) bool { +func (c *Command) isValidConfig(config, cmdConfig *Config) bool { // Check that the server is running in at least one mode. if !(config.Server.Enabled || config.Client.Enabled) { @@ -353,11 +353,12 @@ func (c *Command) isValidConfig(config *Config) bool { } // Check the bootstrap flags - if config.Server.BootstrapExpect > 0 && !config.Server.Enabled { + if !config.Server.Enabled && cmdConfig.Server.BootstrapExpect > 0 { + // report an error if BootstrapExpect is set in CLI but server is disabled c.Ui.Error("Bootstrap requires server mode to be enabled") return false } - if config.Server.BootstrapExpect == 1 { + if config.Server.Enabled && config.Server.BootstrapExpect == 1 { c.Ui.Error("WARNING: Bootstrap mode enabled! Potentially unsafe operation.") }