From 30231ccc74a2eb03d93943a9a91e1bab4d3f17d5 Mon Sep 17 00:00:00 2001 From: Michael Mayer Date: Mon, 21 Dec 2020 14:05:02 +0100 Subject: [PATCH] Albums: Remove YAML backup files when running `photoprism reset` --- internal/commands/reset.go | 45 +++++++++++++++++++++++++++++++++----- internal/config/config.go | 2 +- 2 files changed, 41 insertions(+), 6 deletions(-) diff --git a/internal/commands/reset.go b/internal/commands/reset.go index dc92d4a64..fbe73ae4e 100644 --- a/internal/commands/reset.go +++ b/internal/commands/reset.go @@ -63,12 +63,12 @@ func resetAction(ctx *cli.Context) error { log.Infof("database reset completed in %s", time.Since(start)) - removeYaml := promptui.Prompt{ - Label: "Remove backup by permanently deleting all *.yml sidecar files?", + removeSidecarYaml := promptui.Prompt{ + Label: "Permanently delete all *.yml photo metadata backups?", IsConfirm: true, } - if _, err := removeYaml.Run(); err == nil { + if _, err := removeSidecarYaml.Run(); err == nil { start := time.Now() matches, err := filepath.Glob(regexp.QuoteMeta(conf.SidecarPath()) + "/**/*.yml") @@ -78,7 +78,7 @@ func resetAction(ctx *cli.Context) error { } if len(matches) > 0 { - log.Infof("%d backup files will be removed", len(matches)) + log.Infof("%d photo metadata backups will be removed", len(matches)) for _, name := range matches { if err := os.Remove(name); err != nil { @@ -90,7 +90,42 @@ func resetAction(ctx *cli.Context) error { fmt.Println("") - log.Infof("removed backup files in %s", time.Since(start)) + log.Infof("removed files in %s", time.Since(start)) + } else { + log.Infof("no backup files found") + } + } else { + log.Infof("keeping backup files") + } + + removeAlbumYaml := promptui.Prompt{ + Label: "Permanently delete all *.yml album backups?", + IsConfirm: true, + } + + if _, err := removeAlbumYaml.Run(); err == nil { + start := time.Now() + + matches, err := filepath.Glob(regexp.QuoteMeta(conf.AlbumsPath()) + "/**/*.yml") + + if err != nil { + return err + } + + if len(matches) > 0 { + log.Infof("%d album backups will be removed", len(matches)) + + for _, name := range matches { + if err := os.Remove(name); err != nil { + fmt.Print("E") + } else { + fmt.Print(".") + } + } + + fmt.Println("") + + log.Infof("removed files in %s", time.Since(start)) } else { log.Infof("no backup files found") } diff --git a/internal/config/config.go b/internal/config/config.go index b0cce0335..9737acaf0 100644 --- a/internal/config/config.go +++ b/internal/config/config.go @@ -82,7 +82,7 @@ func NewConfig(ctx *cli.Context) *Config { if err := c.options.Load(configFile); err != nil { log.Warnf("config: %s", err) } else { - log.Infof("config: loaded options from %s", txt.Quote(configFile)) + log.Debugf("config: loaded options from %s", txt.Quote(configFile)) } }