2017-05-31 14:38:44 -04:00
|
|
|
# frozen_string_literal: true
|
2020-12-14 09:06:34 +01:00
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: instances
|
|
|
|
#
|
|
|
|
# domain :string primary key
|
|
|
|
# accounts_count :bigint(8)
|
|
|
|
#
|
2017-05-31 14:38:44 -04:00
|
|
|
|
2020-12-14 09:06:34 +01:00
|
|
|
class Instance < ApplicationRecord
|
|
|
|
self.primary_key = :domain
|
2017-05-31 14:38:44 -04:00
|
|
|
|
2020-12-14 09:06:34 +01:00
|
|
|
has_many :accounts, foreign_key: :domain, primary_key: :domain
|
2017-05-31 14:38:44 -04:00
|
|
|
|
2020-12-14 09:06:34 +01:00
|
|
|
belongs_to :domain_block, foreign_key: :domain, primary_key: :domain
|
|
|
|
belongs_to :domain_allow, foreign_key: :domain, primary_key: :domain
|
|
|
|
|
|
|
|
scope :matches_domain, ->(value) { where(arel_table[:domain].matches("%#{value}%")) }
|
|
|
|
|
|
|
|
def self.refresh
|
|
|
|
Scenic.database.refresh_materialized_view(table_name, concurrently: true, cascade: false)
|
2019-01-08 13:39:49 +01:00
|
|
|
end
|
|
|
|
|
2020-12-14 09:06:34 +01:00
|
|
|
def readonly?
|
|
|
|
true
|
2019-03-26 00:36:35 +01:00
|
|
|
end
|
|
|
|
|
2020-12-14 09:06:34 +01:00
|
|
|
def delivery_failure_tracker
|
|
|
|
@delivery_failure_tracker ||= DeliveryFailureTracker.new(domain)
|
|
|
|
end
|
|
|
|
|
|
|
|
def following_count
|
|
|
|
@following_count ||= Follow.where(account: accounts).count
|
|
|
|
end
|
|
|
|
|
|
|
|
def followers_count
|
|
|
|
@followers_count ||= Follow.where(target_account: accounts).count
|
|
|
|
end
|
|
|
|
|
|
|
|
def reports_count
|
|
|
|
@reports_count ||= Report.where(target_account: accounts).count
|
2019-01-08 13:39:49 +01:00
|
|
|
end
|
|
|
|
|
2020-12-14 09:06:34 +01:00
|
|
|
def blocks_count
|
|
|
|
@blocks_count ||= Block.where(target_account: accounts).count
|
|
|
|
end
|
|
|
|
|
|
|
|
def public_comment
|
|
|
|
domain_block&.public_comment
|
|
|
|
end
|
|
|
|
|
|
|
|
def private_comment
|
|
|
|
domain_block&.private_comment
|
|
|
|
end
|
|
|
|
|
|
|
|
def media_storage
|
|
|
|
@media_storage ||= MediaAttachment.where(account: accounts).sum(:file_file_size)
|
|
|
|
end
|
|
|
|
|
|
|
|
def to_param
|
2019-01-08 13:39:49 +01:00
|
|
|
domain
|
2017-05-31 14:38:44 -04:00
|
|
|
end
|
|
|
|
end
|