2018-12-06 22:58:42 +01:00
|
|
|
package archiver
|
|
|
|
|
|
|
|
import (
|
2019-08-18 11:08:27 +02:00
|
|
|
log "github.com/sirupsen/logrus"
|
2018-12-06 22:58:42 +01:00
|
|
|
"io/ioutil"
|
2019-04-30 19:26:33 +02:00
|
|
|
"os"
|
2018-12-06 22:58:42 +01:00
|
|
|
"strconv"
|
|
|
|
"strings"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
func (a *Archiver) scanLogPath() {
|
|
|
|
channelFiles, err := ioutil.ReadDir(a.logPath)
|
|
|
|
if err != nil {
|
|
|
|
log.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, channelId := range channelFiles {
|
|
|
|
if channelId.IsDir() {
|
|
|
|
yearFiles, err := ioutil.ReadDir(a.logPath + "/" + channelId.Name())
|
|
|
|
if err != nil {
|
|
|
|
log.Error(err)
|
|
|
|
}
|
|
|
|
|
2019-04-30 19:26:33 +02:00
|
|
|
yearFiles = a.filterFiles(yearFiles)
|
|
|
|
|
2018-12-06 22:58:42 +01:00
|
|
|
for _, year := range yearFiles {
|
2019-08-18 11:08:27 +02:00
|
|
|
if year.IsDir() {
|
|
|
|
monthFiles, err := ioutil.ReadDir(a.logPath + "/" + channelId.Name() + "/" + year.Name())
|
2018-12-06 22:58:42 +01:00
|
|
|
if err != nil {
|
|
|
|
log.Error(err)
|
|
|
|
}
|
|
|
|
|
2019-08-18 11:08:27 +02:00
|
|
|
monthFiles = a.filterFiles(monthFiles)
|
2019-04-30 19:26:33 +02:00
|
|
|
|
2019-08-18 11:08:27 +02:00
|
|
|
for _, month := range monthFiles {
|
|
|
|
if month.IsDir() {
|
|
|
|
dayFiles, err := ioutil.ReadDir(a.logPath + "/" + channelId.Name() + "/" + year.Name() + "/" + month.Name())
|
2018-12-06 22:58:42 +01:00
|
|
|
if err != nil {
|
|
|
|
log.Error(err)
|
|
|
|
}
|
|
|
|
|
2019-08-18 11:08:27 +02:00
|
|
|
dayFiles = a.filterFiles(dayFiles)
|
2019-04-30 19:26:33 +02:00
|
|
|
|
2019-08-18 11:08:27 +02:00
|
|
|
for _, dayOrUserId := range dayFiles {
|
|
|
|
if dayOrUserId.IsDir() {
|
|
|
|
channelLogFiles, err := ioutil.ReadDir(a.logPath + "/" + channelId.Name() + "/" + year.Name() + "/" + month.Name() + "/" + dayOrUserId.Name())
|
2018-12-06 22:58:42 +01:00
|
|
|
if err != nil {
|
2019-08-18 11:08:27 +02:00
|
|
|
log.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
channelLogFiles = a.filterFiles(channelLogFiles)
|
|
|
|
|
|
|
|
for _, channelLogFile := range channelLogFiles {
|
|
|
|
if strings.HasSuffix(channelLogFile.Name(), ".txt") {
|
|
|
|
dayInt, err := strconv.Atoi(dayOrUserId.Name())
|
|
|
|
if err != nil {
|
|
|
|
log.Errorf("Failure converting day to int in scanner %s", err.Error())
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
if dayInt == int(time.Now().Day()) {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
a.workQueue <- a.logPath + "/" + channelId.Name() + "/" + year.Name() + "/" + month.Name() + "/" + dayOrUserId.Name() + "/" + channelLogFile.Name()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
} else if strings.HasSuffix(dayOrUserId.Name(), ".txt") {
|
|
|
|
monthInt, err := strconv.Atoi(month.Name())
|
|
|
|
if err != nil {
|
|
|
|
log.Errorf("Failure converting month to int in scanner %s", err.Error())
|
2018-12-06 22:58:42 +01:00
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
2019-08-18 11:08:27 +02:00
|
|
|
if monthInt == int(time.Now().Month()) {
|
2018-12-06 22:58:42 +01:00
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
2019-08-18 11:08:27 +02:00
|
|
|
a.workQueue <- a.logPath + "/" + channelId.Name() + "/" + year.Name() + "/" + month.Name() + "/" + dayOrUserId.Name()
|
2018-12-06 22:58:42 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2019-08-18 11:08:27 +02:00
|
|
|
|
2018-12-06 22:58:42 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2019-04-30 19:26:33 +02:00
|
|
|
|
|
|
|
func (a *Archiver) filterFiles(files []os.FileInfo) []os.FileInfo {
|
|
|
|
var result []os.FileInfo
|
|
|
|
|
|
|
|
for _, file := range files {
|
|
|
|
if !strings.HasPrefix(file.Name(), ".") {
|
|
|
|
result = append(result, file)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return result
|
|
|
|
}
|