HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux vmi1674223.contaboserver.net 5.4.0-182-generic #202-Ubuntu SMP Fri Apr 26 12:29:36 UTC 2024 x86_64
User: root (0)
PHP: 7.4.3-4ubuntu2.22
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: //opt/openproject/config/initializers/job_status.rb
#-- encoding: UTF-8

#-- copyright
# OpenProject is an open source project management software.
# Copyright (C) 2012-2020 the OpenProject GmbH
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License version 3.
#
# OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows:
# Copyright (C) 2006-2017 Jean-Philippe Lang
# Copyright (C) 2010-2013 the ChiliProject Team
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
#
# See docs/COPYRIGHT.rdoc for more details.
#++

# Extends the ActiveJob adapter in use (DelayedJob) by a Status which lives
# indenpendently from the job itself (which is deleted once successful or after max attempts).
# That way, the result of a background job is available even after the original job is gone.

ActiveSupport::Notifications.subscribe "perform.active_job" do |job:, exception_object: nil, **_args|
  next unless job.status_reference

  # job.provider_job_id is not filled at this point as
  # the ActiveJob adapter for DelayedJob is only setting it
  # on enqueue and enqueue_at.
  if exception_object
    dj_job_attempts = Delayed::Job.where(id: Delayed::Job::Status.of_reference(job.status_reference).select(:job_id))
                      .pluck(:attempts)
                      .first || 1

    new_status = if dj_job_attempts + 1 >= Delayed::Worker.max_attempts
                   :failure
                 else
                   :error
                 end

    Delayed::Job::Status
      .of_reference(job.status_reference)
      .update(status: new_status,
              message: exception_object)
  else
    Delayed::Job::Status
      .of_reference(job.status_reference)
      .update(status: :success)
  end
end

ActiveSupport::Notifications.subscribe "enqueue.active_job" do |job:, **_args|
  if job.status_reference
    Delayed::Job::Status.create(status: :in_queue,
                                reference: job.status_reference,
                                job_id: job.provider_job_id)
  end
end

ActiveSupport::Notifications.subscribe "enqueue_at.active_job" do |job:, **_args|
  if job.status_reference
    Delayed::Job::Status.create(status: :in_queue,
                                reference: job.status_reference,
                                job_id: job.provider_job_id)
  end
end