storj/cmd/uplinkng/cmd_rb.go
Jeff Wendling 9615bd191f cmd/uplinkng: update clingy for better boolean support
this allows commands like

    uplinkng cp -r sj://foo sj://bar

to work correctly, rather than complain that sj://foo is
not a boolean.

Change-Id: I003e47aabb85566bc2b454851cf55043b17ee7ea
2021-12-14 09:41:38 +00:00

68 lines
1.4 KiB
Go

// Copyright (C) 2021 Storj Labs, Inc.
// See LICENSE for copying information.
package main
import (
"fmt"
"strconv"
"github.com/zeebo/clingy"
"github.com/zeebo/errs"
"storj.io/storj/cmd/uplinkng/ulext"
"storj.io/storj/cmd/uplinkng/ulloc"
)
type cmdRb struct {
ex ulext.External
access string
force bool
loc ulloc.Location
}
func newCmdRb(ex ulext.External) *cmdRb {
return &cmdRb{ex: ex}
}
func (c *cmdRb) Setup(params clingy.Parameters) {
c.access = params.Flag("access", "Access name or value to use", "").(string)
c.force = params.Flag("force", "Deletes any objects in bucket first", false,
clingy.Transform(strconv.ParseBool), clingy.Boolean,
).(bool)
c.loc = params.Arg("name", "Bucket name (sj://BUCKET)",
clingy.Transform(ulloc.Parse),
).(ulloc.Location)
}
func (c *cmdRb) Execute(ctx clingy.Context) error {
project, err := c.ex.OpenProject(ctx, c.access)
if err != nil {
return err
}
defer func() { _ = project.Close() }()
bucket, key, ok := c.loc.RemoteParts()
if !ok {
return errs.New("location must be remote")
}
if key != "" {
return errs.New("key must not be specified: %q", key)
}
if c.force {
_, err = project.DeleteBucketWithObjects(ctx, bucket)
} else {
_, err = project.DeleteBucket(ctx, bucket)
}
if err != nil {
return err
}
fmt.Fprintf(ctx.Stdout(), "Bucket %q has been deleted.\n", bucket)
return nil
}