RE: Interop issue: Proposal for fixing lock token provision

RE: Interop issue: Proposal for fixing lock token provisionFor example a
long running folder copy, move or delete.
If the operation takes long enough that locks might expire
during the operation, then the semantic might not even be
really enforceable. Particularly, it servers is incapable of checking the
locks in advance, or to do so might be expensive from a time
perspective (say an operation on a optical-archive, where the full set
of resources is only known on the media).
In these cases you want the copy or move to perform "as much work
as possible" so you just want to provide a list of all your current tokens.
A second example is where a server provides multiple views of the same
data. A client may not know for certain what resources it has locked
and are going to participate in a copy, move or delete operation.
Rather than fully enumerating the set of resources to be operated on,
presenting "all-my-tokens" would be useful, if not critical.
A third case is where a user wants the operation to succeed, even
if etags for the locked resources have changed (perhaps a shared-write
has updated the resource, changing its etag). In this case, we want to
present the lock, and don't want to worry about the etag. It might even
have be deleted by the shared-write lock so the token is no longer valid.
Perhaps it is possible to construct an If: header that handles these
cases, but a shorthand that avoids recursive introspection on the server
would be useful, particularly in low-bandwidth environments.
- Seth Osher
 -----Original Message-----
 From: w3c-dist-auth-request@w3.org [mailto:w3c-dist-auth-request@w3.org]On
Behalf Of Julian Reschke
 Sent: Tuesday, October 08, 2002 7:50 PM
 To: Clemm, Geoff; 'Webdav WG'
 Subject: RE: Interop issue: Proposal for fixing lock token provision
 Obviously I agree with Geoff.
 I'd like to underline that I'm *really* interested to understand why a
client would *ever* want a request to succeed if a lock which is supposed to
be present unexpectedly disappeared.
 Julian
 --
 <green/>bytes GmbH -- http://www.greenbytes.de -- tel:+492512807760
 -----Original Message-----
 From: w3c-dist-auth-request@w3.org
[mailto:w3c-dist-auth-request@w3.org]On Behalf Of Clemm, Geoff
 Sent: Tuesday, October 08, 2002 11:18 PM
 To: 'Webdav WG'
 Subject: RE: Interop issue: Proposal for fixing lock token provision
 Julian makes several good points.
 One is that we need to address the If header length problem in 2518bis
 in any case. Even if we did provide a separate header that allowed
 invalid lock tokens, we still need to use the If header when we want
 to check for a list of valid lock tokens, or when we want to check for
 a list of etags.
 Another good point is that we don't have to argue about whether a
 client should be allowed to submit invalid lock tokens, because once
 the If header length problem is addressed (which we have to do
 anyway), then the "If: <tag> (<token>)(Not <token>)" provides this
 functionality without defining a header with new semantics.
 In an earlier message in this thread, the following points were raised
 as being problems with the "If:...Not..." approach:
 PROBLEM #1: Servers may not support the OR, and the NOT, correctly,
 because most clients don't currently use this. This solution HAS NOT
 been proven, it is only theoretical. It might not work.
 It will work against all existing servers that are correctly
 implemented and that don't have an If header length problem, unlike
 the "new header" approach, which is guaranteed to fail against all
 existing servers. If the servers are going to be updated,
 updating them to correctly implement existing semantics seems
 like a sensible approach to take, especially when the existing
 semantics are a "logical or" and a "logical not", built-in operators
 in most programming languages.
 PROBLEM #2: What if multiple locks are required (e.g. moving a
 collection that has multiple locked resources? What if the URLs are
 long? The IF header becomes very long and may be truncated by some
 proxies. E.g.
 If: <http://www.ics.uci.edu/users/f/fielding/index.html>
 (<opaquelocktoken:f81d4fae-7dec-11d0-a765-00a0c91e6bf6>
 NOT <opaquelocktoken:f81d4fae-7dec-11d0-a765-00a0c91e6bf6>)
 <http:// www.ics.uci.edu/users/f/fielding/anotherfile.html>
 (<opaquelocktoken:f81d4fae-7dec-11d0-a765-00a0c91e6bf7>
 NOT <opaquelocktoken:f81d4fae-7dec-11d0-a765-00a0c91e6bf7>)
 <http:// www.ics.uci.edu/users/f/fielding/thirdfile.html>
 (<opaquelocktoken:f81d4fae-7dec-11d0-a765-00a0c91e6bf8>
 NOT <opaquelocktoken:f81d4fae-7dec-11d0-a765-00a0c91e6bf8>)
 This is the If header length problem. Once we fix the If header
 problem (which we have to do anyway), there no longer is a need
 for a new header to get this functionality.
 PROBLEM #3: Uck, this is really complicated. While it's useful to
know
 that a client can do this with some existing servers, provided they
 handle it correctly, surely we can do this in a simpler mechanism
that
 is less prone to interoperability problems. A simple header that
allows
 the client to supply lock tokens to use is semantically equivalent to
 the above example, but shorter, simpler, and easier to implement.
Also
 it can be split across multiple lines.
 Use-Lock-Tokens:
 <opaquelocktoken:f81d4fae-7dec-11d0-a765-00a0c91e6bf6>,
 <opaquelocktoken:f81d4fae-7dec-11d0-a765-00a0c91e6bf7>
 Use-Lock-Tokens:
 <opaquelocktoken:f81d4fae-7dec-11d0-a765-00a0c91e6bf8>
 Computer programs are really good at spitting out the same string
 twice, surrounded by some constant characters. Given the verbosity of
 XML, and the fact that the Internet is used to stream video, cutting
 down the number of characters required to identify lock tokens does
 not strike me as a high priority task. And since any client that
 wants to interoperate with an existing server has to be able to
 generate the If form of the request anyway, this is no simplification
 for an interoperable client that has to be able to generate both forms
 of the request.
 Cheers,
 Geoff
 -----Original Message-----
 From: Julian Reschke [mailto:julian.reschke@gmx.de]
 Some thoughts:
 - it doesn't make sense to raise the header length problem as argument
 in favor of adding a new header. If the If header length is a
 problem, it needs to be fixed anyway -- no matter how the other
 issues are treated
 - As far as I now understand the client issue (BTW: why aren't the
 developers of this or these clients not participating in this
 dicussion??), they want to avoid to re-issue a request that
 specified a lock token just because the lock went away in the
 meantime. I *still* don't see why this is a problem -- if the lock
 was theirs, it's not supposed to go away without reason (such as bad
 timeout value). If the lock *wasn't* theirs, this is a case of "lock
 stealing", which certainly doesn't require to be optimized, right?
 - if a client really really wants the request to succeed either case
 (lock being present or not), can't he simply submit an If header
 production such as:
 If: <http://www.foo.bar/resource1> (<locktoken:a-write-lock-token>)(Not
<locktoken:a-write-lock-token>))
 ?

Received on Tuesday, 8 October 2002 23:53:49 UTC

AltStyle によって変換されたページ (->オリジナル) /