
- move rest handler into handlers package - move errors into handlers/errors package - move negotation code into handlers/negotation package - move http response writer helpers into handlers/responsewriter package - split up pkg/apiserver/apiserver.go Note: this is only an intermediate step towards a proper genericapiserver package hierarchy.
90 lines
2.4 KiB
Go
Executable File
90 lines
2.4 KiB
Go
Executable File
/*
|
|
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 errors
|
|
|
|
import (
|
|
"fmt"
|
|
"net/http"
|
|
|
|
metav1 "k8s.io/kubernetes/pkg/apis/meta/v1"
|
|
"k8s.io/kubernetes/pkg/storage"
|
|
"k8s.io/kubernetes/pkg/util/runtime"
|
|
)
|
|
|
|
// statusError is an object that can be converted into an metav1.Status
|
|
type statusError interface {
|
|
Status() metav1.Status
|
|
}
|
|
|
|
// ErrToAPIStatus converts an error to an metav1.Status object.
|
|
func ErrToAPIStatus(err error) *metav1.Status {
|
|
switch t := err.(type) {
|
|
case statusError:
|
|
status := t.Status()
|
|
if len(status.Status) == 0 {
|
|
status.Status = metav1.StatusFailure
|
|
}
|
|
if status.Code == 0 {
|
|
switch status.Status {
|
|
case metav1.StatusSuccess:
|
|
status.Code = http.StatusOK
|
|
case metav1.StatusFailure:
|
|
status.Code = http.StatusInternalServerError
|
|
}
|
|
}
|
|
//TODO: check for invalid responses
|
|
return &status
|
|
default:
|
|
status := http.StatusInternalServerError
|
|
switch {
|
|
//TODO: replace me with NewConflictErr
|
|
case storage.IsTestFailed(err):
|
|
status = http.StatusConflict
|
|
}
|
|
// Log errors that were not converted to an error status
|
|
// by REST storage - these typically indicate programmer
|
|
// error by not using pkg/api/errors, or unexpected failure
|
|
// cases.
|
|
runtime.HandleError(fmt.Errorf("apiserver received an error that is not an metav1.Status: %v", err))
|
|
return &metav1.Status{
|
|
Status: metav1.StatusFailure,
|
|
Code: int32(status),
|
|
Reason: metav1.StatusReasonUnknown,
|
|
Message: err.Error(),
|
|
}
|
|
}
|
|
}
|
|
|
|
// errAPIPrefixNotFound indicates that a RequestInfo resolution failed because the request isn't under
|
|
// any known API prefixes
|
|
type errAPIPrefixNotFound struct {
|
|
SpecifiedPrefix string
|
|
}
|
|
|
|
func (e *errAPIPrefixNotFound) Error() string {
|
|
return fmt.Sprintf("no valid API prefix found matching %v", e.SpecifiedPrefix)
|
|
}
|
|
|
|
func IsAPIPrefixNotFound(err error) bool {
|
|
if err == nil {
|
|
return false
|
|
}
|
|
|
|
_, ok := err.(*errAPIPrefixNotFound)
|
|
return ok
|
|
}
|