aasm/README.md

150 lines
3.3 KiB
Markdown
Raw Normal View History

2011-08-31 19:50:59 +00:00
# AASM - Ruby state machines #
2008-02-22 23:23:19 +00:00
This package contains AASM, a library for adding finite state machines to Ruby classes.
2008-02-22 23:23:19 +00:00
AASM started as the acts_as_state_machine plugin but has evolved into a more generic library that no longer targets only ActiveRecord models.
2008-02-22 23:23:19 +00:00
2011-08-31 19:50:59 +00:00
## Features ##
2008-02-22 23:23:19 +00:00
2008-05-29 14:24:01 +00:00
* States
* Machines
* Events
* Transitions
2008-02-22 23:23:19 +00:00
2011-08-31 19:50:59 +00:00
## New Callbacks ##
2008-02-22 23:23:19 +00:00
2009-02-26 21:18:22 +00:00
The callback chain & order on a successful event looks like:
oldstate:exit*
event:before
__find transition, if possible__
transition:on_transition*
oldstate:before_exit
newstate:before_enter
newstate:enter*
__update state__
event:success*
oldstate:after_exit
newstate:after_enter
event:after
obj:aasm_event_fired*
(*) marks old callbacks
2011-08-31 19:50:59 +00:00
## Installation ##
2011-10-23 19:21:51 +00:00
### Manually from RubyGems.org ###
2011-08-31 19:50:59 +00:00
```sh
% gem install aasm
```
2011-10-23 19:21:51 +00:00
### Or if you are using Bundler ###
```ruby
# Gemfile
gem 'aasm'
```
2011-08-31 19:50:59 +00:00
### Building your own gems ###
2011-08-31 19:50:59 +00:00
```sh
% rake build
2011-08-31 21:56:57 +00:00
% sudo gem install pkg/aasm-x.y.z.gem
2011-08-31 19:50:59 +00:00
```
2011-08-31 19:50:59 +00:00
## Simple Example ##
Here's a quick example highlighting some of the features.
2011-08-31 19:50:59 +00:00
```ruby
class Conversation
include AASM
2010-01-17 06:12:18 +00:00
aasm_column :current_state # defaults to aasm_state
aasm_initial_state :unread
aasm_state :unread
aasm_state :read
aasm_state :closed
aasm_event :view do
transitions :to => :read, :from => [:unread]
end
aasm_event :close do
transitions :to => :closed, :from => [:read, :unread]
end
end
2011-08-31 19:50:59 +00:00
```
2011-08-31 19:50:59 +00:00
## A Slightly More Complex Example ##
This example uses a few of the more complex features available.
2011-08-31 19:50:59 +00:00
```ruby
class Relationship
include AASM
2010-01-17 06:12:18 +00:00
aasm_column :status
aasm_initial_state Proc.new { |relationship| relationship.strictly_for_fun? ? :intimate : :dating }
aasm_state :dating, :enter => :make_happy, :exit => :make_depressed
aasm_state :intimate, :enter => :make_very_happy, :exit => :never_speak_again
aasm_state :married, :enter => :give_up_intimacy, :exit => :buy_exotic_car_and_wear_a_combover
aasm_event :get_intimate do
transitions :to => :intimate, :from => [:dating], :guard => :drunk?
end
aasm_event :get_married do
transitions :to => :married, :from => [:dating, :intimate], :guard => :willing_to_give_up_manhood?
end
def strictly_for_fun?; end
def drunk?; end
def willing_to_give_up_manhood?; end
def make_happy; end
def make_depressed; end
def make_very_happy; end
def never_speak_again; end
def give_up_intimacy; end
def buy_exotic_car_and_wear_a_combover; end
end
2011-08-31 19:50:59 +00:00
```
2011-09-04 15:59:55 +00:00
## Callbacks around events
```ruby
class Relationship
include AASM
aasm_state :dating
aasm_state :married
2011-09-04 16:00:55 +00:00
aasm_event :get_married,
2011-09-04 15:59:55 +00:00
:before => :make_vows,
2011-09-04 16:01:29 +00:00
:after => :eat_wedding_cake do
2011-09-04 15:59:55 +00:00
transitions :to => :married, :from => [:dating]
end
end
```
2011-08-31 19:50:59 +00:00
# Other Stuff #
Author:: Scott Barron <scott at elitists dot net>
2009-02-26 21:18:22 +00:00
License:: Original code Copyright 2006, 2007, 2008 by Scott Barron.
Released under an MIT-style license. See the LICENSE file
included in the distribution.
2011-08-31 19:50:59 +00:00
## 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.