Class: RcrewAI::Rails::Execution

Inherits:
ApplicationRecord show all
Defined in:
app/models/rcrewai/rails/execution.rb

Instance Method Summary collapse

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

Returns:

  • (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.message,
    error_details: {
      class: error.class.name,
      message: error.message,
      backtrace: error.backtrace&.first(10)
    },
    completed_at: Time.current,
    duration_seconds: calculate_duration
  )
end

#failed?Boolean

Returns:

  • (Boolean)


69
70
71
# File 'app/models/rcrewai/rails/execution.rb', line 69

def failed?
  status == "failed"
end

#finished?Boolean

Returns:

  • (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, message, details = {})
  execution_logs.create!(
    level: level,
    message: message,
    details: details,
    timestamp: Time.current
  )
end

#running?Boolean

Returns:

  • (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