mirror of
https://github.com/ceph/ceph-csi.git
synced 2025-03-09 08:59:30 +00:00
Several packages are only used while running the e2e suite. These packages are less important to update, as the they can not influence the final executable that is part of the Ceph-CSI container-image. By moving these dependencies out of the main Ceph-CSI go.mod, it is easier to identify if a reported CVE affects Ceph-CSI, or only the testing (like most of the Kubernetes CVEs). Signed-off-by: Niels de Vos <ndevos@ibm.com>
147 lines
4.9 KiB
Go
147 lines
4.9 KiB
Go
/*
|
|
Copyright 2021 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 api
|
|
|
|
import (
|
|
admissionv1 "k8s.io/api/admission/v1"
|
|
"k8s.io/apimachinery/pkg/runtime"
|
|
"k8s.io/apimachinery/pkg/runtime/schema"
|
|
)
|
|
|
|
// Attributes exposes the admission request parameters consumed by the PodSecurity admission controller.
|
|
type Attributes interface {
|
|
// GetName is the name of the object associated with the request.
|
|
GetName() string
|
|
// GetNamespace is the namespace associated with the request (if any)
|
|
GetNamespace() string
|
|
// GetResource is the name of the resource being requested. This is not the kind. For example: pods
|
|
GetResource() schema.GroupVersionResource
|
|
// GetKind is the name of the kind being requested. For example: Pod
|
|
GetKind() schema.GroupVersionKind
|
|
// 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.
|
|
// 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"
|
|
// (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".
|
|
GetSubresource() string
|
|
// GetOperation is the operation being performed
|
|
GetOperation() admissionv1.Operation
|
|
|
|
// GetObject returns the typed Object from incoming request.
|
|
// For objects in the core API group, the result must use the v1 API.
|
|
GetObject() (runtime.Object, error)
|
|
// GetOldObject returns the typed existing object. Only populated for UPDATE requests.
|
|
// For objects in the core API group, the result must use the v1 API.
|
|
GetOldObject() (runtime.Object, error)
|
|
// GetUserName is the requesting user's authenticated name.
|
|
GetUserName() string
|
|
}
|
|
|
|
// AttributesRecord is a simple struct implementing the Attributes interface.
|
|
type AttributesRecord struct {
|
|
Name string
|
|
Namespace string
|
|
Kind schema.GroupVersionKind
|
|
Resource schema.GroupVersionResource
|
|
Subresource string
|
|
Operation admissionv1.Operation
|
|
Object runtime.Object
|
|
OldObject runtime.Object
|
|
Username string
|
|
}
|
|
|
|
func (a *AttributesRecord) GetName() string {
|
|
return a.Name
|
|
}
|
|
func (a *AttributesRecord) GetNamespace() string {
|
|
return a.Namespace
|
|
}
|
|
func (a *AttributesRecord) GetKind() schema.GroupVersionKind {
|
|
return a.Kind
|
|
}
|
|
func (a *AttributesRecord) GetResource() schema.GroupVersionResource {
|
|
return a.Resource
|
|
}
|
|
func (a *AttributesRecord) GetSubresource() string {
|
|
return a.Subresource
|
|
}
|
|
func (a *AttributesRecord) GetOperation() admissionv1.Operation {
|
|
return a.Operation
|
|
}
|
|
func (a *AttributesRecord) GetUserName() string {
|
|
return a.Username
|
|
}
|
|
func (a *AttributesRecord) GetObject() (runtime.Object, error) {
|
|
return a.Object, nil
|
|
}
|
|
func (a *AttributesRecord) GetOldObject() (runtime.Object, error) {
|
|
return a.OldObject, nil
|
|
}
|
|
|
|
var _ Attributes = &AttributesRecord{}
|
|
|
|
// RequestAttributes adapts an admission.Request to the Attributes interface.
|
|
func RequestAttributes(request *admissionv1.AdmissionRequest, decoder runtime.Decoder) Attributes {
|
|
return &attributes{
|
|
r: request,
|
|
decoder: decoder,
|
|
}
|
|
}
|
|
|
|
// attributes is an interface used by AdmissionController to get information about a request
|
|
// that is used to make an admission decision.
|
|
type attributes struct {
|
|
r *admissionv1.AdmissionRequest
|
|
decoder runtime.Decoder
|
|
}
|
|
|
|
func (a *attributes) GetName() string {
|
|
return a.r.Name
|
|
}
|
|
func (a *attributes) GetNamespace() string {
|
|
return a.r.Namespace
|
|
}
|
|
func (a *attributes) GetKind() schema.GroupVersionKind {
|
|
return schema.GroupVersionKind(a.r.Kind)
|
|
}
|
|
func (a *attributes) GetResource() schema.GroupVersionResource {
|
|
return schema.GroupVersionResource(a.r.Resource)
|
|
}
|
|
func (a *attributes) GetSubresource() string {
|
|
return a.r.RequestSubResource
|
|
}
|
|
func (a *attributes) GetOperation() admissionv1.Operation {
|
|
return a.r.Operation
|
|
}
|
|
func (a *attributes) GetUserName() string {
|
|
return a.r.UserInfo.Username
|
|
}
|
|
func (a *attributes) GetObject() (runtime.Object, error) {
|
|
return a.decode(a.r.Object)
|
|
}
|
|
func (a *attributes) GetOldObject() (runtime.Object, error) {
|
|
return a.decode(a.r.OldObject)
|
|
}
|
|
func (a *attributes) decode(in runtime.RawExtension) (runtime.Object, error) {
|
|
if in.Raw == nil {
|
|
return nil, nil
|
|
}
|
|
gvk := schema.GroupVersionKind(a.r.Kind)
|
|
out, _, err := a.decoder.Decode(in.Raw, &gvk, nil)
|
|
return out, err
|
|
}
|
|
|
|
var _ Attributes = &attributes{}
|