2018-11-19 10:03:58 -05:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2020-02-19 13:09:10 -05:00
|
|
|
class RepositoryCleanupWorker # rubocop:disable Scalability/IdempotentWorker
|
2018-11-19 10:03:58 -05:00
|
|
|
include ApplicationWorker
|
|
|
|
|
|
|
|
sidekiq_options retry: 3
|
2019-10-18 07:11:44 -04:00
|
|
|
feature_category :source_code_management
|
2018-11-19 10:03:58 -05:00
|
|
|
|
|
|
|
sidekiq_retries_exhausted do |msg, err|
|
|
|
|
next if err.is_a?(ActiveRecord::RecordNotFound)
|
|
|
|
|
|
|
|
args = msg['args'] + [msg['error_message']]
|
|
|
|
|
|
|
|
new.perform_failure(*args)
|
|
|
|
end
|
|
|
|
|
|
|
|
def perform(project_id, user_id)
|
|
|
|
project = Project.find(project_id)
|
|
|
|
user = User.find(user_id)
|
|
|
|
|
|
|
|
Projects::CleanupService.new(project, user).execute
|
|
|
|
|
|
|
|
notification_service.repository_cleanup_success(project, user)
|
|
|
|
end
|
|
|
|
|
|
|
|
def perform_failure(project_id, user_id, error)
|
|
|
|
project = Project.find(project_id)
|
|
|
|
user = User.find(user_id)
|
|
|
|
|
|
|
|
# Ensure the file is removed
|
|
|
|
project.bfg_object_map.remove!
|
|
|
|
notification_service.repository_cleanup_failure(project, user, error)
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def notification_service
|
|
|
|
@notification_service ||= NotificationService.new
|
|
|
|
end
|
|
|
|
end
|