Browse Source

return NoSuchBucket instead of InternalError delete non-existed bucket.

pull/1613/head
ruitao.liu 4 years ago
parent
commit
ab966410d2
  1. 9
      weed/s3api/s3api_bucket_handlers.go

9
weed/s3api/s3api_bucket_handlers.go

@ -120,16 +120,19 @@ func (s3a *S3ApiServer) DeleteBucketHandler(w http.ResponseWriter, r *http.Reque
bucket, _ := getBucketAndObject(r)
if entry, err := s3a.get(s3a.option.BucketsPath, bucket); entry != nil && err == nil {
entry, err := s3a.get(s3a.option.BucketsPath, bucket)
if entry == nil || err == filer_pb.ErrNotFound {
writeErrorResponse(w, s3err.ErrNoSuchBucket, r.URL)
return
}
if id, ok := entry.Extended[xhttp.AmzIdentityId]; ok {
if string(id) != r.Header.Get(xhttp.AmzIdentityId) {
writeErrorResponse(w, s3err.ErrAccessDenied, r.URL)
return
}
}
}
err := s3a.WithFilerClient(func(client filer_pb.SeaweedFilerClient) error {
err = s3a.WithFilerClient(func(client filer_pb.SeaweedFilerClient) error {
// delete collection
deleteCollectionRequest := &filer_pb.DeleteCollectionRequest{

Loading…
Cancel
Save