implement MkDir aka MKCOL

This commit is contained in:
Christoph Polcin
2014-10-23 15:00:20 +02:00
parent 7caa8c8b7d
commit c1fc968bc9
3 changed files with 44 additions and 3 deletions

View File

@@ -14,6 +14,10 @@ func Fail(err interface{}) {
fmt.Println("Usage: client FLAGS ARGS")
fmt.Println("Flags:")
flag.PrintDefaults()
fmt.Println("Method:")
fmt.Println(" LIST, PROPFIND:")
fmt.Println(" RM, DELETE, DEL:")
fmt.Println(" MKDIR, MKCOL:")
}
os.Exit(-1)
}
@@ -22,7 +26,7 @@ func main() {
root := flag.String("root", "URL", "WebDAV Endpoint")
usr := flag.String("user", "", "user")
pw := flag.String("pw", "", "password")
m := flag.String("X", "GET", "Method: LIST aka PROPFIND, GET, DELETE")
m := flag.String("X", "GET", "Method ...")
flag.Parse()
if *root == "URL" {
@@ -39,7 +43,7 @@ func main() {
switch *m {
case "LIST", "PROPFIND":
if files, err := c.ReadDir(path); err == nil {
fmt.Println(fmt.Sprintf("Resources: %d - %s", len(files), path))
fmt.Println(fmt.Sprintf("ReadDir: %s, entries: ", path, len(files)))
for _, f := range files {
fmt.Println(f)
}
@@ -49,9 +53,18 @@ func main() {
case "GET": c.Read(path)
case "DELETE", "RM":
case "DELETE", "RM", "DEL":
if err := c.Remove(path); err != nil {
fmt.Println(err)
} else {
fmt.Println("Remove: " + path)
}
case "MKCOL", "MKDIR":
if err := c.Mkdir(path); err != nil {
fmt.Println(err)
} else {
fmt.Println("MkDir: " + path)
}
default: Fail(nil)