forked from gopasspw/gopass
/
audit.go
47 lines (39 loc) · 1.14 KB
/
audit.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
package action
import (
"github.com/kpitt/gopass/internal/action/exit"
"github.com/kpitt/gopass/internal/audit"
"github.com/kpitt/gopass/internal/out"
"github.com/kpitt/gopass/internal/tree"
"github.com/kpitt/gopass/pkg/ctxutil"
"github.com/kpitt/gopass/pkg/debug"
"github.com/urfave/cli/v2"
)
// Audit validates passwords against common flaws.
func (s *Action) Audit(c *cli.Context) error {
ctx := ctxutil.WithGlobalFlags(c)
expiry := c.Int("expiry")
if expiry > 0 {
out.Print(ctx, "Auditing password expiration ...")
} else {
_ = s.rem.Reset("audit")
out.Print(ctx, "Auditing passwords for common flaws ...")
}
t, err := s.Store.Tree(ctx)
if err != nil {
return exit.Error(exit.List, err, "failed to get store tree: %s", err)
}
if filter := c.Args().First(); filter != "" {
subtree, err := t.FindFolder(filter)
if err != nil {
return exit.Error(exit.Unknown, err, "failed to find subtree: %s", err)
}
debug.Log("subtree for %q: %+v", filter, subtree)
t = subtree
}
list := t.List(tree.INF)
if len(list) < 1 {
out.Printf(ctx, "No secrets found")
return nil
}
return audit.Batch(ctx, list, s.Store, expiry)
}