mirror of
https://github.com/minio/minio.git
synced 2025-01-13 16:03:21 -05:00
fix validation for deletemarker replication on object locked bucket (#10892)
This commit is contained in:
parent
1ebf6f146a
commit
f60b6eb82e
@ -2716,7 +2716,7 @@ func (api objectAPIHandlers) DeleteObjectHandler(w http.ResponseWriter, r *http.
|
|||||||
opts.DeleteMarkerReplicationStatus = string(replication.Pending)
|
opts.DeleteMarkerReplicationStatus = string(replication.Pending)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
replicaDel := false
|
||||||
if r.Header.Get(xhttp.AmzBucketReplicationStatus) == replication.Replica.String() {
|
if r.Header.Get(xhttp.AmzBucketReplicationStatus) == replication.Replica.String() {
|
||||||
// check if replica has permission to be deleted.
|
// check if replica has permission to be deleted.
|
||||||
if apiErrCode := checkRequestAuthType(ctx, r, policy.ReplicateDeleteAction, bucket, object); apiErrCode != ErrNone {
|
if apiErrCode := checkRequestAuthType(ctx, r, policy.ReplicateDeleteAction, bucket, object); apiErrCode != ErrNone {
|
||||||
@ -2724,14 +2724,19 @@ func (api objectAPIHandlers) DeleteObjectHandler(w http.ResponseWriter, r *http.
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
opts.DeleteMarkerReplicationStatus = replication.Replica.String()
|
opts.DeleteMarkerReplicationStatus = replication.Replica.String()
|
||||||
|
replicaDel = true
|
||||||
|
}
|
||||||
|
vID := opts.VersionID
|
||||||
|
if replicaDel && opts.VersionPurgeStatus.Empty() {
|
||||||
|
// opts.VersionID holds delete marker version ID to replicate and not yet present on disk
|
||||||
|
vID = ""
|
||||||
}
|
}
|
||||||
|
|
||||||
apiErr := ErrNone
|
apiErr := ErrNone
|
||||||
if rcfg, _ := globalBucketObjectLockSys.Get(bucket); rcfg.LockEnabled {
|
if rcfg, _ := globalBucketObjectLockSys.Get(bucket); rcfg.LockEnabled {
|
||||||
if opts.VersionID != "" {
|
if vID != "" {
|
||||||
apiErr = enforceRetentionBypassForDelete(ctx, r, bucket, ObjectToDelete{
|
apiErr = enforceRetentionBypassForDelete(ctx, r, bucket, ObjectToDelete{
|
||||||
ObjectName: object,
|
ObjectName: object,
|
||||||
VersionID: opts.VersionID,
|
VersionID: vID,
|
||||||
}, getObjectInfo)
|
}, getObjectInfo)
|
||||||
if apiErr != ErrNone && apiErr != ErrNoSuchKey {
|
if apiErr != ErrNone && apiErr != ErrNoSuchKey {
|
||||||
writeErrorResponse(ctx, w, errorCodes.ToAPIErr(apiErr), r.URL, guessIsBrowserReq(r))
|
writeErrorResponse(ctx, w, errorCodes.ToAPIErr(apiErr), r.URL, guessIsBrowserReq(r))
|
||||||
|
Loading…
Reference in New Issue
Block a user