Class: FlowChat::BaseExecutor
- Inherits:
-
Object
- Object
- FlowChat::BaseExecutor
- Defined in:
- lib/flow_chat/base_executor.rb
Direct Known Subclasses
Http::Middleware::Executor, Ussd::Middleware::Executor, Whatsapp::Middleware::Executor
Instance Method Summary collapse
- #call(context) ⇒ Object
-
#initialize(app) ⇒ BaseExecutor
constructor
A new instance of BaseExecutor.
Constructor Details
#initialize(app) ⇒ BaseExecutor
Returns a new instance of BaseExecutor.
3 4 5 6 |
# File 'lib/flow_chat/base_executor.rb', line 3 def initialize(app) @app = app FlowChat.logger.debug { "#{log_prefix}: Initialized #{platform_name} executor middleware" } end |
Instance Method Details
#call(context) ⇒ Object
8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 |
# File 'lib/flow_chat/base_executor.rb', line 8 def call(context) flow_class = context.flow action = context["flow.action"] session_id = context["session.id"] FlowChat.logger.info { "#{log_prefix}: Executing flow #{flow_class.name}##{action} for session #{session_id}" } platform_app = build_platform_app(context) FlowChat.logger.debug { "#{log_prefix}: #{platform_name} app built for flow execution" } flow = flow_class.new platform_app FlowChat.logger.debug { "#{log_prefix}: Flow instance created, invoking #{action} method" } flow.send action FlowChat.logger.warn { "#{log_prefix}: Flow execution failed to interact with user for #{flow_class.name}##{action}" } raise FlowChat::Interrupt::Terminate, "Unexpected end of flow." rescue FlowChat::Interrupt::RestartFlow => e FlowChat.logger.info { "#{log_prefix}: Flow restart requested - Session: #{session_id}, restarting #{action}" } retry rescue FlowChat::Interrupt::Prompt => e FlowChat.logger.info { "#{log_prefix}: Flow prompted user - Session: #{session_id}, Prompt: '#{e.prompt&.truncate(100)}'" } FlowChat.logger.debug { "#{log_prefix}: Prompt details - Choices: #{e.choices&.size || 0}, Has media: #{!e.media.nil?}" } [:prompt, e.prompt, e.choices, e.media] rescue FlowChat::Interrupt::Terminate => e FlowChat.logger.info { "#{log_prefix}: Flow terminated - Session: #{session_id}, Message: '#{e.prompt&.truncate(100)}'" } FlowChat.logger.debug { "#{log_prefix}: Destroying session #{session_id}" } context.session.destroy [:terminal, e.prompt, nil, e.media] rescue => error FlowChat.logger.error { "#{log_prefix}: Flow execution failed - #{flow_class.name}##{action}, Session: #{session_id}, Error: #{error.class.name}: #{error.}" } FlowChat.logger.debug { "#{log_prefix}: Stack trace: #{error.backtrace.join("\n")}" } raise end |