mirror of
https://github.com/MHSanaei/3x-ui.git
synced 2025-03-01 01:20:49 +03:00

* [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
58 lines
1.3 KiB
Go
58 lines
1.3 KiB
Go
package job
|
|
|
|
import (
|
|
"io"
|
|
"os"
|
|
|
|
"x-ui/logger"
|
|
"x-ui/xray"
|
|
)
|
|
|
|
type ClearLogsJob struct{}
|
|
|
|
func NewClearLogsJob() *ClearLogsJob {
|
|
return new(ClearLogsJob)
|
|
}
|
|
|
|
// Here Run is an interface method of the Job interface
|
|
func (j *ClearLogsJob) Run() {
|
|
logFiles := []string{xray.GetIPLimitLogPath(), xray.GetIPLimitBannedLogPath(), xray.GetAccessPersistentLogPath()}
|
|
logFilesPrev := []string{xray.GetIPLimitBannedPrevLogPath(), xray.GetAccessPersistentPrevLogPath()}
|
|
|
|
// clear old previous logs
|
|
for i := 0; i < len(logFilesPrev); i++ {
|
|
if err := os.Truncate(logFilesPrev[i], 0); err != nil {
|
|
logger.Warning("clear logs job err:", err)
|
|
}
|
|
}
|
|
|
|
// clear log files and copy to previous logs
|
|
for i := 0; i < len(logFiles); i++ {
|
|
if i > 0 {
|
|
// copy to previous logs
|
|
logFilePrev, err := os.OpenFile(logFilesPrev[i-1], os.O_CREATE|os.O_APPEND|os.O_WRONLY, 0644)
|
|
if err != nil {
|
|
logger.Warning("clear logs job err:", err)
|
|
}
|
|
|
|
logFile, err := os.Open(logFiles[i])
|
|
if err != nil {
|
|
logger.Warning("clear logs job err:", err)
|
|
}
|
|
|
|
_, err = io.Copy(logFilePrev, logFile)
|
|
if err != nil {
|
|
logger.Warning("clear logs job err:", err)
|
|
}
|
|
|
|
logFile.Close()
|
|
logFilePrev.Close()
|
|
}
|
|
|
|
err := os.Truncate(logFiles[i], 0)
|
|
if err != nil {
|
|
logger.Warning("clear logs job err:", err)
|
|
}
|
|
}
|
|
}
|