containers.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. package proxy
  2. import (
  3. "context"
  4. "errors"
  5. "github.com/docker/api/containers"
  6. containersv1 "github.com/docker/api/protos/containers/v1"
  7. "github.com/docker/api/server/proxy/streams"
  8. )
  9. func portsToGrpc(ports []containers.Port) []*containersv1.Port {
  10. var result []*containersv1.Port
  11. for _, port := range ports {
  12. result = append(result, &containersv1.Port{
  13. ContainerPort: port.ContainerPort,
  14. HostPort: port.HostPort,
  15. HostIp: port.HostIP,
  16. Protocol: port.Protocol,
  17. })
  18. }
  19. return result
  20. }
  21. func (p *proxy) List(ctx context.Context, request *containersv1.ListRequest) (*containersv1.ListResponse, error) {
  22. containerList, err := Client(ctx).ContainerService().List(ctx, request.GetAll())
  23. if err != nil {
  24. return &containersv1.ListResponse{}, err
  25. }
  26. response := &containersv1.ListResponse{
  27. Containers: []*containersv1.Container{},
  28. }
  29. for _, container := range containerList {
  30. response.Containers = append(response.Containers, toGrpcContainer(container))
  31. }
  32. return response, nil
  33. }
  34. func (p *proxy) Stop(ctx context.Context, request *containersv1.StopRequest) (*containersv1.StopResponse, error) {
  35. timeoutValue := request.GetTimeout()
  36. return &containersv1.StopResponse{}, Client(ctx).ContainerService().Stop(ctx, request.Id, &timeoutValue)
  37. }
  38. func (p *proxy) Run(ctx context.Context, request *containersv1.RunRequest) (*containersv1.RunResponse, error) {
  39. ports := []containers.Port{}
  40. for _, p := range request.GetPorts() {
  41. ports = append(ports, containers.Port{
  42. ContainerPort: p.ContainerPort,
  43. HostIP: p.HostIp,
  44. HostPort: p.HostPort,
  45. Protocol: p.Protocol,
  46. })
  47. }
  48. return &containersv1.RunResponse{}, Client(ctx).ContainerService().Run(ctx, containers.ContainerConfig{
  49. ID: request.GetId(),
  50. Image: request.GetImage(),
  51. Labels: request.GetLabels(),
  52. Ports: ports,
  53. Volumes: request.GetVolumes(),
  54. })
  55. }
  56. func (p *proxy) Inspect(ctx context.Context, request *containersv1.InspectRequest) (*containersv1.InspectResponse, error) {
  57. c, err := Client(ctx).ContainerService().Inspect(ctx, request.Id)
  58. if err != nil {
  59. return nil, err
  60. }
  61. response := &containersv1.InspectResponse{
  62. Container: toGrpcContainer(c),
  63. }
  64. return response, err
  65. }
  66. func (p *proxy) Delete(ctx context.Context, request *containersv1.DeleteRequest) (*containersv1.DeleteResponse, error) {
  67. return &containersv1.DeleteResponse{}, Client(ctx).ContainerService().Delete(ctx, request.Id, request.Force)
  68. }
  69. func (p *proxy) Exec(ctx context.Context, request *containersv1.ExecRequest) (*containersv1.ExecResponse, error) {
  70. p.mu.Lock()
  71. stream, ok := p.streams[request.StreamId]
  72. p.mu.Unlock()
  73. if !ok {
  74. return &containersv1.ExecResponse{}, errors.New("unknown stream id")
  75. }
  76. io := &streams.IO{
  77. Stream: stream,
  78. }
  79. return &containersv1.ExecResponse{}, Client(ctx).ContainerService().Exec(ctx, request.GetId(), request.GetCommand(), io, io)
  80. }
  81. func (p *proxy) Logs(request *containersv1.LogsRequest, stream containersv1.Containers_LogsServer) error {
  82. return Client(stream.Context()).ContainerService().Logs(stream.Context(), request.GetContainerId(), containers.LogsRequest{
  83. Follow: request.Follow,
  84. Writer: &streams.Log{
  85. Stream: stream,
  86. },
  87. })
  88. }
  89. func toGrpcContainer(c containers.Container) *containersv1.Container {
  90. return &containersv1.Container{
  91. Id: c.ID,
  92. Image: c.Image,
  93. Status: c.Status,
  94. Command: c.Command,
  95. CpuTime: c.CPUTime,
  96. MemoryUsage: c.MemoryUsage,
  97. MemoryLimit: c.MemoryLimit,
  98. PidsCurrent: c.PidsCurrent,
  99. PidsLimit: c.PidsLimit,
  100. Labels: c.Labels,
  101. Ports: portsToGrpc(c.Ports),
  102. }
  103. }