stats.go 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. package sqlstore
  2. import (
  3. "github.com/grafana/grafana/pkg/bus"
  4. m "github.com/grafana/grafana/pkg/models"
  5. )
  6. func init() {
  7. bus.AddHandler("sql", GetSystemStats)
  8. bus.AddHandler("sql", GetDataSourceStats)
  9. }
  10. func GetDataSourceStats(query *m.GetDataSourceStatsQuery) error {
  11. var rawSql = `SELECT COUNT(*) as count, type FROM data_source GROUP BY type`
  12. query.Result = make([]*m.DataSourceStats, 0)
  13. err := x.Sql(rawSql).Find(&query.Result)
  14. if err != nil {
  15. return err
  16. }
  17. return err
  18. }
  19. func GetSystemStats(query *m.GetSystemStatsQuery) error {
  20. var rawSql = `SELECT
  21. (
  22. SELECT COUNT(*)
  23. FROM ` + dialect.Quote("user") + `
  24. ) AS user_count,
  25. (
  26. SELECT COUNT(*)
  27. FROM ` + dialect.Quote("org") + `
  28. ) AS org_count,
  29. (
  30. SELECT COUNT(*)
  31. FROM ` + dialect.Quote("dashboard") + `
  32. ) AS dashboard_count,
  33. (
  34. SELECT COUNT(*)
  35. FROM ` + dialect.Quote("playlist") + `
  36. ) AS playlist_count
  37. `
  38. var stats m.SystemStats
  39. _, err := x.Sql(rawSql).Get(&stats)
  40. if err != nil {
  41. return err
  42. }
  43. query.Result = &stats
  44. return err
  45. }