mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-16 03:32:54 -06:00
50 lines
1.2 KiB
Go
50 lines
1.2 KiB
Go
package docker
|
|
|
|
import (
|
|
"fmt"
|
|
"path/filepath"
|
|
|
|
dc "github.com/fsouza/go-dockerclient"
|
|
)
|
|
|
|
// Config is the structure that stores the configuration to talk to a
|
|
// Docker API compatible host.
|
|
type Config struct {
|
|
Host string
|
|
Ca string
|
|
Cert string
|
|
Key string
|
|
CertPath string
|
|
}
|
|
|
|
// NewClient() returns a new Docker client.
|
|
func (c *Config) NewClient() (*dc.Client, error) {
|
|
if c.Ca != "" || c.Cert != "" || c.Key != "" {
|
|
if c.Ca == "" || c.Cert == "" || c.Key == "" {
|
|
return nil, fmt.Errorf("ca_material, cert_material, and key_material must be specified")
|
|
}
|
|
|
|
if c.CertPath != "" {
|
|
return nil, fmt.Errorf("cert_path must not be specified")
|
|
}
|
|
|
|
return dc.NewTLSClientFromBytes(c.Host, []byte(c.Cert), []byte(c.Key), []byte(c.Ca))
|
|
}
|
|
|
|
if c.CertPath != "" {
|
|
// If there is cert information, load it and use it.
|
|
ca := filepath.Join(c.CertPath, "ca.pem")
|
|
cert := filepath.Join(c.CertPath, "cert.pem")
|
|
key := filepath.Join(c.CertPath, "key.pem")
|
|
return dc.NewTLSClient(c.Host, cert, key, ca)
|
|
}
|
|
|
|
// If there is no cert information, then just return the direct client
|
|
return dc.NewClient(c.Host)
|
|
}
|
|
|
|
// Data ia structure for holding data that we fetch from Docker.
|
|
type Data struct {
|
|
DockerImages map[string]*dc.APIImages
|
|
}
|