fix metal provider flag and env loading, and return error if provider not defined
This commit is contained in:
@@ -3,6 +3,10 @@ package emapi
|
||||
import (
|
||||
"fmt"
|
||||
"net/url"
|
||||
|
||||
"github.com/spf13/pflag"
|
||||
"github.com/spf13/viper"
|
||||
"go.infratographer.com/x/viperx"
|
||||
)
|
||||
|
||||
// Config provides configuration for connecting to the Equinix Metal API provider.
|
||||
@@ -17,6 +21,18 @@ type Config struct {
|
||||
ConsumerToken string
|
||||
}
|
||||
|
||||
// MustViperFlags registers command flags along with the viper bindings.
|
||||
func MustViperFlags(v *viper.Viper, flags *pflag.FlagSet) {
|
||||
flags.String("emapi-base-url", "", "Equinix Metal Rest API Base URL")
|
||||
viperx.MustBindFlag(v, "equinixmetal.emapi.baseurl", flags.Lookup("emapi-base-url"))
|
||||
|
||||
flags.String("emapi-auth-token", "", "Equinix Metal Rest Auth Token")
|
||||
viperx.MustBindFlag(v, "equinixmetal.emapi.authtoken", flags.Lookup("emapi-auth-token"))
|
||||
|
||||
flags.String("emapi-consumer-token", "", "Equinix Metal Rest Consumer Token")
|
||||
viperx.MustBindFlag(v, "equinixmetal.emapi.consumertoken", flags.Lookup("emapi-consumer-token"))
|
||||
}
|
||||
|
||||
// Populated checks if any field has been populated.
|
||||
func (c Config) Populated() bool {
|
||||
return c.AuthToken != "" || c.ConsumerToken != "" || c.BaseURL != ""
|
||||
|
||||
@@ -1,11 +1,23 @@
|
||||
package emgql
|
||||
|
||||
import (
|
||||
"github.com/spf13/pflag"
|
||||
"github.com/spf13/viper"
|
||||
"go.infratographer.com/x/viperx"
|
||||
)
|
||||
|
||||
// Config provides configuration for connecting to the Equinix Metal API provider.
|
||||
type Config struct {
|
||||
// BaseURL is the baseurl to use when connecting to the Equinix Metal API Provider.
|
||||
BaseURL string
|
||||
}
|
||||
|
||||
// MustViperFlags registers command flags along with the viper bindings.
|
||||
func MustViperFlags(v *viper.Viper, flags *pflag.FlagSet) {
|
||||
flags.String("emgql-base-url", "", "Equinix Metal GraphQL Base URL")
|
||||
viperx.MustBindFlag(v, "equinixmetal.emgql.baseurl", flags.Lookup("emgql-base-url"))
|
||||
}
|
||||
|
||||
// Populated checks if any field has been populated.
|
||||
func (c Config) Populated() bool {
|
||||
return c.BaseURL != ""
|
||||
|
||||
Reference in New Issue
Block a user