aboutsummaryrefslogtreecommitdiff
path: root/weed/s3api/s3api_handlers.go
diff options
context:
space:
mode:
Diffstat (limited to 'weed/s3api/s3api_handlers.go')
-rw-r--r--weed/s3api/s3api_handlers.go78
1 files changed, 4 insertions, 74 deletions
diff --git a/weed/s3api/s3api_handlers.go b/weed/s3api/s3api_handlers.go
index 6935c75bd..b4d2c22e7 100644
--- a/weed/s3api/s3api_handlers.go
+++ b/weed/s3api/s3api_handlers.go
@@ -1,45 +1,16 @@
package s3api
import (
- "bytes"
"encoding/base64"
- "encoding/xml"
"fmt"
"github.com/chrislusf/seaweedfs/weed/s3api/s3err"
- "net/http"
- "net/url"
- "strconv"
- "time"
-
"google.golang.org/grpc"
+ "net/http"
- "github.com/chrislusf/seaweedfs/weed/glog"
"github.com/chrislusf/seaweedfs/weed/pb"
"github.com/chrislusf/seaweedfs/weed/pb/filer_pb"
)
-type mimeType string
-
-const (
- mimeNone mimeType = ""
- mimeJSON mimeType = "application/json"
- mimeXML mimeType = "application/xml"
-)
-
-func setCommonHeaders(w http.ResponseWriter) {
- w.Header().Set("x-amz-request-id", fmt.Sprintf("%d", time.Now().UnixNano()))
- w.Header().Set("Accept-Ranges", "bytes")
-}
-
-// Encodes the response headers into XML format.
-func encodeResponse(response interface{}) []byte {
- var bytesBuffer bytes.Buffer
- bytesBuffer.WriteString(xml.Header)
- e := xml.NewEncoder(&bytesBuffer)
- e.Encode(response)
- return bytesBuffer.Bytes()
-}
-
var _ = filer_pb.FilerClient(&S3ApiServer{})
func (s3a *S3ApiServer) WithFilerClient(fn func(filer_pb.SeaweedFilerClient) error) error {
@@ -54,53 +25,12 @@ func (s3a *S3ApiServer) AdjustedUrl(location *filer_pb.Location) string {
return location.Url
}
-// If none of the http routes match respond with MethodNotAllowed
-func notFoundHandler(w http.ResponseWriter, r *http.Request) {
- glog.V(0).Infof("unsupported %s %s", r.Method, r.RequestURI)
- writeErrorResponse(w, s3err.ErrMethodNotAllowed, r.URL)
-}
-
-func writeErrorResponse(w http.ResponseWriter, errorCode s3err.ErrorCode, reqURL *url.URL) {
- apiError := s3err.GetAPIError(errorCode)
- errorResponse := getRESTErrorResponse(apiError, reqURL.Path)
- encodedErrorResponse := encodeResponse(errorResponse)
- writeResponse(w, apiError.HTTPStatusCode, encodedErrorResponse, mimeXML)
-}
-
-func getRESTErrorResponse(err s3err.APIError, resource string) s3err.RESTErrorResponse {
- return s3err.RESTErrorResponse{
- Code: err.Code,
- Message: err.Description,
- Resource: resource,
- RequestID: fmt.Sprintf("%d", time.Now().UnixNano()),
- }
-}
-
-func writeResponse(w http.ResponseWriter, statusCode int, response []byte, mType mimeType) {
- setCommonHeaders(w)
- if response != nil {
- w.Header().Set("Content-Length", strconv.Itoa(len(response)))
- }
- if mType != mimeNone {
- w.Header().Set("Content-Type", string(mType))
- }
- w.WriteHeader(statusCode)
- if response != nil {
- glog.V(4).Infof("status %d %s: %s", statusCode, mType, string(response))
- _, err := w.Write(response)
- if err != nil {
- glog.V(0).Infof("write err: %v", err)
- }
- w.(http.Flusher).Flush()
- }
-}
-
-func writeSuccessResponseXML(w http.ResponseWriter, response []byte) {
- writeResponse(w, http.StatusOK, response, mimeXML)
+func writeSuccessResponseXML(w http.ResponseWriter, response interface{}) {
+ s3err.WriteXMLResponse(w, http.StatusOK, response)
}
func writeSuccessResponseEmpty(w http.ResponseWriter) {
- writeResponse(w, http.StatusOK, nil, mimeNone)
+ s3err.WriteEmptyResponse(w, http.StatusOK)
}
func validateContentMd5(h http.Header) ([]byte, error) {