Class: Sequent::Core::Workflow
- Inherits:
-
Object
- Object
- Sequent::Core::Workflow
- Includes:
- Helpers::MessageHandler
- Defined in:
- lib/sequent/core/workflow.rb
Instance Method Summary collapse
-
#after_commit(ignore_errors: false, &block) ⇒ Object
Workflow#after_commit will accept a block to execute after the transaction commits.
- #execute_commands(*commands) ⇒ Object
Methods included from Helpers::MessageHandler
Instance Method Details
#after_commit(ignore_errors: false, &block) ⇒ Object
Workflow#after_commit will accept a block to execute after the transaction commits. This is very useful to isolate side-effects. They will run only on the transaction’s success and will not be able to roll it back when there is an exception. Useful if your background jobs processor is not using the same database connection to enqueue jobs.
19 20 21 22 23 24 25 26 27 |
# File 'lib/sequent/core/workflow.rb', line 19 def after_commit(ignore_errors: false, &block) Sequent.configuration.transaction_provider.after_commit &block rescue StandardError => error if ignore_errors Sequent.logger.warn("An exception was raised in an after_commit hook: #{error}, #{error.inspect}") else raise error end end |
#execute_commands(*commands) ⇒ Object
8 9 10 |
# File 'lib/sequent/core/workflow.rb', line 8 def execute_commands(*commands) Sequent.configuration.command_service.execute_commands(*commands) end |