From 0bc3e46082d9018188262f9cb8fdbc206d0656a0 Mon Sep 17 00:00:00 2001 From: Joram Wilander Date: Thu, 16 Mar 2017 14:59:44 -0400 Subject: Implement GET /logs endpoint for APIv4 (#5778) --- api4/system.go | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) (limited to 'api4/system.go') diff --git a/api4/system.go b/api4/system.go index d33be0c66..f12d802ef 100644 --- a/api4/system.go +++ b/api4/system.go @@ -21,6 +21,8 @@ func InitSystem() { 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") + + BaseRoutes.ApiRoot.Handle("/logs", ApiSessionRequired(getLogs)).Methods("GET") } func getSystemPing(c *Context, w http.ResponseWriter, r *http.Request) { @@ -94,3 +96,18 @@ func invalidateCaches(c *Context, w http.ResponseWriter, r *http.Request) { w.Header().Set("Cache-Control", "no-cache, no-store, must-revalidate") ReturnStatusOK(w) } + +func getLogs(c *Context, w http.ResponseWriter, r *http.Request) { + if !app.SessionHasPermissionTo(c.Session, model.PERMISSION_MANAGE_SYSTEM) { + c.SetPermissionError(model.PERMISSION_MANAGE_SYSTEM) + return + } + + lines, err := app.GetLogs(c.Params.Page, c.Params.PerPage) + if err != nil { + c.Err = err + return + } + + w.Write([]byte(model.ArrayToJson(lines))) +} -- cgit v1.2.3-1-g7c22