web.go 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. // Copyright 2014 Unknwon
  2. // Copyright 2014 Torkel Ödegaard
  3. package cmd
  4. import (
  5. "fmt"
  6. "net/http"
  7. "path"
  8. "time"
  9. "github.com/Unknwon/macaron"
  10. "github.com/codegangsta/cli"
  11. "github.com/macaron-contrib/session"
  12. "github.com/grafana/grafana/pkg/api"
  13. "github.com/grafana/grafana/pkg/log"
  14. "github.com/grafana/grafana/pkg/middleware"
  15. "github.com/grafana/grafana/pkg/plugins"
  16. "github.com/grafana/grafana/pkg/services/eventpublisher"
  17. "github.com/grafana/grafana/pkg/setting"
  18. "github.com/grafana/grafana/pkg/social"
  19. )
  20. var Web = cli.Command{
  21. Name: "web",
  22. Usage: "Starts Grafana backend & web server",
  23. Description: "Starts Grafana backend & web server",
  24. Action: runWeb,
  25. }
  26. func newMacaron() *macaron.Macaron {
  27. macaron.Env = setting.Env
  28. m := macaron.New()
  29. m.Use(middleware.Logger())
  30. m.Use(macaron.Recovery())
  31. if setting.EnableGzip {
  32. m.Use(macaron.Gziper())
  33. }
  34. mapStatic(m, "", "public")
  35. mapStatic(m, "app", "app")
  36. mapStatic(m, "css", "css")
  37. mapStatic(m, "img", "img")
  38. mapStatic(m, "fonts", "fonts")
  39. m.Use(session.Sessioner(setting.SessionOptions))
  40. m.Use(macaron.Renderer(macaron.RenderOptions{
  41. Directory: path.Join(setting.StaticRootPath, "views"),
  42. IndentJSON: macaron.Env != macaron.PROD,
  43. Delims: macaron.Delims{Left: "[[", Right: "]]"},
  44. }))
  45. m.Use(middleware.GetContextHandler())
  46. return m
  47. }
  48. func mapStatic(m *macaron.Macaron, dir string, prefix string) {
  49. m.Use(macaron.Static(
  50. path.Join(setting.StaticRootPath, dir),
  51. macaron.StaticOptions{
  52. SkipLogging: true,
  53. Prefix: prefix,
  54. },
  55. ))
  56. }
  57. func runWeb(c *cli.Context) {
  58. log.Info("Starting Grafana")
  59. log.Info("Version: %v, Commit: %v, Build date: %v", setting.BuildVersion, setting.BuildCommit, time.Unix(setting.BuildStamp, 0))
  60. initRuntime(c)
  61. social.NewOAuthService()
  62. eventpublisher.Init()
  63. plugins.Init()
  64. var err error
  65. m := newMacaron()
  66. api.Register(m)
  67. listenAddr := fmt.Sprintf("%s:%s", setting.HttpAddr, setting.HttpPort)
  68. log.Info("Listen: %v://%s%s", setting.Protocol, listenAddr, setting.AppSubUrl)
  69. switch setting.Protocol {
  70. case setting.HTTP:
  71. err = http.ListenAndServe(listenAddr, m)
  72. case setting.HTTPS:
  73. err = http.ListenAndServeTLS(listenAddr, setting.CertFile, setting.KeyFile, m)
  74. default:
  75. log.Fatal(4, "Invalid protocol: %s", setting.Protocol)
  76. }
  77. if err != nil {
  78. log.Fatal(4, "Fail to start server: %v", err)
  79. }
  80. }