3x-ui/xray/log_writer.go

67 lines
1.4 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) {
crashRegex := regexp.MustCompile(`(?i)(panic|exception|stack trace|fatal error)`)
2023-12-10 15:07:50 +03:00
// Convert the data to a string
message := strings.TrimSpace(string(m))
// Check if the message contains a crash
if crashRegex.MatchString(message) {
logger.Debug("Core crash detected:\n", message)
lw.lastLine = message
err1 := writeCrachReport(m)
if err1 != nil {
logger.Error("Unable to write crash report:", err1)
}
return len(m), nil
}
regex := regexp.MustCompile(`^(\d{4}/\d{2}/\d{2} \d{2}:\d{2}:\d{2}) \[([^\]]+)\] (.+)$`)
2023-12-10 15:07:50 +03:00
messages := strings.Split(message, "\n")
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)
}
lw.lastLine = ""
2023-12-10 15:07:50 +03:00
} else if msg != "" {
logger.Debug("XRAY: " + msg)
lw.lastLine = msg
2023-12-10 15:07:50 +03:00
}
}
return len(m), nil
}