diff options
author | Frédéric Guillot <fred@miniflux.net> | 2018-10-07 18:42:43 -0700 |
---|---|---|
committer | Frédéric Guillot <fred@miniflux.net> | 2018-10-08 15:31:58 -0700 |
commit | 1f58b37a5e86603b16e137031c36f37580e9d410 (patch) | |
tree | 337a7299e91fe7640b64489357dfe7c0f00e2313 /ui/static_app_icon.go | |
parent | ddfe969d6cbc8d23326cb9a3ca9a265d4e9d3e45 (diff) |
Refactor HTTP response builder
Diffstat (limited to 'ui/static_app_icon.go')
-rw-r--r-- | ui/static_app_icon.go | 26 |
1 files changed, 14 insertions, 12 deletions
diff --git a/ui/static_app_icon.go b/ui/static_app_icon.go index 2ad42fd..9e2a448 100644 --- a/ui/static_app_icon.go +++ b/ui/static_app_icon.go @@ -12,26 +12,28 @@ import ( "miniflux.app/http/request" "miniflux.app/http/response" "miniflux.app/http/response/html" - "miniflux.app/logger" "miniflux.app/ui/static" ) -// AppIcon renders application icons. +// AppIcon shows application icons. func (c *Controller) AppIcon(w http.ResponseWriter, r *http.Request) { filename := request.RouteStringParam(r, "filename") - encodedBlob, found := static.Binaries[filename] + etag, found := static.BinariesChecksums[filename] if !found { - logger.Info("[Controller:AppIcon] This icon doesn't exists: %s", filename) - html.NotFound(w) + html.NotFound(w, r) return } - blob, err := base64.StdEncoding.DecodeString(encodedBlob) - if err != nil { - logger.Error("[Controller:AppIcon] %v", err) - html.NotFound(w) - return - } + response.New(w, r).WithCaching(etag, 72*time.Hour, func(b *response.Builder) { + blob, err := base64.StdEncoding.DecodeString(static.Binaries[filename]) + if err != nil { + html.ServerError(w, r, err) + return + } - response.Cache(w, r, "image/png", static.BinariesChecksums[filename], blob, 48*time.Hour) + b.WithHeader("Content-Type", "image/png") + b.WithoutCompression() + b.WithBody(blob) + b.Write() + }) } |