3x-ui/xray/log_writer.go

53 lines
1.0 KiB
Go
Raw Normal View History

2023-12-10 15:07:50 +03:00
package xray
import (
"regexp"
2023-12-10 15:07:50 +03:00
"strings"
2023-12-10 15:07:50 +03:00
"x-ui/logger"
)
func NewLogWriter() *LogWriter {
return &LogWriter{}
}
type LogWriter struct {
lastLine string
}
func (lw *LogWriter) Write(m []byte) (n int, err error) {
regex := regexp.MustCompile(`^(\d{4}/\d{2}/\d{2} \d{2}:\d{2}:\d{2}) \[([^\]]+)\] (.+)$`)
2023-12-10 15:07:50 +03:00
// Convert the data to a string
message := strings.TrimSpace(string(m))
messages := strings.Split(message, "\n")
lw.lastLine = messages[len(messages)-1]
for _, msg := range messages {
matches := regex.FindStringSubmatch(msg)
if len(matches) > 3 {
level := matches[2]
msgBody := matches[3]
2023-12-10 15:07:50 +03:00
// Map the level to the appropriate logger function
switch level {
case "Debug":
logger.Debug("XRAY: " + msgBody)
2023-12-10 15:07:50 +03:00
case "Info":
logger.Info("XRAY: " + msgBody)
2023-12-10 15:07:50 +03:00
case "Warning":
logger.Warning("XRAY: " + msgBody)
2023-12-10 15:07:50 +03:00
case "Error":
logger.Error("XRAY: " + msgBody)
2023-12-10 15:07:50 +03:00
default:
logger.Debug("XRAY: " + msg)
}
} else if msg != "" {
logger.Debug("XRAY: " + msg)
return len(m), nil
}
}
return len(m), nil
}