stats.go 997 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  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. var stats m.SystemStats
  35. _, err := x.Sql(rawSql).Get(&stats)
  36. if err != nil {
  37. return err
  38. }
  39. query.Result = &stats
  40. return err
  41. }