ServerStatsStore.tsx 1.3 KB

1234567891011121314151617181920212223242526272829
  1. import { types, getEnv, flow } from 'mobx-state-tree';
  2. export const ServerStat = types.model('ServerStat', {
  3. name: types.string,
  4. value: types.optional(types.number, 0),
  5. });
  6. export const ServerStatsStore = types
  7. .model('ServerStatsStore', {
  8. stats: types.array(ServerStat),
  9. error: types.optional(types.string, ''),
  10. })
  11. .actions(self => ({
  12. load: flow(function* load() {
  13. let backendSrv = getEnv(self).backendSrv;
  14. let res = yield backendSrv.get('/api/admin/stats');
  15. self.stats.clear();
  16. self.stats.push(ServerStat.create({ name: 'Total dashboards', value: res.dashboards }));
  17. self.stats.push(ServerStat.create({ name: 'Total users', value: res.users }));
  18. self.stats.push(ServerStat.create({ name: 'Active users (seen last 30 days)', value: res.activeUsers }));
  19. self.stats.push(ServerStat.create({ name: 'Total orgs', value: res.orgs }));
  20. self.stats.push(ServerStat.create({ name: 'Total playlists', value: res.playlists }));
  21. self.stats.push(ServerStat.create({ name: 'Total snapshots', value: res.snapshots }));
  22. self.stats.push(ServerStat.create({ name: 'Total dashboard tags', value: res.tags }));
  23. self.stats.push(ServerStat.create({ name: 'Total starred dashboards', value: res.stars }));
  24. self.stats.push(ServerStat.create({ name: 'Total alerts', value: res.alerts }));
  25. }),
  26. }));