- From: <jamsden@us.ibm.com>
- Date: Thu, 19 Aug 1999 09:06:00 -0400
- To: w3c-dist-auth@w3.org
I too would be happy to see Depth: infinity locks go. As Geoff says, they should be substantially unnecessary with versioning systems. They were hard and expensive to implement, and have the effect of reducing resource availability. Perhaps users should be more proactive about their locking and use clients to do "depth" locks when necessary instead of having this facility implemented directly in the server. A client could support a user interface consisting of a "Lock Deep" menu item on a selected collection which iterated over the members of the collection (recursively or not depending on a user option) and lock the members. This would require a lot of round trips, and would result in best-effort locking, but this shouldn't be a significant performance or usability constraint for the few times this capability should be used. "Greg Stein" <gstein@lyra.org> on 08/18/99 06:45:08 PM To: "Geoffrey M. Clemm" <gclemm@tantalum.atria.com>, JSlein@crt.xerox.com cc: w3c-dist-auth@w3.org Subject: Re: Locking: Implementation Considerations I'd be quite happy to dump Depth:infinity locks from mod_dav. There is a lot of code in there to deal with those things. Keith Wannamaker did a good job writing it all and may be sad to see it go :-), but in the best interest of things... I'm game. Cheers, -g ----- Original Message ----- From: Geoffrey M. Clemm <gclemm@tantalum.atria.com> To: <JSlein@crt.xerox.com> Cc: <w3c-dist-auth@w3.org> Sent: Wednesday, August 18, 1999 2:33 PM Subject: Re: Locking: Implementation Considerations > I believe that in the context of advanced collections (multiple > bindings to a single resource) and versioning (multiple workspaces > providing different views of the same URL hierarchy), Depth:infinity > locking will be undesireable both for clients (does the wrong thing) > and for servers (too expensive to implement). > > >From the server side, Judy has described the difficulty of > implementing Depth:infinity locking in the context of multiple > bindings. With the introduction of versioning, with rule-based > selection of each versioned collection on the URL path to a versioned > resource, the cost of maintaining Depth:infinity locking increases to > an even more unacceptable level. > > >From the client side, a Depth:infinity write lock on a collection will > lock all properties of all resources in the workspace's view of that > collection. This effectively prevents labeling and creating > successors of those resources by another user in *any* workspace, > effectively eliminating many critical aspects parallel development. > > In contrast, Depth:0 locks work just fine, since normally you would apply > them only to the working resources you have checked out, and those are > not visible in other workspaces anyway. > > So what conclusion can one draw from all this? > > One possibility is to say that locking is largely unneccessary in the > presence of versioning (after all, everything is read-only unless you > explicitly check it out into your workspace), so versioning servers > just won't bother with locking at all. This would have an unfortunate > interoperability result on Class-2 clients try to work with versioning > servers. > > Another possibility is to downgrade Depth:infinity locking to a MAY, > thereby warning clients that they are likely to find this not supported, > and to turn the default lock into Depth:0, instead of Depth:infinity. > The latter will cause an interoperability issue with existing class-2 > servers, but since there aren't many of those yet, if we move fast, this > would probably be OK. > > Cheers, > Geoff > > From: "Slein, Judith A" <JSlein@crt.xerox.com> > Date: Thu, 5 Aug 1999 17:13:56 -0400 > Mime-Version: 1.0 > X-Mailer: Internet Mail Service (5.5.2448.0) > charset="iso-8859-1" > Resent-From: w3c-dist-auth@w3.org > X-Mailing-List: <w3c-dist-auth@w3.org> archive/latest/3120 > X-Loop: w3c-dist-auth@w3.org > Sender: w3c-dist-auth-request@w3.org > Resent-Sender: w3c-dist-auth-request@w3.org > Precedence: list > Content-Type: text/plain; > charset="iso-8859-1" > Content-Length: 1787 > > One of the issues we've been talking about is what should happen if you MOVE > a resource into a locked collection. What lock should be on the resource > after the MOVE? > > I think the question is whether collection locks with Depth: infinity should > be inherited statically or dynamically. Should a collection lock with > Depth: infinity affect just those resources that are in the collection at > the time the lock is created (static inheritance), or should the lock affect > whatever resources come into the collection while it is in force (and stop > applying to any resources that are removed from the collection) (dynamic > inheritance)? > > Static inheritance suggests that the lock would be maintained on the > collection and also maintained on each resource in the collection to depth > infinity. It would be painful to create this lock, and painful to remove > it, and while it is in force it would be necessary to keep track of the > MOVEs out of the collection in order to be able to remove the lock correctly > in the end. However, if every lock is maintained on each resource it > affects, it is easy to tell whether a given resource is locked. > > Dynamic inheritance suggests that the lock would be maintained only on the > collection. It is easy to create and remove such a lock. But it is > difficult to tell whether any given resource is locked when someone attempts > a PUT, MOVE, etc. Especially once the BIND method is available, you would > have to trace from the resource in question upward through all the bindings > on all the collections in the hierarchy to find out whether the resource is > locked. > > Currently, section 7.7 of RFC 2518 requires dynamic inheritance of locks.
Received on Thursday, 19 August 1999 09:06:28 UTC