tasks.go 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. package cluster
  2. import (
  3. apitypes "github.com/docker/docker/api/types"
  4. "github.com/docker/docker/api/types/filters"
  5. types "github.com/docker/docker/api/types/swarm"
  6. "github.com/docker/docker/daemon/cluster/convert"
  7. swarmapi "github.com/docker/swarmkit/api"
  8. "golang.org/x/net/context"
  9. )
  10. // GetTasks returns a list of tasks matching the filter options.
  11. func (c *Cluster) GetTasks(options apitypes.TaskListOptions) ([]types.Task, error) {
  12. var r *swarmapi.ListTasksResponse
  13. if err := c.lockedManagerAction(func(ctx context.Context, state nodeState) error {
  14. filterTransform := func(filter filters.Args) error {
  15. if filter.Contains("service") {
  16. serviceFilters := filter.Get("service")
  17. for _, serviceFilter := range serviceFilters {
  18. service, err := getService(ctx, state.controlClient, serviceFilter, false)
  19. if err != nil {
  20. return err
  21. }
  22. filter.Del("service", serviceFilter)
  23. filter.Add("service", service.ID)
  24. }
  25. }
  26. if filter.Contains("node") {
  27. nodeFilters := filter.Get("node")
  28. for _, nodeFilter := range nodeFilters {
  29. node, err := getNode(ctx, state.controlClient, nodeFilter)
  30. if err != nil {
  31. return err
  32. }
  33. filter.Del("node", nodeFilter)
  34. filter.Add("node", node.ID)
  35. }
  36. }
  37. if !filter.Contains("runtime") {
  38. // default to only showing container tasks
  39. filter.Add("runtime", "container")
  40. filter.Add("runtime", "")
  41. }
  42. return nil
  43. }
  44. filters, err := newListTasksFilters(options.Filters, filterTransform)
  45. if err != nil {
  46. return err
  47. }
  48. r, err = state.controlClient.ListTasks(
  49. ctx,
  50. &swarmapi.ListTasksRequest{Filters: filters})
  51. return err
  52. }); err != nil {
  53. return nil, err
  54. }
  55. tasks := make([]types.Task, 0, len(r.Tasks))
  56. for _, task := range r.Tasks {
  57. t, err := convert.TaskFromGRPC(*task)
  58. if err != nil {
  59. return nil, err
  60. }
  61. tasks = append(tasks, t)
  62. }
  63. return tasks, nil
  64. }
  65. // GetTask returns a task by an ID.
  66. func (c *Cluster) GetTask(input string) (types.Task, error) {
  67. var task *swarmapi.Task
  68. if err := c.lockedManagerAction(func(ctx context.Context, state nodeState) error {
  69. t, err := getTask(ctx, state.controlClient, input)
  70. if err != nil {
  71. return err
  72. }
  73. task = t
  74. return nil
  75. }); err != nil {
  76. return types.Task{}, err
  77. }
  78. return convert.TaskFromGRPC(*task)
  79. }