module RulesEngine module Rule class <%=rule_class%> < RulesEngine::Rule::Definition attr_reader :description ################################################################## # class options self.options = { :group => 'Workflow', :display_name => 'Workflow Stop', :help_partial => '/re_rule_definitions/<%=rule_name%>/help', :new_partial => '/re_rule_definitions/<%=rule_name%>/new', :edit_partial => '/re_rule_definitions/<%=rule_name%>/edit' } ################################################################## # set the rule data def data= data if data.nil? @title = nil @description = nil else @title, @description = ActiveSupport::JSON.decode(data) end end ################################################################## # get the rule attributes def title @title end def summary description || "Does Nothing" end def data [title, description].to_json end def expected_outcomes [:outcome => RulesEngine::Rule::Outcome::STOP_SUCCESS] end ################################################################## # set the rule attributes def attributes=(params) param_hash = params.symbolize_keys @title = param_hash[:<%=rule_name%>_title] @description = param_hash[:<%=rule_name%>_description] end ################################################################## # validation and errors def valid? @errors = {} @errors[:<%=rule_name%>_title] = "Title required" if title.blank? return @errors.empty? end ################################################################## # callbacks when the rule is added and removed from a workflow def before_add_to_workflow() end def before_remove_from_workflow() end ################################################################## # execute the rule # this rule stops the plan def process(process_id, data) RulesEngine::Process.auditor.audit(process_id, "Inside Rule #{title}", RulesEngine::Process::AUDIT_INFO) RulesEngine::Rule::Outcome.new(RulesEngine::Rule::Outcome::STOP_SUCCESS) end end end end