Add admin dashboard (#8029)
parent
7a68608237
commit
2354b10eb5
@ -0,0 +1,42 @@ |
||||
# frozen_string_literal: true |
||||
require 'sidekiq/api' |
||||
|
||||
module Admin |
||||
class DashboardController < BaseController |
||||
def index |
||||
@users_count = User.count |
||||
@registrations_week = Redis.current.get("activity:accounts:local:#{current_week}") || 0 |
||||
@logins_week = Redis.current.pfcount("activity:logins:#{current_week}") |
||||
@interactions_week = Redis.current.get("activity:interactions:#{current_week}") || 0 |
||||
@relay_enabled = Relay.enabled.exists? |
||||
@single_user_mode = Rails.configuration.x.single_user_mode |
||||
@registrations_enabled = Setting.open_registrations |
||||
@deletions_enabled = Setting.open_deletions |
||||
@invites_enabled = Setting.min_invite_role == 'user' |
||||
@search_enabled = Chewy.enabled? |
||||
@version = Mastodon::Version.to_s |
||||
@database_version = ActiveRecord::Base.connection.execute('SELECT VERSION()').first['version'].match(/\A(?:PostgreSQL |)([^\s]+).*\z/)[1] |
||||
@redis_version = redis_info['redis_version'] |
||||
@reports_count = Report.unresolved.count |
||||
@queue_backlog = Sidekiq::Stats.new.enqueued |
||||
@recent_users = User.confirmed.recent.includes(:account).limit(4) |
||||
@database_size = ActiveRecord::Base.connection.execute('SELECT pg_database_size(current_database())').first['pg_database_size'] |
||||
@redis_size = redis_info['used_memory'] |
||||
@ldap_enabled = ENV['LDAP_ENABLED'] == 'true' |
||||
@cas_enabled = ENV['CAS_ENABLED'] == 'true' |
||||
@saml_enabled = ENV['SAML_ENABLED'] == 'true' |
||||
@pam_enabled = ENV['PAM_ENABLED'] == 'true' |
||||
@hidden_service = ENV['ALLOW_ACCESS_TO_HIDDEN_SERVICE'] == 'true' |
||||
end |
||||
|
||||
private |
||||
|
||||
def current_week |
||||
@current_week ||= Time.now.utc.to_date.cweek |
||||
end |
||||
|
||||
def redis_info |
||||
@redis_info ||= Redis.current.info |
||||
end |
||||
end |
||||
end |
@ -0,0 +1,69 @@ |
||||
.dashboard__counters { |
||||
display: flex; |
||||
flex-wrap: wrap; |
||||
margin: 0 -5px; |
||||
margin-bottom: 20px; |
||||
|
||||
& > div { |
||||
box-sizing: border-box; |
||||
flex: 0 0 33.333%; |
||||
padding: 0 5px; |
||||
margin-bottom: 10px; |
||||
|
||||
& > div, |
||||
& > a { |
||||
padding: 20px; |
||||
background: lighten($ui-base-color, 4%); |
||||
border-radius: 4px; |
||||
} |
||||
|
||||
& > a { |
||||
text-decoration: none; |
||||
color: inherit; |
||||
display: block; |
||||
|
||||
&:hover, |
||||
&:focus, |
||||
&:active { |
||||
background: lighten($ui-base-color, 8%); |
||||
} |
||||
} |
||||
} |
||||
|
||||
&__num { |
||||
text-align: center; |
||||
font-weight: 500; |
||||
font-size: 24px; |
||||
color: $primary-text-color; |
||||
font-family: 'mastodon-font-display', sans-serif; |
||||
margin-bottom: 20px; |
||||
} |
||||
|
||||
&__label { |
||||
font-size: 14px; |
||||
color: $darker-text-color; |
||||
text-align: center; |
||||
font-weight: 500; |
||||
} |
||||
} |
||||
|
||||
.dashboard__widgets { |
||||
display: flex; |
||||
flex-wrap: wrap; |
||||
margin: 0 -5px; |
||||
|
||||
& > div { |
||||
flex: 0 0 33.333%; |
||||
margin-bottom: 20px; |
||||
|
||||
& > div { |
||||
padding: 0 5px; |
||||
} |
||||
} |
||||
|
||||
a:not(.name-tag) { |
||||
color: $ui-secondary-color; |
||||
font-weight: 500; |
||||
text-decoration: none; |
||||
} |
||||
} |
@ -0,0 +1,140 @@ |
||||
- content_for :page_title do |
||||
= t('admin.dashboard.title') |
||||
|
||||
.dashboard__counters |
||||
%div |
||||
= link_to admin_accounts_url(local: 1, recent: 1) do |
||||
.dashboard__counters__num= number_with_delimiter @users_count |
||||
.dashboard__counters__label= t 'admin.dashboard.total_users' |
||||
%div |
||||
%div |
||||
.dashboard__counters__num= number_with_delimiter @registrations_week |
||||
.dashboard__counters__label= t 'admin.dashboard.week_users_new' |
||||
%div |
||||
%div |
||||
.dashboard__counters__num= number_with_delimiter @logins_week |
||||
.dashboard__counters__label= t 'admin.dashboard.week_users_active' |
||||
%div |
||||
%div |
||||
.dashboard__counters__num= number_with_delimiter @interactions_week |
||||
.dashboard__counters__label= t 'admin.dashboard.week_interactions' |
||||
%div |
||||
= link_to admin_reports_url do |
||||
.dashboard__counters__num= number_with_delimiter @reports_count |
||||
.dashboard__counters__label= t 'admin.dashboard.open_reports' |
||||
%div |
||||
= link_to sidekiq_url do |
||||
.dashboard__counters__num= number_with_delimiter @queue_backlog |
||||
.dashboard__counters__label= t 'admin.dashboard.backlog' |
||||
|
||||
.dashboard__widgets |
||||
.dashboard__widgets__users |
||||
%div |
||||
%h4= t 'admin.dashboard.recent_users' |
||||
%ul |
||||
- @recent_users.each do |user| |
||||
%li= admin_account_link_to(user.account) |
||||
|
||||
.dashboard__widgets__features |
||||
%div |
||||
%h4= t 'admin.dashboard.features' |
||||
%ul |
||||
%li |
||||
= link_to t('admin.dashboard.feature_registrations'), edit_admin_settings_path |
||||
- if @registrations_enabled |
||||
%span.pull-right.positive-hint= fa_icon 'check fw' |
||||
- else |
||||
%span.pull-right.negative-hint= fa_icon 'times fw' |
||||
%li |
||||
= link_to t('admin.dashboard.feature_invites'), edit_admin_settings_path |
||||
- if @invites_enabled |
||||
%span.pull-right.positive-hint= fa_icon 'check fw' |
||||
- else |
||||
%span.pull-right.negative-hint= fa_icon 'times fw' |
||||
%li |
||||
= link_to t('admin.dashboard.feature_deletions'), edit_admin_settings_path |
||||
- if @deletions_enabled |
||||
%span.pull-right.positive-hint= fa_icon 'check fw' |
||||
- else |
||||
%span.pull-right.negative-hint= fa_icon 'times fw' |
||||
%li |
||||
= link_to t('admin.dashboard.feature_relay'), admin_relays_path |
||||
- if @relay_enabled |
||||
%span.pull-right.positive-hint= fa_icon 'check fw' |
||||
- else |
||||
%span.pull-right.negative-hint= fa_icon 'times fw' |
||||
|
||||
.dashboard__widgets__versions |
||||
%div |
||||
%h4= t 'admin.dashboard.software' |
||||
%ul |
||||
%li |
||||
Mastodon |
||||
%span.pull-right= @version |
||||
%li |
||||
Ruby |
||||
%span.pull-right= "#{RUBY_VERSION}p#{RUBY_PATCHLEVEL}" |
||||
%li |
||||
PostgreSQL |
||||
%span.pull-right= @database_version |
||||
%li |
||||
Redis |
||||
%span.pull-right= @redis_version |
||||
|
||||
.dashboard__widgets__space |
||||
%div |
||||
%h4= t 'admin.dashboard.space' |
||||
%ul |
||||
%li |
||||
PostgreSQL |
||||
%span.pull-right= number_to_human_size @database_size |
||||
%li |
||||
Redis |
||||
%span.pull-right= number_to_human_size @redis_size |
||||
|
||||
.dashboard__widgets__config |
||||
%div |
||||
%h4= t 'admin.dashboard.config' |
||||
%ul |
||||
%li |
||||
= t('admin.dashboard.search') |
||||
- if @search_enabled |
||||
%span.pull-right.positive-hint= fa_icon 'check fw' |
||||
- else |
||||
%span.pull-right.negative-hint= fa_icon 'times fw' |
||||
%li |
||||
= t('admin.dashboard.single_user_mode') |
||||
- if @single_user_mode |
||||
%span.pull-right.positive-hint= fa_icon 'check fw' |
||||
- else |
||||
%span.pull-right.negative-hint= fa_icon 'times fw' |
||||
%li |
||||
LDAP |
||||
- if @ldap_enabled |
||||
%span.pull-right.positive-hint= fa_icon 'check fw' |
||||
- else |
||||
%span.pull-right.negative-hint= fa_icon 'times fw' |
||||
%li |
||||
CAS |
||||
- if @cas_enabled |
||||
%span.pull-right.positive-hint= fa_icon 'check fw' |
||||
- else |
||||
%span.pull-right.negative-hint= fa_icon 'times fw' |
||||
%li |
||||
SAML |
||||
- if @saml_enabled |
||||
%span.pull-right.positive-hint= fa_icon 'check fw' |
||||
- else |
||||
%span.pull-right.negative-hint= fa_icon 'times fw' |
||||
%li |
||||
PAM |
||||
- if @pam_enabled |
||||
%span.pull-right.positive-hint= fa_icon 'check fw' |
||||
- else |
||||
%span.pull-right.negative-hint= fa_icon 'times fw' |
||||
%li |
||||
= t 'admin.dashboard.hidden_service' |
||||
- if @hidden_service |
||||
%span.pull-right.positive-hint= fa_icon 'check fw' |
||||
- else |
||||
%span.pull-right.negative-hint= fa_icon 'times fw' |
Loading…
Reference in new issue