-
Notifications
You must be signed in to change notification settings - Fork 76
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Change environment prefix from nms to nginx_agent #706
Changes from 2 commits
5b8a8dc
1997ecd
3c5157c
aa1a5ea
5ff0aa5
8873427
596b764
f1d4a55
e4e8ca6
c3c01d3
a31da69
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -47,7 +47,10 @@ const ( | |
` | ||
) | ||
|
||
var Viper = viper.NewWithOptions(viper.KeyDelimiter(agent_config.KeyDelimiter)) | ||
var ( | ||
Viper = viper.NewWithOptions(viper.KeyDelimiter(agent_config.KeyDelimiter)) | ||
MigratedEnv = false | ||
) | ||
|
||
func SetVersion(version, commit string) { | ||
ROOT_COMMAND.Version = version + "-" + commit | ||
|
@@ -133,7 +136,7 @@ func deprecateFlags() { | |
} | ||
|
||
func RegisterFlags() { | ||
Viper.SetEnvPrefix(EnvPrefix) | ||
Viper.SetEnvPrefix(NewEnvPrefix) | ||
Viper.SetEnvKeyReplacer(strings.NewReplacer("-", "_")) | ||
Viper.AutomaticEnv() | ||
|
||
|
@@ -149,6 +152,17 @@ func RegisterFlags() { | |
if err := Viper.BindPFlag(strings.ReplaceAll(flag.Name, "-", "_"), fs.Lookup(flag.Name)); err != nil { | ||
return | ||
} | ||
|
||
oldKey := strings.ToUpper(OldEnvPrefix + "_" + strings.ReplaceAll(flag.Name, "-", "_")) | ||
newKey := strings.ToUpper(NewEnvPrefix + "_" + strings.ReplaceAll(flag.Name, "-", "_")) | ||
|
||
if os.Getenv(oldKey) != "" && os.Getenv(newKey) == "" { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. What about the (admittedly unlikely) case where both There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. If both oldKey and newKey are set we assume the newKey is the one with the correct value and ignore the value from the old key |
||
if err := os.Setenv(newKey, os.Getenv(oldKey)); err != nil { | ||
log.Warnf("Failed to set environment variable %s: %v", newKey, err) | ||
} | ||
MigratedEnv = true | ||
} | ||
|
||
err := Viper.BindEnv(flag.Name) | ||
if err != nil { | ||
log.Warnf("Error occurred binding env %s: %v", flag.Name, err) | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -103,7 +103,8 @@ const ( | |
DynamicConfigFileAbsFreeBsdPath = "/var/db/nginx-agent/agent-dynamic.conf" | ||
ConfigFileName = "nginx-agent.conf" | ||
ConfigFileType = "yaml" | ||
EnvPrefix = "nms" | ||
OldEnvPrefix = "nms" | ||
NewEnvPrefix = "nginx_agent" | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. nit: I think |
||
ConfigPathKey = "path" | ||
DynamicConfigPathKey = "dynamic_config_path" | ||
|
||
|
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Generally it's good practice to use
fmt.Sprintf()
for building strings instead of "string" + "another_string". However, I think your solution is more readable so it's fine here.I would perhaps reuse the
agent_config.KeyDelimiter
variable we have here: