3x-ui/xray/log_writer.go

74 lines
1.6 KiB
Go
Raw Normal View History

2023-12-10 12:07:50 +00:00
package xray
import (
"regexp"
2023-12-10 12:07:50 +00:00
"strings"
2023-12-10 12:07:50 +00: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 12:07:50 +00: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
}
2025-03-10 12:46:46 +00:00
regex := regexp.MustCompile(`^(\d{4}/\d{2}/\d{2} \d{2}:\d{2}:\d{2}\.\d{6}) \[([^\]]+)\] (.+)$`)
messages := strings.SplitSeq(message, "\n")
2023-12-10 12:07:50 +00:00
for msg := range messages {
matches := regex.FindStringSubmatch(msg)
if len(matches) > 3 {
level := matches[2]
msgBody := matches[3]
2023-12-10 12:07:50 +00:00
if strings.Contains(strings.ToLower(msgBody), "failed") {
logger.Error("XRAY: " + msgBody)
} else {
switch level {
case "Debug":
logger.Debug("XRAY: " + msgBody)
case "Info":
logger.Info("XRAY: " + msgBody)
case "Warning":
logger.Warning("XRAY: " + msgBody)
case "Error":
logger.Error("XRAY: " + msgBody)
default:
logger.Debug("XRAY: " + msg)
}
2023-12-10 12:07:50 +00:00
}
lw.lastLine = ""
2023-12-10 12:07:50 +00:00
} else if msg != "" {
if strings.Contains(strings.ToLower(msg), "failed") {
logger.Error("XRAY: " + msg)
} else {
logger.Debug("XRAY: " + msg)
}
lw.lastLine = msg
2023-12-10 12:07:50 +00:00
}
}
return len(m), nil
}