Gem to moderate fields of a model or its associations for Rails and ActiveRecord
Go to file
Guillaume Dott ed65771fd6 Add support for Rails 8 2024-12-19 16:36:53 +01:00
lib Bump version to 0.1.6 2024-09-24 16:31:04 +02:00
spec Update dev dependencies 2021-07-09 11:34:09 +02:00
.gitignore Add vendor/bundle to .gitignore 2021-07-09 11:34:28 +02:00
.rspec Create dummy rails app with combustion and first tests 2013-11-28 11:08:21 +01:00
.travis.yml Add support for Rails 7 2022-01-06 12:52:06 +01:00
Gemfile First commit 2013-11-28 11:08:21 +01:00
LICENSE.txt First commit 2013-11-28 11:08:21 +01:00
README.md Add build status in README 2014-09-23 17:46:46 +02:00
Rakefile First commit 2013-11-28 11:08:21 +01:00
config.ru Update dev dependencies 2021-07-09 11:34:09 +02:00
the_moderator.gemspec Add support for Rails 8 2024-12-19 16:36:53 +01:00

README.md

TheModerator

Build Status

Moderate fields before their insertion in the database by serializing and saving them into a separate 'moderations' table.

Installation

Add this line to your application's Gemfile:

gem 'the_moderator'

And then execute:

$ bundle

Or install it yourself as:

$ gem install the_moderator

Then use the generator for the migration and the basic Moderation model:

$ rails generate the_moderator:install

Usage

To use TheModerator, you need to include TheModerator::Model in the models you want to moderate.

class Article
  include TheModerator::Model
end

The Moderation model added by the genenrator is used to access the moderations.

Moderate attributes

This gem adds 3 methods to your models.

  • moderate
  • moderated?
  • moderated_fields_for(assoc)

Manage moderations

To list pending moderations, you can use the Moderation model

Moderation.all

You can access the moderations for a specific object with

post = Post.last
post.moderations

A Moderation instance has 4 methods:

  • moderation.data returns a hash of the moderated attributes
  • moderation.data_display returns a user-friendly hash to display the moderated attributes
  • moderation.preview
  • moderation.accept modifies the moderated object with the specified attributes and saves it
  • moderation.discard destroys the moderation

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request