aboutsummaryrefslogtreecommitdiff
path: root/server/ui/controller/proxy.go
diff options
context:
space:
mode:
authorGravatar Frédéric Guillot <fred@miniflux.net> 2017-11-19 21:10:04 -0800
committerGravatar Frédéric Guillot <fred@miniflux.net> 2017-11-19 22:01:46 -0800
commit8ffb773f43c8dc54801ca1d111854e7e881c93c9 (patch)
tree38133a2fc612597a75fed1d13e5b4042f58a2b7e /server/ui/controller/proxy.go
downloadv2-8ffb773f43c8dc54801ca1d111854e7e881c93c9.tar.gz
v2-8ffb773f43c8dc54801ca1d111854e7e881c93c9.tar.zst
v2-8ffb773f43c8dc54801ca1d111854e7e881c93c9.zip
First commit
Diffstat (limited to 'server/ui/controller/proxy.go')
-rw-r--r--server/ui/controller/proxy.go49
1 files changed, 49 insertions, 0 deletions
diff --git a/server/ui/controller/proxy.go b/server/ui/controller/proxy.go
new file mode 100644
index 00000000..8a2f2bfa
--- /dev/null
+++ b/server/ui/controller/proxy.go
@@ -0,0 +1,49 @@
+// Copyright 2017 Frédéric Guillot. All rights reserved.
+// Use of this source code is governed by the Apache 2.0
+// license that can be found in the LICENSE file.
+
+package controller
+
+import (
+ "encoding/base64"
+ "errors"
+ "github.com/miniflux/miniflux2/helper"
+ "github.com/miniflux/miniflux2/server/core"
+ "io/ioutil"
+ "log"
+ "net/http"
+ "time"
+)
+
+func (c *Controller) ImageProxy(ctx *core.Context, request *core.Request, response *core.Response) {
+ encodedURL := request.GetStringParam("encodedURL", "")
+ if encodedURL == "" {
+ response.Html().BadRequest(errors.New("No URL provided"))
+ return
+ }
+
+ decodedURL, err := base64.StdEncoding.DecodeString(encodedURL)
+ if err != nil {
+ response.Html().BadRequest(errors.New("Unable to decode this URL"))
+ return
+ }
+
+ resp, err := http.Get(string(decodedURL))
+ if err != nil {
+ log.Println(err)
+ response.Html().NotFound()
+ return
+ }
+ defer resp.Body.Close()
+
+ if resp.StatusCode != http.StatusOK {
+ response.Html().NotFound()
+ return
+ }
+
+ body, _ := ioutil.ReadAll(resp.Body)
+ etag := helper.HashFromBytes(body)
+ contentType := resp.Header.Get("Content-Type")
+
+ response.Cache(contentType, etag, body, 72*time.Hour)
+}