mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2024-01-19 02:48:24 +00:00
s3: DeleteMultipleObjectsHandler clean up leftover empty folders
fix https://github.com/chrislusf/seaweedfs/issues/1772
This commit is contained in:
parent
9c56b46886
commit
609daaf387
|
@ -206,18 +206,8 @@ func (s3a *S3ApiServer) DeleteMultipleObjectsHandler(w http.ResponseWriter, r *h
|
||||||
}
|
}
|
||||||
|
|
||||||
// purge empty folders, only checking folders with deletions
|
// purge empty folders, only checking folders with deletions
|
||||||
var allDirs []string
|
for len(directoriesWithDeletion) > 0 {
|
||||||
for dir, _ := range directoriesWithDeletion {
|
directoriesWithDeletion = doDeleteEmptyDirectories(client, directoriesWithDeletion)
|
||||||
allDirs = append(allDirs, dir)
|
|
||||||
}
|
|
||||||
sort.Slice(allDirs, func(i, j int) bool {
|
|
||||||
return len(allDirs[i]) > len(allDirs[j])
|
|
||||||
})
|
|
||||||
for _, dir := range allDirs {
|
|
||||||
parentDir, dirName := util.FullPath(dir).DirAndName()
|
|
||||||
if err := doDeleteEntry(client, parentDir, dirName, false, false); err != nil {
|
|
||||||
glog.V(4).Infof("directory %s has %d deletion but still not empty: %v", dir, directoriesWithDeletion[dir], err)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
|
@ -233,6 +223,26 @@ func (s3a *S3ApiServer) DeleteMultipleObjectsHandler(w http.ResponseWriter, r *h
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func doDeleteEmptyDirectories(client filer_pb.SeaweedFilerClient, directoriesWithDeletion map[string]int) (newDirectoriesWithDeletion map[string]int){
|
||||||
|
var allDirs []string
|
||||||
|
for dir, _ := range directoriesWithDeletion {
|
||||||
|
allDirs = append(allDirs, dir)
|
||||||
|
}
|
||||||
|
sort.Slice(allDirs, func(i, j int) bool {
|
||||||
|
return len(allDirs[i]) > len(allDirs[j])
|
||||||
|
})
|
||||||
|
newDirectoriesWithDeletion = make(map[string]int)
|
||||||
|
for _, dir := range allDirs {
|
||||||
|
parentDir, dirName := util.FullPath(dir).DirAndName()
|
||||||
|
if err := doDeleteEntry(client, parentDir, dirName, false, false); err != nil {
|
||||||
|
glog.V(4).Infof("directory %s has %d deletion but still not empty: %v", dir, directoriesWithDeletion[dir], err)
|
||||||
|
} else {
|
||||||
|
newDirectoriesWithDeletion[parentDir]++
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
var passThroughHeaders = []string{
|
var passThroughHeaders = []string{
|
||||||
"response-cache-control",
|
"response-cache-control",
|
||||||
"response-content-disposition",
|
"response-content-disposition",
|
||||||
|
|
Loading…
Reference in a new issue