-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathclean.go
117 lines (99 loc) · 2.32 KB
/
clean.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
package main
import (
"fmt"
"html/template"
"os"
"time"
"github.com/dmgk/fallout/cache"
"github.com/dmgk/getopt"
)
var cleanUsageTmpl = template.Must(template.New("usage-clean").Parse(`
usage: {{.progname}} clean [-hx] [-D days] [-A date]
Clean log cache.
Options:
-h show help and exit
-x remove all cached data
-D days remove logs that are more than days old (default: {{.daysLimit}})
-A date remove logs that are older than date, in RFC-3339 format (default: {{.dateLimit.Format .dateFormat}})
`[1:]))
var cleanCmd = command{
Name: "clean",
Summary: "clean log cache",
run: runClean,
}
const defaultCleanDaysLimit = 30
var (
cleanDateLimit = time.Now().UTC().AddDate(0, 0, -defaultCleanDaysLimit)
cleanAll bool
)
func showCleanUsage() {
err := cleanUsageTmpl.Execute(os.Stdout, map[string]any{
"progname": progname,
"daysLimit": defaultCleanDaysLimit,
"dateLimit": cleanDateLimit,
"dateFormat": dateFormat,
})
if err != nil {
panic(fmt.Sprintf("error executing template %s: %v", cleanUsageTmpl.Name(), err))
}
}
func runClean(args []string) int {
opts, err := getopt.NewArgv("hxD:A:", args)
if err != nil {
panic(fmt.Sprintf("error creating options parser: %s", err))
}
for opts.Scan() {
opt, err := opts.Option()
if err != nil {
errExit(err.Error())
}
switch opt.Opt {
case 'h':
showCleanUsage()
os.Exit(0)
case 'x':
cleanAll = true
case 'D':
v, err := opt.Int()
if err != nil {
errExit("-D: %s", err)
}
cleanDateLimit = time.Now().UTC().AddDate(0, 0, -v)
case 'A':
t, err := parseDateTime(opt.String())
if err != nil {
errExit("-A: %s", err)
}
cleanDateLimit = t
default:
panic("unhandled option: -" + string(opt.Opt))
}
}
c, err := cache.NewDefaultDirectory(progname)
if err != nil {
errExit("error initializing cache: %s", err)
}
if cleanAll {
fmt.Printf("Removing %s\n", c.Path())
if err := c.Remove(); err != nil {
errExit("error removing cache: %s", err)
}
return 0
}
w := c.Walker(nil)
err = w.Walk(func(entry cache.Entry, err error) error {
if err != nil {
return err
}
inf := entry.Info()
if inf.Timestamp.Before(cleanDateLimit) {
fmt.Printf("Removing %s\n", entry)
entry.Remove()
}
return nil
})
if err != nil {
errExit("error: %s", err)
}
return 0
}