59 lines
1.5 KiB
Ruby
59 lines
1.5 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
# == Schema Information
|
|
#
|
|
# Table name: account_warnings
|
|
#
|
|
# id :bigint(8) not null, primary key
|
|
# account_id :bigint(8)
|
|
# target_account_id :bigint(8)
|
|
# action :integer default("none"), not null
|
|
# text :text default(""), not null
|
|
# created_at :datetime not null
|
|
# updated_at :datetime not null
|
|
# report_id :bigint(8)
|
|
# status_ids :string is an Array
|
|
# overruled_at :datetime
|
|
#
|
|
|
|
class AccountWarning < ApplicationRecord
|
|
enum action: {
|
|
none: 0,
|
|
disable: 1_000,
|
|
mark_statuses_as_sensitive: 1_250,
|
|
delete_statuses: 1_500,
|
|
sensitive: 2_000,
|
|
silence: 3_000,
|
|
suspend: 4_000,
|
|
}, _suffix: :action
|
|
|
|
before_validation :before_validate
|
|
|
|
belongs_to :account, inverse_of: :account_warnings
|
|
belongs_to :target_account, class_name: 'Account', inverse_of: :strikes
|
|
belongs_to :report, optional: true
|
|
|
|
has_one :appeal, dependent: :destroy, inverse_of: :strike
|
|
|
|
scope :latest, -> { order(id: :desc) }
|
|
scope :custom, -> { where.not(text: '') }
|
|
scope :recent, -> { where('account_warnings.created_at >= ?', 3.months.ago) }
|
|
|
|
def statuses
|
|
Status.with_discarded.where(id: status_ids || [])
|
|
end
|
|
|
|
def overruled?
|
|
overruled_at.present?
|
|
end
|
|
|
|
def to_log_human_identifier
|
|
target_account.acct
|
|
end
|
|
|
|
private
|
|
|
|
def before_validate
|
|
self.text = '' if text.blank?
|
|
end
|
|
end
|