github.com/kaisenlinux/docker.io@v0.0.0-20230510090727-ea55db55fac7/swarmkit/cmd/swarmctl/cluster/list.go (about) 1 package cluster 2 3 import ( 4 "errors" 5 "fmt" 6 "os" 7 "text/tabwriter" 8 9 "github.com/docker/swarmkit/api" 10 "github.com/docker/swarmkit/cmd/swarmctl/common" 11 "github.com/spf13/cobra" 12 ) 13 14 var ( 15 listCmd = &cobra.Command{ 16 Use: "ls", 17 Short: "List clusters", 18 RunE: func(cmd *cobra.Command, args []string) error { 19 if len(args) != 0 { 20 return errors.New("ls command takes no arguments") 21 } 22 23 flags := cmd.Flags() 24 25 quiet, err := flags.GetBool("quiet") 26 if err != nil { 27 return err 28 } 29 30 c, err := common.Dial(cmd) 31 if err != nil { 32 return err 33 } 34 r, err := c.ListClusters(common.Context(cmd), &api.ListClustersRequest{}) 35 if err != nil { 36 return err 37 } 38 39 var output func(j *api.Cluster) 40 41 if !quiet { 42 w := tabwriter.NewWriter(os.Stdout, 0, 4, 2, ' ', 0) 43 defer func() { 44 // Ignore flushing errors - there's nothing we can do. 45 _ = w.Flush() 46 }() 47 common.PrintHeader(w, "ID", "Name") 48 output = func(s *api.Cluster) { 49 spec := s.Spec 50 51 fmt.Fprintf(w, "%s\t%s\n", 52 s.ID, 53 spec.Annotations.Name, 54 ) 55 } 56 57 } else { 58 output = func(j *api.Cluster) { fmt.Println(j.ID) } 59 } 60 61 for _, j := range r.Clusters { 62 output(j) 63 } 64 return nil 65 }, 66 } 67 ) 68 69 func init() { 70 listCmd.Flags().BoolP("quiet", "q", false, "Only display IDs") 71 }