mirror of
https://github.com/crowdsecurity/crowdsec.git
synced 2025-05-11 04:15:54 +02:00
* command "cscli doc --target /path/to/dir" * typos and improved messages * CI: remove obsolete parameters for golangi-lint action * lint
73 lines
1.7 KiB
Go
73 lines
1.7 KiB
Go
package cwhub
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
)
|
|
|
|
// enable enables the item by creating a symlink to the downloaded content, and also enables sub-items.
|
|
func (i *Item) enable() error {
|
|
if i.State.Installed {
|
|
if i.State.Tainted {
|
|
return fmt.Errorf("%s is tainted, won't overwrite unless --force", i.Name)
|
|
}
|
|
|
|
if i.State.IsLocal() {
|
|
return fmt.Errorf("%s is local, won't overwrite", i.Name)
|
|
}
|
|
|
|
// if it's a collection, check sub-items even if the collection file itself is up-to-date
|
|
if i.State.UpToDate && !i.HasSubItems() {
|
|
i.hub.logger.Tracef("%s is installed and up-to-date, skip.", i.Name)
|
|
return nil
|
|
}
|
|
}
|
|
|
|
for _, sub := range i.SubItems() {
|
|
if err := sub.enable(); err != nil {
|
|
return fmt.Errorf("while installing %s: %w", sub.Name, err)
|
|
}
|
|
}
|
|
|
|
if err := i.createInstallLink(); err != nil {
|
|
return err
|
|
}
|
|
|
|
i.hub.logger.Infof("Enabled %s: %s", i.Type, i.Name)
|
|
i.State.Installed = true
|
|
|
|
return nil
|
|
}
|
|
|
|
// Install installs the item from the hub, downloading it if needed.
|
|
func (i *Item) Install(ctx context.Context, force bool, downloadOnly bool) error {
|
|
if downloadOnly && i.State.Downloaded && i.State.UpToDate {
|
|
i.hub.logger.Infof("%s is already downloaded and up-to-date", i.Name)
|
|
|
|
if !force {
|
|
return nil
|
|
}
|
|
}
|
|
|
|
downloaded, err := i.downloadLatest(ctx, force, true)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if downloadOnly && downloaded {
|
|
return nil
|
|
}
|
|
|
|
if err := i.enable(); err != nil {
|
|
return fmt.Errorf("while enabling %s: %w", i.Name, err)
|
|
}
|
|
|
|
// a check on stdout is used while scripting to know if the hub has been upgraded
|
|
// and a configuration reload is required
|
|
// TODO: use a better way to communicate this
|
|
fmt.Printf("installed %s\n", i.Name)
|
|
|
|
i.hub.logger.Infof("Enabled %s", i.Name)
|
|
|
|
return nil
|
|
}
|