Class: SolidQueueMonitor::FailedJobService
- Inherits:
-
Object
- Object
- SolidQueueMonitor::FailedJobService
- Defined in:
- app/services/solid_queue_monitor/failed_job_service.rb
Instance Method Summary collapse
- #discard_all(job_ids) ⇒ Object
- #discard_job(failed_execution_id) ⇒ Object
- #retry_all(job_ids) ⇒ Object
- #retry_job(failed_execution_id) ⇒ Object
Instance Method Details
#discard_all(job_ids) ⇒ Object
63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 |
# File 'app/services/solid_queue_monitor/failed_job_service.rb', line 63 def discard_all(job_ids) return { success: false, message: "No jobs selected" } if job_ids.blank? success_count = 0 failed_count = 0 job_ids.each do |id| result = discard_job(id) if result[:success] success_count += 1 else failed_count += 1 end end if success_count > 0 && failed_count == 0 { success: true, message: "All selected jobs have been discarded" } elsif success_count > 0 && failed_count > 0 { success: true, message: "#{success_count} jobs discarded, #{failed_count} failed" } else { success: false, message: "Failed to discard jobs" } end end |
#discard_job(failed_execution_id) ⇒ Object
23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 |
# File 'app/services/solid_queue_monitor/failed_job_service.rb', line 23 def discard_job(failed_execution_id) failed_execution = SolidQueue::FailedExecution.find_by(id: failed_execution_id) return { success: false, message: "Failed job not found" } unless failed_execution job = failed_execution.job return { success: false, message: "Associated job not found" } unless job ActiveRecord::Base.transaction do job.update!(finished_at: Time.current) failed_execution.destroy! end { success: true, message: "Job has been discarded" } end |
#retry_all(job_ids) ⇒ Object
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 |
# File 'app/services/solid_queue_monitor/failed_job_service.rb', line 39 def retry_all(job_ids) return { success: false, message: "No jobs selected" } if job_ids.blank? success_count = 0 failed_count = 0 job_ids.each do |id| result = retry_job(id) if result[:success] success_count += 1 else failed_count += 1 end end if success_count > 0 && failed_count == 0 { success: true, message: "All selected jobs have been queued for retry" } elsif success_count > 0 && failed_count > 0 { success: true, message: "#{success_count} jobs queued for retry, #{failed_count} failed" } else { success: false, message: "Failed to retry jobs" } end end |
#retry_job(failed_execution_id) ⇒ Object
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
# File 'app/services/solid_queue_monitor/failed_job_service.rb', line 3 def retry_job(failed_execution_id) failed_execution = SolidQueue::FailedExecution.find_by(id: failed_execution_id) return { success: false, message: "Failed job not found" } unless failed_execution job = failed_execution.job return { success: false, message: "Associated job not found" } unless job ActiveRecord::Base.transaction do SolidQueue::ReadyExecution.create!( job_id: job.id, queue_name: get_queue_name(failed_execution, job), priority: job.priority ) failed_execution.destroy! end { success: true, message: "Job moved to ready queue for retry" } end |