Class: RcrewAI::Rails::Execution
- Inherits:
-
ApplicationRecord
- Object
- ActiveRecord::Base
- ApplicationRecord
- RcrewAI::Rails::Execution
- Defined in:
- app/models/rcrewai/rails/execution.rb
Instance Method Summary collapse
- #cancel! ⇒ Object
- #complete!(result) ⇒ Object
- #completed? ⇒ Boolean
- #fail!(error) ⇒ Object
- #failed? ⇒ Boolean
- #finished? ⇒ Boolean
- #log(level, message, details = {}) ⇒ Object
- #running? ⇒ Boolean
- #start! ⇒ Object
Instance Method Details
#cancel! ⇒ Object
53 54 55 56 57 58 59 |
# File 'app/models/rcrewai/rails/execution.rb', line 53 def cancel! update!( status: "cancelled", completed_at: Time.current, duration_seconds: calculate_duration ) end |
#complete!(result) ⇒ Object
30 31 32 33 34 35 36 37 |
# File 'app/models/rcrewai/rails/execution.rb', line 30 def complete!(result) update!( status: "completed", output: result, completed_at: Time.current, duration_seconds: calculate_duration ) end |
#completed? ⇒ Boolean
65 66 67 |
# File 'app/models/rcrewai/rails/execution.rb', line 65 def completed? status == "completed" end |
#fail!(error) ⇒ Object
39 40 41 42 43 44 45 46 47 48 49 50 51 |
# File 'app/models/rcrewai/rails/execution.rb', line 39 def fail!(error) update!( status: "failed", error_message: error., error_details: { class: error.class.name, message: error., backtrace: error.backtrace&.first(10) }, completed_at: Time.current, duration_seconds: calculate_duration ) end |
#failed? ⇒ Boolean
69 70 71 |
# File 'app/models/rcrewai/rails/execution.rb', line 69 def failed? status == "failed" end |
#finished? ⇒ Boolean
73 74 75 |
# File 'app/models/rcrewai/rails/execution.rb', line 73 def finished? %w[completed failed cancelled].include?(status) end |
#log(level, message, details = {}) ⇒ Object
77 78 79 80 81 82 83 84 |
# File 'app/models/rcrewai/rails/execution.rb', line 77 def log(level, , details = {}) execution_logs.create!( level: level, message: , details: details, timestamp: Time.current ) end |
#running? ⇒ Boolean
61 62 63 |
# File 'app/models/rcrewai/rails/execution.rb', line 61 def running? status == "running" end |
#start! ⇒ Object
23 24 25 26 27 28 |
# File 'app/models/rcrewai/rails/execution.rb', line 23 def start! update!( status: "running", started_at: Time.current ) end |