GEM UNMAINTAINED: We have abandoned this gem and included the scopes into a project directly. If you are looking for updates, have a look at this file: https://github.com/fiedl/your_platform/blob/master/app/models/user_group_membership_mixins/validity_range.rb
Providing temporal scopes for an ActiveRecord model to allow queries by time. For example, MyModel.now.where(...)
, my_model.archive
, MyModel.past.where(...)
.
This is done by adding the database columns valid_from
and valid_to
to the model's table.
class Article < ActiveRecord::Base
has_temporal_scopes
end
current_article = Article.create(title: 'My new article', body: 'Lorem ipsum')
past_article = Article.create(title: 'My new article', body: 'Lorem ipsum')
past_article.archive
# or provide a datetime:
past_article.archive at: 1.hour.ago
Article.now # => [current_article]
Article.past # => [past_article]
Article.with_past # => [current_article, past_article]
Note that the default scope is set to now
.
Article.all # => [current_article]
Article.now # => [current_article]
Article.with_past # => [current_article, past_article]
Article.without_temporal_condition # => [current_article, past_article]
Further documentation can be found on rubydoc.info.
- This gem requires Rails 4.
- There is only one
valid_from
and onevalid_to
time per object. Therefore, you can't keep track of first archiving an object and later un-archiving it. Un-archiving an object loses the information of first archiving it. - Currently, the future is not handled (
Article.future
andarticle.archive at: 1.hour.from.now
do not work.) But this is planned to be implemented in the future.
Add the gem to your Gemfile
:
# Gemfile
# ...
gem 'temporal_scopes'
Then, run bundle install
.
Add the columns valid_from
and valid_to
to the model you would like to have temporal scopes.
bundle exec rails generate migration add_validity_period_to_articles valid_from:datetime:index valid_to:datetime:index
bundle exec rake db:migrate
Copyright (c) 2014 Sebastian Fiedlschuster.
Released under the MIT License.