# frozen_string_literal: true module Projects class AfterImportWorker include ApplicationWorker RESERVED_REF_PREFIXES = Repository::RESERVED_REFS_NAMES.map { |n| File.join('refs', n, '/') } data_consistency :always idempotent! urgency :low feature_category :importers def perform(project_id) @project = Project.find(project_id) service = Repositories::HousekeepingService.new(@project) service.execute do import_failure_service.with_retry(action: 'delete_all_refs') do repository.delete_all_refs_except(RESERVED_REF_PREFIXES) end end # Right now we don't actually have a way to know if a project # import actually changed, so we increment the counter to avoid # causing GC to run every time. service.increment! rescue Repositories::HousekeepingService::LeaseTaken => e Gitlab::Import::Logger.info( message: 'Project housekeeping failed', project_full_path: @project.full_path, project_id: @project.id, 'error.message' => e.message ) end private def import_failure_service Gitlab::ImportExport::ImportFailureService.new(@project) end def repository @project.repository end end end