mirror of
https://github.com/1f349/go-webdav.git
synced 2024-12-22 08:14:15 +00:00
wip: switch to io/fs
References: https://github.com/emersion/go-webdav/issues/40
This commit is contained in:
parent
3f8b212b0d
commit
4d71a37916
19
client.go
19
client.go
@ -3,6 +3,7 @@ package webdav
|
|||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
|
"io/fs"
|
||||||
"net/http"
|
"net/http"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
@ -74,13 +75,13 @@ var fileInfoPropfind = internal.NewPropNamePropfind(
|
|||||||
internal.GetETagName,
|
internal.GetETagName,
|
||||||
)
|
)
|
||||||
|
|
||||||
func fileInfoFromResponse(resp *internal.Response) (*FileInfo, error) {
|
func fileInfoFromResponse(resp *internal.Response) (*fileInfo, error) {
|
||||||
path, err := resp.Path()
|
path, err := resp.Path()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
fi := &FileInfo{Path: path}
|
fi := FileInfo{Path: path}
|
||||||
|
|
||||||
var resType internal.ResourceType
|
var resType internal.ResourceType
|
||||||
if err := resp.DecodeProp(&resType); err != nil {
|
if err := resp.DecodeProp(&resType); err != nil {
|
||||||
@ -116,10 +117,10 @@ func fileInfoFromResponse(resp *internal.Response) (*FileInfo, error) {
|
|||||||
}
|
}
|
||||||
fi.ModTime = time.Time(getMod.LastModified)
|
fi.ModTime = time.Time(getMod.LastModified)
|
||||||
|
|
||||||
return fi, nil
|
return &fileInfo{fi}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Client) Stat(name string) (*FileInfo, error) {
|
func (c *Client) Stat(name string) (fs.FileInfo, error) {
|
||||||
resp, err := c.ic.PropfindFlat(name, fileInfoPropfind)
|
resp, err := c.ic.PropfindFlat(name, fileInfoPropfind)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -141,24 +142,24 @@ func (c *Client) Open(name string) (io.ReadCloser, error) {
|
|||||||
return resp.Body, nil
|
return resp.Body, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Client) Readdir(name string, recursive bool) ([]FileInfo, error) {
|
func (c *Client) ReadDir(name string) ([]fs.DirEntry, error) {
|
||||||
depth := internal.DepthOne
|
depth := internal.DepthOne
|
||||||
if recursive {
|
/*if recursive {
|
||||||
depth = internal.DepthInfinity
|
depth = internal.DepthInfinity
|
||||||
}
|
}*/
|
||||||
|
|
||||||
ms, err := c.ic.Propfind(name, depth, fileInfoPropfind)
|
ms, err := c.ic.Propfind(name, depth, fileInfoPropfind)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
l := make([]FileInfo, 0, len(ms.Responses))
|
l := make([]fs.DirEntry, 0, len(ms.Responses))
|
||||||
for _, resp := range ms.Responses {
|
for _, resp := range ms.Responses {
|
||||||
fi, err := fileInfoFromResponse(&resp)
|
fi, err := fileInfoFromResponse(&resp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return l, err
|
return l, err
|
||||||
}
|
}
|
||||||
l = append(l, *fi)
|
l = append(l, fi)
|
||||||
}
|
}
|
||||||
|
|
||||||
return l, nil
|
return l, nil
|
||||||
|
47
webdav.go
47
webdav.go
@ -4,6 +4,8 @@
|
|||||||
package webdav
|
package webdav
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"io/fs"
|
||||||
|
"path"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -15,3 +17,48 @@ type FileInfo struct {
|
|||||||
MIMEType string
|
MIMEType string
|
||||||
ETag string
|
ETag string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type fileInfo struct {
|
||||||
|
FileInfo
|
||||||
|
}
|
||||||
|
|
||||||
|
var (
|
||||||
|
_ fs.FileInfo = (*fileInfo)(nil)
|
||||||
|
_ fs.DirEntry = (*fileInfo)(nil)
|
||||||
|
)
|
||||||
|
|
||||||
|
func (fi *fileInfo) Name() string {
|
||||||
|
return path.Base(fi.Path)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (fi *fileInfo) Size() int64 {
|
||||||
|
return fi.FileInfo.Size
|
||||||
|
}
|
||||||
|
|
||||||
|
func (fi *fileInfo) Mode() fs.FileMode {
|
||||||
|
var mode fs.FileMode
|
||||||
|
if fi.FileInfo.IsDir {
|
||||||
|
mode |= fs.ModeDir
|
||||||
|
}
|
||||||
|
return mode
|
||||||
|
}
|
||||||
|
|
||||||
|
func (fi *fileInfo) ModTime() time.Time {
|
||||||
|
return fi.FileInfo.ModTime
|
||||||
|
}
|
||||||
|
|
||||||
|
func (fi *fileInfo) IsDir() bool {
|
||||||
|
return fi.FileInfo.IsDir
|
||||||
|
}
|
||||||
|
|
||||||
|
func (fi *fileInfo) Sys() interface{} {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (fi *fileInfo) Type() fs.FileMode {
|
||||||
|
return fi.Mode()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (fi *fileInfo) Info() (fs.FileInfo, error) {
|
||||||
|
return fi, nil
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user