mirror of
				https://github.com/containers/podman.git
				synced 2025-10-26 18:54:17 +08:00 
			
		
		
		
	build: mirror --authfile to filesystem if pointing to FD instead of file
Following commit makes sure that podman mirrors --authfile to a temporary file in filesystem if arg is pointing to an FD instead of actual file as FD can be only consumed once. Reference: * https://github.com/containers/buildah/pull/3498 * https://github.com/containers/buildah/issues/3070 [NO TESTS NEEDED] Signed-off-by: Aditya Rajan <arajan@redhat.com>
This commit is contained in:
		| @ -11,6 +11,7 @@ import ( | |||||||
| 	buildahDefine "github.com/containers/buildah/define" | 	buildahDefine "github.com/containers/buildah/define" | ||||||
| 	buildahCLI "github.com/containers/buildah/pkg/cli" | 	buildahCLI "github.com/containers/buildah/pkg/cli" | ||||||
| 	"github.com/containers/buildah/pkg/parse" | 	"github.com/containers/buildah/pkg/parse" | ||||||
|  | 	buildahUtil "github.com/containers/buildah/pkg/util" | ||||||
| 	"github.com/containers/common/pkg/auth" | 	"github.com/containers/common/pkg/auth" | ||||||
| 	"github.com/containers/common/pkg/completion" | 	"github.com/containers/common/pkg/completion" | ||||||
| 	"github.com/containers/common/pkg/config" | 	"github.com/containers/common/pkg/config" | ||||||
| @ -359,6 +360,12 @@ func buildFlagsWrapperToOptions(c *cobra.Command, contextDir string, flags *buil | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	cleanTmpFile := false | ||||||
|  | 	flags.Authfile, cleanTmpFile = buildahUtil.MirrorToTempFileIfPathIsDescriptor(flags.Authfile) | ||||||
|  | 	if cleanTmpFile { | ||||||
|  | 		defer os.Remove(flags.Authfile) | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	args := make(map[string]string) | 	args := make(map[string]string) | ||||||
| 	if c.Flag("build-arg").Changed { | 	if c.Flag("build-arg").Changed { | ||||||
| 		for _, arg := range flags.BuildArg { | 		for _, arg := range flags.BuildArg { | ||||||
|  | |||||||
							
								
								
									
										81
									
								
								vendor/github.com/containers/buildah/pkg/util/util.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										81
									
								
								vendor/github.com/containers/buildah/pkg/util/util.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,81 @@ | |||||||
|  | package util | ||||||
|  |  | ||||||
|  | import ( | ||||||
|  | 	"io/ioutil" | ||||||
|  | 	"os" | ||||||
|  | 	"path/filepath" | ||||||
|  | 	"strings" | ||||||
|  |  | ||||||
|  | 	"github.com/pkg/errors" | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | // Mirrors path to a tmpfile if path points to a | ||||||
|  | // file descriptor instead of actual file on filesystem | ||||||
|  | // reason: operations with file descriptors are can lead | ||||||
|  | // to edge cases where content on FD is not in a consumable | ||||||
|  | // state after first consumption. | ||||||
|  | // returns path as string and bool to confirm if temp file | ||||||
|  | // was created and needs to be cleaned up. | ||||||
|  | func MirrorToTempFileIfPathIsDescriptor(file string) (string, bool) { | ||||||
|  | 	// one use-case is discussed here | ||||||
|  | 	// https://github.com/containers/buildah/issues/3070 | ||||||
|  | 	if !strings.HasPrefix(file, "/dev/fd") { | ||||||
|  | 		return file, false | ||||||
|  | 	} | ||||||
|  | 	b, err := ioutil.ReadFile(file) | ||||||
|  | 	if err != nil { | ||||||
|  | 		// if anything goes wrong return original path | ||||||
|  | 		return file, false | ||||||
|  | 	} | ||||||
|  | 	tmpfile, err := ioutil.TempFile(os.TempDir(), "buildah-temp-file") | ||||||
|  | 	if err != nil { | ||||||
|  | 		return file, false | ||||||
|  | 	} | ||||||
|  | 	if _, err := tmpfile.Write(b); err != nil { | ||||||
|  | 		// if anything goes wrong return original path | ||||||
|  | 		return file, false | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	return tmpfile.Name(), true | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DiscoverContainerfile tries to find a Containerfile or a Dockerfile within the provided `path`. | ||||||
|  | func DiscoverContainerfile(path string) (foundCtrFile string, err error) { | ||||||
|  | 	// Test for existence of the file | ||||||
|  | 	target, err := os.Stat(path) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return "", errors.Wrap(err, "discovering Containerfile") | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	switch mode := target.Mode(); { | ||||||
|  | 	case mode.IsDir(): | ||||||
|  | 		// If the path is a real directory, we assume a Containerfile or a Dockerfile within it | ||||||
|  | 		ctrfile := filepath.Join(path, "Containerfile") | ||||||
|  |  | ||||||
|  | 		// Test for existence of the Containerfile file | ||||||
|  | 		file, err := os.Stat(ctrfile) | ||||||
|  | 		if err != nil { | ||||||
|  | 			// See if we have a Dockerfile within it | ||||||
|  | 			ctrfile = filepath.Join(path, "Dockerfile") | ||||||
|  |  | ||||||
|  | 			// Test for existence of the Dockerfile file | ||||||
|  | 			file, err = os.Stat(ctrfile) | ||||||
|  | 			if err != nil { | ||||||
|  | 				return "", errors.Wrap(err, "cannot find Containerfile or Dockerfile in context directory") | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		// The file exists, now verify the correct mode | ||||||
|  | 		if mode := file.Mode(); mode.IsRegular() { | ||||||
|  | 			foundCtrFile = ctrfile | ||||||
|  | 		} else { | ||||||
|  | 			return "", errors.Errorf("assumed Containerfile %q is not a file", ctrfile) | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 	case mode.IsRegular(): | ||||||
|  | 		// If the context dir is a file, we assume this as Containerfile | ||||||
|  | 		foundCtrFile = path | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	return foundCtrFile, nil | ||||||
|  | } | ||||||
							
								
								
									
										1
									
								
								vendor/modules.txt
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								vendor/modules.txt
									
									
									
									
										vendored
									
									
								
							| @ -97,6 +97,7 @@ github.com/containers/buildah/pkg/overlay | |||||||
| github.com/containers/buildah/pkg/parse | github.com/containers/buildah/pkg/parse | ||||||
| github.com/containers/buildah/pkg/rusage | github.com/containers/buildah/pkg/rusage | ||||||
| github.com/containers/buildah/pkg/sshagent | github.com/containers/buildah/pkg/sshagent | ||||||
|  | github.com/containers/buildah/pkg/util | ||||||
| github.com/containers/buildah/util | github.com/containers/buildah/util | ||||||
| # github.com/containers/common v0.44.0 | # github.com/containers/common v0.44.0 | ||||||
| github.com/containers/common/libimage | github.com/containers/common/libimage | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 Aditya Rajan
					Aditya Rajan