state_machine_history¶ ↑
state_machine_history is an extension of the state_machine gem, that logs transitions between states and allows to check if a state was visited earlier.
Install¶ ↑
gem install state_machine_history
Ruby On Rails 2.x¶ ↑
Add the gem dependency to environment.rb:
... config.gem 'state_machine_history' ...
Generate the migration:
script/generate state_machine_history_2 create_machine_history
Run the migration
rake db:migrate
Ruby On Rails 3¶ ↑
In Gemfile:
gem 'state_machine_history'
Generate the migration:
rails generate state_machine_history create_machine_history
Run the migration:
rake db:migrate
Usage¶ ↑
This gem adds logging function to the state_machine gem. Sample:
Class definition¶ ↑
class Order state_machine :initial => :not_selected do # Switch on state machine logging track_history event :choose do transition :not_selected => :selected end event :add_to_basket do transition :selected => :in_basket end event :pay do transition :in_basket => :paid end event :to_send do transition :paid => :sent end end end
Using extensions¶ ↑
order = Order.new # Perform transition (state change is logged) order.choose # Find whether order has visited not_selected state before selected one order.was_there?(:not_selected, :selected) #=> true # Find whether order has visited not_selected state before the current one order.was_there?(:not_selected) #=> true
Credits¶ ↑
Project Team¶ ↑
-
Mykhaylo Sorochan - Project Manager
-
Dmitriy Landberg - Software Developer
-
Nataliya Shatokhina - Tester
-
Sergey Mostovoy - Extension idea
Copyright © 2010 Sphere Consulting Inc., released under the MIT license (see LICENSE).