inspect_linux.go 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. package daemon // import "github.com/docker/docker/daemon"
  2. import (
  3. "context"
  4. "github.com/docker/docker/api/types"
  5. "github.com/docker/docker/api/types/backend"
  6. "github.com/docker/docker/api/types/versions/v1p19"
  7. "github.com/docker/docker/container"
  8. )
  9. // This sets platform-specific fields
  10. func setPlatformSpecificContainerFields(container *container.Container, contJSONBase *types.ContainerJSONBase) *types.ContainerJSONBase {
  11. contJSONBase.AppArmorProfile = container.AppArmorProfile
  12. contJSONBase.ResolvConfPath = container.ResolvConfPath
  13. contJSONBase.HostnamePath = container.HostnamePath
  14. contJSONBase.HostsPath = container.HostsPath
  15. return contJSONBase
  16. }
  17. // containerInspectPre120 gets containers for pre 1.20 APIs.
  18. func (daemon *Daemon) containerInspectPre120(ctx context.Context, name string) (*v1p19.ContainerJSON, error) {
  19. ctr, err := daemon.GetContainer(name)
  20. if err != nil {
  21. return nil, err
  22. }
  23. ctr.Lock()
  24. defer ctr.Unlock()
  25. base, err := daemon.getInspectData(&daemon.config().Config, ctr)
  26. if err != nil {
  27. return nil, err
  28. }
  29. volumes := make(map[string]string)
  30. volumesRW := make(map[string]bool)
  31. for _, m := range ctr.MountPoints {
  32. volumes[m.Destination] = m.Path()
  33. volumesRW[m.Destination] = m.RW
  34. }
  35. return &v1p19.ContainerJSON{
  36. ContainerJSONBase: base,
  37. Volumes: volumes,
  38. VolumesRW: volumesRW,
  39. Config: &v1p19.ContainerConfig{
  40. Config: ctr.Config,
  41. MacAddress: ctr.Config.MacAddress, //nolint:staticcheck // ignore SA1019: field is deprecated, but still used on API < v1.44.
  42. NetworkDisabled: ctr.Config.NetworkDisabled,
  43. ExposedPorts: ctr.Config.ExposedPorts,
  44. VolumeDriver: ctr.HostConfig.VolumeDriver,
  45. Memory: ctr.HostConfig.Memory,
  46. MemorySwap: ctr.HostConfig.MemorySwap,
  47. CPUShares: ctr.HostConfig.CPUShares,
  48. CPUSet: ctr.HostConfig.CpusetCpus,
  49. },
  50. NetworkSettings: daemon.getBackwardsCompatibleNetworkSettings(ctr.NetworkSettings),
  51. }, nil
  52. }
  53. func inspectExecProcessConfig(e *container.ExecConfig) *backend.ExecProcessConfig {
  54. return &backend.ExecProcessConfig{
  55. Tty: e.Tty,
  56. Entrypoint: e.Entrypoint,
  57. Arguments: e.Args,
  58. Privileged: &e.Privileged,
  59. User: e.User,
  60. }
  61. }