tasks.go 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  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. c.mu.RLock()
  13. defer c.mu.RUnlock()
  14. state := c.currentNodeState()
  15. if !state.IsActiveManager() {
  16. return nil, c.errNoManager(state)
  17. }
  18. filterTransform := func(filter filters.Args) error {
  19. if filter.Include("service") {
  20. serviceFilters := filter.Get("service")
  21. for _, serviceFilter := range serviceFilters {
  22. service, err := c.GetService(serviceFilter, false)
  23. if err != nil {
  24. return err
  25. }
  26. filter.Del("service", serviceFilter)
  27. filter.Add("service", service.ID)
  28. }
  29. }
  30. if filter.Include("node") {
  31. nodeFilters := filter.Get("node")
  32. for _, nodeFilter := range nodeFilters {
  33. node, err := c.GetNode(nodeFilter)
  34. if err != nil {
  35. return err
  36. }
  37. filter.Del("node", nodeFilter)
  38. filter.Add("node", node.ID)
  39. }
  40. }
  41. if !filter.Include("runtime") {
  42. // default to only showing container tasks
  43. filter.Add("runtime", "container")
  44. filter.Add("runtime", "")
  45. }
  46. return nil
  47. }
  48. filters, err := newListTasksFilters(options.Filters, filterTransform)
  49. if err != nil {
  50. return nil, err
  51. }
  52. ctx, cancel := c.getRequestContext()
  53. defer cancel()
  54. r, err := state.controlClient.ListTasks(
  55. ctx,
  56. &swarmapi.ListTasksRequest{Filters: filters})
  57. if err != nil {
  58. return nil, err
  59. }
  60. tasks := make([]types.Task, 0, len(r.Tasks))
  61. for _, task := range r.Tasks {
  62. t, err := convert.TaskFromGRPC(*task)
  63. if err != nil {
  64. return nil, err
  65. }
  66. tasks = append(tasks, t)
  67. }
  68. return tasks, nil
  69. }
  70. // GetTask returns a task by an ID.
  71. func (c *Cluster) GetTask(input string) (types.Task, error) {
  72. var task *swarmapi.Task
  73. if err := c.lockedManagerAction(func(ctx context.Context, state nodeState) error {
  74. t, err := getTask(ctx, state.controlClient, input)
  75. if err != nil {
  76. return err
  77. }
  78. task = t
  79. return nil
  80. }); err != nil {
  81. return types.Task{}, err
  82. }
  83. return convert.TaskFromGRPC(*task)
  84. }