tasks.go 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. package node
  2. import (
  3. "golang.org/x/net/context"
  4. "github.com/docker/docker/api/client"
  5. "github.com/docker/docker/api/client/idresolver"
  6. "github.com/docker/docker/api/client/task"
  7. "github.com/docker/docker/cli"
  8. "github.com/docker/docker/opts"
  9. "github.com/docker/engine-api/types"
  10. "github.com/docker/engine-api/types/swarm"
  11. "github.com/spf13/cobra"
  12. )
  13. type tasksOptions struct {
  14. nodeID string
  15. all bool
  16. noResolve bool
  17. filter opts.FilterOpt
  18. }
  19. func newTasksCommand(dockerCli *client.DockerCli) *cobra.Command {
  20. opts := tasksOptions{filter: opts.NewFilterOpt()}
  21. cmd := &cobra.Command{
  22. Use: "tasks [OPTIONS] self|NODE",
  23. Short: "List tasks running on a node",
  24. Args: cli.ExactArgs(1),
  25. RunE: func(cmd *cobra.Command, args []string) error {
  26. opts.nodeID = args[0]
  27. return runTasks(dockerCli, opts)
  28. },
  29. }
  30. flags := cmd.Flags()
  31. flags.BoolVarP(&opts.all, "all", "a", false, "Display all instances")
  32. flags.BoolVarP(&opts.noResolve, "no-resolve", "n", false, "Do not map IDs to Names")
  33. flags.VarP(&opts.filter, "filter", "f", "Filter output based on conditions provided")
  34. return cmd
  35. }
  36. func runTasks(dockerCli *client.DockerCli, opts tasksOptions) error {
  37. client := dockerCli.Client()
  38. ctx := context.Background()
  39. nodeRef, err := Reference(client, ctx, opts.nodeID)
  40. if err != nil {
  41. return nil
  42. }
  43. node, _, err := client.NodeInspectWithRaw(ctx, nodeRef)
  44. if err != nil {
  45. return err
  46. }
  47. filter := opts.filter.Value()
  48. filter.Add("node", node.ID)
  49. if !opts.all && !filter.Include("desired-state") {
  50. filter.Add("desired-state", string(swarm.TaskStateRunning))
  51. filter.Add("desired-state", string(swarm.TaskStateAccepted))
  52. }
  53. tasks, err := client.TaskList(
  54. ctx,
  55. types.TaskListOptions{Filter: filter})
  56. if err != nil {
  57. return err
  58. }
  59. return task.Print(dockerCli, ctx, tasks, idresolver.New(client, opts.noResolve))
  60. }