mirror of
https://github.com/passbolt/go-passbolt-cli.git
synced 2025-09-13 14:59:09 +00:00
add group commands
This commit is contained in:
parent
1b129332ae
commit
36c8318db1
12 changed files with 398 additions and 0 deletions
87
group/get.go
Normal file
87
group/get.go
Normal file
|
@ -0,0 +1,87 @@
|
|||
package group
|
||||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
"strings"
|
||||
|
||||
"github.com/pterm/pterm"
|
||||
"github.com/speatzle/go-passbolt-cli/util"
|
||||
"github.com/speatzle/go-passbolt/helper"
|
||||
"github.com/spf13/cobra"
|
||||
)
|
||||
|
||||
// GroupGetCmd Gets a Passbolt Group
|
||||
var GroupGetCmd = &cobra.Command{
|
||||
Use: "group",
|
||||
Short: "Gets a Passbolt Group",
|
||||
Long: `Gets a Passbolt Group`,
|
||||
RunE: GroupGet,
|
||||
}
|
||||
|
||||
func init() {
|
||||
GroupGetCmd.Flags().String("id", "", "id of Group to Get")
|
||||
|
||||
GroupGetCmd.Flags().StringArrayP("columns", "c", []string{"UserID", "IsGroupManager"}, "Membership Columns to return, possible Columns:\nUserID, Username, UserFirstName, UserLastName, IsGroupManager")
|
||||
|
||||
GroupGetCmd.MarkFlagRequired("id")
|
||||
}
|
||||
|
||||
func GroupGet(cmd *cobra.Command, args []string) error {
|
||||
id, err := cmd.Flags().GetString("id")
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
columns, err := cmd.Flags().GetStringArray("columns")
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
ctx := util.GetContext()
|
||||
|
||||
client, err := util.GetClient(ctx)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
defer client.Logout(context.TODO())
|
||||
cmd.SilenceUsage = true
|
||||
|
||||
name, memberships, err := helper.GetGroup(
|
||||
ctx,
|
||||
client,
|
||||
id,
|
||||
)
|
||||
if err != nil {
|
||||
return fmt.Errorf("Getting Group: %w", err)
|
||||
}
|
||||
fmt.Printf("Name: %v\n", name)
|
||||
// Print Memberships
|
||||
if len(columns) != 0 {
|
||||
data := pterm.TableData{columns}
|
||||
|
||||
for _, membership := range memberships {
|
||||
entry := make([]string, len(columns))
|
||||
for i := range columns {
|
||||
switch strings.ToLower(columns[i]) {
|
||||
case "userid":
|
||||
entry[i] = membership.UserID
|
||||
case "isgroupmanager":
|
||||
entry[i] = fmt.Sprint(membership.IsGroupManager)
|
||||
case "username":
|
||||
entry[i] = fmt.Sprint(membership.Username)
|
||||
case "userfirstname":
|
||||
entry[i] = fmt.Sprint(membership.UserFirstName)
|
||||
case "userlastname":
|
||||
entry[i] = fmt.Sprint(membership.UserLastName)
|
||||
default:
|
||||
cmd.SilenceUsage = false
|
||||
return fmt.Errorf("Unknown Column: %v", columns[i])
|
||||
}
|
||||
}
|
||||
data = append(data, entry)
|
||||
}
|
||||
|
||||
pterm.DefaultTable.WithHasHeader().WithData(data).Render()
|
||||
}
|
||||
return nil
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue