forgeplus/app/jobs/check_mirror_job.rb

36 lines
1.5 KiB
Ruby

# 运行示例: bundle exec rails runner "CheckMirrorJob.new.call()"
class CheckMirrorJob < ApplicationJob
queue_as :default
def perform(project)
SyncLog.sync_log("==========begin_check_project_id_job:#{project.id}============")
begin
response = Gitea::Repository::Branches::ListService.new(project.owner, project.identifier).call
unless response.present?
SyncLog.sync_log("==========check_project_error_id:#{project.id}============")
ActiveRecord::Base.transaction do
delete_gitea = Gitea::Repository::DeleteService.new(project.owner, project.identifier).call
if delete_gitea.status == 204 || delete_gitea.status == 404 #删除成功或者仓库不存在,都重新创建
repository_params= {
name: project.identifier,
auto_init: true,
private: project.repository.hidden,
}
gitea_repository = Gitea::Repository::CreateService.new(project.owner.gitea_token, repository_params).call
if gitea_repository
project.update_columns(gpid: gitea_repository["id"],forked_count: gitea_repository["forks_count"])
else
SyncLog.sync_log("==========gitea_repository_created_failed:#{project.id}============")
end
else
SyncLog.sync_log("==========delete_gitea_failed:#{project.id}============")
end
end
end
rescue => e
SyncLog.sync_log("==========failed_check_project_id:#{project.id}============errors:#{e}")
end
end
end