Remove expensive counters from federation page in admin UI (#11139)

pull/1138/head
Eugen Rochko 2019-06-22 00:39:09 +02:00 committed by GitHub
parent 707ddf7808
commit 1b052c7b2d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 13 additions and 16 deletions

View File

@ -11,12 +11,8 @@ class Instance
@domain_block = resource.is_a?(DomainBlock) ? resource : DomainBlock.rule_for(domain) @domain_block = resource.is_a?(DomainBlock) ? resource : DomainBlock.rule_for(domain)
end end
def cached_sample_accounts def countable?
Rails.cache.fetch("#{cache_key}/sample_accounts", expires_in: 12.hours) { Account.where(domain: domain).searchable.joins(:account_stat).popular.limit(3) } @accounts_count.present?
end
def cached_accounts_count
@accounts_count || Rails.cache.fetch("#{cache_key}/count", expires_in: 12.hours) { Account.where(domain: domain).count }
end end
def to_param def to_param

View File

@ -33,21 +33,22 @@
%h4 %h4
= instance.domain = instance.domain
%small %small
= t('admin.instances.known_accounts', count: instance.cached_accounts_count)
- if instance.domain_block - if instance.domain_block
- first_item = true
- if !instance.domain_block.noop? - if !instance.domain_block.noop?
•
= t("admin.domain_blocks.severity.#{instance.domain_block.severity}") = t("admin.domain_blocks.severity.#{instance.domain_block.severity}")
- first_item = false
- if instance.domain_block.reject_media? - if instance.domain_block.reject_media?
- unless first_item
• •
= t('admin.domain_blocks.rejecting_media') = t('admin.domain_blocks.rejecting_media')
- first_item = false
- if instance.domain_block.reject_reports? - if instance.domain_block.reject_reports?
- unless first_item
• •
= t('admin.domain_blocks.rejecting_reports') = t('admin.domain_blocks.rejecting_reports')
- else
.avatar-stack = t('admin.accounts.no_limits_imposed')
- instance.cached_sample_accounts.each do |account| - if instance.countable?
= image_tag current_account&.user&.setting_auto_play_gif ? account.avatar_original_url : account.avatar_static_url, width: 48, height: 48, alt: '', class: 'account__avatar' .trends__item__current{ title: t('admin.instances.known_accounts', count: instance.accounts_count) }= number_to_human instance.accounts_count, strip_insignificant_zeros: true
= paginate paginated_instances = paginate paginated_instances