-
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathconf.go
146 lines (122 loc) · 3.89 KB
/
conf.go
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
// SPDX-FileCopyrightText: Andrei Gherzan <[email protected]>
//
// SPDX-License-Identifier: MIT
package mirror
import (
"encoding/json"
"errors"
)
var (
ErrNoSrc = errors.New("no source repository provided")
ErrNoDst = errors.New("no destination repository provided")
ErrNoHostKey = errors.New("SSH authentication requires host public keys")
ErrHostKey = errors.New("host public keys provided via both file path " +
"and content")
)
// SSHConf structure defines SSH configuration used for git authentication over
// SSH.
type SSHConf struct {
PrivateKey string
KnownHosts string
KnownHostsPath string
}
// Config structure provides all the configuration need for the tool to perform
// its operations. It can be populated via a CLI component.
type Config struct {
SrcRepo string
DstRepo string
SSH SSHConf
Debug bool
}
// GetSSHKey is the getter function for the private SSH key from a
// configuration struct.
func (conf Config) GetSSHKey() string {
return conf.SSH.PrivateKey
}
// SetSSHKey is the setter function for the private SSH key from a
// configuration struct.
func (conf *Config) SetSSHKey(key string) {
conf.SSH.PrivateKey = key
}
// GetKnownHosts is the getter function for the public host key from a
// configuration struct.
func (conf Config) GetKnownHosts() string {
return conf.SSH.KnownHosts
}
// GetKnownHosts is the setter function for the public host key from a
// configuration struct.
func (conf *Config) SetKnownHosts(key string) {
conf.SSH.KnownHosts = key
}
// GetKnownHostsPath is the getter function for the public host key by file
// path from a configuration struct.
func (conf Config) GetKnownHostsPath() string {
return conf.SSH.KnownHostsPath
}
// GetKnownHostsPath is the setter function for the public host key by file
// path from a configuration struct.
func (conf *Config) SetKnownHostsPath(file string) {
conf.SSH.KnownHostsPath = file
}
// Pretty provides a string representation of the configuration structure. It
// does that by making sure sensitive information is masked using a hash
// function - e.g. the SSH private key.
func (conf Config) Pretty() string {
// It's important to have a passed by value conf struct to not have the
// masking affect the struct's actual values.
conf.SetSSHKey(mask(conf.SSH.PrivateKey))
conf.SetKnownHosts(mask(conf.SSH.KnownHosts))
out, err := json.MarshalIndent(conf, "", "\t")
if err != nil {
return ""
}
return string(out)
}
// ProcessEnv deals with environment configuration. It populates or overrides
// configuration based on a map that models environment variables.
func (conf *Config) ProcessEnv(logger *Logger, env map[string]string) {
// Fallback to environment variables for the source repository value.
if len(conf.SrcRepo) == 0 {
if src, srcSet := env["GMM_SRC_REPO"]; srcSet {
conf.SrcRepo = src
} else {
url := env["GITHUB_SERVER_URL"]
repo := env["GITHUB_REPOSITORY"]
conf.SrcRepo = url + "/" + repo
}
}
// Fallback to environment variables for the destination repository value.
if len(conf.DstRepo) == 0 {
conf.DstRepo = env["GMM_DST_REPO"]
}
conf.SSH.PrivateKey = env["GMM_SSH_PRIVATE_KEY"]
conf.SSH.KnownHosts = env["GMM_SSH_KNOWN_HOSTS"]
if !conf.Debug {
if env["GMM_DEBUG"] == "1" {
conf.Debug = true
}
}
}
// Validate provides the logic of validating a configuration.
func (conf Config) Validate(logger *Logger) error {
if len(conf.SrcRepo) == 0 {
return ErrNoSrc
}
logger.Info("Source repository:", conf.SrcRepo, ".")
if len(conf.DstRepo) == 0 {
return ErrNoDst
}
logger.Info("Destination repository:", conf.DstRepo, ".")
if len(conf.GetSSHKey()) == 0 {
logger.Warn("Tool configured with no authentication.")
} else {
if len(conf.GetKnownHosts()) != 0 &&
len(conf.GetKnownHostsPath()) != 0 {
return ErrHostKey
} else if len(conf.GetKnownHosts()) == 0 &&
len(conf.GetKnownHostsPath()) == 0 {
return ErrNoHostKey
}
}
return nil
}