containers.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  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. client := Client(ctx)
  23. c, err := client.ContainerService().List(ctx, request.GetAll())
  24. if err != nil {
  25. return &containersv1.ListResponse{}, err
  26. }
  27. response := &containersv1.ListResponse{
  28. Containers: []*containersv1.Container{},
  29. }
  30. for _, container := range c {
  31. response.Containers = append(response.Containers, &containersv1.Container{
  32. Id: container.ID,
  33. Image: container.Image,
  34. Command: container.Command,
  35. Status: container.Status,
  36. CpuTime: container.CPUTime,
  37. Labels: container.Labels,
  38. MemoryLimit: container.MemoryLimit,
  39. MemoryUsage: container.MemoryUsage,
  40. PidsCurrent: container.PidsCurrent,
  41. PidsLimit: container.PidsLimit,
  42. Ports: portsToGrpc(container.Ports),
  43. })
  44. }
  45. return response, nil
  46. }
  47. func (p *proxy) Stop(ctx context.Context, request *containersv1.StopRequest) (*containersv1.StopResponse, error) {
  48. c := Client(ctx)
  49. timeoutValue := request.GetTimeout()
  50. return &containersv1.StopResponse{}, c.ContainerService().Stop(ctx, request.Id, &timeoutValue)
  51. }
  52. func (p *proxy) Run(ctx context.Context, request *containersv1.RunRequest) (*containersv1.RunResponse, error) {
  53. ports := []containers.Port{}
  54. for _, p := range request.GetPorts() {
  55. ports = append(ports, containers.Port{
  56. ContainerPort: p.ContainerPort,
  57. HostIP: p.HostIp,
  58. HostPort: p.HostPort,
  59. Protocol: p.Protocol,
  60. })
  61. }
  62. err := Client(ctx).ContainerService().Run(ctx, containers.ContainerConfig{
  63. ID: request.GetId(),
  64. Image: request.GetImage(),
  65. Labels: request.GetLabels(),
  66. Ports: ports,
  67. Volumes: request.GetVolumes(),
  68. })
  69. return &containersv1.RunResponse{}, err
  70. }
  71. func (p *proxy) Delete(ctx context.Context, request *containersv1.DeleteRequest) (*containersv1.DeleteResponse, error) {
  72. err := Client(ctx).ContainerService().Delete(ctx, request.Id, request.Force)
  73. if err != nil {
  74. return &containersv1.DeleteResponse{}, err
  75. }
  76. return &containersv1.DeleteResponse{}, nil
  77. }
  78. func (p *proxy) Exec(ctx context.Context, request *containersv1.ExecRequest) (*containersv1.ExecResponse, error) {
  79. p.mu.Lock()
  80. stream, ok := p.streams[request.StreamId]
  81. p.mu.Unlock()
  82. if !ok {
  83. return &containersv1.ExecResponse{}, errors.New("unknown stream id")
  84. }
  85. io := &streams.IO{
  86. Stream: stream,
  87. }
  88. err := Client(ctx).ContainerService().Exec(ctx, request.GetId(), request.GetCommand(), io, io)
  89. return &containersv1.ExecResponse{}, err
  90. }
  91. func (p *proxy) Logs(request *containersv1.LogsRequest, stream containersv1.Containers_LogsServer) error {
  92. ctx := stream.Context()
  93. c := Client(ctx)
  94. return c.ContainerService().Logs(ctx, request.GetContainerId(), containers.LogsRequest{
  95. Follow: request.Follow,
  96. Writer: &streams.Log{
  97. Stream: stream,
  98. },
  99. })
  100. }