summaryrefslogtreecommitdiff
path: root/cmd/podman/remoteclientconfig/configfile.go
blob: aa3e82a31789f6368be59463165ce54a72a7cedc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
package remoteclientconfig

import (
	"io"

	"github.com/BurntSushi/toml"
	"github.com/pkg/errors"
)

// ReadRemoteConfig takes an io.Reader representing the remote configuration
// file and returns a remoteconfig
func ReadRemoteConfig(reader io.Reader) (*RemoteConfig, error) {
	var remoteConfig RemoteConfig
	// the configuration file does not exist
	if reader == nil {
		return &remoteConfig, ErrNoConfigationFile
	}
	_, err := toml.DecodeReader(reader, &remoteConfig)
	if err != nil {
		return nil, err
	}
	// We need to validate each remote connection has fields filled out
	for name, conn := range remoteConfig.Connections {
		if len(conn.Destination) < 1 {
			return nil, errors.Errorf("connection %s has no destination defined", name)
		}
	}
	return &remoteConfig, err
}

// GetDefault returns the default RemoteConnection. If there is only one
// connection, we assume it is the default as well
func (r *RemoteConfig) GetDefault() (*RemoteConnection, error) {
	if len(r.Connections) == 0 {
		return nil, ErrNoDefinedConnections
	}
	for _, v := range r.Connections {
		if len(r.Connections) == 1 {
			// if there is only one defined connection, we assume it is
			// the default whether tagged as such or not
			return &v, nil
		}
		if v.IsDefault {
			return &v, nil
		}
	}
	return nil, ErrNoDefaultConnection
}

// GetRemoteConnection "looks up" a remote connection by name and returns it in the
// form of a RemoteConnection
func (r *RemoteConfig) GetRemoteConnection(name string) (*RemoteConnection, error) {
	if len(r.Connections) == 0 {
		return nil, ErrNoDefinedConnections
	}
	for k, v := range r.Connections {
		if k == name {
			return &v, nil
		}
	}
	return nil, errors.Wrap(ErrConnectionNotFound, name)
}