LendingHome / active_record-updated_at

Touch `updated_at` by default with calls to `update_all` and `update_column(s)`
MIT License
26 stars 5 forks source link
activerecord gem ruby ruby-on-rails

LendingHome active_record-updated_at

Code Climate Coverage Gem Version

Touch updated_at by default with calls to update_all and update_column(s)

Installation

Add this gem to the project Gemfile.

gem "active_record-updated_at"

Usage

The default ActiveRecord behavior does not touch updated_at when the following are called:

We rarely ever have a case to modify data WITHOUT touching updated_at so this gem enables the touching behavior by default. For those rare occasions that we don't want the touching we can wrap these calls in a disable block explicitly:

ActiveRecord::UpdatedAt.disable { User.update_all(role: "member") }

If updated_at is explicitly specified then the UPDATE query is not modified.

# This touches `updated_at` with `Time.current`
User.update_all(role: "member")

# This sets `updated_at` to `1.day.ago`
User.update_all(role: "member", updated_at: 1.day.ago)

# This sets `updated_at` to `NULL`
User.update_all(role: "member", updated_at: nil)

# This doesn't touch `updated_at`
ActiveRecord::UpdatedAt.disable { User.update_all(role: "member") }

Testing

bundle exec rspec

Contributing

Authors

License

MIT - Copyright © 2016 LendingHome