mirror of
https://github.com/containers/podman.git
synced 2025-10-13 09:15:20 +08:00

Using golang.org/x/tools/gopls/internal/analysis/modernize/cmd/modernize + some manual cleanup in libpod/lock/shm/shm_lock_test.go as it generated an unused variable + restored one removed comment Signed-off-by: Paul Holzinger <pholzing@redhat.com>
92 lines
2.7 KiB
Go
92 lines
2.7 KiB
Go
package bindings
|
|
|
|
import (
|
|
"encoding/json"
|
|
"errors"
|
|
"fmt"
|
|
"io"
|
|
|
|
"github.com/blang/semver/v4"
|
|
"github.com/containers/podman/v5/pkg/errorhandling"
|
|
)
|
|
|
|
var (
|
|
ErrNotImplemented = errors.New("function not implemented")
|
|
)
|
|
|
|
func handleError(data []byte, unmarshalErrorInto any) error {
|
|
if err := json.Unmarshal(data, unmarshalErrorInto); err != nil {
|
|
return fmt.Errorf("unmarshalling error into %#v, data %q: %w", unmarshalErrorInto, string(data), err)
|
|
}
|
|
return unmarshalErrorInto.(error)
|
|
}
|
|
|
|
// Process drains the response body, and processes the HTTP status code
|
|
// Note: Closing the response.Body is left to the caller
|
|
func (h *APIResponse) Process(unmarshalInto any) error {
|
|
return h.ProcessWithError(unmarshalInto, &errorhandling.ErrorModel{})
|
|
}
|
|
|
|
// ProcessWithError drains the response body, and processes the HTTP status code
|
|
// Note: Closing the response.Body is left to the caller
|
|
func (h *APIResponse) ProcessWithError(unmarshalInto any, unmarshalErrorInto any) error {
|
|
data, err := io.ReadAll(h.Response.Body)
|
|
if err != nil {
|
|
return fmt.Errorf("unable to process API response: %w", err)
|
|
}
|
|
if h.IsSuccess() || h.IsRedirection() {
|
|
if unmarshalInto != nil {
|
|
if err := json.Unmarshal(data, unmarshalInto); err != nil {
|
|
return fmt.Errorf("unmarshalling into %#v, data %q: %w", unmarshalInto, string(data), err)
|
|
}
|
|
return nil
|
|
}
|
|
return nil
|
|
}
|
|
|
|
if h.IsConflictError() {
|
|
return handleError(data, unmarshalErrorInto)
|
|
}
|
|
if h.Response.Header.Get("Content-Type") == "application/json" {
|
|
return handleError(data, &errorhandling.ErrorModel{})
|
|
}
|
|
return &errorhandling.ErrorModel{
|
|
Message: string(data),
|
|
ResponseCode: h.Response.StatusCode,
|
|
}
|
|
}
|
|
|
|
func CheckResponseCode(inError error) (int, error) {
|
|
switch e := inError.(type) {
|
|
case *errorhandling.ErrorModel:
|
|
return e.Code(), nil
|
|
case *errorhandling.PodConflictErrorModel:
|
|
return e.Code(), nil
|
|
default:
|
|
return -1, errors.New("is not type ErrorModel")
|
|
}
|
|
}
|
|
|
|
type APIVersionError struct {
|
|
endpoint string
|
|
serverVersion *semver.Version
|
|
requiredVersion string
|
|
}
|
|
|
|
// NewAPIVersionError create bindings error when the endpoint on the server is not supported
|
|
// because the version is to old.
|
|
// - endpoint is the name for the endpoint (e.g. /containers/json)
|
|
// - version is the server API version
|
|
// - requiredVersion is the server version need to use said endpoint
|
|
func NewAPIVersionError(endpoint string, version *semver.Version, requiredVersion string) *APIVersionError {
|
|
return &APIVersionError{
|
|
endpoint: endpoint,
|
|
serverVersion: version,
|
|
requiredVersion: requiredVersion,
|
|
}
|
|
}
|
|
|
|
func (e *APIVersionError) Error() string {
|
|
return fmt.Sprintf("API server version is %s, need at least %s to call %s", e.serverVersion.String(), e.requiredVersion, e.endpoint)
|
|
}
|