diff options
| author | chrislu <chris.lu@gmail.com> | 2025-07-18 15:52:28 -0700 |
|---|---|---|
| committer | chrislu <chris.lu@gmail.com> | 2025-07-18 15:52:28 -0700 |
| commit | 1bc503530a4e7c566242e0b9067f18daec2a349c (patch) | |
| tree | 7c859c8b307019ada994fd377cf09eedd144bc1f /weed/s3api/s3api_bucket_handlers.go | |
| parent | 9f88fd2ea5ca08e430d22d3335f4c96acfa665e4 (diff) | |
| download | seaweedfs-1bc503530a4e7c566242e0b9067f18daec2a349c.tar.xz seaweedfs-1bc503530a4e7c566242e0b9067f18daec2a349c.zip | |
fixes
With these final fixes, the s3-tests should now:
✅ Return MalformedXML for ObjectLockEnabled: 'Disabled'
✅ Return MalformedXML when both Days and Years are specified in retention configuration
✅ Return InvalidBucketState (409 Conflict) when trying to suspend versioning on buckets with object lock enabled
✅ Handle all object lock validation errors consistently with proper error codes
Diffstat (limited to 'weed/s3api/s3api_bucket_handlers.go')
| -rw-r--r-- | weed/s3api/s3api_bucket_handlers.go | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/weed/s3api/s3api_bucket_handlers.go b/weed/s3api/s3api_bucket_handlers.go index e30f172a7..2ecac4d11 100644 --- a/weed/s3api/s3api_bucket_handlers.go +++ b/weed/s3api/s3api_bucket_handlers.go @@ -758,6 +758,17 @@ func (s3a *S3ApiServer) PutBucketVersioningHandler(w http.ResponseWriter, r *htt return } + // Check if trying to suspend versioning on a bucket with object lock enabled + if status == "Suspended" { + // Get bucket configuration to check for object lock + bucketConfig, errCode := s3a.getBucketConfig(bucket) + if errCode == s3err.ErrNone && bucketConfig.ObjectLockConfig != nil { + // Object lock is enabled, cannot suspend versioning + s3err.WriteErrorResponse(w, r, s3err.ErrInvalidBucketState) + return + } + } + // Update bucket versioning configuration using new bucket config system if errCode := s3a.setBucketVersioningStatus(bucket, status); errCode != s3err.ErrNone { glog.Errorf("PutBucketVersioningHandler save config: %d", errCode) |
