class JobsController < ApplicationController before_filter :authenticate_admin! def index @jobs = Delayed::Job.page(params[:page]) respond_to do |format| format.html { render layout: !request.xhr? } format.json { render json: @jobs } end end def destroy @job = Delayed::Job.find(params[:id]) respond_to do |format| if !running? && @job.destroy format.html { redirect_to jobs_path, notice: "Job deleted." } format.json { render json: "", status: :ok } else format.html { redirect_to jobs_path, alert: 'Can not delete a running job.' } format.json { render json: "", status: :unprocessable_entity } end end end def run @job = Delayed::Job.find(params[:id]) @job.last_error = nil respond_to do |format| if !running? && @job.update_attributes!(run_at: Time.now, failed_at: nil) format.html { redirect_to jobs_path, notice: "Job enqueued." } format.json { render json: @job, status: :ok } else format.html { redirect_to jobs_path, alert: 'Can not enqueue a running job.' } format.json { render json: "", status: :unprocessable_entity } end end end def destroy_failed Delayed::Job.where.not(failed_at: nil).delete_all respond_to do |format| format.html { redirect_to jobs_path, notice: "Failed jobs removed." } format.json { render json: '', status: :ok } end end private def running? @job.locked_at || @job.locked_by end end