Add Folder Json Output

This commit is contained in:
Samuel Lorch 2022-12-30 16:08:29 +01:00
parent c8dc067697
commit e8bb791686
3 changed files with 76 additions and 31 deletions

View file

@ -2,11 +2,11 @@ package folder
import ( import (
"context" "context"
"encoding/json"
"fmt" "fmt"
"github.com/alessio/shellescape" "github.com/alessio/shellescape"
"github.com/passbolt/go-passbolt-cli/util" "github.com/passbolt/go-passbolt-cli/util"
"github.com/passbolt/go-passbolt/helper"
"github.com/spf13/cobra" "github.com/spf13/cobra"
) )
@ -29,6 +29,10 @@ func FolderGet(cmd *cobra.Command, args []string) error {
if err != nil { if err != nil {
return err return err
} }
jsonOutput, err := cmd.Flags().GetBool("json")
if err != nil {
return err
}
ctx := util.GetContext() ctx := util.GetContext()
@ -39,15 +43,22 @@ func FolderGet(cmd *cobra.Command, args []string) error {
defer client.Logout(context.TODO()) defer client.Logout(context.TODO())
cmd.SilenceUsage = true cmd.SilenceUsage = true
folderParentID, name, err := helper.GetFolder( folder, err := client.GetFolder(ctx, id, nil)
ctx,
client,
id,
)
if err != nil { if err != nil {
return fmt.Errorf("Getting Folder: %w", err) return fmt.Errorf("Getting Folder: %w", err)
} }
fmt.Printf("FolderParentID: %v\n", folderParentID) if jsonOutput {
fmt.Printf("Name: %v\n", shellescape.StripUnsafe(name)) jsonGroup, err := json.MarshalIndent(FolderJsonOutput{
FolderParentID: &folder.FolderParentID,
Name: &folder.Name,
}, "", " ")
if err != nil {
return err
}
fmt.Println(string(jsonGroup))
} else {
fmt.Printf("FolderParentID: %v\n", folder.FolderParentID)
fmt.Printf("Name: %v\n", shellescape.StripUnsafe(folder.Name))
}
return nil return nil
} }

11
folder/json.go Normal file
View file

@ -0,0 +1,11 @@
package folder
import "time"
type FolderJsonOutput struct {
ID *string `json:"id,omitempty"`
FolderParentID *string `json:"folder_parent_id,omitempty"`
Name *string `json:"name,omitempty"`
CreatedTimestamp *time.Time `json:"created_timestamp,omitempty"`
ModifiedTimestamp *time.Time `json:"modified_timestamp,omitempty"`
}

View file

@ -2,6 +2,7 @@ package folder
import ( import (
"context" "context"
"encoding/json"
"fmt" "fmt"
"strings" "strings"
"time" "time"
@ -46,6 +47,10 @@ func FolderList(cmd *cobra.Command, args []string) error {
if len(columns) == 0 { if len(columns) == 0 {
return fmt.Errorf("You need to Specify atleast one column to return") return fmt.Errorf("You need to Specify atleast one column to return")
} }
jsonOutput, err := cmd.Flags().GetBool("json")
if err != nil {
return err
}
ctx := util.GetContext() ctx := util.GetContext()
cmd.SilenceUsage = true cmd.SilenceUsage = true
@ -64,30 +69,48 @@ func FolderList(cmd *cobra.Command, args []string) error {
return fmt.Errorf("Listing Folder: %w", err) return fmt.Errorf("Listing Folder: %w", err)
} }
data := pterm.TableData{columns} if jsonOutput {
outputFolders := []FolderJsonOutput{}
for _, folder := range folders { for i := range folders {
entry := make([]string, len(columns)) outputFolders = append(outputFolders, FolderJsonOutput{
for i := range columns { ID: &folders[i].ID,
switch strings.ToLower(columns[i]) { FolderParentID: &folders[i].FolderParentID,
case "id": Name: &folders[i].Name,
entry[i] = folder.ID CreatedTimestamp: &folders[i].Created.Time,
case "folderparentid": ModifiedTimestamp: &folders[i].Modified.Time,
entry[i] = folder.FolderParentID })
case "name":
entry[i] = shellescape.StripUnsafe(folder.Name)
case "createdtimestamp":
entry[i] = folder.Created.Format(time.RFC3339)
case "modifiedtimestamp":
entry[i] = folder.Modified.Format(time.RFC3339)
default:
cmd.SilenceUsage = false
return fmt.Errorf("Unknown Column: %v", columns[i])
}
} }
data = append(data, entry) jsonFolders, err := json.MarshalIndent(outputFolders, "", " ")
} if err != nil {
return err
}
fmt.Println(string(jsonFolders))
} else {
data := pterm.TableData{columns}
pterm.DefaultTable.WithHasHeader().WithData(data).Render() for _, folder := range folders {
entry := make([]string, len(columns))
for i := range columns {
switch strings.ToLower(columns[i]) {
case "id":
entry[i] = folder.ID
case "folderparentid":
entry[i] = folder.FolderParentID
case "name":
entry[i] = shellescape.StripUnsafe(folder.Name)
case "createdtimestamp":
entry[i] = folder.Created.Format(time.RFC3339)
case "modifiedtimestamp":
entry[i] = folder.Modified.Format(time.RFC3339)
default:
cmd.SilenceUsage = false
return fmt.Errorf("Unknown Column: %v", columns[i])
}
}
data = append(data, entry)
}
pterm.DefaultTable.WithHasHeader().WithData(data).Render()
}
return nil return nil
} }