mirror of
https://github.com/ceph/ceph-csi.git
synced 2024-12-01 02:30:18 +00:00
b1a4590967
There is no release for sigs.k8s.io/controller-runtime that supports Kubernetes v1.27. The main branch has all the required modifications, so we can use that for the time being. Signed-off-by: Niels de Vos <ndevos@ibm.com>
106 lines
2.7 KiB
Go
106 lines
2.7 KiB
Go
/*
|
|
Copyright 2020 The Kubernetes Authors.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package cluster
|
|
|
|
import (
|
|
"context"
|
|
"net/http"
|
|
|
|
"github.com/go-logr/logr"
|
|
"k8s.io/apimachinery/pkg/api/meta"
|
|
"k8s.io/apimachinery/pkg/runtime"
|
|
"k8s.io/client-go/rest"
|
|
"k8s.io/client-go/tools/record"
|
|
|
|
"sigs.k8s.io/controller-runtime/pkg/cache"
|
|
"sigs.k8s.io/controller-runtime/pkg/client"
|
|
intrec "sigs.k8s.io/controller-runtime/pkg/internal/recorder"
|
|
)
|
|
|
|
type cluster struct {
|
|
// config is the rest.config used to talk to the apiserver. Required.
|
|
config *rest.Config
|
|
|
|
httpClient *http.Client
|
|
scheme *runtime.Scheme
|
|
cache cache.Cache
|
|
client client.Client
|
|
|
|
// apiReader is the reader that will make requests to the api server and not the cache.
|
|
apiReader client.Reader
|
|
|
|
// fieldIndexes knows how to add field indexes over the Cache used by this controller,
|
|
// which can later be consumed via field selectors from the injected client.
|
|
fieldIndexes client.FieldIndexer
|
|
|
|
// recorderProvider is used to generate event recorders that will be injected into Controllers
|
|
// (and EventHandlers, Sources and Predicates).
|
|
recorderProvider *intrec.Provider
|
|
|
|
// mapper is used to map resources to kind, and map kind and version.
|
|
mapper meta.RESTMapper
|
|
|
|
// Logger is the logger that should be used by this manager.
|
|
// If none is set, it defaults to log.Log global logger.
|
|
logger logr.Logger
|
|
}
|
|
|
|
func (c *cluster) GetConfig() *rest.Config {
|
|
return c.config
|
|
}
|
|
|
|
func (c *cluster) GetHTTPClient() *http.Client {
|
|
return c.httpClient
|
|
}
|
|
|
|
func (c *cluster) GetClient() client.Client {
|
|
return c.client
|
|
}
|
|
|
|
func (c *cluster) GetScheme() *runtime.Scheme {
|
|
return c.scheme
|
|
}
|
|
|
|
func (c *cluster) GetFieldIndexer() client.FieldIndexer {
|
|
return c.fieldIndexes
|
|
}
|
|
|
|
func (c *cluster) GetCache() cache.Cache {
|
|
return c.cache
|
|
}
|
|
|
|
func (c *cluster) GetEventRecorderFor(name string) record.EventRecorder {
|
|
return c.recorderProvider.GetEventRecorderFor(name)
|
|
}
|
|
|
|
func (c *cluster) GetRESTMapper() meta.RESTMapper {
|
|
return c.mapper
|
|
}
|
|
|
|
func (c *cluster) GetAPIReader() client.Reader {
|
|
return c.apiReader
|
|
}
|
|
|
|
func (c *cluster) GetLogger() logr.Logger {
|
|
return c.logger
|
|
}
|
|
|
|
func (c *cluster) Start(ctx context.Context) error {
|
|
defer c.recorderProvider.Stop(ctx)
|
|
return c.cache.Start(ctx)
|
|
}
|