2018-11-19 01:43:52 +02:00
|
|
|
# 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
|
2018-12-06 18:36:11 +02:00
|
|
|
# last_status_at :datetime
|
2018-11-19 01:43:52 +02:00
|
|
|
#
|
|
|
|
|
|
|
|
class AccountStat < ApplicationRecord
|
|
|
|
belongs_to :account, inverse_of: :account_stat
|
|
|
|
|
2019-10-01 02:19:11 +03:00
|
|
|
update_index('accounts#account', :account)
|
2019-08-16 02:24:03 +03:00
|
|
|
|
2018-11-19 01:43:52 +02:00
|
|
|
def increment_count!(key)
|
2018-12-06 18:36:11 +02:00
|
|
|
update(attributes_for_increment(key))
|
2018-11-19 01:43:52 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
def decrement_count!(key)
|
|
|
|
update(key => [public_send(key) - 1, 0].max)
|
|
|
|
end
|
2018-12-06 18:36:11 +02:00
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def attributes_for_increment(key)
|
|
|
|
attrs = { key => public_send(key) + 1 }
|
|
|
|
attrs[:last_status_at] = Time.now.utc if key == :statuses_count
|
|
|
|
attrs
|
|
|
|
end
|
2018-11-19 01:43:52 +02:00
|
|
|
end
|