Mark models as has_publishing
to publish, draft and embargo models. Easy peasy!
published
,draft
,embargoed
scopes for easy filtering/finding- Rails environment-based default scoping: if your site is using
draft
, draft/embargoed records will still be found - if you useRAILS_ENV=published
, though, only published records will be found. - In use in production on multiple sites
- Covered by automated tests
Add this line to your application's Gemfile:
gem 'has_publishing'
And then execute:
$ bundle
Or install it yourself as:
$ gem install has_publishing
Simply add has_publishing
to the model of your choice, and then generate the publishing attributes for your model:
bundle exec rails generate migration [YOUR MODEL NAME] embargoed_until:datetime published_at:datetime published_id:integer kind:string
…and then of course run rake db:migrate
(If anyone would like to add a generator to automate this process, it would be very much appreciated)
Publishing is typically used in an environment where there may be two installations of the Rails application sharing a common database. This at least is the set up that has_publishing
is designed to operate in - something like the following:
|-- Admin RAILS_ENV=draft --| >>>>> SharedDatabase <<<<<< |-- Published Site RAILS_ENV=published --|
Because of this, the gem applies a default_scope to all instances of this model to either:
- Only return published records if
Rails.env
matchesHasPublishing.config.published_rails_environment
(which by default is'published'
) - Only return draft records otherwise
This prevents 'duplicate' records from appearing for the user (since each 'record' has two representations - 'draft' and 'published/withdrawn')
- If you would prefer that this default scope NOT be applied, then simply set
HasPublishing.config.scope_records
tofalse
. - If you want the default scope to apply properly, ensure that you set the Rails environment of your published application in
HasPublishing.config.published_rails_environment
.
When you call publish!
and withdraw!
you can pass a hash of attributes with it to be updated with your ActiveRecord::Model
object.
This is usefull if you are using a gem like ancestry, for example:
@page = Page.find_by_slug('foo-bar-page')
@page.publish!(:parent => (@page.parent.published unless @page.is_root?))
- Fork it
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create new Pull Request