You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

49 lines
1.4 KiB

  1. package s3api
  2. import (
  3. "github.com/seaweedfs/seaweedfs/weed/s3api/s3_constants"
  4. "github.com/seaweedfs/seaweedfs/weed/s3api/s3account"
  5. "github.com/seaweedfs/seaweedfs/weed/s3api/s3err"
  6. "net/http"
  7. )
  8. func getAccountId(r *http.Request) string {
  9. id := r.Header.Get(s3_constants.AmzAccountId)
  10. if len(id) == 0 {
  11. return s3account.AccountAnonymous.Id
  12. } else {
  13. return id
  14. }
  15. }
  16. func (s3a *S3ApiServer) checkAccessByOwnership(r *http.Request, bucket string) s3err.ErrorCode {
  17. metadata, errCode := s3a.bucketRegistry.GetBucketMetadata(bucket)
  18. if errCode != s3err.ErrNone {
  19. return errCode
  20. }
  21. accountId := getAccountId(r)
  22. if accountId == s3account.AccountAdmin.Id || accountId == *metadata.Owner.ID {
  23. return s3err.ErrNone
  24. }
  25. return s3err.ErrAccessDenied
  26. }
  27. // Check Object-Read related access
  28. // includes:
  29. // - GetObjectHandler
  30. //
  31. // offload object access validation to Filer layer
  32. // - s3acl.CheckObjectAccessForReadObject
  33. func (s3a *S3ApiServer) checkBucketAccessForReadObject(r *http.Request, bucket string) s3err.ErrorCode {
  34. bucketMetadata, errCode := s3a.bucketRegistry.GetBucketMetadata(bucket)
  35. if errCode != s3err.ErrNone {
  36. return errCode
  37. }
  38. if bucketMetadata.ObjectOwnership != s3_constants.OwnershipBucketOwnerEnforced {
  39. //offload object acl validation to filer layer
  40. r.Header.Set(s3_constants.XSeaweedFSHeaderAmzBucketOwnerId, *bucketMetadata.Owner.ID)
  41. }
  42. return s3err.ErrNone
  43. }