From 5eae32f2b0acd2e2ca2774f490853de2d8d0e3b7 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Thu, 16 Jul 2015 17:22:45 -0700 Subject: [PATCH] Return proper InvalidArgument messages like s3 for invalid data for ListObjects(), ListObjectParts(), ListMultipartUploads() --- pkg/server/api/bucket-handlers.go | 8 ++++++++ pkg/server/api/errors.go | 26 +++++++++++++++++++++++++- pkg/server/api/object-handlers.go | 8 ++++++++ 3 files changed, 41 insertions(+), 1 deletion(-) diff --git a/pkg/server/api/bucket-handlers.go b/pkg/server/api/bucket-handlers.go index d5b34d35a..eb5911f88 100644 --- a/pkg/server/api/bucket-handlers.go +++ b/pkg/server/api/bucket-handlers.go @@ -88,6 +88,10 @@ func (api Minio) ListMultipartUploadsHandler(w http.ResponseWriter, req *http.Re } resources := getBucketMultipartResources(req.URL.Query()) + if resources.MaxUploads < 0 { + writeErrorResponse(w, req, InvalidMaxUploads, acceptsContentType, req.URL.Path) + return + } if resources.MaxUploads == 0 { resources.MaxUploads = maxObjectList } @@ -155,6 +159,10 @@ func (api Minio) ListObjectsHandler(w http.ResponseWriter, req *http.Request) { } resources := getBucketResources(req.URL.Query()) + if resources.Maxkeys < 0 { + writeErrorResponse(w, req, InvalidMaxKeys, acceptsContentType, req.URL.Path) + return + } if resources.Maxkeys == 0 { resources.Maxkeys = maxObjectList } diff --git a/pkg/server/api/errors.go b/pkg/server/api/errors.go index 7879a18ba..1058c2937 100644 --- a/pkg/server/api/errors.go +++ b/pkg/server/api/errors.go @@ -52,6 +52,10 @@ const ( InvalidDigest InvalidRange InvalidRequest + InvalidMaxKeys + InvalidMaxUploads + InvalidMaxParts + InvalidPartNumberMarker MalformedXML MissingContentLength MissingRequestBodyError @@ -69,11 +73,31 @@ const ( // Error codes, non exhaustive list - standard HTTP errors const ( - NotAcceptable = iota + 25 + NotAcceptable = iota + 29 ) // Error code to Error structure map var errorCodeResponse = map[int]Error{ + InvalidMaxUploads: { + Code: "InvalidArgument", + Description: "Argument maxUploads must be an integer between 0 and 2147483647", + HTTPStatusCode: http.StatusBadRequest, + }, + InvalidMaxKeys: { + Code: "InvalidArgument", + Description: "Argument maxKeys must be an integer between 0 and 2147483647", + HTTPStatusCode: http.StatusBadRequest, + }, + InvalidMaxParts: { + Code: "InvalidArgument", + Description: "Argument maxParts must be an integer between 1 and 10000 ", + HTTPStatusCode: http.StatusBadRequest, + }, + InvalidPartNumberMarker: { + Code: "InvalidArgument", + Description: "Argument partNumberMarker must be an integer", + HTTPStatusCode: http.StatusBadRequest, + }, AccessDenied: { Code: "AccessDenied", Description: "Access Denied", diff --git a/pkg/server/api/object-handlers.go b/pkg/server/api/object-handlers.go index f1a5d73d5..e51fb1bac 100644 --- a/pkg/server/api/object-handlers.go +++ b/pkg/server/api/object-handlers.go @@ -473,6 +473,14 @@ func (api Minio) ListObjectPartsHandler(w http.ResponseWriter, req *http.Request } objectResourcesMetadata := getObjectResources(req.URL.Query()) + if objectResourcesMetadata.PartNumberMarker < 0 { + writeErrorResponse(w, req, InvalidPartNumberMarker, acceptsContentType, req.URL.Path) + return + } + if objectResourcesMetadata.MaxParts < 0 { + writeErrorResponse(w, req, InvalidMaxParts, acceptsContentType, req.URL.Path) + return + } if objectResourcesMetadata.MaxParts == 0 { objectResourcesMetadata.MaxParts = maxPartsList }