2015-07-16 17:14:58 -04:00
|
|
|
// +build !windows
|
|
|
|
|
|
|
|
package daemon
|
|
|
|
|
2015-09-10 18:01:18 -04:00
|
|
|
import (
|
|
|
|
"github.com/docker/docker/api/types"
|
|
|
|
"github.com/docker/docker/context"
|
|
|
|
)
|
2015-07-16 17:14:58 -04:00
|
|
|
|
|
|
|
// This sets platform-specific fields
|
|
|
|
func setPlatformSpecificContainerFields(container *Container, contJSONBase *types.ContainerJSONBase) *types.ContainerJSONBase {
|
|
|
|
contJSONBase.AppArmorProfile = container.AppArmorProfile
|
|
|
|
contJSONBase.ResolvConfPath = container.ResolvConfPath
|
|
|
|
contJSONBase.HostnamePath = container.HostnamePath
|
|
|
|
contJSONBase.HostsPath = container.HostsPath
|
|
|
|
|
|
|
|
return contJSONBase
|
|
|
|
}
|
|
|
|
|
2015-08-24 13:57:39 -04:00
|
|
|
// ContainerInspectPre120 gets containers for pre 1.20 APIs.
|
2015-09-10 18:01:18 -04:00
|
|
|
func (daemon *Daemon) ContainerInspectPre120(ctx context.Context, name string) (*types.ContainerJSONPre120, error) {
|
|
|
|
container, err := daemon.Get(ctx, name)
|
2015-07-16 17:14:58 -04:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
container.Lock()
|
|
|
|
defer container.Unlock()
|
|
|
|
|
2015-09-10 18:01:18 -04:00
|
|
|
base, err := daemon.getInspectData(ctx, container)
|
2015-07-16 17:14:58 -04:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
volumes := make(map[string]string)
|
|
|
|
volumesRW := make(map[string]bool)
|
|
|
|
for _, m := range container.MountPoints {
|
|
|
|
volumes[m.Destination] = m.Path()
|
|
|
|
volumesRW[m.Destination] = m.RW
|
|
|
|
}
|
|
|
|
|
2015-08-24 13:57:39 -04:00
|
|
|
config := &types.ContainerConfigPre120{
|
2015-07-16 17:14:58 -04:00
|
|
|
container.Config,
|
2015-08-24 13:57:39 -04:00
|
|
|
container.hostConfig.VolumeDriver,
|
2015-07-16 17:14:58 -04:00
|
|
|
container.hostConfig.Memory,
|
|
|
|
container.hostConfig.MemorySwap,
|
|
|
|
container.hostConfig.CPUShares,
|
|
|
|
container.hostConfig.CpusetCpus,
|
|
|
|
}
|
|
|
|
|
|
|
|
return &types.ContainerJSONPre120{base, volumes, volumesRW, config}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func addMountPoints(container *Container) []types.MountPoint {
|
|
|
|
mountPoints := make([]types.MountPoint, 0, len(container.MountPoints))
|
|
|
|
for _, m := range container.MountPoints {
|
|
|
|
mountPoints = append(mountPoints, types.MountPoint{
|
|
|
|
Name: m.Name,
|
|
|
|
Source: m.Path(),
|
|
|
|
Destination: m.Destination,
|
|
|
|
Driver: m.Driver,
|
|
|
|
Mode: m.Mode,
|
|
|
|
RW: m.RW,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
return mountPoints
|
|
|
|
}
|