= AASM - Ruby state machines This package contains AASM, a library for adding finite state machines to Ruby classes. AASM started as the acts_as_state_machine plugin but has evolved into a more generic library that no longer targets only ActiveRecord models. AASM has the following features: * States * Machines * Events * Transitions == Download The latest AASM can currently be pulled from the git repository on github. * http://github.com/rubyist/aasm/tree/master A release and a gem are forthcoming. == Installation === From GitHub hosted gems % sudo gem sources -a http://gems.github.com # (you only need to do this once) % sudo gem install rubyist-aasm === Building your own gems % rake gem % sudo gem install pkg/aasm-2.0.2.gem == Simple Example Here's a quick example highlighting some of the features. class Conversation include AASM aasm_initial_state :new aasm_state :new aasm_state :read, :enter => :mark_thread_as_read aasm_state :closed aasm_event :view do # Transitions can take an optional on_transition option to execute some logic when the event is happening. # It can take a single string or symbol (denoting a method), an array of string or symbols # (denoting several methods), or an inline lambda transitions :to => :read, :from => [:new], :on_transition => :set_last_read_at, :guard => :user_authorized end aasm_event :close do transitions :to => :closed, :from => [:read, :new] end # Update last_read_at timestamp when the conversation is viewed def set_last_read_at self.last_read_at = Time.now end end == Explanation of transitions The current state machine has the following process. If we were to call Conversation#view!, we would get: state:new | | <-- :exit called on state[new] | | <-- :guard called on state[read] | | <-- :on_transition called on state[read] | | <-- aasm_current_state set to "read" | | <-- :success called on state[read] | | <-- :enter called on state[read] | state:read = Other Stuff Author:: Scott Barron License:: Copyright 2006, 2007, 2008 by Scott Barron. Released under an MIT-style license. See the LICENSE file included in the distribution. Bugs:: http://rubyist.lighthouseapp.com/projects/13207-aasm/ GitHub:: http://github.com/rubyist/aasm/tree/master == Warranty This software is provided "as is" and without any express or implied warranties, including, without limitation, the implied warranties of merchantibility and fitness for a particular purpose.