From f9a4a6120db69e5ead542cb130533b0c20e2cd66 Mon Sep 17 00:00:00 2001 From: tobi <31960611+tsmethurst@users.noreply.github.com> Date: Wed, 29 May 2024 12:56:17 +0200 Subject: [feature] Debug admin endpoint to clear caches (#2940) * [feature] Debug admin endpoint to clear caches * go fmt --- internal/api/client/admin/debug_on.go | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) (limited to 'internal/api/client/admin/debug_on.go') diff --git a/internal/api/client/admin/debug_on.go b/internal/api/client/admin/debug_on.go index c6dfa11ff..ea42206f8 100644 --- a/internal/api/client/admin/debug_on.go +++ b/internal/api/client/admin/debug_on.go @@ -56,3 +56,27 @@ func (m *Module) DebugAPUrlHandler(c *gin.Context) { c.JSON(http.StatusOK, resp) } + +func (m *Module) DebugClearCachesHandler(c *gin.Context) { + authed, err := oauth.Authed(c, true, true, true, true) + if err != nil { + apiutil.ErrorHandler(c, gtserror.NewErrorUnauthorized(err, err.Error()), m.processor.InstanceGetV1) + return + } + + if !*authed.User.Admin { + err := fmt.Errorf("user %s not an admin", authed.User.ID) + apiutil.ErrorHandler(c, gtserror.NewErrorForbidden(err, err.Error()), m.processor.InstanceGetV1) + return + } + + if _, err := apiutil.NegotiateAccept(c, apiutil.JSONAcceptHeaders...); err != nil { + apiutil.ErrorHandler(c, gtserror.NewErrorNotAcceptable(err, err.Error()), m.processor.InstanceGetV1) + return + } + + // Sweep all caches down to 0 (empty). + m.state.Caches.Sweep(0) + + c.JSON(http.StatusOK, gin.H{"status": "OK"}) +} -- cgit v1.2.3