Files
trihuy-russian/xray/log_writer.go
T

67 lines
1.4 KiB
Go
Raw Normal View History

2023-12-10 13:07:50 +01:00
package xray
import (
2024-02-17 21:37:58 +03:30
"regexp"
2023-12-10 13:07:50 +01:00
"strings"
2024-03-11 01:01:24 +03:30
2023-12-10 13:07:50 +01:00
"x-ui/logger"
)
func NewLogWriter() *LogWriter {
return &LogWriter{}
}
type LogWriter struct {
lastLine string
}
func (lw *LogWriter) Write(m []byte) (n int, err error) {
2024-12-03 23:07:24 +01:00
crashRegex := regexp.MustCompile(`(?i)(panic|exception|stack trace|fatal error)`)
2023-12-10 13:07:50 +01:00
// Convert the data to a string
message := strings.TrimSpace(string(m))
2024-12-03 23:07:24 +01:00
// 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 13:46:46 +01:00
regex := regexp.MustCompile(`^(\d{4}/\d{2}/\d{2} \d{2}:\d{2}:\d{2}\.\d{6}) \[([^\]]+)\] (.+)$`)
2023-12-10 13:07:50 +01:00
messages := strings.Split(message, "\n")
for _, msg := range messages {
2024-02-17 21:37:58 +03:30
matches := regex.FindStringSubmatch(msg)
2024-01-10 16:16:18 +03:30
2024-02-17 21:37:58 +03:30
if len(matches) > 3 {
level := matches[2]
msgBody := matches[3]
2023-12-10 13:07:50 +01:00
// Map the level to the appropriate logger function
switch level {
case "Debug":
2024-02-19 00:45:00 +03:30
logger.Debug("XRAY: " + msgBody)
2023-12-10 13:07:50 +01:00
case "Info":
2024-02-19 00:45:00 +03:30
logger.Info("XRAY: " + msgBody)
2023-12-10 13:07:50 +01:00
case "Warning":
2024-02-19 00:45:00 +03:30
logger.Warning("XRAY: " + msgBody)
2023-12-10 13:07:50 +01:00
case "Error":
2024-02-19 00:45:00 +03:30
logger.Error("XRAY: " + msgBody)
2023-12-10 13:07:50 +01:00
default:
logger.Debug("XRAY: " + msg)
}
2024-12-03 23:07:24 +01:00
lw.lastLine = ""
2023-12-10 13:07:50 +01:00
} else if msg != "" {
logger.Debug("XRAY: " + msg)
2024-12-03 23:07:24 +01:00
lw.lastLine = msg
2023-12-10 13:07:50 +01:00
}
}
return len(m), nil
}