api/count added

master
serr 2025-04-06 15:12:45 +03:00
parent 61341eaa03
commit 78a5b847ae
4 changed files with 64 additions and 1 deletions

10
main.go
View File

@ -15,6 +15,11 @@ go build main.go
sudo systemctl start server.service sudo systemctl start server.service
*/ */
func init() {
log.SetFlags(log.LstdFlags)
log.SetPrefix("hikan.ru | ")
}
func main() { func main() {
var app *models.App var app *models.App
var err error var err error
@ -64,6 +69,11 @@ func setupRoutes(a *models.App) *http.ServeMux {
router.Handle("/", m(controllers_pages.MainPageHandler(a))) router.Handle("/", m(controllers_pages.MainPageHandler(a)))
} }
// api
{
router.Handle("/api/count/", m(controllers.CountHandler()))
}
return router return router
} }

24
mvc/controllers/api.go Normal file
View File

@ -0,0 +1,24 @@
package controllers
import (
"log"
"main/tools"
"net/http"
)
func CountHandler() http.HandlerFunc {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
var count []byte
var err error
if count, err = tools.GetJournalctlLogs("server", "hikan.ru", 24); err != nil {
log.Printf("%s", err.Error())
}
SendCount(w, count)
})
}
func SendCount(w http.ResponseWriter, data []byte) {
w.Header().Set("Content-Type", "text/plain; charset=utf-8")
w.WriteHeader(http.StatusOK)
w.Write(data)
}

View File

@ -38,6 +38,6 @@ func LoggingMiddleware(next http.Handler) http.Handler {
next.ServeHTTP(w, r) next.ServeHTTP(w, r)
log.Printf("%s %s in %v", r.Method, r.URL.Path, time.Since(start)) log.Printf("%s %s %v", r.Method, r.URL.Path, time.Since(start))
}) })
} }

29
tools/logs.go Normal file
View File

@ -0,0 +1,29 @@
package tools
import (
"bytes"
"fmt"
"os/exec"
"runtime"
)
func GetJournalctlLogs(serviceName, grepPattern string, hoursAgo int) ([]byte, error) {
if runtime.GOOS != "linux" {
return nil, fmt.Errorf("not a linux")
}
cmd := exec.Command("sh", "-c",
fmt.Sprintf("journalctl -u %s --since '%d hours ago' | grep -c '%s'",
serviceName, hoursAgo, grepPattern))
var output bytes.Buffer
cmd.Stdout = &output
err := cmd.Run()
if err != nil {
return nil, err
}
return output.Bytes(), nil
}