lib/aasm/base.rb in aasm-3.0.26 vs lib/aasm/base.rb in aasm-3.1.0

- old
+ new

@@ -3,28 +3,23 @@ def initialize(clazz, options={}, &block) @clazz = clazz @state_machine = AASM::StateMachine[@clazz] @state_machine.config.column = options[:column].to_sym if options[:column] + @options = options - if options.key?(:whiny_transitions) - @state_machine.config.whiny_transitions = options[:whiny_transitions] - elsif @state_machine.config.whiny_transitions.nil? - @state_machine.config.whiny_transitions = true # this is the default, so let's cry - end + # let's cry if the transition is invalid + configure :whiny_transitions, true - if options.key?(:create_scopes) - @state_machine.config.create_scopes = options[:create_scopes] - elsif @state_machine.config.create_scopes.nil? - @state_machine.config.create_scopes = true # this is the default, so let's create scopes - end + # create named scopes for each state + configure :create_scopes, true - if options.key?(:skip_validation_on_save) - @state_machine.config.skip_validation_on_save = options[:skip_validation_on_save] - elsif @state_machine.config.skip_validation_on_save.nil? - @state_machine.config.skip_validation_on_save = false # this is the default, so don't store any new state if the model is invalid - end + # don't store any new state if the model is invalid + configure :skip_validation_on_save, false + + # use requires_new for nested transactions + configure :requires_new_transaction, true end def initial_state(new_initial_state=nil) if new_initial_state @state_machine.initial_state = new_initial_state @@ -82,9 +77,20 @@ def from_states_for_state(state, options={}) if options[:transition] events[options[:transition]].transitions_to_state(state).flatten.map(&:from).flatten else events.map {|k,v| v.transitions_to_state(state)}.flatten.map(&:from).flatten + end + end + + private + + def configure(key, default_value) + @state_machine.config.send(:new_ostruct_member, key) + if @options.key?(key) + @state_machine.config.send("#{key}=", @options[key]) + elsif @state_machine.config.send(key).nil? + @state_machine.config.send("#{key}=", default_value) end end end end