forked from evergreen-ci/evergreen
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconfig_auth.go
115 lines (98 loc) · 3.81 KB
/
config_auth.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
package evergreen
import (
"fmt"
"github.com/mongodb/grip"
"github.com/pkg/errors"
"go.mongodb.org/mongo-driver/bson"
"go.mongodb.org/mongo-driver/mongo"
"go.mongodb.org/mongo-driver/mongo/options"
)
// AuthUser configures a user for our Naive authentication setup.
type AuthUser struct {
Username string `bson:"username" json:"username" yaml:"username"`
DisplayName string `bson:"display_name" json:"display_name" yaml:"display_name"`
Password string `bson:"password" json:"password" yaml:"password"`
Email string `bson:"email" json:"email" yaml:"email"`
}
// NaiveAuthConfig contains a list of AuthUsers from the settings file.
type NaiveAuthConfig struct {
Users []*AuthUser `bson:"users" json:"users" yaml:"users"`
}
// LDAPConfig contains settings for interacting with an LDAP server.
type LDAPConfig struct {
URL string `bson:"url" json:"url" yaml:"url"`
Port string `bson:"port" json:"port" yaml:"port"`
UserPath string `bson:"path" json:"path" yaml:"path"`
ServicePath string `bson:"service_path" json:"service_path" yaml:"service_path"`
Group string `bson:"group" json:"group" yaml:"group"`
ServiceGroup string `bson:"service_group" json:"service_group" yaml:"service_group"`
ExpireAfterMinutes string `bson:"expire_after_minutes" json:"expire_after_minutes" yaml:"expire_after_minutes"`
}
// GithubAuthConfig holds settings for interacting with Github Authentication including the
// ClientID, ClientSecret and CallbackUri which are given when registering the application
// Furthermore,
type GithubAuthConfig struct {
ClientId string `bson:"client_id" json:"client_id" yaml:"client_id"`
ClientSecret string `bson:"client_secret" json:"client_secret" yaml:"client_secret"`
Users []string `bson:"users" json:"users" yaml:"users"`
Organization string `bson:"organization" json:"organization" yaml:"organization"`
}
// AuthConfig has a pointer to either a CrowConfig or a NaiveAuthConfig.
type AuthConfig struct {
LDAP *LDAPConfig `bson:"ldap,omitempty" json:"ldap" yaml:"ldap"`
Naive *NaiveAuthConfig `bson:"naive,omitempty" json:"naive" yaml:"naive"`
Github *GithubAuthConfig `bson:"github,omitempty" json:"github" yaml:"github"`
}
func (c *AuthConfig) SectionId() string { return "auth" }
func (c *AuthConfig) Get(env Environment) error {
ctx, cancel := env.Context()
defer cancel()
coll := env.DB().Collection(ConfigCollection)
res := coll.FindOne(ctx, byId(c.SectionId()))
if err := res.Err(); err != nil {
return errors.Wrapf(err, "error retrieving section %s", c.SectionId())
}
if err := res.Decode(c); err != nil {
if err == mongo.ErrNoDocuments {
*c = AuthConfig{}
return nil
}
return errors.Wrap(err, "problem decoding result")
}
return nil
}
func (c *AuthConfig) Set() error {
env := GetEnvironment()
ctx, cancel := env.Context()
defer cancel()
coll := env.DB().Collection(ConfigCollection)
_, err := coll.UpdateOne(ctx, byId(c.SectionId()), bson.M{
"$set": bson.M{
"ldap": c.LDAP,
"naive": c.Naive,
"github": c.Github,
},
}, options.Update().SetUpsert(true))
return errors.Wrapf(err, "error updating section %s", c.SectionId())
}
func (c *AuthConfig) ValidateAndDefault() error {
catcher := grip.NewSimpleCatcher()
if c.LDAP == nil && c.Naive == nil && c.Github == nil {
catcher.Add(errors.New("You must specify one form of authentication"))
}
if c.Naive != nil {
used := map[string]bool{}
for _, x := range c.Naive.Users {
if used[x.Username] {
catcher.Add(fmt.Errorf("Duplicate user %s in list", x.Username))
}
used[x.Username] = true
}
}
if c.Github != nil {
if c.Github.Users == nil && c.Github.Organization == "" {
catcher.Add(errors.New("Must specify either a set of users or an organization for Github Authentication"))
}
}
return catcher.Resolve()
}