No commit activity in last 3 years
No release in over 3 years
Provides a straightforward way for auditing changes on active record models, especially for composite entities. Also provides helper methods for easily rendering an audit trail in Ruby on Rails views.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

 Project Readme

Build Status Coverage Status

MongoidSimpleAudit

This is a modified version of the Gem simple_audit from Gabriel Tarnovan (https://github.com/gtarnovan/simple_audit) wich uses MongoDB with Mongoid to store audit logs instead of ActiveRecord. Furthermore it is capable of auditing both ActiveRecord and Mongoid models, which is especialy usefull for applications which use both backends.

What is this Gem about?

It's a simple auditing solution for ActiveRecord and Mongoid models. Provides an easy way of creating audit logs for complex model associations. Instead of storing audits for all data aggregated by the audited model, you can specify a serializable representation of the model. mongoid_simple_audit is intended as a straightforward, performant and simple auditing solution.

  • a helper method is provided to easily display the audit log
  • the Audit object provides a #delta method which computes the differences between two audits

Requirements

The gem requires Mongoid version 3.x with Ruby on Rails 3.x or Mongoid 4.x with Rails 4.x

Installation

Add this line to your application's Gemfile:

gem 'mongoid_simple_audit'

And then execute:

$ bundle

Or install it yourself as:

$ gem install mongoid_simple_audit

Don't forget to create the MongoDB indeces

rake db:mongoid:create_indexes

Usage

class Booking < ActiveRecord::Base simple_audit do |record| # data to be audited { :price => record.price, :period => record.period, ... } end end

in your view

<%= render_audits(@booking) %>

Audit ActiveRecord or Mongoid models. Somewhere in your (backend) views show the audit logs.

# in your model
# app/models/booking.rb

class Booking < ActiveRecord::Base
    simple_audit
    ...
end

# or for Mongoid

class Booking
    include Mongoid::Document
    simple_audit
    ...
end    

# in your view
# app/views/bookings/booking.html.erb

...
<%= render_audits(@booking) %>
...     

# in order to have the default styles, include the stylesheet

<%= stylesheet_link_tag 'mongoid_simple_audit' %>

Assumptions and limitations

  • Your user model is called User (or Cms::User) and the current user User.current See sentient_user for more information.

Customize auditing

By default after each save, all model's attributes and belongs_to associations (their id and to_s on these) are saved in the audits table. You can customize the data which is saved by supplying a block which will return all relevant data for the audited model.

# app/models/booking.rb

class Booking < ActiveRecord::Base
    simple_audit do |record|
      {
        :state  => record.state, 
        :price  => record.price.format,
        :period => record.period.to_s,
        :housing_units => record.housing_units.collect(&:name).join('; '),
        ...
        }
    end
    ...
end

You can also customize the attribute of the User model which will be stored in the audit.

# default is :name
simple_audit :username_method => :email

As a default it will audit all save and update calls even though no changes where made, unless you specify :audit_changes_only => true

simple_audit :audit_changes_only => true

Rendering audit trail

A helper method for displaying a list of audits is provided. It will render a decorated list of the provided audits; only the differences between revisions will be shown, thus making the audit information easily readable.

Why I consider the MongoDB Version more suitable to the original with ActiveRecord

  1. Changed attributes are natively searchable by the database
  2. Better perfomance
  3. High scalability
  4. It supports the Mongoid wrapper

Negative aspect though, its not working nicely hand in hand with not MongoDB backends

How to migrate simple_audit record stored with ActiveRecord

If you want to migrate from the ActiveRecord version of simple_audit to a document based datamodel (maybe because your database got super fat), mongoid_simple_audit has a rake task for that.

rake mongoid_simple_audit:migrates_from_mysql_to_mongoid

Contributing

  1. Fork it ( https://github.com/felixabele/mongoid_simple_audit/fork )
  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 a new Pull Request