Browse Source

s3: report metadata if the directory is explicitly created (#3498)

* replace mkdir to mkFile

* ContentLength must be zero

* revert mkDir

* Seaweedfs-Is-Directory-Key return metadata
pull/3503/head
Konstantin Lebedev 2 years ago
committed by GitHub
parent
commit
f7aeb06544
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 8
      weed/s3api/s3api_object_handlers.go
  2. 9
      weed/server/filer_server_handlers_read.go

8
weed/s3api/s3api_object_handlers.go

@ -93,8 +93,10 @@ func (s3a *S3ApiServer) PutObjectHandler(w http.ResponseWriter, r *http.Request)
defer dataReader.Close() defer dataReader.Close()
objectContentType := r.Header.Get("Content-Type") objectContentType := r.Header.Get("Content-Type")
if strings.HasSuffix(object, "/") {
if err := s3a.mkdir(s3a.option.BucketsPath, bucket+strings.TrimSuffix(object, "/"), func(entry *filer_pb.Entry) {
if strings.HasSuffix(object, "/") && r.ContentLength == 0 {
if err := s3a.mkdir(
s3a.option.BucketsPath, bucket+strings.TrimSuffix(object, "/"),
func(entry *filer_pb.Entry) {
if objectContentType == "" { if objectContentType == "" {
objectContentType = "httpd/unix-directory" objectContentType = "httpd/unix-directory"
} }
@ -314,7 +316,7 @@ func (s3a *S3ApiServer) DeleteMultipleObjectsHandler(w http.ResponseWriter, r *h
func (s3a *S3ApiServer) doDeleteEmptyDirectories(client filer_pb.SeaweedFilerClient, directoriesWithDeletion map[string]int) (newDirectoriesWithDeletion map[string]int) { func (s3a *S3ApiServer) doDeleteEmptyDirectories(client filer_pb.SeaweedFilerClient, directoriesWithDeletion map[string]int) (newDirectoriesWithDeletion map[string]int) {
var allDirs []string var allDirs []string
for dir, _ := range directoriesWithDeletion {
for dir := range directoriesWithDeletion {
allDirs = append(allDirs, dir) allDirs = append(allDirs, dir)
} }
slices.SortFunc(allDirs, func(a, b string) bool { slices.SortFunc(allDirs, func(a, b string) bool {

9
weed/server/filer_server_handlers_read.go

@ -25,6 +25,7 @@ import (
// Validates the preconditions. Returns true if GET/HEAD operation should not proceed. // Validates the preconditions. Returns true if GET/HEAD operation should not proceed.
// Preconditions supported are: // Preconditions supported are:
//
// If-Modified-Since // If-Modified-Since
// If-Unmodified-Since // If-Unmodified-Since
// If-Match // If-Match
@ -111,13 +112,13 @@ func (fs *FilerServer) GetOrHeadHandler(w http.ResponseWriter, r *http.Request)
w.WriteHeader(http.StatusMethodNotAllowed) w.WriteHeader(http.StatusMethodNotAllowed)
return return
} }
if entry.Attr.Mime != "" {
// inform S3 API this is a user created directory key object
w.Header().Set(s3_constants.X_SeaweedFS_Header_Directory_Key, "true")
}
if entry.Attr.Mime == "" {
fs.listDirectoryHandler(w, r) fs.listDirectoryHandler(w, r)
return return
} }
// inform S3 API this is a user created directory key object
w.Header().Set(s3_constants.X_SeaweedFS_Header_Directory_Key, "true")
}
if isForDirectory { if isForDirectory {
w.WriteHeader(http.StatusNotFound) w.WriteHeader(http.StatusNotFound)

Loading…
Cancel
Save