args: Honor config-dir & quiet wherever they are (#3356)

setGlobalsFromContext() is added to set global variables after parsing
command line arguments. Thus, global flags will be honored wherever
they are placed in minio command.
master
Anis Elleuch 8 years ago committed by Harshavardhana
parent 9ccfb70104
commit 01f625824a
  1. 25
      cmd/globals.go
  2. 119
      cmd/main.go
  3. 9
      cmd/server-main.go
  4. 10
      cmd/update-main.go
  5. 10
      cmd/version-main.go

@ -22,6 +22,8 @@ import (
humanize "github.com/dustin/go-humanize" humanize "github.com/dustin/go-humanize"
"github.com/fatih/color" "github.com/fatih/color"
"github.com/minio/cli"
"github.com/minio/mc/pkg/console"
"github.com/minio/minio/pkg/objcache" "github.com/minio/minio/pkg/objcache"
) )
@ -53,11 +55,12 @@ const (
) )
var ( var (
globalQuiet = false // Quiet flag set via command line. globalQuiet = false // quiet flag set via command line.
globalIsDistXL = false // "Is Distributed?" flag. globalConfigDir = mustGetConfigPath() // config-dir flag set via command line
// Add new global flags here. // Add new global flags here.
globalIsDistXL = false // "Is Distributed?" flag.
// Maximum cache size. // Maximum cache size.
globalMaxCacheSize = uint64(maxCacheSize) globalMaxCacheSize = uint64(maxCacheSize)
// Cache expiry. // Cache expiry.
@ -90,3 +93,19 @@ var (
colorBlue = color.New(color.FgBlue).SprintfFunc() colorBlue = color.New(color.FgBlue).SprintfFunc()
colorGreen = color.New(color.FgGreen).SprintfFunc() colorGreen = color.New(color.FgGreen).SprintfFunc()
) )
// Parse command arguments and set global variables accordingly
func setGlobalsFromContext(c *cli.Context) {
// Set config dir
switch {
case c.IsSet("config-dir"):
globalConfigDir = c.String("config-dir")
case c.GlobalIsSet("config-dir"):
globalConfigDir = c.GlobalString("config-dir")
}
if globalConfigDir == "" {
console.Fatalf("Unable to get config file. Config directory is empty.")
}
// Set global quiet flag.
globalQuiet = c.Bool("quiet") || c.GlobalBool("quiet")
}

@ -17,7 +17,6 @@
package cmd package cmd
import ( import (
"errors"
"fmt" "fmt"
"os" "os"
"sort" "sort"
@ -148,72 +147,70 @@ func checkMainSyntax(c *cli.Context) {
} }
} }
// Main main for minio server. // Check for updates and print a notification message
func Main() { func checkUpdate() {
app := registerApp() // Do not print update messages, if quiet flag is set.
app.Before = func(c *cli.Context) error { if !globalQuiet {
configDir := c.GlobalString("config-dir") updateMsg, _, err := getReleaseUpdate(minioUpdateStableURL, 1*time.Second)
if configDir == "" { if err != nil {
fatalIf(errors.New("Config directory is empty"), "Unable to get config file.") // Ignore any errors during getReleaseUpdate(), possibly
// because of network errors.
return
} }
// Sets new config directory. if updateMsg.Update {
setGlobalConfigPath(configDir) console.Println(updateMsg)
}
}
}
// Valid input arguments to main. // Generic Minio initialization to create/load config, prepare loggers, etc..
checkMainSyntax(c) func minioInit() {
// Sets new config directory.
setGlobalConfigPath(globalConfigDir)
// Migrate any old version of config / state files to newer format. // Migrate any old version of config / state files to newer format.
migrate() migrate()
// Initialize config. // Initialize config.
configCreated, err := initConfig() configCreated, err := initConfig()
if err != nil { if err != nil {
console.Fatalf("Unable to initialize minio config. Err: %s.\n", err) console.Fatalf("Unable to initialize minio config. Err: %s.\n", err)
} }
if configCreated { if configCreated {
console.Println("Created minio configuration file at " + mustGetConfigPath()) console.Println("Created minio configuration file at " + mustGetConfigPath())
} }
// Enable all loggers by now so we can use errorIf() and fatalIf() // Enable all loggers by now so we can use errorIf() and fatalIf()
enableLoggers() enableLoggers()
// Fetch access keys from environment variables and update the config. // Fetch access keys from environment variables and update the config.
accessKey := os.Getenv("MINIO_ACCESS_KEY") accessKey := os.Getenv("MINIO_ACCESS_KEY")
secretKey := os.Getenv("MINIO_SECRET_KEY") secretKey := os.Getenv("MINIO_SECRET_KEY")
if accessKey != "" && secretKey != "" { if accessKey != "" && secretKey != "" {
// Set new credentials. // Set new credentials.
serverConfig.SetCredential(credential{ serverConfig.SetCredential(credential{
AccessKeyID: accessKey, AccessKeyID: accessKey,
SecretAccessKey: secretKey, SecretAccessKey: secretKey,
}) })
} }
if !isValidAccessKey(serverConfig.GetCredential().AccessKeyID) { if !isValidAccessKey(serverConfig.GetCredential().AccessKeyID) {
fatalIf(errInvalidArgument, "Invalid access key. Accept only a string starting with a alphabetic and containing from 5 to 20 characters.") fatalIf(errInvalidArgument, "Invalid access key. Accept only a string starting with a alphabetic and containing from 5 to 20 characters.")
} }
if !isValidSecretKey(serverConfig.GetCredential().SecretAccessKey) { if !isValidSecretKey(serverConfig.GetCredential().SecretAccessKey) {
fatalIf(errInvalidArgument, "Invalid secret key. Accept only a string containing from 8 to 40 characters.") fatalIf(errInvalidArgument, "Invalid secret key. Accept only a string containing from 8 to 40 characters.")
} }
// Init the error tracing module. // Init the error tracing module.
initError() initError()
// Set global quiet flag. }
globalQuiet = c.Bool("quiet") || c.GlobalBool("quiet")
// Main main for minio server.
// Do not print update messages, if quiet flag is set. func Main() {
if !globalQuiet { app := registerApp()
if c.Args().Get(0) != "update" { app.Before = func(c *cli.Context) error {
updateMsg, _, err := getReleaseUpdate(minioUpdateStableURL, 1*time.Second) // Valid input arguments to main.
if err != nil { checkMainSyntax(c)
// Ignore any errors during getReleaseUpdate(), possibly
// because of network errors.
return nil
}
if updateMsg.Update {
console.Println(updateMsg)
}
}
}
return nil return nil
} }

@ -363,8 +363,13 @@ func serverMain(c *cli.Context) {
cli.ShowCommandHelpAndExit(c, "server", 1) cli.ShowCommandHelpAndExit(c, "server", 1)
} }
// Set global quiet flag. // Set global variables after parsing passed arguments
globalQuiet = c.Bool("quiet") || c.GlobalBool("quiet") setGlobalsFromContext(c)
// Initialization routine, such as config loading, enable logging, ..
minioInit()
checkUpdate()
// Server address. // Server address.
serverAddr := c.String("address") serverAddr := c.String("address")

@ -265,8 +265,14 @@ func getReleaseUpdate(updateURL string, duration time.Duration) (updateMsg updat
// main entry point for update command. // main entry point for update command.
func mainUpdate(ctx *cli.Context) { func mainUpdate(ctx *cli.Context) {
// Set global quiet flag.
if ctx.Bool("quiet") || ctx.GlobalBool("quiet") { // Set global variables after parsing passed arguments
setGlobalsFromContext(ctx)
// Initialization routine, such as config loading, enable logging, ..
minioInit()
if globalQuiet {
return return
} }

@ -43,8 +43,14 @@ func mainVersion(ctx *cli.Context) {
if len(ctx.Args()) != 0 { if len(ctx.Args()) != 0 {
cli.ShowCommandHelpAndExit(ctx, "version", 1) cli.ShowCommandHelpAndExit(ctx, "version", 1)
} }
// Set global quiet flag.
if ctx.Bool("quiet") || ctx.GlobalBool("quiet") { // Set global variables after parsing passed arguments
setGlobalsFromContext(ctx)
// Initialization routine, such as config loading, enable logging, ..
minioInit()
if globalQuiet {
return return
} }

Loading…
Cancel
Save