mirror of
https://github.com/1f349/go-webdav.git
synced 2025-01-21 23:06:23 +00:00
carddav: return multistatus response on PROPPATCH
This does not implement any actual PROPPATCH logic, but makes the server return a proper multistatus response with errors for each property instead of a generic HTTP error. It also adds the distinction between requests to the address book and those to other resources. In CardDAV, only the address book itself has properties that make sense to change via PROPPATCH. Those are responded to with a 501, indicating that this needs further implementation. Requests to other resources return 405 for each property, indicating that the resources do not support PROPPATCH at all.
This commit is contained in:
parent
b0c59cdea1
commit
cabaf3268b
@ -457,9 +457,43 @@ func (b *backend) propfindAddressObject(ctx context.Context, propfind *internal.
|
||||
}
|
||||
|
||||
func (b *backend) Proppatch(r *http.Request, update *internal.Propertyupdate) (*internal.Response, error) {
|
||||
// TODO: return a failed Response instead
|
||||
// TODO: support PROPPATCH for address books
|
||||
return nil, internal.HTTPErrorf(http.StatusForbidden, "carddav: PROPPATCH is unsupported")
|
||||
homeSetPath, err := b.Backend.AddressbookHomeSetPath(r.Context())
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
resp := internal.NewOKResponse(r.URL.Path)
|
||||
|
||||
if r.URL.Path == homeSetPath {
|
||||
// TODO: support PROPPATCH for address books
|
||||
for _, prop := range update.Remove {
|
||||
emptyVal := internal.NewRawXMLElement(prop.Prop.XMLName, nil, nil)
|
||||
if err := resp.EncodeProp(http.StatusNotImplemented, emptyVal); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
}
|
||||
for _, prop := range update.Set {
|
||||
emptyVal := internal.NewRawXMLElement(prop.Prop.XMLName, nil, nil)
|
||||
if err := resp.EncodeProp(http.StatusNotImplemented, emptyVal); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
}
|
||||
} else {
|
||||
for _, prop := range update.Remove {
|
||||
emptyVal := internal.NewRawXMLElement(prop.Prop.XMLName, nil, nil)
|
||||
if err := resp.EncodeProp(http.StatusMethodNotAllowed, emptyVal); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
}
|
||||
for _, prop := range update.Set {
|
||||
emptyVal := internal.NewRawXMLElement(prop.Prop.XMLName, nil, nil)
|
||||
if err := resp.EncodeProp(http.StatusMethodNotAllowed, emptyVal); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return resp, nil
|
||||
}
|
||||
|
||||
func (b *backend) Put(r *http.Request) (*internal.Href, error) {
|
||||
|
Loading…
Reference in New Issue
Block a user