From 709b789742b7569f14e82576fedc3e85f308f03c Mon Sep 17 00:00:00 2001 From: Jamie Magee Date: Fri, 1 Dec 2023 08:59:18 -0800 Subject: [PATCH] Fix image pulling authentication issue --- internal/infra/run.go | 21 +++++++-------------- 1 file changed, 7 insertions(+), 14 deletions(-) diff --git a/internal/infra/run.go b/internal/infra/run.go index 1f6b0c8..cd0df3d 100644 --- a/internal/infra/run.go +++ b/internal/infra/run.go @@ -451,15 +451,15 @@ func pullImage(ctx context.Context, cli *client.Client, image string) error { // pull image if necessary if err != nil { - var privilegeFunc types.RequestPrivilegeFunc + var imagePullOptions types.ImagePullOptions if strings.HasPrefix(image, "ghcr.io/") { token := os.Getenv("LOCAL_GITHUB_ACCESS_TOKEN") if token != "" { auth := base64.StdEncoding.EncodeToString([]byte("x:" + token)) - privilegeFunc = func() (string, error) { - return "Basic " + auth, nil + imagePullOptions = types.ImagePullOptions{ + RegistryAuth: fmt.Sprintf("Basic %s", auth), } } else { log.Println("Failed to find credentials for GitHub container registry.") @@ -479,8 +479,9 @@ func pullImage(ctx context.Context, cli *client.Client, image string) error { encodedJSON, _ := json.Marshal(authConfig) authStr := base64.URLEncoding.EncodeToString(encodedJSON) - privilegeFunc = func() (string, error) { - return authStr, nil + + imagePullOptions = types.ImagePullOptions{ + RegistryAuth: authStr, } } else { log.Println("Failed to find credentials for Azure container registry.") @@ -489,16 +490,8 @@ func pullImage(ctx context.Context, cli *client.Client, image string) error { log.Printf("Failed to find credentials for pulling image: %s\n.", image) } - if privilegeFunc == nil { - return fmt.Errorf("failed to get credentials to pull image: %s", image) - } - - encodedAuth, _ := privilegeFunc() - log.Printf("pulling image: %s\n", image) - out, err := cli.ImagePull(ctx, image, types.ImagePullOptions{ - RegistryAuth: encodedAuth, - }) + out, err := cli.ImagePull(ctx, image, imagePullOptions) if err != nil { return fmt.Errorf("failed to pull %v: %w", image, err) }