From 8e8ccd47558eccd155c134bcfad501355f5b0f0b Mon Sep 17 00:00:00 2001 From: Louis Blin <45168934+lbpdt@users.noreply.github.com> Date: Thu, 11 Mar 2021 12:31:13 +0000 Subject: [PATCH] makisu pull: add support for --registry-config This is useful to authenticate with the registry when pulling images. --- bin/makisu/cmd/pull.go | 28 ++++++++++++++++++++++------ 1 file changed, 22 insertions(+), 6 deletions(-) diff --git a/bin/makisu/cmd/pull.go b/bin/makisu/cmd/pull.go index 44b32a2e..60846f51 100644 --- a/bin/makisu/cmd/pull.go +++ b/bin/makisu/cmd/pull.go @@ -11,6 +11,7 @@ import ( "github.com/andres-erbsen/clock" "github.com/spf13/cobra" "github.com/uber/makisu/lib/docker/image" + "github.com/uber/makisu/lib/log" "github.com/uber/makisu/lib/registry" "github.com/uber/makisu/lib/snapshot" "github.com/uber/makisu/lib/storage" @@ -20,18 +21,19 @@ import ( type pullCmd struct { *cobra.Command - registry string - tag string - cacerts string - extract string + registryConfig string + registry string + tag string + cacerts string + extract string } func getPullCmd() *pullCmd { pullCmd := &pullCmd{ Command: &cobra.Command{ - Use: "pull --dest ", + Use: "pull --dest ", DisableFlagsInUseLine: true, - Short: "Pull docker image from registry into the storage directory of makisu.", + Short: "Pull docker image from registry into the storage directory of makisu.", }, } pullCmd.Args = func(cmd *cobra.Command, args []string) error { @@ -41,9 +43,15 @@ func getPullCmd() *pullCmd { return nil } pullCmd.Run = func(cmd *cobra.Command, args []string) { + if err := pullCmd.processFlags(); err != nil { + log.Errorf("failed to process flags: %s", err) + os.Exit(1) + } + pullCmd.Pull(args[0]) } + pullCmd.PersistentFlags().StringVar(&pullCmd.registryConfig, "registry-config", "", "Set build-time variables") pullCmd.PersistentFlags().StringVar(&pullCmd.registry, "registry", "index.docker.io", "The registry to pull the image from.") pullCmd.PersistentFlags().StringVar(&pullCmd.tag, "tag", "latest", "The tag of the image to pull.") pullCmd.PersistentFlags().StringVar(&pullCmd.cacerts, "cacerts", "/etc/ssl/certs", "The location of the CA certs to use for TLS authentication with the registry.") @@ -52,6 +60,14 @@ func getPullCmd() *pullCmd { return pullCmd } +func (cmd *pullCmd) processFlags() error { + if err := initRegistryConfig(cmd.registryConfig); err != nil { + return fmt.Errorf("failed to initialize registry configuration: %s", err) + } + + return nil +} + func (cmd *pullCmd) Pull(repository string) { store, err := storage.NewImageStore("/tmp/makisu-storage") if err != nil {