2017-06-19 17:56:23 +08:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
"os/signal"
|
|
|
|
"syscall"
|
|
|
|
|
|
|
|
"git.openstack.org/openstack/stackube/pkg/auth-controller/rbacmanager"
|
|
|
|
"git.openstack.org/openstack/stackube/pkg/auth-controller/tenant"
|
2017-06-23 17:42:16 +08:00
|
|
|
"git.openstack.org/openstack/stackube/pkg/network-controller"
|
2017-06-19 17:56:23 +08:00
|
|
|
"git.openstack.org/openstack/stackube/pkg/openstack"
|
|
|
|
"git.openstack.org/openstack/stackube/pkg/util"
|
|
|
|
|
|
|
|
"github.com/golang/glog"
|
2017-06-30 14:07:26 +08:00
|
|
|
"github.com/spf13/pflag"
|
2017-06-19 17:56:23 +08:00
|
|
|
"golang.org/x/sync/errgroup"
|
|
|
|
"k8s.io/client-go/kubernetes"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2017-06-30 14:07:26 +08:00
|
|
|
kubeconfig = pflag.String("kubeconfig", "/etc/kubernetes/admin.conf",
|
|
|
|
"path to kubernetes admin config file")
|
|
|
|
cloudconfig = pflag.String("cloudconfig", "/etc/stackube.conf",
|
|
|
|
"path to stackube config file")
|
2017-07-20 23:01:00 +08:00
|
|
|
userCIDR = pflag.String("user-cidr", "10.244.0.0/16", "user Pod network CIDR")
|
|
|
|
userGateway = pflag.String("user-gateway", "10.244.0.1", "user Pod network gateway")
|
2017-06-19 17:56:23 +08:00
|
|
|
)
|
|
|
|
|
2017-07-07 15:44:11 +08:00
|
|
|
func startControllers(kubeconfig, cloudconfig string) error {
|
2017-07-13 13:10:43 +08:00
|
|
|
// Creates a new Tenant controller
|
|
|
|
tc, err := tenant.NewTenantController(kubeconfig, cloudconfig)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Creates a new Network controller
|
|
|
|
nc, err := network.NewNetworkController(
|
|
|
|
kubeconfig, cloudconfig)
|
2017-06-19 17:56:23 +08:00
|
|
|
if err != nil {
|
2017-06-30 14:07:26 +08:00
|
|
|
return err
|
2017-06-19 17:56:23 +08:00
|
|
|
}
|
2017-06-30 14:07:26 +08:00
|
|
|
|
2017-06-19 17:56:23 +08:00
|
|
|
// Creates a new RBAC controller
|
2017-07-20 23:01:00 +08:00
|
|
|
rm, err := rbacmanager.NewRBACController(kubeconfig,
|
2017-07-18 22:52:03 +08:00
|
|
|
tc.GetKubeCRDClient(),
|
2017-07-20 23:01:00 +08:00
|
|
|
*userCIDR,
|
|
|
|
*userGateway,
|
2017-07-13 13:10:43 +08:00
|
|
|
)
|
2017-06-19 17:56:23 +08:00
|
|
|
if err != nil {
|
2017-06-30 14:07:26 +08:00
|
|
|
return err
|
2017-06-19 17:56:23 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
ctx, cancel := context.WithCancel(context.Background())
|
|
|
|
wg, ctx := errgroup.WithContext(ctx)
|
|
|
|
|
2017-06-23 17:42:16 +08:00
|
|
|
// start auth controllers in stackube
|
2017-06-19 17:56:23 +08:00
|
|
|
wg.Go(func() error { return tc.Run(ctx.Done()) })
|
|
|
|
wg.Go(func() error { return rm.Run(ctx.Done()) })
|
|
|
|
|
2017-06-23 17:42:16 +08:00
|
|
|
// start network controller
|
2017-07-13 13:10:43 +08:00
|
|
|
wg.Go(func() error { return nc.Run(ctx.Done()) })
|
2017-06-23 17:42:16 +08:00
|
|
|
|
2017-06-19 17:56:23 +08:00
|
|
|
term := make(chan os.Signal)
|
|
|
|
signal.Notify(term, os.Interrupt, syscall.SIGTERM)
|
|
|
|
|
|
|
|
select {
|
|
|
|
case <-term:
|
|
|
|
glog.V(4).Info("Received SIGTERM, exiting gracefully...")
|
|
|
|
case <-ctx.Done():
|
|
|
|
}
|
|
|
|
|
|
|
|
cancel()
|
|
|
|
if err := wg.Wait(); err != nil {
|
|
|
|
glog.Errorf("Unhandled error received: %v", err)
|
2017-06-30 14:07:26 +08:00
|
|
|
return err
|
2017-06-19 17:56:23 +08:00
|
|
|
}
|
|
|
|
|
2017-06-30 14:07:26 +08:00
|
|
|
return nil
|
2017-06-19 17:56:23 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func verifyClientSetting() error {
|
2017-06-30 14:07:26 +08:00
|
|
|
config, err := util.NewClusterConfig(*kubeconfig)
|
2017-06-19 17:56:23 +08:00
|
|
|
if err != nil {
|
2017-06-30 14:07:26 +08:00
|
|
|
return fmt.Errorf("Init kubernetes cluster failed: %v", err)
|
2017-06-19 17:56:23 +08:00
|
|
|
}
|
2017-06-30 14:07:26 +08:00
|
|
|
|
2017-06-19 17:56:23 +08:00
|
|
|
_, err = kubernetes.NewForConfig(config)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Init kubernetes clientset failed: %v", err)
|
|
|
|
}
|
2017-06-30 14:07:26 +08:00
|
|
|
|
2017-07-18 22:52:03 +08:00
|
|
|
_, err = openstack.NewClient(*cloudconfig, *kubeconfig)
|
2017-06-19 17:56:23 +08:00
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Init openstack client failed: %v", err)
|
|
|
|
}
|
2017-06-30 14:07:26 +08:00
|
|
|
|
2017-06-19 17:56:23 +08:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func main() {
|
2017-06-30 14:07:26 +08:00
|
|
|
util.InitFlags()
|
|
|
|
util.InitLogs()
|
|
|
|
defer util.FlushLogs()
|
|
|
|
|
|
|
|
// Verify client setting at the beginning and fail early if there are errors.
|
|
|
|
err := verifyClientSetting()
|
|
|
|
if err != nil {
|
|
|
|
glog.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Start stackube controllers.
|
2017-07-07 15:44:11 +08:00
|
|
|
if err := startControllers(*kubeconfig, *cloudconfig); err != nil {
|
2017-06-30 14:07:26 +08:00
|
|
|
glog.Fatal(err)
|
|
|
|
}
|
2017-06-19 17:56:23 +08:00
|
|
|
}
|