Laters 👋
Run any instance_method of ActiveRecord models via a job by adding _later
to it. Laters, means See you later in
Dutch 🇳🇱
Installation
Add to your Gemfile
$ bundle add laters
Or install it yourself as:
$ gem install laters
Usage
- Include the
Laters::Concern
in your model - Call instance methods with
_later
class User < ApplicationRecord
include Laters::Concern
after_create_commit :notify_user_later
after_commit :refresh_cache_later
private
def notify_user
# External services
Sms.send(to: user.phone, message: 'Hey!')
end
def refresh_cache!
# Expensive calculation
end
end
To set the queue to any other than the default
set it like this:
class User < ApplicationRecord
include Laters::Concern
run_in_queue :low
end
If you need callbacks, they are provided as standart model callbacks:
class User < ApplicationRecord
include Laters::Concern
before_laters :do_something
after_laters :do_something_more
around_laters :do_something_around
# Etc..
end
Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/kieranklaassen/laters. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the code of conduct.
License
The gem is available as open source under the terms of the MIT License.
Code of Conduct
Everyone interacting in the Laters project's codebases, issue trackers, chat rooms and mailing lists is expected to follow the code of conduct.