mirror of
https://gitlab.bertha.cloud/partitio/Nextcloud-Partitio/gonextcloud
synced 2024-11-15 10:56:25 +00:00
148 lines
4.3 KiB
Markdown
148 lines
4.3 KiB
Markdown
|
# GoWebDAV
|
||
|
|
||
|
[![Build Status](https://travis-ci.org/studio-b12/gowebdav.svg?branch=master)](https://travis-ci.org/studio-b12/gowebdav)
|
||
|
[![GoDoc](https://godoc.org/github.com/studio-b12/gowebdav?status.svg)](https://godoc.org/github.com/studio-b12/gowebdav)
|
||
|
[![Go Report Card](https://goreportcard.com/badge/github.com/studio-b12/gowebdav)](https://goreportcard.com/report/github.com/studio-b12/gowebdav)
|
||
|
|
||
|
A golang WebDAV client library.
|
||
|
|
||
|
## Main features
|
||
|
`gowebdav` library allows to perform following actions on the remote WebDAV server:
|
||
|
* [create path](#create-path-on-a-webdav-server)
|
||
|
* [get files list](#get-files-list)
|
||
|
* [download file](#download-file-to-byte-array)
|
||
|
* [upload file](#upload-file-from-byte-array)
|
||
|
* [get information about specified file/folder](#get-information-about-specified-filefolder)
|
||
|
* [move file to another location](#move-file-to-another-location)
|
||
|
* [copy file to another location](#copy-file-to-another-location)
|
||
|
* [delete file](#delete-file)
|
||
|
|
||
|
## Usage
|
||
|
|
||
|
First of all you should create `Client` instance using `NewClient()` function:
|
||
|
|
||
|
```go
|
||
|
root := "https://webdav.mydomain.me"
|
||
|
user := "user"
|
||
|
password := "password"
|
||
|
|
||
|
c := gowebdav.NewClient(root, user, password)
|
||
|
```
|
||
|
|
||
|
After you can use this `Client` to perform actions, described below.
|
||
|
|
||
|
**NOTICE:** we will not check errors in examples, to focus you on the `gowebdav` library's code, but you should do it in your code!
|
||
|
|
||
|
### Create path on a WebDAV server
|
||
|
```go
|
||
|
err := c.Mkdir("folder", 0644)
|
||
|
```
|
||
|
In case you want to create several folders you can use `c.MkdirAll()`:
|
||
|
```go
|
||
|
err := c.MkdirAll("folder/subfolder/subfolder2", 0644)
|
||
|
```
|
||
|
|
||
|
### Get files list
|
||
|
```go
|
||
|
files, _ := c.ReadDir("folder/subfolder")
|
||
|
for _, file := range files {
|
||
|
//notice that [file] has os.FileInfo type
|
||
|
fmt.Println(file.Name())
|
||
|
}
|
||
|
```
|
||
|
|
||
|
### Download file to byte array
|
||
|
```go
|
||
|
webdavFilePath := "folder/subfolder/file.txt"
|
||
|
localFilePath := "/tmp/webdav/file.txt"
|
||
|
|
||
|
bytes, _ := c.Read(webdavFilePath)
|
||
|
ioutil.WriteFile(localFilePath, bytes, 0644)
|
||
|
```
|
||
|
|
||
|
### Download file via reader
|
||
|
Also you can use `c.ReadStream()` method:
|
||
|
```go
|
||
|
webdavFilePath := "folder/subfolder/file.txt"
|
||
|
localFilePath := "/tmp/webdav/file.txt"
|
||
|
|
||
|
reader, _ := c.ReadStream(webdavFilePath)
|
||
|
|
||
|
file, _ := os.Create(localFilePath)
|
||
|
defer file.Close()
|
||
|
|
||
|
io.Copy(file, reader)
|
||
|
```
|
||
|
|
||
|
### Upload file from byte array
|
||
|
```go
|
||
|
webdavFilePath := "folder/subfolder/file.txt"
|
||
|
localFilePath := "/tmp/webdav/file.txt"
|
||
|
|
||
|
bytes, _ := ioutil.ReadFile(localFilePath)
|
||
|
|
||
|
c.Write(webdavFilePath, bytes, 0644)
|
||
|
```
|
||
|
|
||
|
### Upload file via writer
|
||
|
```go
|
||
|
webdavFilePath := "folder/subfolder/file.txt"
|
||
|
localFilePath := "/tmp/webdav/file.txt"
|
||
|
|
||
|
file, _ := os.Open(localFilePath)
|
||
|
defer file.Close()
|
||
|
|
||
|
c.WriteStream(webdavFilePath, file, 0644)
|
||
|
```
|
||
|
|
||
|
### Get information about specified file/folder
|
||
|
```go
|
||
|
webdavFilePath := "folder/subfolder/file.txt"
|
||
|
|
||
|
info := c.Stat(webdavFilePath)
|
||
|
//notice that [info] has os.FileInfo type
|
||
|
fmt.Println(info)
|
||
|
```
|
||
|
|
||
|
### Move file to another location
|
||
|
```go
|
||
|
oldPath := "folder/subfolder/file.txt"
|
||
|
newPath := "folder/subfolder/moved.txt"
|
||
|
isOverwrite := true
|
||
|
|
||
|
c.Rename(oldPath, newPath, isOverwrite)
|
||
|
```
|
||
|
|
||
|
### Copy file to another location
|
||
|
```go
|
||
|
oldPath := "folder/subfolder/file.txt"
|
||
|
newPath := "folder/subfolder/file-copy.txt"
|
||
|
isOverwrite := true
|
||
|
|
||
|
c.Copy(oldPath, newPath, isOverwrite)
|
||
|
```
|
||
|
|
||
|
### Delete file
|
||
|
```go
|
||
|
webdavFilePath := "folder/subfolder/file.txt"
|
||
|
|
||
|
c.Remove(webdavFilePath)
|
||
|
```
|
||
|
|
||
|
## Links
|
||
|
|
||
|
More details about WebDAV server you can read from following resources:
|
||
|
|
||
|
* [RFC 4918 - HTTP Extensions for Web Distributed Authoring and Versioning (WebDAV)](https://tools.ietf.org/html/rfc4918)
|
||
|
* [RFC 5689 - Extended MKCOL for Web Distributed Authoring and Versioning (WebDAV)](https://tools.ietf.org/html/rfc5689)
|
||
|
* [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")
|
||
|
|
||
|
**NOTICE**: RFC 2518 is obsoleted by RFC 4918 in June 2007
|
||
|
|
||
|
## Contributing
|
||
|
All contributing are welcome. If you have any suggestions or find some bug - please create an Issue to let us make this project better. We appreciate your help!
|
||
|
|
||
|
## License
|
||
|
This library is distributed under the BSD 3-Clause license found in the [LICENSE](https://github.com/studio-b12/gowebdav/blob/master/LICENSE) file.
|