|
@ -40,11 +40,9 @@ func (s3a *S3ApiServer) ListBucketsHandler(w http.ResponseWriter, r *http.Reques |
|
|
var buckets []*s3.Bucket |
|
|
var buckets []*s3.Bucket |
|
|
for _, entry := range entries { |
|
|
for _, entry := range entries { |
|
|
if entry.IsDirectory { |
|
|
if entry.IsDirectory { |
|
|
if id, ok := entry.Extended[xhttp.AmzIdentityId]; ok { |
|
|
|
|
|
if identityId != string(id) { |
|
|
|
|
|
|
|
|
if !s3a.hasAccess(r, entry) { |
|
|
continue |
|
|
continue |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
buckets = append(buckets, &s3.Bucket{ |
|
|
buckets = append(buckets, &s3.Bucket{ |
|
|
Name: aws.String(entry.Name), |
|
|
Name: aws.String(entry.Name), |
|
|
CreationDate: aws.Time(time.Unix(entry.Attributes.Crtime, 0).UTC()), |
|
|
CreationDate: aws.Time(time.Unix(entry.Attributes.Crtime, 0).UTC()), |
|
@ -126,14 +124,10 @@ func (s3a *S3ApiServer) DeleteBucketHandler(w http.ResponseWriter, r *http.Reque |
|
|
return |
|
|
return |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if entry.Extended != nil { |
|
|
|
|
|
if id, ok := entry.Extended[xhttp.AmzIdentityId]; ok { |
|
|
|
|
|
if string(id) != r.Header.Get(xhttp.AmzIdentityId) { |
|
|
|
|
|
|
|
|
if !s3a.hasAccess(r, entry) { |
|
|
writeErrorResponse(w, s3err.ErrAccessDenied, r.URL) |
|
|
writeErrorResponse(w, s3err.ErrAccessDenied, r.URL) |
|
|
return |
|
|
return |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
err = s3a.WithFilerClient(func(client filer_pb.SeaweedFilerClient) error { |
|
|
err = s3a.WithFilerClient(func(client filer_pb.SeaweedFilerClient) error { |
|
|
|
|
|
|
|
@ -170,14 +164,28 @@ func (s3a *S3ApiServer) HeadBucketHandler(w http.ResponseWriter, r *http.Request |
|
|
return |
|
|
return |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if entry.Extended != nil { |
|
|
|
|
|
if id, ok := entry.Extended[xhttp.AmzIdentityId]; ok { |
|
|
|
|
|
if string(id) != r.Header.Get(xhttp.AmzIdentityId) { |
|
|
|
|
|
|
|
|
if !s3a.hasAccess(r, entry) { |
|
|
writeErrorResponse(w, s3err.ErrAccessDenied, r.URL) |
|
|
writeErrorResponse(w, s3err.ErrAccessDenied, r.URL) |
|
|
return |
|
|
return |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
writeSuccessResponseEmpty(w) |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func (s3a *S3ApiServer) hasAccess(r *http.Request, entry *filer_pb.Entry) bool { |
|
|
|
|
|
isAdmin := r.Header.Get(xhttp.AmzIsAdmin) != "" |
|
|
|
|
|
if isAdmin { |
|
|
|
|
|
return true |
|
|
} |
|
|
} |
|
|
|
|
|
if entry.Extended == nil { |
|
|
|
|
|
return true |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
writeSuccessResponseEmpty(w) |
|
|
|
|
|
|
|
|
identityId := r.Header.Get(xhttp.AmzIdentityId) |
|
|
|
|
|
if id, ok := entry.Extended[xhttp.AmzIdentityId]; ok { |
|
|
|
|
|
if identityId != string(id) { |
|
|
|
|
|
return false |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
return true |
|
|
} |
|
|
} |