three clarification questions on the If header.

For the following questions, assume a collection C contains resource R, and
suppose C is locked at Depth 0.  Assume that resource S does not exist.

1. Is it true that the lock on C has no effect on doing a PUT to R?  (The
protocol in 7.10.2 is clear that it affects ability to add or remove
members, but says nothing about changing existing ones.)

2. In 8.4.1, which says "If a method, due to the presence of a Depth or
Destination header, is applied to multiple resources then the No-tag-list
production MUST be applied to each resource the method is applied to", what
is the significance of "due to the presence of a Depth or Destination header"?

Can a method be applied to multiple resources in any other way?  It seems
to me that it can.  Consider a PUT to S (which does not yet exist).
Certainly the PUT applies to S.  Does it also "apply" to C?  It seems to me
that it does, or else why would the client have to pass the state token for
the lock on C?

Will someone please clarify 8.4.1?

3.  In the case where the client has a lock on C, but no lock on R, and
does not have the etag for R, is it possible for a client to use an
_untagged_ production in the If header to pass the lock token on the C?

If so, I don't see how to implement it.  The production matches the state
of C, but it will not match the state of R, so it will fail, and hence the
PUT will fail.

If this is right, it seems to me that the protocol document should say that
a client SHOULD use tagged productions when the set of affected resources
is known in advance and is small (as in this case) and it should explain
the potential problem with using the no tagged production.  Otherwise,
clients will fail and programmers will be puzzled.

If this is wrong, then a clarification in 8.4 is in order.

Received on Friday, 11 September 1998 18:00:22 UTC