b7ca2289e0
* improve setup wizard * added access grant file support * improved consistency across commands * a couple bug fixes * added access import and export Change-Id: I30ad9d4771f15430904a503a4d465bc40be471b5
62 lines
1.3 KiB
Go
62 lines
1.3 KiB
Go
// Copyright (C) 2021 Storj Labs, Inc.
|
|
// See LICENSE for copying information.
|
|
|
|
package main
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/zeebo/clingy"
|
|
"github.com/zeebo/errs"
|
|
|
|
"storj.io/storj/cmd/uplinkng/ulext"
|
|
)
|
|
|
|
type cmdAccessRestrict struct {
|
|
ex ulext.External
|
|
am accessMaker
|
|
|
|
access string
|
|
importAs string
|
|
exportTo string
|
|
}
|
|
|
|
func newCmdAccessRestrict(ex ulext.External) *cmdAccessRestrict {
|
|
return &cmdAccessRestrict{ex: ex}
|
|
}
|
|
|
|
func (c *cmdAccessRestrict) Setup(params clingy.Parameters) {
|
|
c.access = params.Flag("access", "Access name or value to restrict", "").(string)
|
|
c.importAs = params.Flag("import-as", "Import the access as this name", "").(string)
|
|
c.exportTo = params.Flag("export-to", "Export the access to this file path", "").(string)
|
|
|
|
params.Break()
|
|
c.am.Setup(params, c.ex)
|
|
params.Break()
|
|
c.am.perms.Setup(params, true)
|
|
}
|
|
|
|
func (c *cmdAccessRestrict) Execute(ctx clingy.Context) error {
|
|
access, err := c.ex.OpenAccess(c.access)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
access, err = c.am.Execute(ctx, c.importAs, access)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if c.exportTo != "" {
|
|
return c.ex.ExportAccess(ctx, access, c.exportTo)
|
|
}
|
|
|
|
serialized, err := access.Serialize()
|
|
if err != nil {
|
|
return errs.Wrap(err)
|
|
}
|
|
|
|
fmt.Fprintln(ctx, serialized)
|
|
return nil
|
|
}
|