Skip to content

Commit

Permalink
Merge pull request moby#12163 from duglin/RemoveJobPS
Browse files Browse the repository at this point in the history
Remove Job from PS API
  • Loading branch information
Arnaud Porterie committed Apr 8, 2015
2 parents 56a2c58 + 1bfa80b commit 7233bd2
Show file tree
Hide file tree
Showing 6 changed files with 72 additions and 166 deletions.
2 changes: 1 addition & 1 deletion api/client/ps.go
Original file line number Diff line number Diff line change
Expand Up @@ -153,7 +153,7 @@ func (cli *DockerCli) CmdPs(args ...string) error {

fmt.Fprintf(w, "%s\t%s\t%s\t%s ago\t%s\t%s\t%s\t", ID, image, command,
units.HumanDuration(time.Now().UTC().Sub(time.Unix(int64(container.Created), 0))),
container.Status, api.NewDisplayablePorts(container.Ports), strings.Join(names, ","))
container.Status, api.DisplayablePorts(container.Ports), strings.Join(names, ","))

if *size {
if container.SizeRootFs > 0 {
Expand Down
55 changes: 1 addition & 54 deletions api/common.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@ import (

"github.com/Sirupsen/logrus"
"github.com/docker/docker/api/types"
"github.com/docker/docker/engine"
"github.com/docker/docker/pkg/parsers"
"github.com/docker/docker/pkg/version"
"github.com/docker/libtrust"
Expand All @@ -32,65 +31,13 @@ func ValidateHost(val string) (string, error) {
return host, nil
}

// TODO remove, used on < 1.5 in getContainersJSON
// TODO this can go away when we get rid of engine.table
func DisplayablePorts(ports *engine.Table) string {
var (
result = []string{}
hostMappings = []string{}
firstInGroupMap map[string]int
lastInGroupMap map[string]int
)
firstInGroupMap = make(map[string]int)
lastInGroupMap = make(map[string]int)
ports.SetKey("PrivatePort")
ports.Sort()
for _, port := range ports.Data {
var (
current = port.GetInt("PrivatePort")
portKey = port.Get("Type")
firstInGroup int
lastInGroup int
)
if port.Get("IP") != "" {
if port.GetInt("PublicPort") != current {
hostMappings = append(hostMappings, fmt.Sprintf("%s:%d->%d/%s", port.Get("IP"), port.GetInt("PublicPort"), port.GetInt("PrivatePort"), port.Get("Type")))
continue
}
portKey = fmt.Sprintf("%s/%s", port.Get("IP"), port.Get("Type"))
}
firstInGroup = firstInGroupMap[portKey]
lastInGroup = lastInGroupMap[portKey]

if firstInGroup == 0 {
firstInGroupMap[portKey] = current
lastInGroupMap[portKey] = current
continue
}

if current == (lastInGroup + 1) {
lastInGroupMap[portKey] = current
continue
}
result = append(result, FormGroup(portKey, firstInGroup, lastInGroup))
firstInGroupMap[portKey] = current
lastInGroupMap[portKey] = current
}
for portKey, firstInGroup := range firstInGroupMap {
result = append(result, FormGroup(portKey, firstInGroup, lastInGroupMap[portKey]))
}
result = append(result, hostMappings...)
return strings.Join(result, ", ")
}

type ByPrivatePort []types.Port

func (r ByPrivatePort) Len() int { return len(r) }
func (r ByPrivatePort) Swap(i, j int) { r[i], r[j] = r[j], r[i] }
func (r ByPrivatePort) Less(i, j int) bool { return r[i].PrivatePort < r[j].PrivatePort }

// TODO Rename to DisplayablePorts (remove "New") when engine.Table goes away
func NewDisplayablePorts(ports []types.Port) string {
func DisplayablePorts(ports []types.Port) string {
var (
result = []string{}
hostMappings = []string{}
Expand Down
48 changes: 19 additions & 29 deletions api/server/server.go
Original file line number Diff line number Diff line change
Expand Up @@ -482,42 +482,32 @@ func getContainersTop(eng *engine.Engine, version version.Version, w http.Respon
}

func getContainersJSON(eng *engine.Engine, version version.Version, w http.ResponseWriter, r *http.Request, vars map[string]string) error {
if err := parseForm(r); err != nil {
var err error
if err = parseForm(r); err != nil {
return err
}
var (
err error
outs *engine.Table
job = eng.Job("containers")
)

job.Setenv("all", r.Form.Get("all"))
job.Setenv("size", r.Form.Get("size"))
job.Setenv("since", r.Form.Get("since"))
job.Setenv("before", r.Form.Get("before"))
job.Setenv("limit", r.Form.Get("limit"))
job.Setenv("filters", r.Form.Get("filters"))

if version.GreaterThanOrEqualTo("1.5") {
streamJSON(job, w, false)
} else if outs, err = job.Stdout.AddTable(); err != nil {
return err
}
if err = job.Run(); err != nil {
return err
config := &daemon.ContainersConfig{
All: r.Form.Get("all") == "1",
Size: r.Form.Get("size") == "1",
Since: r.Form.Get("since"),
Before: r.Form.Get("before"),
Filters: r.Form.Get("filters"),
}
if version.LessThan("1.5") { // Convert to legacy format
for _, out := range outs.Data {
ports := engine.NewTable("", 0)
ports.ReadListFrom([]byte(out.Get("Ports")))
out.Set("Ports", api.DisplayablePorts(ports))
}
w.Header().Set("Content-Type", "application/json")
if _, err = outs.WriteListTo(w); err != nil {

if tmpLimit := r.Form.Get("limit"); tmpLimit != "" {
config.Limit, err = strconv.Atoi(tmpLimit)
if err != nil {
return err
}
}
return nil

containers, err := getDaemon(eng).Containers(config)
if err != nil {
return err
}

return writeJSON(w, http.StatusOK, containers)
}

func getContainersStats(eng *engine.Engine, version version.Version, w http.ResponseWriter, r *http.Request, vars map[string]string) error {
Expand Down
1 change: 0 additions & 1 deletion daemon/daemon.go
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,6 @@ func (daemon *Daemon) Install(eng *engine.Engine) error {
"container_rename": daemon.ContainerRename,
"container_inspect": daemon.ContainerInspect,
"container_stats": daemon.ContainerStats,
"containers": daemon.Containers,
"create": daemon.ContainerCreate,
"rm": daemon.ContainerRm,
"export": daemon.ContainerExport,
Expand Down
63 changes: 28 additions & 35 deletions daemon/list.go
Original file line number Diff line number Diff line change
@@ -1,15 +1,12 @@
package daemon

import (
"encoding/json"
"errors"
"fmt"
"sort"
"strconv"
"strings"

"github.com/docker/docker/api/types"
"github.com/docker/docker/engine"
"github.com/docker/docker/graph"
"github.com/docker/docker/nat"
"github.com/docker/docker/pkg/graphdb"
Expand All @@ -23,35 +20,35 @@ func (daemon *Daemon) List() []*Container {
return daemon.containers.List()
}

type ByCreated []types.Container

func (r ByCreated) Len() int { return len(r) }
func (r ByCreated) Swap(i, j int) { r[i], r[j] = r[j], r[i] }
func (r ByCreated) Less(i, j int) bool { return r[i].Created < r[j].Created }
type ContainersConfig struct {
All bool
Since string
Before string
Limit int
Size bool
Filters string
}

func (daemon *Daemon) Containers(job *engine.Job) error {
func (daemon *Daemon) Containers(config *ContainersConfig) ([]*types.Container, error) {
var (
foundBefore bool
displayed int
all = job.GetenvBool("all")
since = job.Getenv("since")
before = job.Getenv("before")
n = job.GetenvInt("limit")
size = job.GetenvBool("size")
all = config.All
n = config.Limit
psFilters filters.Args
filtExited []int
)
containers := []types.Container{}
containers := []*types.Container{}

psFilters, err := filters.FromParam(job.Getenv("filters"))
psFilters, err := filters.FromParam(config.Filters)
if err != nil {
return err
return nil, err
}
if i, ok := psFilters["exited"]; ok {
for _, value := range i {
code, err := strconv.Atoi(value)
if err != nil {
return err
return nil, err
}
filtExited = append(filtExited, code)
}
Expand All @@ -71,25 +68,25 @@ func (daemon *Daemon) Containers(job *engine.Job) error {
}, 1)

var beforeCont, sinceCont *Container
if before != "" {
beforeCont, err = daemon.Get(before)
if config.Before != "" {
beforeCont, err = daemon.Get(config.Before)
if err != nil {
return err
return nil, err
}
}

if since != "" {
sinceCont, err = daemon.Get(since)
if config.Since != "" {
sinceCont, err = daemon.Get(config.Since)
if err != nil {
return err
return nil, err
}
}

errLast := errors.New("last container")
writeCont := func(container *Container) error {
container.Lock()
defer container.Unlock()
if !container.Running && !all && n <= 0 && since == "" && before == "" {
if !container.Running && !all && n <= 0 && config.Since == "" && config.Before == "" {
return nil
}
if !psFilters.Match("name", container.Name) {
Expand All @@ -104,7 +101,7 @@ func (daemon *Daemon) Containers(job *engine.Job) error {
return nil
}

if before != "" && !foundBefore {
if config.Before != "" && !foundBefore {
if container.ID == beforeCont.ID {
foundBefore = true
}
Expand All @@ -113,7 +110,7 @@ func (daemon *Daemon) Containers(job *engine.Job) error {
if n > 0 && displayed == n {
return errLast
}
if since != "" {
if config.Since != "" {
if container.ID == sinceCont.ID {
return errLast
}
Expand All @@ -135,7 +132,7 @@ func (daemon *Daemon) Containers(job *engine.Job) error {
return nil
}
displayed++
newC := types.Container{
newC := &types.Container{
ID: container.ID,
Names: names[container.ID],
}
Expand Down Expand Up @@ -184,7 +181,7 @@ func (daemon *Daemon) Containers(job *engine.Job) error {
}
}

if size {
if config.Size {
sizeRw, sizeRootFs := container.GetSize()
newC.SizeRw = int(sizeRw)
newC.SizeRootFs = int(sizeRootFs)
Expand All @@ -197,14 +194,10 @@ func (daemon *Daemon) Containers(job *engine.Job) error {
for _, container := range daemon.List() {
if err := writeCont(container); err != nil {
if err != errLast {
return err
return nil, err
}
break
}
}
sort.Sort(sort.Reverse(ByCreated(containers)))
if err = json.NewEncoder(job.Stdout).Encode(containers); err != nil {
return err
}
return nil
return containers, nil
}
Loading

0 comments on commit 7233bd2

Please sign in to comment.