Low commit activity in last 3 years
No release in over a year
Easily track changes to various ActiveRecord models. Supports both attribute and method tracking.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

>= 4.2.0
 Project Readme

Track Changes

Installation

Migration

class CreateTrackChangesTables < ActiveRecord::Migration
  def change
    create_table :track_changes_snapshots do |t|
      t.references :record, :polymorphic => true
      t.text :state
      t.timestamps
    end

    create_table :track_changes_diffs do |t|
      t.references :record, :polymorphic => true
      t.text :from
      t.text :to
      t.string :action
      t.string :changes_by
      t.timestamps
    end
  end
end

Configuration

TrackChanges::Configuration.cascade_destroy = false # Controls whether tracked changes are deleted when the record is deleted. Can be set to false if an audit trail of destroyed records is desired. Default: true
TrackChanges::Configuration.serialize = false # Controls whether tracked changes are serialized as YAML before being written to the database. Can be set to false if the `state`, `from`, and `to` columns are JSON datatype instead of text. Default: true

Usage

class Person < ActiveRecord::Base
  tracks_changes # may also pass an options hash
end

Options

By default all model attributes are tracked, except the primary_key, usually id, created_at, and updated_at.

  • :only accepts a field name or array of field names to track instead of the default fields
  • :except accepts a field name or array of field names to ignore
  • :methods accepts a field name or array of field names to track in addition to the default fields
  • :track_timestamps accepts a boolean, enabling or disabling tracking of created_at and updated_at
  • :track_primary_key accepts a boolean, enabling or disabling tracking of the model's primary key
  • :track_locking_column accepts a boolean, enabling or disabling tracking of the model's locking column

Attribution

Changes can be attributed to a particular source. The source is saved as a string in the :changes_by column of the record. If given an instance of ActiveRecord::Base, the record's id will be used.

# Model-level attribution
person.track_changes_by = 'Joe Changems'
person.save

# Block-level attribution
TrackChanges.with_changes_attributed_to 'Joe Changems' do
  person.save
end

# Controller-level attribution
class MyController < ApplicationController
  attribute_changes_to :current_user
end