|  | @@ -15,8 +15,8 @@ func NewClearLogsJob() *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.GetIPLimitPrevLogPath(), xray.GetIPLimitBannedPrevLogPath(), xray.GetAccessPersistentPrevLogPath()}
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | +	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 {
 | 
	
	
		
			
				|  | @@ -26,25 +26,26 @@ func (j *ClearLogsJob) Run() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	// clear log files and copy to previous logs
 | 
	
		
			
				|  |  |  	for i := 0; i < len(logFiles); i++ {
 | 
	
		
			
				|  |  | -		
 | 
	
		
			
				|  |  | -		// copy to previous logs
 | 
	
		
			
				|  |  | -		logFilePrev, err := os.OpenFile(logFilesPrev[i], os.O_CREATE|os.O_APPEND|os.O_RDWR, 0644)
 | 
	
		
			
				|  |  | -		if err != nil {
 | 
	
		
			
				|  |  | -			logger.Warning("clear logs job err:", err)
 | 
	
		
			
				|  |  | -		}
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -		logFile, err := os.ReadFile(logFiles[i])
 | 
	
		
			
				|  |  | -		if err != nil {
 | 
	
		
			
				|  |  | -			logger.Warning("clear logs job err:", err)
 | 
	
		
			
				|  |  | -		}
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -		_, err = logFilePrev.Write(logFile)
 | 
	
		
			
				|  |  | -		if err != nil {
 | 
	
		
			
				|  |  | -			logger.Warning("clear logs job err:", err)
 | 
	
		
			
				|  |  | +		if i > 0 {
 | 
	
		
			
				|  |  | +			// copy to previous logs
 | 
	
		
			
				|  |  | +			logFilePrev, err := os.OpenFile(logFilesPrev[i-1], os.O_CREATE|os.O_APPEND|os.O_RDWR, 0644)
 | 
	
		
			
				|  |  | +			if err != nil {
 | 
	
		
			
				|  |  | +				logger.Warning("clear logs job err:", err)
 | 
	
		
			
				|  |  | +			}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +			logFile, err := os.ReadFile(logFiles[i])
 | 
	
		
			
				|  |  | +			if err != nil {
 | 
	
		
			
				|  |  | +				logger.Warning("clear logs job err:", err)
 | 
	
		
			
				|  |  | +			}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +			_, err = logFilePrev.Write(logFile)
 | 
	
		
			
				|  |  | +			if err != nil {
 | 
	
		
			
				|  |  | +				logger.Warning("clear logs job err:", err)
 | 
	
		
			
				|  |  | +			}
 | 
	
		
			
				|  |  | +			defer logFilePrev.Close()
 | 
	
		
			
				|  |  |  		}
 | 
	
		
			
				|  |  | -		defer logFilePrev.Close()
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -		err = os.Truncate(logFiles[i], 0)
 | 
	
		
			
				|  |  | +		err := os.Truncate(logFiles[i], 0)
 | 
	
		
			
				|  |  |  		if err != nil {
 | 
	
		
			
				|  |  |  			logger.Warning("clear logs job err:", err)
 | 
	
		
			
				|  |  |  		}
 |