0.02
Repository is archived
No commit activity in last 3 years
No release in over 3 years
There's a lot of open issues
An action based auditor, which has internal as well as outgoing link tracking. Provides Analytics for User count in line-chart.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

< 5, > 3.2.6
~> 0.0.3
~> 1.5.1
 Project Readme

AuditRails

Gem VersionBuild StatusCoverage StatusBitdeli Badge

It generates audit-trails for your rails application and provide analytics out of the box!

It is inspired from many great audit gems in rails community that audits model and I was looking for a gem which can audit based on actions as well as can audit link tracking. This gem just serve this purpose.

Roughly it is doing similar to what Omniture/Google Analytics does, but it your data remain within your app, so you can build custom charts as and when you wish.

Example

User visit & page view count by date range:

Audits

Pre-requisites:

For rails 4.x+ & 3.2.6 + and ruby>1.9.2:

gem install audit_rails

or in application’s Gemfile add:

gem ‘audit_rails’

Install

rails g audit_rails:install

Usage

To add audit migration:

rake audit_rails:install:migrations

To add additional attributes to Audit (let's say book_id):

Add attributes to migration generated from above rake task

Inherit from AuditRails::Audit:

# MyApp/app/models/audit.rb
class Audit < AuditRails::Audit
  # attr_accessible is only needed for Rails 3.2.6+ not needed for Rails 4+
  attr_accessible :action, :controller, :description, :user_name,
  :book_id
  # add associations as usual:
  belongs_to :book
end

To log user events

Simply call 'add_to_audit' with desired parameters in any controller (as this is now a helper method included in application_controller.rb of application)

To override controller's add_to_audit method (or the helper method)

Simply re-implement in application_controller.rb

To track user login (one per day)

Override current_user method in application controller, e.g.:

def current_user
  add_to_audit('login', 'sessions', "John Smith")
  super
end

To see Analytics

Go to <app-url>/audit_rails/audits/analytics

To download the audit report as xls file:

Add this to initializers/mime_types.rb

Mime::Type.register "application/vnd.ms-excel", :xls

Use below link in views:

link_to audit_rails.audits_path(:format => "xls")

To restrict access to analytics page

Restrict access to Analytics

What's next?

  • Rails 4+ support (Done: Tested with example application )
  • ReactJS awesomeness
  • geoip integration
  • World Map Integration

Changelog

https://github.com/gouravtiwari/audit_rails/blob/master/CHANGELOG.rdoc

Contribute

You are welcome to contribute and add more feature to this gem. I have added rspec and guard to it to run tests quickly. So running specs shouldn't be a problem.

Please fork it, add specs and send a pull request!

License

This project rocks and uses MIT-LICENSE.