mirror of
https://github.com/minio/minio.git
synced 2025-01-11 23:13:23 -05:00
Add restore-status header for multipart objects (#16508)
This commit is contained in:
parent
f713436dd0
commit
cea2ca8c8e
@ -660,7 +660,9 @@ func putRestoreOpts(bucket, object string, rreq *RestoreObjectRequest, objInfo O
|
|||||||
if len(objInfo.UserTags) != 0 {
|
if len(objInfo.UserTags) != 0 {
|
||||||
meta[xhttp.AmzObjectTagging] = objInfo.UserTags
|
meta[xhttp.AmzObjectTagging] = objInfo.UserTags
|
||||||
}
|
}
|
||||||
|
// Set restore object status
|
||||||
|
restoreExpiry := lifecycle.ExpectedExpiryTime(time.Now().UTC(), rreq.Days)
|
||||||
|
meta[xhttp.AmzRestore] = completedRestoreObj(restoreExpiry).String()
|
||||||
return ObjectOptions{
|
return ObjectOptions{
|
||||||
Versioned: globalBucketVersioningSys.PrefixEnabled(bucket, object),
|
Versioned: globalBucketVersioningSys.PrefixEnabled(bucket, object),
|
||||||
VersionSuspended: globalBucketVersioningSys.PrefixSuspended(bucket, object),
|
VersionSuspended: globalBucketVersioningSys.PrefixSuspended(bucket, object),
|
||||||
|
@ -2006,15 +2006,13 @@ func (er erasureObjects) RestoreTransitionedObject(ctx context.Context, bucket,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// update restore status header in the metadata
|
// update restore status header in the metadata
|
||||||
func (er erasureObjects) updateRestoreMetadata(ctx context.Context, bucket, object string, objInfo ObjectInfo, opts ObjectOptions, rerr error) error {
|
func (er erasureObjects) updateRestoreMetadata(ctx context.Context, bucket, object string, objInfo ObjectInfo, opts ObjectOptions) error {
|
||||||
oi := objInfo.Clone()
|
oi := objInfo.Clone()
|
||||||
oi.metadataOnly = true // Perform only metadata updates.
|
oi.metadataOnly = true // Perform only metadata updates.
|
||||||
|
|
||||||
if rerr == nil {
|
// allow retry in the case of failure to restore
|
||||||
oi.UserDefined[xhttp.AmzRestore] = completedRestoreObj(opts.Transition.RestoreExpiry).String()
|
delete(oi.UserDefined, xhttp.AmzRestore)
|
||||||
} else { // allow retry in the case of failure to restore
|
|
||||||
delete(oi.UserDefined, xhttp.AmzRestore)
|
|
||||||
}
|
|
||||||
if _, err := er.CopyObject(ctx, bucket, object, bucket, object, oi, ObjectOptions{
|
if _, err := er.CopyObject(ctx, bucket, object, bucket, object, oi, ObjectOptions{
|
||||||
VersionID: oi.VersionID,
|
VersionID: oi.VersionID,
|
||||||
}, ObjectOptions{
|
}, ObjectOptions{
|
||||||
@ -2030,7 +2028,10 @@ func (er erasureObjects) updateRestoreMetadata(ctx context.Context, bucket, obje
|
|||||||
// as in the xl.meta for this version and rehydrates the part.n into the fi.DataDir for this version as in the xl.meta
|
// as in the xl.meta for this version and rehydrates the part.n into the fi.DataDir for this version as in the xl.meta
|
||||||
func (er erasureObjects) restoreTransitionedObject(ctx context.Context, bucket string, object string, opts ObjectOptions) error {
|
func (er erasureObjects) restoreTransitionedObject(ctx context.Context, bucket string, object string, opts ObjectOptions) error {
|
||||||
setRestoreHeaderFn := func(oi ObjectInfo, rerr error) error {
|
setRestoreHeaderFn := func(oi ObjectInfo, rerr error) error {
|
||||||
er.updateRestoreMetadata(ctx, bucket, object, oi, opts, rerr)
|
if rerr == nil {
|
||||||
|
return nil // nothing to do; restore object was successful
|
||||||
|
}
|
||||||
|
er.updateRestoreMetadata(ctx, bucket, object, oi, opts)
|
||||||
return rerr
|
return rerr
|
||||||
}
|
}
|
||||||
var oi ObjectInfo
|
var oi ObjectInfo
|
||||||
@ -2054,7 +2055,6 @@ func (er erasureObjects) restoreTransitionedObject(ctx context.Context, bucket s
|
|||||||
return setRestoreHeaderFn(oi, toObjectErr(err, bucket, object))
|
return setRestoreHeaderFn(oi, toObjectErr(err, bucket, object))
|
||||||
}
|
}
|
||||||
pReader := NewPutObjReader(hashReader)
|
pReader := NewPutObjReader(hashReader)
|
||||||
ropts.UserDefined[xhttp.AmzRestore] = completedRestoreObj(opts.Transition.RestoreExpiry).String()
|
|
||||||
_, err = er.PutObject(ctx, bucket, object, pReader, ropts)
|
_, err = er.PutObject(ctx, bucket, object, pReader, ropts)
|
||||||
return setRestoreHeaderFn(oi, toObjectErr(err, bucket, object))
|
return setRestoreHeaderFn(oi, toObjectErr(err, bucket, object))
|
||||||
}
|
}
|
||||||
|
@ -3051,7 +3051,7 @@ func (api objectAPIHandlers) PostRestoreObjectHandler(w http.ResponseWriter, r *
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
// set or upgrade restore expiry
|
// set or upgrade restore expiry
|
||||||
restoreExpiry := lifecycle.ExpectedExpiryTime(time.Now(), rreq.Days)
|
restoreExpiry := lifecycle.ExpectedExpiryTime(time.Now().UTC(), rreq.Days)
|
||||||
metadata := cloneMSS(objInfo.UserDefined)
|
metadata := cloneMSS(objInfo.UserDefined)
|
||||||
|
|
||||||
// update self with restore metadata
|
// update self with restore metadata
|
||||||
|
Loading…
Reference in New Issue
Block a user