This is a clone of the acts_as_versioned git project. I am in the process of adding in temporal logic.
It stores the effective_start and effective_end dates of records so that the version history can be searched for what happened at an exact point in history.
Below is the details for acts_as_versioned which still works today.
This library adds simple versioning to an ActiveRecord module. ActiveRecord is required. as well as temporal capabilities
It will set timestamps for the effectivity of a record.
on initial create the versioned record
the effective_start field will be set to current time or to whatever effective_date method is set to. the effective_end field will be set to max integer which is some time in the year 2038 (another y2k but waiting to happen)
on update the versioned record
the previous version record's effective_end field will be set to the current time or to whatever effective_date method is set to. the new versioned record will act like the initial create
It turns all fields into integers for easier quering
This can be converted by Time.at(1221627600) and back with Time.now.to_i
version | effective_start | effective_end 1 | 1221627600 | 1222405201 2 | 1222405201 | 2147483202
so this allows you to write a between query on the version table to find what the state was at a point in time.
VersionedModel.find(:all, :conditions => ["effective_start <= ? AND effective_end > ?", point_in_time, point_in_time])
the model looks the same as acts_as_versioned except I added the following
t.column effective_start, :integer t.column effective_end, :integer
- ./script/plugin install git://github.com/pbrumm/acts_as_temporal.git/
More details on approach