未验证 提交 1dcb9232 编写于 作者: K KubeSphere CI Bot 提交者: GitHub

Merge pull request #702 from zryfish/refactor_clientset

refactor dependent service client creation
...@@ -21,7 +21,12 @@ before_script: ...@@ -21,7 +21,12 @@ before_script:
- bash hack/install_kubebuilder.sh - bash hack/install_kubebuilder.sh
script: script:
- make all - diff -u <(echo -n) <(gofmt -d ./pkg ./cmd ./tools)
- make openapi
- make all
install:
- go get golang.org/x/lint/golint
deploy: deploy:
skip_cleanup: true skip_cleanup: true
......
...@@ -39,7 +39,7 @@ define ALL_HELP_INFO ...@@ -39,7 +39,7 @@ define ALL_HELP_INFO
# debugging tools like delve. # debugging tools like delve.
endef endef
.PHONY: all .PHONY: all
all: test ks-apiserver ks-apigateway ks-iam controller-manager all: hypersphere ks-apiserver ks-apigateway ks-iam controller-manager
# Build ks-apiserver binary # Build ks-apiserver binary
ks-apiserver: test ks-apiserver: test
...@@ -57,9 +57,13 @@ ks-iam: test ...@@ -57,9 +57,13 @@ ks-iam: test
controller-manager: test controller-manager: test
hack/gobuild.sh cmd/controller-manager hack/gobuild.sh cmd/controller-manager
# Build hypersphere binary
hypersphere: test
hack/gobuild.sh cmd/hypersphere
# Run go fmt against code # Run go fmt against code
fmt: generate fmt: generate
go fmt ./pkg/... ./cmd/... gofmt -w ./pkg ./cmd ./tools ./api
# Run go vet against code # Run go vet against code
vet: generate vet: generate
......
# Copyright 2018 The KubeSphere Authors. All rights reserved.
# Use of this source code is governed by a Apache license
# that can be found in the LICENSE file.
# Copyright 2018 The KubeSphere Authors. All rights reserved.
# Use of this source code is governed by a Apache license
# that can be found in the LICENSE file.
FROM golang:1.12 as hypersphere-builder
COPY / /go/src/kubesphere.io/kubesphere
WORKDIR /go/src/kubesphere.io/kubesphere
RUN CGO_ENABLED=0 GO111MODULE=on GOOS=linux GOARCH=amd64 GOFLAGS=-mod=vendor go build -i -ldflags '-w -s' -o hypersphere cmd/hypersphere/hypersphere.go
FROM alpine:3.9
RUN apk add --update ca-certificates && update-ca-certificates
COPY --from=ks-apiserver-builder /go/src/kubesphere.io/kubesphere/hypersphere /usr/local/bin/
CMD ["sh"]
...@@ -25,7 +25,6 @@ import ( ...@@ -25,7 +25,6 @@ import (
"kubesphere.io/kubesphere/pkg/controller/destinationrule" "kubesphere.io/kubesphere/pkg/controller/destinationrule"
"kubesphere.io/kubesphere/pkg/controller/job" "kubesphere.io/kubesphere/pkg/controller/job"
"kubesphere.io/kubesphere/pkg/controller/s2ibinary" "kubesphere.io/kubesphere/pkg/controller/s2ibinary"
"kubesphere.io/kubesphere/pkg/controller/s2irun" "kubesphere.io/kubesphere/pkg/controller/s2irun"
//"kubesphere.io/kubesphere/pkg/controller/job" //"kubesphere.io/kubesphere/pkg/controller/job"
...@@ -112,7 +111,9 @@ func AddControllers(mgr manager.Manager, cfg *rest.Config, stopCh <-chan struct{ ...@@ -112,7 +111,9 @@ func AddControllers(mgr manager.Manager, cfg *rest.Config, stopCh <-chan struct{
jobController := job.NewJobController(informerFactory.Batch().V1().Jobs(), kubeClient) jobController := job.NewJobController(informerFactory.Batch().V1().Jobs(), kubeClient)
s2iBinaryController := s2ibinary.NewController(kubesphereclient, kubeClient, kubesphereInformer.Devops().V1alpha1().S2iBinaries()) s2iBinaryController := s2ibinary.NewController(kubesphereclient,
kubeClient,
kubesphereInformer.Devops().V1alpha1().S2iBinaries())
s2iRunController := s2irun.NewController(kubesphereclient, s2iclient, kubeClient, s2iRunController := s2irun.NewController(kubesphereclient, s2iclient, kubeClient,
kubesphereInformer.Devops().V1alpha1().S2iBinaries(), kubesphereInformer.Devops().V1alpha1().S2iBinaries(),
......
package options
import (
"flag"
cliflag "k8s.io/component-base/cli/flag"
"k8s.io/klog"
kubesphereconfig "kubesphere.io/kubesphere/pkg/server/config"
"kubesphere.io/kubesphere/pkg/simple/client/devops"
"kubesphere.io/kubesphere/pkg/simple/client/k8s"
"kubesphere.io/kubesphere/pkg/simple/client/s2is3"
"strings"
)
type KubeSphereControllerManagerOptions struct {
KubernetesOptions *k8s.KubernetesOptions
DevopsOptions *devops.DevopsOptions
S3Options *s2is3.S3Options
}
func NewKubeSphereControllerManagerOptions() *KubeSphereControllerManagerOptions {
s := &KubeSphereControllerManagerOptions{
KubernetesOptions: k8s.NewKubernetesOptions(),
DevopsOptions: devops.NewDevopsOptions(),
S3Options: s2is3.NewS3Options(),
}
return s
}
func (s *KubeSphereControllerManagerOptions) ApplyTo(conf *kubesphereconfig.Config) {
s.S3Options.ApplyTo(conf.S3Options)
s.KubernetesOptions.ApplyTo(conf.KubernetesOptions)
s.DevopsOptions.ApplyTo(conf.DevopsOptions)
}
func (s *KubeSphereControllerManagerOptions) Flags() cliflag.NamedFlagSets {
fss := cliflag.NamedFlagSets{}
s.KubernetesOptions.AddFlags(fss.FlagSet("kubernetes"))
s.DevopsOptions.AddFlags(fss.FlagSet("devops"))
s.S3Options.AddFlags(fss.FlagSet("s3"))
fs := fss.FlagSet("klog")
local := flag.NewFlagSet("klog", flag.ExitOnError)
klog.InitFlags(local)
local.VisitAll(func(fl *flag.Flag) {
fl.Name = strings.Replace(fl.Name, "_", "-", -1)
fs.AddGoFlag(fl)
})
return fss
}
func (s *KubeSphereControllerManagerOptions) Validate() []error {
var errs []error
errs = append(errs, s.DevopsOptions.Validate()...)
errs = append(errs, s.KubernetesOptions.Validate()...)
errs = append(errs, s.S3Options.Validate()...)
return errs
}
/*
Copyright 2019 The KubeSphere 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 app
import (
"fmt"
"github.com/spf13/cobra"
utilerrors "k8s.io/apimachinery/pkg/util/errors"
cliflag "k8s.io/component-base/cli/flag"
"k8s.io/klog"
"kubesphere.io/kubesphere/cmd/controller-manager/app/options"
"kubesphere.io/kubesphere/pkg/apis"
"kubesphere.io/kubesphere/pkg/controller"
controllerconfig "kubesphere.io/kubesphere/pkg/server/config"
"kubesphere.io/kubesphere/pkg/simple/client"
"kubesphere.io/kubesphere/pkg/utils/term"
"os"
"sigs.k8s.io/controller-runtime/pkg/manager"
"sigs.k8s.io/controller-runtime/pkg/runtime/signals"
)
func NewControllerManagerCommand() *cobra.Command {
s := options.NewKubeSphereControllerManagerOptions()
cmd := &cobra.Command{
Use: "controller-manager",
Long: `KubeSphere controller manager is a daemon that`,
Run: func(cmd *cobra.Command, args []string) {
err := controllerconfig.Load()
if err != nil {
klog.Fatal(err)
os.Exit(1)
}
err = Complete(s)
if err != nil {
os.Exit(1)
}
if errs := s.Validate(); len(errs) != 0 {
klog.Error(utilerrors.NewAggregate(errs))
os.Exit(1)
}
if err = Run(s, signals.SetupSignalHandler()); err != nil {
os.Exit(1)
}
},
}
fs := cmd.Flags()
namedFlagSets := s.Flags()
for _, f := range namedFlagSets.FlagSets {
fs.AddFlagSet(f)
}
usageFmt := "Usage:\n %s\n"
cols, _, _ := term.TerminalSize(cmd.OutOrStdout())
cmd.SetHelpFunc(func(cmd *cobra.Command, args []string) {
fmt.Fprintf(cmd.OutOrStdout(), "%s\n\n"+usageFmt, cmd.Long, cmd.UseLine())
cliflag.PrintSections(cmd.OutOrStdout(), namedFlagSets, cols)
})
return cmd
}
func Complete(s *options.KubeSphereControllerManagerOptions) error {
conf := controllerconfig.Get()
conf.Apply(&controllerconfig.Config{
DevopsOptions: s.DevopsOptions,
KubernetesOptions: s.KubernetesOptions,
S3Options: s.S3Options,
})
s = &options.KubeSphereControllerManagerOptions{
KubernetesOptions: conf.KubernetesOptions,
DevopsOptions: conf.DevopsOptions,
S3Options: conf.S3Options,
}
return nil
}
func CreateClientSet(s *options.KubeSphereControllerManagerOptions, stopCh <-chan struct{}) error {
csop := &client.ClientSetOptions{}
csop.SetKubernetesOptions(s.KubernetesOptions).
SetDevopsOptions(s.DevopsOptions).
SetS3Options(s.S3Options)
client.NewClientSetFactory(csop, stopCh)
return nil
}
func Run(s *options.KubeSphereControllerManagerOptions, stopCh <-chan struct{}) error {
err := CreateClientSet(s, stopCh)
if err != nil {
klog.Error(err)
return err
}
config := client.ClientSets().K8s().Config()
klog.Info("setting up manager")
mgr, err := manager.New(config, manager.Options{})
if err != nil {
klog.Error(err, "unable to set up overall controller manager")
return err
}
klog.Info("setting up scheme")
if err := apis.AddToScheme(mgr.GetScheme()); err != nil {
klog.Error(err, "unable add APIs to scheme")
return err
}
klog.Info("Setting up controllers")
if err := controller.AddToManager(mgr); err != nil {
klog.Error(err, "unable to register controllers to the manager")
return err
}
if err := AddControllers(mgr, config, stopCh); err != nil {
klog.Error(err, "unable to register controllers to the manager")
return err
}
klog.Info("Starting the Cmd.")
if err := mgr.Start(stopCh); err != nil {
klog.Error(err, "unable to run the manager")
return err
}
return nil
}
/*
Copyright 2019 The KubeSphere 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 package main
import ( import (
"flag"
"k8s.io/klog"
"kubesphere.io/kubesphere/cmd/controller-manager/app" "kubesphere.io/kubesphere/cmd/controller-manager/app"
"kubesphere.io/kubesphere/pkg/apis"
"kubesphere.io/kubesphere/pkg/controller"
"kubesphere.io/kubesphere/pkg/simple/client/k8s"
"os" "os"
"sigs.k8s.io/controller-runtime/pkg/manager"
"sigs.k8s.io/controller-runtime/pkg/runtime/signals"
)
var (
masterURL string
metricsAddr string
) )
func init() {
flag.StringVar(&metricsAddr, "metrics-addr", ":8080", "The address the metric endpoint binds to.")
}
func main() { func main() {
flag.Parse() command := app.NewControllerManagerCommand()
cfg, err := k8s.Config()
if err != nil {
klog.Error(err, "failed to build kubeconfig")
os.Exit(1)
}
stopCh := signals.SetupSignalHandler()
klog.Info("setting up manager") if err := command.Execute(); err != nil {
mgr, err := manager.New(cfg, manager.Options{})
if err != nil {
klog.Error(err, "unable to set up overall controller manager")
os.Exit(1) os.Exit(1)
} }
klog.Info("setting up scheme")
if err := apis.AddToScheme(mgr.GetScheme()); err != nil {
klog.Error(err, "unable add APIs to scheme")
os.Exit(1)
}
klog.Info("Setting up controllers")
if err := controller.AddToManager(mgr); err != nil {
klog.Error(err, "unable to register controllers to the manager")
os.Exit(1)
}
if err := app.AddControllers(mgr, cfg, stopCh); err != nil {
klog.Error(err, "unable to register controllers to the manager")
os.Exit(1)
}
klog.Info("Starting the Cmd.")
if err := mgr.Start(stopCh); err != nil {
klog.Error(err, "unable to run the manager")
os.Exit(1)
}
} }
package main
import (
goflag "flag"
cliflag "k8s.io/component-base/cli/flag"
"path/filepath"
"github.com/spf13/cobra"
"github.com/spf13/pflag"
controllermanager "kubesphere.io/kubesphere/cmd/controller-manager/app"
ksapiserver "kubesphere.io/kubesphere/cmd/ks-apiserver/app"
ksaiam "kubesphere.io/kubesphere/cmd/ks-iam/app"
"os"
)
func main() {
hypersphereCommand, allCommandFns := NewHyperSphereCommand()
pflag.CommandLine.SetNormalizeFunc(cliflag.WordSepNormalizeFunc)
pflag.CommandLine.AddGoFlagSet(goflag.CommandLine)
basename := filepath.Base(os.Args[0])
if err := commandFor(basename, hypersphereCommand, allCommandFns).Execute(); err != nil {
os.Exit(1)
}
}
func commandFor(basename string, defaultCommand *cobra.Command, commands []func() *cobra.Command) *cobra.Command {
for _, commandFn := range commands {
command := commandFn()
if command.Name() == basename {
return command
}
for _, alias := range command.Aliases {
if alias == basename {
return command
}
}
}
return defaultCommand
}
func NewHyperSphereCommand() (*cobra.Command, []func() *cobra.Command) {
apiserver := func() *cobra.Command { return ksapiserver.NewAPIServerCommand() }
controllermanager := func() *cobra.Command { return controllermanager.NewControllerManagerCommand() }
iam := func() *cobra.Command { return ksaiam.NewAPIServerCommand() }
commandFns := []func() *cobra.Command{
apiserver,
controllermanager,
iam,
}
cmd := &cobra.Command{
Use: "hypersphere",
Short: "Request a new project",
Run: func(cmd *cobra.Command, args []string) {
if len(args) != 0 {
cmd.Help()
os.Exit(0)
}
},
}
for i := range commandFns {
cmd.AddCommand(commandFns[i]())
}
return cmd, commandFns
}
package options package options
import ( import (
"github.com/spf13/pflag" "flag"
cliflag "k8s.io/component-base/cli/flag"
"k8s.io/klog"
genericoptions "kubesphere.io/kubesphere/pkg/options" genericoptions "kubesphere.io/kubesphere/pkg/options"
"kubesphere.io/kubesphere/pkg/simple/client/devops"
"kubesphere.io/kubesphere/pkg/simple/client/k8s"
"kubesphere.io/kubesphere/pkg/simple/client/mysql"
"kubesphere.io/kubesphere/pkg/simple/client/prometheus"
"kubesphere.io/kubesphere/pkg/simple/client/servicemesh"
"kubesphere.io/kubesphere/pkg/simple/client/sonarqube"
"strings"
) )
type ServerRunOptions struct { type ServerRunOptions struct {
GenericServerRunOptions *genericoptions.ServerRunOptions GenericServerRunOptions *genericoptions.ServerRunOptions
// istio pilot discovery service url KubernetesOptions *k8s.KubernetesOptions
IstioPilotServiceURL string
// jaeger query service url DevopsOptions *devops.DevopsOptions
JaegerQueryServiceUrl string
// prometheus service url for servicemesh metrics SonarQubeOptions *sonarqube.SonarQubeOptions
ServicemeshPrometheusServiceUrl string
// openpitrix api gateway service url ServiceMeshOptions *servicemesh.ServiceMeshOptions
OpenPitrixServer string
// openpitrix service token MySQLOptions *mysql.MySQLOptions
OpenPitrixProxyToken string
MonitoringOptions *prometheus.PrometheusOptions
} }
func NewServerRunOptions() *ServerRunOptions { func NewServerRunOptions() *ServerRunOptions {
s := ServerRunOptions{ s := ServerRunOptions{
GenericServerRunOptions: genericoptions.NewServerRunOptions(), GenericServerRunOptions: genericoptions.NewServerRunOptions(),
IstioPilotServiceURL: "http://istio-pilot.istio-system.svc:8080/version", KubernetesOptions: k8s.NewKubernetesOptions(),
JaegerQueryServiceUrl: "http://jaeger-query.istio-system.svc:16686/jaeger", DevopsOptions: devops.NewDevopsOptions(),
SonarQubeOptions: sonarqube.NewSonarQubeOptions(),
ServiceMeshOptions: servicemesh.NewServiceMeshOptions(),
MySQLOptions: mysql.NewMySQLOptions(),
MonitoringOptions: prometheus.NewPrometheusOptions(),
} }
return &s return &s
} }
func (s *ServerRunOptions) AddFlags(fs *pflag.FlagSet) { func (s *ServerRunOptions) Flags() (fss cliflag.NamedFlagSets) {
s.GenericServerRunOptions.AddFlags(fss.FlagSet("generic"))
s.KubernetesOptions.AddFlags(fss.FlagSet("kubernetes"))
s.DevopsOptions.AddFlags(fss.FlagSet("devops"))
s.SonarQubeOptions.AddFlags(fss.FlagSet("sonarqube"))
s.ServiceMeshOptions.AddFlags(fss.FlagSet("servicemesh"))
s.MonitoringOptions.AddFlags(fss.FlagSet("monitoring"))
s.GenericServerRunOptions.AddFlags(fs) fs := fss.FlagSet("klog")
local := flag.NewFlagSet("klog", flag.ExitOnError)
klog.InitFlags(local)
local.VisitAll(func(fl *flag.Flag) {
fl.Name = strings.Replace(fl.Name, "_", "-", -1)
fs.AddGoFlag(fl)
})
fs.StringVar(&s.IstioPilotServiceURL, "istio-pilot-service-url", "http://istio-pilot.istio-system.svc:8080/version", "istio pilot discovery service url") return fss
fs.StringVar(&s.JaegerQueryServiceUrl, "jaeger-query-service-url", "http://jaeger-query.istio-system.svc:16686/jaeger", "jaeger query service url")
fs.StringVar(&s.ServicemeshPrometheusServiceUrl, "servicemesh-prometheus-service-url", "http://prometheus-k8s-system.kubesphere-monitoring-system.svc:9090", "prometheus service for servicemesh")
} }
package options
func (s *ServerRunOptions) Validate() []error {
var errors []error
errors = append(errors, s.DevopsOptions.Validate()...)
errors = append(errors, s.KubernetesOptions.Validate()...)
errors = append(errors, s.MySQLOptions.Validate()...)
errors = append(errors, s.ServiceMeshOptions.Validate()...)
errors = append(errors, s.MonitoringOptions.Validate()...)
errors = append(errors, s.SonarQubeOptions.Validate()...)
return errors
}
...@@ -18,113 +18,110 @@ ...@@ -18,113 +18,110 @@
package app package app
import ( import (
goflag "flag"
"fmt" "fmt"
"github.com/golang/glog"
"github.com/json-iterator/go"
kconfig "github.com/kiali/kiali/config" kconfig "github.com/kiali/kiali/config"
"github.com/spf13/cobra" "github.com/spf13/cobra"
"github.com/spf13/pflag" "k8s.io/apimachinery/pkg/runtime/schema"
utilerrors "k8s.io/apimachinery/pkg/util/errors"
cliflag "k8s.io/component-base/cli/flag"
"k8s.io/klog"
"kubesphere.io/kubesphere/cmd/ks-apiserver/app/options" "kubesphere.io/kubesphere/cmd/ks-apiserver/app/options"
"kubesphere.io/kubesphere/pkg/apiserver/runtime" "kubesphere.io/kubesphere/pkg/apiserver/runtime"
"kubesphere.io/kubesphere/pkg/apiserver/servicemesh/tracing" "kubesphere.io/kubesphere/pkg/apiserver/servicemesh/tracing"
"kubesphere.io/kubesphere/pkg/filter" "kubesphere.io/kubesphere/pkg/filter"
"kubesphere.io/kubesphere/pkg/informers" "kubesphere.io/kubesphere/pkg/informers"
"kubesphere.io/kubesphere/pkg/models/devops"
logging "kubesphere.io/kubesphere/pkg/models/log" logging "kubesphere.io/kubesphere/pkg/models/log"
"kubesphere.io/kubesphere/pkg/server" "kubesphere.io/kubesphere/pkg/server"
"kubesphere.io/kubesphere/pkg/signals" apiserverconfig "kubesphere.io/kubesphere/pkg/server/config"
"kubesphere.io/kubesphere/pkg/simple/client/admin_jenkins" "kubesphere.io/kubesphere/pkg/simple/client"
"kubesphere.io/kubesphere/pkg/simple/client/devops_mysql" "kubesphere.io/kubesphere/pkg/utils/signals"
"log" "kubesphere.io/kubesphere/pkg/utils/term"
"net/http" "net/http"
) )
var jsonIter = jsoniter.ConfigCompatibleWithStandardLibrary
func NewAPIServerCommand() *cobra.Command { func NewAPIServerCommand() *cobra.Command {
s := options.NewServerRunOptions() s := options.NewServerRunOptions()
cmd := &cobra.Command{ cmd := &cobra.Command{
Use: "ks-apiserver", Use: "ks-apiserver",
Long: `The KubeSphere API server validates and configures data Long: `The KubeSphere API server validates and configures data for the api objects.
for the api objects. The API Server services REST operations and provides the frontend to the The API Server services REST operations and provides the frontend to the
cluster's shared state through which all other components interact.`, cluster's shared state through which all other components interact.`,
RunE: func(cmd *cobra.Command, args []string) error { RunE: func(cmd *cobra.Command, args []string) error {
return Run(s) err := apiserverconfig.Load()
if err != nil {
return err
}
err = Complete(s)
if err != nil {
return err
}
if errs := s.Validate(); len(errs) != 0 {
return utilerrors.NewAggregate(errs)
}
return Run(s, signals.SetupSignalHandler())
}, },
} }
s.AddFlags(cmd.Flags()) fs := cmd.Flags()
cmd.Flags().AddGoFlagSet(goflag.CommandLine) namedFlagSets := s.Flags()
glog.CopyStandardLogTo("INFO")
return cmd
}
func Run(s *options.ServerRunOptions) error { for _, f := range namedFlagSets.FlagSets {
fs.AddFlagSet(f)
}
pflag.VisitAll(func(flag *pflag.Flag) { usageFmt := "Usage:\n %s\n"
log.Printf("FLAG: --%s=%q", flag.Name, flag.Value) cols, _, _ := term.TerminalSize(cmd.OutOrStdout())
cmd.SetHelpFunc(func(cmd *cobra.Command, args []string) {
fmt.Fprintf(cmd.OutOrStdout(), "%s\n\n"+usageFmt, cmd.Long, cmd.UseLine())
cliflag.PrintSections(cmd.OutOrStdout(), namedFlagSets, cols)
}) })
return cmd
}
var err error func Run(s *options.ServerRunOptions, stopCh <-chan struct{}) error {
waitForResourceSync() err := CreateClientSet(apiserverconfig.Get(), stopCh)
if err != nil {
return err
}
container := runtime.Container err = WaitForResourceSync(stopCh)
container.DoNotRecover(false) if err != nil {
container.Filter(filter.Logging) return err
container.RecoverHandler(server.LogStackOnRecover)
for _, webservice := range container.RegisteredWebServices() {
for _, route := range webservice.Routes() {
log.Println(route.Method, route.Path)
}
} }
initializeAdminJenkins()
initializeDevOpsDatabase()
initializeESClientConfig()
initializeServicemeshConfig(s) initializeServicemeshConfig(s)
if s.GenericServerRunOptions.InsecurePort != 0 { initializeESClientConfig()
log.Printf("Server listening on %d.", s.GenericServerRunOptions.InsecurePort)
err = http.ListenAndServe(fmt.Sprintf("%s:%d", s.GenericServerRunOptions.BindAddress, s.GenericServerRunOptions.InsecurePort), container)
}
if s.GenericServerRunOptions.SecurePort != 0 && len(s.GenericServerRunOptions.TlsCertFile) > 0 && len(s.GenericServerRunOptions.TlsPrivateKey) > 0 { err = CreateAPIServer(s)
log.Printf("Server listening on %d.", s.GenericServerRunOptions.SecurePort) if err != nil {
err = http.ListenAndServeTLS(fmt.Sprintf("%s:%d", s.GenericServerRunOptions.BindAddress, s.GenericServerRunOptions.SecurePort), s.GenericServerRunOptions.TlsCertFile, s.GenericServerRunOptions.TlsPrivateKey, container) return err
} }
return err return nil
}
func initializeAdminJenkins() {
devops.JenkinsInit()
admin_jenkins.Client()
}
func initializeDevOpsDatabase() {
devops_mysql.OpenDatabase()
} }
func initializeServicemeshConfig(s *options.ServerRunOptions) { func initializeServicemeshConfig(s *options.ServerRunOptions) {
// Initialize kiali config // Initialize kiali config
config := kconfig.NewConfig() config := kconfig.NewConfig()
tracing.JaegerQueryUrl = s.JaegerQueryServiceUrl tracing.JaegerQueryUrl = s.ServiceMeshOptions.JaegerQueryHost
// Exclude system namespaces // Exclude system namespaces
config.API.Namespaces.Exclude = []string{"istio-system", "kubesphere*", "kube*"} config.API.Namespaces.Exclude = []string{"istio-system", "kubesphere*", "kube*"}
config.InCluster = true config.InCluster = true
// Set default prometheus service url // Set default prometheus service url
config.ExternalServices.PrometheusServiceURL = s.ServicemeshPrometheusServiceUrl config.ExternalServices.PrometheusServiceURL = s.ServiceMeshOptions.ServicemeshPrometheusHost
config.ExternalServices.PrometheusCustomMetricsURL = config.ExternalServices.PrometheusServiceURL config.ExternalServices.PrometheusCustomMetricsURL = config.ExternalServices.PrometheusServiceURL
// Set istio pilot discovery service url // Set istio pilot discovery service url
config.ExternalServices.Istio.UrlServiceVersion = s.IstioPilotServiceURL config.ExternalServices.Istio.UrlServiceVersion = s.ServiceMeshOptions.IstioPilotHost
kconfig.Set(config) kconfig.Set(config)
} }
...@@ -134,7 +131,7 @@ func initializeESClientConfig() { ...@@ -134,7 +131,7 @@ func initializeESClientConfig() {
// List all outputs // List all outputs
outputs, err := logging.GetFluentbitOutputFromConfigMap() outputs, err := logging.GetFluentbitOutputFromConfigMap()
if err != nil { if err != nil {
glog.Errorln(err) klog.Errorln(err)
return return
} }
...@@ -147,54 +144,164 @@ func initializeESClientConfig() { ...@@ -147,54 +144,164 @@ func initializeESClientConfig() {
} }
} }
func waitForResourceSync() { //
stopChan := signals.SetupSignalHandler() func CreateAPIServer(s *options.ServerRunOptions) error {
var err error
container := runtime.Container
container.DoNotRecover(false)
container.Filter(filter.Logging)
container.RecoverHandler(server.LogStackOnRecover)
// install config api
apiserverconfig.InstallAPI(container)
for _, webservice := range container.RegisteredWebServices() {
for _, route := range webservice.Routes() {
klog.V(0).Info(route.Method, route.Path)
}
}
if s.GenericServerRunOptions.InsecurePort != 0 {
err = http.ListenAndServe(fmt.Sprintf("%s:%d", s.GenericServerRunOptions.BindAddress, s.GenericServerRunOptions.InsecurePort), container)
if err != nil {
klog.Infof("Server listening on %d.", s.GenericServerRunOptions.InsecurePort)
}
}
if s.GenericServerRunOptions.SecurePort != 0 && len(s.GenericServerRunOptions.TlsCertFile) > 0 && len(s.GenericServerRunOptions.TlsPrivateKey) > 0 {
klog.Infof("Server listening on %d.", s.GenericServerRunOptions.SecurePort)
err = http.ListenAndServeTLS(fmt.Sprintf("%s:%d", s.GenericServerRunOptions.BindAddress, s.GenericServerRunOptions.SecurePort), s.GenericServerRunOptions.TlsCertFile, s.GenericServerRunOptions.TlsPrivateKey, container)
}
return err
}
func CreateClientSet(conf *apiserverconfig.Config, stopCh <-chan struct{}) error {
csop := &client.ClientSetOptions{}
csop.SetDevopsOptions(conf.DevopsOptions).
SetKubernetesOptions(conf.KubernetesOptions).
SetMySQLOptions(conf.MySQLOptions)
client.NewClientSetFactory(csop, stopCh)
return nil
}
func WaitForResourceSync(stopCh <-chan struct{}) error {
//apis.AddToScheme(scheme.Scheme)
informerFactory := informers.SharedInformerFactory() informerFactory := informers.SharedInformerFactory()
informerFactory.Rbac().V1().Roles().Lister()
informerFactory.Rbac().V1().RoleBindings().Lister() // resources we have to create informer first
informerFactory.Rbac().V1().ClusterRoles().Lister() k8sGVRs := []schema.GroupVersionResource{
informerFactory.Rbac().V1().ClusterRoleBindings().Lister() {Group: "", Version: "v1", Resource: "namespaces"},
{Group: "", Version: "v1", Resource: "nodes"},
informerFactory.Storage().V1().StorageClasses().Lister() {Group: "", Version: "v1", Resource: "resourcequotas"},
{Group: "", Version: "v1", Resource: "pods"},
informerFactory.Core().V1().Namespaces().Lister() {Group: "", Version: "v1", Resource: "services"},
informerFactory.Core().V1().Nodes().Lister() {Group: "", Version: "v1", Resource: "persistentvolumeclaims"},
informerFactory.Core().V1().ResourceQuotas().Lister() {Group: "", Version: "v1", Resource: "secrets"},
informerFactory.Core().V1().Pods().Lister() {Group: "", Version: "v1", Resource: "configmaps"},
informerFactory.Core().V1().Services().Lister()
informerFactory.Core().V1().PersistentVolumeClaims().Lister() {Group: "rbac.authorization.k8s.io", Version: "v1", Resource: "roles"},
informerFactory.Core().V1().Secrets().Lister() {Group: "rbac.authorization.k8s.io", Version: "v1", Resource: "rolebindings"},
informerFactory.Core().V1().ConfigMaps().Lister() {Group: "rbac.authorization.k8s.io", Version: "v1", Resource: "clusterroles"},
{Group: "rbac.authorization.k8s.io", Version: "v1", Resource: "clusterrolebindings"},
informerFactory.Apps().V1().ControllerRevisions().Lister()
informerFactory.Apps().V1().StatefulSets().Lister() {Group: "apps", Version: "v1", Resource: "deployments"},
informerFactory.Apps().V1().Deployments().Lister() {Group: "apps", Version: "v1", Resource: "daemonsets"},
informerFactory.Apps().V1().DaemonSets().Lister() {Group: "apps", Version: "v1", Resource: "replicasets"},
informerFactory.Apps().V1().ReplicaSets().Lister() {Group: "apps", Version: "v1", Resource: "statefulsets"},
{Group: "apps", Version: "v1", Resource: "controllerrevisions"},
informerFactory.Batch().V1().Jobs().Lister()
informerFactory.Batch().V1beta1().CronJobs().Lister() {Group: "batch", Version: "v1", Resource: "jobs"},
informerFactory.Extensions().V1beta1().Ingresses().Lister() {Group: "batch", Version: "v1beta1", Resource: "cronjobs"},
informerFactory.Autoscaling().V2beta2().HorizontalPodAutoscalers().Lister()
{Group: "extensions", Version: "v1beta1", Resource: "ingresses"},
informerFactory.Start(stopChan)
informerFactory.WaitForCacheSync(stopChan) {Group: "autoscaling", Version: "v2beta2", Resource: "horizontalpodautoscalers"},
}
for _, gvr := range k8sGVRs {
_, err := informerFactory.ForResource(gvr)
if err != nil {
klog.Errorf("cannot create informer for %s", gvr)
return err
}
}
informerFactory.Start(stopCh)
informerFactory.WaitForCacheSync(stopCh)
s2iInformerFactory := informers.S2iSharedInformerFactory() s2iInformerFactory := informers.S2iSharedInformerFactory()
s2iInformerFactory.Devops().V1alpha1().S2iBuilderTemplates().Lister()
s2iInformerFactory.Devops().V1alpha1().S2iRuns().Lister()
s2iInformerFactory.Devops().V1alpha1().S2iBuilders().Lister()
s2iInformerFactory.Start(stopChan) s2iGVRs := []schema.GroupVersionResource{
s2iInformerFactory.WaitForCacheSync(stopChan) {Group: "devops.kubesphere.io", Version: "v1alpha1", Resource: "s2ibuildertemplates"},
{Group: "devops.kubesphere.io", Version: "v1alpha1", Resource: "s2iruns"},
{Group: "devops.kubesphere.io", Version: "v1alpha1", Resource: "s2ibuilders"},
}
for _, gvr := range s2iGVRs {
_, err := s2iInformerFactory.ForResource(gvr)
if err != nil {
return err
}
}
s2iInformerFactory.Start(stopCh)
s2iInformerFactory.WaitForCacheSync(stopCh)
ksInformerFactory := informers.KsSharedInformerFactory() ksInformerFactory := informers.KsSharedInformerFactory()
ksInformerFactory.Tenant().V1alpha1().Workspaces().Lister()
ksInformerFactory.Devops().V1alpha1().S2iBinaries().Lister()
ksInformerFactory.Start(stopChan) ksGVRs := []schema.GroupVersionResource{
ksInformerFactory.WaitForCacheSync(stopChan) {Group: "tenant.kubesphere.io", Version: "v1alpha1", Resource: "workspaces"},
{Group: "devops.kubesphere.io", Version: "v1alpha1", Resource: "s2ibinaries"},
{Group: "servicemesh.kubesphere.io", Version: "v1alpha2", Resource: "strategies"},
{Group: "servicemesh.kubesphere.io", Version: "v1alpha2", Resource: "servicepolicies"},
}
for _, gvr := range ksGVRs {
_, err := ksInformerFactory.ForResource(gvr)
if err != nil {
return err
}
}
ksInformerFactory.Start(stopCh)
ksInformerFactory.WaitForCacheSync(stopCh)
return nil
}
// apply server run options to configuration
func Complete(s *options.ServerRunOptions) error {
// loading configuration file
conf := apiserverconfig.Get()
conf.Apply(&apiserverconfig.Config{
MySQLOptions: s.MySQLOptions,
DevopsOptions: s.DevopsOptions,
SonarQubeOptions: s.SonarQubeOptions,
KubernetesOptions: s.KubernetesOptions,
ServiceMeshOptions: s.ServiceMeshOptions,
MonitoringOptions: s.MonitoringOptions,
})
s = &options.ServerRunOptions{
GenericServerRunOptions: s.GenericServerRunOptions,
KubernetesOptions: conf.KubernetesOptions,
DevopsOptions: conf.DevopsOptions,
SonarQubeOptions: conf.SonarQubeOptions,
ServiceMeshOptions: conf.ServiceMeshOptions,
MySQLOptions: conf.MySQLOptions,
MonitoringOptions: conf.MonitoringOptions,
}
log.Println("resources sync success") return nil
} }
...@@ -29,10 +29,8 @@ import ( ...@@ -29,10 +29,8 @@ import (
"kubesphere.io/kubesphere/pkg/informers" "kubesphere.io/kubesphere/pkg/informers"
"kubesphere.io/kubesphere/pkg/models/iam" "kubesphere.io/kubesphere/pkg/models/iam"
"kubesphere.io/kubesphere/pkg/server" "kubesphere.io/kubesphere/pkg/server"
"kubesphere.io/kubesphere/pkg/signals"
"kubesphere.io/kubesphere/pkg/simple/client/admin_jenkins"
"kubesphere.io/kubesphere/pkg/simple/client/devops_mysql"
"kubesphere.io/kubesphere/pkg/utils/jwtutil" "kubesphere.io/kubesphere/pkg/utils/jwtutil"
"kubesphere.io/kubesphere/pkg/utils/signals"
"log" "log"
"net/http" "net/http"
"time" "time"
...@@ -72,9 +70,6 @@ func Run(s *options.ServerRunOptions) error { ...@@ -72,9 +70,6 @@ func Run(s *options.ServerRunOptions) error {
waitForResourceSync() waitForResourceSync()
initializeAdminJenkins()
initializeDevOpsDatabase()
err = iam.Init(s.AdminEmail, s.AdminPassword, expireTime, s.AuthRateLimit) err = iam.Init(s.AdminEmail, s.AdminPassword, expireTime, s.AuthRateLimit)
jwtutil.Setup(s.JWTSecret) jwtutil.Setup(s.JWTSecret)
...@@ -127,11 +122,3 @@ func waitForResourceSync() { ...@@ -127,11 +122,3 @@ func waitForResourceSync() {
ksInformerFactory.WaitForCacheSync(stopChan) ksInformerFactory.WaitForCacheSync(stopChan)
log.Println("resources sync success") log.Println("resources sync success")
} }
func initializeAdminJenkins() {
admin_jenkins.Client()
}
func initializeDevOpsDatabase() {
devops_mysql.OpenDatabase()
}
...@@ -24,7 +24,6 @@ require ( ...@@ -24,7 +24,6 @@ require (
github.com/coreos/etcd v3.3.13+incompatible // indirect github.com/coreos/etcd v3.3.13+incompatible // indirect
github.com/coreos/go-semver v0.3.0 // indirect github.com/coreos/go-semver v0.3.0 // indirect
github.com/coreos/go-systemd v0.0.0-20190719114852-fd7a80b32e1f // indirect github.com/coreos/go-systemd v0.0.0-20190719114852-fd7a80b32e1f // indirect
github.com/coreos/pkg v0.0.0-20180928190104-399ea9e2e55f // indirect
github.com/deckarep/golang-set v1.7.1 // indirect github.com/deckarep/golang-set v1.7.1 // indirect
github.com/dgrijalva/jwt-go v3.2.0+incompatible github.com/dgrijalva/jwt-go v3.2.0+incompatible
github.com/docker/distribution v2.7.1+incompatible github.com/docker/distribution v2.7.1+incompatible
...@@ -59,8 +58,6 @@ require ( ...@@ -59,8 +58,6 @@ require (
github.com/gocraft/dbr v0.0.0-20180507214907-a0fd650918f6 github.com/gocraft/dbr v0.0.0-20180507214907-a0fd650918f6
github.com/golang/example v0.0.0-20170904185048-46695d81d1fa github.com/golang/example v0.0.0-20170904185048-46695d81d1fa
github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b
github.com/golang/groupcache v0.0.0-20190129154638-5b532d6fd5ef // indirect
github.com/google/btree v1.0.0 // indirect
github.com/google/go-querystring v1.0.0 // indirect github.com/google/go-querystring v1.0.0 // indirect
github.com/google/gofuzz v1.0.0 // indirect github.com/google/gofuzz v1.0.0 // indirect
github.com/google/uuid v1.1.1 github.com/google/uuid v1.1.1
...@@ -68,15 +65,12 @@ require ( ...@@ -68,15 +65,12 @@ require (
github.com/gophercloud/gophercloud v0.3.0 // indirect github.com/gophercloud/gophercloud v0.3.0 // indirect
github.com/gorilla/mux v1.7.1 // indirect github.com/gorilla/mux v1.7.1 // indirect
github.com/gregjones/httpcache v0.0.0-20190212212710-3befbb6ad0cc // indirect github.com/gregjones/httpcache v0.0.0-20190212212710-3befbb6ad0cc // indirect
github.com/grpc-ecosystem/go-grpc-middleware v1.0.0 // indirect
github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 // indirect
github.com/grpc-ecosystem/grpc-gateway v1.9.5 // indirect github.com/grpc-ecosystem/grpc-gateway v1.9.5 // indirect
github.com/hashicorp/go-version v1.2.0 // indirect github.com/hashicorp/go-version v1.2.0 // indirect
github.com/hashicorp/golang-lru v0.5.1 // indirect github.com/hashicorp/golang-lru v0.5.1 // indirect
github.com/igm/sockjs-go v2.0.1+incompatible // indirect github.com/igm/sockjs-go v2.0.1+incompatible // indirect
github.com/imdario/mergo v0.3.7 // indirect github.com/imdario/mergo v0.3.7 // indirect
github.com/inconshreveable/mousetrap v1.0.0 // indirect github.com/inconshreveable/mousetrap v1.0.0 // indirect
github.com/jonboulle/clockwork v0.1.0 // indirect
github.com/json-iterator/go v1.1.6 github.com/json-iterator/go v1.1.6
github.com/kelseyhightower/envconfig v1.4.0 // indirect github.com/kelseyhightower/envconfig v1.4.0 // indirect
github.com/kiali/kiali v0.15.1-0.20190407071308-6b5b818211c3 github.com/kiali/kiali v0.15.1-0.20190407071308-6b5b818211c3
...@@ -114,22 +108,16 @@ require ( ...@@ -114,22 +108,16 @@ require (
github.com/prometheus/procfs v0.0.0-20190507164030-5867b95ac084 // indirect github.com/prometheus/procfs v0.0.0-20190507164030-5867b95ac084 // indirect
github.com/russross/blackfriday v1.5.2 // indirect github.com/russross/blackfriday v1.5.2 // indirect
github.com/satori/go.uuid v1.2.0 // indirect github.com/satori/go.uuid v1.2.0 // indirect
github.com/soheilhy/cmux v0.1.4 // indirect
github.com/sony/sonyflake v0.0.0-20181109022403-6d5bd6181009 github.com/sony/sonyflake v0.0.0-20181109022403-6d5bd6181009
github.com/speps/go-hashids v2.0.0+incompatible github.com/speps/go-hashids v2.0.0+incompatible
github.com/spf13/cobra v0.0.3 github.com/spf13/cobra v0.0.3
github.com/spf13/pflag v1.0.3 github.com/spf13/pflag v1.0.3
github.com/spf13/viper v1.4.0
github.com/stretchr/testify v1.3.0 github.com/stretchr/testify v1.3.0
github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5 // indirect
github.com/xanzy/ssh-agent v0.2.1 // indirect github.com/xanzy/ssh-agent v0.2.1 // indirect
github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2 // indirect
go.etcd.io/bbolt v1.3.3 // indirect go.etcd.io/bbolt v1.3.3 // indirect
go.uber.org/atomic v1.4.0 // indirect
go.uber.org/multierr v1.1.0 // indirect
go.uber.org/zap v1.10.0 // indirect
golang.org/x/net v0.0.0-20190620200207-3b0461eec859 golang.org/x/net v0.0.0-20190620200207-3b0461eec859
golang.org/x/oauth2 v0.0.0-20190402181905-9f3314589c9a // indirect golang.org/x/oauth2 v0.0.0-20190402181905-9f3314589c9a // indirect
golang.org/x/time v0.0.0-20190308202827-9d24e82272b4 // indirect
golang.org/x/tools v0.0.0-20190710153321-831012c29e42 // indirect golang.org/x/tools v0.0.0-20190710153321-831012c29e42 // indirect
google.golang.org/appengine v1.5.0 // indirect google.golang.org/appengine v1.5.0 // indirect
google.golang.org/genproto v0.0.0-20190418145605-e7d98fc518a7 // indirect google.golang.org/genproto v0.0.0-20190418145605-e7d98fc518a7 // indirect
...@@ -145,15 +133,15 @@ require ( ...@@ -145,15 +133,15 @@ require (
gotest.tools v2.2.0+incompatible // indirect gotest.tools v2.2.0+incompatible // indirect
k8s.io/api v0.0.0-20181213150558-05914d821849 k8s.io/api v0.0.0-20181213150558-05914d821849
k8s.io/apiextensions-apiserver v0.0.0-20181213153335-0fe22c71c476 k8s.io/apiextensions-apiserver v0.0.0-20181213153335-0fe22c71c476
k8s.io/apimachinery v0.0.0-20190221213512-86fb29eff628 k8s.io/apimachinery v0.0.0-20190831074630-461753078381
k8s.io/apiserver v0.0.0-20190507070644-e9c02aff496d k8s.io/apiserver v0.0.0-20190507070644-e9c02aff496d
k8s.io/client-go v0.0.0-20181213151034-8d9ed539ba31 k8s.io/client-go v0.0.0-20190831074946-3fe2abece89e
k8s.io/code-generator v0.0.0-20181117043124-c2090bec4d9b k8s.io/code-generator v0.0.0-20181117043124-c2090bec4d9b
k8s.io/component-base v0.0.0-20190831075413-37a093468564
k8s.io/gengo v0.0.0-20190327210449-e17681d19d3a // indirect k8s.io/gengo v0.0.0-20190327210449-e17681d19d3a // indirect
k8s.io/klog v0.3.1 k8s.io/klog v0.4.0
k8s.io/kube-openapi v0.0.0-20181109181836-c59034cc13d5 k8s.io/kube-openapi v0.0.0-20181109181836-c59034cc13d5
k8s.io/kubernetes v1.13.6 k8s.io/kubernetes v1.13.6
k8s.io/utils v0.0.0-20190506122338-8fab8cb257d5 // indirect
sigs.k8s.io/application v0.0.0-20190404151855-67ae7f915d4e sigs.k8s.io/application v0.0.0-20190404151855-67ae7f915d4e
sigs.k8s.io/controller-runtime v0.1.10 sigs.k8s.io/controller-runtime v0.1.10
sigs.k8s.io/controller-tools v0.1.12 sigs.k8s.io/controller-tools v0.1.12
...@@ -188,10 +176,12 @@ replace ( ...@@ -188,10 +176,12 @@ replace (
github.com/anmitsu/go-shlex => github.com/anmitsu/go-shlex v0.0.0-20161002113705-648efa622239 github.com/anmitsu/go-shlex => github.com/anmitsu/go-shlex v0.0.0-20161002113705-648efa622239
github.com/apache/thrift => github.com/apache/thrift v0.12.0 github.com/apache/thrift => github.com/apache/thrift v0.12.0
github.com/appscode/jsonpatch => github.com/appscode/jsonpatch v0.0.0-20190108182946-7c0e3b262f30 github.com/appscode/jsonpatch => github.com/appscode/jsonpatch v0.0.0-20190108182946-7c0e3b262f30
github.com/armon/consul-api => github.com/armon/consul-api v0.0.0-20180202201655-eb2c6b5be1b6
github.com/asaskevich/govalidator => github.com/asaskevich/govalidator v0.0.0-20180315120708-ccb8e960c48f github.com/asaskevich/govalidator => github.com/asaskevich/govalidator v0.0.0-20180315120708-ccb8e960c48f
github.com/aws/aws-sdk-go => github.com/aws/aws-sdk-go v1.22.2 github.com/aws/aws-sdk-go => github.com/aws/aws-sdk-go v1.22.2
github.com/beevik/etree => github.com/beevik/etree v1.1.0 github.com/beevik/etree => github.com/beevik/etree v1.1.0
github.com/beorn7/perks => github.com/beorn7/perks v1.0.0 github.com/beorn7/perks => github.com/beorn7/perks v1.0.0
github.com/blang/semver => github.com/blang/semver v3.5.0+incompatible
github.com/cenkalti/backoff => github.com/cenkalti/backoff v2.2.1+incompatible github.com/cenkalti/backoff => github.com/cenkalti/backoff v2.2.1+incompatible
github.com/census-instrumentation/opencensus-proto => github.com/census-instrumentation/opencensus-proto v0.2.0 github.com/census-instrumentation/opencensus-proto => github.com/census-instrumentation/opencensus-proto v0.2.0
github.com/cheekybits/genny => github.com/cheekybits/genny v1.0.0 github.com/cheekybits/genny => github.com/cheekybits/genny v1.0.0
...@@ -270,6 +260,7 @@ replace ( ...@@ -270,6 +260,7 @@ replace (
github.com/hashicorp/go-syslog => github.com/hashicorp/go-syslog v1.0.0 github.com/hashicorp/go-syslog => github.com/hashicorp/go-syslog v1.0.0
github.com/hashicorp/go-version => github.com/hashicorp/go-version v1.2.0 github.com/hashicorp/go-version => github.com/hashicorp/go-version v1.2.0
github.com/hashicorp/golang-lru => github.com/hashicorp/golang-lru v0.5.1 github.com/hashicorp/golang-lru => github.com/hashicorp/golang-lru v0.5.1
github.com/hashicorp/hcl => github.com/hashicorp/hcl v1.0.0
github.com/hpcloud/tail => github.com/hpcloud/tail v1.0.0 github.com/hpcloud/tail => github.com/hpcloud/tail v1.0.0
github.com/igm/sockjs-go => github.com/igm/sockjs-go v2.0.1+incompatible github.com/igm/sockjs-go => github.com/igm/sockjs-go v2.0.1+incompatible
github.com/imdario/mergo => github.com/imdario/mergo v0.3.7 github.com/imdario/mergo => github.com/imdario/mergo v0.3.7
...@@ -298,6 +289,7 @@ replace ( ...@@ -298,6 +289,7 @@ replace (
github.com/leodido/go-urn => github.com/leodido/go-urn v1.1.0 github.com/leodido/go-urn => github.com/leodido/go-urn v1.1.0
github.com/lib/pq => github.com/lib/pq v1.2.0 github.com/lib/pq => github.com/lib/pq v1.2.0
github.com/lucas-clemente/quic-go => github.com/lucas-clemente/quic-go v0.11.1 github.com/lucas-clemente/quic-go => github.com/lucas-clemente/quic-go v0.11.1
github.com/magiconair/properties => github.com/magiconair/properties v1.8.0
github.com/mailru/easyjson => github.com/mailru/easyjson v0.0.0-20180823135443-60711f1a8329 github.com/mailru/easyjson => github.com/mailru/easyjson v0.0.0-20180823135443-60711f1a8329
github.com/marten-seemann/qtls => github.com/marten-seemann/qtls v0.2.3 github.com/marten-seemann/qtls => github.com/marten-seemann/qtls v0.2.3
github.com/mattn/go-sqlite3 => github.com/mattn/go-sqlite3 v1.11.0 github.com/mattn/go-sqlite3 => github.com/mattn/go-sqlite3 v1.11.0
...@@ -306,6 +298,7 @@ replace ( ...@@ -306,6 +298,7 @@ replace (
github.com/mholt/certmagic => github.com/mholt/certmagic v0.5.1 github.com/mholt/certmagic => github.com/mholt/certmagic v0.5.1
github.com/miekg/dns => github.com/miekg/dns v1.1.9 github.com/miekg/dns => github.com/miekg/dns v1.1.9
github.com/mitchellh/go-homedir => github.com/mitchellh/go-homedir v1.1.0 github.com/mitchellh/go-homedir => github.com/mitchellh/go-homedir v1.1.0
github.com/mitchellh/mapstructure => github.com/mitchellh/mapstructure v1.1.2
github.com/modern-go/concurrent => github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd github.com/modern-go/concurrent => github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd
github.com/modern-go/reflect2 => github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742 github.com/modern-go/reflect2 => github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742
github.com/morikuni/aec => github.com/morikuni/aec v0.0.0-20170113033406-39771216ff4c github.com/morikuni/aec => github.com/morikuni/aec v0.0.0-20170113033406-39771216ff4c
...@@ -320,6 +313,7 @@ replace ( ...@@ -320,6 +313,7 @@ replace (
github.com/openzipkin/zipkin-go => github.com/openzipkin/zipkin-go v0.1.6 github.com/openzipkin/zipkin-go => github.com/openzipkin/zipkin-go v0.1.6
github.com/pborman/uuid => github.com/pborman/uuid v0.0.0-20180906182336-adf5a7427709 github.com/pborman/uuid => github.com/pborman/uuid v0.0.0-20180906182336-adf5a7427709
github.com/pelletier/go-buffruneio => github.com/pelletier/go-buffruneio v0.2.0 github.com/pelletier/go-buffruneio => github.com/pelletier/go-buffruneio v0.2.0
github.com/pelletier/go-toml => github.com/pelletier/go-toml v1.2.0
github.com/peterbourgon/diskv => github.com/peterbourgon/diskv v2.0.1+incompatible github.com/peterbourgon/diskv => github.com/peterbourgon/diskv v2.0.1+incompatible
github.com/pierrec/lz4 => github.com/pierrec/lz4 v2.0.5+incompatible github.com/pierrec/lz4 => github.com/pierrec/lz4 v2.0.5+incompatible
github.com/pkg/errors => github.com/pkg/errors v0.8.1 github.com/pkg/errors => github.com/pkg/errors v0.8.1
...@@ -343,14 +337,19 @@ replace ( ...@@ -343,14 +337,19 @@ replace (
github.com/sony/sonyflake => github.com/sony/sonyflake v0.0.0-20181109022403-6d5bd6181009 github.com/sony/sonyflake => github.com/sony/sonyflake v0.0.0-20181109022403-6d5bd6181009
github.com/speps/go-hashids => github.com/speps/go-hashids v2.0.0+incompatible github.com/speps/go-hashids => github.com/speps/go-hashids v2.0.0+incompatible
github.com/spf13/afero => github.com/spf13/afero v1.2.2 github.com/spf13/afero => github.com/spf13/afero v1.2.2
github.com/spf13/cast => github.com/spf13/cast v1.3.0
github.com/spf13/cobra => github.com/spf13/cobra v0.0.3 github.com/spf13/cobra => github.com/spf13/cobra v0.0.3
github.com/spf13/jwalterweatherman => github.com/spf13/jwalterweatherman v1.0.0
github.com/spf13/pflag => github.com/spf13/pflag v1.0.3 github.com/spf13/pflag => github.com/spf13/pflag v1.0.3
github.com/spf13/viper => github.com/spf13/viper v1.4.0
github.com/src-d/gcfg => github.com/src-d/gcfg v1.4.0 github.com/src-d/gcfg => github.com/src-d/gcfg v1.4.0
github.com/stretchr/objx => github.com/stretchr/objx v0.1.1 github.com/stretchr/objx => github.com/stretchr/objx v0.1.1
github.com/stretchr/testify => github.com/stretchr/testify v1.3.0 github.com/stretchr/testify => github.com/stretchr/testify v1.3.0
github.com/tmc/grpc-websocket-proxy => github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5 github.com/tmc/grpc-websocket-proxy => github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5
github.com/ugorji/go => github.com/ugorji/go v1.1.4
github.com/xanzy/ssh-agent => github.com/xanzy/ssh-agent v0.2.1 github.com/xanzy/ssh-agent => github.com/xanzy/ssh-agent v0.2.1
github.com/xiang90/probing => github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2 github.com/xiang90/probing => github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2
github.com/xordataexchange/crypt => github.com/xordataexchange/crypt v0.0.3-0.20170626215501-b2862e3d0a77
go.etcd.io/bbolt => go.etcd.io/bbolt v1.3.3 go.etcd.io/bbolt => go.etcd.io/bbolt v1.3.3
go.opencensus.io => go.opencensus.io v0.20.2 go.opencensus.io => go.opencensus.io v0.20.2
go.uber.org/atomic => go.uber.org/atomic v1.4.0 go.uber.org/atomic => go.uber.org/atomic v1.4.0
...@@ -396,8 +395,9 @@ replace ( ...@@ -396,8 +395,9 @@ replace (
k8s.io/apiserver => k8s.io/apiserver v0.0.0-20190507070644-e9c02aff496d k8s.io/apiserver => k8s.io/apiserver v0.0.0-20190507070644-e9c02aff496d
k8s.io/client-go => k8s.io/client-go v0.0.0-20181213151034-8d9ed539ba31 k8s.io/client-go => k8s.io/client-go v0.0.0-20181213151034-8d9ed539ba31
k8s.io/code-generator => k8s.io/code-generator v0.0.0-20181117043124-c2090bec4d9b k8s.io/code-generator => k8s.io/code-generator v0.0.0-20181117043124-c2090bec4d9b
k8s.io/component-base => k8s.io/component-base v0.0.0-20190831075413-37a093468564
k8s.io/gengo => k8s.io/gengo v0.0.0-20190327210449-e17681d19d3a k8s.io/gengo => k8s.io/gengo v0.0.0-20190327210449-e17681d19d3a
k8s.io/klog => k8s.io/klog v0.3.1 k8s.io/klog => k8s.io/klog v0.4.0
k8s.io/kube-openapi => k8s.io/kube-openapi v0.0.0-20181109181836-c59034cc13d5 k8s.io/kube-openapi => k8s.io/kube-openapi v0.0.0-20181109181836-c59034cc13d5
k8s.io/kubernetes => k8s.io/kubernetes v1.13.6 k8s.io/kubernetes => k8s.io/kubernetes v1.13.6
k8s.io/utils => k8s.io/utils v0.0.0-20190506122338-8fab8cb257d5 k8s.io/utils => k8s.io/utils v0.0.0-20190506122338-8fab8cb257d5
......
...@@ -47,6 +47,7 @@ github.com/anmitsu/go-shlex v0.0.0-20161002113705-648efa622239/go.mod h1:2FmKhYU ...@@ -47,6 +47,7 @@ github.com/anmitsu/go-shlex v0.0.0-20161002113705-648efa622239/go.mod h1:2FmKhYU
github.com/apache/thrift v0.12.0/go.mod h1:cp2SuWMxlEZw2r+iP2GNCdIi4C1qmUzdZFSVb+bacwQ= github.com/apache/thrift v0.12.0/go.mod h1:cp2SuWMxlEZw2r+iP2GNCdIi4C1qmUzdZFSVb+bacwQ=
github.com/appscode/jsonpatch v0.0.0-20190108182946-7c0e3b262f30 h1:Kn3rqvbUFqSepE2OqVu0Pn1CbDw9IuMlONapol0zuwk= github.com/appscode/jsonpatch v0.0.0-20190108182946-7c0e3b262f30 h1:Kn3rqvbUFqSepE2OqVu0Pn1CbDw9IuMlONapol0zuwk=
github.com/appscode/jsonpatch v0.0.0-20190108182946-7c0e3b262f30/go.mod h1:4AJxUpXUhv4N+ziTvIcWWXgeorXpxPZOfk9HdEVr96M= github.com/appscode/jsonpatch v0.0.0-20190108182946-7c0e3b262f30/go.mod h1:4AJxUpXUhv4N+ziTvIcWWXgeorXpxPZOfk9HdEVr96M=
github.com/armon/consul-api v0.0.0-20180202201655-eb2c6b5be1b6/go.mod h1:grANhF5doyWs3UAsr3K4I6qtAmlQcZDesFNEHPZAzj8=
github.com/asaskevich/govalidator v0.0.0-20180315120708-ccb8e960c48f h1:y2hSFdXeA1y5z5f0vfNO0Dg5qVY036qzlz3Pds0B92o= github.com/asaskevich/govalidator v0.0.0-20180315120708-ccb8e960c48f h1:y2hSFdXeA1y5z5f0vfNO0Dg5qVY036qzlz3Pds0B92o=
github.com/asaskevich/govalidator v0.0.0-20180315120708-ccb8e960c48f/go.mod h1:lB+ZfQJz7igIIfQNfa7Ml4HSf2uFQQRzpGGRXenZAgY= github.com/asaskevich/govalidator v0.0.0-20180315120708-ccb8e960c48f/go.mod h1:lB+ZfQJz7igIIfQNfa7Ml4HSf2uFQQRzpGGRXenZAgY=
github.com/aws/aws-sdk-go v1.22.2 h1:uYP58k2Cd9y1qBy8CxTe5ADmdi4kANm8Ul8ch3kkIcQ= github.com/aws/aws-sdk-go v1.22.2 h1:uYP58k2Cd9y1qBy8CxTe5ADmdi4kANm8Ul8ch3kkIcQ=
...@@ -55,6 +56,7 @@ github.com/beevik/etree v1.1.0 h1:T0xke/WvNtMoCqgzPhkX2r4rjY3GDZFi+FjpRZY2Jbs= ...@@ -55,6 +56,7 @@ github.com/beevik/etree v1.1.0 h1:T0xke/WvNtMoCqgzPhkX2r4rjY3GDZFi+FjpRZY2Jbs=
github.com/beevik/etree v1.1.0/go.mod h1:r8Aw8JqVegEf0w2fDnATrX9VpkMcyFeM0FhwO62wh+A= github.com/beevik/etree v1.1.0/go.mod h1:r8Aw8JqVegEf0w2fDnATrX9VpkMcyFeM0FhwO62wh+A=
github.com/beorn7/perks v1.0.0 h1:HWo1m869IqiPhD389kmkxeTalrjNbbJTC8LXupb+sl0= github.com/beorn7/perks v1.0.0 h1:HWo1m869IqiPhD389kmkxeTalrjNbbJTC8LXupb+sl0=
github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8= github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8=
github.com/blang/semver v3.5.0+incompatible/go.mod h1:kRBLl5iJ+tD4TcOOxsy/0fnwebNt5EWlYSAyrTnjyyk=
github.com/cenkalti/backoff v2.2.1+incompatible h1:tNowT99t7UNflLxfYYSlKYsBpXdEet03Pg2g16Swow4= github.com/cenkalti/backoff v2.2.1+incompatible h1:tNowT99t7UNflLxfYYSlKYsBpXdEet03Pg2g16Swow4=
github.com/cenkalti/backoff v2.2.1+incompatible/go.mod h1:90ReRw6GdpyfrHakVjL/QHaoyV4aDUVVkXQJJJ3NXXM= github.com/cenkalti/backoff v2.2.1+incompatible/go.mod h1:90ReRw6GdpyfrHakVjL/QHaoyV4aDUVVkXQJJJ3NXXM=
github.com/census-instrumentation/opencensus-proto v0.2.0 h1:LzQXZOgg4CQfE6bFvXGM30YZL1WW/M337pXml+GrcZ4= github.com/census-instrumentation/opencensus-proto v0.2.0 h1:LzQXZOgg4CQfE6bFvXGM30YZL1WW/M337pXml+GrcZ4=
...@@ -202,6 +204,8 @@ github.com/hashicorp/go-version v1.2.0 h1:3vNe/fWF5CBgRIguda1meWhsZHy3m8gCJ5wx+d ...@@ -202,6 +204,8 @@ github.com/hashicorp/go-version v1.2.0 h1:3vNe/fWF5CBgRIguda1meWhsZHy3m8gCJ5wx+d
github.com/hashicorp/go-version v1.2.0/go.mod h1:fltr4n8CU8Ke44wwGCBoEymUuxUHl09ZGVZPK5anwXA= github.com/hashicorp/go-version v1.2.0/go.mod h1:fltr4n8CU8Ke44wwGCBoEymUuxUHl09ZGVZPK5anwXA=
github.com/hashicorp/golang-lru v0.5.1 h1:0hERBMJE1eitiLkihrMvRVBYAkpHzc/J3QdDN+dAcgU= github.com/hashicorp/golang-lru v0.5.1 h1:0hERBMJE1eitiLkihrMvRVBYAkpHzc/J3QdDN+dAcgU=
github.com/hashicorp/golang-lru v0.5.1/go.mod h1:/m3WP610KZHVQ1SGc6re/UDhFvYD7pJ4Ao+sR/qLZy8= github.com/hashicorp/golang-lru v0.5.1/go.mod h1:/m3WP610KZHVQ1SGc6re/UDhFvYD7pJ4Ao+sR/qLZy8=
github.com/hashicorp/hcl v1.0.0 h1:0Anlzjpi4vEasTeNFn2mLJgTSwt0+6sfsiTG8qcWGx4=
github.com/hashicorp/hcl v1.0.0/go.mod h1:E5yfLk+7swimpb2L/Alb/PJmXilQ/rhwaUYs4T20WEQ=
github.com/hpcloud/tail v1.0.0 h1:nfCOvKYfkgYP8hkirhJocXT2+zOD8yUNjXaWfTlyFKI= github.com/hpcloud/tail v1.0.0 h1:nfCOvKYfkgYP8hkirhJocXT2+zOD8yUNjXaWfTlyFKI=
github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU= github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU=
github.com/igm/sockjs-go v2.0.1+incompatible h1:iyv0auU1Xh1KC8N+GIiLPa3zZXwRsfRZTIzo09UzeUU= github.com/igm/sockjs-go v2.0.1+incompatible h1:iyv0auU1Xh1KC8N+GIiLPa3zZXwRsfRZTIzo09UzeUU=
...@@ -254,6 +258,8 @@ github.com/lib/pq v1.2.0 h1:LXpIM/LZ5xGFhOpXAQUIMM1HdyqzVYM13zNdjCEEcA0= ...@@ -254,6 +258,8 @@ github.com/lib/pq v1.2.0 h1:LXpIM/LZ5xGFhOpXAQUIMM1HdyqzVYM13zNdjCEEcA0=
github.com/lib/pq v1.2.0/go.mod h1:5WUZQaWbwv1U+lTReE5YruASi9Al49XbQIvNi/34Woo= github.com/lib/pq v1.2.0/go.mod h1:5WUZQaWbwv1U+lTReE5YruASi9Al49XbQIvNi/34Woo=
github.com/lucas-clemente/quic-go v0.11.1 h1:zasajC848Dqq/+WqfqBCkmPw+YHNe1MBts/z7y7nXf4= github.com/lucas-clemente/quic-go v0.11.1 h1:zasajC848Dqq/+WqfqBCkmPw+YHNe1MBts/z7y7nXf4=
github.com/lucas-clemente/quic-go v0.11.1/go.mod h1:PpMmPfPKO9nKJ/psF49ESTAGQSdfXxlg1otPbEB2nOw= github.com/lucas-clemente/quic-go v0.11.1/go.mod h1:PpMmPfPKO9nKJ/psF49ESTAGQSdfXxlg1otPbEB2nOw=
github.com/magiconair/properties v1.8.0 h1:LLgXmsheXeRoUOBOjtwPQCWIYqM/LU1ayDtDePerRcY=
github.com/magiconair/properties v1.8.0/go.mod h1:PppfXfuXeibc/6YijjN8zIbojt8czPbwD3XqdrwzmxQ=
github.com/mailru/easyjson v0.0.0-20180823135443-60711f1a8329 h1:2gxZ0XQIU/5z3Z3bUBu+FXuk2pFbkN6tcwi/pjyaDic= github.com/mailru/easyjson v0.0.0-20180823135443-60711f1a8329 h1:2gxZ0XQIU/5z3Z3bUBu+FXuk2pFbkN6tcwi/pjyaDic=
github.com/mailru/easyjson v0.0.0-20180823135443-60711f1a8329/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= github.com/mailru/easyjson v0.0.0-20180823135443-60711f1a8329/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc=
github.com/marten-seemann/qtls v0.2.3 h1:0yWJ43C62LsZt08vuQJDK1uC1czUc3FJeCLPoNAI4vA= github.com/marten-seemann/qtls v0.2.3 h1:0yWJ43C62LsZt08vuQJDK1uC1czUc3FJeCLPoNAI4vA=
...@@ -270,6 +276,8 @@ github.com/miekg/dns v1.1.9 h1:OIdC9wT96RzuZMf2PfKRhFgsStHUUBZLM/lo1LqiM9E= ...@@ -270,6 +276,8 @@ github.com/miekg/dns v1.1.9 h1:OIdC9wT96RzuZMf2PfKRhFgsStHUUBZLM/lo1LqiM9E=
github.com/miekg/dns v1.1.9/go.mod h1:W1PPwlIAgtquWBMBEV9nkV9Cazfe8ScdGz/Lj7v3Nrg= github.com/miekg/dns v1.1.9/go.mod h1:W1PPwlIAgtquWBMBEV9nkV9Cazfe8ScdGz/Lj7v3Nrg=
github.com/mitchellh/go-homedir v1.1.0 h1:lukF9ziXFxDFPkA1vsr5zpc1XuPDn/wFntq5mG+4E0Y= github.com/mitchellh/go-homedir v1.1.0 h1:lukF9ziXFxDFPkA1vsr5zpc1XuPDn/wFntq5mG+4E0Y=
github.com/mitchellh/go-homedir v1.1.0/go.mod h1:SfyaCUpYCn1Vlf4IUYiD9fPX4A5wJrkLzIz1N1q0pr0= github.com/mitchellh/go-homedir v1.1.0/go.mod h1:SfyaCUpYCn1Vlf4IUYiD9fPX4A5wJrkLzIz1N1q0pr0=
github.com/mitchellh/mapstructure v1.1.2 h1:fmNYVwqnSfB9mZU6OS2O6GsXM+wcskZDuKQzvN1EDeE=
github.com/mitchellh/mapstructure v1.1.2/go.mod h1:FVVH3fgwuzCH5S8UJGiWEs2h04kUh9fWfEaFds41c1Y=
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd h1:TRLaZ9cD/w8PVh93nsPXa1VrQ6jlwL5oN8l14QlcNfg= github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd h1:TRLaZ9cD/w8PVh93nsPXa1VrQ6jlwL5oN8l14QlcNfg=
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q=
github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742 h1:Esafd1046DLDQ0W1YjYsBW+p8U2u7vzgW2SQVmlNazg= github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742 h1:Esafd1046DLDQ0W1YjYsBW+p8U2u7vzgW2SQVmlNazg=
...@@ -296,6 +304,8 @@ github.com/pborman/uuid v0.0.0-20180906182336-adf5a7427709 h1:zNBQb37RGLmJybyMcs ...@@ -296,6 +304,8 @@ github.com/pborman/uuid v0.0.0-20180906182336-adf5a7427709 h1:zNBQb37RGLmJybyMcs
github.com/pborman/uuid v0.0.0-20180906182336-adf5a7427709/go.mod h1:VyrYX9gd7irzKovcSS6BIIEwPRkP2Wm2m9ufcdFSJ34= github.com/pborman/uuid v0.0.0-20180906182336-adf5a7427709/go.mod h1:VyrYX9gd7irzKovcSS6BIIEwPRkP2Wm2m9ufcdFSJ34=
github.com/pelletier/go-buffruneio v0.2.0 h1:U4t4R6YkofJ5xHm3dJzuRpPZ0mr5MMCoAWooScCR7aA= github.com/pelletier/go-buffruneio v0.2.0 h1:U4t4R6YkofJ5xHm3dJzuRpPZ0mr5MMCoAWooScCR7aA=
github.com/pelletier/go-buffruneio v0.2.0/go.mod h1:JkE26KsDizTr40EUHkXVtNPvgGtbSNq5BcowyYOWdKo= github.com/pelletier/go-buffruneio v0.2.0/go.mod h1:JkE26KsDizTr40EUHkXVtNPvgGtbSNq5BcowyYOWdKo=
github.com/pelletier/go-toml v1.2.0 h1:T5zMGML61Wp+FlcbWjRDT7yAxhJNAiPPLOFECq181zc=
github.com/pelletier/go-toml v1.2.0/go.mod h1:5z9KED0ma1S8pY6P1sdut58dfprrGBbd/94hg7ilaic=
github.com/peterbourgon/diskv v2.0.1+incompatible h1:UBdAOUP5p4RWqPBg048CAvpKN+vxiaj6gdUUzhl4XmI= github.com/peterbourgon/diskv v2.0.1+incompatible h1:UBdAOUP5p4RWqPBg048CAvpKN+vxiaj6gdUUzhl4XmI=
github.com/peterbourgon/diskv v2.0.1+incompatible/go.mod h1:uqqh8zWWbv1HBMNONnaR/tNboyR3/BZd58JJSHlUSCU= github.com/peterbourgon/diskv v2.0.1+incompatible/go.mod h1:uqqh8zWWbv1HBMNONnaR/tNboyR3/BZd58JJSHlUSCU=
github.com/pierrec/lz4 v2.0.5+incompatible/go.mod h1:pdkljMzZIN41W+lC3N2tnIh5sFi+IEE17M5jbnwPHcY= github.com/pierrec/lz4 v2.0.5+incompatible/go.mod h1:pdkljMzZIN41W+lC3N2tnIh5sFi+IEE17M5jbnwPHcY=
...@@ -338,10 +348,16 @@ github.com/speps/go-hashids v2.0.0+incompatible h1:kSfxGfESueJKTx0mpER9Y/1XHl+FV ...@@ -338,10 +348,16 @@ github.com/speps/go-hashids v2.0.0+incompatible h1:kSfxGfESueJKTx0mpER9Y/1XHl+FV
github.com/speps/go-hashids v2.0.0+incompatible/go.mod h1:P7hqPzMdnZOfyIk+xrlG1QaSMw+gCBdHKsBDnhpaZvc= github.com/speps/go-hashids v2.0.0+incompatible/go.mod h1:P7hqPzMdnZOfyIk+xrlG1QaSMw+gCBdHKsBDnhpaZvc=
github.com/spf13/afero v1.2.2 h1:5jhuqJyZCZf2JRofRvN/nIFgIWNzPa3/Vz8mYylgbWc= github.com/spf13/afero v1.2.2 h1:5jhuqJyZCZf2JRofRvN/nIFgIWNzPa3/Vz8mYylgbWc=
github.com/spf13/afero v1.2.2/go.mod h1:9ZxEEn6pIJ8Rxe320qSDBk6AsU0r9pR7Q4OcevTdifk= github.com/spf13/afero v1.2.2/go.mod h1:9ZxEEn6pIJ8Rxe320qSDBk6AsU0r9pR7Q4OcevTdifk=
github.com/spf13/cast v1.3.0 h1:oget//CVOEoFewqQxwr0Ej5yjygnqGkvggSE/gB35Q8=
github.com/spf13/cast v1.3.0/go.mod h1:Qx5cxh0v+4UWYiBimWS+eyWzqEqokIECu5etghLkUJE=
github.com/spf13/cobra v0.0.3 h1:ZlrZ4XsMRm04Fr5pSFxBgfND2EBVa1nLpiy1stUsX/8= github.com/spf13/cobra v0.0.3 h1:ZlrZ4XsMRm04Fr5pSFxBgfND2EBVa1nLpiy1stUsX/8=
github.com/spf13/cobra v0.0.3/go.mod h1:1l0Ry5zgKvJasoi3XT1TypsSe7PqH0Sj9dhYf7v3XqQ= github.com/spf13/cobra v0.0.3/go.mod h1:1l0Ry5zgKvJasoi3XT1TypsSe7PqH0Sj9dhYf7v3XqQ=
github.com/spf13/jwalterweatherman v1.0.0 h1:XHEdyB+EcvlqZamSM4ZOMGlc93t6AcsBEu9Gc1vn7yk=
github.com/spf13/jwalterweatherman v1.0.0/go.mod h1:cQK4TGJAtQXfYWX+Ddv3mKDzgVb68N+wFjFa4jdeBTo=
github.com/spf13/pflag v1.0.3 h1:zPAT6CGy6wXeQ7NtTnaTerfKOsV6V6F8agHXFiazDkg= github.com/spf13/pflag v1.0.3 h1:zPAT6CGy6wXeQ7NtTnaTerfKOsV6V6F8agHXFiazDkg=
github.com/spf13/pflag v1.0.3/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4= github.com/spf13/pflag v1.0.3/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4=
github.com/spf13/viper v1.4.0 h1:yXHLWeravcrgGyFSyCgdYpXQ9dR9c/WED3pg1RhxqEU=
github.com/spf13/viper v1.4.0/go.mod h1:PTJ7Z/lr49W6bUbkmS1V3by4uWynFiR9p7+dSq/yZzE=
github.com/src-d/gcfg v1.4.0 h1:xXbNR5AlLSA315x2UO+fTSSAXCDf+Ar38/6oyGbDKQ4= github.com/src-d/gcfg v1.4.0 h1:xXbNR5AlLSA315x2UO+fTSSAXCDf+Ar38/6oyGbDKQ4=
github.com/src-d/gcfg v1.4.0/go.mod h1:p/UMsR43ujA89BJY9duynAwIpvqEujIH/jFlfL7jWoI= github.com/src-d/gcfg v1.4.0/go.mod h1:p/UMsR43ujA89BJY9duynAwIpvqEujIH/jFlfL7jWoI=
github.com/stretchr/objx v0.1.1 h1:2vfRuCMp5sSVIDSqO8oNnWJq7mPa6KVP3iPIwFBuy8A= github.com/stretchr/objx v0.1.1 h1:2vfRuCMp5sSVIDSqO8oNnWJq7mPa6KVP3iPIwFBuy8A=
...@@ -350,10 +366,12 @@ github.com/stretchr/testify v1.3.0 h1:TivCn/peBQ7UY8ooIcPgZFpTNSz0Q2U6UrFlUfqbe0 ...@@ -350,10 +366,12 @@ github.com/stretchr/testify v1.3.0 h1:TivCn/peBQ7UY8ooIcPgZFpTNSz0Q2U6UrFlUfqbe0
github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5 h1:LnC5Kc/wtumK+WB441p7ynQJzVuNRJiqddSIE3IlSEQ= github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5 h1:LnC5Kc/wtumK+WB441p7ynQJzVuNRJiqddSIE3IlSEQ=
github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5/go.mod h1:ncp9v5uamzpCO7NfCPTXjqaC+bZgJeR0sMTm6dMHP7U= github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5/go.mod h1:ncp9v5uamzpCO7NfCPTXjqaC+bZgJeR0sMTm6dMHP7U=
github.com/ugorji/go v1.1.4/go.mod h1:uQMGLiO92mf5W77hV/PUCpI3pbzQx3CRekS0kk+RGrc=
github.com/xanzy/ssh-agent v0.2.1 h1:TCbipTQL2JiiCprBWx9frJ2eJlCYT00NmctrHxVAr70= github.com/xanzy/ssh-agent v0.2.1 h1:TCbipTQL2JiiCprBWx9frJ2eJlCYT00NmctrHxVAr70=
github.com/xanzy/ssh-agent v0.2.1/go.mod h1:mLlQY/MoOhWBj+gOGMQkOeiEvkx+8pJSI+0Bx9h2kr4= github.com/xanzy/ssh-agent v0.2.1/go.mod h1:mLlQY/MoOhWBj+gOGMQkOeiEvkx+8pJSI+0Bx9h2kr4=
github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2 h1:eY9dn8+vbi4tKz5Qo6v2eYzo7kUS51QINcR5jNpbZS8= github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2 h1:eY9dn8+vbi4tKz5Qo6v2eYzo7kUS51QINcR5jNpbZS8=
github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2/go.mod h1:UETIi67q53MR2AWcXfiuqkDkRtnGDLqkBTpCHuJHxtU= github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2/go.mod h1:UETIi67q53MR2AWcXfiuqkDkRtnGDLqkBTpCHuJHxtU=
github.com/xordataexchange/crypt v0.0.3-0.20170626215501-b2862e3d0a77/go.mod h1:aYKd//L2LvnjZzWKhF00oedf4jCCReLcmhLdhm1A27Q=
go.etcd.io/bbolt v1.3.3 h1:MUGmc65QhB3pIlaQ5bB4LwqSj6GIonVJXpZiaKNyaKk= go.etcd.io/bbolt v1.3.3 h1:MUGmc65QhB3pIlaQ5bB4LwqSj6GIonVJXpZiaKNyaKk=
go.etcd.io/bbolt v1.3.3/go.mod h1:IbVyRI1SCnLcuJnV2u8VeU0CEYM7e686BmAb1XKL+uU= go.etcd.io/bbolt v1.3.3/go.mod h1:IbVyRI1SCnLcuJnV2u8VeU0CEYM7e686BmAb1XKL+uU=
go.opencensus.io v0.20.2 h1:NAfh7zF0/3/HqtMvJNZ/RFrSlCE6ZTlHmKfhL/Dm1Jk= go.opencensus.io v0.20.2 h1:NAfh7zF0/3/HqtMvJNZ/RFrSlCE6ZTlHmKfhL/Dm1Jk=
...@@ -440,10 +458,12 @@ k8s.io/client-go v0.0.0-20181213151034-8d9ed539ba31 h1:OH3z6khCtxnJBAc0C5CMYWLl1 ...@@ -440,10 +458,12 @@ k8s.io/client-go v0.0.0-20181213151034-8d9ed539ba31 h1:OH3z6khCtxnJBAc0C5CMYWLl1
k8s.io/client-go v0.0.0-20181213151034-8d9ed539ba31/go.mod h1:7vJpHMYJwNQCWgzmNV+VYUl1zCObLyodBc8nIyt8L5s= k8s.io/client-go v0.0.0-20181213151034-8d9ed539ba31/go.mod h1:7vJpHMYJwNQCWgzmNV+VYUl1zCObLyodBc8nIyt8L5s=
k8s.io/code-generator v0.0.0-20181117043124-c2090bec4d9b h1:KH0fUlgdFZH8UMxJ/FDCYHpczfSQKefetq5NjL6BVF0= k8s.io/code-generator v0.0.0-20181117043124-c2090bec4d9b h1:KH0fUlgdFZH8UMxJ/FDCYHpczfSQKefetq5NjL6BVF0=
k8s.io/code-generator v0.0.0-20181117043124-c2090bec4d9b/go.mod h1:MYiN+ZJZ9HkETbgVZdWw2AsuAi9PZ4V80cwfuf2axe8= k8s.io/code-generator v0.0.0-20181117043124-c2090bec4d9b/go.mod h1:MYiN+ZJZ9HkETbgVZdWw2AsuAi9PZ4V80cwfuf2axe8=
k8s.io/component-base v0.0.0-20190831075413-37a093468564 h1:mY4AxuX1h/hbjrwVkBBiTGnWeh41YGfEcFIFGb9Iabs=
k8s.io/component-base v0.0.0-20190831075413-37a093468564/go.mod h1:pB3zmhcOR5xextKMKdxRr2XUCERS2UNFA/6Tr2WmSJs=
k8s.io/gengo v0.0.0-20190327210449-e17681d19d3a h1:QoHVuRquf80YZ+/bovwxoMO3Q/A3nt3yTgS0/0nejuk= k8s.io/gengo v0.0.0-20190327210449-e17681d19d3a h1:QoHVuRquf80YZ+/bovwxoMO3Q/A3nt3yTgS0/0nejuk=
k8s.io/gengo v0.0.0-20190327210449-e17681d19d3a/go.mod h1:ezvh/TsK7cY6rbqRK0oQQ8IAqLxYwwyPxAX1Pzy0ii0= k8s.io/gengo v0.0.0-20190327210449-e17681d19d3a/go.mod h1:ezvh/TsK7cY6rbqRK0oQQ8IAqLxYwwyPxAX1Pzy0ii0=
k8s.io/klog v0.3.1 h1:RVgyDHY/kFKtLqh67NvEWIgkMneNoIrdkN0CxDSQc68= k8s.io/klog v0.4.0 h1:lCJCxf/LIowc2IGS9TPjWDyXY4nOmdGdfcwwDQCOURQ=
k8s.io/klog v0.3.1/go.mod h1:Gq+BEi5rUBO/HRz0bTSXDUcqjScdoY3a9IHpCEIOOfk= k8s.io/klog v0.4.0/go.mod h1:4Bi6QPql/J/LkTDqv7R/cd3hPo4k2DG6Ptcz060Ez5I=
k8s.io/kube-openapi v0.0.0-20181109181836-c59034cc13d5 h1:MH8SvyTlIiLt8b1oHy4Dtp1zPpLGp6lTOjvfzPTkoQE= k8s.io/kube-openapi v0.0.0-20181109181836-c59034cc13d5 h1:MH8SvyTlIiLt8b1oHy4Dtp1zPpLGp6lTOjvfzPTkoQE=
k8s.io/kube-openapi v0.0.0-20181109181836-c59034cc13d5/go.mod h1:BXM9ceUBTj2QnfH2MK1odQs778ajze1RxcmP6S8RVVc= k8s.io/kube-openapi v0.0.0-20181109181836-c59034cc13d5/go.mod h1:BXM9ceUBTj2QnfH2MK1odQs778ajze1RxcmP6S8RVVc=
k8s.io/kubernetes v1.13.6 h1:eUAUryzMLFmi4ZY8kMOUtLG5lHp2PUx5WOmy4RVaobk= k8s.io/kubernetes v1.13.6 h1:eUAUryzMLFmi4ZY8kMOUtLG5lHp2PUx5WOmy4RVaobk=
......
...@@ -9,7 +9,7 @@ TAG=latest ...@@ -9,7 +9,7 @@ TAG=latest
# check if build was triggered by a travis cronjob # check if build was triggered by a travis cronjob
if [[ -z "$TRAVIS_EVENT_TYPE" ]]; then if [[ -z "$TRAVIS_EVENT_TYPE" ]]; then
echo "TRAVIS_EVENT_TYPE is empty, also normaly build" echo "TRAVIS_EVENT_TYPE is empty, also normaly build"
elif [ $TRAVIS_EVENT_TYPE == "cron" ]; then elif [[ $TRAVIS_EVENT_TYPE == "cron" ]]; then
TAG=dev-$(date +%Y%m%d) TAG=dev-$(date +%Y%m%d)
fi fi
...@@ -18,6 +18,7 @@ docker build -f build/ks-apigateway/Dockerfile -t $REPO/ks-apigateway:$TAG . ...@@ -18,6 +18,7 @@ docker build -f build/ks-apigateway/Dockerfile -t $REPO/ks-apigateway:$TAG .
docker build -f build/ks-apiserver/Dockerfile -t $REPO/ks-apiserver:$TAG . docker build -f build/ks-apiserver/Dockerfile -t $REPO/ks-apiserver:$TAG .
docker build -f build/ks-iam/Dockerfile -t $REPO/ks-account:$TAG . docker build -f build/ks-iam/Dockerfile -t $REPO/ks-account:$TAG .
docker build -f build/ks-controller-manager/Dockerfile -t $REPO/ks-controller-manager:$TAG . docker build -f build/ks-controller-manager/Dockerfile -t $REPO/ks-controller-manager:$TAG .
docker build -f build/hypersphere/Dockerfile -t $REPO/hypersphere:$TAG .
docker build -f ./pkg/db/Dockerfile -t $REPO/ks-devops:flyway-$TAG ./pkg/db/ docker build -f ./pkg/db/Dockerfile -t $REPO/ks-devops:flyway-$TAG ./pkg/db/
# Push image to dockerhub, need to support multiple push # Push image to dockerhub, need to support multiple push
...@@ -27,4 +28,5 @@ docker push $REPO/ks-apigateway:$TAG ...@@ -27,4 +28,5 @@ docker push $REPO/ks-apigateway:$TAG
docker push $REPO/ks-apiserver:$TAG docker push $REPO/ks-apiserver:$TAG
docker push $REPO/ks-account:$TAG docker push $REPO/ks-account:$TAG
docker push $REPO/ks-controller-manager:$TAG docker push $REPO/ks-controller-manager:$TAG
docker push $REPO/hypersphere:$TAG
docker push $REPO/ks-devops:flyway-$TAG docker push $REPO/ks-devops:flyway-$TAG
...@@ -168,7 +168,7 @@ func addWebService(c *restful.Container) error { ...@@ -168,7 +168,7 @@ func addWebService(c *restful.Container) error {
Param(webservice.PathParameter("workload", "workload name").Required(true)). Param(webservice.PathParameter("workload", "workload name").Required(true)).
Param(webservice.QueryParameter("rateInterval", "the rate interval used for fetching error rate").DefaultValue("10m").Required(true)). Param(webservice.QueryParameter("rateInterval", "the rate interval used for fetching error rate").DefaultValue("10m").Required(true)).
Param(webservice.QueryParameter("queryTime", "the time to use for query")). Param(webservice.QueryParameter("queryTime", "the time to use for query")).
ReturnsError(http.StatusOK, "ok", workloadHealthResponse{}). Returns(http.StatusOK, "ok", workloadHealthResponse{}).
Writes(workloadHealthResponse{})).Produces(restful.MIME_JSON) Writes(workloadHealthResponse{})).Produces(restful.MIME_JSON)
// Get app health // Get app health
......
...@@ -20,8 +20,14 @@ package monitoring ...@@ -20,8 +20,14 @@ package monitoring
import ( import (
"fmt" "fmt"
"github.com/emicklei/go-restful" "github.com/emicklei/go-restful"
"k8s.io/klog"
"kubesphere.io/kubesphere/pkg/informers"
"kubesphere.io/kubesphere/pkg/models/metrics" "kubesphere.io/kubesphere/pkg/models/metrics"
"kubesphere.io/kubesphere/pkg/simple/client/prometheus" "kubesphere.io/kubesphere/pkg/simple/client"
"net/url"
"strconv"
"strings"
"time"
) )
func MonitorAllPodsOfSpecificNamespace(request *restful.Request, response *restful.Response) { func MonitorAllPodsOfSpecificNamespace(request *restful.Request, response *restful.Response) {
...@@ -41,7 +47,7 @@ func MonitorSpecificPodOnSpecificNode(request *restful.Request, response *restfu ...@@ -41,7 +47,7 @@ func MonitorSpecificPodOnSpecificNode(request *restful.Request, response *restfu
} }
func MonitorPod(request *restful.Request, response *restful.Response) { func MonitorPod(request *restful.Request, response *restful.Response) {
requestParams := prometheus.ParseMonitoringRequestParams(request) requestParams := ParseMonitoringRequestParams(request)
podName := requestParams.PodName podName := requestParams.PodName
if podName != "" { if podName != "" {
requestParams.ResourcesFilter = fmt.Sprintf("^%s$", requestParams.PodName) requestParams.ResourcesFilter = fmt.Sprintf("^%s$", requestParams.PodName)
...@@ -68,7 +74,7 @@ func MonitorSpecificContainerOfSpecificNamespace(request *restful.Request, respo ...@@ -68,7 +74,7 @@ func MonitorSpecificContainerOfSpecificNamespace(request *restful.Request, respo
} }
func MonitorContainer(request *restful.Request, response *restful.Response) { func MonitorContainer(request *restful.Request, response *restful.Response) {
requestParams := prometheus.ParseMonitoringRequestParams(request) requestParams := ParseMonitoringRequestParams(request)
rawMetrics := metrics.GetContainerLevelMetrics(requestParams) rawMetrics := metrics.GetContainerLevelMetrics(requestParams)
// sorting // sorting
sortedMetrics, maxMetricCount := metrics.Sort(requestParams.SortMetricName, requestParams.SortType, rawMetrics) sortedMetrics, maxMetricCount := metrics.Sort(requestParams.SortMetricName, requestParams.SortType, rawMetrics)
...@@ -91,7 +97,7 @@ func MonitorAllWorkloadsOfSpecificNamespace(request *restful.Request, response * ...@@ -91,7 +97,7 @@ func MonitorAllWorkloadsOfSpecificNamespace(request *restful.Request, response *
} }
func MonitorWorkload(request *restful.Request, response *restful.Response) { func MonitorWorkload(request *restful.Request, response *restful.Response) {
requestParams := prometheus.ParseMonitoringRequestParams(request) requestParams := ParseMonitoringRequestParams(request)
rawMetrics := metrics.GetWorkloadLevelMetrics(requestParams) rawMetrics := metrics.GetWorkloadLevelMetrics(requestParams)
...@@ -107,7 +113,7 @@ func MonitorWorkload(request *restful.Request, response *restful.Response) { ...@@ -107,7 +113,7 @@ func MonitorWorkload(request *restful.Request, response *restful.Response) {
func MonitorAllWorkspaces(request *restful.Request, response *restful.Response) { func MonitorAllWorkspaces(request *restful.Request, response *restful.Response) {
requestParams := prometheus.ParseMonitoringRequestParams(request) requestParams := ParseMonitoringRequestParams(request)
tp := requestParams.Tp tp := requestParams.Tp
if tp == "statistics" { if tp == "statistics" {
...@@ -129,7 +135,7 @@ func MonitorAllWorkspaces(request *restful.Request, response *restful.Response) ...@@ -129,7 +135,7 @@ func MonitorAllWorkspaces(request *restful.Request, response *restful.Response)
} }
func MonitorSpecificWorkspace(request *restful.Request, response *restful.Response) { func MonitorSpecificWorkspace(request *restful.Request, response *restful.Response) {
requestParams := prometheus.ParseMonitoringRequestParams(request) requestParams := ParseMonitoringRequestParams(request)
tp := requestParams.Tp tp := requestParams.Tp
if tp == "rank" { if tp == "rank" {
...@@ -164,7 +170,7 @@ func MonitorSpecificNamespace(request *restful.Request, response *restful.Respon ...@@ -164,7 +170,7 @@ func MonitorSpecificNamespace(request *restful.Request, response *restful.Respon
} }
func MonitorNamespace(request *restful.Request, response *restful.Response) { func MonitorNamespace(request *restful.Request, response *restful.Response) {
requestParams := prometheus.ParseMonitoringRequestParams(request) requestParams := ParseMonitoringRequestParams(request)
// multiple // multiple
rawMetrics := metrics.GetNamespaceLevelMetrics(requestParams) rawMetrics := metrics.GetNamespaceLevelMetrics(requestParams)
...@@ -176,13 +182,23 @@ func MonitorNamespace(request *restful.Request, response *restful.Response) { ...@@ -176,13 +182,23 @@ func MonitorNamespace(request *restful.Request, response *restful.Response) {
} }
func MonitorCluster(request *restful.Request, response *restful.Response) { func MonitorCluster(request *restful.Request, response *restful.Response) {
requestParams := prometheus.ParseMonitoringRequestParams(request) requestParams := ParseMonitoringRequestParams(request)
metricName := requestParams.MetricsName metricName := requestParams.MetricsName
if metricName != "" { if metricName != "" {
prometheusClient, err := client.ClientSets().Prometheus()
if err != nil {
if _, ok := err.(client.ClientSetNotEnabledError); ok {
klog.Error("monitoring is not enabled")
return
} else {
klog.Errorf("get prometheus client failed %+v", err)
}
}
// single // single
queryType, params := metrics.AssembleClusterMetricRequestInfo(requestParams, metricName) queryType, params := metrics.AssembleClusterMetricRequestInfo(requestParams, metricName)
metricsStr := prometheus.SendMonitoringRequest(prometheus.PrometheusEndpoint, queryType, params) metricsStr := prometheusClient.SendMonitoringRequest(queryType, params)
res := metrics.ReformatJson(metricsStr, metricName, map[string]string{metrics.MetricLevelCluster: "local"}) res := metrics.ReformatJson(metricsStr, metricName, map[string]string{metrics.MetricLevelCluster: "local"})
response.WriteAsJson(res) response.WriteAsJson(res)
...@@ -202,13 +218,22 @@ func MonitorSpecificNode(request *restful.Request, response *restful.Response) { ...@@ -202,13 +218,22 @@ func MonitorSpecificNode(request *restful.Request, response *restful.Response) {
} }
func MonitorNode(request *restful.Request, response *restful.Response) { func MonitorNode(request *restful.Request, response *restful.Response) {
requestParams := prometheus.ParseMonitoringRequestParams(request) requestParams := ParseMonitoringRequestParams(request)
metricName := requestParams.MetricsName metricName := requestParams.MetricsName
if metricName != "" { if metricName != "" {
prometheusClient, err := client.ClientSets().Prometheus()
if err != nil {
if _, ok := err.(client.ClientSetNotEnabledError); ok {
klog.Error("monitoring is not enabled")
return
} else {
klog.Errorf("get prometheus client failed %+v", err)
}
}
// single // single
queryType, params := metrics.AssembleNodeMetricRequestInfo(requestParams, metricName) queryType, params := metrics.AssembleNodeMetricRequestInfo(requestParams, metricName)
metricsStr := prometheus.SendMonitoringRequest(prometheus.PrometheusEndpoint, queryType, params) metricsStr := prometheusClient.SendMonitoringRequest(queryType, params)
res := metrics.ReformatJson(metricsStr, metricName, map[string]string{metrics.MetricLevelNode: ""}) res := metrics.ReformatJson(metricsStr, metricName, map[string]string{metrics.MetricLevelNode: ""})
// The raw node-exporter result doesn't include ip address information // The raw node-exporter result doesn't include ip address information
// Thereby, append node ip address to .data.result[].metric // Thereby, append node ip address to .data.result[].metric
...@@ -248,7 +273,7 @@ func MonitorSpecificPVCofSpecificNamespace(request *restful.Request, response *r ...@@ -248,7 +273,7 @@ func MonitorSpecificPVCofSpecificNamespace(request *restful.Request, response *r
} }
func MonitorPVC(request *restful.Request, response *restful.Response) { func MonitorPVC(request *restful.Request, response *restful.Response) {
requestParams := prometheus.ParseMonitoringRequestParams(request) requestParams := ParseMonitoringRequestParams(request)
pvcName := requestParams.PVCName pvcName := requestParams.PVCName
if pvcName != "" { if pvcName != "" {
requestParams.ResourcesFilter = fmt.Sprintf("^%s$", requestParams.PVCName) requestParams.ResourcesFilter = fmt.Sprintf("^%s$", requestParams.PVCName)
...@@ -263,7 +288,7 @@ func MonitorPVC(request *restful.Request, response *restful.Response) { ...@@ -263,7 +288,7 @@ func MonitorPVC(request *restful.Request, response *restful.Response) {
} }
func MonitorComponent(request *restful.Request, response *restful.Response) { func MonitorComponent(request *restful.Request, response *restful.Response) {
requestParams := prometheus.ParseMonitoringRequestParams(request) requestParams := ParseMonitoringRequestParams(request)
if requestParams.MetricsFilter == "" { if requestParams.MetricsFilter == "" {
requestParams.MetricsFilter = requestParams.ComponentName + "_.*" requestParams.MetricsFilter = requestParams.ComponentName + "_.*"
...@@ -273,3 +298,113 @@ func MonitorComponent(request *restful.Request, response *restful.Response) { ...@@ -273,3 +298,113 @@ func MonitorComponent(request *restful.Request, response *restful.Response) {
response.WriteAsJson(rawMetrics) response.WriteAsJson(rawMetrics)
} }
func ParseMonitoringRequestParams(request *restful.Request) *metrics.MonitoringRequestParams {
instantTime := strings.Trim(request.QueryParameter("time"), " ")
start := strings.Trim(request.QueryParameter("start"), " ")
end := strings.Trim(request.QueryParameter("end"), " ")
step := strings.Trim(request.QueryParameter("step"), " ")
timeout := strings.Trim(request.QueryParameter("timeout"), " ")
sortMetricName := strings.Trim(request.QueryParameter("sort_metric"), " ")
sortType := strings.Trim(request.QueryParameter("sort_type"), " ")
pageNum := strings.Trim(request.QueryParameter("page"), " ")
limitNum := strings.Trim(request.QueryParameter("limit"), " ")
tp := strings.Trim(request.QueryParameter("type"), " ")
metricsFilter := strings.Trim(request.QueryParameter("metrics_filter"), " ")
resourcesFilter := strings.Trim(request.QueryParameter("resources_filter"), " ")
metricsName := strings.Trim(request.QueryParameter("metrics_name"), " ")
workloadName := strings.Trim(request.PathParameter("workload"), " ")
nodeId := strings.Trim(request.PathParameter("node"), " ")
wsName := strings.Trim(request.PathParameter("workspace"), " ")
nsName := strings.Trim(request.PathParameter("namespace"), " ")
podName := strings.Trim(request.PathParameter("pod"), " ")
pvcName := strings.Trim(request.PathParameter("pvc"), " ")
storageClassName := strings.Trim(request.PathParameter("storageclass"), " ")
containerName := strings.Trim(request.PathParameter("container"), " ")
workloadKind := strings.Trim(request.PathParameter("kind"), " ")
componentName := strings.Trim(request.PathParameter("component"), " ")
var requestParams = metrics.MonitoringRequestParams{
SortMetricName: sortMetricName,
SortType: sortType,
PageNum: pageNum,
LimitNum: limitNum,
Tp: tp,
MetricsFilter: metricsFilter,
ResourcesFilter: resourcesFilter,
MetricsName: metricsName,
WorkloadName: workloadName,
NodeId: nodeId,
WsName: wsName,
NsName: nsName,
PodName: podName,
PVCName: pvcName,
StorageClassName: storageClassName,
ContainerName: containerName,
WorkloadKind: workloadKind,
ComponentName: componentName,
}
if timeout == "" {
timeout = metrics.DefaultQueryTimeout
}
if step == "" {
step = metrics.DefaultQueryStep
}
// Whether query or query_range request
u := url.Values{}
if start != "" && end != "" {
u.Set("start", convertTimeGranularity(start))
u.Set("end", convertTimeGranularity(end))
u.Set("step", step)
u.Set("timeout", timeout)
// range query start time must be greater than the namespace creation time
if nsName != "" {
nsLister := informers.SharedInformerFactory().Core().V1().Namespaces().Lister()
ns, err := nsLister.Get(nsName)
if err == nil {
queryStartTime := u.Get("start")
nsCreationTime := strconv.FormatInt(ns.CreationTimestamp.Unix(), 10)
if nsCreationTime > queryStartTime {
u.Set("start", nsCreationTime)
}
}
}
requestParams.QueryType = metrics.RangeQueryType
requestParams.Params = u
return &requestParams
}
if instantTime != "" {
u.Set("time", instantTime)
u.Set("timeout", timeout)
requestParams.QueryType = metrics.DefaultQueryType
requestParams.Params = u
return &requestParams
} else {
u.Set("timeout", timeout)
requestParams.QueryType = metrics.DefaultQueryType
requestParams.Params = u
return &requestParams
}
}
func convertTimeGranularity(ts string) string {
timeFloat, err := strconv.ParseFloat(ts, 64)
if err != nil {
klog.Errorf("convert second timestamp %s to minute timestamp failed", ts)
return strconv.FormatInt(int64(time.Now().Unix()), 10)
}
timeInt := int64(timeFloat)
// convert second timestamp to minute timestamp
secondTime := time.Unix(timeInt, 0).Truncate(time.Minute).Unix()
return strconv.FormatInt(secondTime, 10)
}
...@@ -22,11 +22,11 @@ import ( ...@@ -22,11 +22,11 @@ import (
"k8s.io/client-go/tools/cache" "k8s.io/client-go/tools/cache"
"k8s.io/client-go/tools/record" "k8s.io/client-go/tools/record"
"k8s.io/client-go/util/workqueue" "k8s.io/client-go/util/workqueue"
log "k8s.io/klog"
"k8s.io/kubernetes/pkg/util/metrics" "k8s.io/kubernetes/pkg/util/metrics"
servicemeshinformers "kubesphere.io/kubesphere/pkg/client/informers/externalversions/servicemesh/v1alpha2" servicemeshinformers "kubesphere.io/kubesphere/pkg/client/informers/externalversions/servicemesh/v1alpha2"
servicemeshlisters "kubesphere.io/kubesphere/pkg/client/listers/servicemesh/v1alpha2" servicemeshlisters "kubesphere.io/kubesphere/pkg/client/listers/servicemesh/v1alpha2"
"kubesphere.io/kubesphere/pkg/controller/virtualservice/util" "kubesphere.io/kubesphere/pkg/controller/virtualservice/util"
logf "sigs.k8s.io/controller-runtime/pkg/runtime/log"
) )
const ( const (
...@@ -38,8 +38,6 @@ const ( ...@@ -38,8 +38,6 @@ const (
maxRetries = 15 maxRetries = 15
) )
var log = logf.Log.WithName("application-controller")
type ApplicationController struct { type ApplicationController struct {
client clientset.Interface client clientset.Interface
......
...@@ -27,6 +27,7 @@ import ( ...@@ -27,6 +27,7 @@ import (
"k8s.io/apimachinery/pkg/labels" "k8s.io/apimachinery/pkg/labels"
"k8s.io/apimachinery/pkg/runtime" "k8s.io/apimachinery/pkg/runtime"
"k8s.io/apimachinery/pkg/types" "k8s.io/apimachinery/pkg/types"
log "k8s.io/klog"
"kubesphere.io/kubesphere/pkg/constants" "kubesphere.io/kubesphere/pkg/constants"
"kubesphere.io/kubesphere/pkg/utils/k8sutil" "kubesphere.io/kubesphere/pkg/utils/k8sutil"
"reflect" "reflect"
...@@ -35,14 +36,9 @@ import ( ...@@ -35,14 +36,9 @@ import (
"sigs.k8s.io/controller-runtime/pkg/handler" "sigs.k8s.io/controller-runtime/pkg/handler"
"sigs.k8s.io/controller-runtime/pkg/manager" "sigs.k8s.io/controller-runtime/pkg/manager"
"sigs.k8s.io/controller-runtime/pkg/reconcile" "sigs.k8s.io/controller-runtime/pkg/reconcile"
logf "sigs.k8s.io/controller-runtime/pkg/runtime/log"
"sigs.k8s.io/controller-runtime/pkg/source" "sigs.k8s.io/controller-runtime/pkg/source"
) )
var (
log = logf.Log.WithName("clusterrolebinding-controller")
)
/** /**
* USER ACTION REQUIRED: This is a scaffold file intended for the user to modify with their own Controller * USER ACTION REQUIRED: This is a scaffold file intended for the user to modify with their own Controller
* business logic. Delete these comments after modifying this file.* * business logic. Delete these comments after modifying this file.*
...@@ -139,7 +135,7 @@ func (r *ReconcileClusterRoleBinding) updateRoleBindings(clusterRoleBinding *rba ...@@ -139,7 +135,7 @@ func (r *ReconcileClusterRoleBinding) updateRoleBindings(clusterRoleBinding *rba
err := r.Get(context.TODO(), types.NamespacedName{Namespace: namespace.Name, Name: adminBinding.Name}, found) err := r.Get(context.TODO(), types.NamespacedName{Namespace: namespace.Name, Name: adminBinding.Name}, found)
if errors.IsNotFound(err) { if errors.IsNotFound(err) {
log.Info("Creating default role binding", "namespace", namespace.Name, "name", adminBinding.Name) log.V(4).Info("Creating default role binding", "namespace", namespace.Name, "name", adminBinding.Name)
err = r.Create(context.TODO(), adminBinding) err = r.Create(context.TODO(), adminBinding)
if err != nil { if err != nil {
log.Error(err, "default role binding create failed", "namespace", namespace.Name, "name", adminBinding.Name) log.Error(err, "default role binding create failed", "namespace", namespace.Name, "name", adminBinding.Name)
...@@ -151,7 +147,7 @@ func (r *ReconcileClusterRoleBinding) updateRoleBindings(clusterRoleBinding *rba ...@@ -151,7 +147,7 @@ func (r *ReconcileClusterRoleBinding) updateRoleBindings(clusterRoleBinding *rba
} }
if !reflect.DeepEqual(found.RoleRef, adminBinding.RoleRef) { if !reflect.DeepEqual(found.RoleRef, adminBinding.RoleRef) {
log.Info("Deleting conflict role binding", "namespace", namespace.Name, "name", adminBinding.Name) log.V(4).Info("Deleting conflict role binding", "namespace", namespace.Name, "name", adminBinding.Name)
err = r.Delete(context.TODO(), found) err = r.Delete(context.TODO(), found)
if err != nil { if err != nil {
return err return err
...@@ -161,7 +157,7 @@ func (r *ReconcileClusterRoleBinding) updateRoleBindings(clusterRoleBinding *rba ...@@ -161,7 +157,7 @@ func (r *ReconcileClusterRoleBinding) updateRoleBindings(clusterRoleBinding *rba
if !reflect.DeepEqual(found.Subjects, adminBinding.Subjects) { if !reflect.DeepEqual(found.Subjects, adminBinding.Subjects) {
found.Subjects = adminBinding.Subjects found.Subjects = adminBinding.Subjects
log.Info("Updating role binding", "namespace", namespace.Name, "name", adminBinding.Name) log.V(4).Info("Updating role binding", "namespace", namespace.Name, "name", adminBinding.Name)
err = r.Update(context.TODO(), found) err = r.Update(context.TODO(), found)
if err != nil { if err != nil {
return err return err
......
...@@ -16,10 +16,10 @@ import ( ...@@ -16,10 +16,10 @@ import (
"k8s.io/apimachinery/pkg/util/wait" "k8s.io/apimachinery/pkg/util/wait"
"k8s.io/client-go/kubernetes/scheme" "k8s.io/client-go/kubernetes/scheme"
v1core "k8s.io/client-go/kubernetes/typed/core/v1" v1core "k8s.io/client-go/kubernetes/typed/core/v1"
log "k8s.io/klog"
"k8s.io/kubernetes/pkg/util/metrics" "k8s.io/kubernetes/pkg/util/metrics"
servicemeshv1alpha2 "kubesphere.io/kubesphere/pkg/apis/servicemesh/v1alpha2" servicemeshv1alpha2 "kubesphere.io/kubesphere/pkg/apis/servicemesh/v1alpha2"
"kubesphere.io/kubesphere/pkg/controller/virtualservice/util" "kubesphere.io/kubesphere/pkg/controller/virtualservice/util"
logf "sigs.k8s.io/controller-runtime/pkg/runtime/log"
"time" "time"
...@@ -49,8 +49,6 @@ const ( ...@@ -49,8 +49,6 @@ const (
maxRetries = 15 maxRetries = 15
) )
var log = logf.Log.WithName("destinationrule-controller")
type DestinationRuleController struct { type DestinationRuleController struct {
client clientset.Interface client clientset.Interface
......
...@@ -30,8 +30,8 @@ import ( ...@@ -30,8 +30,8 @@ import (
"k8s.io/apimachinery/pkg/util/wait" "k8s.io/apimachinery/pkg/util/wait"
batchv1informers "k8s.io/client-go/informers/batch/v1" batchv1informers "k8s.io/client-go/informers/batch/v1"
batchv1listers "k8s.io/client-go/listers/batch/v1" batchv1listers "k8s.io/client-go/listers/batch/v1"
log "k8s.io/klog"
"k8s.io/kubernetes/pkg/util/metrics" "k8s.io/kubernetes/pkg/util/metrics"
logf "sigs.k8s.io/controller-runtime/pkg/runtime/log"
"time" "time"
...@@ -51,8 +51,6 @@ const ( ...@@ -51,8 +51,6 @@ const (
revisionsAnnotationKey = "revisions" revisionsAnnotationKey = "revisions"
) )
var log = logf.Log.WithName("job-controller")
type JobController struct { type JobController struct {
client clientset.Interface client clientset.Interface
eventBroadcaster record.EventBroadcaster eventBroadcaster record.EventBroadcaster
......
...@@ -33,6 +33,7 @@ import ( ...@@ -33,6 +33,7 @@ import (
"k8s.io/kubernetes/pkg/apis/core" "k8s.io/kubernetes/pkg/apis/core"
"kubesphere.io/kubesphere/pkg/apis/tenant/v1alpha1" "kubesphere.io/kubesphere/pkg/apis/tenant/v1alpha1"
"kubesphere.io/kubesphere/pkg/constants" "kubesphere.io/kubesphere/pkg/constants"
cs "kubesphere.io/kubesphere/pkg/simple/client"
"kubesphere.io/kubesphere/pkg/simple/client/openpitrix" "kubesphere.io/kubesphere/pkg/simple/client/openpitrix"
"kubesphere.io/kubesphere/pkg/utils/k8sutil" "kubesphere.io/kubesphere/pkg/utils/k8sutil"
"kubesphere.io/kubesphere/pkg/utils/sliceutil" "kubesphere.io/kubesphere/pkg/utils/sliceutil"
...@@ -356,6 +357,10 @@ func (r *ReconcileNamespace) checkAndCreateRoleBindings(namespace *corev1.Namesp ...@@ -356,6 +357,10 @@ func (r *ReconcileNamespace) checkAndCreateRoleBindings(namespace *corev1.Namesp
// Create openpitrix runtime // Create openpitrix runtime
func (r *ReconcileNamespace) checkAndCreateRuntime(namespace *corev1.Namespace) error { func (r *ReconcileNamespace) checkAndCreateRuntime(namespace *corev1.Namespace) error {
openPitrixClient, err := cs.ClientSets().OpenPitrix()
if err != nil {
return err
}
if runtimeId := namespace.Annotations[constants.OpenPitrixRuntimeAnnotationKey]; runtimeId != "" { if runtimeId := namespace.Annotations[constants.OpenPitrixRuntimeAnnotationKey]; runtimeId != "" {
return nil return nil
...@@ -363,7 +368,7 @@ func (r *ReconcileNamespace) checkAndCreateRuntime(namespace *corev1.Namespace) ...@@ -363,7 +368,7 @@ func (r *ReconcileNamespace) checkAndCreateRuntime(namespace *corev1.Namespace)
cm := &corev1.ConfigMap{} cm := &corev1.ConfigMap{}
configName := fmt.Sprintf("kubeconfig-%s", constants.AdminUserName) configName := fmt.Sprintf("kubeconfig-%s", constants.AdminUserName)
err := r.Get(context.TODO(), types.NamespacedName{Namespace: constants.KubeSphereControlNamespace, Name: configName}, cm) err = r.Get(context.TODO(), types.NamespacedName{Namespace: constants.KubeSphereControlNamespace, Name: configName}, cm)
if err != nil { if err != nil {
return err return err
...@@ -371,7 +376,7 @@ func (r *ReconcileNamespace) checkAndCreateRuntime(namespace *corev1.Namespace) ...@@ -371,7 +376,7 @@ func (r *ReconcileNamespace) checkAndCreateRuntime(namespace *corev1.Namespace)
runtime := &openpitrix.RunTime{Name: namespace.Name, Zone: namespace.Name, Provider: "kubernetes", RuntimeCredential: cm.Data["config"]} runtime := &openpitrix.RunTime{Name: namespace.Name, Zone: namespace.Name, Provider: "kubernetes", RuntimeCredential: cm.Data["config"]}
if err := openpitrix.Client().CreateRuntime(runtime); err != nil { if err := openPitrixClient.CreateRuntime(runtime); err != nil {
klog.Errorf("creating openpitrix runtime namespace: %s, error: %s", namespace.Name, err) klog.Errorf("creating openpitrix runtime namespace: %s, error: %s", namespace.Name, err)
return err return err
} }
...@@ -387,7 +392,12 @@ func (r *ReconcileNamespace) deleteRuntime(namespace *corev1.Namespace) error { ...@@ -387,7 +392,12 @@ func (r *ReconcileNamespace) deleteRuntime(namespace *corev1.Namespace) error {
for i := float64(0); i < maxRetries; i++ { for i := float64(0); i < maxRetries; i++ {
time.Sleep(time.Duration(i*math.Pow(2, i)) * time.Second) time.Sleep(time.Duration(i*math.Pow(2, i)) * time.Second)
err := openpitrix.Client().DeleteRuntime(runtimeId) openPitrixClient, err := cs.ClientSets().OpenPitrix()
if err != nil {
return err
}
err = openPitrixClient.DeleteRuntime(runtimeId)
if err == nil || openpitrix.IsNotFound(err) || openpitrix.IsDeleted(err) { if err == nil || openpitrix.IsNotFound(err) || openpitrix.IsDeleted(err) {
return nil return nil
......
...@@ -71,9 +71,9 @@ var _ = Describe("Wsnetworkpolicy", func() { ...@@ -71,9 +71,9 @@ var _ = Describe("Wsnetworkpolicy", func() {
wsnp := newWorkspaceNP(testName) wsnp := newWorkspaceNP(testName)
wsnp.Spec.PolicyTypes = []k8snetwork.PolicyType{k8snetwork.PolicyTypeIngress} wsnp.Spec.PolicyTypes = []k8snetwork.PolicyType{k8snetwork.PolicyTypeIngress}
wsnp.Spec.Ingress = []v1alpha1.WorkspaceNetworkPolicyIngressRule{ wsnp.Spec.Ingress = []v1alpha1.WorkspaceNetworkPolicyIngressRule{
v1alpha1.WorkspaceNetworkPolicyIngressRule{ {
From: []v1alpha1.WorkspaceNetworkPolicyPeer{ From: []v1alpha1.WorkspaceNetworkPolicyPeer{
v1alpha1.WorkspaceNetworkPolicyPeer{ {
WorkspaceSelector: &metav1.LabelSelector{ WorkspaceSelector: &metav1.LabelSelector{
MatchLabels: label, MatchLabels: label,
}, },
......
...@@ -17,7 +17,7 @@ import ( ...@@ -17,7 +17,7 @@ import (
"k8s.io/client-go/util/workqueue" "k8s.io/client-go/util/workqueue"
"k8s.io/klog" "k8s.io/klog"
"k8s.io/kubernetes/pkg/util/metrics" "k8s.io/kubernetes/pkg/util/metrics"
"kubesphere.io/kubesphere/pkg/simple/client/s2is3" "kubesphere.io/kubesphere/pkg/simple/client"
"kubesphere.io/kubesphere/pkg/utils/sliceutil" "kubesphere.io/kubesphere/pkg/utils/sliceutil"
"time" "time"
...@@ -210,12 +210,16 @@ func (c *S2iBinaryController) syncHandler(key string) error { ...@@ -210,12 +210,16 @@ func (c *S2iBinaryController) syncHandler(key string) error {
} }
func (c *S2iBinaryController) deleteBinaryInS3(s2ibin *devopsv1alpha1.S2iBinary) error { func (c *S2iBinaryController) deleteBinaryInS3(s2ibin *devopsv1alpha1.S2iBinary) error {
s3client := s2is3.Client() s3Client, err := client.ClientSets().S3()
if err != nil {
return err
}
input := &s3.DeleteObjectInput{ input := &s3.DeleteObjectInput{
Bucket: s2is3.Bucket(), Bucket: s3Client.Bucket(),
Key: aws.String(fmt.Sprintf("%s-%s", s2ibin.Namespace, s2ibin.Name)), Key: aws.String(fmt.Sprintf("%s-%s", s2ibin.Namespace, s2ibin.Name)),
} }
_, err := s3client.DeleteObject(input) _, err = s3Client.Client().DeleteObject(input)
if err != nil { if err != nil {
if aerr, ok := err.(awserr.Error); ok { if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() { switch aerr.Code() {
......
...@@ -16,9 +16,9 @@ import ( ...@@ -16,9 +16,9 @@ import (
"k8s.io/apimachinery/pkg/util/wait" "k8s.io/apimachinery/pkg/util/wait"
"k8s.io/client-go/kubernetes/scheme" "k8s.io/client-go/kubernetes/scheme"
v1core "k8s.io/client-go/kubernetes/typed/core/v1" v1core "k8s.io/client-go/kubernetes/typed/core/v1"
log "k8s.io/klog"
"k8s.io/kubernetes/pkg/util/metrics" "k8s.io/kubernetes/pkg/util/metrics"
"kubesphere.io/kubesphere/pkg/controller/virtualservice/util" "kubesphere.io/kubesphere/pkg/controller/virtualservice/util"
logf "sigs.k8s.io/controller-runtime/pkg/runtime/log"
istioclient "github.com/knative/pkg/client/clientset/versioned" istioclient "github.com/knative/pkg/client/clientset/versioned"
istioinformers "github.com/knative/pkg/client/informers/externalversions/istio/v1alpha3" istioinformers "github.com/knative/pkg/client/informers/externalversions/istio/v1alpha3"
...@@ -46,8 +46,6 @@ const ( ...@@ -46,8 +46,6 @@ const (
maxRetries = 15 maxRetries = 15
) )
var log = logf.Log.WithName("virtualservice-controller")
type VirtualServiceController struct { type VirtualServiceController struct {
client clientset.Interface client clientset.Interface
...@@ -152,7 +150,7 @@ func (v *VirtualServiceController) Run(workers int, stopCh <-chan struct{}) erro ...@@ -152,7 +150,7 @@ func (v *VirtualServiceController) Run(workers int, stopCh <-chan struct{}) erro
defer utilruntime.HandleCrash() defer utilruntime.HandleCrash()
defer v.queue.ShutDown() defer v.queue.ShutDown()
log.Info("starting virtualservice controller") log.V(0).Info("starting virtualservice controller")
defer log.Info("shutting down virtualservice controller") defer log.Info("shutting down virtualservice controller")
if !cache.WaitForCacheSync(stopCh, v.serviceSynced, v.virtualServiceSynced, v.destinationRuleSynced, v.strategySynced) { if !cache.WaitForCacheSync(stopCh, v.serviceSynced, v.virtualServiceSynced, v.destinationRuleSynced, v.strategySynced) {
......
...@@ -18,15 +18,12 @@ ...@@ -18,15 +18,12 @@
package informers package informers
import ( import (
s2iinformers "github.com/kubesphere/s2ioperator/pkg/client/informers/externalversions"
k8sinformers "k8s.io/client-go/informers"
ksinformers "kubesphere.io/kubesphere/pkg/client/informers/externalversions"
"kubesphere.io/kubesphere/pkg/simple/client"
"sync" "sync"
"time" "time"
s2iInformers "github.com/kubesphere/s2ioperator/pkg/client/informers/externalversions"
"k8s.io/client-go/informers"
ksInformers "kubesphere.io/kubesphere/pkg/client/informers/externalversions"
"kubesphere.io/kubesphere/pkg/simple/client/k8s"
) )
const defaultResync = 600 * time.Second const defaultResync = 600 * time.Second
...@@ -35,31 +32,31 @@ var ( ...@@ -35,31 +32,31 @@ var (
k8sOnce sync.Once k8sOnce sync.Once
s2iOnce sync.Once s2iOnce sync.Once
ksOnce sync.Once ksOnce sync.Once
informerFactory informers.SharedInformerFactory informerFactory k8sinformers.SharedInformerFactory
s2iInformerFactory s2iInformers.SharedInformerFactory s2iInformerFactory s2iinformers.SharedInformerFactory
ksInformerFactory ksInformers.SharedInformerFactory ksInformerFactory ksinformers.SharedInformerFactory
) )
func SharedInformerFactory() informers.SharedInformerFactory { func SharedInformerFactory() k8sinformers.SharedInformerFactory {
k8sOnce.Do(func() { k8sOnce.Do(func() {
k8sClient := k8s.Client() k8sClient := client.ClientSets().K8s().Kubernetes()
informerFactory = informers.NewSharedInformerFactory(k8sClient, defaultResync) informerFactory = k8sinformers.NewSharedInformerFactory(k8sClient, defaultResync)
}) })
return informerFactory return informerFactory
} }
func S2iSharedInformerFactory() s2iInformers.SharedInformerFactory { func S2iSharedInformerFactory() s2iinformers.SharedInformerFactory {
s2iOnce.Do(func() { s2iOnce.Do(func() {
k8sClient := k8s.S2iClient() k8sClient := client.ClientSets().K8s().S2i()
s2iInformerFactory = s2iInformers.NewSharedInformerFactory(k8sClient, defaultResync) s2iInformerFactory = s2iinformers.NewSharedInformerFactory(k8sClient, defaultResync)
}) })
return s2iInformerFactory return s2iInformerFactory
} }
func KsSharedInformerFactory() ksInformers.SharedInformerFactory { func KsSharedInformerFactory() ksinformers.SharedInformerFactory {
ksOnce.Do(func() { ksOnce.Do(func() {
k8sClient := k8s.KsClient() k8sClient := client.ClientSets().K8s().KubeSphere()
ksInformerFactory = ksInformers.NewSharedInformerFactory(k8sClient, defaultResync) ksInformerFactory = ksinformers.NewSharedInformerFactory(k8sClient, defaultResync)
}) })
return ksInformerFactory return ksInformerFactory
} }
...@@ -31,7 +31,7 @@ import ( ...@@ -31,7 +31,7 @@ import (
"kubesphere.io/kubesphere/pkg/models" "kubesphere.io/kubesphere/pkg/models"
"kubesphere.io/kubesphere/pkg/models/resources" "kubesphere.io/kubesphere/pkg/models/resources"
"kubesphere.io/kubesphere/pkg/params" "kubesphere.io/kubesphere/pkg/params"
"kubesphere.io/kubesphere/pkg/simple/client/k8s" "kubesphere.io/kubesphere/pkg/simple/client"
"kubesphere.io/kubesphere/pkg/simple/client/openpitrix" "kubesphere.io/kubesphere/pkg/simple/client/openpitrix"
"strings" "strings"
"time" "time"
...@@ -63,7 +63,11 @@ type workLoads struct { ...@@ -63,7 +63,11 @@ type workLoads struct {
} }
func ListApplication(runtimeId string, conditions *params.Conditions, limit, offset int) (*models.PageableResponse, error) { func ListApplication(runtimeId string, conditions *params.Conditions, limit, offset int) (*models.PageableResponse, error) {
clusterList, err := openpitrix.ListClusters(runtimeId, conditions.Match["keyword"], conditions.Match["status"], limit, offset) openPitrixClient, err := client.ClientSets().OpenPitrix()
if err != nil {
return nil, err
}
clusterList, err := openPitrixClient.ListClusters(runtimeId, conditions.Match["keyword"], conditions.Match["status"], limit, offset)
if err != nil { if err != nil {
return nil, err return nil, err
} }
...@@ -76,13 +80,13 @@ func ListApplication(runtimeId string, conditions *params.Conditions, limit, off ...@@ -76,13 +80,13 @@ func ListApplication(runtimeId string, conditions *params.Conditions, limit, off
app.ClusterID = item.ClusterID app.ClusterID = item.ClusterID
app.UpdateTime = item.UpdateTime app.UpdateTime = item.UpdateTime
app.Status = item.Status app.Status = item.Status
versionInfo, _ := openpitrix.GetVersion(item.VersionID) versionInfo, _ := openPitrixClient.GetVersion(item.VersionID)
app.Version = versionInfo app.Version = versionInfo
app.VersionId = item.VersionID app.VersionId = item.VersionID
runtimeInfo, _ := openpitrix.GetRuntime(item.RunTimeId) runtimeInfo, _ := openPitrixClient.GetRuntime(item.RunTimeId)
app.Runtime = runtimeInfo app.Runtime = runtimeInfo
app.RuntimeId = item.RunTimeId app.RuntimeId = item.RunTimeId
appInfo, _, appId, _ := openpitrix.GetAppInfo(item.AppID) appInfo, _, appId, _ := openPitrixClient.GetAppInfo(item.AppID)
app.App = appInfo app.App = appInfo
app.AppId = appId app.AppId = appId
app.Description = item.Description app.Description = item.Description
...@@ -94,8 +98,11 @@ func ListApplication(runtimeId string, conditions *params.Conditions, limit, off ...@@ -94,8 +98,11 @@ func ListApplication(runtimeId string, conditions *params.Conditions, limit, off
} }
func GetApp(clusterId string) (*Application, error) { func GetApp(clusterId string) (*Application, error) {
openPitrixClient, err := client.ClientSets().OpenPitrix()
item, err := openpitrix.GetCluster(clusterId) if err != nil {
return nil, err
}
item, err := openPitrixClient.GetCluster(clusterId)
if err != nil { if err != nil {
glog.Error(err) glog.Error(err)
...@@ -109,19 +116,19 @@ func GetApp(clusterId string) (*Application, error) { ...@@ -109,19 +116,19 @@ func GetApp(clusterId string) (*Application, error) {
app.UpdateTime = item.UpdateTime app.UpdateTime = item.UpdateTime
app.CreateTime = item.CreateTime app.CreateTime = item.CreateTime
app.Status = item.Status app.Status = item.Status
versionInfo, _ := openpitrix.GetVersion(item.VersionID) versionInfo, _ := openPitrixClient.GetVersion(item.VersionID)
app.Version = versionInfo app.Version = versionInfo
app.VersionId = item.VersionID app.VersionId = item.VersionID
runtimeInfo, _ := openpitrix.GetRuntime(item.RunTimeId) runtimeInfo, _ := openPitrixClient.GetRuntime(item.RunTimeId)
app.Runtime = runtimeInfo app.Runtime = runtimeInfo
app.RuntimeId = item.RunTimeId app.RuntimeId = item.RunTimeId
appInfo, repoId, appId, _ := openpitrix.GetAppInfo(item.AppID) appInfo, repoId, appId, _ := openPitrixClient.GetAppInfo(item.AppID)
app.App = appInfo app.App = appInfo
app.AppId = appId app.AppId = appId
app.Description = item.Description app.Description = item.Description
app.RepoName, _ = openpitrix.GetRepo(repoId) app.RepoName, _ = openPitrixClient.GetRepo(repoId)
workloads, err := getWorkLoads(app.Runtime, item.ClusterRoleSets) workloads, err := getWorkLoads(app.Runtime, item.ClusterRoleSets)
if err != nil { if err != nil {
...@@ -195,7 +202,7 @@ func getWorkLoads(namespace string, clusterRoles []openpitrix.ClusterRole) (*wor ...@@ -195,7 +202,7 @@ func getWorkLoads(namespace string, clusterRoles []openpitrix.ClusterRole) (*wor
} }
func getLabels(namespace string, workloads *workLoads) *[]map[string]string { func getLabels(namespace string, workloads *workLoads) *[]map[string]string {
k8sClient := k8s.Client() k8sClient := client.ClientSets().K8s().Kubernetes()
var workloadLables []map[string]string var workloadLables []map[string]string
if workloads == nil { if workloads == nil {
...@@ -242,7 +249,7 @@ func getSvcs(namespace string, workLoadLabels *[]map[string]string) []v1.Service ...@@ -242,7 +249,7 @@ func getSvcs(namespace string, workLoadLabels *[]map[string]string) []v1.Service
if len(*workLoadLabels) == 0 { if len(*workLoadLabels) == 0 {
return nil return nil
} }
k8sClient := k8s.Client() k8sClient := client.ClientSets().K8s().Kubernetes()
var services []v1.Service var services []v1.Service
for _, label := range *workLoadLabels { for _, label := range *workLoadLabels {
labelSelector := labels.Set(label).AsSelector().String() labelSelector := labels.Set(label).AsSelector().String()
...@@ -302,6 +309,11 @@ func getIng(namespace string, services []v1.Service) []v1beta1.Ingress { ...@@ -302,6 +309,11 @@ func getIng(namespace string, services []v1.Service) []v1beta1.Ingress {
} }
func DeployApplication(namespace string, app openpitrix.CreateClusterRequest) error { func DeployApplication(namespace string, app openpitrix.CreateClusterRequest) error {
openPitrixClient, err := client.ClientSets().OpenPitrix()
if err != nil {
return err
}
ns, err := informers.SharedInformerFactory().Core().V1().Namespaces().Lister().Get(namespace) ns, err := informers.SharedInformerFactory().Core().V1().Namespaces().Lister().Get(namespace)
if err != nil { if err != nil {
glog.Errorf("deploy application failed: %+v", err) glog.Errorf("deploy application failed: %+v", err)
...@@ -313,9 +325,14 @@ func DeployApplication(namespace string, app openpitrix.CreateClusterRequest) er ...@@ -313,9 +325,14 @@ func DeployApplication(namespace string, app openpitrix.CreateClusterRequest) er
} else { } else {
return fmt.Errorf("runtime not init: namespace %s", namespace) return fmt.Errorf("runtime not init: namespace %s", namespace)
} }
return openpitrix.CreateCluster(app) return openPitrixClient.CreateCluster(app)
} }
func DeleteApplication(clusterId string) error { func DeleteApplication(clusterId string) error {
return openpitrix.DeleteCluster(openpitrix.DeleteClusterRequest{ClusterId: []string{clusterId}}) openPitrixClient, err := client.ClientSets().OpenPitrix()
if err != nil {
return err
}
return openPitrixClient.DeleteCluster(openpitrix.DeleteClusterRequest{ClusterId: []string{clusterId}})
} }
...@@ -19,9 +19,9 @@ package components ...@@ -19,9 +19,9 @@ package components
import ( import (
"fmt" "fmt"
meta_v1 "k8s.io/apimachinery/pkg/apis/meta/v1" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"kubesphere.io/kubesphere/pkg/models" "kubesphere.io/kubesphere/pkg/models"
"kubesphere.io/kubesphere/pkg/simple/client/k8s" "kubesphere.io/kubesphere/pkg/simple/client"
"kubesphere.io/kubesphere/pkg/informers" "kubesphere.io/kubesphere/pkg/informers"
...@@ -93,7 +93,7 @@ func GetSystemHealthStatus() (*models.HealthStatus, error) { ...@@ -93,7 +93,7 @@ func GetSystemHealthStatus() (*models.HealthStatus, error) {
status := &models.HealthStatus{} status := &models.HealthStatus{}
componentStatuses, err := k8s.Client().CoreV1().ComponentStatuses().List(meta_v1.ListOptions{}) componentStatuses, err := client.ClientSets().K8s().Kubernetes().CoreV1().ComponentStatuses().List(metav1.ListOptions{})
if err != nil { if err != nil {
return nil, err return nil, err
} }
......
...@@ -16,9 +16,10 @@ package devops ...@@ -16,9 +16,10 @@ package devops
import ( import (
"fmt" "fmt"
"github.com/fatih/structs" "github.com/fatih/structs"
"k8s.io/klog"
"kubesphere.io/kubesphere/pkg/db" "kubesphere.io/kubesphere/pkg/db"
"kubesphere.io/kubesphere/pkg/gojenkins" "kubesphere.io/kubesphere/pkg/gojenkins"
"kubesphere.io/kubesphere/pkg/simple/client/devops_mysql" "kubesphere.io/kubesphere/pkg/simple/client"
"kubesphere.io/kubesphere/pkg/utils/reflectutils" "kubesphere.io/kubesphere/pkg/utils/reflectutils"
"kubesphere.io/kubesphere/pkg/utils/stringutils" "kubesphere.io/kubesphere/pkg/utils/stringutils"
) )
...@@ -126,7 +127,7 @@ var JenkinsOwnerProjectPermissionIds = &gojenkins.ProjectPermissionIds{ ...@@ -126,7 +127,7 @@ var JenkinsOwnerProjectPermissionIds = &gojenkins.ProjectPermissionIds{
} }
var JenkinsProjectPermissionMap = map[string]gojenkins.ProjectPermissionIds{ var JenkinsProjectPermissionMap = map[string]gojenkins.ProjectPermissionIds{
ProjectOwner: gojenkins.ProjectPermissionIds{ ProjectOwner: {
CredentialCreate: true, CredentialCreate: true,
CredentialDelete: true, CredentialDelete: true,
CredentialManageDomains: true, CredentialManageDomains: true,
...@@ -146,7 +147,7 @@ var JenkinsProjectPermissionMap = map[string]gojenkins.ProjectPermissionIds{ ...@@ -146,7 +147,7 @@ var JenkinsProjectPermissionMap = map[string]gojenkins.ProjectPermissionIds{
RunUpdate: true, RunUpdate: true,
SCMTag: true, SCMTag: true,
}, },
ProjectMaintainer: gojenkins.ProjectPermissionIds{ ProjectMaintainer: {
CredentialCreate: true, CredentialCreate: true,
CredentialDelete: true, CredentialDelete: true,
CredentialManageDomains: true, CredentialManageDomains: true,
...@@ -166,7 +167,7 @@ var JenkinsProjectPermissionMap = map[string]gojenkins.ProjectPermissionIds{ ...@@ -166,7 +167,7 @@ var JenkinsProjectPermissionMap = map[string]gojenkins.ProjectPermissionIds{
RunUpdate: true, RunUpdate: true,
SCMTag: true, SCMTag: true,
}, },
ProjectDeveloper: gojenkins.ProjectPermissionIds{ ProjectDeveloper: {
CredentialCreate: false, CredentialCreate: false,
CredentialDelete: false, CredentialDelete: false,
CredentialManageDomains: false, CredentialManageDomains: false,
...@@ -186,7 +187,7 @@ var JenkinsProjectPermissionMap = map[string]gojenkins.ProjectPermissionIds{ ...@@ -186,7 +187,7 @@ var JenkinsProjectPermissionMap = map[string]gojenkins.ProjectPermissionIds{
RunUpdate: true, RunUpdate: true,
SCMTag: false, SCMTag: false,
}, },
ProjectReporter: gojenkins.ProjectPermissionIds{ ProjectReporter: {
CredentialCreate: false, CredentialCreate: false,
CredentialDelete: false, CredentialDelete: false,
CredentialManageDomains: false, CredentialManageDomains: false,
...@@ -209,7 +210,7 @@ var JenkinsProjectPermissionMap = map[string]gojenkins.ProjectPermissionIds{ ...@@ -209,7 +210,7 @@ var JenkinsProjectPermissionMap = map[string]gojenkins.ProjectPermissionIds{
} }
var JenkinsPipelinePermissionMap = map[string]gojenkins.ProjectPermissionIds{ var JenkinsPipelinePermissionMap = map[string]gojenkins.ProjectPermissionIds{
ProjectOwner: gojenkins.ProjectPermissionIds{ ProjectOwner: {
CredentialCreate: true, CredentialCreate: true,
CredentialDelete: true, CredentialDelete: true,
CredentialManageDomains: true, CredentialManageDomains: true,
...@@ -229,7 +230,7 @@ var JenkinsPipelinePermissionMap = map[string]gojenkins.ProjectPermissionIds{ ...@@ -229,7 +230,7 @@ var JenkinsPipelinePermissionMap = map[string]gojenkins.ProjectPermissionIds{
RunUpdate: true, RunUpdate: true,
SCMTag: true, SCMTag: true,
}, },
ProjectMaintainer: gojenkins.ProjectPermissionIds{ ProjectMaintainer: {
CredentialCreate: true, CredentialCreate: true,
CredentialDelete: true, CredentialDelete: true,
CredentialManageDomains: true, CredentialManageDomains: true,
...@@ -249,7 +250,7 @@ var JenkinsPipelinePermissionMap = map[string]gojenkins.ProjectPermissionIds{ ...@@ -249,7 +250,7 @@ var JenkinsPipelinePermissionMap = map[string]gojenkins.ProjectPermissionIds{
RunUpdate: true, RunUpdate: true,
SCMTag: true, SCMTag: true,
}, },
ProjectDeveloper: gojenkins.ProjectPermissionIds{ ProjectDeveloper: {
CredentialCreate: false, CredentialCreate: false,
CredentialDelete: false, CredentialDelete: false,
CredentialManageDomains: false, CredentialManageDomains: false,
...@@ -269,7 +270,7 @@ var JenkinsPipelinePermissionMap = map[string]gojenkins.ProjectPermissionIds{ ...@@ -269,7 +270,7 @@ var JenkinsPipelinePermissionMap = map[string]gojenkins.ProjectPermissionIds{
RunUpdate: true, RunUpdate: true,
SCMTag: false, SCMTag: false,
}, },
ProjectReporter: gojenkins.ProjectPermissionIds{ ProjectReporter: {
CredentialCreate: false, CredentialCreate: false,
CredentialDelete: false, CredentialDelete: false,
CredentialManageDomains: false, CredentialManageDomains: false,
...@@ -311,9 +312,18 @@ func CheckProjectUserInRole(username, projectId string, roles []string) error { ...@@ -311,9 +312,18 @@ func CheckProjectUserInRole(username, projectId string, roles []string) error {
if username == KS_ADMIN { if username == KS_ADMIN {
return nil return nil
} }
dbconn := devops_mysql.OpenDatabase() dbconn, err := client.ClientSets().MySQL()
if err != nil {
if _, ok := err.(client.ClientSetNotEnabledError); ok {
klog.Error("mysql is not enabled")
} else {
klog.Error("error creating mysql client", err)
}
return nil
}
membership := &DevOpsProjectMembership{} membership := &DevOpsProjectMembership{}
err := dbconn.Select(DevOpsProjectMembershipColumns...). err = dbconn.Select(DevOpsProjectMembershipColumns...).
From(DevOpsProjectMembershipTableName). From(DevOpsProjectMembershipTableName).
Where(db.And( Where(db.And(
db.Eq(DevOpsProjectMembershipUsernameColumn, username), db.Eq(DevOpsProjectMembershipUsernameColumn, username),
...@@ -331,9 +341,17 @@ func GetProjectUserRole(username, projectId string) (string, error) { ...@@ -331,9 +341,17 @@ func GetProjectUserRole(username, projectId string) (string, error) {
if username == KS_ADMIN { if username == KS_ADMIN {
return ProjectOwner, nil return ProjectOwner, nil
} }
dbconn := devops_mysql.OpenDatabase() dbconn, err := client.ClientSets().MySQL()
if err != nil {
if _, ok := err.(client.ClientSetNotEnabledError); ok {
klog.Error("mysql is not enabled")
} else {
klog.Error("error creating mysql client", err)
}
return "", err
}
membership := &DevOpsProjectMembership{} membership := &DevOpsProjectMembership{}
err := dbconn.Select(DevOpsProjectMembershipColumns...). err = dbconn.Select(DevOpsProjectMembershipColumns...).
From(DevOpsProjectMembershipTableName). From(DevOpsProjectMembershipTableName).
Where(db.And( Where(db.And(
db.Eq(DevOpsProjectMembershipUsernameColumn, username), db.Eq(DevOpsProjectMembershipUsernameColumn, username),
......
此差异已折叠。
...@@ -24,25 +24,25 @@ import ( ...@@ -24,25 +24,25 @@ import (
"kubesphere.io/kubesphere/pkg/db" "kubesphere.io/kubesphere/pkg/db"
"kubesphere.io/kubesphere/pkg/gojenkins" "kubesphere.io/kubesphere/pkg/gojenkins"
"kubesphere.io/kubesphere/pkg/gojenkins/utils" "kubesphere.io/kubesphere/pkg/gojenkins/utils"
"kubesphere.io/kubesphere/pkg/simple/client/admin_jenkins" cs "kubesphere.io/kubesphere/pkg/simple/client"
"kubesphere.io/kubesphere/pkg/simple/client/devops_mysql"
"net/http" "net/http"
"strings" "strings"
) )
func CreateProjectCredential(projectId, username string, credentialRequest *JenkinsCredential) (string, error) { func CreateProjectCredential(projectId, username string, credentialRequest *JenkinsCredential) (string, error) {
jenkinsClient := admin_jenkins.Client() devops, err := cs.ClientSets().Devops()
if jenkinsClient == nil { if err != nil {
err := fmt.Errorf("could not connect to jenkins")
glog.Error(err)
return "", restful.NewError(http.StatusServiceUnavailable, err.Error()) return "", restful.NewError(http.StatusServiceUnavailable, err.Error())
} }
err := checkJenkinsCredentialExists(projectId, credentialRequest.Domain, credentialRequest.Id) jenkinsClient := devops.Jenkins()
err = checkJenkinsCredentialExists(projectId, credentialRequest.Domain, credentialRequest.Id)
if err != nil { if err != nil {
glog.Errorf("%+v", err) glog.Errorf("%+v", err)
return "", err return "", err
} }
switch credentialRequest.Type { switch credentialRequest.Type {
case CredentialTypeUsernamePassword: case CredentialTypeUsernamePassword:
if credentialRequest.UsernamePasswordCredential == nil { if credentialRequest.UsernamePasswordCredential == nil {
...@@ -144,12 +144,12 @@ func CreateProjectCredential(projectId, username string, credentialRequest *Jenk ...@@ -144,12 +144,12 @@ func CreateProjectCredential(projectId, username string, credentialRequest *Jenk
} }
func UpdateProjectCredential(projectId, credentialId string, credentialRequest *JenkinsCredential) (string, error) { func UpdateProjectCredential(projectId, credentialId string, credentialRequest *JenkinsCredential) (string, error) {
jenkinsClient := admin_jenkins.Client() devops, err := cs.ClientSets().Devops()
if jenkinsClient == nil { if err != nil {
err := fmt.Errorf("could not connect to jenkins")
glog.Error(err)
return "", restful.NewError(http.StatusServiceUnavailable, err.Error()) return "", restful.NewError(http.StatusServiceUnavailable, err.Error())
} }
jenkinsClient := devops.Jenkins()
jenkinsCredential, err := jenkinsClient.GetCredentialInFolder(credentialRequest.Domain, jenkinsCredential, err := jenkinsClient.GetCredentialInFolder(credentialRequest.Domain,
credentialId, credentialId,
projectId) projectId)
...@@ -238,20 +238,25 @@ func UpdateProjectCredential(projectId, credentialId string, credentialRequest * ...@@ -238,20 +238,25 @@ func UpdateProjectCredential(projectId, credentialId string, credentialRequest *
} }
func DeleteProjectCredential(projectId, credentialId string, credentialRequest *JenkinsCredential) (string, error) { func DeleteProjectCredential(projectId, credentialId string, credentialRequest *JenkinsCredential) (string, error) {
jenkinsClient := admin_jenkins.Client() devops, err := cs.ClientSets().Devops()
if jenkinsClient == nil { if err != nil {
err := fmt.Errorf("could not connect to jenkins") return "", restful.NewError(http.StatusServiceUnavailable, err.Error())
glog.Error(err) }
jenkinsClient := devops.Jenkins()
dbClient, err := cs.ClientSets().MySQL()
if err != nil {
return "", restful.NewError(http.StatusServiceUnavailable, err.Error()) return "", restful.NewError(http.StatusServiceUnavailable, err.Error())
} }
dbClient := devops_mysql.OpenDatabase()
_, err := jenkinsClient.GetCredentialInFolder(credentialRequest.Domain, _, err = jenkinsClient.GetCredentialInFolder(credentialRequest.Domain,
credentialId, credentialId,
projectId) projectId)
if err != nil { if err != nil {
glog.Errorf("%+v", err) glog.Errorf("%+v", err)
return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
id, err := jenkinsClient.DeleteCredentialInFolder(credentialRequest.Domain, credentialId, projectId) id, err := jenkinsClient.DeleteCredentialInFolder(credentialRequest.Domain, credentialId, projectId)
if err != nil { if err != nil {
glog.Errorf("%+v", err) glog.Errorf("%+v", err)
...@@ -277,13 +282,16 @@ func DeleteProjectCredential(projectId, credentialId string, credentialRequest * ...@@ -277,13 +282,16 @@ func DeleteProjectCredential(projectId, credentialId string, credentialRequest *
} }
func GetProjectCredential(projectId, credentialId, domain, getContent string) (*JenkinsCredential, error) { func GetProjectCredential(projectId, credentialId, domain, getContent string) (*JenkinsCredential, error) {
jenkinsClient := admin_jenkins.Client() devops, err := cs.ClientSets().Devops()
if jenkinsClient == nil { if err != nil {
err := fmt.Errorf("could not connect to jenkins") return nil, restful.NewError(http.StatusServiceUnavailable, err.Error())
glog.Error(err) }
jenkinsClient := devops.Jenkins()
dbClient, err := cs.ClientSets().MySQL()
if err != nil {
return nil, restful.NewError(http.StatusServiceUnavailable, err.Error()) return nil, restful.NewError(http.StatusServiceUnavailable, err.Error())
} }
dbClient := devops_mysql.OpenDatabase()
jenkinsResponse, err := jenkinsClient.GetCredentialInFolder(domain, jenkinsResponse, err := jenkinsClient.GetCredentialInFolder(domain,
credentialId, credentialId,
projectId) projectId)
...@@ -352,13 +360,16 @@ func GetProjectCredential(projectId, credentialId, domain, getContent string) (* ...@@ -352,13 +360,16 @@ func GetProjectCredential(projectId, credentialId, domain, getContent string) (*
} }
func GetProjectCredentials(projectId, domain string) ([]*JenkinsCredential, error) { func GetProjectCredentials(projectId, domain string) ([]*JenkinsCredential, error) {
jenkinsClient := admin_jenkins.Client() devops, err := cs.ClientSets().Devops()
if jenkinsClient == nil { if err != nil {
err := fmt.Errorf("could not connect to jenkins") return nil, restful.NewError(http.StatusServiceUnavailable, err.Error())
glog.Error(err) }
jenkinsClient := devops.Jenkins()
dbClient, err := cs.ClientSets().MySQL()
if err != nil {
return nil, restful.NewError(http.StatusServiceUnavailable, err.Error()) return nil, restful.NewError(http.StatusServiceUnavailable, err.Error())
} }
dbClient := devops_mysql.OpenDatabase()
jenkinsCredentialResponses, err := jenkinsClient.GetCredentialsInFolder(domain, projectId) jenkinsCredentialResponses, err := jenkinsClient.GetCredentialsInFolder(domain, projectId)
if err != nil { if err != nil {
glog.Errorf("%+v", err) glog.Errorf("%+v", err)
...@@ -380,9 +391,13 @@ func GetProjectCredentials(projectId, domain string) ([]*JenkinsCredential, erro ...@@ -380,9 +391,13 @@ func GetProjectCredentials(projectId, domain string) ([]*JenkinsCredential, erro
} }
func insertCredentialToDb(projectId, credentialId, domain, username string) error { func insertCredentialToDb(projectId, credentialId, domain, username string) error {
dbClient := devops_mysql.OpenDatabase() dbClient, err := cs.ClientSets().MySQL()
if err != nil {
return err
}
projectCredential := NewProjectCredential(projectId, credentialId, domain, username) projectCredential := NewProjectCredential(projectId, credentialId, domain, username)
_, err := dbClient.InsertInto(ProjectCredentialTableName).Columns(ProjectCredentialColumns...). _, err = dbClient.InsertInto(ProjectCredentialTableName).Columns(ProjectCredentialColumns...).
Record(projectCredential).Exec() Record(projectCredential).Exec()
if err != nil { if err != nil {
glog.Errorf("%+v", err) glog.Errorf("%+v", err)
...@@ -392,12 +407,13 @@ func insertCredentialToDb(projectId, credentialId, domain, username string) erro ...@@ -392,12 +407,13 @@ func insertCredentialToDb(projectId, credentialId, domain, username string) erro
} }
func checkJenkinsCredentialExists(projectId, domain, credentialId string) error { func checkJenkinsCredentialExists(projectId, domain, credentialId string) error {
jenkinsClient := admin_jenkins.Client() devops, err := cs.ClientSets().Devops()
if jenkinsClient == nil { if err != nil {
err := fmt.Errorf("could not connect to jenkins")
glog.Error(err)
return restful.NewError(http.StatusServiceUnavailable, err.Error()) return restful.NewError(http.StatusServiceUnavailable, err.Error())
} }
jenkinsClient := devops.Jenkins()
credential, err := jenkinsClient.GetCredentialInFolder(domain, credentialId, projectId) credential, err := jenkinsClient.GetCredentialInFolder(domain, credentialId, projectId)
if credential != nil { if credential != nil {
err := fmt.Errorf("credential id [%s] has been used", credential.Id) err := fmt.Errorf("credential id [%s] has been used", credential.Id)
......
...@@ -19,14 +19,17 @@ import ( ...@@ -19,14 +19,17 @@ import (
"github.com/gocraft/dbr" "github.com/gocraft/dbr"
"github.com/golang/glog" "github.com/golang/glog"
"kubesphere.io/kubesphere/pkg/db" "kubesphere.io/kubesphere/pkg/db"
"kubesphere.io/kubesphere/pkg/simple/client/devops_mysql" cs "kubesphere.io/kubesphere/pkg/simple/client"
"net/http" "net/http"
) )
func GetProject(projectId string) (*DevOpsProject, error) { func GetProject(projectId string) (*DevOpsProject, error) {
dbconn := devops_mysql.OpenDatabase() dbconn, err := cs.ClientSets().MySQL()
if err != nil {
return nil, err
}
project := &DevOpsProject{} project := &DevOpsProject{}
err := dbconn.Select(DevOpsProjectColumns...). err = dbconn.Select(DevOpsProjectColumns...).
From(DevOpsProjectTableName). From(DevOpsProjectTableName).
Where(db.Eq(DevOpsProjectIdColumn, projectId)). Where(db.Eq(DevOpsProjectIdColumn, projectId)).
LoadOne(project) LoadOne(project)
...@@ -43,7 +46,11 @@ func GetProject(projectId string) (*DevOpsProject, error) { ...@@ -43,7 +46,11 @@ func GetProject(projectId string) (*DevOpsProject, error) {
} }
func UpdateProject(project *DevOpsProject) (*DevOpsProject, error) { func UpdateProject(project *DevOpsProject) (*DevOpsProject, error) {
dbconn := devops_mysql.OpenDatabase() dbconn, err := cs.ClientSets().MySQL()
if err != nil {
return nil, err
}
query := dbconn.Update(DevOpsProjectTableName) query := dbconn.Update(DevOpsProjectTableName)
if !govalidator.IsNull(project.Description) { if !govalidator.IsNull(project.Description) {
query.Set(DevOpsProjectDescriptionColumn, project.Description) query.Set(DevOpsProjectDescriptionColumn, project.Description)
...@@ -65,7 +72,7 @@ func UpdateProject(project *DevOpsProject) (*DevOpsProject, error) { ...@@ -65,7 +72,7 @@ func UpdateProject(project *DevOpsProject) (*DevOpsProject, error) {
} }
} }
newProject := &DevOpsProject{} newProject := &DevOpsProject{}
err := dbconn.Select(DevOpsProjectColumns...). err = dbconn.Select(DevOpsProjectColumns...).
From(DevOpsProjectTableName). From(DevOpsProjectTableName).
Where(db.Eq(DevOpsProjectIdColumn, project.ProjectId)). Where(db.Eq(DevOpsProjectIdColumn, project.ProjectId)).
LoadOne(newProject) LoadOne(newProject)
......
...@@ -14,22 +14,24 @@ package devops ...@@ -14,22 +14,24 @@ package devops
import ( import (
"fmt" "fmt"
"k8s.io/klog"
"net/http" "net/http"
"github.com/emicklei/go-restful" "github.com/emicklei/go-restful"
"github.com/gocraft/dbr" "github.com/gocraft/dbr"
"github.com/golang/glog"
"kubesphere.io/kubesphere/pkg/db" "kubesphere.io/kubesphere/pkg/db"
"kubesphere.io/kubesphere/pkg/gojenkins" "kubesphere.io/kubesphere/pkg/gojenkins"
"kubesphere.io/kubesphere/pkg/gojenkins/utils" "kubesphere.io/kubesphere/pkg/gojenkins/utils"
"kubesphere.io/kubesphere/pkg/models" "kubesphere.io/kubesphere/pkg/models"
"kubesphere.io/kubesphere/pkg/params" "kubesphere.io/kubesphere/pkg/params"
"kubesphere.io/kubesphere/pkg/simple/client/admin_jenkins" cs "kubesphere.io/kubesphere/pkg/simple/client"
"kubesphere.io/kubesphere/pkg/simple/client/devops_mysql"
) )
func GetProjectMembers(projectId string, conditions *params.Conditions, orderBy string, reverse bool, limit int, offset int) (*models.PageableResponse, error) { func GetProjectMembers(projectId string, conditions *params.Conditions, orderBy string, reverse bool, limit int, offset int) (*models.PageableResponse, error) {
dbconn := devops_mysql.OpenDatabase() dbconn, err := cs.ClientSets().MySQL()
if err != nil {
return nil, err
}
memberships := make([]*DevOpsProjectMembership, 0) memberships := make([]*DevOpsProjectMembership, 0)
var sqconditions []dbr.Builder var sqconditions []dbr.Builder
sqconditions = append(sqconditions, db.Eq(DevOpsProjectMembershipProjectIdColumn, projectId)) sqconditions = append(sqconditions, db.Eq(DevOpsProjectMembershipProjectIdColumn, projectId))
...@@ -59,14 +61,14 @@ func GetProjectMembers(projectId string, conditions *params.Conditions, orderBy ...@@ -59,14 +61,14 @@ func GetProjectMembers(projectId string, conditions *params.Conditions, orderBy
} else { } else {
query.Where(sqconditions[0]) query.Where(sqconditions[0])
} }
_, err := query.Load(&memberships) _, err = query.Load(&memberships)
if err != nil && err != dbr.ErrNotFound { if err != nil && err != dbr.ErrNotFound {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(http.StatusInternalServerError, err.Error()) return nil, restful.NewError(http.StatusInternalServerError, err.Error())
} }
count, err := query.Count() count, err := query.Count()
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(http.StatusInternalServerError, err.Error()) return nil, restful.NewError(http.StatusInternalServerError, err.Error())
} }
result := make([]interface{}, 0) result := make([]interface{}, 0)
...@@ -78,35 +80,46 @@ func GetProjectMembers(projectId string, conditions *params.Conditions, orderBy ...@@ -78,35 +80,46 @@ func GetProjectMembers(projectId string, conditions *params.Conditions, orderBy
} }
func GetProjectMember(projectId, username string) (*DevOpsProjectMembership, error) { func GetProjectMember(projectId, username string) (*DevOpsProjectMembership, error) {
dbconn := devops_mysql.OpenDatabase() dbconn, err := cs.ClientSets().MySQL()
if err != nil {
return nil, err
}
member := &DevOpsProjectMembership{} member := &DevOpsProjectMembership{}
err := dbconn.Select(DevOpsProjectMembershipColumns...). err = dbconn.Select(DevOpsProjectMembershipColumns...).
From(DevOpsProjectMembershipTableName). From(DevOpsProjectMembershipTableName).
Where(db.And(db.Eq(DevOpsProjectMembershipProjectIdColumn, projectId), Where(db.And(db.Eq(DevOpsProjectMembershipProjectIdColumn, projectId),
db.Eq(DevOpsProjectMembershipUsernameColumn, username))). db.Eq(DevOpsProjectMembershipUsernameColumn, username))).
LoadOne(&member) LoadOne(&member)
if err != nil && err != dbr.ErrNotFound { if err != nil && err != dbr.ErrNotFound {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(http.StatusInternalServerError, err.Error()) return nil, restful.NewError(http.StatusInternalServerError, err.Error())
} }
if err == dbr.ErrNotFound { if err == dbr.ErrNotFound {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(http.StatusNotFound, err.Error()) return nil, restful.NewError(http.StatusNotFound, err.Error())
} }
return member, nil return member, nil
} }
func AddProjectMember(projectId, operator string, member *DevOpsProjectMembership) (*DevOpsProjectMembership, error) { func AddProjectMember(projectId, operator string, member *DevOpsProjectMembership) (*DevOpsProjectMembership, error) {
dbconn := devops_mysql.OpenDatabase() dbconn, err := cs.ClientSets().MySQL()
jenkinsClient := admin_jenkins.Client() if err != nil {
return nil, err
}
devops, err := cs.ClientSets().Devops()
if err != nil {
return nil, err
}
jenkinsClient := devops.Jenkins()
if jenkinsClient == nil { if jenkinsClient == nil {
err := fmt.Errorf("could not connect to jenkins") err := fmt.Errorf("could not connect to jenkins")
glog.Error(err) klog.Error(err)
return nil, restful.NewError(http.StatusServiceUnavailable, err.Error()) return nil, restful.NewError(http.StatusServiceUnavailable, err.Error())
} }
membership := &DevOpsProjectMembership{} membership := &DevOpsProjectMembership{}
err := dbconn.Select(DevOpsProjectMembershipColumns...). err = dbconn.Select(DevOpsProjectMembershipColumns...).
From(DevOpsProjectMembershipTableName). From(DevOpsProjectMembershipTableName).
Where(db.And( Where(db.And(
db.Eq(DevOpsProjectMembershipUsernameColumn, member.Username), db.Eq(DevOpsProjectMembershipUsernameColumn, member.Username),
...@@ -114,18 +127,18 @@ func AddProjectMember(projectId, operator string, member *DevOpsProjectMembershi ...@@ -114,18 +127,18 @@ func AddProjectMember(projectId, operator string, member *DevOpsProjectMembershi
// if user could be founded in db, user have been added to project // if user could be founded in db, user have been added to project
if err == nil { if err == nil {
err = fmt.Errorf("user [%s] have been added to project", member.Username) err = fmt.Errorf("user [%s] have been added to project", member.Username)
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(http.StatusBadRequest, err.Error()) return nil, restful.NewError(http.StatusBadRequest, err.Error())
} }
if err != nil && err != db.ErrNotFound { if err != db.ErrNotFound {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(http.StatusInternalServerError, err.Error()) return nil, restful.NewError(http.StatusInternalServerError, err.Error())
} }
globalRole, err := jenkinsClient.GetGlobalRole(JenkinsAllUserRoleName) globalRole, err := jenkinsClient.GetGlobalRole(JenkinsAllUserRoleName)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
if globalRole == nil { if globalRole == nil {
...@@ -133,33 +146,33 @@ func AddProjectMember(projectId, operator string, member *DevOpsProjectMembershi ...@@ -133,33 +146,33 @@ func AddProjectMember(projectId, operator string, member *DevOpsProjectMembershi
GlobalRead: true, GlobalRead: true,
}, true) }, true)
if err != nil { if err != nil {
glog.Errorf("failed to create jenkins global role %+v", err) klog.Errorf("failed to create jenkins global role %+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
} }
err = globalRole.AssignRole(member.Username) err = globalRole.AssignRole(member.Username)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
projectRole, err := jenkinsClient.GetProjectRole(GetProjectRoleName(projectId, member.Role)) projectRole, err := jenkinsClient.GetProjectRole(GetProjectRoleName(projectId, member.Role))
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
err = projectRole.AssignRole(member.Username) err = projectRole.AssignRole(member.Username)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
pipelineRole, err := jenkinsClient.GetProjectRole(GetPipelineRoleName(projectId, member.Role)) pipelineRole, err := jenkinsClient.GetProjectRole(GetPipelineRoleName(projectId, member.Role))
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
err = pipelineRole.AssignRole(member.Username) err = pipelineRole.AssignRole(member.Username)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
projectMembership := NewDevOpsProjectMemberShip(member.Username, projectId, member.Role, operator) projectMembership := NewDevOpsProjectMemberShip(member.Username, projectId, member.Role, operator)
...@@ -168,15 +181,15 @@ func AddProjectMember(projectId, operator string, member *DevOpsProjectMembershi ...@@ -168,15 +181,15 @@ func AddProjectMember(projectId, operator string, member *DevOpsProjectMembershi
Columns(DevOpsProjectMembershipColumns...). Columns(DevOpsProjectMembershipColumns...).
Record(projectMembership).Exec() Record(projectMembership).Exec()
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
err = projectRole.UnAssignRole(member.Username) err = projectRole.UnAssignRole(member.Username)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
err = pipelineRole.UnAssignRole(member.Username) err = pipelineRole.UnAssignRole(member.Username)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
return nil, restful.NewError(http.StatusInternalServerError, err.Error()) return nil, restful.NewError(http.StatusInternalServerError, err.Error())
...@@ -185,66 +198,82 @@ func AddProjectMember(projectId, operator string, member *DevOpsProjectMembershi ...@@ -185,66 +198,82 @@ func AddProjectMember(projectId, operator string, member *DevOpsProjectMembershi
} }
func UpdateProjectMember(projectId, operator string, member *DevOpsProjectMembership) (*DevOpsProjectMembership, error) { func UpdateProjectMember(projectId, operator string, member *DevOpsProjectMembership) (*DevOpsProjectMembership, error) {
dbconn := devops_mysql.OpenDatabase() dbconn, err := cs.ClientSets().MySQL()
jenkinsClient := admin_jenkins.Client() if err != nil {
return nil, restful.NewError(http.StatusServiceUnavailable, err.Error())
}
devops, err := cs.ClientSets().Devops()
if err != nil {
return nil, err
}
jenkinsClient := devops.Jenkins()
if jenkinsClient == nil { if jenkinsClient == nil {
err := fmt.Errorf("could not connect to jenkins") err := fmt.Errorf("could not connect to jenkins")
glog.Error(err) klog.Error(err)
return nil, restful.NewError(http.StatusServiceUnavailable, err.Error()) return nil, restful.NewError(http.StatusServiceUnavailable, err.Error())
} }
oldMembership := &DevOpsProjectMembership{} oldMembership := &DevOpsProjectMembership{}
err := dbconn.Select(DevOpsProjectMembershipColumns...). err = dbconn.Select(DevOpsProjectMembershipColumns...).
From(DevOpsProjectMembershipTableName). From(DevOpsProjectMembershipTableName).
Where(db.And( Where(db.And(
db.Eq(DevOpsProjectMembershipUsernameColumn, member.Username), db.Eq(DevOpsProjectMembershipUsernameColumn, member.Username),
db.Eq(DevOpsProjectMembershipProjectIdColumn, projectId), db.Eq(DevOpsProjectMembershipProjectIdColumn, projectId),
)).LoadOne(oldMembership) )).LoadOne(oldMembership)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(http.StatusBadRequest, err.Error()) return nil, restful.NewError(http.StatusBadRequest, err.Error())
} }
oldProjectRole, err := jenkinsClient.GetProjectRole(GetProjectRoleName(projectId, oldMembership.Role)) oldProjectRole, err := jenkinsClient.GetProjectRole(GetProjectRoleName(projectId, oldMembership.Role))
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
err = oldProjectRole.UnAssignRole(member.Username) err = oldProjectRole.UnAssignRole(member.Username)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
oldPipelineRole, err := jenkinsClient.GetProjectRole(GetPipelineRoleName(projectId, oldMembership.Role)) oldPipelineRole, err := jenkinsClient.GetProjectRole(GetPipelineRoleName(projectId, oldMembership.Role))
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
err = oldPipelineRole.UnAssignRole(member.Username) err = oldPipelineRole.UnAssignRole(member.Username)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
projectRole, err := jenkinsClient.GetProjectRole(GetProjectRoleName(projectId, member.Role)) projectRole, err := jenkinsClient.GetProjectRole(GetProjectRoleName(projectId, member.Role))
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
err = projectRole.AssignRole(member.Username) err = projectRole.AssignRole(member.Username)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
pipelineRole, err := jenkinsClient.GetProjectRole(GetPipelineRoleName(projectId, member.Role)) pipelineRole, err := jenkinsClient.GetProjectRole(GetPipelineRoleName(projectId, member.Role))
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
err = pipelineRole.AssignRole(member.Username) err = pipelineRole.AssignRole(member.Username)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
_, err = dbconn.Update(DevOpsProjectMembershipTableName). _, err = dbconn.Update(DevOpsProjectMembershipTableName).
Set(DevOpsProjectMembershipRoleColumn, member.Role). Set(DevOpsProjectMembershipRoleColumn, member.Role).
Where(db.And( Where(db.And(
...@@ -252,9 +281,10 @@ func UpdateProjectMember(projectId, operator string, member *DevOpsProjectMember ...@@ -252,9 +281,10 @@ func UpdateProjectMember(projectId, operator string, member *DevOpsProjectMember
db.Eq(DevOpsProjectMembershipUsernameColumn, member.Username), db.Eq(DevOpsProjectMembershipUsernameColumn, member.Username),
)).Exec() )).Exec()
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(http.StatusInternalServerError, err.Error()) return nil, restful.NewError(http.StatusInternalServerError, err.Error())
} }
responseMembership := &DevOpsProjectMembership{} responseMembership := &DevOpsProjectMembership{}
err = dbconn.Select(DevOpsProjectMembershipColumns...). err = dbconn.Select(DevOpsProjectMembershipColumns...).
From(DevOpsProjectMembershipTableName). From(DevOpsProjectMembershipTableName).
...@@ -263,35 +293,42 @@ func UpdateProjectMember(projectId, operator string, member *DevOpsProjectMember ...@@ -263,35 +293,42 @@ func UpdateProjectMember(projectId, operator string, member *DevOpsProjectMember
db.Eq(DevOpsProjectMembershipProjectIdColumn, projectId), db.Eq(DevOpsProjectMembershipProjectIdColumn, projectId),
)).LoadOne(responseMembership) )).LoadOne(responseMembership)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(http.StatusInternalServerError, err.Error()) return nil, restful.NewError(http.StatusInternalServerError, err.Error())
} }
return responseMembership, nil return responseMembership, nil
} }
func DeleteProjectMember(projectId, username string) (string, error) { func DeleteProjectMember(projectId, username string) (string, error) {
dbconn := devops_mysql.OpenDatabase() dbconn, err := cs.ClientSets().MySQL()
jenkinsClient := admin_jenkins.Client() if err != nil {
if jenkinsClient == nil { return "", restful.NewError(http.StatusServiceUnavailable, err.Error())
err := fmt.Errorf("could not connect to jenkins") }
glog.Error(err)
devops, err := cs.ClientSets().Devops()
if err != nil {
return "", restful.NewError(http.StatusServiceUnavailable, err.Error()) return "", restful.NewError(http.StatusServiceUnavailable, err.Error())
} }
jenkinsClient := devops.Jenkins()
oldMembership := &DevOpsProjectMembership{} oldMembership := &DevOpsProjectMembership{}
err := dbconn.Select(DevOpsProjectMembershipColumns...). err = dbconn.Select(DevOpsProjectMembershipColumns...).
From(DevOpsProjectMembershipTableName). From(DevOpsProjectMembershipTableName).
Where(db.And( Where(db.And(
db.Eq(DevOpsProjectMembershipUsernameColumn, username), db.Eq(DevOpsProjectMembershipUsernameColumn, username),
db.Eq(DevOpsProjectMembershipProjectIdColumn, projectId), db.Eq(DevOpsProjectMembershipProjectIdColumn, projectId),
)).LoadOne(oldMembership) )).LoadOne(oldMembership)
if err != nil && err != db.ErrNotFound { if err != nil {
glog.Errorf("%+v", err) if err != db.ErrNotFound {
return "", restful.NewError(http.StatusInternalServerError, err.Error()) klog.Errorf("%+v", err)
} return "", restful.NewError(http.StatusInternalServerError, err.Error())
if err == db.ErrNotFound { } else if err == db.ErrNotFound {
glog.Warningf("user [%s] not found in project", username) klog.Warningf("user [%s] not found in project", username)
return username, nil return username, nil
}
} }
if oldMembership.Role == ProjectOwner { if oldMembership.Role == ProjectOwner {
count, err := dbconn.Select(DevOpsProjectMembershipProjectIdColumn). count, err := dbconn.Select(DevOpsProjectMembershipProjectIdColumn).
From(DevOpsProjectMembershipTableName). From(DevOpsProjectMembershipTableName).
...@@ -299,34 +336,35 @@ func DeleteProjectMember(projectId, username string) (string, error) { ...@@ -299,34 +336,35 @@ func DeleteProjectMember(projectId, username string) (string, error) {
db.Eq(DevOpsProjectMembershipProjectIdColumn, projectId), db.Eq(DevOpsProjectMembershipProjectIdColumn, projectId),
db.Eq(DevOpsProjectMembershipRoleColumn, ProjectOwner))).Count() db.Eq(DevOpsProjectMembershipRoleColumn, ProjectOwner))).Count()
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(http.StatusInternalServerError, err.Error()) return "", restful.NewError(http.StatusInternalServerError, err.Error())
} }
if count == 1 { if count == 1 {
err = fmt.Errorf("project must has at least one admin") err = fmt.Errorf("project must has at least one admin")
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(http.StatusBadRequest, err.Error()) return "", restful.NewError(http.StatusBadRequest, err.Error())
} }
} }
oldProjectRole, err := jenkinsClient.GetProjectRole(GetProjectRoleName(projectId, oldMembership.Role)) oldProjectRole, err := jenkinsClient.GetProjectRole(GetProjectRoleName(projectId, oldMembership.Role))
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
err = oldProjectRole.UnAssignRole(username) err = oldProjectRole.UnAssignRole(username)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
oldPipelineRole, err := jenkinsClient.GetProjectRole(GetPipelineRoleName(projectId, oldMembership.Role)) oldPipelineRole, err := jenkinsClient.GetProjectRole(GetPipelineRoleName(projectId, oldMembership.Role))
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
err = oldPipelineRole.UnAssignRole(username) err = oldPipelineRole.UnAssignRole(username)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
...@@ -336,7 +374,7 @@ func DeleteProjectMember(projectId, username string) (string, error) { ...@@ -336,7 +374,7 @@ func DeleteProjectMember(projectId, username string) (string, error) {
db.Eq(DevOpsProjectMembershipUsernameColumn, username), db.Eq(DevOpsProjectMembershipUsernameColumn, username),
)).Exec() )).Exec()
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(http.StatusInternalServerError, err.Error()) return "", restful.NewError(http.StatusInternalServerError, err.Error())
} }
return username, nil return username, nil
......
...@@ -19,7 +19,7 @@ import ( ...@@ -19,7 +19,7 @@ import (
"github.com/golang/glog" "github.com/golang/glog"
"github.com/kubesphere/sonargo/sonar" "github.com/kubesphere/sonargo/sonar"
"kubesphere.io/kubesphere/pkg/gojenkins" "kubesphere.io/kubesphere/pkg/gojenkins"
"kubesphere.io/kubesphere/pkg/simple/client/sonarqube" "kubesphere.io/kubesphere/pkg/simple/client"
"strconv" "strconv"
"strings" "strings"
"time" "time"
...@@ -175,7 +175,7 @@ type RemoteTrigger struct { ...@@ -175,7 +175,7 @@ type RemoteTrigger struct {
} }
func replaceXmlVersion(config, oldVersion, targetVersion string) string { func replaceXmlVersion(config, oldVersion, targetVersion string) string {
lines := strings.Split(string(config), "\n") lines := strings.Split(config, "\n")
lines[0] = strings.Replace(lines[0], oldVersion, targetVersion, -1) lines[0] = strings.Replace(lines[0], oldVersion, targetVersion, -1)
output := strings.Join(lines, "\n") output := strings.Join(lines, "\n")
return output return output
...@@ -1077,7 +1077,12 @@ func toCrontab(millis int64) string { ...@@ -1077,7 +1077,12 @@ func toCrontab(millis int64) string {
} }
func getBuildSonarResults(build *gojenkins.Build) ([]*SonarStatus, error) { func getBuildSonarResults(build *gojenkins.Build) ([]*SonarStatus, error) {
sonarClient := sonarqube.Client()
sonarClient, err := client.ClientSets().SonarQube()
if err != nil {
return nil, err
}
actions := build.GetActions() actions := build.GetActions()
sonarStatuses := make([]*SonarStatus, 0) sonarStatuses := make([]*SonarStatus, 0)
for _, action := range actions { for _, action := range actions {
...@@ -1086,7 +1091,7 @@ func getBuildSonarResults(build *gojenkins.Build) ([]*SonarStatus, error) { ...@@ -1086,7 +1091,7 @@ func getBuildSonarResults(build *gojenkins.Build) ([]*SonarStatus, error) {
taskOptions := &sonargo.CeTaskOption{ taskOptions := &sonargo.CeTaskOption{
Id: action.SonarTaskId, Id: action.SonarTaskId,
} }
ceTask, _, err := sonarClient.Ce.Task(taskOptions) ceTask, _, err := sonarClient.SonarQube().Ce.Task(taskOptions)
if err != nil { if err != nil {
glog.Errorf("get sonar task error [%+v]", err) glog.Errorf("get sonar task error [%+v]", err)
continue continue
...@@ -1097,7 +1102,7 @@ func getBuildSonarResults(build *gojenkins.Build) ([]*SonarStatus, error) { ...@@ -1097,7 +1102,7 @@ func getBuildSonarResults(build *gojenkins.Build) ([]*SonarStatus, error) {
AdditionalFields: SonarAdditionalFields, AdditionalFields: SonarAdditionalFields,
MetricKeys: SonarMetricKeys, MetricKeys: SonarMetricKeys,
} }
measures, _, err := sonarClient.Measures.Component(measuresComponentOption) measures, _, err := sonarClient.SonarQube().Measures.Component(measuresComponentOption)
if err != nil { if err != nil {
glog.Errorf("get sonar task error [%+v]", err) glog.Errorf("get sonar task error [%+v]", err)
continue continue
...@@ -1112,7 +1117,7 @@ func getBuildSonarResults(build *gojenkins.Build) ([]*SonarStatus, error) { ...@@ -1112,7 +1117,7 @@ func getBuildSonarResults(build *gojenkins.Build) ([]*SonarStatus, error) {
S: "FILE_LINE", S: "FILE_LINE",
Facets: "severities,types", Facets: "severities,types",
} }
issuesSearch, _, err := sonarClient.Issues.Search(issuesSearchOption) issuesSearch, _, err := sonarClient.SonarQube().Issues.Search(issuesSearchOption)
sonarStatus.Issues = issuesSearch sonarStatus.Issues = issuesSearch
jenkinsAction := action jenkinsAction := action
sonarStatus.JenkinsAction = &jenkinsAction sonarStatus.JenkinsAction = &jenkinsAction
......
...@@ -16,43 +16,43 @@ package devops ...@@ -16,43 +16,43 @@ package devops
import ( import (
"fmt" "fmt"
"github.com/emicklei/go-restful" "github.com/emicklei/go-restful"
"github.com/golang/glog" "k8s.io/klog"
"kubesphere.io/kubesphere/pkg/gojenkins/utils" "kubesphere.io/kubesphere/pkg/gojenkins/utils"
"kubesphere.io/kubesphere/pkg/simple/client/admin_jenkins" cs "kubesphere.io/kubesphere/pkg/simple/client"
"net/http" "net/http"
) )
func CreateProjectPipeline(projectId string, pipeline *ProjectPipeline) (string, error) { func CreateProjectPipeline(projectId string, pipeline *ProjectPipeline) (string, error) {
jenkinsClient := admin_jenkins.Client() devops, err := cs.ClientSets().Devops()
if jenkinsClient == nil { if err != nil {
err := fmt.Errorf("could not connect to jenkins")
glog.Error(err)
return "", restful.NewError(http.StatusServiceUnavailable, err.Error()) return "", restful.NewError(http.StatusServiceUnavailable, err.Error())
} }
jenkinsClient := devops.Jenkins()
switch pipeline.Type { switch pipeline.Type {
case NoScmPipelineType: case NoScmPipelineType:
config, err := createPipelineConfigXml(pipeline.Pipeline) config, err := createPipelineConfigXml(pipeline.Pipeline)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(http.StatusInternalServerError, err.Error()) return "", restful.NewError(http.StatusInternalServerError, err.Error())
} }
job, err := jenkinsClient.GetJob(pipeline.Pipeline.Name, projectId) job, err := jenkinsClient.GetJob(pipeline.Pipeline.Name, projectId)
if job != nil { if job != nil {
err := fmt.Errorf("job name [%s] has been used", job.GetName()) err := fmt.Errorf("job name [%s] has been used", job.GetName())
glog.Warning(err.Error()) klog.Warning(err.Error())
return "", restful.NewError(http.StatusConflict, err.Error()) return "", restful.NewError(http.StatusConflict, err.Error())
} }
if err != nil && utils.GetJenkinsStatusCode(err) != http.StatusNotFound { if err != nil && utils.GetJenkinsStatusCode(err) != http.StatusNotFound {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
_, err = jenkinsClient.CreateJobInFolder(config, pipeline.Pipeline.Name, projectId) _, err = jenkinsClient.CreateJobInFolder(config, pipeline.Pipeline.Name, projectId)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
...@@ -60,7 +60,7 @@ func CreateProjectPipeline(projectId string, pipeline *ProjectPipeline) (string, ...@@ -60,7 +60,7 @@ func CreateProjectPipeline(projectId string, pipeline *ProjectPipeline) (string,
case MultiBranchPipelineType: case MultiBranchPipelineType:
config, err := createMultiBranchPipelineConfigXml(projectId, pipeline.MultiBranchPipeline) config, err := createMultiBranchPipelineConfigXml(projectId, pipeline.MultiBranchPipeline)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(http.StatusInternalServerError, err.Error()) return "", restful.NewError(http.StatusInternalServerError, err.Error())
} }
...@@ -68,18 +68,18 @@ func CreateProjectPipeline(projectId string, pipeline *ProjectPipeline) (string, ...@@ -68,18 +68,18 @@ func CreateProjectPipeline(projectId string, pipeline *ProjectPipeline) (string,
job, err := jenkinsClient.GetJob(pipeline.MultiBranchPipeline.Name, projectId) job, err := jenkinsClient.GetJob(pipeline.MultiBranchPipeline.Name, projectId)
if job != nil { if job != nil {
err := fmt.Errorf("job name [%s] has been used", job.GetName()) err := fmt.Errorf("job name [%s] has been used", job.GetName())
glog.Warning(err.Error()) klog.Warning(err.Error())
return "", restful.NewError(http.StatusConflict, err.Error()) return "", restful.NewError(http.StatusConflict, err.Error())
} }
if err != nil && utils.GetJenkinsStatusCode(err) != http.StatusNotFound { if err != nil && utils.GetJenkinsStatusCode(err) != http.StatusNotFound {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
_, err = jenkinsClient.CreateJobInFolder(config, pipeline.MultiBranchPipeline.Name, projectId) _, err = jenkinsClient.CreateJobInFolder(config, pipeline.MultiBranchPipeline.Name, projectId)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
...@@ -87,52 +87,52 @@ func CreateProjectPipeline(projectId string, pipeline *ProjectPipeline) (string, ...@@ -87,52 +87,52 @@ func CreateProjectPipeline(projectId string, pipeline *ProjectPipeline) (string,
default: default:
err := fmt.Errorf("error unsupport job type") err := fmt.Errorf("error unsupport job type")
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(http.StatusBadRequest, err.Error()) return "", restful.NewError(http.StatusBadRequest, err.Error())
} }
} }
func DeleteProjectPipeline(projectId string, pipelineId string) (string, error) { func DeleteProjectPipeline(projectId string, pipelineId string) (string, error) {
jenkinsClient := admin_jenkins.Client() devops, err := cs.ClientSets().Devops()
if jenkinsClient == nil { if err != nil {
err := fmt.Errorf("could not connect to jenkins")
glog.Error(err)
return "", restful.NewError(http.StatusServiceUnavailable, err.Error()) return "", restful.NewError(http.StatusServiceUnavailable, err.Error())
} }
_, err := jenkinsClient.DeleteJob(pipelineId, projectId) jenkinsClient := devops.Jenkins()
_, err = jenkinsClient.DeleteJob(pipelineId, projectId)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
return pipelineId, nil return pipelineId, nil
} }
func UpdateProjectPipeline(projectId, pipelineId string, pipeline *ProjectPipeline) (string, error) { func UpdateProjectPipeline(projectId, pipelineId string, pipeline *ProjectPipeline) (string, error) {
jenkinsClient := admin_jenkins.Client() devops, err := cs.ClientSets().Devops()
if jenkinsClient == nil { if err != nil {
err := fmt.Errorf("could not connect to jenkins")
glog.Error(err)
return "", restful.NewError(http.StatusServiceUnavailable, err.Error()) return "", restful.NewError(http.StatusServiceUnavailable, err.Error())
} }
jenkinsClient := devops.Jenkins()
switch pipeline.Type { switch pipeline.Type {
case NoScmPipelineType: case NoScmPipelineType:
config, err := createPipelineConfigXml(pipeline.Pipeline) config, err := createPipelineConfigXml(pipeline.Pipeline)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(http.StatusInternalServerError, err.Error()) return "", restful.NewError(http.StatusInternalServerError, err.Error())
} }
job, err := jenkinsClient.GetJob(pipelineId, projectId) job, err := jenkinsClient.GetJob(pipelineId, projectId)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
err = job.UpdateConfig(config) err = job.UpdateConfig(config)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
...@@ -141,7 +141,7 @@ func UpdateProjectPipeline(projectId, pipelineId string, pipeline *ProjectPipeli ...@@ -141,7 +141,7 @@ func UpdateProjectPipeline(projectId, pipelineId string, pipeline *ProjectPipeli
config, err := createMultiBranchPipelineConfigXml(projectId, pipeline.MultiBranchPipeline) config, err := createMultiBranchPipelineConfigXml(projectId, pipeline.MultiBranchPipeline)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(http.StatusInternalServerError, err.Error()) return "", restful.NewError(http.StatusInternalServerError, err.Error())
} }
...@@ -149,13 +149,13 @@ func UpdateProjectPipeline(projectId, pipelineId string, pipeline *ProjectPipeli ...@@ -149,13 +149,13 @@ func UpdateProjectPipeline(projectId, pipelineId string, pipeline *ProjectPipeli
job, err := jenkinsClient.GetJob(pipelineId, projectId) job, err := jenkinsClient.GetJob(pipelineId, projectId)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
err = job.UpdateConfig(config) err = job.UpdateConfig(config)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return "", restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
...@@ -163,33 +163,33 @@ func UpdateProjectPipeline(projectId, pipelineId string, pipeline *ProjectPipeli ...@@ -163,33 +163,33 @@ func UpdateProjectPipeline(projectId, pipelineId string, pipeline *ProjectPipeli
default: default:
err := fmt.Errorf("error unsupport job type") err := fmt.Errorf("error unsupport job type")
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return "", restful.NewError(http.StatusBadRequest, err.Error()) return "", restful.NewError(http.StatusBadRequest, err.Error())
} }
} }
func GetProjectPipeline(projectId, pipelineId string) (*ProjectPipeline, error) { func GetProjectPipeline(projectId, pipelineId string) (*ProjectPipeline, error) {
jenkinsClient := admin_jenkins.Client() devops, err := cs.ClientSets().Devops()
if jenkinsClient == nil { if err != nil {
err := fmt.Errorf("could not connect to jenkins")
glog.Error(err)
return nil, restful.NewError(http.StatusServiceUnavailable, err.Error()) return nil, restful.NewError(http.StatusServiceUnavailable, err.Error())
} }
jenkinsClient := devops.Jenkins()
job, err := jenkinsClient.GetJob(pipelineId, projectId) job, err := jenkinsClient.GetJob(pipelineId, projectId)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
switch job.Raw.Class { switch job.Raw.Class {
case "org.jenkinsci.plugins.workflow.job.WorkflowJob": case "org.jenkinsci.plugins.workflow.job.WorkflowJob":
config, err := job.GetConfig() config, err := job.GetConfig()
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
pipeline, err := parsePipelineConfigXml(config) pipeline, err := parsePipelineConfigXml(config)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
pipeline.Name = pipelineId pipeline.Name = pipelineId
...@@ -201,12 +201,12 @@ func GetProjectPipeline(projectId, pipelineId string) (*ProjectPipeline, error) ...@@ -201,12 +201,12 @@ func GetProjectPipeline(projectId, pipelineId string) (*ProjectPipeline, error)
case "org.jenkinsci.plugins.workflow.multibranch.WorkflowMultiBranchProject": case "org.jenkinsci.plugins.workflow.multibranch.WorkflowMultiBranchProject":
config, err := job.GetConfig() config, err := job.GetConfig()
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
pipeline, err := parseMultiBranchPipelineConfigXml(config) pipeline, err := parseMultiBranchPipelineConfigXml(config)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
pipeline.Name = pipelineId pipeline.Name = pipelineId
...@@ -216,50 +216,50 @@ func GetProjectPipeline(projectId, pipelineId string) (*ProjectPipeline, error) ...@@ -216,50 +216,50 @@ func GetProjectPipeline(projectId, pipelineId string) (*ProjectPipeline, error)
}, nil }, nil
default: default:
err := fmt.Errorf("error unsupport job type") err := fmt.Errorf("error unsupport job type")
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(http.StatusBadRequest, err.Error()) return nil, restful.NewError(http.StatusBadRequest, err.Error())
} }
} }
func GetPipelineSonar(projectId, pipelineId string) ([]*SonarStatus, error) { func GetPipelineSonar(projectId, pipelineId string) ([]*SonarStatus, error) {
jenkinsClient := admin_jenkins.Client() devops, err := cs.ClientSets().Devops()
if jenkinsClient == nil { if err != nil {
err := fmt.Errorf("could not connect to jenkins")
glog.Error(err)
return nil, restful.NewError(http.StatusServiceUnavailable, err.Error()) return nil, restful.NewError(http.StatusServiceUnavailable, err.Error())
} }
jenkinsClient := devops.Jenkins()
job, err := jenkinsClient.GetJob(pipelineId, projectId) job, err := jenkinsClient.GetJob(pipelineId, projectId)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
build, err := job.GetLastBuild() build, err := job.GetLastBuild()
if err != nil && utils.GetJenkinsStatusCode(err) != http.StatusNotFound { if err != nil && utils.GetJenkinsStatusCode(err) != http.StatusNotFound {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} else if err != nil { } else if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, nil return nil, nil
} }
sonarStatus, err := getBuildSonarResults(build) sonarStatus, err := getBuildSonarResults(build)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(http.StatusBadRequest, err.Error()) return nil, restful.NewError(http.StatusBadRequest, err.Error())
} }
if len(sonarStatus) == 0 { if len(sonarStatus) == 0 {
build, err := job.GetLastCompletedBuild() build, err := job.GetLastCompletedBuild()
if err != nil && utils.GetJenkinsStatusCode(err) != http.StatusNotFound { if err != nil && utils.GetJenkinsStatusCode(err) != http.StatusNotFound {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} else if err != nil { } else if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, nil return nil, nil
} }
sonarStatus, err = getBuildSonarResults(build) sonarStatus, err = getBuildSonarResults(build)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(http.StatusBadRequest, err.Error()) return nil, restful.NewError(http.StatusBadRequest, err.Error())
} }
} }
...@@ -267,43 +267,43 @@ func GetPipelineSonar(projectId, pipelineId string) ([]*SonarStatus, error) { ...@@ -267,43 +267,43 @@ func GetPipelineSonar(projectId, pipelineId string) ([]*SonarStatus, error) {
} }
func GetMultiBranchPipelineSonar(projectId, pipelineId, branchId string) ([]*SonarStatus, error) { func GetMultiBranchPipelineSonar(projectId, pipelineId, branchId string) ([]*SonarStatus, error) {
jenkinsClient := admin_jenkins.Client() devops, err := cs.ClientSets().Devops()
if jenkinsClient == nil { if err != nil {
err := fmt.Errorf("could not connect to jenkins")
glog.Error(err)
return nil, restful.NewError(http.StatusServiceUnavailable, err.Error()) return nil, restful.NewError(http.StatusServiceUnavailable, err.Error())
} }
jenkinsClient := devops.Jenkins()
job, err := jenkinsClient.GetJob(branchId, projectId, pipelineId) job, err := jenkinsClient.GetJob(branchId, projectId, pipelineId)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} }
build, err := job.GetLastBuild() build, err := job.GetLastBuild()
if err != nil && utils.GetJenkinsStatusCode(err) != http.StatusNotFound { if err != nil && utils.GetJenkinsStatusCode(err) != http.StatusNotFound {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} else if err != nil { } else if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, nil return nil, nil
} }
sonarStatus, err := getBuildSonarResults(build) sonarStatus, err := getBuildSonarResults(build)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(http.StatusBadRequest, err.Error()) return nil, restful.NewError(http.StatusBadRequest, err.Error())
} }
if len(sonarStatus) == 0 { if len(sonarStatus) == 0 {
build, err := job.GetLastCompletedBuild() build, err := job.GetLastCompletedBuild()
if err != nil && utils.GetJenkinsStatusCode(err) != http.StatusNotFound { if err != nil && utils.GetJenkinsStatusCode(err) != http.StatusNotFound {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error()) return nil, restful.NewError(utils.GetJenkinsStatusCode(err), err.Error())
} else if err != nil { } else if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, nil return nil, nil
} }
sonarStatus, err = getBuildSonarResults(build) sonarStatus, err = getBuildSonarResults(build)
if err != nil { if err != nil {
glog.Errorf("%+v", err) klog.Errorf("%+v", err)
return nil, restful.NewError(http.StatusBadRequest, err.Error()) return nil, restful.NewError(http.StatusBadRequest, err.Error())
} }
} }
......
...@@ -20,17 +20,17 @@ import ( ...@@ -20,17 +20,17 @@ import (
func Test_NoScmPipelineConfig(t *testing.T) { func Test_NoScmPipelineConfig(t *testing.T) {
inputs := []*NoScmPipeline{ inputs := []*NoScmPipeline{
&NoScmPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
Jenkinsfile: "node{echo 'hello'}", Jenkinsfile: "node{echo 'hello'}",
}, },
&NoScmPipeline{ {
Name: "", Name: "",
Description: "", Description: "",
Jenkinsfile: "node{echo 'hello'}", Jenkinsfile: "node{echo 'hello'}",
}, },
&NoScmPipeline{ {
Name: "", Name: "",
Description: "", Description: "",
Jenkinsfile: "node{echo 'hello'}", Jenkinsfile: "node{echo 'hello'}",
...@@ -55,7 +55,7 @@ func Test_NoScmPipelineConfig(t *testing.T) { ...@@ -55,7 +55,7 @@ func Test_NoScmPipelineConfig(t *testing.T) {
func Test_NoScmPipelineConfig_Discarder(t *testing.T) { func Test_NoScmPipelineConfig_Discarder(t *testing.T) {
inputs := []*NoScmPipeline{ inputs := []*NoScmPipeline{
&NoScmPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
Jenkinsfile: "node{echo 'hello'}", Jenkinsfile: "node{echo 'hello'}",
...@@ -63,7 +63,7 @@ func Test_NoScmPipelineConfig_Discarder(t *testing.T) { ...@@ -63,7 +63,7 @@ func Test_NoScmPipelineConfig_Discarder(t *testing.T) {
"3", "5", "3", "5",
}, },
}, },
&NoScmPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
Jenkinsfile: "node{echo 'hello'}", Jenkinsfile: "node{echo 'hello'}",
...@@ -71,7 +71,7 @@ func Test_NoScmPipelineConfig_Discarder(t *testing.T) { ...@@ -71,7 +71,7 @@ func Test_NoScmPipelineConfig_Discarder(t *testing.T) {
"3", "", "3", "",
}, },
}, },
&NoScmPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
Jenkinsfile: "node{echo 'hello'}", Jenkinsfile: "node{echo 'hello'}",
...@@ -79,7 +79,7 @@ func Test_NoScmPipelineConfig_Discarder(t *testing.T) { ...@@ -79,7 +79,7 @@ func Test_NoScmPipelineConfig_Discarder(t *testing.T) {
"", "21321", "", "21321",
}, },
}, },
&NoScmPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
Jenkinsfile: "node{echo 'hello'}", Jenkinsfile: "node{echo 'hello'}",
...@@ -106,7 +106,7 @@ func Test_NoScmPipelineConfig_Discarder(t *testing.T) { ...@@ -106,7 +106,7 @@ func Test_NoScmPipelineConfig_Discarder(t *testing.T) {
func Test_NoScmPipelineConfig_Param(t *testing.T) { func Test_NoScmPipelineConfig_Param(t *testing.T) {
inputs := []*NoScmPipeline{ inputs := []*NoScmPipeline{
&NoScmPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
Jenkinsfile: "node{echo 'hello'}", Jenkinsfile: "node{echo 'hello'}",
...@@ -119,7 +119,7 @@ func Test_NoScmPipelineConfig_Param(t *testing.T) { ...@@ -119,7 +119,7 @@ func Test_NoScmPipelineConfig_Param(t *testing.T) {
}, },
}, },
}, },
&NoScmPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
Jenkinsfile: "node{echo 'hello'}", Jenkinsfile: "node{echo 'hello'}",
...@@ -169,7 +169,7 @@ func Test_NoScmPipelineConfig_Param(t *testing.T) { ...@@ -169,7 +169,7 @@ func Test_NoScmPipelineConfig_Param(t *testing.T) {
func Test_NoScmPipelineConfig_Trigger(t *testing.T) { func Test_NoScmPipelineConfig_Trigger(t *testing.T) {
inputs := []*NoScmPipeline{ inputs := []*NoScmPipeline{
&NoScmPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
Jenkinsfile: "node{echo 'hello'}", Jenkinsfile: "node{echo 'hello'}",
...@@ -178,7 +178,7 @@ func Test_NoScmPipelineConfig_Trigger(t *testing.T) { ...@@ -178,7 +178,7 @@ func Test_NoScmPipelineConfig_Trigger(t *testing.T) {
}, },
}, },
&NoScmPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
Jenkinsfile: "node{echo 'hello'}", Jenkinsfile: "node{echo 'hello'}",
...@@ -186,7 +186,7 @@ func Test_NoScmPipelineConfig_Trigger(t *testing.T) { ...@@ -186,7 +186,7 @@ func Test_NoScmPipelineConfig_Trigger(t *testing.T) {
Token: "abc", Token: "abc",
}, },
}, },
&NoScmPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
Jenkinsfile: "node{echo 'hello'}", Jenkinsfile: "node{echo 'hello'}",
...@@ -218,28 +218,28 @@ func Test_NoScmPipelineConfig_Trigger(t *testing.T) { ...@@ -218,28 +218,28 @@ func Test_NoScmPipelineConfig_Trigger(t *testing.T) {
func Test_MultiBranchPipelineConfig(t *testing.T) { func Test_MultiBranchPipelineConfig(t *testing.T) {
inputs := []*MultiBranchPipeline{ inputs := []*MultiBranchPipeline{
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
SourceType: "git", SourceType: "git",
GitSource: &GitSource{}, GitSource: &GitSource{},
}, },
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
SourceType: "github", SourceType: "github",
GitHubSource: &GithubSource{}, GitHubSource: &GithubSource{},
}, },
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
SourceType: "single_svn", SourceType: "single_svn",
SingleSvnSource: &SingleSvnSource{}, SingleSvnSource: &SingleSvnSource{},
}, },
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
...@@ -266,7 +266,7 @@ func Test_MultiBranchPipelineConfig(t *testing.T) { ...@@ -266,7 +266,7 @@ func Test_MultiBranchPipelineConfig(t *testing.T) {
func Test_MultiBranchPipelineConfig_Discarder(t *testing.T) { func Test_MultiBranchPipelineConfig_Discarder(t *testing.T) {
inputs := []*MultiBranchPipeline{ inputs := []*MultiBranchPipeline{
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
...@@ -296,7 +296,7 @@ func Test_MultiBranchPipelineConfig_Discarder(t *testing.T) { ...@@ -296,7 +296,7 @@ func Test_MultiBranchPipelineConfig_Discarder(t *testing.T) {
func Test_MultiBranchPipelineConfig_TimerTrigger(t *testing.T) { func Test_MultiBranchPipelineConfig_TimerTrigger(t *testing.T) {
inputs := []*MultiBranchPipeline{ inputs := []*MultiBranchPipeline{
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
...@@ -326,7 +326,7 @@ func Test_MultiBranchPipelineConfig_TimerTrigger(t *testing.T) { ...@@ -326,7 +326,7 @@ func Test_MultiBranchPipelineConfig_TimerTrigger(t *testing.T) {
func Test_MultiBranchPipelineConfig_Source(t *testing.T) { func Test_MultiBranchPipelineConfig_Source(t *testing.T) {
inputs := []*MultiBranchPipeline{ inputs := []*MultiBranchPipeline{
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
...@@ -340,7 +340,7 @@ func Test_MultiBranchPipelineConfig_Source(t *testing.T) { ...@@ -340,7 +340,7 @@ func Test_MultiBranchPipelineConfig_Source(t *testing.T) {
DiscoverBranches: true, DiscoverBranches: true,
}, },
}, },
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
...@@ -361,7 +361,7 @@ func Test_MultiBranchPipelineConfig_Source(t *testing.T) { ...@@ -361,7 +361,7 @@ func Test_MultiBranchPipelineConfig_Source(t *testing.T) {
}, },
}, },
}, },
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
...@@ -383,7 +383,7 @@ func Test_MultiBranchPipelineConfig_Source(t *testing.T) { ...@@ -383,7 +383,7 @@ func Test_MultiBranchPipelineConfig_Source(t *testing.T) {
}, },
}, },
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
...@@ -398,7 +398,7 @@ func Test_MultiBranchPipelineConfig_Source(t *testing.T) { ...@@ -398,7 +398,7 @@ func Test_MultiBranchPipelineConfig_Source(t *testing.T) {
Includes: "tag/*", Includes: "tag/*",
}, },
}, },
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
...@@ -432,7 +432,7 @@ func Test_MultiBranchPipelineConfig_Source(t *testing.T) { ...@@ -432,7 +432,7 @@ func Test_MultiBranchPipelineConfig_Source(t *testing.T) {
func Test_MultiBranchPipelineCloneConfig(t *testing.T) { func Test_MultiBranchPipelineCloneConfig(t *testing.T) {
inputs := []*MultiBranchPipeline{ inputs := []*MultiBranchPipeline{
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
...@@ -448,7 +448,7 @@ func Test_MultiBranchPipelineCloneConfig(t *testing.T) { ...@@ -448,7 +448,7 @@ func Test_MultiBranchPipelineCloneConfig(t *testing.T) {
}, },
}, },
}, },
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
...@@ -493,7 +493,7 @@ func Test_MultiBranchPipelineCloneConfig(t *testing.T) { ...@@ -493,7 +493,7 @@ func Test_MultiBranchPipelineCloneConfig(t *testing.T) {
func Test_MultiBranchPipelineRegexFilter(t *testing.T) { func Test_MultiBranchPipelineRegexFilter(t *testing.T) {
inputs := []*MultiBranchPipeline{ inputs := []*MultiBranchPipeline{
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
...@@ -505,7 +505,7 @@ func Test_MultiBranchPipelineRegexFilter(t *testing.T) { ...@@ -505,7 +505,7 @@ func Test_MultiBranchPipelineRegexFilter(t *testing.T) {
RegexFilter: ".*", RegexFilter: ".*",
}, },
}, },
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
...@@ -546,7 +546,7 @@ func Test_MultiBranchPipelineRegexFilter(t *testing.T) { ...@@ -546,7 +546,7 @@ func Test_MultiBranchPipelineRegexFilter(t *testing.T) {
func Test_MultiBranchPipelineMultibranchTrigger(t *testing.T) { func Test_MultiBranchPipelineMultibranchTrigger(t *testing.T) {
inputs := []*MultiBranchPipeline{ inputs := []*MultiBranchPipeline{
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
...@@ -569,7 +569,7 @@ func Test_MultiBranchPipelineMultibranchTrigger(t *testing.T) { ...@@ -569,7 +569,7 @@ func Test_MultiBranchPipelineMultibranchTrigger(t *testing.T) {
DeleteActionJobsToTrigger: "ddd", DeleteActionJobsToTrigger: "ddd",
}, },
}, },
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
...@@ -591,7 +591,7 @@ func Test_MultiBranchPipelineMultibranchTrigger(t *testing.T) { ...@@ -591,7 +591,7 @@ func Test_MultiBranchPipelineMultibranchTrigger(t *testing.T) {
CreateActionJobsToTrigger: "abc", CreateActionJobsToTrigger: "abc",
}, },
}, },
&MultiBranchPipeline{ {
Name: "", Name: "",
Description: "for test", Description: "for test",
ScriptPath: "Jenkinsfile", ScriptPath: "Jenkinsfile",
......
...@@ -13,8 +13,7 @@ import ( ...@@ -13,8 +13,7 @@ import (
"k8s.io/klog" "k8s.io/klog"
"kubesphere.io/kubesphere/pkg/apis/devops/v1alpha1" "kubesphere.io/kubesphere/pkg/apis/devops/v1alpha1"
"kubesphere.io/kubesphere/pkg/informers" "kubesphere.io/kubesphere/pkg/informers"
"kubesphere.io/kubesphere/pkg/simple/client/k8s" "kubesphere.io/kubesphere/pkg/simple/client"
"kubesphere.io/kubesphere/pkg/simple/client/s2is3"
"mime/multipart" "mime/multipart"
"net/http" "net/http"
"reflect" "reflect"
...@@ -26,6 +25,11 @@ const ( ...@@ -26,6 +25,11 @@ const (
) )
func UploadS2iBinary(namespace, name, md5 string, fileHeader *multipart.FileHeader) (*v1alpha1.S2iBinary, error) { func UploadS2iBinary(namespace, name, md5 string, fileHeader *multipart.FileHeader) (*v1alpha1.S2iBinary, error) {
s3Client, err := client.ClientSets().S3()
if err != nil {
return nil, err
}
binFile, err := fileHeader.Open() binFile, err := fileHeader.Open()
if err != nil { if err != nil {
klog.Errorf("%+v", err) klog.Errorf("%+v", err)
...@@ -66,7 +70,8 @@ func UploadS2iBinary(namespace, name, md5 string, fileHeader *multipart.FileHead ...@@ -66,7 +70,8 @@ func UploadS2iBinary(namespace, name, md5 string, fileHeader *multipart.FileHead
copy.Spec.Size = bytefmt.ByteSize(uint64(fileHeader.Size)) copy.Spec.Size = bytefmt.ByteSize(uint64(fileHeader.Size))
copy.Spec.FileName = fileHeader.Filename copy.Spec.FileName = fileHeader.Filename
copy.Spec.DownloadURL = fmt.Sprintf(GetS2iBinaryURL, namespace, name, copy.Spec.FileName) copy.Spec.DownloadURL = fmt.Sprintf(GetS2iBinaryURL, namespace, name, copy.Spec.FileName)
s3session := s2is3.Session()
s3session := s3Client.Session()
if s3session == nil { if s3session == nil {
err := fmt.Errorf("could not connect to s2i s3") err := fmt.Errorf("could not connect to s2i s3")
klog.Error(err) klog.Error(err)
...@@ -82,7 +87,7 @@ func UploadS2iBinary(namespace, name, md5 string, fileHeader *multipart.FileHead ...@@ -82,7 +87,7 @@ func UploadS2iBinary(namespace, name, md5 string, fileHeader *multipart.FileHead
uploader.LeavePartsOnError = true uploader.LeavePartsOnError = true
}) })
_, err = uploader.Upload(&s3manager.UploadInput{ _, err = uploader.Upload(&s3manager.UploadInput{
Bucket: s2is3.Bucket(), Bucket: s3Client.Bucket(),
Key: aws.String(fmt.Sprintf("%s-%s", namespace, name)), Key: aws.String(fmt.Sprintf("%s-%s", namespace, name)),
Body: binFile, Body: binFile,
ContentMD5: aws.String(md5), ContentMD5: aws.String(md5),
...@@ -116,7 +121,7 @@ func UploadS2iBinary(namespace, name, md5 string, fileHeader *multipart.FileHead ...@@ -116,7 +121,7 @@ func UploadS2iBinary(namespace, name, md5 string, fileHeader *multipart.FileHead
copy.Spec.UploadTimeStamp = new(metav1.Time) copy.Spec.UploadTimeStamp = new(metav1.Time)
} }
*copy.Spec.UploadTimeStamp = metav1.Now() *copy.Spec.UploadTimeStamp = metav1.Now()
copy, err = k8s.KsClient().DevopsV1alpha1().S2iBinaries(namespace).Update(copy) copy, err = client.ClientSets().K8s().KubeSphere().DevopsV1alpha1().S2iBinaries(namespace).Update(copy)
if err != nil { if err != nil {
klog.Error(err) klog.Error(err)
return nil, err return nil, err
...@@ -131,6 +136,11 @@ func UploadS2iBinary(namespace, name, md5 string, fileHeader *multipart.FileHead ...@@ -131,6 +136,11 @@ func UploadS2iBinary(namespace, name, md5 string, fileHeader *multipart.FileHead
} }
func DownloadS2iBinary(namespace, name, fileName string) (string, error) { func DownloadS2iBinary(namespace, name, fileName string) (string, error) {
s3Client, err := client.ClientSets().S3()
if err != nil {
return "", err
}
origin, err := informers.KsSharedInformerFactory().Devops().V1alpha1().S2iBinaries().Lister().S2iBinaries(namespace).Get(name) origin, err := informers.KsSharedInformerFactory().Devops().V1alpha1().S2iBinaries().Lister().S2iBinaries(namespace).Get(name)
if err != nil { if err != nil {
klog.Errorf("%+v", err) klog.Errorf("%+v", err)
...@@ -146,14 +156,9 @@ func DownloadS2iBinary(namespace, name, fileName string) (string, error) { ...@@ -146,14 +156,9 @@ func DownloadS2iBinary(namespace, name, fileName string) (string, error) {
klog.Error(err) klog.Error(err)
return "", err return "", err
} }
s3Client := s2is3.Client()
if s3Client == nil { req, _ := s3Client.Client().GetObjectRequest(&s3.GetObjectInput{
err := fmt.Errorf("could not get s3 client") Bucket: s3Client.Bucket(),
klog.Error(err)
return "", err
}
req, _ := s3Client.GetObjectRequest(&s3.GetObjectInput{
Bucket: s2is3.Bucket(),
Key: aws.String(fmt.Sprintf("%s-%s", namespace, name)), Key: aws.String(fmt.Sprintf("%s-%s", namespace, name)),
ResponseContentDisposition: aws.String(fmt.Sprintf("attachment; filename=\"%s\"", origin.Spec.FileName)), ResponseContentDisposition: aws.String(fmt.Sprintf("attachment; filename=\"%s\"", origin.Spec.FileName)),
}) })
...@@ -169,7 +174,7 @@ func DownloadS2iBinary(namespace, name, fileName string) (string, error) { ...@@ -169,7 +174,7 @@ func DownloadS2iBinary(namespace, name, fileName string) (string, error) {
func SetS2iBinaryStatus(s2ibin *v1alpha1.S2iBinary, status string) (*v1alpha1.S2iBinary, error) { func SetS2iBinaryStatus(s2ibin *v1alpha1.S2iBinary, status string) (*v1alpha1.S2iBinary, error) {
copy := s2ibin.DeepCopy() copy := s2ibin.DeepCopy()
copy.Status.Phase = status copy.Status.Phase = status
copy, err := k8s.KsClient().DevopsV1alpha1().S2iBinaries(s2ibin.Namespace).Update(copy) copy, err := client.ClientSets().K8s().KubeSphere().DevopsV1alpha1().S2iBinaries(s2ibin.Namespace).Update(copy)
if err != nil { if err != nil {
klog.Error(err) klog.Error(err)
return nil, err return nil, err
...@@ -188,7 +193,7 @@ func SetS2iBinaryStatusWithRetry(s2ibin *v1alpha1.S2iBinary, status string) (*v1 ...@@ -188,7 +193,7 @@ func SetS2iBinaryStatusWithRetry(s2ibin *v1alpha1.S2iBinary, status string) (*v1
return err return err
} }
bin.Status.Phase = status bin.Status.Phase = status
bin, err = k8s.KsClient().DevopsV1alpha1().S2iBinaries(s2ibin.Namespace).Update(bin) bin, err = client.ClientSets().K8s().KubeSphere().DevopsV1alpha1().S2iBinaries(s2ibin.Namespace).Update(bin)
if err != nil { if err != nil {
klog.Error(err) klog.Error(err)
return err return err
......
...@@ -33,7 +33,7 @@ import ( ...@@ -33,7 +33,7 @@ import (
"kubesphere.io/kubesphere/pkg/models/kubectl" "kubesphere.io/kubesphere/pkg/models/kubectl"
"kubesphere.io/kubesphere/pkg/models/resources" "kubesphere.io/kubesphere/pkg/models/resources"
"kubesphere.io/kubesphere/pkg/params" "kubesphere.io/kubesphere/pkg/params"
"kubesphere.io/kubesphere/pkg/simple/client/k8s" "kubesphere.io/kubesphere/pkg/simple/client"
"kubesphere.io/kubesphere/pkg/utils/k8sutil" "kubesphere.io/kubesphere/pkg/utils/k8sutil"
"kubesphere.io/kubesphere/pkg/utils/sliceutil" "kubesphere.io/kubesphere/pkg/utils/sliceutil"
"sort" "sort"
...@@ -650,7 +650,7 @@ func CreateClusterRoleBinding(username string, clusterRoleName string) error { ...@@ -650,7 +650,7 @@ func CreateClusterRoleBinding(username string, clusterRoleName string) error {
found, err := clusterRoleBindingLister.Get(username) found, err := clusterRoleBindingLister.Get(username)
if apierrors.IsNotFound(err) { if apierrors.IsNotFound(err) {
_, err = k8s.Client().RbacV1().ClusterRoleBindings().Create(clusterRoleBinding) _, err = client.ClientSets().K8s().Kubernetes().RbacV1().ClusterRoleBindings().Create(clusterRoleBinding)
if err != nil { if err != nil {
glog.Errorln("create cluster role binding", err) glog.Errorln("create cluster role binding", err)
return err return err
...@@ -665,14 +665,14 @@ func CreateClusterRoleBinding(username string, clusterRoleName string) error { ...@@ -665,14 +665,14 @@ func CreateClusterRoleBinding(username string, clusterRoleName string) error {
deletePolicy := metav1.DeletePropagationForeground deletePolicy := metav1.DeletePropagationForeground
gracePeriodSeconds := int64(0) gracePeriodSeconds := int64(0)
deleteOption := &metav1.DeleteOptions{PropagationPolicy: &deletePolicy, GracePeriodSeconds: &gracePeriodSeconds} deleteOption := &metav1.DeleteOptions{PropagationPolicy: &deletePolicy, GracePeriodSeconds: &gracePeriodSeconds}
err = k8s.Client().RbacV1().ClusterRoleBindings().Delete(found.Name, deleteOption) err = client.ClientSets().K8s().Kubernetes().RbacV1().ClusterRoleBindings().Delete(found.Name, deleteOption)
if err != nil { if err != nil {
glog.Errorln("delete cluster role binding", err) glog.Errorln("delete cluster role binding", err)
return err return err
} }
maxRetries := 3 maxRetries := 3
for i := 0; i < maxRetries; i++ { for i := 0; i < maxRetries; i++ {
_, err = k8s.Client().RbacV1().ClusterRoleBindings().Create(clusterRoleBinding) _, err = client.ClientSets().K8s().Kubernetes().RbacV1().ClusterRoleBindings().Create(clusterRoleBinding)
if err == nil { if err == nil {
return nil return nil
} }
...@@ -684,7 +684,7 @@ func CreateClusterRoleBinding(username string, clusterRoleName string) error { ...@@ -684,7 +684,7 @@ func CreateClusterRoleBinding(username string, clusterRoleName string) error {
if !k8sutil.ContainsUser(found.Subjects, username) { if !k8sutil.ContainsUser(found.Subjects, username) {
found.Subjects = clusterRoleBinding.Subjects found.Subjects = clusterRoleBinding.Subjects
_, err = k8s.Client().RbacV1().ClusterRoleBindings().Update(found) _, err = client.ClientSets().K8s().Kubernetes().RbacV1().ClusterRoleBindings().Update(found)
if err != nil { if err != nil {
glog.Errorln("update cluster role binding", err) glog.Errorln("update cluster role binding", err)
return err return err
......
此差异已折叠。
...@@ -19,7 +19,7 @@ package iam ...@@ -19,7 +19,7 @@ package iam
import ( import (
"fmt" "fmt"
ldapclient "kubesphere.io/kubesphere/pkg/simple/client/ldap" "kubesphere.io/kubesphere/pkg/simple/client"
"regexp" "regexp"
"strings" "strings"
) )
...@@ -44,6 +44,10 @@ func convertDNToPath(dn string) string { ...@@ -44,6 +44,10 @@ func convertDNToPath(dn string) string {
} }
func splitPath(path string) (searchBase string, cn string) { func splitPath(path string) (searchBase string, cn string) {
ldapClient, err := client.ClientSets().Ldap()
if err != nil {
return "", ""
}
paths := strings.Split(path, ":") paths := strings.Split(path, ":")
length := len(paths) length := len(paths)
...@@ -60,12 +64,12 @@ func splitPath(path string) (searchBase string, cn string) { ...@@ -60,12 +64,12 @@ func splitPath(path string) (searchBase string, cn string) {
basePath[i], basePath[j] = basePath[j], basePath[i] basePath[i], basePath[j] = basePath[j], basePath[i]
} }
searchBase = fmt.Sprintf("%s,%s", strings.Join(basePath, ","), ldapclient.GroupSearchBase) searchBase = fmt.Sprintf("%s,%s", strings.Join(basePath, ","), ldapClient.GroupSearchBase())
} else if length == 2 { } else if length == 2 {
searchBase = fmt.Sprintf("cn=%s,%s", paths[0], ldapclient.GroupSearchBase) searchBase = fmt.Sprintf("cn=%s,%s", paths[0], ldapClient.GroupSearchBase())
cn = paths[1] cn = paths[1]
} else { } else {
searchBase = ldapclient.GroupSearchBase searchBase = ldapClient.GroupSearchBase()
if paths[0] == "" { if paths[0] == "" {
cn = "*" cn = "*"
} else { } else {
......
...@@ -29,7 +29,7 @@ import ( ...@@ -29,7 +29,7 @@ import (
"fmt" "fmt"
"gopkg.in/yaml.v2" "gopkg.in/yaml.v2"
"io/ioutil" "io/ioutil"
"kubesphere.io/kubesphere/pkg/simple/client/k8s" "kubesphere.io/kubesphere/pkg/simple/client"
"math/big" "math/big"
rd "math/rand" rd "math/rand"
"time" "time"
...@@ -217,7 +217,7 @@ func createKubeConfig(username string) (string, error) { ...@@ -217,7 +217,7 @@ func createKubeConfig(username string) (string, error) {
return "", err return "", err
} }
base64ServerCa := base64.StdEncoding.EncodeToString(serverCa) base64ServerCa := base64.StdEncoding.EncodeToString(serverCa)
tmpClusterInfo := clusterInfo{CertificateAuthorityData: base64ServerCa, Server: k8s.KubeConfig.Host} tmpClusterInfo := clusterInfo{CertificateAuthorityData: base64ServerCa, Server: client.ClientSets().K8s().Master()}
tmpCluster := cluster{Cluster: tmpClusterInfo, Name: clusterName} tmpCluster := cluster{Cluster: tmpClusterInfo, Name: clusterName}
tmpKubeConfig.Clusters = append(tmpKubeConfig.Clusters, tmpCluster) tmpKubeConfig.Clusters = append(tmpKubeConfig.Clusters, tmpCluster)
...@@ -244,7 +244,7 @@ func createKubeConfig(username string) (string, error) { ...@@ -244,7 +244,7 @@ func createKubeConfig(username string) (string, error) {
} }
func CreateKubeConfig(username string) error { func CreateKubeConfig(username string) error {
k8sClient := k8s.Client() k8sClient := client.ClientSets().K8s().Kubernetes()
configName := fmt.Sprintf("kubeconfig-%s", username) configName := fmt.Sprintf("kubeconfig-%s", username)
_, err := k8sClient.CoreV1().ConfigMaps(constants.KubeSphereControlNamespace).Get(configName, metaV1.GetOptions{}) _, err := k8sClient.CoreV1().ConfigMaps(constants.KubeSphereControlNamespace).Get(configName, metaV1.GetOptions{})
...@@ -255,7 +255,7 @@ func CreateKubeConfig(username string) error { ...@@ -255,7 +255,7 @@ func CreateKubeConfig(username string) error {
return err return err
} }
data := map[string]string{"config": string(config)} data := map[string]string{"config": config}
configMap := v1.ConfigMap{TypeMeta: metaV1.TypeMeta{Kind: "Configmap", APIVersion: "v1"}, ObjectMeta: metaV1.ObjectMeta{Name: configName}, Data: data} configMap := v1.ConfigMap{TypeMeta: metaV1.TypeMeta{Kind: "Configmap", APIVersion: "v1"}, ObjectMeta: metaV1.ObjectMeta{Name: configName}, Data: data}
_, err = k8sClient.CoreV1().ConfigMaps(constants.KubeSphereControlNamespace).Create(&configMap) _, err = k8sClient.CoreV1().ConfigMaps(constants.KubeSphereControlNamespace).Create(&configMap)
if err != nil && !errors.IsAlreadyExists(err) { if err != nil && !errors.IsAlreadyExists(err) {
...@@ -269,7 +269,7 @@ func CreateKubeConfig(username string) error { ...@@ -269,7 +269,7 @@ func CreateKubeConfig(username string) error {
} }
func GetKubeConfig(username string) (string, error) { func GetKubeConfig(username string) (string, error) {
k8sClient := k8s.Client() k8sClient := client.ClientSets().K8s().Kubernetes()
configName := fmt.Sprintf("kubeconfig-%s", username) configName := fmt.Sprintf("kubeconfig-%s", username)
configMap, err := k8sClient.CoreV1().ConfigMaps(constants.KubeSphereControlNamespace).Get(configName, metaV1.GetOptions{}) configMap, err := k8sClient.CoreV1().ConfigMaps(constants.KubeSphereControlNamespace).Get(configName, metaV1.GetOptions{})
if err != nil { if err != nil {
...@@ -284,10 +284,7 @@ func GetKubeConfig(username string) (string, error) { ...@@ -284,10 +284,7 @@ func GetKubeConfig(username string) (string, error) {
glog.Error(err) glog.Error(err)
return "", err return "", err
} }
masterURL := k8s.KubeConfig.Host masterURL := client.ClientSets().K8s().Master()
if host := k8s.MasterURL; host != "" {
masterURL = host
}
for i, cluster := range kubeConfig.Clusters { for i, cluster := range kubeConfig.Clusters {
cluster.Cluster.Server = masterURL cluster.Cluster.Server = masterURL
kubeConfig.Clusters[i] = cluster kubeConfig.Clusters[i] = cluster
...@@ -301,7 +298,7 @@ func GetKubeConfig(username string) (string, error) { ...@@ -301,7 +298,7 @@ func GetKubeConfig(username string) (string, error) {
} }
func DelKubeConfig(username string) error { func DelKubeConfig(username string) error {
k8sClient := k8s.Client() k8sClient := client.ClientSets().K8s().Kubernetes()
configName := fmt.Sprintf("kubeconfig-%s", username) configName := fmt.Sprintf("kubeconfig-%s", username)
_, err := k8sClient.CoreV1().ConfigMaps(constants.KubeSphereControlNamespace).Get(configName, metaV1.GetOptions{}) _, err := k8sClient.CoreV1().ConfigMaps(constants.KubeSphereControlNamespace).Get(configName, metaV1.GetOptions{})
if errors.IsNotFound(err) { if errors.IsNotFound(err) {
......
...@@ -21,7 +21,7 @@ package kubectl ...@@ -21,7 +21,7 @@ package kubectl
import ( import (
"fmt" "fmt"
"kubesphere.io/kubesphere/pkg/models" "kubesphere.io/kubesphere/pkg/models"
"kubesphere.io/kubesphere/pkg/simple/client/k8s" "kubesphere.io/kubesphere/pkg/simple/client"
"math/rand" "math/rand"
"os" "os"
...@@ -49,7 +49,7 @@ func init() { ...@@ -49,7 +49,7 @@ func init() {
} }
func GetKubectlPod(username string) (models.PodInfo, error) { func GetKubectlPod(username string) (models.PodInfo, error) {
k8sClient := k8s.Client() k8sClient := client.ClientSets().K8s().Kubernetes()
deployName := fmt.Sprintf("kubectl-%s", username) deployName := fmt.Sprintf("kubectl-%s", username)
deploy, err := k8sClient.AppsV1().Deployments(namespace).Get(deployName, metav1.GetOptions{}) deploy, err := k8sClient.AppsV1().Deployments(namespace).Get(deployName, metav1.GetOptions{})
if err != nil { if err != nil {
...@@ -97,7 +97,7 @@ func selectCorrectPod(namespace string, pods []v1.Pod) (kubectlPod v1.Pod, err e ...@@ -97,7 +97,7 @@ func selectCorrectPod(namespace string, pods []v1.Pod) (kubectlPod v1.Pod, err e
} }
func CreateKubectlDeploy(username string) error { func CreateKubectlDeploy(username string) error {
k8sClient := k8s.Client() k8sClient := client.ClientSets().K8s().Kubernetes()
deployName := fmt.Sprintf("kubectl-%s", username) deployName := fmt.Sprintf("kubectl-%s", username)
configName := fmt.Sprintf("kubeconfig-%s", username) configName := fmt.Sprintf("kubeconfig-%s", username)
_, err := k8sClient.AppsV1().Deployments(namespace).Get(deployName, metav1.GetOptions{}) _, err := k8sClient.AppsV1().Deployments(namespace).Get(deployName, metav1.GetOptions{})
...@@ -140,7 +140,7 @@ func CreateKubectlDeploy(username string) error { ...@@ -140,7 +140,7 @@ func CreateKubectlDeploy(username string) error {
} }
func DelKubectlDeploy(username string) error { func DelKubectlDeploy(username string) error {
k8sClient := k8s.Client() k8sClient := client.ClientSets().K8s().Kubernetes()
deployName := fmt.Sprintf("kubectl-%s", username) deployName := fmt.Sprintf("kubectl-%s", username)
_, err := k8sClient.AppsV1().Deployments(namespace).Get(deployName, metav1.GetOptions{}) _, err := k8sClient.AppsV1().Deployments(namespace).Get(deployName, metav1.GetOptions{})
if errors.IsNotFound(err) { if errors.IsNotFound(err) {
......
此差异已折叠。
...@@ -22,8 +22,6 @@ import ( ...@@ -22,8 +22,6 @@ import (
"strings" "strings"
"k8s.io/api/core/v1" "k8s.io/api/core/v1"
prom "kubesphere.io/kubesphere/pkg/simple/client/prometheus"
) )
func GetNamespacesWithMetrics(namespaces []*v1.Namespace) []*v1.Namespace { func GetNamespacesWithMetrics(namespaces []*v1.Namespace) []*v1.Namespace {
...@@ -34,10 +32,10 @@ func GetNamespacesWithMetrics(namespaces []*v1.Namespace) []*v1.Namespace { ...@@ -34,10 +32,10 @@ func GetNamespacesWithMetrics(namespaces []*v1.Namespace) []*v1.Namespace {
nsFilter := "^(" + strings.Join(nsNameList, "|") + ")$" nsFilter := "^(" + strings.Join(nsNameList, "|") + ")$"
var timeRelateParams = make(url.Values) var timeRelateParams = make(url.Values)
params := prom.MonitoringRequestParams{ params := MonitoringRequestParams{
ResourcesFilter: nsFilter, ResourcesFilter: nsFilter,
Params: timeRelateParams, Params: timeRelateParams,
QueryType: prom.DefaultQueryType, QueryType: DefaultQueryType,
MetricsFilter: "namespace_cpu_usage|namespace_memory_usage_wo_cache|namespace_pod_count", MetricsFilter: "namespace_cpu_usage|namespace_memory_usage_wo_cache|namespace_pod_count",
} }
......
package metrics
import "net/url"
const (
DefaultQueryStep = "10m"
DefaultQueryTimeout = "10s"
RangeQueryType = "query_range?"
DefaultQueryType = "query?"
)
type MonitoringRequestParams struct {
Params url.Values
QueryType string
SortMetricName string
SortType string
PageNum string
LimitNum string
Tp string
MetricsFilter string
ResourcesFilter string
MetricsName string
WorkloadName string
NodeId string
WsName string
NsName string
PodName string
PVCName string
StorageClassName string
ContainerName string
WorkloadKind string
ComponentName string
}
此差异已折叠。
此差异已折叠。
此差异已折叠。
...@@ -25,7 +25,7 @@ import ( ...@@ -25,7 +25,7 @@ import (
"kubesphere.io/kubesphere/pkg/models" "kubesphere.io/kubesphere/pkg/models"
ws "kubesphere.io/kubesphere/pkg/models/workspaces" ws "kubesphere.io/kubesphere/pkg/models/workspaces"
"kubesphere.io/kubesphere/pkg/params" "kubesphere.io/kubesphere/pkg/params"
"kubesphere.io/kubesphere/pkg/simple/client/k8s" "kubesphere.io/kubesphere/pkg/simple/client"
"strconv" "strconv"
) )
...@@ -44,7 +44,7 @@ func CreateNamespace(workspaceName string, namespace *v1.Namespace, username str ...@@ -44,7 +44,7 @@ func CreateNamespace(workspaceName string, namespace *v1.Namespace, username str
namespace.Labels[constants.WorkspaceLabelKey] = workspaceName namespace.Labels[constants.WorkspaceLabelKey] = workspaceName
return k8s.Client().CoreV1().Namespaces().Create(namespace) return client.ClientSets().K8s().Kubernetes().CoreV1().Namespaces().Create(namespace)
} }
func DescribeWorkspace(username, workspaceName string) (*v1alpha1.Workspace, error) { func DescribeWorkspace(username, workspaceName string) (*v1alpha1.Workspace, error) {
......
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
...@@ -3,10 +3,10 @@ ...@@ -3,10 +3,10 @@
package tools package tools
import ( import (
_ "k8s.io/kube-openapi/cmd/openapi-gen/"
_ "k8s.io/code-generator/cmd/client-gen" _ "k8s.io/code-generator/cmd/client-gen"
_ "k8s.io/code-generator/cmd/deepcopy-gen"
_ "k8s.io/code-generator/cmd/informer-gen" _ "k8s.io/code-generator/cmd/informer-gen"
_ "k8s.io/code-generator/cmd/lister-gen" _ "k8s.io/code-generator/cmd/lister-gen"
_ "k8s.io/code-generator/cmd/deepcopy-gen" _ "k8s.io/kube-openapi/cmd/openapi-gen/"
_ "sigs.k8s.io/controller-tools/cmd/controller-gen" _ "sigs.k8s.io/controller-tools/cmd/controller-gen"
) )
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册