From 2acb5486157691c5b52656f7b45e0a2ab18d1c68 Mon Sep 17 00:00:00 2001 From: Joram Wilander Date: Fri, 3 Nov 2017 17:47:52 -0400 Subject: PLT-8086 Fix plugin config watcher for enabling and disabling (#7770) * Fix plugin config watcher for enabling and disabling * Make sure HTTP routes are served * Set content-type explicitly --- app/app.go | 3 +++ app/plugins.go | 25 ++++++++++++++----------- 2 files changed, 17 insertions(+), 11 deletions(-) (limited to 'app') diff --git a/app/app.go b/app/app.go index a8d2977b5..80dc5a8ab 100644 --- a/app/app.go +++ b/app/app.go @@ -93,6 +93,9 @@ func New(options ...Option) *App { app.Srv.Store = app.newStore() app.initJobs() + app.Srv.Router.HandleFunc("/plugins/{plugin_id:[A-Za-z0-9\\_\\-\\.]+}", app.ServePluginRequest) + app.Srv.Router.HandleFunc("/plugins/{plugin_id:[A-Za-z0-9\\_\\-\\.]+}/{anything:.*}", app.ServePluginRequest) + app.Srv.Router.NotFoundHandler = http.HandlerFunc(app.Handle404) app.Srv.WebSocketRouter = &WebSocketRouter{ diff --git a/app/plugins.go b/app/plugins.go index 579b5d4e6..ce55bfc20 100644 --- a/app/plugins.go +++ b/app/plugins.go @@ -557,30 +557,33 @@ func (a *App) InitPlugins(pluginPath, webappPath string) { utils.RemoveConfigListener(a.PluginConfigListenerId) a.PluginConfigListenerId = utils.AddConfigListener(func(prevCfg, cfg *model.Config) { - if !*prevCfg.PluginSettings.Enable && *cfg.PluginSettings.Enable { - a.InitPlugins(pluginPath, webappPath) - } else if *prevCfg.PluginSettings.Enable && !*cfg.PluginSettings.Enable { - a.ShutDownPlugins() - } else if *prevCfg.PluginSettings.Enable && *cfg.PluginSettings.Enable { - a.ActivatePlugins() - } - if a.PluginEnv == nil { return } + if *prevCfg.PluginSettings.Enable && *cfg.PluginSettings.Enable { + a.ActivatePlugins() + } + for _, err := range a.PluginEnv.Hooks().OnConfigurationChange() { l4g.Error(err.Error()) } }) - a.Srv.Router.HandleFunc("/plugins/{plugin_id:[A-Za-z0-9\\_\\-\\.]+}", a.ServePluginRequest) - a.Srv.Router.HandleFunc("/plugins/{plugin_id:[A-Za-z0-9\\_\\-\\.]+}/{anything:.*}", a.ServePluginRequest) - a.ActivatePlugins() } func (a *App) ServePluginRequest(w http.ResponseWriter, r *http.Request) { + if a.PluginEnv == nil || !*a.Config().PluginSettings.Enable { + err := model.NewAppError("ServePluginRequest", "app.plugin.disabled.app_error", nil, "Enable plugins to serve plugin requests", http.StatusNotImplemented) + err.Translate(utils.T) + l4g.Error(err.Error()) + w.WriteHeader(err.StatusCode) + w.Header().Set("Content-Type", "application/json") + w.Write([]byte(err.ToJson())) + return + } + token := "" authHeader := r.Header.Get(model.HEADER_AUTH) -- cgit v1.2.3-1-g7c22