mirror of
https://github.com/1f349/go-webdav.git
synced 2025-01-25 16:56:24 +00:00
webdav: remove File.Stat, add FileSystem.Stat
References: https://github.com/emersion/go-webdav/issues/15
This commit is contained in:
parent
6526cef9eb
commit
e851e6e3f1
@ -31,4 +31,12 @@ func (fs LocalFileSystem) Open(name string) (File, error) {
|
|||||||
return os.Open(p)
|
return os.Open(p)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (fs LocalFileSystem) Stat(name string) (os.FileInfo, error) {
|
||||||
|
p, err := fs.path(name)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return os.Stat(p)
|
||||||
|
}
|
||||||
|
|
||||||
var _ FileSystem = LocalFileSystem("")
|
var _ FileSystem = LocalFileSystem("")
|
||||||
|
46
server.go
46
server.go
@ -2,6 +2,7 @@ package webdav
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/xml"
|
"encoding/xml"
|
||||||
|
"io"
|
||||||
"mime"
|
"mime"
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
"os"
|
||||||
@ -11,11 +12,15 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type File interface {
|
type File interface {
|
||||||
http.File
|
io.Closer
|
||||||
|
io.Reader
|
||||||
|
io.Seeker
|
||||||
|
Readdir(count int) ([]os.FileInfo, error)
|
||||||
}
|
}
|
||||||
|
|
||||||
type FileSystem interface {
|
type FileSystem interface {
|
||||||
Open(name string) (File, error)
|
Open(name string) (File, error)
|
||||||
|
Stat(name string) (os.FileInfo, error)
|
||||||
}
|
}
|
||||||
|
|
||||||
type Handler struct {
|
type Handler struct {
|
||||||
@ -38,18 +43,12 @@ type backend struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (b *backend) Options(r *http.Request) ([]string, error) {
|
func (b *backend) Options(r *http.Request) ([]string, error) {
|
||||||
f, err := b.FileSystem.Open(r.URL.Path)
|
fi, err := b.FileSystem.Stat(r.URL.Path)
|
||||||
if os.IsNotExist(err) {
|
if os.IsNotExist(err) {
|
||||||
return []string{http.MethodOptions}, nil
|
return []string{http.MethodOptions}, nil
|
||||||
} else if err != nil {
|
} else if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
defer f.Close()
|
|
||||||
|
|
||||||
fi, err := f.Stat()
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
if fi.IsDir() {
|
if fi.IsDir() {
|
||||||
return []string{http.MethodOptions, "PROPFIND"}, nil
|
return []string{http.MethodOptions, "PROPFIND"}, nil
|
||||||
@ -59,34 +58,31 @@ func (b *backend) Options(r *http.Request) ([]string, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (b *backend) HeadGet(w http.ResponseWriter, r *http.Request) error {
|
func (b *backend) HeadGet(w http.ResponseWriter, r *http.Request) error {
|
||||||
|
fi, err := b.FileSystem.Stat(r.URL.Path)
|
||||||
|
if os.IsNotExist(err) {
|
||||||
|
return &internal.HTTPError{Code: http.StatusNotFound, Err: err}
|
||||||
|
} else if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if fi.IsDir() {
|
||||||
|
return &internal.HTTPError{Code: http.StatusMethodNotAllowed}
|
||||||
|
}
|
||||||
|
|
||||||
f, err := b.FileSystem.Open(r.URL.Path)
|
f, err := b.FileSystem.Open(r.URL.Path)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
defer f.Close()
|
defer f.Close()
|
||||||
|
|
||||||
fi, err := f.Stat()
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
if fi.IsDir() {
|
|
||||||
return &internal.HTTPError{Code: http.StatusMethodNotAllowed}
|
|
||||||
}
|
|
||||||
|
|
||||||
http.ServeContent(w, r, r.URL.Path, fi.ModTime(), f)
|
http.ServeContent(w, r, r.URL.Path, fi.ModTime(), f)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (b *backend) Propfind(r *http.Request, propfind *internal.Propfind, depth internal.Depth) (*internal.Multistatus, error) {
|
func (b *backend) Propfind(r *http.Request, propfind *internal.Propfind, depth internal.Depth) (*internal.Multistatus, error) {
|
||||||
f, err := b.FileSystem.Open(r.URL.Path)
|
fi, err := b.FileSystem.Stat(r.URL.Path)
|
||||||
if err != nil {
|
if os.IsNotExist(err) {
|
||||||
return nil, err
|
return nil, &internal.HTTPError{Code: http.StatusNotFound, Err: err}
|
||||||
}
|
} else if err != nil {
|
||||||
defer f.Close()
|
|
||||||
|
|
||||||
fi, err := f.Stat()
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user