mirror of
				https://github.com/containers/skopeo.git
				synced 2025-10-25 05:39:01 +00:00 
			
		
		
		
	cmd: per command tls flags
Signed-off-by: Antonio Murdaca <runcom@redhat.com>
This commit is contained in:
		
							
								
								
									
										67
									
								
								vendor/github.com/containers/image/docker/docker_client.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										67
									
								
								vendor/github.com/containers/image/docker/docker_client.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -87,6 +87,64 @@ func newTransport() *http.Transport { | ||||
| 	return tr | ||||
| } | ||||
|  | ||||
| func setupCertificates(dir string, tlsc *tls.Config) error { | ||||
| 	if dir == "" { | ||||
| 		return nil | ||||
| 	} | ||||
| 	fs, err := ioutil.ReadDir(dir) | ||||
| 	if err != nil && !os.IsNotExist(err) { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	for _, f := range fs { | ||||
| 		fullPath := filepath.Join(dir, f.Name()) | ||||
| 		if strings.HasSuffix(f.Name(), ".crt") { | ||||
| 			systemPool, err := tlsconfig.SystemCertPool() | ||||
| 			if err != nil { | ||||
| 				return fmt.Errorf("unable to get system cert pool: %v", err) | ||||
| 			} | ||||
| 			tlsc.RootCAs = systemPool | ||||
| 			logrus.Debugf("crt: %s", fullPath) | ||||
| 			data, err := ioutil.ReadFile(fullPath) | ||||
| 			if err != nil { | ||||
| 				return err | ||||
| 			} | ||||
| 			tlsc.RootCAs.AppendCertsFromPEM(data) | ||||
| 		} | ||||
| 		if strings.HasSuffix(f.Name(), ".cert") { | ||||
| 			certName := f.Name() | ||||
| 			keyName := certName[:len(certName)-5] + ".key" | ||||
| 			logrus.Debugf("cert: %s", fullPath) | ||||
| 			if !hasFile(fs, keyName) { | ||||
| 				return fmt.Errorf("missing key %s for client certificate %s. Note that CA certificates should use the extension .crt", keyName, certName) | ||||
| 			} | ||||
| 			cert, err := tls.LoadX509KeyPair(filepath.Join(dir, certName), filepath.Join(dir, keyName)) | ||||
| 			if err != nil { | ||||
| 				return err | ||||
| 			} | ||||
| 			tlsc.Certificates = append(tlsc.Certificates, cert) | ||||
| 		} | ||||
| 		if strings.HasSuffix(f.Name(), ".key") { | ||||
| 			keyName := f.Name() | ||||
| 			certName := keyName[:len(keyName)-4] + ".cert" | ||||
| 			logrus.Debugf("key: %s", fullPath) | ||||
| 			if !hasFile(fs, certName) { | ||||
| 				return fmt.Errorf("missing client certificate %s for key %s", certName, keyName) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func hasFile(files []os.FileInfo, name string) bool { | ||||
| 	for _, f := range files { | ||||
| 		if f.Name() == name { | ||||
| 			return true | ||||
| 		} | ||||
| 	} | ||||
| 	return false | ||||
| } | ||||
|  | ||||
| // newDockerClient returns a new dockerClient instance for refHostname (a host a specified in the Docker image reference, not canonicalized to dockerRegistry) | ||||
| // “write” specifies whether the client will be used for "write" access (in particular passed to lookaside.go:toplevelFromSection) | ||||
| func newDockerClient(ctx *types.SystemContext, ref dockerReference, write bool) (*dockerClient, error) { | ||||
| @@ -102,13 +160,10 @@ func newDockerClient(ctx *types.SystemContext, ref dockerReference, write bool) | ||||
| 	if ctx != nil && (ctx.DockerCertPath != "" || ctx.DockerInsecureSkipTLSVerify) { | ||||
| 		tlsc := &tls.Config{} | ||||
|  | ||||
| 		if ctx.DockerCertPath != "" { | ||||
| 			cert, err := tls.LoadX509KeyPair(filepath.Join(ctx.DockerCertPath, "cert.pem"), filepath.Join(ctx.DockerCertPath, "key.pem")) | ||||
| 			if err != nil { | ||||
| 				return nil, fmt.Errorf("Error loading x509 key pair: %s", err) | ||||
| 			} | ||||
| 			tlsc.Certificates = append(tlsc.Certificates, cert) | ||||
| 		if err := setupCertificates(ctx.DockerCertPath, tlsc); err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
|  | ||||
| 		tlsc.InsecureSkipVerify = ctx.DockerInsecureSkipTLSVerify | ||||
| 		tr.TLSClientConfig = tlsc | ||||
| 	} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user