|
|
@ -21,26 +21,26 @@ class AccountStat < ApplicationRecord
|
|
|
|
|
|
|
|
|
|
|
|
def increment_count!(key)
|
|
|
|
def increment_count!(key)
|
|
|
|
update(attributes_for_increment(key))
|
|
|
|
update(attributes_for_increment(key))
|
|
|
|
rescue ActiveRecord::StaleObjectError
|
|
|
|
rescue ActiveRecord::StaleObjectError, ActiveRecord::RecordNotUnique
|
|
|
|
begin
|
|
|
|
begin
|
|
|
|
reload_with_id
|
|
|
|
reload_with_id
|
|
|
|
rescue ActiveRecord::RecordNotFound
|
|
|
|
rescue ActiveRecord::RecordNotFound
|
|
|
|
# Nothing to do
|
|
|
|
return
|
|
|
|
else
|
|
|
|
|
|
|
|
retry
|
|
|
|
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
retry
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
def decrement_count!(key)
|
|
|
|
def decrement_count!(key)
|
|
|
|
update(key => [public_send(key) - 1, 0].max)
|
|
|
|
update(attributes_for_decrement(key))
|
|
|
|
rescue ActiveRecord::StaleObjectError
|
|
|
|
rescue ActiveRecord::StaleObjectError, ActiveRecord::RecordNotUnique
|
|
|
|
begin
|
|
|
|
begin
|
|
|
|
reload_with_id
|
|
|
|
reload_with_id
|
|
|
|
rescue ActiveRecord::RecordNotFound
|
|
|
|
rescue ActiveRecord::RecordNotFound
|
|
|
|
# Nothing to do
|
|
|
|
return
|
|
|
|
else
|
|
|
|
|
|
|
|
retry
|
|
|
|
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
retry
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
private
|
|
|
|
private
|
|
|
@ -51,8 +51,13 @@ class AccountStat < ApplicationRecord
|
|
|
|
attrs
|
|
|
|
attrs
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def attributes_for_decrement(key)
|
|
|
|
|
|
|
|
attrs = { key => [public_send(key) - 1, 0].max }
|
|
|
|
|
|
|
|
attrs
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
def reload_with_id
|
|
|
|
def reload_with_id
|
|
|
|
self.id = find_by!(account: account).id if new_record?
|
|
|
|
self.id = self.class.find_by!(account: account).id if new_record?
|
|
|
|
reload
|
|
|
|
reload
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|