Return 400 status instead of 500 for empty volume create body
The `POST /volumes/create` expects a request body to be provided. If no body was provided, a 500 status was returned. A 500 status is incorrect, because the request is invalid (it's not a server error). Before this change: $ curl --unix-socket /var/run/docker.sock -v -X POST http://localhost/volumes/create * Trying /var/run/docker.sock... * Connected to localhost (/Users/sebastiaan/Library/Containers/com.dock) port 80 (#0) > POST /volumes/create HTTP/1.1 > Host: localhost > User-Agent: curl/7.51.0 > Accept: */* > < HTTP/1.1 500 Internal Server Error < Api-Version: 1.30 < Content-Length: 18 < Content-Type: application/json < Date: Wed, 19 Jul 2017 11:29:26 GMT < Docker-Experimental: true < Ostype: linux < Server: Docker/17.06.0-ce (linux) < {"message":"EOF"} * Curl_http_done: called premature == 0 * Connection #0 to host localhost left intact After this change: $ curl --unix-socket /var/run/docker.sock -v -X POST http://localhost/volumes/create * Trying /var/run/docker.sock... * Connected to localhost (/var/run/docker.sock) port 80 (#0) > POST /volumes/create HTTP/1.1 > Host: localhost > User-Agent: curl/7.52.1 > Accept: */* > < HTTP/1.1 400 Bad Request < Api-Version: 1.36 < Content-Type: application/json < Docker-Experimental: false < Ostype: linux < Server: Docker/dev (linux) < Date: Tue, 09 Jan 2018 15:00:13 GMT < Content-Length: 42 < {"message":"no body provided in request"} * Curl_http_done: called premature == 0 * Connection #0 to host localhost left intact Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
This commit is contained in:
parent
be14665210
commit
5ad1e4be6b
1 changed files with 6 additions and 0 deletions
|
@ -2,11 +2,14 @@ package volume
|
|||
|
||||
import (
|
||||
"encoding/json"
|
||||
"errors"
|
||||
"io"
|
||||
"net/http"
|
||||
|
||||
"github.com/docker/docker/api/server/httputils"
|
||||
"github.com/docker/docker/api/types/filters"
|
||||
volumetypes "github.com/docker/docker/api/types/volume"
|
||||
"github.com/docker/docker/errdefs"
|
||||
"golang.org/x/net/context"
|
||||
)
|
||||
|
||||
|
@ -45,6 +48,9 @@ func (v *volumeRouter) postVolumesCreate(ctx context.Context, w http.ResponseWri
|
|||
|
||||
var req volumetypes.VolumesCreateBody
|
||||
if err := json.NewDecoder(r.Body).Decode(&req); err != nil {
|
||||
if err == io.EOF {
|
||||
return errdefs.InvalidParameter(errors.New("got EOF while reading request body"))
|
||||
}
|
||||
return err
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue