Skip to content
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

Add setting webhook data via env and cli flags: #5992

Closed
wants to merge 3 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
24 changes: 15 additions & 9 deletions cmd/eksctl-anywhere/cmd/createcluster.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ import (
"github.com/aws/eks-anywhere/pkg/executables"
"github.com/aws/eks-anywhere/pkg/features"
"github.com/aws/eks-anywhere/pkg/kubeconfig"
"github.com/aws/eks-anywhere/pkg/providers/tinkerbell"
"github.com/aws/eks-anywhere/pkg/types"
"github.com/aws/eks-anywhere/pkg/validations"
"github.com/aws/eks-anywhere/pkg/validations/createvalidations"
Expand All @@ -23,11 +24,10 @@ import (
type createClusterOptions struct {
clusterOptions
timeoutOptions
forceClean bool
skipIpCheck bool
hardwareCSVPath string
tinkerbellBootstrapIP string
installPackages string
forceClean bool
skipIpCheck bool
installPackages string
tinkerbellConfig tinkerbell.Config
}

var cc = &createClusterOptions{}
Expand All @@ -45,15 +45,20 @@ func init() {
createCmd.AddCommand(createClusterCmd)
applyClusterOptionFlags(createClusterCmd.Flags(), &cc.clusterOptions)
applyTimeoutFlags(createClusterCmd.Flags(), &cc.timeoutOptions)
applyTinkerbellHardwareFlag(createClusterCmd.Flags(), &cc.hardwareCSVPath)
createClusterCmd.Flags().StringVar(&cc.tinkerbellBootstrapIP, "tinkerbell-bootstrap-ip", "", "Override the local tinkerbell IP in the bootstrap cluster")
applyTinkerbellHardwareFlag(createClusterCmd.Flags(), &cc.tinkerbellConfig.HardwareFile)
createClusterCmd.Flags().StringVar(&cc.tinkerbellConfig.IP, "tinkerbell-bootstrap-ip", "", "Override the local tinkerbell IP in the bootstrap cluster")
createClusterCmd.Flags().BoolVar(&cc.forceClean, "force-cleanup", false, "Force deletion of previously created bootstrap cluster")
createClusterCmd.Flags().BoolVar(&cc.skipIpCheck, "skip-ip-check", false, "Skip check for whether cluster control plane ip is in use")
createClusterCmd.Flags().StringVar(&cc.installPackages, "install-packages", "", "Location of curated packages configuration files to install to the cluster")

if err := createClusterCmd.MarkFlagRequired("filename"); err != nil {
log.Fatalf("Error marking flag as required: %v", err)
}

createClusterCmd.Flags().StringVar(&cc.tinkerbellConfig.Rufio.WebhookSecret, "webhook-secrets", "", "Comma separated list of secrets for use with the bare metal webhook provider")
markFlagHidden(createClusterCmd.Flags(), "webhook-secrets")
createClusterCmd.Flags().StringVar(&cc.tinkerbellConfig.Rufio.WebhookURL, "webhook-url", "", "URL for the bare metal webhook consumer")
markFlagHidden(createClusterCmd.Flags(), "webhook-url")
}

func (cc *createClusterOptions) createCluster(cmd *cobra.Command, _ []string) error {
Expand All @@ -70,7 +75,7 @@ func (cc *createClusterOptions) createCluster(cmd *cobra.Command, _ []string) er
}

if clusterConfig.Spec.DatacenterRef.Kind == v1alpha1.TinkerbellDatacenterKind {
if err := checkTinkerbellFlags(cmd.Flags(), cc.hardwareCSVPath, Create); err != nil {
if err := checkTinkerbellFlags(cmd.Flags(), cc.tinkerbellConfig.HardwareFile, Create); err != nil {
return err
}
}
Expand Down Expand Up @@ -115,7 +120,8 @@ func (cc *createClusterOptions) createCluster(cmd *cobra.Command, _ []string) er
WithBootstrapper().
WithCliConfig(cliConfig).
WithClusterManager(clusterSpec.Cluster, clusterManagerTimeoutOpts).
WithProvider(cc.fileName, clusterSpec.Cluster, cc.skipIpCheck, cc.hardwareCSVPath, cc.forceClean, cc.tinkerbellBootstrapIP).
WithTinkerbellConfig(cc.tinkerbellConfig).
WithProvider(cc.fileName, clusterSpec.Cluster, cc.skipIpCheck, cc.forceClean).
WithGitOpsFlux(clusterSpec.Cluster, clusterSpec.FluxConfig, cliConfig).
WithWriter().
WithEksdInstaller().
Expand Down
4 changes: 3 additions & 1 deletion cmd/eksctl-anywhere/cmd/deletecluster.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import (

"github.com/aws/eks-anywhere/pkg/dependencies"
"github.com/aws/eks-anywhere/pkg/kubeconfig"
"github.com/aws/eks-anywhere/pkg/providers/tinkerbell"
"github.com/aws/eks-anywhere/pkg/types"
"github.com/aws/eks-anywhere/pkg/validations"
"github.com/aws/eks-anywhere/pkg/workflows"
Expand Down Expand Up @@ -94,7 +95,8 @@ func (dc *deleteClusterOptions) deleteCluster(ctx context.Context) error {
WithBootstrapper().
WithCliConfig(cliConfig).
WithClusterManager(clusterSpec.Cluster, nil).
WithProvider(dc.fileName, clusterSpec.Cluster, cc.skipIpCheck, dc.hardwareFileName, false, dc.tinkerbellBootstrapIP).
WithTinkerbellConfig(tinkerbell.Config{HardwareFile: dc.hardwareFileName, IP: dc.tinkerbellBootstrapIP}).
WithProvider(dc.fileName, clusterSpec.Cluster, cc.skipIpCheck, false).
WithGitOpsFlux(clusterSpec.Cluster, clusterSpec.FluxConfig, cliConfig).
WithWriter().
Build(ctx)
Expand Down
19 changes: 15 additions & 4 deletions cmd/eksctl-anywhere/cmd/flags.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package cmd

import (
"fmt"
"strings"

"github.com/spf13/cobra"
"github.com/spf13/pflag"
Expand All @@ -18,14 +19,24 @@ const (
)

func bindFlagsToViper(cmd *cobra.Command, args []string) error {
var err error
cmd.Flags().VisitAll(func(flag *pflag.Flag) {
if err != nil {
if err := viper.BindPFlag(flag.Name, flag); err != nil {
return
}
err = viper.BindPFlag(flag.Name, flag)
viper.AutomaticEnv()
// Environment variables can't have dashes in them, so bind them to their equivalent
// keys with underscores, e.g. --hardware-csv to HARDWARE_CSV
viper.SetEnvKeyReplacer(strings.NewReplacer("-", "_"))
// viper.AutomaticEnv() needs help with dashes in flag names.
if !flag.Changed && viper.IsSet(flag.Name) {
val := viper.Get(flag.Name)
if err := cmd.Flags().Set(flag.Name, fmt.Sprintf("%v", val)); err != nil {
return
}
}
})
return err

return nil
}

func applyClusterOptionFlags(flagSet *pflag.FlagSet, clusterOpt *clusterOptions) {
Expand Down
4 changes: 3 additions & 1 deletion cmd/eksctl-anywhere/cmd/generatebundleconfig.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ import (
"github.com/aws/eks-anywhere/pkg/dependencies"
"github.com/aws/eks-anywhere/pkg/diagnostics"
"github.com/aws/eks-anywhere/pkg/kubeconfig"
"github.com/aws/eks-anywhere/pkg/providers/tinkerbell"
"github.com/aws/eks-anywhere/pkg/validations"
"github.com/aws/eks-anywhere/pkg/version"
)
Expand Down Expand Up @@ -89,7 +90,8 @@ func (gsbo *generateSupportBundleOptions) generateBundleConfig(ctx context.Conte
}

deps, err := dependencies.ForSpec(ctx, clusterSpec).
WithProvider(clusterConfigPath, clusterSpec.Cluster, cc.skipIpCheck, gsbo.hardwareFileName, false, gsbo.tinkerbellBootstrapIP).
WithTinkerbellConfig(tinkerbell.Config{HardwareFile: gsbo.hardwareFileName, IP: gsbo.tinkerbellBootstrapIP}).
WithProvider(clusterConfigPath, clusterSpec.Cluster, cc.skipIpCheck, false).
WithDiagnosticBundleFactory().
Build(ctx)
if err != nil {
Expand Down
14 changes: 11 additions & 3 deletions cmd/eksctl-anywhere/cmd/generatehardware.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,19 +6,22 @@ import (

"github.com/spf13/cobra"

"github.com/aws/eks-anywhere/pkg/providers/tinkerbell"
"github.com/aws/eks-anywhere/pkg/providers/tinkerbell/hardware"
)

type hardwareOptions struct {
csvPath string
outputPath string
config tinkerbell.Config
}

var hOpts = &hardwareOptions{}

var generateHardwareCmd = &cobra.Command{
Use: "hardware",
Short: "Generate hardware files",
Use: "hardware",
Short: "Generate hardware files",
PreRunE: bindFlagsToViper,
Long: `
Generate Kubernetes hardware YAML manifests for each Hardware entry in the source.
`,
Expand All @@ -41,10 +44,15 @@ func init() {
if err := generateHardwareCmd.MarkFlagRequired(TinkerbellHardwareCSVFlagName); err != nil {
panic(err)
}

generateHardwareCmd.Flags().StringVar(&hOpts.config.Rufio.WebhookSecret, "webhook-secrets", "", "Comma separated list of secrets for use with the bare metal webhook provider")
markFlagHidden(generateHardwareCmd.Flags(), "webhook-secrets")
generateHardwareCmd.Flags().StringVar(&hOpts.config.Rufio.WebhookURL, "webhook-url", "", "URL for the bare metal webhook consumer")
markFlagHidden(generateHardwareCmd.Flags(), "webhook-url")
}

func (hOpts *hardwareOptions) generateHardware(cmd *cobra.Command, args []string) error {
hardwareYaml, err := hardware.BuildHardwareYAML(hOpts.csvPath)
hardwareYaml, err := hardware.BuildHardwareYAML(hOpts.csvPath, hOpts.config.Rufio.WebhookSecret)
if err != nil {
return fmt.Errorf("building hardware yaml from csv: %v", err)
}
Expand Down
4 changes: 3 additions & 1 deletion cmd/eksctl-anywhere/cmd/supportbundle.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ import (
"github.com/aws/eks-anywhere/pkg/dependencies"
"github.com/aws/eks-anywhere/pkg/diagnostics"
"github.com/aws/eks-anywhere/pkg/kubeconfig"
"github.com/aws/eks-anywhere/pkg/providers/tinkerbell"
"github.com/aws/eks-anywhere/pkg/version"
)

Expand Down Expand Up @@ -89,7 +90,8 @@ func (csbo *createSupportBundleOptions) createBundle(ctx context.Context, since,
}

deps, err := dependencies.ForSpec(ctx, clusterSpec).
WithProvider(csbo.fileName, clusterSpec.Cluster, cc.skipIpCheck, csbo.hardwareFileName, false, csbo.tinkerbellBootstrapIP).
WithTinkerbellConfig(tinkerbell.Config{HardwareFile: csbo.hardwareFileName, IP: csbo.tinkerbellBootstrapIP}).
WithProvider(csbo.fileName, clusterSpec.Cluster, cc.skipIpCheck, false).
WithDiagnosticBundleFactory().
Build(ctx)
if err != nil {
Expand Down
4 changes: 3 additions & 1 deletion cmd/eksctl-anywhere/cmd/upgradecluster.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import (
"github.com/aws/eks-anywhere/pkg/api/v1alpha1"
"github.com/aws/eks-anywhere/pkg/dependencies"
"github.com/aws/eks-anywhere/pkg/kubeconfig"
"github.com/aws/eks-anywhere/pkg/providers/tinkerbell"
"github.com/aws/eks-anywhere/pkg/types"
"github.com/aws/eks-anywhere/pkg/validations"
"github.com/aws/eks-anywhere/pkg/validations/upgradevalidations"
Expand Down Expand Up @@ -103,7 +104,8 @@ func (uc *upgradeClusterOptions) upgradeCluster(cmd *cobra.Command) error {
WithCliConfig(cliConfig).
WithClusterManager(clusterSpec.Cluster, clusterManagerTimeoutOpts).
WithKubeProxyCLIUpgrader().
WithProvider(uc.fileName, clusterSpec.Cluster, cc.skipIpCheck, uc.hardwareCSVPath, uc.forceClean, uc.tinkerbellBootstrapIP).
WithTinkerbellConfig(tinkerbell.Config{HardwareFile: uc.hardwareCSVPath, IP: uc.tinkerbellBootstrapIP}).
WithProvider(uc.fileName, clusterSpec.Cluster, cc.skipIpCheck, uc.forceClean).
WithGitOpsFlux(clusterSpec.Cluster, clusterSpec.FluxConfig, cliConfig).
WithWriter().
WithCAPIManager().
Expand Down
4 changes: 3 additions & 1 deletion cmd/eksctl-anywhere/cmd/upgradeplancluster.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ import (
fluxupgrader "github.com/aws/eks-anywhere/pkg/gitops/flux"
"github.com/aws/eks-anywhere/pkg/logger"
"github.com/aws/eks-anywhere/pkg/networking/cilium"
"github.com/aws/eks-anywhere/pkg/providers/tinkerbell"
"github.com/aws/eks-anywhere/pkg/types"
)

Expand Down Expand Up @@ -78,7 +79,8 @@ func (uc *upgradeClusterOptions) upgradePlanCluster(ctx context.Context) error {

deps, err := dependencies.ForSpec(ctx, newClusterSpec).
WithClusterManager(newClusterSpec.Cluster, nil).
WithProvider(uc.fileName, newClusterSpec.Cluster, false, uc.hardwareCSVPath, uc.forceClean, uc.tinkerbellBootstrapIP).
WithTinkerbellConfig(tinkerbell.Config{HardwareFile: uc.hardwareCSVPath, IP: uc.tinkerbellBootstrapIP}).
WithProvider(uc.fileName, newClusterSpec.Cluster, false, uc.forceClean).
WithGitOpsFlux(newClusterSpec.Cluster, newClusterSpec.FluxConfig, nil).
WithCAPIManager().
Build(ctx)
Expand Down
18 changes: 12 additions & 6 deletions cmd/eksctl-anywhere/cmd/validatecreatecluster.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import (
"github.com/aws/eks-anywhere/pkg/api/v1alpha1"
"github.com/aws/eks-anywhere/pkg/dependencies"
"github.com/aws/eks-anywhere/pkg/kubeconfig"
"github.com/aws/eks-anywhere/pkg/providers/tinkerbell"
"github.com/aws/eks-anywhere/pkg/types"
"github.com/aws/eks-anywhere/pkg/validations"
"github.com/aws/eks-anywhere/pkg/validations/createcluster"
Expand All @@ -18,8 +19,7 @@ import (

type validateOptions struct {
clusterOptions
hardwareCSVPath string
tinkerbellBootstrapIP string
tinkerbell tinkerbell.Config
}

var valOpt = &validateOptions{}
Expand All @@ -35,13 +35,17 @@ var validateCreateClusterCmd = &cobra.Command{

func init() {
validateCreateCmd.AddCommand(validateCreateClusterCmd)
applyTinkerbellHardwareFlag(validateCreateClusterCmd.Flags(), &valOpt.hardwareCSVPath)
applyTinkerbellHardwareFlag(validateCreateClusterCmd.Flags(), &valOpt.tinkerbell.HardwareFile)
validateCreateClusterCmd.Flags().StringVarP(&valOpt.fileName, "filename", "f", "", "Filename that contains EKS-A cluster configuration")
validateCreateClusterCmd.Flags().StringVar(&valOpt.tinkerbellBootstrapIP, "tinkerbell-bootstrap-ip", "", "Override the local tinkerbell IP in the bootstrap cluster")
validateCreateClusterCmd.Flags().StringVar(&valOpt.tinkerbell.IP, "tinkerbell-bootstrap-ip", "", "Override the local tinkerbell IP in the bootstrap cluster")

if err := validateCreateClusterCmd.MarkFlagRequired("filename"); err != nil {
log.Fatalf("Error marking flag as required: %v", err)
}
validateCreateClusterCmd.Flags().StringVar(&valOpt.tinkerbell.Rufio.WebhookSecret, "webhook-secrets", "", "Comma separated list of secrets for use with the bare metal webhook provider")
markFlagHidden(validateCreateClusterCmd.Flags(), "webhook-secrets")
validateCreateClusterCmd.Flags().StringVar(&valOpt.tinkerbell.Rufio.WebhookURL, "webhook-url", "", "URL for the bare metal webhook consumer")
markFlagHidden(validateCreateClusterCmd.Flags(), "webhook-url")
}

func (valOpt *validateOptions) validateCreateCluster(cmd *cobra.Command, _ []string) error {
Expand All @@ -53,7 +57,7 @@ func (valOpt *validateOptions) validateCreateCluster(cmd *cobra.Command, _ []str
}

if clusterSpec.Config.Cluster.Spec.DatacenterRef.Kind == v1alpha1.TinkerbellDatacenterKind {
if err := checkTinkerbellFlags(cmd.Flags(), valOpt.hardwareCSVPath, 0); err != nil {
if err := checkTinkerbellFlags(cmd.Flags(), valOpt.tinkerbell.HardwareFile, 0); err != nil {
return err
}
}
Expand All @@ -68,12 +72,14 @@ func (valOpt *validateOptions) validateCreateCluster(cmd *cobra.Command, _ []str
if err != nil {
return err
}

deps, err := dependencies.ForSpec(ctx, clusterSpec).
WithExecutableMountDirs(dirs...).
WithWriterFolder(tmpPath).
WithDocker().
WithKubectl().
WithProvider(valOpt.fileName, clusterSpec.Cluster, false, valOpt.hardwareCSVPath, true, valOpt.tinkerbellBootstrapIP).
WithTinkerbellConfig(valOpt.tinkerbell).
WithProvider(valOpt.fileName, clusterSpec.Cluster, false, true).
WithGitOpsFlux(clusterSpec.Cluster, clusterSpec.FluxConfig, cliConfig).
WithUnAuthKubeClient().
WithValidatorClients().
Expand Down
31 changes: 23 additions & 8 deletions pkg/dependencies/factory.go
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@ import (
"github.com/aws/eks-anywhere/pkg/providers/nutanix"
"github.com/aws/eks-anywhere/pkg/providers/snow"
"github.com/aws/eks-anywhere/pkg/providers/tinkerbell"
"github.com/aws/eks-anywhere/pkg/providers/tinkerbell/rufio"
"github.com/aws/eks-anywhere/pkg/providers/validator"
"github.com/aws/eks-anywhere/pkg/providers/vsphere"
"github.com/aws/eks-anywhere/pkg/registrymirror"
Expand Down Expand Up @@ -143,6 +144,7 @@ type Factory struct {
diagnosticCollectorImage string
buildSteps []buildStep
dependencies Dependencies
tinkerbellConfig tinkerbell.Config
}

type executablesConfig struct {
Expand Down Expand Up @@ -376,7 +378,13 @@ func (f *Factory) WithExecutableBuilder() *Factory {
return f
}

func (f *Factory) WithProvider(clusterConfigFile string, clusterConfig *v1alpha1.Cluster, skipIpCheck bool, hardwareCSVPath string, force bool, tinkerbellBootstrapIp string) *Factory {
// WithTinkerbellConfig allows for setting all Tinkerbell specific values.
func (f *Factory) WithTinkerbellConfig(t tinkerbell.Config) *Factory {
f.tinkerbellConfig = t
return f
}

func (f *Factory) WithProvider(clusterConfigFile string, clusterConfig *v1alpha1.Cluster, skipIpCheck bool, force bool) *Factory {
switch clusterConfig.Spec.DatacenterRef.Kind {
case v1alpha1.VSphereDatacenterKind:
f.WithKubectl().WithGovc().WithWriter().WithIPValidator()
Expand Down Expand Up @@ -453,30 +461,37 @@ func (f *Factory) WithProvider(clusterConfigFile string, clusterConfig *v1alpha1
return fmt.Errorf("unable to get machine config from file %s: %v", clusterConfigFile, err)
}

tinkerbellIp := tinkerbellBootstrapIp
if tinkerbellIp == "" {
tinkerbellIP := f.tinkerbellConfig.IP
if tinkerbellIP == "" {
logger.V(4).Info("Inferring local Tinkerbell Bootstrap IP from environment")
localIp, err := networkutils.GetLocalIP()
if err != nil {
return err
}
tinkerbellIp = localIp.String()
tinkerbellIP = localIp.String()
}
logger.V(4).Info("Tinkerbell IP", "tinkerbell-ip", tinkerbellIP)

cfg := tinkerbell.Config{
HardwareFile: f.tinkerbellConfig.HardwareFile,
IP: tinkerbellIP,
Rufio: rufio.Config{
WebhookSecret: f.tinkerbellConfig.Rufio.WebhookSecret,
WebhookURL: f.tinkerbellConfig.Rufio.WebhookURL,
},
}
logger.V(4).Info("Tinkerbell IP", "tinkerbell-ip", tinkerbellIp)

provider, err := tinkerbell.NewProvider(
datacenterConfig,
machineConfigs,
clusterConfig,
hardwareCSVPath,
f.dependencies.Writer,
f.dependencies.DockerClient,
f.dependencies.Helm,
f.dependencies.Kubectl,
tinkerbellIp,
time.Now,
force,
skipIpCheck,
cfg,
)
if err != nil {
return err
Expand Down
Loading