123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- /*
- Copyright 2015 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 configmap
- import (
- "k8s.io/kubernetes/pkg/api"
- "k8s.io/kubernetes/pkg/api/rest"
- "k8s.io/kubernetes/pkg/watch"
- )
- // Registry is an interface for things that know how to store ConfigMaps.
- type Registry interface {
- ListConfigMaps(ctx api.Context, options *api.ListOptions) (*api.ConfigMapList, error)
- WatchConfigMaps(ctx api.Context, options *api.ListOptions) (watch.Interface, error)
- GetConfigMap(ctx api.Context, name string) (*api.ConfigMap, error)
- CreateConfigMap(ctx api.Context, cfg *api.ConfigMap) (*api.ConfigMap, error)
- UpdateConfigMap(ctx api.Context, cfg *api.ConfigMap) (*api.ConfigMap, error)
- DeleteConfigMap(ctx api.Context, name string) error
- }
- // storage puts strong typing around storage calls
- type storage struct {
- rest.StandardStorage
- }
- // NewRegistry returns a new Registry interface for the given Storage. Any mismatched
- // types will panic.
- func NewRegistry(s rest.StandardStorage) Registry {
- return &storage{s}
- }
- func (s *storage) ListConfigMaps(ctx api.Context, options *api.ListOptions) (*api.ConfigMapList, error) {
- obj, err := s.List(ctx, options)
- if err != nil {
- return nil, err
- }
- return obj.(*api.ConfigMapList), err
- }
- func (s *storage) WatchConfigMaps(ctx api.Context, options *api.ListOptions) (watch.Interface, error) {
- return s.Watch(ctx, options)
- }
- func (s *storage) GetConfigMap(ctx api.Context, name string) (*api.ConfigMap, error) {
- obj, err := s.Get(ctx, name)
- if err != nil {
- return nil, err
- }
- return obj.(*api.ConfigMap), nil
- }
- func (s *storage) CreateConfigMap(ctx api.Context, cfg *api.ConfigMap) (*api.ConfigMap, error) {
- obj, err := s.Create(ctx, cfg)
- if err != nil {
- return nil, err
- }
- return obj.(*api.ConfigMap), nil
- }
- func (s *storage) UpdateConfigMap(ctx api.Context, cfg *api.ConfigMap) (*api.ConfigMap, error) {
- obj, _, err := s.Update(ctx, cfg.Name, rest.DefaultUpdatedObjectInfo(cfg, api.Scheme))
- if err != nil {
- return nil, err
- }
- return obj.(*api.ConfigMap), nil
- }
- func (s *storage) DeleteConfigMap(ctx api.Context, name string) error {
- _, err := s.Delete(ctx, name, nil)
- return err
- }
|