Files
kopia/cli/command_acl_enable.go
Julio López 961a39039b refactor(general): use errors.New where appropriate (#4160)
Replaces 'errors.Errorf\("([^"]+)"\)' => 'errors.New("\1")'
2024-10-05 19:05:00 -07:00

51 lines
1.2 KiB
Go

package cli
import (
"context"
"github.com/pkg/errors"
"github.com/kopia/kopia/internal/acl"
"github.com/kopia/kopia/internal/auth"
"github.com/kopia/kopia/repo"
)
type commandACLEnable struct {
reset bool
}
func (c *commandACLEnable) setup(svc appServices, parent commandParent) {
cmd := parent.Command("enable", "Enable ACLs and install default entries")
cmd.Flag("reset", "Reset all ACLs to default").BoolVar(&c.reset)
cmd.Action(svc.repositoryWriterAction(c.run))
}
func (c *commandACLEnable) run(ctx context.Context, rep repo.RepositoryWriter) error {
entries, err := acl.LoadEntries(ctx, rep, nil)
if err != nil {
return errors.Wrap(err, "error loading ACL entries")
}
if len(entries) != 0 && !c.reset {
return errors.New("ACLs already enabled")
}
if c.reset {
for _, e := range entries {
log(ctx).Infof("deleting previous ACL entry %v", e.ManifestID)
if err := rep.DeleteManifest(ctx, e.ManifestID); err != nil {
return errors.Wrap(err, "unable to delete previous ACL")
}
}
}
for _, e := range auth.DefaultACLs {
if err := acl.AddACL(ctx, rep, e, false); err != nil {
return errors.Wrap(err, "unable to add default ACL")
}
}
return nil
}