diff options
| author | chrislu <chris.lu@gmail.com> | 2025-07-18 15:39:30 -0700 |
|---|---|---|
| committer | chrislu <chris.lu@gmail.com> | 2025-07-18 15:39:30 -0700 |
| commit | 0123abe49b51a250b46831e07417f5f5ae503866 (patch) | |
| tree | 8ef8dd8980f64d5158131c61c30b531377d87b7a /weed/s3api/s3api_object_handlers_put.go | |
| parent | 4b92f03b654b97ee7317bd7fc5b195b65a735550 (diff) | |
| download | seaweedfs-0123abe49b51a250b46831e07417f5f5ae503866.tar.xz seaweedfs-0123abe49b51a250b46831e07417f5f5ae503866.zip | |
address test errors
With these fixes, the s3-tests should now:
✅ Return InvalidBucketState (409 Conflict) for object lock operations on invalid buckets
✅ Return MalformedXML for invalid retention configurations
✅ Include VersionId in response headers when available
✅ Return proper HTTP status codes (403 Forbidden for retention mode changes)
✅ Handle all object lock validation errors consistently
Diffstat (limited to 'weed/s3api/s3api_object_handlers_put.go')
| -rw-r--r-- | weed/s3api/s3api_object_handlers_put.go | 22 |
1 files changed, 9 insertions, 13 deletions
diff --git a/weed/s3api/s3api_object_handlers_put.go b/weed/s3api/s3api_object_handlers_put.go index c601fbe36..a52fd90b4 100644 --- a/weed/s3api/s3api_object_handlers_put.go +++ b/weed/s3api/s3api_object_handlers_put.go @@ -555,26 +555,22 @@ func (s3a *S3ApiServer) validateObjectLockHeaders(r *http.Request, versioningEna func mapValidationErrorToS3Error(err error) s3err.ErrorCode { switch { case errors.Is(err, ErrObjectLockVersioningRequired): - // For object lock operations on non-versioned buckets, return 409 Conflict + // For object lock operations on non-versioned buckets, return InvalidBucketState // This matches AWS S3 behavior and s3-tests expectations - return s3err.ErrBucketNotEmpty // This maps to 409 Conflict + return s3err.ErrInvalidBucketState case errors.Is(err, ErrInvalidObjectLockMode): return s3err.ErrInvalidRequest case errors.Is(err, ErrInvalidLegalHoldStatus): // For malformed legal hold status, return MalformedXML as expected by s3-tests return s3err.ErrMalformedXML case errors.Is(err, ErrInvalidRetentionDateFormat): - return s3err.ErrMalformedDate - case errors.Is(err, ErrRetentionDateMustBeFuture), - errors.Is(err, ErrObjectLockModeRequiresDate), - errors.Is(err, ErrRetentionDateRequiresMode): - return s3err.ErrInvalidRequest - case errors.Is(err, ErrGovernanceBypassVersioningRequired): - return s3err.ErrInvalidRequest - case errors.Is(err, ErrInvalidObjectLockDuration): - return s3err.ErrInvalidRequest - case errors.Is(err, ErrObjectLockDurationExceeded): - return s3err.ErrInvalidRequest + return s3err.ErrMalformedXML + case errors.Is(err, ErrInvalidRetentionPeriod): + // For invalid retention periods (days/years), return MalformedXML + return s3err.ErrMalformedXML + case errors.Is(err, ErrInvalidRetentionMode): + // For invalid retention modes, return MalformedXML + return s3err.ErrMalformedXML default: return s3err.ErrInvalidRequest } |
