mirror of
https://github.com/ceph/ceph-csi.git
synced 2025-03-09 17:09:29 +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>
125 lines
4.9 KiB
Go
125 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 spec3
|
|
|
|
import (
|
|
"encoding/json"
|
|
|
|
"github.com/go-openapi/swag"
|
|
"k8s.io/kube-openapi/pkg/internal"
|
|
jsonv2 "k8s.io/kube-openapi/pkg/internal/third_party/go-json-experiment/json"
|
|
"k8s.io/kube-openapi/pkg/validation/spec"
|
|
)
|
|
|
|
// Operation describes a single API operation on a path, more at https://github.com/OAI/OpenAPI-Specification/blob/master/versions/3.0.0.md#operationObject
|
|
//
|
|
// Note that this struct is actually a thin wrapper around OperationProps to make it referable and extensible
|
|
type Operation struct {
|
|
OperationProps
|
|
spec.VendorExtensible
|
|
}
|
|
|
|
// MarshalJSON is a custom marshal function that knows how to encode Operation as JSON
|
|
func (o *Operation) MarshalJSON() ([]byte, error) {
|
|
if internal.UseOptimizedJSONMarshalingV3 {
|
|
return internal.DeterministicMarshal(o)
|
|
}
|
|
b1, err := json.Marshal(o.OperationProps)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
b2, err := json.Marshal(o.VendorExtensible)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return swag.ConcatJSON(b1, b2), nil
|
|
}
|
|
|
|
func (o *Operation) MarshalNextJSON(opts jsonv2.MarshalOptions, enc *jsonv2.Encoder) error {
|
|
var x struct {
|
|
spec.Extensions
|
|
OperationProps operationPropsOmitZero `json:",inline"`
|
|
}
|
|
x.Extensions = internal.SanitizeExtensions(o.Extensions)
|
|
x.OperationProps = operationPropsOmitZero(o.OperationProps)
|
|
return opts.MarshalNext(enc, x)
|
|
}
|
|
|
|
// UnmarshalJSON hydrates this items instance with the data from JSON
|
|
func (o *Operation) UnmarshalJSON(data []byte) error {
|
|
if internal.UseOptimizedJSONUnmarshalingV3 {
|
|
return jsonv2.Unmarshal(data, o)
|
|
}
|
|
if err := json.Unmarshal(data, &o.OperationProps); err != nil {
|
|
return err
|
|
}
|
|
return json.Unmarshal(data, &o.VendorExtensible)
|
|
}
|
|
|
|
func (o *Operation) UnmarshalNextJSON(opts jsonv2.UnmarshalOptions, dec *jsonv2.Decoder) error {
|
|
var x struct {
|
|
spec.Extensions
|
|
OperationProps
|
|
}
|
|
if err := opts.UnmarshalNext(dec, &x); err != nil {
|
|
return err
|
|
}
|
|
o.Extensions = internal.SanitizeExtensions(x.Extensions)
|
|
o.OperationProps = x.OperationProps
|
|
return nil
|
|
}
|
|
|
|
// OperationProps describes a single API operation on a path, more at https://github.com/OAI/OpenAPI-Specification/blob/master/versions/3.0.0.md#operationObject
|
|
type OperationProps struct {
|
|
// Tags holds a list of tags for API documentation control
|
|
Tags []string `json:"tags,omitempty"`
|
|
// Summary holds a short summary of what the operation does
|
|
Summary string `json:"summary,omitempty"`
|
|
// Description holds a verbose explanation of the operation behavior
|
|
Description string `json:"description,omitempty"`
|
|
// ExternalDocs holds additional external documentation for this operation
|
|
ExternalDocs *ExternalDocumentation `json:"externalDocs,omitempty"`
|
|
// OperationId holds a unique string used to identify the operation
|
|
OperationId string `json:"operationId,omitempty"`
|
|
// Parameters a list of parameters that are applicable for this operation
|
|
Parameters []*Parameter `json:"parameters,omitempty"`
|
|
// RequestBody holds the request body applicable for this operation
|
|
RequestBody *RequestBody `json:"requestBody,omitempty"`
|
|
// Responses holds the list of possible responses as they are returned from executing this operation
|
|
Responses *Responses `json:"responses,omitempty"`
|
|
// Deprecated declares this operation to be deprecated
|
|
Deprecated bool `json:"deprecated,omitempty"`
|
|
// SecurityRequirement holds a declaration of which security mechanisms can be used for this operation
|
|
SecurityRequirement []map[string][]string `json:"security,omitempty"`
|
|
// Servers contains an alternative server array to service this operation
|
|
Servers []*Server `json:"servers,omitempty"`
|
|
}
|
|
|
|
type operationPropsOmitZero struct {
|
|
Tags []string `json:"tags,omitempty"`
|
|
Summary string `json:"summary,omitempty"`
|
|
Description string `json:"description,omitempty"`
|
|
ExternalDocs *ExternalDocumentation `json:"externalDocs,omitzero"`
|
|
OperationId string `json:"operationId,omitempty"`
|
|
Parameters []*Parameter `json:"parameters,omitempty"`
|
|
RequestBody *RequestBody `json:"requestBody,omitzero"`
|
|
Responses *Responses `json:"responses,omitzero"`
|
|
Deprecated bool `json:"deprecated,omitzero"`
|
|
SecurityRequirement []map[string][]string `json:"security,omitempty"`
|
|
Servers []*Server `json:"servers,omitempty"`
|
|
}
|