|
|
@ -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 |
|
|
|