crowdsec/cmd/crowdsec-cli/cliitem/cmdremove.go
mmetc bfed861ba7
don't ask user to reload systemd service when running in docker (#3434)
* don't ask user to reload systemd service when running in docker

* refactor + give appropriate message if terminal is attached

* remove explicit filetype
2025-01-31 10:15:28 +00:00

151 lines
3.9 KiB
Go

package cliitem
import (
"cmp"
"context"
"errors"
"fmt"
log "github.com/sirupsen/logrus"
"github.com/spf13/cobra"
"github.com/crowdsecurity/crowdsec/cmd/crowdsec-cli/reload"
"github.com/crowdsecurity/crowdsec/cmd/crowdsec-cli/require"
"github.com/crowdsecurity/crowdsec/pkg/cwhub"
"github.com/crowdsecurity/crowdsec/pkg/hubops"
)
func (cli cliItem) removePlan(hub *cwhub.Hub, args []string, purge bool, force bool, all bool) (*hubops.ActionPlan, error) {
plan := hubops.NewActionPlan(hub)
if all {
itemGetter := hub.GetInstalledByType
if purge {
itemGetter = hub.GetItemsByType
}
for _, item := range itemGetter(cli.name, true) {
if err := plan.AddCommand(hubops.NewDisableCommand(item, force)); err != nil {
return nil, err
}
if purge {
if err := plan.AddCommand(hubops.NewPurgeCommand(item, force)); err != nil {
return nil, err
}
}
}
return plan, nil
}
if len(args) == 0 {
return nil, fmt.Errorf("specify at least one %s to remove or '--all'", cli.singular)
}
for _, itemName := range args {
item := hub.GetItem(cli.name, itemName)
if item == nil {
return nil, fmt.Errorf("can't find '%s' in %s", itemName, cli.name)
}
parents := installedParentNames(item)
if !force && len(parents) > 0 {
log.Warningf("%s belongs to collections: %s", item.Name, parents)
log.Warningf("Run 'sudo cscli %s remove %s --force' if you want to force remove this %s", item.Type, item.Name, cli.singular)
continue
}
if err := plan.AddCommand(hubops.NewDisableCommand(item, force)); err != nil {
return nil, err
}
if purge {
if err := plan.AddCommand(hubops.NewPurgeCommand(item, force)); err != nil {
return nil, err
}
}
}
return plan, nil
}
// return the names of the installed parents of an item, used to check if we can remove it
func installedParentNames(item *cwhub.Item) []string {
ret := make([]string, 0)
for _, parent := range item.Ancestors() {
if parent.State.Installed {
ret = append(ret, parent.Name)
}
}
return ret
}
func (cli cliItem) remove(ctx context.Context, args []string, yes bool, dryRun bool, purge bool, force bool, all bool) error {
cfg := cli.cfg()
hub, err := require.Hub(cli.cfg(), log.StandardLogger())
if err != nil {
return err
}
plan, err := cli.removePlan(hub, args, purge, force, all)
if err != nil {
return err
}
verbose := (cfg.Cscli.Output == "raw")
if err := plan.Execute(ctx, yes, dryRun, verbose); err != nil {
return err
}
if msg := reload.UserMessage(); msg != "" && plan.ReloadNeeded {
fmt.Println("\n" + msg)
}
return nil
}
func (cli cliItem) newRemoveCmd() *cobra.Command {
var (
yes bool
dryRun bool
purge bool
force bool
all bool
)
cmd := &cobra.Command{
Use: cmp.Or(cli.removeHelp.use, "remove [item]..."),
Short: cmp.Or(cli.removeHelp.short, "Remove given "+cli.oneOrMore),
Long: cmp.Or(cli.removeHelp.long, "Remove one or more "+cli.name),
Example: cli.removeHelp.example,
Aliases: []string{"delete"},
DisableAutoGenTag: true,
ValidArgsFunction: func(_ *cobra.Command, args []string, toComplete string) ([]string, cobra.ShellCompDirective) {
return compInstalledItems(cli.name, args, toComplete, cli.cfg)
},
RunE: func(cmd *cobra.Command, args []string) error {
if len(args) > 0 && all {
return errors.New("can't specify items and '--all' at the same time")
}
return cli.remove(cmd.Context(), args, yes, dryRun, purge, force, all)
},
}
flags := cmd.Flags()
flags.BoolVarP(&yes, "yes", "y", false, "Confirm execution without prompt")
flags.BoolVar(&dryRun, "dry-run", false, "Don't install or remove anything; print the execution plan")
flags.BoolVar(&purge, "purge", false, "Delete source file too")
flags.BoolVar(&force, "force", false, "Force remove: remove tainted and outdated files")
flags.BoolVar(&all, "all", false, "Remove all the "+cli.name)
cmd.MarkFlagsMutuallyExclusive("yes", "dry-run")
return cmd
}