diff options
| author | Adam Mathes <adam@adammathes.com> | 2026-02-12 21:35:46 -0800 |
|---|---|---|
| committer | Adam Mathes <adam@adammathes.com> | 2026-02-12 21:35:46 -0800 |
| commit | de96851d8eb0a0b45d7bf0cee67339fea54349f0 (patch) | |
| tree | d9ca55835743e2254732ea68a674e7007f3554eb /web/web.go | |
| parent | 8a8f516ebd1115eed6256cd1b60be6393fd42c26 (diff) | |
| download | neko-de96851d8eb0a0b45d7bf0cee67339fea54349f0.tar.gz neko-de96851d8eb0a0b45d7bf0cee67339fea54349f0.tar.bz2 neko-de96851d8eb0a0b45d7bf0cee67339fea54349f0.zip | |
wip: tui updates (buggy)
Diffstat (limited to 'web/web.go')
| -rw-r--r-- | web/web.go | 12 |
1 files changed, 11 insertions, 1 deletions
@@ -7,6 +7,7 @@ import ( "log" "net/http" "strconv" + "strings" "time" "adammathes.com/neko/api" @@ -20,8 +21,17 @@ func indexHandler(w http.ResponseWriter, r *http.Request) { } func imageProxyHandler(w http.ResponseWriter, r *http.Request) { - imgURL := r.URL.String() + imgURL := strings.TrimPrefix(r.URL.Path, "/") + if imgURL == "" { + http.Error(w, "no image url provided", http.StatusNotFound) + return + } + decodedURL, err := base64.URLEncoding.DecodeString(imgURL) + if err != nil { + http.Error(w, "invalid image url", http.StatusNotFound) + return + } // pseudo-caching if r.Header.Get("If-None-Match") == string(decodedURL) { |
