Skip to content

Commit

Permalink
fix gzipped plugin asset response (grafana#36721)
Browse files Browse the repository at this point in the history
  • Loading branch information
wbrowne authored Jul 14, 2021
1 parent cbda218 commit 7dbe388
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 16 deletions.
2 changes: 1 addition & 1 deletion pkg/api/api.go
Original file line number Diff line number Diff line change
Expand Up @@ -133,7 +133,7 @@ func (hs *HTTPServer) registerRoutes() {
r.Get("/api/login/ping", quota("session"), routing.Wrap(hs.LoginAPIPing))

// expose plugin file system assets
r.Get("/public/plugins/:pluginId/*", routing.Wrap(hs.GetPluginAssets))
r.Get("/public/plugins/:pluginId/*", hs.GetPluginAssets)

// authed api
r.Group("/api", func(apiRoute routing.RouteRegister) {
Expand Down
30 changes: 15 additions & 15 deletions pkg/api/plugins.go
Original file line number Diff line number Diff line change
Expand Up @@ -257,11 +257,12 @@ func (hs *HTTPServer) CollectPluginMetrics(c *models.ReqContext) response.Respon
// GetPluginAssets returns public plugin assets (images, JS, etc.)
//
// /public/plugins/:pluginId/*
func (hs *HTTPServer) GetPluginAssets(c *models.ReqContext) response.Response {
func (hs *HTTPServer) GetPluginAssets(c *models.ReqContext) {
pluginID := c.Params("pluginId")
plugin := hs.PluginManager.GetPlugin(pluginID)
if plugin == nil {
return response.Error(404, "Plugin not found", nil)
c.Handle(hs.Cfg, 404, "Plugin not found", nil)
return
}

requestedFile := filepath.Clean(c.Params("*"))
Expand All @@ -273,9 +274,11 @@ func (hs *HTTPServer) GetPluginAssets(c *models.ReqContext) response.Response {
f, err := os.Open(pluginFilePath)
if err != nil {
if os.IsNotExist(err) {
return response.Error(404, "Plugin file not found", err)
c.Handle(hs.Cfg, 404, "Plugin file not found", err)
return
}
return response.Error(500, "Could not open plugin file", err)
c.Handle(hs.Cfg, 500, "Could not open plugin file", err)
return
}
defer func() {
if err := f.Close(); err != nil {
Expand All @@ -285,26 +288,23 @@ func (hs *HTTPServer) GetPluginAssets(c *models.ReqContext) response.Response {

fi, err := f.Stat()
if err != nil {
return response.Error(500, "Plugin file exists but could not open", err)
c.Handle(hs.Cfg, 500, "Plugin file exists but could not open", err)
return
}

if shouldExclude(fi) {
return response.Error(403, "Plugin file access forbidden",
c.Handle(hs.Cfg, 403, "Plugin file access forbidden",
fmt.Errorf("access is forbidden to executable plugin file %s", pluginFilePath))
return
}

resp := response.CreateNormalResponse(
http.Header{"Cache-Control": []string{"public", "max-age=3600"}},
[]byte{},
200)

if hs.Cfg.Env == setting.Dev {
resp.SetHeader("Cache-Control", "max-age=0, must-revalidate, no-cache")
c.Resp.Header().Set("Cache-Control", "max-age=0, must-revalidate, no-cache")
} else {
c.Resp.Header().Set("Cache-Control", "public, max-age=3600")
}

http.ServeContent(resp, c.Req.Request, pluginFilePath, fi.ModTime(), f)

return resp
http.ServeContent(c.Resp, c.Req.Request, pluginFilePath, fi.ModTime(), f)
}

// CheckHealth returns the health of a plugin.
Expand Down

0 comments on commit 7dbe388

Please sign in to comment.