system.go 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. package system // import "github.com/docker/docker/api/server/router/system"
  2. import (
  3. "github.com/docker/docker/api/server/router"
  4. "github.com/docker/docker/api/types"
  5. buildkit "github.com/docker/docker/builder/builder-next"
  6. "github.com/docker/docker/builder/fscache"
  7. )
  8. // systemRouter provides information about the Docker system overall.
  9. // It gathers information about host, daemon and container events.
  10. type systemRouter struct {
  11. backend Backend
  12. cluster ClusterBackend
  13. routes []router.Route
  14. fscache *fscache.FSCache // legacy
  15. builder *buildkit.Builder
  16. builderVersion types.BuilderVersion
  17. }
  18. // NewRouter initializes a new system router
  19. func NewRouter(b Backend, c ClusterBackend, fscache *fscache.FSCache, builder *buildkit.Builder, bv types.BuilderVersion) router.Router {
  20. r := &systemRouter{
  21. backend: b,
  22. cluster: c,
  23. fscache: fscache,
  24. builder: builder,
  25. builderVersion: bv,
  26. }
  27. r.routes = []router.Route{
  28. router.NewOptionsRoute("/{anyroute:.*}", optionsHandler),
  29. router.NewGetRoute("/_ping", r.pingHandler),
  30. router.NewGetRoute("/events", r.getEvents, router.WithCancel),
  31. router.NewGetRoute("/info", r.getInfo),
  32. router.NewGetRoute("/version", r.getVersion),
  33. router.NewGetRoute("/system/df", r.getDiskUsage, router.WithCancel),
  34. router.NewPostRoute("/auth", r.postAuth),
  35. }
  36. return r
  37. }
  38. // Routes returns all the API routes dedicated to the docker system
  39. func (s *systemRouter) Routes() []router.Route {
  40. return s.routes
  41. }