k8s.io/apiserver@v0.31.1/pkg/admission/interfaces.go (about)

     1  /*
     2  Copyright 2014 The Kubernetes Authors.
     3  
     4  Licensed under the Apache License, Version 2.0 (the "License");
     5  you may not use this file except in compliance with the License.
     6  You may obtain a copy of the License at
     7  
     8      http://www.apache.org/licenses/LICENSE-2.0
     9  
    10  Unless required by applicable law or agreed to in writing, software
    11  distributed under the License is distributed on an "AS IS" BASIS,
    12  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    13  See the License for the specific language governing permissions and
    14  limitations under the License.
    15  */
    16  
    17  package admission
    18  
    19  import (
    20  	"context"
    21  	"io"
    22  
    23  	"k8s.io/apimachinery/pkg/runtime"
    24  	"k8s.io/apimachinery/pkg/runtime/schema"
    25  	auditinternal "k8s.io/apiserver/pkg/apis/audit"
    26  	"k8s.io/apiserver/pkg/authentication/user"
    27  )
    28  
    29  // Attributes is an interface used by AdmissionController to get information about a request
    30  // that is used to make an admission decision.
    31  type Attributes interface {
    32  	// GetName returns the name of the object as presented in the request.  On a CREATE operation, the client
    33  	// may omit name and rely on the server to generate the name.  If that is the case, this method will return
    34  	// the empty string
    35  	GetName() string
    36  	// GetNamespace is the namespace associated with the request (if any)
    37  	GetNamespace() string
    38  	// GetResource is the name of the resource being requested.  This is not the kind.  For example: pods
    39  	GetResource() schema.GroupVersionResource
    40  	// GetSubresource is the name of the subresource being requested.  This is a different resource, scoped to the parent resource, but it may have a different kind.
    41  	// For instance, /pods has the resource "pods" and the kind "Pod", while /pods/foo/status has the resource "pods", the sub resource "status", and the kind "Pod"
    42  	// (because status operates on pods). The binding resource for a pod though may be /pods/foo/binding, which has resource "pods", subresource "binding", and kind "Binding".
    43  	GetSubresource() string
    44  	// GetOperation is the operation being performed
    45  	GetOperation() Operation
    46  	// GetOperationOptions is the options for the operation being performed
    47  	GetOperationOptions() runtime.Object
    48  	// IsDryRun indicates that modifications will definitely not be persisted for this request. This is to prevent
    49  	// admission controllers with side effects and a method of reconciliation from being overwhelmed.
    50  	// However, a value of false for this does not mean that the modification will be persisted, because it
    51  	// could still be rejected by a subsequent validation step.
    52  	IsDryRun() bool
    53  	// GetObject is the object from the incoming request prior to default values being applied
    54  	GetObject() runtime.Object
    55  	// GetOldObject is the existing object. Only populated for UPDATE and DELETE requests.
    56  	GetOldObject() runtime.Object
    57  	// GetKind is the type of object being manipulated.  For example: Pod
    58  	GetKind() schema.GroupVersionKind
    59  	// GetUserInfo is information about the requesting user
    60  	GetUserInfo() user.Info
    61  
    62  	// AddAnnotation sets annotation according to key-value pair. The key should be qualified, e.g., podsecuritypolicy.admission.k8s.io/admit-policy, where
    63  	// "podsecuritypolicy" is the name of the plugin, "admission.k8s.io" is the name of the organization, "admit-policy" is the key name.
    64  	// An error is returned if the format of key is invalid. When trying to overwrite annotation with a new value, an error is returned.
    65  	// Both ValidationInterface and MutationInterface are allowed to add Annotations.
    66  	// By default, an annotation gets logged into audit event if the request's audit level is greater or
    67  	// equal to Metadata.
    68  	AddAnnotation(key, value string) error
    69  
    70  	// AddAnnotationWithLevel sets annotation according to key-value pair with additional intended audit level.
    71  	// An Annotation gets logged into audit event if the request's audit level is greater or equal to the
    72  	// intended audit level.
    73  	AddAnnotationWithLevel(key, value string, level auditinternal.Level) error
    74  
    75  	// GetReinvocationContext tracks the admission request information relevant to the re-invocation policy.
    76  	GetReinvocationContext() ReinvocationContext
    77  }
    78  
    79  // ObjectInterfaces is an interface used by AdmissionController to get object interfaces
    80  // such as Converter or Defaulter. These interfaces are normally coming from Request Scope
    81  // to handle special cases like CRDs.
    82  type ObjectInterfaces interface {
    83  	// GetObjectCreater is the ObjectCreator appropriate for the requested object.
    84  	GetObjectCreater() runtime.ObjectCreater
    85  	// GetObjectTyper is the ObjectTyper appropriate for the requested object.
    86  	GetObjectTyper() runtime.ObjectTyper
    87  	// GetObjectDefaulter is the ObjectDefaulter appropriate for the requested object.
    88  	GetObjectDefaulter() runtime.ObjectDefaulter
    89  	// GetObjectConvertor is the ObjectConvertor appropriate for the requested object.
    90  	GetObjectConvertor() runtime.ObjectConvertor
    91  	// GetEquivalentResourceMapper is the EquivalentResourceMapper appropriate for finding equivalent resources and expected kind for the requested object.
    92  	GetEquivalentResourceMapper() runtime.EquivalentResourceMapper
    93  }
    94  
    95  // privateAnnotationsGetter is a private interface which allows users to get annotations from Attributes.
    96  type privateAnnotationsGetter interface {
    97  	getAnnotations(maxLevel auditinternal.Level) map[string]string
    98  }
    99  
   100  // AnnotationsGetter allows users to get annotations from Attributes. An alternate Attribute should implement
   101  // this interface.
   102  type AnnotationsGetter interface {
   103  	GetAnnotations(maxLevel auditinternal.Level) map[string]string
   104  }
   105  
   106  // ReinvocationContext provides access to the admission related state required to implement the re-invocation policy.
   107  type ReinvocationContext interface {
   108  	// IsReinvoke returns true if the current admission check is a re-invocation.
   109  	IsReinvoke() bool
   110  	// SetIsReinvoke sets the current admission check as a re-invocation.
   111  	SetIsReinvoke()
   112  	// ShouldReinvoke returns true if any plugin has requested a re-invocation.
   113  	ShouldReinvoke() bool
   114  	// SetShouldReinvoke signals that a re-invocation is desired.
   115  	SetShouldReinvoke()
   116  	// AddValue set a value for a plugin name, possibly overriding a previous value.
   117  	SetValue(plugin string, v interface{})
   118  	// Value reads a value for a webhook.
   119  	Value(plugin string) interface{}
   120  }
   121  
   122  // Interface is an abstract, pluggable interface for Admission Control decisions.
   123  type Interface interface {
   124  	// Handles returns true if this admission controller can handle the given operation
   125  	// where operation can be one of CREATE, UPDATE, DELETE, or CONNECT
   126  	Handles(operation Operation) bool
   127  }
   128  
   129  type MutationInterface interface {
   130  	Interface
   131  
   132  	// Admit makes an admission decision based on the request attributes.
   133  	// Context is used only for timeout/deadline/cancellation and tracing information.
   134  	Admit(ctx context.Context, a Attributes, o ObjectInterfaces) (err error)
   135  }
   136  
   137  // ValidationInterface is an abstract, pluggable interface for Admission Control decisions.
   138  type ValidationInterface interface {
   139  	Interface
   140  
   141  	// Validate makes an admission decision based on the request attributes.  It is NOT allowed to mutate
   142  	// Context is used only for timeout/deadline/cancellation and tracing information.
   143  	Validate(ctx context.Context, a Attributes, o ObjectInterfaces) (err error)
   144  }
   145  
   146  // Operation is the type of resource operation being checked for admission control
   147  type Operation string
   148  
   149  // Operation constants
   150  const (
   151  	Create  Operation = "CREATE"
   152  	Update  Operation = "UPDATE"
   153  	Delete  Operation = "DELETE"
   154  	Connect Operation = "CONNECT"
   155  )
   156  
   157  // PluginInitializer is used for initialization of shareable resources between admission plugins.
   158  // After initialization the resources have to be set separately
   159  type PluginInitializer interface {
   160  	Initialize(plugin Interface)
   161  }
   162  
   163  // InitializationValidator holds ValidateInitialization functions, which are responsible for validation of initialized
   164  // shared resources and should be implemented on admission plugins
   165  type InitializationValidator interface {
   166  	ValidateInitialization() error
   167  }
   168  
   169  // ConfigProvider provides a way to get configuration for an admission plugin based on its name
   170  type ConfigProvider interface {
   171  	ConfigFor(pluginName string) (io.Reader, error)
   172  }