mirror of
https://github.com/kopia/kopia.git
synced 2026-01-17 02:48:00 -05:00
Reader methods go to repo.Reader and write methods go to repo.Writer Switched usage to new interfaces based on linter errors.
43 lines
1.1 KiB
Go
43 lines
1.1 KiB
Go
package cli
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
"github.com/kopia/kopia/repo"
|
|
"github.com/kopia/kopia/snapshot/policy"
|
|
)
|
|
|
|
var (
|
|
policyRemoveCommand = policyCommands.Command("remove", "Remove snapshot policy for a single directory, user@host or a global policy.").Alias("rm").Alias("delete")
|
|
policyRemoveTargets = policyRemoveCommand.Arg("target", "Target of a policy ('global','user@host','@host') or a path").Strings()
|
|
policyRemoveGlobal = policyRemoveCommand.Flag("global", "Set global policy").Bool()
|
|
policyRemoveDryRun = policyRemoveCommand.Flag("dry-run", "Do not remove").Short('n').Bool()
|
|
)
|
|
|
|
func init() {
|
|
policyRemoveCommand.Action(repositoryWriterAction(removePolicy))
|
|
}
|
|
|
|
func removePolicy(ctx context.Context, rep repo.Writer) error {
|
|
targets, err := policyTargets(ctx, rep, policyRemoveGlobal, policyRemoveTargets)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
for _, target := range targets {
|
|
log(ctx).Infof("Removing policy on %q...", target)
|
|
|
|
if *policyRemoveDryRun {
|
|
continue
|
|
}
|
|
|
|
if err := policy.RemovePolicy(ctx, rep, target); err != nil {
|
|
return errors.Wrapf(err, "error removing policy on %v", target)
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|