api.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. package api
  2. import (
  3. "github.com/Unknwon/macaron"
  4. "github.com/macaron-contrib/binding"
  5. "github.com/torkelo/grafana-pro/pkg/api/dtos"
  6. "github.com/torkelo/grafana-pro/pkg/middleware"
  7. m "github.com/torkelo/grafana-pro/pkg/models"
  8. "github.com/torkelo/grafana-pro/pkg/setting"
  9. )
  10. // Register adds http routes
  11. func Register(r *macaron.Macaron) {
  12. reqSignedIn := middleware.Auth(&middleware.AuthOptions{ReqSignedIn: true})
  13. reqAdmin := middleware.Auth(&middleware.AuthOptions{ReqSignedIn: true, ReqAdmin: true})
  14. bind := binding.Bind
  15. // not logged in views
  16. r.Get("/", reqSignedIn, Index)
  17. r.Post("/logout", LogoutPost)
  18. r.Post("/login", LoginPost)
  19. r.Get("/login/:name", OAuthLogin)
  20. r.Get("/login", Index)
  21. // authed views
  22. r.Get("/account/", reqSignedIn, Index)
  23. r.Get("/account/datasources/", reqSignedIn, Index)
  24. r.Get("/account/collaborators/", reqSignedIn, Index)
  25. r.Get("/account/apikeys/", reqSignedIn, Index)
  26. r.Get("/admin", reqSignedIn, Index)
  27. r.Get("/dashboard/*", reqSignedIn, Index)
  28. // sign up
  29. r.Get("/signup", Index)
  30. r.Post("/api/account/signup", SignUp)
  31. // authed api
  32. r.Group("/api", func() {
  33. // account
  34. r.Group("/account", func() {
  35. r.Get("/", GetAccount)
  36. r.Post("/", UpdateAccount)
  37. r.Put("/collaborators", bind(m.AddCollaboratorCommand{}), AddCollaborator)
  38. r.Get("/collaborators", GetCollaborators)
  39. r.Delete("/collaborators/:id", RemoveCollaborator)
  40. r.Post("/using/:id", SetUsingAccount)
  41. r.Get("/others", GetOtherAccounts)
  42. })
  43. // Token
  44. r.Group("/tokens", func() {
  45. r.Combo("/").
  46. Get(GetTokens).
  47. Put(bind(m.AddTokenCommand{}), AddToken).
  48. Post(bind(m.UpdateTokenCommand{}), UpdateToken)
  49. r.Delete("/:id", DeleteToken)
  50. })
  51. // Data sources
  52. r.Group("/datasources", func() {
  53. r.Combo("/").Get(GetDataSources).Put(AddDataSource).Post(UpdateDataSource)
  54. r.Delete("/:id", DeleteDataSource)
  55. r.Any("/proxy/:id/*", reqSignedIn, ProxyDataSourceRequest)
  56. })
  57. // Dashboard
  58. r.Group("/dashboard", func() {
  59. r.Combo("/:slug").Get(GetDashboard).Delete(DeleteDashboard)
  60. r.Post("/", PostDashboard)
  61. })
  62. // Search
  63. r.Get("/search/", Search)
  64. // metrics
  65. r.Get("/metrics/test", GetTestMetrics)
  66. }, reqSignedIn)
  67. // admin api
  68. r.Group("/api/admin", func() {
  69. r.Get("/accounts", AdminSearchAccounts)
  70. }, reqAdmin)
  71. // rendering
  72. r.Get("/render/*", reqSignedIn, RenderToPng)
  73. r.NotFound(NotFound)
  74. }
  75. func setIndexViewData(c *middleware.Context) error {
  76. settings, err := getFrontendSettings(c)
  77. if err != nil {
  78. return err
  79. }
  80. c.Data["User"] = dtos.NewCurrentUser(c.UserAccount)
  81. c.Data["Settings"] = settings
  82. c.Data["AppUrl"] = setting.AppUrl
  83. c.Data["AppSubUrl"] = setting.AppSubUrl
  84. return nil
  85. }
  86. func Index(c *middleware.Context) {
  87. if err := setIndexViewData(c); err != nil {
  88. c.Handle(500, "Failed to get settings", err)
  89. return
  90. }
  91. c.HTML(200, "index")
  92. }
  93. func NotFound(c *middleware.Context) {
  94. if c.IsApiRequest() {
  95. c.JsonApiErr(200, "Not found", nil)
  96. return
  97. }
  98. if err := setIndexViewData(c); err != nil {
  99. c.Handle(500, "Failed to get settings", err)
  100. return
  101. }
  102. c.HTML(404, "index")
  103. }