* RBD: The ``try-netlink`` mapping option for rbd-nbd has become the default
and is now deprecated. If the NBD netlink interface is not supported by the
kernel, then the mapping is retried using the legacy ioctl interface.
+* RGW: PutObjectLockConfiguration can now be used to enable S3 Object Lock on an
+ existing versioning-enabled bucket that was not created with Object Lock enabled.
>=18.2.4
--------
void RGWPutBucketObjectLock::execute(optional_yield y)
{
- if (!s->bucket->get_info().obj_lock_enabled()) {
- s->err.message = "object lock configuration can't be set if bucket object lock not enabled";
+ if (!s->bucket->get_info().versioning_enabled()) {
+ s->err.message = "Object lock cannot be enabled unless the "
+ "bucket has versioning enabled";
ldpp_dout(this, 4) << "ERROR: " << s->err.message << dendl;
op_ret = -ERR_INVALID_BUCKET_STATE;
return;
}
op_ret = retry_raced_bucket_write(this, s->bucket.get(), [this] {
+ if (!s->bucket->get_info().obj_lock_enabled()) {
+ // automatically enable object lock if the bucket is versioning-enabled
+ if (!s->bucket->get_info().versioning_enabled()) {
+ s->err.message = "Object lock cannot be enabled unless the "
+ "bucket has versioning enabled";
+ ldpp_dout(this, 4) << "ERROR: " << s->err.message << dendl;
+ return -ERR_INVALID_BUCKET_STATE;
+ }
+ s->bucket->get_info().flags |= BUCKET_OBJ_LOCK_ENABLED;
+ }
+
s->bucket->get_info().obj_lock = obj_lock;
op_ret = s->bucket->put_info(this, false, real_time());
return op_ret;