2018-05-16 13:52:24 +02:00
# GoWebDAV
2018-05-17 00:05:28 +02:00
[![Build Status ](https://travis-ci.org/studio-b12/gowebdav.svg?branch=master )](https://travis-ci.org/studio-b12/gowebdav)
2018-05-16 13:52:24 +02:00
[![Go Report Card ](https://goreportcard.com/badge/github.com/studio-b12/gowebdav )](https://goreportcard.com/report/github.com/studio-b12/gowebdav)
A WebDAV client and library for golang.
## Install
```sh
go get -u github.com/studio-b12/gowebdav/cmd/gowebdav
```
## Usage
```sh
2018-05-25 11:03:42 +02:00
$ gowebdav --help
Usage of gowebdav
2018-05-16 13:52:24 +02:00
-X string
2018-05-25 11:03:42 +02:00
Method:
LS < PATH >
STAT < PATH >
MKDIR < PATH >
MKDIRALL < PATH >
GET < PATH > < FILE >
PUT < PATH > < FILE >
MV < OLD > < NEW >
CP < OLD > < NEW >
DEL < PATH >
2018-05-16 13:52:24 +02:00
-pw string
2018-05-24 01:13:26 +02:00
Password [ENV.PASSWORD]
2018-05-16 13:52:24 +02:00
-root string
2018-05-24 01:13:26 +02:00
WebDAV Endpoint [ENV.ROOT]
2018-05-16 13:52:24 +02:00
-user string
2018-05-24 01:13:26 +02:00
User [ENV.USER]
```
*Example*
```sh
ROOT="https://webdav.server/" \
USER="foo" \
PASSWORD="bar" \
./gowebdav -X LS /
2018-05-16 13:52:24 +02:00
```
2014-10-23 10:35:52 +02:00
2014-10-28 07:53:14 +01:00
## LINKS
2018-05-16 13:52:24 +02:00
* [RFC 2518 - HTTP Extensions for Distributed Authoring -- WEBDAV ](http://www.faqs.org/rfcs/rfc2518.html "RFC 2518 - HTTP Extensions for Distributed Authoring -- WEBDAV" )
* [RFC 2616 - HTTP/1.1 Status Code Definitions ](http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html "HTTP/1.1 Status Code Definitions" )
* [WebDav: Next Generation Collaborative Web Authoring By Lisa Dusseaul ](https://books.google.de/books?isbn=0130652083 "WebDav: Next Generation Collaborative Web Authoring By Lisa Dusseault" )
## API
`import "github.com/studio-b12/gowebdav"`
* [Overview ](#pkg-overview )
* [Index ](#pkg-index )
2018-05-23 13:41:06 +02:00
* [Examples ](#pkg-examples )
2018-05-16 13:52:24 +02:00
* [Subdirectories ](#pkg-subdirectories )
### <a name="pkg-overview">Overview</a>
2018-05-16 14:35:38 +02:00
Package gowebdav A golang WebDAV library
2018-05-16 13:52:24 +02:00
### <a name="pkg-index">Index</a>
* [func FixSlash(s string) string ](#FixSlash )
* [func FixSlashes(s string) string ](#FixSlashes )
* [func Join(path0 string, path1 string) string ](#Join )
2018-05-23 13:41:06 +02:00
* [func PathEscape(path string) string ](#PathEscape )
2018-05-16 13:52:24 +02:00
* [func String(r io.Reader) string ](#String )
* [type Client ](#Client )
2018-05-24 01:14:19 +02:00
* [func NewClient(uri, user, pw string) *Client ](#NewClient )
2018-05-16 13:52:24 +02:00
* [func (c *Client) Connect() error ](#Client.Connect )
2018-05-23 14:15:46 +02:00
* [func (c *Client) Copy(oldpath, newpath string, overwrite bool) error ](#Client.Copy )
2018-05-16 13:52:24 +02:00
* [func (c *Client) Mkdir(path string, _ os.FileMode) error ](#Client.Mkdir )
* [func (c *Client) MkdirAll(path string, _ os.FileMode) error ](#Client.MkdirAll )
* [func (c *Client) Read(path string) ([]byte, error)](#Client.Read)
* [func (c *Client) ReadDir(path string) ([]os.FileInfo, error)](#Client.ReadDir)
* [func (c *Client) ReadStream(path string) (io.ReadCloser, error) ](#Client.ReadStream )
* [func (c *Client) Remove(path string) error ](#Client.Remove )
* [func (c *Client) RemoveAll(path string) error ](#Client.RemoveAll )
2018-05-23 14:15:46 +02:00
* [func (c *Client) Rename(oldpath, newpath string, overwrite bool) error ](#Client.Rename )
2018-05-16 13:52:24 +02:00
* [func (c *Client) SetHeader(key, value string) ](#Client.SetHeader )
* [func (c *Client) SetTimeout(timeout time.Duration) ](#Client.SetTimeout )
* [func (c *Client) SetTransport(transport http.RoundTripper) ](#Client.SetTransport )
* [func (c *Client) Stat(path string) (os.FileInfo, error) ](#Client.Stat )
* [func (c *Client) Write(path string, data []byte, _ os.FileMode) error](#Client.Write)
* [func (c *Client) WriteStream(path string, stream io.Reader, _ os.FileMode) error ](#Client.WriteStream )
* [type File ](#File )
2017-11-26 17:23:14 +01:00
* [func (f File) ContentType() string ](#File.ContentType )
* [func (f File) ETag() string ](#File.ETag )
2018-05-16 13:52:24 +02:00
* [func (f File) IsDir() bool ](#File.IsDir )
* [func (f File) ModTime() time.Time ](#File.ModTime )
* [func (f File) Mode() os.FileMode ](#File.Mode )
* [func (f File) Name() string ](#File.Name )
* [func (f File) Size() int64 ](#File.Size )
* [func (f File) String() string ](#File.String )
2018-05-16 14:35:38 +02:00
* [func (f File) Sys() interface{} ](#File.Sys )
2018-05-16 13:52:24 +02:00
2018-05-23 13:41:06 +02:00
##### <a name="pkg-examples">Examples</a>
* [PathEscape ](#example_PathEscape )
2018-05-16 13:52:24 +02:00
##### <a name="pkg-files">Package files</a>
[client.go ](https://github.com/studio-b12/gowebdav/blob/master/client.go ) [file.go ](https://github.com/studio-b12/gowebdav/blob/master/file.go ) [requests.go ](https://github.com/studio-b12/gowebdav/blob/master/requests.go ) [utils.go ](https://github.com/studio-b12/gowebdav/blob/master/utils.go )
2018-05-23 13:41:06 +02:00
### <a name="FixSlash">func</a> [FixSlash](https://github.com/studio-b12/gowebdav/blob/master/utils.go?s=707:737#L45)
2018-05-16 13:52:24 +02:00
``` go
func FixSlash(s string) string
```
FixSlash appends a trailing / to our string
2018-05-23 13:41:06 +02:00
### <a name="FixSlashes">func</a> [FixSlashes](https://github.com/studio-b12/gowebdav/blob/master/utils.go?s=859:891#L53)
2018-05-16 13:52:24 +02:00
``` go
func FixSlashes(s string) string
```
FixSlashes appends and prepends a / if they are missing
2018-05-23 13:41:06 +02:00
### <a name="Join">func</a> [Join](https://github.com/studio-b12/gowebdav/blob/master/utils.go?s=976:1020#L61)
2018-05-16 13:52:24 +02:00
``` go
func Join(path0 string, path1 string) string
```
Join joins two paths
2018-05-23 13:41:06 +02:00
### <a name="PathEscape">func</a> [PathEscape](https://github.com/studio-b12/gowebdav/blob/master/utils.go?s=506:541#L36)
``` go
func PathEscape(path string) string
```
PathEscape escapes all segemnts of a given path
### <a name="String">func</a> [String](https://github.com/studio-b12/gowebdav/blob/master/utils.go?s=1150:1181#L66)
2018-05-16 13:52:24 +02:00
``` go
func String(r io.Reader) string
```
String pulls a string out of our io.Reader
2018-05-16 14:35:38 +02:00
### <a name="Client">type</a> [Client](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=220:301#L18)
2018-05-16 13:52:24 +02:00
``` go
type Client struct {
// contains filtered or unexported fields
}
```
Client defines our structure
2018-05-24 01:14:19 +02:00
#### <a name="NewClient">func</a> [NewClient](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=349:393#L25)
2018-05-16 13:52:24 +02:00
``` go
2018-05-24 01:14:19 +02:00
func NewClient(uri, user, pw string) *Client
2018-05-16 13:52:24 +02:00
```
NewClient creates a new instance of client
2018-05-24 01:14:19 +02:00
#### <a name="Client.Connect">func</a> (\*Client) [Connect](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=1138:1170#L55)
2018-05-16 13:52:24 +02:00
``` go
func (c *Client) Connect() error
```
Connect connects to our dav server
2018-05-24 01:14:19 +02:00
#### <a name="Client.Copy">func</a> (\*Client) [Copy](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=6060:6128#L281)
2018-05-16 13:52:24 +02:00
``` go
2018-05-23 14:15:46 +02:00
func (c *Client) Copy(oldpath, newpath string, overwrite bool) error
2018-05-16 13:52:24 +02:00
```
Copy copies a file from A to B
2018-05-24 01:14:19 +02:00
#### <a name="Client.Mkdir">func</a> (\*Client) [Mkdir](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=5151:5207#L240)
2018-05-16 13:52:24 +02:00
``` go
func (c *Client) Mkdir(path string, _ os.FileMode) error
```
Mkdir makes a directory
2018-05-24 01:14:19 +02:00
#### <a name="Client.MkdirAll">func</a> (\*Client) [MkdirAll](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=5386:5445#L251)
2018-05-16 13:52:24 +02:00
``` go
func (c *Client) MkdirAll(path string, _ os.FileMode) error
```
MkdirAll like mkdir -p, but for webdav
2018-05-24 01:14:19 +02:00
#### <a name="Client.Read">func</a> (\*Client) [Read](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=6234:6284#L286)
2018-05-16 13:52:24 +02:00
``` go
func (c *Client) Read(path string) ([]byte, error)
```
Read reads the contents of a remote file
2018-05-24 01:14:19 +02:00
#### <a name="Client.ReadDir">func</a> (\*Client) [ReadDir](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=2226:2286#L98)
2018-05-16 13:52:24 +02:00
``` go
func (c *Client) ReadDir(path string) ([]os.FileInfo, error)
```
ReadDir reads the contents of a remote directory
2018-05-24 01:14:19 +02:00
#### <a name="Client.ReadStream">func</a> (\*Client) [ReadStream](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=6595:6658#L304)
2018-05-16 13:52:24 +02:00
``` go
func (c *Client) ReadStream(path string) (io.ReadCloser, error)
```
ReadStream reads the stream for a given path
2018-05-24 01:14:19 +02:00
#### <a name="Client.Remove">func</a> (\*Client) [Remove](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=4657:4699#L217)
2018-05-16 13:52:24 +02:00
``` go
func (c *Client) Remove(path string) error
```
Remove removes a remote file
2018-05-24 01:14:19 +02:00
#### <a name="Client.RemoveAll">func</a> (\*Client) [RemoveAll](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=4765:4810#L222)
2018-05-16 13:52:24 +02:00
``` go
func (c *Client) RemoveAll(path string) error
```
RemoveAll removes remote files
2018-05-24 01:14:19 +02:00
#### <a name="Client.Rename">func</a> (\*Client) [Rename](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=5894:5964#L276)
2018-05-16 13:52:24 +02:00
``` go
2018-05-23 14:15:46 +02:00
func (c *Client) Rename(oldpath, newpath string, overwrite bool) error
2018-05-16 13:52:24 +02:00
```
Rename moves a file from A to B
2018-05-24 01:14:19 +02:00
#### <a name="Client.SetHeader">func</a> (\*Client) [SetHeader](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=721:766#L40)
2018-05-16 13:52:24 +02:00
``` go
func (c *Client) SetHeader(key, value string)
```
SetHeader lets us set arbitrary headers for a given client
2018-05-24 01:14:19 +02:00
#### <a name="Client.SetTimeout">func</a> (\*Client) [SetTimeout](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=866:916#L45)
2018-05-16 13:52:24 +02:00
``` go
func (c *Client) SetTimeout(timeout time.Duration)
```
SetTimeout exposes the ability to set a time limit for requests
2018-05-24 01:14:19 +02:00
#### <a name="Client.SetTransport">func</a> (\*Client) [SetTransport](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=1009:1067#L50)
2018-05-16 13:52:24 +02:00
``` go
func (c *Client) SetTransport(transport http.RoundTripper)
```
SetTransport exposes the ability to define custom transports
2018-05-24 01:14:19 +02:00
#### <a name="Client.Stat">func</a> (\*Client) [Stat](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=3613:3668#L165)
2018-05-16 13:52:24 +02:00
``` go
func (c *Client) Stat(path string) (os.FileInfo, error)
```
Stat returns the file stats for a specified path
2018-05-24 01:14:19 +02:00
#### <a name="Client.Write">func</a> (\*Client) [Write](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=6949:7018#L319)
2018-05-16 13:52:24 +02:00
``` go
func (c *Client) Write(path string, data []byte, _ os.FileMode) error
```
Write writes data to a given path
2018-05-24 01:14:19 +02:00
#### <a name="Client.WriteStream">func</a> (\*Client) [WriteStream](https://github.com/studio-b12/gowebdav/blob/master/client.go?s=7420:7500#L341)
2018-05-16 13:52:24 +02:00
``` go
func (c *Client) WriteStream(path string, stream io.Reader, _ os.FileMode) error
```
WriteStream writes a stream
2017-11-26 17:23:14 +01:00
### <a name="File">type</a> [File](https://github.com/studio-b12/gowebdav/blob/master/file.go?s=93:253#L10)
2018-05-16 13:52:24 +02:00
``` go
type File struct {
// contains filtered or unexported fields
}
```
File is our structure for a given file
2017-11-26 17:23:14 +01:00
#### <a name="File.ContentType">func</a> (File) [ContentType](https://github.com/studio-b12/gowebdav/blob/master/file.go?s=388:422#L26)
``` go
func (f File) ContentType() string
```
ContentType returns the content type of a file
#### <a name="File.ETag">func</a> (File) [ETag](https://github.com/studio-b12/gowebdav/blob/master/file.go?s=841:868#L51)
``` go
func (f File) ETag() string
```
ETag returns the ETag of a file
#### <a name="File.IsDir">func</a> (File) [IsDir](https://github.com/studio-b12/gowebdav/blob/master/file.go?s=947:973#L56)
2018-05-16 13:52:24 +02:00
``` go
func (f File) IsDir() bool
```
IsDir let us see if a given file is a directory or not
2017-11-26 17:23:14 +01:00
#### <a name="File.ModTime">func</a> (File) [ModTime](https://github.com/studio-b12/gowebdav/blob/master/file.go?s=748:781#L46)
2018-05-16 13:52:24 +02:00
``` go
func (f File) ModTime() time.Time
```
ModTime returns the modified time of a file
2017-11-26 17:23:14 +01:00
#### <a name="File.Mode">func</a> (File) [Mode](https://github.com/studio-b12/gowebdav/blob/master/file.go?s=577:609#L36)
2018-05-16 13:52:24 +02:00
``` go
func (f File) Mode() os.FileMode
```
Mode will return the mode of a given file
2017-11-26 17:23:14 +01:00
#### <a name="File.Name">func</a> (File) [Name](https://github.com/studio-b12/gowebdav/blob/master/file.go?s=290:317#L21)
2018-05-16 13:52:24 +02:00
``` go
func (f File) Name() string
```
Name returns the name of a file
2017-11-26 17:23:14 +01:00
#### <a name="File.Size">func</a> (File) [Size](https://github.com/studio-b12/gowebdav/blob/master/file.go?s=485:511#L31)
2018-05-16 13:52:24 +02:00
``` go
func (f File) Size() int64
```
Size returns the size of a file
2014-10-28 07:53:14 +01:00
2017-11-26 17:23:14 +01:00
#### <a name="File.String">func</a> (File) [String](https://github.com/studio-b12/gowebdav/blob/master/file.go?s=1095:1124#L66)
2018-05-16 13:52:24 +02:00
``` go
func (f File) String() string
```
String lets us see file information
2014-10-28 07:53:14 +01:00
2017-11-26 17:23:14 +01:00
#### <a name="File.Sys">func</a> (File) [Sys](https://github.com/studio-b12/gowebdav/blob/master/file.go?s=1007:1038#L61)
2018-05-16 14:35:38 +02:00
``` go
func (f File) Sys() interface{}
```
Sys ????
2018-05-16 13:52:24 +02:00
- - -
Generated by [godoc2md ](http://godoc.org/github.com/davecheney/godoc2md )