Blame view
http_utility.go
3.28 KB
64041a2ea first commit |
1 2 3 4 5 6 |
package restutility import ( "net/http" "encoding/json" ) |
25e001550 exported everything |
7 8 9 10 |
var _apiVersion = "/api/v1" func SetApiVersion(ver string) string { _apiVersion = ver |
b291ac8c4 clened up |
11 |
return _apiVersion |
25e001550 exported everything |
12 |
} |
90fd36e9b resolved some dep... |
13 |
|
64041a2ea first commit |
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |
//// //// ERROR UTILITY //// const templateHttpErr500_EN = "An internal server error has occurred." const templateHttpErr500_RS = "Došlo je do greške na serveru." const templateHttpErr400_EN = "Bad request: invalid request body." const templateHttpErr400_RS = "Neispravan zahtev." type HttpError struct { Error []HttpErrorDesc `json:"error"` Request string `json:"request"` } type HttpErrorDesc struct { Lang string `json:"lang"` Desc string `json:"description"` } |
25e001550 exported everything |
32 |
func RespondWithHttpError(w http.ResponseWriter, |
64041a2ea first commit |
33 34 35 36 37 38 39 40 41 42 43 |
req *http.Request, code int, httpErr []HttpErrorDesc) { err := HttpError{ Error: httpErr, Request: req.Method + " " + req.URL.Path, } w.WriteHeader(code) json.NewEncoder(w).Encode(err) } |
25e001550 exported everything |
44 45 46 47 48 |
func RespondWithHttpError400(w http.ResponseWriter, req *http.Request) { RespondWithHttpError(w, req, http.StatusBadRequest, []HttpErrorDesc{ {Lang: "en", Desc: templateHttpErr400_EN}, {Lang: "rs", Desc: templateHttpErr400_RS}, }) |
64041a2ea first commit |
49 |
} |
25e001550 exported everything |
50 51 52 53 54 |
func RespondWithHttpError500(w http.ResponseWriter, req *http.Request) { RespondWithHttpError(w, req, http.StatusInternalServerError, []HttpErrorDesc{ {Lang: "en", Desc: templateHttpErr500_EN}, {Lang: "rs", Desc: templateHttpErr500_RS}, }) |
64041a2ea first commit |
55 |
} |
25e001550 exported everything |
56 |
func DeliverPayload(w http.ResponseWriter, payload JSONPayload) { |
64041a2ea first commit |
57 58 59 60 61 62 63 64 65 66 |
json.NewEncoder(w).Encode(payload) payload.Data = nil } //// //// HANDLER FUNC WRAPPER //// // wrapHandlerFunc is as wrapper function for route handlers. // Sets common headers and checks for token validity. |
25e001550 exported everything |
67 |
func HandleFuncWrap(fn http.HandlerFunc) http.HandlerFunc { |
64041a2ea first commit |
68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 |
return func(w http.ResponseWriter, req *http.Request) { // @TODO: check Content-type header (must be application/json) // ctype := w.Header.Get("Content-Type") // if req.Method != "GET" && ctype != "application/json" { // replyWithHttpError(w, req, http.StatusBadRequest, // "Not a supported content type: " + ctype) // } w.Header().Set("Access-Control-Allow-Origin", "*") w.Header().Set("Access-Control-Allow-Methods", `POST, GET, PUT, DELETE, OPTIONS`) w.Header().Set("Access-Control-Allow-Headers", `Accept, Content-Type, Content-Length, Accept-Encoding, X-CSRF-Token, Authorization`) w.Header().Set("Content-Type", "application/json; charset=utf-8") if req.Method == "OPTIONS" { return } |
25e001550 exported everything |
95 |
if req.URL.Path != _apiVersion + "/token/new" { |
64041a2ea first commit |
96 |
token := req.Header.Get("Authorization") |
25e001550 exported everything |
97 98 |
if _, err := ParseAPIToken(token); err != nil { RespondWithHttpError(w, req, http.StatusUnauthorized, |
64041a2ea first commit |
99 |
[]HttpErrorDesc{ |
25e001550 exported everything |
100 101 |
{Lang: "en", Desc: "Unauthorized request."}, {Lang: "rs", Desc: "Neautorizovani zahtev."}, |
64041a2ea first commit |
102 103 104 105 106 107 108 |
}) return } } err := req.ParseForm() if err != nil { |
25e001550 exported everything |
109 |
RespondWithHttpError(w, req, http.StatusBadRequest, |
64041a2ea first commit |
110 |
[]HttpErrorDesc{ |
25e001550 exported everything |
111 112 |
{Lang: "en", Desc: templateHttpErr400_EN}, {Lang: "rs", Desc: templateHttpErr400_RS}, |
64041a2ea first commit |
113 114 115 116 117 118 119 120 121 122 |
}) return } fn(w, req) } } //// //// NOT FOUND HANDLER //// |
25e001550 exported everything |
123 124 125 126 127 |
func NotFoundHandler(w http.ResponseWriter, req *http.Request) { RespondWithHttpError(w, req, http.StatusNotFound, []HttpErrorDesc{ {Lang: "en", Desc: "Not found."}, {Lang: "rs", Desc: "Traženi resurs ne postoji."}, }) |
64041a2ea first commit |
128 |
} |