mirror of
				https://github.com/MHSanaei/3x-ui.git
				synced 2025-10-24 17:14:40 +00:00 
			
		
		
		
	 64a5a9f1bc
			
		
	
	
		64a5a9f1bc
		
			
		
	
	
	
	
		
			
			* [refactor] api controller * [fix] access log path better to not hardcode the access log path, maybe some ppl dont want to use the default ./access.log * [fix] set select options from logs paths in xray settings * [update] .gitignore * [lint] all .go files * [update] use status code for jsonMsg and 401 to unauthorize * [update] handle response status code via axios * [fix] set correct value if log paths is set to 'none' we also use the default value for the paths if its set to none * [fix] iplimit - only warning access log if f2b is installed
		
			
				
	
	
		
			52 lines
		
	
	
	
		
			1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
	
		
			1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package xray
 | |
| 
 | |
| import (
 | |
| 	"regexp"
 | |
| 	"strings"
 | |
| 
 | |
| 	"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}) \[([^\]]+)\] (.+)$`)
 | |
| 	// 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]
 | |
| 
 | |
| 			// Map the level to the appropriate logger function
 | |
| 			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)
 | |
| 			}
 | |
| 		} else if msg != "" {
 | |
| 			logger.Debug("XRAY: " + msg)
 | |
| 			return len(m), nil
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	return len(m), nil
 | |
| }
 |