summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--app/app.go3
-rw-r--r--app/plugins.go25
-rw-r--r--cmd/platform/server.go7
3 files changed, 24 insertions, 11 deletions
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)
diff --git a/cmd/platform/server.go b/cmd/platform/server.go
index 6de14d63e..93bc00f88 100644
--- a/cmd/platform/server.go
+++ b/cmd/platform/server.go
@@ -75,6 +75,13 @@ func runServer(configFileLocation string) {
if webappDir, ok := utils.FindDir(model.CLIENT_DIR); ok {
a.InitPlugins(*a.Config().PluginSettings.Directory, webappDir+"/plugins")
+ utils.AddConfigListener(func(prevCfg, cfg *model.Config) {
+ if *cfg.PluginSettings.Enable {
+ a.InitPlugins(*cfg.PluginSettings.Directory, webappDir+"/plugins")
+ } else {
+ a.ShutDownPlugins()
+ }
+ })
} else {
l4g.Error("Unable to find webapp directory, could not initialize plugins")
}