parent
							
								
									e29bc0f031
								
							
						
					
					
						commit
						7493d8befb
					
				
							
								
								
									
										108
									
								
								cmd/gowebdav/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										108
									
								
								cmd/gowebdav/README.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,108 @@ | |||||||
|  | # Description | ||||||
|  | Command line tool for [gowebdav](https://github.com/studio-b12/gowebdav) library. | ||||||
|  | 
 | ||||||
|  | # Prerequisites | ||||||
|  | ## Software | ||||||
|  | * **OS**: all, which are supported by `Golang` | ||||||
|  | * **Golang**: version 1.x | ||||||
|  | * **Git**: version 2.14.2 at higher (required to install via `go get`) | ||||||
|  | 
 | ||||||
|  | # Install | ||||||
|  | ```sh | ||||||
|  | go get -u github.com/studio-b12/gowebdav/cmd/gowebdav | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | # Usage | ||||||
|  | It is recommended to set following environment variables to improve your experience with this tool: | ||||||
|  | * `ROOT` is an URL of target WebDAV server (e.g. `https://webdav.mydomain.me/user_root_folder`) | ||||||
|  | * `USER` is a login to connect to specified server (e.g. `user`) | ||||||
|  | * `PASSWORD` is a password to connect to specified server (e.g. `p@s$w0rD`) | ||||||
|  | 
 | ||||||
|  | In following examples we suppose that: | ||||||
|  | * environment variable `ROOT` is set to `https://webdav.mydomain.me/ufolder` | ||||||
|  | * environment variable `USER` is set to `user` | ||||||
|  | * environment variable `PASSWORD` is set `p@s$w0rD` | ||||||
|  | * folder `/ufolder/temp` exists on the server | ||||||
|  | * file `/ufolder/temp/file.txt` exists on the server | ||||||
|  | * file `/ufolder/temp/document.rtf` exists on the server | ||||||
|  | * file `/tmp/webdav/to_upload.txt` exists on the local machine | ||||||
|  | * folder `/tmp/webdav/` is used to download files from the server | ||||||
|  | 
 | ||||||
|  | ## Examples | ||||||
|  | 
 | ||||||
|  | #### Get content of specified folder | ||||||
|  | ```sh | ||||||
|  | gowebdav -X LS temp | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | #### Get info about file/folder | ||||||
|  | ```sh | ||||||
|  | gowebdav -X STAT temp | ||||||
|  | gowebdav -X STAT temp/file.txt | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | #### Create folder on the remote server | ||||||
|  | ```sh | ||||||
|  | gowebdav -X MKDIR temp2 | ||||||
|  | gowebdav -X MKDIRALL all/folders/which-you-want/to_create | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | #### Download file | ||||||
|  | ```sh | ||||||
|  | gowebdav -X GET temp/document.rtf /tmp/webdav/document.rtf | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | You may do not specify target local path, in this case file will be downloaded to the current folder with the | ||||||
|  | 
 | ||||||
|  | #### Upload file | ||||||
|  | ```sh | ||||||
|  | gowebdav -X PUT temp/uploaded.txt /tmp/webdav/to_upload.txt | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | #### Move file on the remote server | ||||||
|  | ```sh | ||||||
|  | gowebdav -X MV temp/file.txt temp/moved_file.txt | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | #### Copy file to another location | ||||||
|  | ```sh | ||||||
|  | gowebdav -X MV temp/file.txt temp/file-copy.txt | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | #### Delete file from the remote server | ||||||
|  | ```sh | ||||||
|  | gowebdav -X DEL temp/file.txt | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | # Wrapper script | ||||||
|  | 
 | ||||||
|  | Create a wrapper script for example `$EDITOR ./dav && chmod a+x ./dav` for your | ||||||
|  | server and use [pass](https://www.passwordstore.org/ "the standard unix password manager") | ||||||
|  | or similar tools to retrieve the password. | ||||||
|  | 
 | ||||||
|  | ```sh | ||||||
|  | #!/bin/sh | ||||||
|  | 
 | ||||||
|  | ROOT="https://my.dav.server/" \ | ||||||
|  | USER="foo" \ | ||||||
|  | PASSWORD="$(pass dav/foo@my.dav.server)" \ | ||||||
|  | gowebdav $@ | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | ## Examples | ||||||
|  | 
 | ||||||
|  | Using the `dav` wrapper: | ||||||
|  | 
 | ||||||
|  | ```sh | ||||||
|  | $ ./dav -X LS / | ||||||
|  | 
 | ||||||
|  | $ echo hi dav! > hello && ./dav -X PUT /hello | ||||||
|  | 
 | ||||||
|  | $ ./dav -X STAT /hello | ||||||
|  | 
 | ||||||
|  | $ ./dav -X PUT /hello_dav hello | ||||||
|  | 
 | ||||||
|  | $ ./dav -X GET /hello_dav | ||||||
|  | 
 | ||||||
|  | $ ./dav -X GET /hello_dav hello.txt | ||||||
|  | ``` | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user