Skip to content

Commit

Permalink
Re-introduce variadic parameters to table API (#2022)
Browse files Browse the repository at this point in the history
* Reapply "Use variadic parameters for the table interface (#2008)" (#2010)

This reverts commit d2d8c19.

* Introduce struct to handle colored columns

This makes adding colored columns a little more ergonomic
  • Loading branch information
JAORMX authored Dec 22, 2023
1 parent 3ea876e commit dcba43a
Show file tree
Hide file tree
Showing 13 changed files with 184 additions and 140 deletions.
8 changes: 4 additions & 4 deletions cmd/cli/app/artifact/artifact_get.go
Original file line number Diff line number Diff line change
Expand Up @@ -73,27 +73,27 @@ func getCommand(ctx context.Context, cmd *cobra.Command, conn *grpc.ClientConn)
case app.Table:
ta := table.New(table.Simple, layouts.Default,
[]string{"ID", "Type", "Owner", "Name", "Repository", "Visibility", "Creation date"})
ta.AddRow([]string{
ta.AddRow(
art.ArtifactPk,
art.Type,
art.GetOwner(),
art.GetName(),
art.Repository,
art.Visibility,
art.CreatedAt.AsTime().Format(time.RFC3339),
})
)
ta.Render()

tv := table.New(table.Simple, layouts.Default,
[]string{"ID", "Tags", "Signature", "Identity", "Creation date"})
for _, version := range versions {
tv.AddRow([]string{
tv.AddRow(
fmt.Sprintf("%d", version.VersionId),
strings.Join(version.Tags, ","),
getSignatureStatusText(version.SignatureVerification),
version.GetSignatureVerification().GetCertIdentity(),
version.CreatedAt.AsTime().Format(time.RFC3339),
})
)
}
tv.Render()
case app.JSON:
Expand Down
4 changes: 2 additions & 2 deletions cmd/cli/app/artifact/artifact_list.go
Original file line number Diff line number Diff line change
Expand Up @@ -77,15 +77,15 @@ func listCommand(ctx context.Context, cmd *cobra.Command, conn *grpc.ClientConn)
t := table.New(table.Simple, layouts.Default,
[]string{"ID", "Type", "Owner", "Name", "Repository", "Visibility", "Creation date"})
for _, artifact := range artifactList.Results {
t.AddRow([]string{
t.AddRow(
artifact.ArtifactPk,
artifact.Type,
artifact.GetOwner(),
artifact.GetName(),
artifact.Repository,
artifact.Visibility,
artifact.CreatedAt.AsTime().Format(time.RFC3339),
})
)

}
t.Render()
Expand Down
20 changes: 10 additions & 10 deletions cmd/cli/app/auth/common.go
Original file line number Diff line number Diff line change
Expand Up @@ -41,29 +41,29 @@ func userRegistered(ctx context.Context, client minderv1.UserServiceClient) (boo

func renderNewUser(conn string, newUser *minderv1.CreateUserResponse) {
t := table.New(table.Simple, layouts.KeyValue, nil)
t.AddRow([]string{"Project ID", newUser.ProjectId})
t.AddRow([]string{"Project Name", newUser.ProjectName})
t.AddRow([]string{"Minder Server", conn})
t.AddRow("Project ID", newUser.ProjectId)
t.AddRow("Project Name", newUser.ProjectName)
t.AddRow("Minder Server", conn)
t.Render()
}

func renderUserInfo(conn string, user *minderv1.GetUserResponse) {
t := table.New(table.Simple, layouts.KeyValue, nil)
t.AddRow([]string{"Minder Server", conn})
t.AddRow("Minder Server", conn)
for _, project := range getProjectTableRows(user.Projects) {
t.AddRow(project)
t.AddRow(project...)
}
t.Render()
}

func renderUserInfoWhoami(conn string, user *minderv1.GetUserResponse) {
t := table.New(table.Simple, layouts.KeyValue, nil)
t.AddRow([]string{"Subject", user.GetUser().GetIdentitySubject()})
t.AddRow([]string{"Created At", user.GetUser().GetCreatedAt().AsTime().String()})
t.AddRow([]string{"Updated At", user.GetUser().GetUpdatedAt().AsTime().String()})
t.AddRow([]string{"Minder Server", conn})
t.AddRow("Subject", user.GetUser().GetIdentitySubject())
t.AddRow("Created At", user.GetUser().GetCreatedAt().AsTime().String())
t.AddRow("Updated At", user.GetUser().GetUpdatedAt().AsTime().String())
t.AddRow("Minder Server", conn)
for _, project := range getProjectTableRows(user.Projects) {
t.AddRow(project)
t.AddRow(project...)
}
t.Render()
}
Expand Down
86 changes: 35 additions & 51 deletions cmd/cli/app/profile/table_render.go
Original file line number Diff line number Diff line change
Expand Up @@ -60,11 +60,11 @@ func NewProfileSettingsTable() table.Table {

// RenderProfileSettingsTable renders the profile settings table
func RenderProfileSettingsTable(p *minderv1.Profile, t table.Table) {
t.AddRow([]string{"ID", p.GetId()})
t.AddRow([]string{"Name", p.GetName()})
t.AddRow([]string{"Provider", p.GetContext().GetProvider()})
t.AddRow([]string{"Alert", p.GetAlert()})
t.AddRow([]string{"Remediate", p.GetRemediate()})
t.AddRow("ID", p.GetId())
t.AddRow("Name", p.GetName())
t.AddRow("Provider", p.GetContext().GetProvider())
t.AddRow("Alert", p.GetAlert())
t.AddRow("Remediate", p.GetRemediate())
}

// NewProfileTable creates a new table for rendering profiles
Expand Down Expand Up @@ -99,13 +99,12 @@ func renderRuleTable(entType minderv1.EntityType, rule *minderv1.Profile_Rule, t
params := marshalStructOrEmpty(rule.Params)
def := marshalStructOrEmpty(rule.Def)

row := []string{
t.AddRow(
entType.String(),
rule.Type,
params,
def,
}
t.AddRow(row)
)
}

// NewProfileStatusTable creates a new table for rendering profile status
Expand All @@ -115,33 +114,28 @@ func NewProfileStatusTable() table.Table {

// RenderProfileStatusTable renders the profile status table
func RenderProfileStatusTable(ps *minderv1.ProfileStatus, t table.Table) {
row := []string{
ps.ProfileId,
ps.ProfileName,
getEvalStatusText(ps.ProfileStatus),
ps.LastUpdated.AsTime().Format(time.RFC3339),
}
t.AddRowWithColor(row, []string{
"",
"",
getEvalStatusColor(ps.ProfileStatus),
"",
})
t.AddRowWithColor(
layouts.NoColor(ps.ProfileId),
layouts.NoColor(ps.ProfileName),
getColoredEvalStatus(ps.ProfileStatus),
layouts.NoColor(ps.LastUpdated.AsTime().Format(time.RFC3339)),
)
}

func getEvalStatusColor(status string) string {
func getColoredEvalStatus(status string) layouts.ColoredColumn {
txt := getEvalStatusText(status)
// eval statuses can be 'success', 'failure', 'error', 'skipped', 'pending'
switch strings.ToLower(status) {
case successStatus:
return table.ColorGreen
return layouts.GreenColumn(txt)
case failureStatus:
return table.ColorRed
return layouts.RedColumn(txt)
case errorStatus:
return table.ColorRed
return layouts.RedColumn(txt)
case skippedStatus:
return table.ColorYellow
return layouts.YellowColumn(txt)
default:
return ""
return layouts.NoColor(txt)
}
}

Expand All @@ -156,42 +150,32 @@ func RenderRuleEvaluationStatusTable(
t table.Table,
) {
for _, eval := range statuses {
row := []string{
eval.RuleId,
eval.RuleName,
eval.Entity,
getEvalStatusText(eval.Status),
getRemediationStatusText(eval.RemediationStatus),
mapToYAMLOrEmpty(eval.EntityInfo),
guidanceOrEncouragement(eval.Status, eval.Guidance),
}

t.AddRowWithColor(row, []string{
"",
"",
"",
"",
getEvalStatusColor(eval.Status),
t.AddRowWithColor(
layouts.NoColor(eval.RuleId),
layouts.NoColor(eval.RuleName),
layouts.NoColor(eval.Entity),
getColoredEvalStatus(eval.Status),
getRemediateStatusColor(eval.RemediationStatus),
"",
"",
})
layouts.NoColor(mapToYAMLOrEmpty(eval.EntityInfo)),
layouts.NoColor(guidanceOrEncouragement(eval.Status, eval.Guidance)),
)
}
}

func getRemediateStatusColor(status string) string {
func getRemediateStatusColor(status string) layouts.ColoredColumn {
txt := getRemediationStatusText(status)
// remediation statuses can be 'success', 'failure', 'error', 'skipped', 'not supported'
switch strings.ToLower(status) {
case successStatus:
return table.ColorGreen
return layouts.GreenColumn(txt)
case failureStatus:
return table.ColorRed
return layouts.RedColumn(txt)
case errorStatus:
return table.ColorRed
return layouts.RedColumn(txt)
case notAvailableStatus:
return table.ColorYellow
return layouts.YellowColumn(txt)
default:
return ""
return layouts.NoColor(txt)
}
}

Expand Down
4 changes: 2 additions & 2 deletions cmd/cli/app/repo/repo_list.go
Original file line number Diff line number Diff line change
Expand Up @@ -71,14 +71,14 @@ func listCommand(ctx context.Context, cmd *cobra.Command, conn *grpc.ClientConn)
case app.Table:
t := table.New(table.Simple, layouts.RepoList, nil)
for _, v := range resp.Results {
t.AddRow([]string{
t.AddRow(
*v.Id,
*v.Context.Project,
*v.Context.Provider,
fmt.Sprintf("%d", v.GetRepoId()),
v.GetOwner(),
v.GetName(),
})
)
}
t.Render()
case app.JSON:
Expand Down
2 changes: 1 addition & 1 deletion cmd/cli/app/repo/repo_register.go
Original file line number Diff line number Diff line change
Expand Up @@ -143,7 +143,7 @@ func RegisterCmd(ctx context.Context, cmd *cobra.Command, conn *grpc.ClientConn)
} else {
row = append(row, "")
}
t.AddRow(row)
t.AddRow(row...)
}
t.Render()
return nil
Expand Down
4 changes: 2 additions & 2 deletions cmd/cli/app/ruletype/common.go
Original file line number Diff line number Diff line change
Expand Up @@ -60,13 +60,13 @@ func execOnOneRuleType(
}

// add the rule type to the table rows
t.AddRow([]string{
t.AddRow(
*rt.Context.Provider,
*rt.Context.Project,
*rt.Id,
rt.Name,
rt.Description,
})
)
return nil
}

Expand Down
4 changes: 2 additions & 2 deletions cmd/cli/app/ruletype/ruletype_get.go
Original file line number Diff line number Diff line change
Expand Up @@ -83,13 +83,13 @@ func getCommand(ctx context.Context, cmd *cobra.Command, conn *grpc.ClientConn)
table := initializeTable()
rt := rtype.GetRuleType()
// add the rule type to the table rows
table.AddRow([]string{
table.AddRow(
*rt.Context.Provider,
*rt.Context.Project,
*rt.Id,
rt.Name,
rt.Description,
})
)
table.Render()
}
return nil
Expand Down
4 changes: 2 additions & 2 deletions cmd/cli/app/ruletype/ruletype_list.go
Original file line number Diff line number Diff line change
Expand Up @@ -78,13 +78,13 @@ func listCommand(ctx context.Context, cmd *cobra.Command, conn *grpc.ClientConn)
case app.Table:
table := initializeTable()
for _, rt := range resp.RuleTypes {
table.AddRow([]string{
table.AddRow(
*rt.Context.Provider,
*rt.Context.Project,
*rt.Id,
rt.Name,
rt.Description,
})
)
}
table.Render()
}
Expand Down
38 changes: 0 additions & 38 deletions internal/util/cli/table/layouts/constants.go

This file was deleted.

Loading

0 comments on commit dcba43a

Please sign in to comment.