aboutsummaryrefslogtreecommitdiffhomepage
path: root/ui/static_favicon.go
diff options
context:
space:
mode:
authorGravatar Frédéric Guillot <fred@miniflux.net>2018-10-07 18:42:43 -0700
committerGravatar Frédéric Guillot <fred@miniflux.net>2018-10-08 15:31:58 -0700
commit1f58b37a5e86603b16e137031c36f37580e9d410 (patch)
tree337a7299e91fe7640b64489357dfe7c0f00e2313 /ui/static_favicon.go
parentddfe969d6cbc8d23326cb9a3ca9a265d4e9d3e45 (diff)
Refactor HTTP response builder
Diffstat (limited to 'ui/static_favicon.go')
-rw-r--r--ui/static_favicon.go25
1 files changed, 17 insertions, 8 deletions
diff --git a/ui/static_favicon.go b/ui/static_favicon.go
index 2e19c05..1266a19 100644
--- a/ui/static_favicon.go
+++ b/ui/static_favicon.go
@@ -2,7 +2,7 @@
// Use of this source code is governed by the Apache 2.0
// license that can be found in the LICENSE file.
-package ui // import "miniflux.app/ui"
+package ui // import "miniflux.app/ui"
import (
"encoding/base64"
@@ -11,18 +11,27 @@ import (
"miniflux.app/http/response"
"miniflux.app/http/response/html"
- "miniflux.app/logger"
"miniflux.app/ui/static"
)
-// Favicon renders the application favicon.
+// Favicon shows the application favicon.
func (c *Controller) Favicon(w http.ResponseWriter, r *http.Request) {
- blob, err := base64.StdEncoding.DecodeString(static.Binaries["favicon.ico"])
- if err != nil {
- logger.Error("[Controller:Favicon] %v", err)
- html.NotFound(w)
+ etag, found := static.BinariesChecksums["favicon.ico"]
+ if !found {
+ html.NotFound(w, r)
return
}
- response.Cache(w, r, "image/x-icon", static.BinariesChecksums["favicon.ico"], blob, 48*time.Hour)
+ response.New(w, r).WithCaching(etag, 48*time.Hour, func(b *response.Builder) {
+ blob, err := base64.StdEncoding.DecodeString(static.Binaries["favicon.ico"])
+ if err != nil {
+ html.ServerError(w, r, err)
+ return
+ }
+
+ b.WithHeader("Content-Type", "image/x-icon")
+ b.WithoutCompression()
+ b.WithBody(blob)
+ b.Write()
+ })
}