debian-mirror-gitlab/app/workers/repository_fork_worker.rb

35 lines
952 B
Ruby
Raw Normal View History

2015-09-25 12:07:36 +05:30
class RepositoryForkWorker
include Sidekiq::Worker
include Gitlab::ShellAdapter
sidekiq_options queue: :gitlab_shell
def perform(project_id, source_path, target_path)
project = Project.find_by_id(project_id)
unless project.present?
logger.error("Project #{project_id} no longer exists!")
return
end
result = gitlab_shell.fork_repository(source_path, target_path)
unless result
logger.error("Unable to fork project #{project_id} for repository #{source_path} -> #{target_path}")
2015-11-26 14:37:03 +05:30
project.update(import_error: "The project could not be forked.")
2015-09-25 12:07:36 +05:30
project.import_fail
return
end
2016-06-02 11:05:42 +05:30
project.repository.after_import
2015-11-26 14:37:03 +05:30
unless project.valid_repo?
2016-06-02 11:05:42 +05:30
logger.error("Project #{project_id} had an invalid repository after fork")
2015-11-26 14:37:03 +05:30
project.update(import_error: "The forked repository is invalid.")
project.import_fail
return
2015-09-25 12:07:36 +05:30
end
2015-11-26 14:37:03 +05:30
project.import_finish
2015-09-25 12:07:36 +05:30
end
end