-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathhandler.go
73 lines (64 loc) · 1.67 KB
/
handler.go
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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
package webizen
import (
"encoding/json"
"fmt"
"log"
"net/http"
"strings"
)
var (
methodsAll = []string{
"OPTIONS", "HEAD", "GET", "POST",
}
)
type Handler struct{ http.Handler }
func (h *Handler) ServeHTTP(w http.ResponseWriter, req *http.Request) {
origin := ""
origins := req.Header["Origin"] // all CORS requests
if len(origins) > 0 {
origin = origins[0]
w.Header().Set("Access-Control-Allow-Origin", origin)
}
switch req.Method {
case "OPTIONS":
w.Header().Set("Accept-Patch", "application/json")
w.Header().Set("Accept-Post", "text/turtle,application/json")
corsReqH := req.Header["Access-Control-Request-Headers"] // CORS preflight only
if len(corsReqH) > 0 {
w.Header().Set("Access-Control-Allow-Headers", strings.Join(corsReqH, ", "))
}
corsReqM := req.Header["Access-Control-Request-Method"] // CORS preflight only
if len(corsReqM) > 0 {
w.Header().Set("Access-Control-Allow-Methods", strings.Join(corsReqM, ", "))
} else {
w.Header().Set("Access-Control-Allow-Methods", strings.Join(methodsAll, ", "))
}
if len(origin) < 1 {
w.Header().Set("Access-Control-Allow-Origin", "*")
}
w.Header().Set("Allow", strings.Join(methodsAll, ", "))
w.WriteHeader(200)
return
case "GET", "POST":
query := req.FormValue("q")
if len(query) > 0 {
r := search(query)
if len(r) > 0 {
w.Header().Set("Content-Type", "application/json")
w.WriteHeader(200)
body, err := json.MarshalIndent(r, "", " ")
if err == nil {
fmt.Fprintln(w, string(body))
} else {
log.Println(err)
}
return
}
}
default:
w.WriteHeader(405)
fmt.Fprintln(w, "Method Not Allowed:", req.Method)
return
}
w.WriteHeader(404)
}