123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 |
- /*
- Copyright 2014 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 runtime
- import (
- "fmt"
- "reflect"
- "strings"
- "k8s.io/apimachinery/pkg/runtime/schema"
- )
- type notRegisteredErr struct {
- schemeName string
- gvk schema.GroupVersionKind
- target GroupVersioner
- t reflect.Type
- }
- func NewNotRegisteredErrForKind(schemeName string, gvk schema.GroupVersionKind) error {
- return ¬RegisteredErr{schemeName: schemeName, gvk: gvk}
- }
- func NewNotRegisteredErrForType(schemeName string, t reflect.Type) error {
- return ¬RegisteredErr{schemeName: schemeName, t: t}
- }
- func NewNotRegisteredErrForTarget(schemeName string, t reflect.Type, target GroupVersioner) error {
- return ¬RegisteredErr{schemeName: schemeName, t: t, target: target}
- }
- func NewNotRegisteredGVKErrForTarget(schemeName string, gvk schema.GroupVersionKind, target GroupVersioner) error {
- return ¬RegisteredErr{schemeName: schemeName, gvk: gvk, target: target}
- }
- func (k *notRegisteredErr) Error() string {
- if k.t != nil && k.target != nil {
- return fmt.Sprintf("%v is not suitable for converting to %q in scheme %q", k.t, k.target, k.schemeName)
- }
- nullGVK := schema.GroupVersionKind{}
- if k.gvk != nullGVK && k.target != nil {
- return fmt.Sprintf("%q is not suitable for converting to %q in scheme %q", k.gvk.GroupVersion(), k.target, k.schemeName)
- }
- if k.t != nil {
- return fmt.Sprintf("no kind is registered for the type %v in scheme %q", k.t, k.schemeName)
- }
- if len(k.gvk.Kind) == 0 {
- return fmt.Sprintf("no version %q has been registered in scheme %q", k.gvk.GroupVersion(), k.schemeName)
- }
- if k.gvk.Version == APIVersionInternal {
- return fmt.Sprintf("no kind %q is registered for the internal version of group %q in scheme %q", k.gvk.Kind, k.gvk.Group, k.schemeName)
- }
- return fmt.Sprintf("no kind %q is registered for version %q in scheme %q", k.gvk.Kind, k.gvk.GroupVersion(), k.schemeName)
- }
- // IsNotRegisteredError returns true if the error indicates the provided
- // object or input data is not registered.
- func IsNotRegisteredError(err error) bool {
- if err == nil {
- return false
- }
- _, ok := err.(*notRegisteredErr)
- return ok
- }
- type missingKindErr struct {
- data string
- }
- func NewMissingKindErr(data string) error {
- return &missingKindErr{data}
- }
- func (k *missingKindErr) Error() string {
- return fmt.Sprintf("Object 'Kind' is missing in '%s'", k.data)
- }
- // IsMissingKind returns true if the error indicates that the provided object
- // is missing a 'Kind' field.
- func IsMissingKind(err error) bool {
- if err == nil {
- return false
- }
- _, ok := err.(*missingKindErr)
- return ok
- }
- type missingVersionErr struct {
- data string
- }
- func NewMissingVersionErr(data string) error {
- return &missingVersionErr{data}
- }
- func (k *missingVersionErr) Error() string {
- return fmt.Sprintf("Object 'apiVersion' is missing in '%s'", k.data)
- }
- // IsMissingVersion returns true if the error indicates that the provided object
- // is missing a 'Version' field.
- func IsMissingVersion(err error) bool {
- if err == nil {
- return false
- }
- _, ok := err.(*missingVersionErr)
- return ok
- }
- // strictDecodingError is a base error type that is returned by a strict Decoder such
- // as UniversalStrictDecoder.
- type strictDecodingError struct {
- errors []error
- }
- // NewStrictDecodingError creates a new strictDecodingError object.
- func NewStrictDecodingError(errors []error) error {
- return &strictDecodingError{
- errors: errors,
- }
- }
- func (e *strictDecodingError) Error() string {
- var s strings.Builder
- s.WriteString("strict decoding error: ")
- for i, err := range e.errors {
- if i != 0 {
- s.WriteString(", ")
- }
- s.WriteString(err.Error())
- }
- return s.String()
- }
- func (e *strictDecodingError) Errors() []error {
- return e.errors
- }
- // IsStrictDecodingError returns true if the error indicates that the provided object
- // strictness violations.
- func IsStrictDecodingError(err error) bool {
- if err == nil {
- return false
- }
- _, ok := err.(*strictDecodingError)
- return ok
- }
- // AsStrictDecodingError returns a strict decoding error
- // containing all the strictness violations.
- func AsStrictDecodingError(err error) (*strictDecodingError, bool) {
- if err == nil {
- return nil, false
- }
- strictErr, ok := err.(*strictDecodingError)
- return strictErr, ok
- }
|