mirror of
https://github.com/1f349/go-webdav.git
synced 2025-01-12 10:26:26 +00:00
carddav: add PUT support to server
This commit is contained in:
parent
bf97060e19
commit
aa750836d4
@ -3,6 +3,7 @@ package carddav
|
|||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"encoding/xml"
|
"encoding/xml"
|
||||||
|
"mime"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
|
||||||
"github.com/emersion/go-vcard"
|
"github.com/emersion/go-vcard"
|
||||||
@ -14,9 +15,10 @@ import (
|
|||||||
// Backend is a CardDAV server backend.
|
// Backend is a CardDAV server backend.
|
||||||
type Backend interface {
|
type Backend interface {
|
||||||
AddressBook() (*AddressBook, error)
|
AddressBook() (*AddressBook, error)
|
||||||
GetAddressObject(href string) (*AddressObject, error)
|
GetAddressObject(path string) (*AddressObject, error)
|
||||||
ListAddressObjects() ([]AddressObject, error)
|
ListAddressObjects() ([]AddressObject, error)
|
||||||
QueryAddressObjects(query *AddressBookQuery) ([]AddressObject, error)
|
QueryAddressObjects(query *AddressBookQuery) ([]AddressObject, error)
|
||||||
|
PutAddressObject(path string, card vcard.Card) error
|
||||||
}
|
}
|
||||||
|
|
||||||
// Handler handles CardDAV HTTP requests. It can be used to create a CardDAV
|
// Handler handles CardDAV HTTP requests. It can be used to create a CardDAV
|
||||||
@ -269,7 +271,26 @@ func (b *backend) Proppatch(r *http.Request, update *internal.Propertyupdate) (*
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (b *backend) Put(r *http.Request) error {
|
func (b *backend) Put(r *http.Request) error {
|
||||||
panic("TODO")
|
// TODO: add support for If-None-Match
|
||||||
|
|
||||||
|
t, _, err := mime.ParseMediaType(r.Header.Get("Content-Type"))
|
||||||
|
if err != nil {
|
||||||
|
return internal.HTTPErrorf(http.StatusBadRequest, "carddav: malformed Content-Type: %v", err)
|
||||||
|
}
|
||||||
|
if t != vcard.MIMEType {
|
||||||
|
// TODO: send CARDDAV:supported-address-data error
|
||||||
|
return internal.HTTPErrorf(http.StatusBadRequest, "carddav: unsupporetd Content-Type %q", t)
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: check CARDDAV:max-resource-size precondition
|
||||||
|
card, err := vcard.NewDecoder(r.Body).Decode()
|
||||||
|
if err != nil {
|
||||||
|
// TODO: send CARDDAV:valid-address-data error
|
||||||
|
return internal.HTTPErrorf(http.StatusBadRequest, "carddav: failed to parse vCard: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: add support for the CARDDAV:no-uid-conflict error
|
||||||
|
return b.Backend.PutAddressObject(r.URL.Path, card)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (b *backend) Delete(r *http.Request) error {
|
func (b *backend) Delete(r *http.Request) error {
|
||||||
|
Loading…
Reference in New Issue
Block a user