aboutsummaryrefslogtreecommitdiff
path: root/backend/api/routes.go
blob: ef8ccf72cacbb0d6d7662306b696d92ada954709 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
package api

import (
	"encoding/json"
	"fmt"
	"net/http"
	"time"

	"github.com/gorilla/mux"
	"github.com/jackyzha0/ctrl-v/cache"
	"github.com/jackyzha0/ctrl-v/db"

	log "github.com/sirupsen/logrus"
)

func healthCheckFunc(w http.ResponseWriter, r *http.Request) {
	fmt.Fprint(w, "status ok")
}

func insertFunc(w http.ResponseWriter, r *http.Request) {
	// get content
	_ = r.ParseMultipartForm(0)
	expiry := r.FormValue("expiry")
	content := r.FormValue("content")
	title := r.FormValue("title")

	// get ip
	ip := getIP(r)

	log.Infof("got content '%s' and ip '%s'", content, ip)

	// insert content
	err := db.New(ip, content, expiry, title)
	if err != nil {
		fmt.Fprintf(w, "got err: %s", err.Error())
	}
}

func getHashFunc(w http.ResponseWriter, r *http.Request) {
	hash := mux.Vars(r)["hash"]
	paste, err := cache.C.Get(hash)

	// if hash was not found
	if err != nil {
		w.WriteHeader(http.StatusNotFound)
		fmt.Fprintf(w, "got err: %s", err.Error())
		return
	}

	// otherwise, return paste content and current time
	w.Header().Set("Content-Type", "application/json")
	pasteMap := map[string]interface{}{
		"timestamp": time.Now(),
		"content":   paste.Content,
	}

	jsonData, _ := json.Marshal(pasteMap)
	fmt.Fprintf(w, "%+v", string(jsonData))
}