-
Notifications
You must be signed in to change notification settings - Fork 118
/
Copy pathmain.go
177 lines (149 loc) · 5.61 KB
/
main.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
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
/*
Copyright 2017 The Kubernetes Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package main
import (
"flag"
"net/http"
"os"
"strconv"
"time"
"github.com/jenkins-x/lighthouse/pkg/config"
configutil "github.com/jenkins-x/lighthouse/pkg/config/util"
"github.com/jenkins-x/lighthouse/pkg/interrupts"
"github.com/jenkins-x/lighthouse/pkg/jobutil"
"github.com/jenkins-x/lighthouse/pkg/keeper"
"github.com/jenkins-x/lighthouse/pkg/keeper/githubapp"
"github.com/jenkins-x/lighthouse/pkg/logrusutil"
"github.com/jenkins-x/lighthouse/pkg/metrics"
"github.com/jenkins-x/lighthouse/pkg/util"
"github.com/jenkins-x/lighthouse/pkg/watcher"
"github.com/sirupsen/logrus"
)
type options struct {
port int
configPath string
jobConfigPath string
botName string
gitServerURL string
gitKind string
namespace string
runOnce bool
maxRecordsPerPool int
// historyURI where Keeper should store its action history.
// Can be a /local/path or gs://path/to/object.
// GCS writes will use the bucket's default acl for new objects. Ensure both that
// a) the gcs credentials can write to this bucket
// b) the default acls do not expose any private info
historyURI string
// statusURI where Keeper store status update state.
// Can be a /local/path or gs://path/to/object.
// GCS writes will use the bucket's default acl for new objects. Ensure both that
// a) the gcs credentials can write to this bucket
// b) the default acls do not expose any private info
statusURI string
}
func (o *options) Validate() error {
return nil
}
func gatherOptions(fs *flag.FlagSet, args ...string) options {
var o options
fs.IntVar(&o.port, "port", 8888, "Port to listen on.")
fs.StringVar(&o.configPath, "config-path", "", "Path to config.yaml.")
fs.StringVar(&o.jobConfigPath, "job-config-path", "", "Path to prow job configs.")
fs.StringVar(&o.botName, "bot-name", "", "The bot name")
fs.StringVar(&o.gitServerURL, "git-url", "", "The git provider URL")
fs.StringVar(&o.gitKind, "git-kind", "", "The git provider kind (e.g. github, gitlab, bitbucketserver")
fs.BoolVar(&o.runOnce, "run-once", false, "If true, run only once then quit.")
fs.IntVar(&o.maxRecordsPerPool, "max-records-per-pool", 1000, "The maximum number of history records stored for an individual Keeper pool.")
fs.StringVar(&o.historyURI, "history-uri", "", "The /local/path or gs://path/to/object to store keeper action history. GCS writes will use the default object ACL for the bucket")
fs.StringVar(&o.statusURI, "status-path", "", "The /local/path or gs://path/to/object to store status controller state. GCS writes will use the default object ACL for the bucket.")
fs.StringVar(&o.namespace, "namespace", "", "The namespace to listen in")
err := fs.Parse(args)
if err != nil {
logrus.WithError(err).Fatal("Invalid options")
}
o.configPath = configutil.PathOrDefault(o.configPath)
return o
}
func main() {
logrusutil.ComponentInit("keeper")
defer interrupts.WaitForGracefulShutdown()
jobutil.ServePProf()
o := gatherOptions(flag.NewFlagSet(os.Args[0], flag.ExitOnError), os.Args[1:]...)
if err := o.Validate(); err != nil {
logrus.WithError(err).Fatal("Invalid options")
}
configAgent := &config.Agent{}
cfgMapWatcher, err := watcher.SetupConfigMapWatchers(o.namespace, configAgent, nil)
if err != nil {
logrus.WithError(err).Fatal("error starting config map watcher")
}
defer cfgMapWatcher.Stop()
botName := o.botName
if botName == "" {
botName = util.GetBotName(configAgent.Config)
}
if util.GetGitHubAppSecretDir() != "" {
botName, err = util.GetGitHubAppAPIUser()
if err != nil {
logrus.WithError(err).Fatal("unable to read API user for GitHub App integration")
}
}
if botName == "" {
logrus.Fatal("no $GIT_USER defined")
}
serverURL := o.gitServerURL
if serverURL == "" {
serverURL = util.GetGitServer(configAgent.Config)
}
gitKind := o.gitKind
if gitKind == "" {
gitKind = util.GitKind(configAgent.Config)
}
gitToken, err := util.GetSCMToken(gitKind)
if err != nil {
logrus.WithError(err).Fatal("Error creating Keeper controller.")
}
cfg := configAgent.Config
c, err := githubapp.NewKeeperController(configAgent, botName, gitKind, gitToken, serverURL, o.maxRecordsPerPool, o.historyURI, o.statusURI, o.namespace)
if err != nil {
logrus.WithError(err).Fatal("Error creating Keeper controller.")
}
defer c.Shutdown()
http.Handle("/", c)
http.Handle("/history", c.GetHistory())
server := &http.Server{Addr: ":" + strconv.Itoa(o.port)}
start := time.Now()
sync(c)
if o.runOnce {
return
}
// run the controller, but only after one sync period expires after our first run
time.Sleep(time.Until(start.Add(cfg().Keeper.SyncPeriod)))
interrupts.Tick(func() {
sync(c)
}, func() time.Duration {
return cfg().Keeper.SyncPeriod
})
// Push metrics to the configured prometheus pushgateway endpoint or serve them
metrics.ExposeMetrics("keeper", cfg().PushGateway)
// serve data
logrus.WithField("port", o.port).Info("Starting HTTP server")
interrupts.ListenAndServe(server, 10*time.Second)
interrupts.WaitForGracefulShutdown()
}
func sync(c keeper.Controller) {
if err := c.Sync(); err != nil {
logrus.WithError(err).Error("Error syncing.")
}
}