2022-02-06 02:22:23 +04:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2022-02-07 21:23:13 +04:00
|
|
|
"dwelling-upload/pkg/logging"
|
2022-02-06 03:03:01 +04:00
|
|
|
"dwelling-upload/pkg/utils"
|
2022-02-06 02:22:23 +04:00
|
|
|
"flag"
|
2022-03-31 16:10:56 +04:00
|
|
|
"fmt"
|
2022-02-06 02:22:23 +04:00
|
|
|
"io/ioutil"
|
|
|
|
"log"
|
|
|
|
"os"
|
|
|
|
"path"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2022-02-06 03:03:01 +04:00
|
|
|
var configPath *string = flag.String("conf", "config.yaml", "path to configuration file")
|
2023-05-24 22:09:41 +04:00
|
|
|
var uploadDir *string = flag.String("upload-dir", "/srv/uploads", "path to a directory where uploaded files are stored")
|
|
|
|
var keepFileForHours *int64 = flag.Int64("keep-for", 36, "keep files for this much hours")
|
2022-03-31 16:10:56 +04:00
|
|
|
var showVersion *bool = flag.Bool("v", false, "show version")
|
2022-02-06 02:22:23 +04:00
|
|
|
|
2023-04-24 01:05:07 +04:00
|
|
|
var version string
|
|
|
|
|
2022-02-07 22:04:40 +04:00
|
|
|
func main() {
|
|
|
|
flag.Parse()
|
2023-05-24 22:09:04 +04:00
|
|
|
log.SetFlags(log.Llongfile)
|
2022-02-07 22:04:40 +04:00
|
|
|
|
2022-03-31 16:10:56 +04:00
|
|
|
if *showVersion {
|
2023-04-24 01:05:07 +04:00
|
|
|
fmt.Println("dwelling-upload-clean Ver. ", version, "\nCopyright (c) 2022,2023 Alexander \"Arav\" Andreev <me@arav.su>")
|
2022-03-31 16:10:56 +04:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-05-24 22:09:04 +04:00
|
|
|
logClean, err := logging.New(path.Join(os.Getenv("LOGS_DIRECTORY"), "clean.log"))
|
2022-02-07 22:04:40 +04:00
|
|
|
if err != nil {
|
2023-05-24 22:09:04 +04:00
|
|
|
log.Fatalln("failed to open clean logger:", err)
|
2022-02-07 21:23:13 +04:00
|
|
|
}
|
2022-03-20 18:19:59 +04:00
|
|
|
defer logClean.Close()
|
2022-02-06 02:22:23 +04:00
|
|
|
|
2023-05-24 22:09:41 +04:00
|
|
|
uploadsDir, err := ioutil.ReadDir(*uploadDir)
|
2022-02-06 02:22:23 +04:00
|
|
|
if err != nil {
|
2023-05-24 22:09:04 +04:00
|
|
|
log.Fatalf("failed to open directory %s: %s\n", *uploadDir, err)
|
2022-02-06 02:22:23 +04:00
|
|
|
}
|
|
|
|
|
2022-02-06 03:03:01 +04:00
|
|
|
var deletedCount int64 = 0
|
|
|
|
var deletedSize int64 = 0
|
2022-02-06 02:22:23 +04:00
|
|
|
|
2022-02-06 03:03:01 +04:00
|
|
|
for _, entry := range uploadsDir {
|
2023-05-24 22:09:41 +04:00
|
|
|
if time.Now().UTC().Sub(entry.ModTime().UTC()) >= time.Duration(*keepFileForHours)*time.Hour {
|
|
|
|
if err := os.Remove(path.Join(*uploadDir, entry.Name())); err != nil {
|
2023-05-24 22:09:04 +04:00
|
|
|
log.Printf("failed to remove file %s: %s", entry.Name(), err)
|
2022-03-06 22:00:07 +04:00
|
|
|
} else {
|
|
|
|
deletedSize += entry.Size()
|
|
|
|
deletedCount++
|
2022-02-06 02:22:23 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-06 03:03:01 +04:00
|
|
|
_, _, cFSz := utils.ConvertFileSize(deletedSize)
|
|
|
|
|
2022-02-08 02:35:48 +04:00
|
|
|
if deletedCount > 0 {
|
2023-05-24 22:09:04 +04:00
|
|
|
logClean.Println(deletedCount, cFSz)
|
2022-02-08 02:35:48 +04:00
|
|
|
}
|
2022-02-06 02:22:23 +04:00
|
|
|
}
|