Hi Mike,

I hope I've some answers for you.

Re a) Holds are stored as a multi-value property. CMIS only allows retrieving and updating multi-value properties as a whole. There is no support for partial retrieval or partial update. But if a client doesn't modify the list of holds, it shouldn't send it to the server. Hence, there is no need for the server to retrieve the list of holds all the time. Do you except a frequent change of holds on an object? In the use cases I know, holds are not updated very often.

Re b) That shouldn't happen if your server implements change tokens correctly. Change tokens are supposed to prevent lost updates.


- Florian



Hi all,

In the current CMIS 1.1 spec, hold is supported by secondary type.
Specifically, the user can add/remove ids from cmis:hold.rm_holdIds to
add/remove holds. There are two major issues here.
a) The user need to firstly retrieve out the whole hold list before the
   user can add/remove hold. The list might be a big one depends on
business needs. In CMIS server side implementation, we need to firstly retrieve out this list from content server and compare it to the list in
   the update request. So that we get to know which one should be
   added/removed. Even though there is no change in this list, we still
need to do the retrieve and compare practice in each checkin. This will
   not perform well.
b) May result in inconsistences in consequent updates. For example, user
   A is trying to add a hold, so it pass the original list plus the one
that it wants to add hold. Now user B wants to add another hold. If user
   B's original list had been retrieved out before user A completed the
   update, then user A's update will be overwritten by user B's update,
   unintentionally.


So, I wonder whether there is a better way to add/remove holds without
going through the retrieve and compare logic in an update(checkin). Thanks
in advance!


Best Regards,

Mike Li(李永亮)
IBM Content Manager RM Development
Tel:(86-10)82453403 Fax:(86-10)58851920 Tie-line: 905-3403
liyo...@cn.ibm.com

Reply via email to