# frozen_string_literal: true

# == Schema Information
#
# Table name: account_stats
#
#  id                      :bigint(8)        not null, primary key
#  account_id              :bigint(8)        not null
#  statuses_count          :bigint(8)        default(0), not null
#  following_count         :bigint(8)        default(0), not null
#  followers_count         :bigint(8)        default(0), not null
#  created_at              :datetime         not null
#  updated_at              :datetime         not null
#  last_status_at          :datetime
#  group_activitypub_count :integer
#

class AccountStat < ApplicationRecord
  self.locking_column = nil
  self.ignored_columns += %w(lock_version)

  belongs_to :account, inverse_of: :account_stat

  update_index('accounts', :account)

  def following_count
    [attributes['following_count'], 0].max
  end

  def followers_count
    [attributes['followers_count'], 0].max
  end

  def statuses_count
    [attributes['statuses_count'], 0].max
  end

  def group_activitypub_count
    [attributes['group_activitypub_count'] || 0, 0].max
  end
end