mirror of
https://github.com/opf/openproject.git
synced 2026-06-14 03:30:14 +00:00
93 lines
2.9 KiB
Ruby
93 lines
2.9 KiB
Ruby
|
|
# frozen_string_literal: true
|
||
|
|
|
||
|
|
#-- copyright
|
||
|
|
# OpenProject is an open source project management software.
|
||
|
|
# Copyright (C) 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-2013 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 COPYRIGHT and LICENSE files for more details.
|
||
|
|
#++
|
||
|
|
|
||
|
|
# Shared setup for jobs.
|
||
|
|
#
|
||
|
|
# This module is included in `ApplicationJob` and `Mails::MailerJob` and does
|
||
|
|
# the following:
|
||
|
|
#
|
||
|
|
# - disable logging of arguments
|
||
|
|
# - before each job execution:
|
||
|
|
# - reloads the mailer settings
|
||
|
|
# - resets the request store
|
||
|
|
# - tags the request for AppSignal
|
||
|
|
module SharedJobSetup
|
||
|
|
extend ActiveSupport::Concern
|
||
|
|
|
||
|
|
included do
|
||
|
|
# By default, do not log the arguments of a background job
|
||
|
|
# to avoid leaking sensitive information to logs
|
||
|
|
self.log_arguments = false
|
||
|
|
|
||
|
|
around_perform :prepare_job_context
|
||
|
|
end
|
||
|
|
|
||
|
|
# Prepare the job execution by cleaning the request store, reloading the
|
||
|
|
# mailer settings and tagging the request
|
||
|
|
def prepare_job_context
|
||
|
|
with_clean_request_store do
|
||
|
|
::OpenProject::Appsignal.tag_request
|
||
|
|
reload_mailer_settings!
|
||
|
|
|
||
|
|
yield
|
||
|
|
end
|
||
|
|
end
|
||
|
|
|
||
|
|
# Resets the thread local request store.
|
||
|
|
#
|
||
|
|
# This should be done, because normal application code expects the
|
||
|
|
# RequestStore to be invalidated between multiple requests and does usually
|
||
|
|
# not care whether it is executed from a request or from a job.
|
||
|
|
#
|
||
|
|
# For a job, each job execution is the thing that comes closest to the concept
|
||
|
|
# of a new request.
|
||
|
|
def with_clean_request_store
|
||
|
|
store = RequestStore.store
|
||
|
|
|
||
|
|
begin
|
||
|
|
RequestStore.clear!
|
||
|
|
yield
|
||
|
|
ensure
|
||
|
|
# Reset to previous value
|
||
|
|
RequestStore.clear!
|
||
|
|
RequestStore.store.merge! store
|
||
|
|
end
|
||
|
|
end
|
||
|
|
|
||
|
|
# Reloads the thread local ActionMailer configuration.
|
||
|
|
#
|
||
|
|
# Since the email configuration is done in the web app, it makes sure that any
|
||
|
|
# changes to the configuration is correctly picked up by the background jobs
|
||
|
|
# at runtime.
|
||
|
|
def reload_mailer_settings!
|
||
|
|
Setting.reload_mailer_settings!
|
||
|
|
end
|
||
|
|
end
|