keel/main.go

164 lines
3.9 KiB
Go
Raw Normal View History

2017-06-10 11:23:51 +00:00
package main
import (
"os"
"os/signal"
"time"
2017-06-10 23:25:36 +00:00
"golang.org/x/net/context"
2017-06-10 11:23:51 +00:00
"github.com/rusenask/keel/provider"
"github.com/rusenask/keel/provider/kubernetes"
2017-06-12 20:54:11 +00:00
"github.com/rusenask/keel/trigger/http"
2017-06-10 23:25:36 +00:00
"github.com/rusenask/keel/trigger/pubsub"
2017-06-10 11:23:51 +00:00
"github.com/rusenask/keel/types"
2017-06-15 07:47:40 +00:00
"github.com/rusenask/keel/version"
2017-06-10 11:23:51 +00:00
log "github.com/Sirupsen/logrus"
)
2017-06-10 23:25:36 +00:00
// gcloud pubsub related config
const (
2017-06-11 21:52:18 +00:00
EnvTriggerPubSub = "PUBSUB" // set to 1 or something to enable pub/sub trigger
EnvProjectID = "PROJECT_ID"
2017-06-10 23:25:36 +00:00
)
// kubernetes config, if empty - will default to InCluster
const (
EnvKubernetesConfig = "KUBERNETES_CONFIG"
)
2017-06-11 21:52:18 +00:00
// EnvDebug - set to 1 or anything else to enable debug logging
const EnvDebug = "DEBUG"
2017-06-10 11:23:51 +00:00
func main() {
2017-06-15 07:47:40 +00:00
ver := version.GetKeelVersion()
log.WithFields(log.Fields{
"os": ver.OS,
"build_date": ver.BuildDate,
"revision": ver.Revision,
"version": ver.Version,
"go_version": ver.GoVersion,
"arch": ver.Arch,
}).Info("Keel starting..")
2017-06-11 21:52:18 +00:00
if os.Getenv(EnvDebug) != "" {
log.SetLevel(log.DebugLevel)
}
2017-06-10 11:23:51 +00:00
// getting k8s provider
2017-06-10 23:25:36 +00:00
k8sCfg := &kubernetes.Opts{}
if os.Getenv(EnvKubernetesConfig) != "" {
k8sCfg.ConfigPath = os.Getenv(EnvKubernetesConfig)
} else {
k8sCfg.InCluster = true
}
2017-06-11 21:52:18 +00:00
implementer, err := kubernetes.NewKubernetesImplementer(k8sCfg)
if err != nil {
log.WithFields(log.Fields{
"error": err,
"config": k8sCfg,
}).Fatal("main: failed to create kubernetes implementer")
}
2017-06-12 20:49:01 +00:00
// setting up providers
providers, teardownProviders := setupProviders(implementer)
// setting up triggers
ctx, cancel := context.WithCancel(context.Background())
defer cancel()
teardownTriggers := setupTriggers(ctx, implementer, providers)
signalChan := make(chan os.Signal, 1)
cleanupDone := make(chan bool)
signal.Notify(signalChan, os.Interrupt)
go func() {
for _ = range signalChan {
log.Info("received an interrupt, closing connection...")
go func() {
select {
case <-time.After(10 * time.Second):
log.Info("connection shutdown took too long, exiting... ")
close(cleanupDone)
return
case <-cleanupDone:
return
}
}()
teardownProviders()
teardownTriggers()
cleanupDone <- true
}
}()
<-cleanupDone
}
// setupProviders - setting up available providers. New providers should be initialised here and added to
// provider map
func setupProviders(k8sImplementer kubernetes.Implementer) (providers map[string]provider.Provider, teardown func()) {
k8sProvider, err := kubernetes.NewProvider(k8sImplementer)
2017-06-10 11:23:51 +00:00
if err != nil {
log.WithFields(log.Fields{
"error": err,
2017-06-12 20:49:01 +00:00
}).Fatal("main.setupProviders: failed to create kubernetes provider")
2017-06-10 11:23:51 +00:00
}
go k8sProvider.Start()
2017-06-12 20:49:01 +00:00
providers = make(map[string]provider.Provider)
2017-06-10 11:23:51 +00:00
providers[k8sProvider.GetName()] = k8sProvider
2017-06-12 20:49:01 +00:00
teardown = func() {
k8sProvider.Stop()
}
return providers, teardown
}
// setupTriggers - setting up triggers. New triggers should be added to this function. Each trigger
// should go through all providers (or not if there is a reason) and submit events)
func setupTriggers(ctx context.Context, k8sImplementer kubernetes.Implementer, providers map[string]provider.Provider) (teardown func()) {
2017-06-12 20:54:11 +00:00
// setting up generic http webhook server
whs := http.NewTriggerServer(&http.Opts{
2017-06-10 11:23:51 +00:00
Port: types.KeelDefaultPort,
Providers: providers,
})
go whs.Start()
2017-06-12 20:49:01 +00:00
// checking whether pubsub (GCR) trigger is enabled
2017-06-10 23:25:36 +00:00
if os.Getenv(EnvTriggerPubSub) != "" {
projectID := os.Getenv(EnvProjectID)
if projectID == "" {
2017-06-12 20:49:01 +00:00
log.Fatalf("main.setupTriggers: project ID env variable not set")
2017-06-10 23:25:36 +00:00
return
}
2017-06-14 19:03:37 +00:00
ps, err := pubsub.NewPubsubSubscriber(&pubsub.Opts{
2017-06-11 21:52:18 +00:00
ProjectID: projectID,
Providers: providers,
2017-06-10 23:25:36 +00:00
})
if err != nil {
log.WithFields(log.Fields{
"error": err,
2017-06-12 20:49:01 +00:00
}).Fatal("main.setupTriggers: failed to create gcloud pubsub subscriber")
2017-06-10 23:25:36 +00:00
return
}
2017-06-11 21:52:18 +00:00
2017-06-12 20:49:01 +00:00
subManager := pubsub.NewDefaultManager(projectID, k8sImplementer, ps)
2017-06-11 21:52:18 +00:00
go subManager.Start(ctx)
2017-06-10 23:25:36 +00:00
}
2017-06-12 20:49:01 +00:00
teardown = func() {
whs.Stop()
}
2017-06-10 11:23:51 +00:00
2017-06-12 20:49:01 +00:00
return teardown
2017-06-10 11:23:51 +00:00
}