From 9525106ccc4d9b2d92806fff9aa8635c8a573282 Mon Sep 17 00:00:00 2001 From: video-prize-ranch Date: Fri, 26 May 2023 15:45:59 -0400 Subject: [PATCH] Use browser headers for image requests --- pages/media.go | 21 +++++---------------- utils/request.go | 11 +---------- utils/setHeaders.go | 19 ++++++++++++++++++- 3 files changed, 24 insertions(+), 27 deletions(-) diff --git a/pages/media.go b/pages/media.go index 1307e96..ebd27af 100644 --- a/pages/media.go +++ b/pages/media.go @@ -1,8 +1,6 @@ package pages import ( - "crypto/sha256" - "encoding/hex" "net/http" "os" "strings" @@ -43,23 +41,12 @@ func handleMedia(c *fiber.Ctx, url string) error { url = url + "?" + strings.Split(c.OriginalURL(), "?")[1] } - optionsHash := "" - if utils.Config.ImageCache { - hasher := sha256.New() - hasher.Write([]byte(url)) - optionsHash = hex.EncodeToString(hasher.Sum(nil)) - - image, err := os.ReadFile(utils.Config.CacheDir + "/" + optionsHash) - if err == nil { - _, err := c.Write(image) - return err - } - } - req, err := http.NewRequest("GET", url, nil) if err != nil { return err } + + utils.SetReqHeaders(req) if c.Get("Range") != "" { req.Header.Set("Range", c.Get("Range")) @@ -70,9 +57,11 @@ func handleMedia(c *fiber.Ctx, url string) error { return err } + c.Status(res.StatusCode) if res.StatusCode == 404 { - c.Status(404) return c.Render("errors/404", nil) + } else if res.StatusCode == 429 { + return c.Render("errors/429", nil) } c.Set("Accept-Ranges", "bytes") diff --git a/utils/request.go b/utils/request.go index 54bb040..181847c 100644 --- a/utils/request.go +++ b/utils/request.go @@ -15,16 +15,7 @@ func GetJSON(url string) (gjson.Result, error) { return gjson.Result{}, err } - req.Header.Set("Accept", "*/*") - req.Header.Set("Accept-Language", "en-US,en;q=0.5") - req.Header.Set("Cache-Control", "no-cache") - req.Header.Set("Connection", "keep-alive") - req.Header.Set("Origin", "https://imgur.com") - req.Header.Set("Pragma", "no-cache") - req.Header.Set("Sec-Fetch-Dest", "empty") - req.Header.Set("Sec-Fetch-Mode", "cors") - req.Header.Set("Sec-Fetch-Site", "same-site") - req.Header.Set("User-Agent", "Mozilla/5.0 (Windows NT 10.0; rv:91.0) Gecko/20100101 Firefox/91.0") + SetReqHeaders(req) client := http.Client{} res, err := client.Do(req) diff --git a/utils/setHeaders.go b/utils/setHeaders.go index cff477a..0130570 100644 --- a/utils/setHeaders.go +++ b/utils/setHeaders.go @@ -1,6 +1,10 @@ package utils -import "github.com/gofiber/fiber/v2" +import ( + "net/http" + + "github.com/gofiber/fiber/v2" +) func SetHeaders(c *fiber.Ctx) { c.Set("Referrer-Policy", "no-referrer") @@ -8,4 +12,17 @@ func SetHeaders(c *fiber.Ctx) { c.Set("X-Robots-Tag", "noindex, noimageindex, nofollow") c.Set("Strict-Transport-Security", "max-age=31557600") c.Set("Permissions-Policy", "accelerometer=(), ambient-light-sensor=(), autoplay=(), battery=(), camera=(), cross-origin-isolated=(), display-capture=(), document-domain=(), encrypted-media=(), execution-while-not-rendered=(), execution-while-out-of-viewport=(), fullscreen=(self), geolocation=(), gyroscope=(), interest-cohort=(), magnetometer=(), microphone=(), midi=(), navigation-override=(), payment=(), picture-in-picture=(), publickey-credentials-get=(), screen-wake-lock=(), sync-xhr=(), usb=(), web-share=(), xr-spatial-tracking=()") +} + +func SetReqHeaders(req *http.Request) { + req.Header.Set("Accept", "*/*") + req.Header.Set("Accept-Language", "en-US,en;q=0.5") + req.Header.Set("Cache-Control", "no-cache") + req.Header.Set("Connection", "keep-alive") + req.Header.Set("Origin", "https://imgur.com") + req.Header.Set("Pragma", "no-cache") + req.Header.Set("Sec-Fetch-Dest", "empty") + req.Header.Set("Sec-Fetch-Mode", "cors") + req.Header.Set("Sec-Fetch-Site", "same-site") + req.Header.Set("User-Agent", "Mozilla/5.0 (Windows NT 10.0; rv:102.0) Gecko/20100101 Firefox/102.0") } \ No newline at end of file