Files
kubevela/pkg/commands/traits.go
roywang a961b002c2 faster refresh capabilities
Signed-off-by: roywang <seiwy2010@gmail.com>
2020-12-09 23:51:04 +09:00

62 lines
1.8 KiB
Go

package commands
import (
"context"
"strings"
"github.com/spf13/cobra"
"github.com/oam-dev/kubevela/apis/types"
cmdutil "github.com/oam-dev/kubevela/pkg/commands/util"
"github.com/oam-dev/kubevela/pkg/serverlib"
)
// NewTraitsCommand creates `traits` command
func NewTraitsCommand(c types.Args, ioStreams cmdutil.IOStreams) *cobra.Command {
var workloadName string
var syncCluster, enforceRefresh bool
ctx := context.Background()
cmd := &cobra.Command{
Use: "traits [--apply-to WORKLOAD_NAME]",
DisableFlagsInUseLine: true,
Short: "List traits",
Long: "List traits",
Example: `vela traits`,
PersistentPreRunE: func(cmd *cobra.Command, args []string) error {
return c.SetConfig()
},
RunE: func(cmd *cobra.Command, args []string) error {
if syncCluster {
if err := RefreshDefinitions(ctx, c, ioStreams, true, enforceRefresh); err != nil {
return err
}
}
return printTraitList(&workloadName, ioStreams)
},
Annotations: map[string]string{
types.TagCommandType: types.TypeCap,
},
}
cmd.SetOut(ioStreams.Out)
cmd.Flags().StringVar(&workloadName, "apply-to", "", "Workload name")
cmd.Flags().BoolVarP(&syncCluster, "sync", "s", true, "Synchronize capabilities from cluster into local")
cmd.Flags().BoolVarP(&enforceRefresh, "", "r", false, "Enforce refresh from cluster even if cache is not expired")
return cmd
}
func printTraitList(workloadName *string, ioStreams cmdutil.IOStreams) error {
table := newUITable()
table.Wrap = true
traitDefinitionList, err := serverlib.ListTraitDefinitions(workloadName)
if err != nil {
return err
}
table.AddRow("NAME", "DESCRIPTION", "APPLIES TO")
for _, t := range traitDefinitionList {
table.AddRow(t.Name, t.Description, strings.Join(t.AppliesTo, "\n"))
}
ioStreams.Info(table.String())
return nil
}