wsgidav.samples.virtual_dav_provider.RootCollection.handle_delete

RootCollection.handle_delete()

Handle a DELETE request natively.

This method is called by the DELETE handler after checking for valid request syntax and making sure that there are no conflicting locks and If-headers. Depending on the return value, this provider can control further processing:

False:

handle_delete() did not do anything. WsgiDAV will process the request by calling delete() for every resource, bottom-up.

True:

handle_delete() has successfully performed the DELETE request. HTTP_NO_CONTENT will be reported to the DAV client.

List of errors:

handle_delete() tried to perform the delete request, but failed completely or partially. A list of errors is returned like [ (<ref-url>, <DAVError>), ... ] These errors will be reported to the client.

DAVError raised:

handle_delete() refuses to perform the delete request. The DAVError will be reported to the client.

An implementation may choose to apply other semantics and return True. For example deleting ‘/by_tag/cool/myres’ may simply remove the ‘cool’ tag from ‘my_res’. In this case, the resource might still be available by other URLs, so locks and properties are not removed.

This default implementation returns False, so standard processing takes place.

Implementation of this method is OPTIONAL.