]> git-server-git.apps.pok.os.sepia.ceph.com Git - ceph.git/commitdiff
rgw: rgw_obj_key use adjustment in multipart copy part
authorYehuda Sadeh <yehuda@redhat.com>
Fri, 30 Sep 2016 00:43:00 +0000 (17:43 -0700)
committerYehuda Sadeh <yehuda@redhat.com>
Fri, 30 Sep 2016 00:44:32 +0000 (17:44 -0700)
This fixes a case where objects start with double underscore.

Signed-off-by: Yehuda Sadeh <yehuda@redhat.com>
src/rgw/rgw_op.cc

index 37f419197b04c210084dd7fef433733fa915f558..16c6280a652e708715987f3c08633a9430c6dac1 100644 (file)
@@ -2489,8 +2489,7 @@ int RGWPutObj::verify_permission()
     RGWAccessControlPolicy cs_policy(s->cct);
     map<string, bufferlist> cs_attrs;
     rgw_bucket cs_bucket(copy_source_bucket_info.bucket);
-    rgw_obj_key cs_object(copy_source_object_name);
-    rgw_obj cs_obj(cs_bucket, cs_object);
+    rgw_obj_key cs_object(copy_source_object_name, copy_source_version_id);
 
     /* check source object permissions */
     if (read_policy(store, s, copy_source_bucket_info, cs_attrs, &cs_policy, cs_bucket, cs_object) < 0) {
@@ -2715,8 +2714,9 @@ int RGWPutObj::get_data(const off_t fst, const off_t lst, bufferlist& bl)
   new_ofs = fst;
   new_end = lst;
 
-  rgw_obj_key obj_key(copy_source_object_name);
-  rgw_obj obj(copy_source_bucket_info.bucket, obj_key);
+  rgw_obj_key obj_key(copy_source_object_name, copy_source_version_id);
+  rgw_obj obj(copy_source_bucket_info.bucket, obj_key.name);
+  obj.set_instance(obj_key.instance);
 
   RGWRados::Object op_target(store, copy_source_bucket_info, *static_cast<RGWObjectCtx *>(s->obj_ctx), obj);
   RGWRados::Object::Read read_op(&op_target);