diff options
-rw-r--r-- | api4/system.go | 17 | ||||
-rw-r--r-- | api4/system_test.go | 17 | ||||
-rw-r--r-- | model/client4.go | 13 |
3 files changed, 47 insertions, 0 deletions
diff --git a/api4/system.go b/api4/system.go index 32c010d82..d33be0c66 100644 --- a/api4/system.go +++ b/api4/system.go @@ -20,6 +20,7 @@ func InitSystem() { BaseRoutes.ApiRoot.Handle("/config/reload", ApiSessionRequired(configReload)).Methods("POST") BaseRoutes.ApiRoot.Handle("/email/test", ApiSessionRequired(testEmail)).Methods("POST") BaseRoutes.ApiRoot.Handle("/database/recycle", ApiSessionRequired(databaseRecycle)).Methods("POST") + BaseRoutes.ApiRoot.Handle("/caches/invalidate", ApiSessionRequired(invalidateCaches)).Methods("POST") } func getSystemPing(c *Context, w http.ResponseWriter, r *http.Request) { @@ -77,3 +78,19 @@ func databaseRecycle(c *Context, w http.ResponseWriter, r *http.Request) { ReturnStatusOK(w) } + +func invalidateCaches(c *Context, w http.ResponseWriter, r *http.Request) { + if !app.SessionHasPermissionTo(c.Session, model.PERMISSION_MANAGE_SYSTEM) { + c.SetPermissionError(model.PERMISSION_MANAGE_SYSTEM) + return + } + + err := app.InvalidateAllCaches() + if err != nil { + c.Err = err + return + } + + w.Header().Set("Cache-Control", "no-cache, no-store, must-revalidate") + ReturnStatusOK(w) +} diff --git a/api4/system_test.go b/api4/system_test.go index cb6ca7b81..4da91f428 100644 --- a/api4/system_test.go +++ b/api4/system_test.go @@ -126,5 +126,22 @@ func TestDatabaseRecycle(t *testing.T) { _, resp = th.SystemAdminClient.DatabaseRecycle() CheckNoError(t, resp) +} + +func TestInvalidateCaches(t *testing.T) { + th := Setup().InitBasic().InitSystemAdmin() + defer TearDown() + Client := th.Client + + flag, resp := Client.InvalidateCaches() + CheckForbiddenStatus(t, resp) + if flag == true { + t.Fatal("should not clean the cache due no permission.") + } + flag, resp = th.SystemAdminClient.InvalidateCaches() + CheckNoError(t, resp) + if flag == false { + t.Fatal("should clean the cache") + } } diff --git a/model/client4.go b/model/client4.go index df09174d5..8f3328e80 100644 --- a/model/client4.go +++ b/model/client4.go @@ -154,6 +154,10 @@ func (c *Client4) GetDatabaseRoute() string { return fmt.Sprintf("/database") } +func (c *Client4) GetCacheRoute() string { + return fmt.Sprintf("/caches") +} + func (c *Client4) GetClusterRoute() string { return fmt.Sprintf("/cluster") } @@ -1154,6 +1158,15 @@ func (c *Client4) DatabaseRecycle() (bool, *Response) { } } +func (c *Client4) InvalidateCaches() (bool, *Response) { + if r, err := c.DoApiPost(c.GetCacheRoute()+"/invalidate", ""); err != nil { + return false, &Response{StatusCode: r.StatusCode, Error: err} + } else { + defer closeBody(r) + return CheckStatusOK(r), BuildResponse(r) + } +} + // Webhooks Section // CreateIncomingWebhook creates an incoming webhook for a channel. |