summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCarlos Tadeu Panato Junior <ctadeu@gmail.com>2017-03-14 17:06:07 +0100
committerGeorge Goldberg <george@gberg.me>2017-03-14 16:06:07 +0000
commitfa47132b8f1d6d889450021f6afbdc903208ac41 (patch)
tree128ff3b7563e3fcef45c0ddc07704335566eb881
parenta1994cf7ce3d660edd4be4a470b1239443a99275 (diff)
downloadchat-fa47132b8f1d6d889450021f6afbdc903208ac41.tar.gz
chat-fa47132b8f1d6d889450021f6afbdc903208ac41.tar.bz2
chat-fa47132b8f1d6d889450021f6afbdc903208ac41.zip
[APIV4] POST /caches/invalidate - endpoint for apiV4 (#5756)
-rw-r--r--api4/system.go17
-rw-r--r--api4/system_test.go17
-rw-r--r--model/client4.go13
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.