1
0

serve.go 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. package cmd
  2. import (
  3. "context"
  4. "net"
  5. cliv1 "github.com/docker/api/cli/v1"
  6. "github.com/docker/api/client"
  7. "github.com/docker/api/containers/proxy"
  8. containersv1 "github.com/docker/api/containers/v1"
  9. "github.com/docker/api/context/store"
  10. "github.com/docker/api/server"
  11. "github.com/golang/protobuf/ptypes/empty"
  12. "github.com/pkg/errors"
  13. "github.com/sirupsen/logrus"
  14. "github.com/spf13/cobra"
  15. )
  16. type serveOpts struct {
  17. address string
  18. }
  19. func ServeCommand() *cobra.Command {
  20. var opts serveOpts
  21. cmd := &cobra.Command{
  22. Use: "serve",
  23. Short: "Start an api server",
  24. RunE: func(cmd *cobra.Command, args []string) error {
  25. return runServe(cmd.Context(), opts)
  26. },
  27. }
  28. cmd.Flags().StringVar(&opts.address, "address", "", "The address to listen to")
  29. return cmd
  30. }
  31. func runServe(ctx context.Context, opts serveOpts) error {
  32. s := server.New()
  33. l, err := net.Listen("unix", opts.address)
  34. if err != nil {
  35. return errors.Wrap(err, "listen unix socket")
  36. }
  37. defer l.Close()
  38. c, err := client.New(ctx)
  39. if err != nil {
  40. return err
  41. }
  42. p := proxy.NewContainerApi(c.ContainerService(ctx))
  43. containersv1.RegisterContainersServer(s, p)
  44. cliv1.RegisterCliServer(s, &cliServer{
  45. ctx,
  46. })
  47. go func() {
  48. <-ctx.Done()
  49. logrus.Info("stopping server")
  50. s.Stop()
  51. }()
  52. logrus.WithField("address", opts.address).Info("serving daemon API")
  53. // start the GRPC server to serve on the listener
  54. return s.Serve(l)
  55. }
  56. type cliServer struct {
  57. ctx context.Context
  58. }
  59. func (cs *cliServer) Contexts(context.Context, *empty.Empty) (*cliv1.ContextsResponse, error) {
  60. s, err := store.New()
  61. if err != nil {
  62. logrus.Error(err)
  63. return &cliv1.ContextsResponse{}, err
  64. }
  65. contexts, err := s.List()
  66. if err != nil {
  67. logrus.Error(err)
  68. return &cliv1.ContextsResponse{}, err
  69. }
  70. result := &cliv1.ContextsResponse{}
  71. for _, c := range contexts {
  72. result.Contexts = append(result.Contexts, &cliv1.Context{
  73. Name: c.Name,
  74. ContextType: c.Metadata.Type,
  75. })
  76. }
  77. return result, nil
  78. }