2017-09-26 12:50:09 +00:00
|
|
|
package docker
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"io"
|
2017-10-19 12:40:05 +00:00
|
|
|
"math"
|
|
|
|
"sort"
|
2017-09-26 12:50:09 +00:00
|
|
|
|
2017-10-19 12:40:05 +00:00
|
|
|
"github.com/cuigh/auxo/util/choose"
|
|
|
|
"github.com/cuigh/swirl/misc"
|
2017-09-26 12:50:09 +00:00
|
|
|
"github.com/cuigh/swirl/model"
|
|
|
|
"github.com/docker/docker/api/types"
|
|
|
|
"github.com/docker/docker/api/types/filters"
|
|
|
|
"github.com/docker/docker/api/types/swarm"
|
|
|
|
"github.com/docker/docker/client"
|
|
|
|
)
|
|
|
|
|
|
|
|
// TaskList return all running tasks of a service or a node.
|
2017-10-19 12:40:05 +00:00
|
|
|
func TaskList(args *model.TaskListArgs) (infos []*model.TaskInfo, totalCount int, err error) {
|
2017-09-26 12:50:09 +00:00
|
|
|
err = mgr.Do(func(ctx context.Context, cli *client.Client) (err error) {
|
|
|
|
var (
|
|
|
|
tasks []swarm.Task
|
2017-10-19 12:40:05 +00:00
|
|
|
opts = types.TaskListOptions{
|
|
|
|
Filters: filters.NewArgs(),
|
|
|
|
}
|
2017-09-26 12:50:09 +00:00
|
|
|
)
|
|
|
|
|
2017-10-19 12:40:05 +00:00
|
|
|
if args.PageIndex < 1 {
|
|
|
|
args.PageIndex = 1
|
2017-09-26 12:50:09 +00:00
|
|
|
}
|
2017-10-19 12:40:05 +00:00
|
|
|
if args.PageSize < 1 {
|
|
|
|
args.PageSize = math.MaxInt32
|
2017-09-26 12:50:09 +00:00
|
|
|
}
|
2017-10-19 12:40:05 +00:00
|
|
|
if args.Service != "" {
|
|
|
|
opts.Filters.Add("service", args.Service)
|
2017-09-26 12:50:09 +00:00
|
|
|
}
|
2017-10-19 12:40:05 +00:00
|
|
|
if args.Node != "" {
|
|
|
|
opts.Filters.Add("node", args.Node)
|
|
|
|
}
|
|
|
|
if args.Name != "" {
|
|
|
|
opts.Filters.Add("name", args.Name)
|
|
|
|
}
|
|
|
|
if args.State != "" {
|
|
|
|
opts.Filters.Add("desired-state", args.State)
|
|
|
|
}
|
|
|
|
|
2017-09-26 12:50:09 +00:00
|
|
|
tasks, err = cli.TaskList(ctx, opts)
|
2017-10-19 12:40:05 +00:00
|
|
|
totalCount = len(tasks)
|
|
|
|
if err == nil && totalCount > 0 {
|
2017-09-26 12:50:09 +00:00
|
|
|
sort.Slice(tasks, func(i, j int) bool {
|
|
|
|
return tasks[i].UpdatedAt.After(tasks[j].UpdatedAt)
|
|
|
|
})
|
2017-10-19 12:40:05 +00:00
|
|
|
start, end := misc.Page(totalCount, args.PageIndex, args.PageSize)
|
|
|
|
tasks = tasks[start:end]
|
2017-09-26 12:50:09 +00:00
|
|
|
|
|
|
|
nodes := make(map[string]string)
|
|
|
|
for _, t := range tasks {
|
|
|
|
if _, ok := nodes[t.NodeID]; !ok {
|
|
|
|
if n, _, e := cli.NodeInspectWithRaw(ctx, t.NodeID); e == nil {
|
2017-10-19 12:40:05 +00:00
|
|
|
nodes[t.NodeID] = choose.String(n.Spec.Name == "", n.Description.Hostname, n.Spec.Name)
|
2017-09-26 12:50:09 +00:00
|
|
|
} else {
|
|
|
|
nodes[t.NodeID] = ""
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
infos = make([]*model.TaskInfo, len(tasks))
|
|
|
|
for i, t := range tasks {
|
|
|
|
infos[i] = model.NewTaskInfo(t, nodes[t.NodeID])
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return
|
|
|
|
})
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// TaskInspect return detail information of a task.
|
|
|
|
func TaskInspect(id string) (task swarm.Task, raw []byte, err error) {
|
|
|
|
err = mgr.Do(func(ctx context.Context, cli *client.Client) (err error) {
|
|
|
|
task, raw, err = cli.TaskInspectWithRaw(ctx, id)
|
|
|
|
return
|
|
|
|
})
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// TaskLogs returns the logs generated by a task in an io.ReadCloser.
|
|
|
|
// It's up to the caller to close the stream.
|
|
|
|
func TaskLogs(id string) (rc io.ReadCloser, err error) {
|
|
|
|
err = mgr.Do(func(ctx context.Context, cli *client.Client) (err error) {
|
|
|
|
opts := types.ContainerLogsOptions{}
|
|
|
|
rc, err = cli.TaskLogs(ctx, id, opts)
|
|
|
|
return
|
|
|
|
})
|
|
|
|
return
|
|
|
|
}
|