roese-utils/rslogger/rslogger.go

79 lines
1.7 KiB
Go
Raw Normal View History

2023-10-08 12:54:38 +02:00
package rslogger
import (
"encoding/json"
"os"
"time"
"github.com/gofiber/fiber/v2"
"github.com/rs/zerolog"
"github.com/rs/zerolog/log"
)
var usedLogManagerServerUrl string
func InitLogger(debug bool, colorizedOutput bool, logManagerServerUrl string) {
zerolog.TimeFieldFormat = zerolog.TimeFormatUnix
if debug {
zerolog.SetGlobalLevel(zerolog.DebugLevel)
} else {
zerolog.SetGlobalLevel(zerolog.InfoLevel)
}
if colorizedOutput {
log.Logger = log.Output(zerolog.ConsoleWriter{Out: os.Stderr, TimeFormat: "15:04:05"})
}
if logManagerServerUrl != "" {
usedLogManagerServerUrl = logManagerServerUrl
}
}
2023-10-08 12:57:19 +02:00
func GetTime() string {
2023-10-08 12:54:38 +02:00
return time.Now().Format("15:04:05 02-01-2006") + " "
}
type LogManagerRequestBody struct {
2023-10-17 22:02:19 +02:00
Type string // like system, grouptasks, etc
Logs []string // array of logs
2023-10-08 12:54:38 +02:00
}
2023-10-17 22:02:19 +02:00
const (
2023-10-17 22:03:34 +02:00
LogTypeInfo = "I "
LogTypeWarning = "W "
LogTypeError = "E "
2023-10-17 22:02:19 +02:00
)
func LogManagerRequestClient(requestMethod string, requestBody LogManagerRequestBody) {
if usedLogManagerServerUrl == "" {
log.Error().Msgf("Log manager server url is not set, skipping request")
return
}
2023-10-08 12:54:38 +02:00
a := fiber.AcquireAgent()
req := a.Request()
req.Header.SetMethod(requestMethod)
req.SetRequestURI(usedLogManagerServerUrl + "/v1/log")
2023-10-08 12:54:38 +02:00
req.Header.SetContentType("application/json")
2023-10-17 22:02:19 +02:00
reqestBodyBytes, err := json.Marshal(requestBody)
2023-10-08 12:54:38 +02:00
if err != nil {
log.Error().Msgf("Failed to marshal request body, err: %s", err)
return
}
req.SetBody(reqestBodyBytes)
if err := a.Parse(); err != nil {
log.Error().Msgf("Failed to parse request, err: %s", err)
return
}
code, body, _ := a.Bytes()
2023-10-09 19:30:37 +02:00
log.Debug().Msgf("Log manager request, code: %d, body: %s", code, body)
2023-10-08 12:54:38 +02:00
}