2018-12-19 14:26:16 +00:00
|
|
|
/*
|
2019-04-03 08:46:15 +00:00
|
|
|
Copyright 2018 The Ceph-CSI Authors.
|
2018-12-19 14:26:16 +00:00
|
|
|
|
|
|
|
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 util
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
|
2020-07-09 05:14:10 +00:00
|
|
|
klog "k8s.io/klog/v2"
|
2018-12-19 14:26:16 +00:00
|
|
|
)
|
|
|
|
|
2019-02-25 17:05:20 +00:00
|
|
|
// ForAllFunc is a unary predicate for visiting all cache entries
|
|
|
|
// matching the `pattern' in CachePersister's ForAll function.
|
2018-12-19 14:26:16 +00:00
|
|
|
type ForAllFunc func(identifier string) error
|
|
|
|
|
2019-02-25 17:05:20 +00:00
|
|
|
// CacheEntryNotFound is an error type for "Not Found" cache errors
|
|
|
|
type CacheEntryNotFound struct {
|
|
|
|
error
|
|
|
|
}
|
|
|
|
|
2019-01-28 11:47:06 +00:00
|
|
|
// CachePersister interface implemented for store
|
2018-12-19 14:26:16 +00:00
|
|
|
type CachePersister interface {
|
|
|
|
Create(identifier string, data interface{}) error
|
|
|
|
Get(identifier string, data interface{}) error
|
|
|
|
ForAll(pattern string, destObj interface{}, f ForAllFunc) error
|
|
|
|
Delete(identifier string) error
|
|
|
|
}
|
|
|
|
|
2019-01-28 11:47:06 +00:00
|
|
|
// NewCachePersister returns CachePersister based on store
|
2019-07-04 09:49:57 +00:00
|
|
|
func NewCachePersister(metadataStore, pluginPath string) (CachePersister, error) {
|
2018-12-19 14:26:16 +00:00
|
|
|
if metadataStore == "k8s_configmap" {
|
2020-03-23 02:15:35 +00:00
|
|
|
klog.V(4).Infof("cache-perister: using kubernetes configmap as metadata cache persister")
|
2018-12-19 14:26:16 +00:00
|
|
|
k8scm := &K8sCMCache{}
|
|
|
|
k8scm.Client = NewK8sClient()
|
|
|
|
k8scm.Namespace = GetK8sNamespace()
|
|
|
|
return k8scm, nil
|
|
|
|
} else if metadataStore == "node" {
|
2020-03-23 02:15:35 +00:00
|
|
|
klog.V(4).Infof("cache-persister: using node as metadata cache persister")
|
2018-12-19 14:26:16 +00:00
|
|
|
nc := &NodeCache{}
|
2019-07-04 09:49:57 +00:00
|
|
|
nc.BasePath = pluginPath
|
2019-03-25 14:47:39 +00:00
|
|
|
nc.CacheDir = "controller"
|
2018-12-19 14:26:16 +00:00
|
|
|
return nc, nil
|
|
|
|
}
|
|
|
|
return nil, errors.New("cache-persister: couldn't parse metadatastorage flag")
|
|
|
|
}
|