From 4471eba47a87711d4708d4a77839f2d4e82f4fc1 Mon Sep 17 00:00:00 2001 From: Eliot Whalan Date: Fri, 24 Jun 2016 12:59:29 +1000 Subject: [PATCH] Add clone paste handler --- assets/clone.html | 478 +++++++++++++++++++++++++++++++++++++++++++++ assets/paste.html | 1 + assets/syntax.html | 1 + main.go | 26 ++- 4 files changed, 504 insertions(+), 2 deletions(-) create mode 100644 assets/clone.html diff --git a/assets/clone.html b/assets/clone.html new file mode 100644 index 0000000..598776a --- /dev/null +++ b/assets/clone.html @@ -0,0 +1,478 @@ + + + + + + + + {{.Title}} + + + + + + + + + + + + + + + + +
+ +
+
+
+
+ + Paste your text here +
+
+
+
+
+ + + + Home + Download + Raw + Clone + +
+
+
+
+
+
+ $ <command> | curl -F 'p=<-' https://p.pantsu.cat/save
+ https://p.pantsu.cat/save/(XML|JSON|HTML)
+ https://p.pantsu.cat/p/(PASTE)/(lang)
+ https://p.pantsu.cat/del/(PASTE)/(DELKEY)
+

Source: Github

+
+
+ + + + + + + + + + diff --git a/assets/paste.html b/assets/paste.html index c8fb3c4..725960d 100644 --- a/assets/paste.html +++ b/assets/paste.html @@ -39,6 +39,7 @@ Home Download Raw + Clone diff --git a/assets/syntax.html b/assets/syntax.html index 59005c2..54fc90e 100644 --- a/assets/syntax.html +++ b/assets/syntax.html @@ -39,6 +39,7 @@ Home Download Raw + Clone diff --git a/main.go b/main.go index 2ed7d5c..9300c5c 100644 --- a/main.go +++ b/main.go @@ -44,6 +44,7 @@ type Page struct { Raw string Home string Download string + Clone string } func check(err error) { @@ -227,7 +228,7 @@ func getPaste(paste string, lang string) string { } -var templates = template.Must(template.ParseFiles("assets/paste.html", "assets/index.html")) +var templates = template.Must(template.ParseFiles("assets/paste.html", "assets/index.html", "assets/clone.html")) var syntax, _ = ioutil.ReadFile("assets/syntax.html") func pasteHandler(w http.ResponseWriter, r *http.Request) { @@ -237,6 +238,7 @@ func pasteHandler(w http.ResponseWriter, r *http.Request) { s := getPaste(paste, lang) link := ADDRESS + "/raw/" + paste download := ADDRESS + "/download/" + paste + clone := ADDRESS + "/clone/" + paste if lang == "" { p := &Page{ Title: paste, @@ -244,6 +246,7 @@ func pasteHandler(w http.ResponseWriter, r *http.Request) { Raw: link, Home: ADDRESS, Download: download, + Clone: clone, } err := templates.ExecuteTemplate(w, "paste.html", p) if err != nil { @@ -251,12 +254,31 @@ func pasteHandler(w http.ResponseWriter, r *http.Request) { } } else { - fmt.Fprintf(w, string(syntax), paste, paste, s, ADDRESS, download, link) + fmt.Fprintf(w, string(syntax), paste, paste, s, ADDRESS, download, link, clone) } } func cloneHandler(w http.ResponseWriter, r *http.Request) { + vars := mux.Vars(r) + paste := vars["pasteId"] + s := getPaste(paste, "") + link := ADDRESS + "/raw/" + paste + download := ADDRESS + "/download/" + paste + clone := ADDRESS + "/clone/" + paste + p := &Page{ + Title: paste, + Body: []byte(s), + Raw: link, + Home: ADDRESS, + Download: download, + Clone: clone, + } + err := templates.ExecuteTemplate(w, "clone.html", p) + if err != nil { + http.Error(w, err.Error(), http.StatusInternalServerError) + } + } func downloadHandler(w http.ResponseWriter, r *http.Request) { vars := mux.Vars(r)