forked from Gitlink/forgeplus
change trustie-proejcts
This commit is contained in:
parent
f820250ad0
commit
5c28ad9c0a
|
@ -7,12 +7,11 @@ class SyncForgeController < ApplicationController
|
|||
sync_params = params[:sync_params]
|
||||
#以前已同步的项目,那么肯定存在仓库
|
||||
if Project.exists?(identifier: sync_params[:identifier])
|
||||
Rails.logger.info("=================begin_to_update_project========")
|
||||
SyncLog.sync_log("=================begin_to_update_project========")
|
||||
project = Project.find_by(identifier: sync_params[:identifier])
|
||||
Rails.logger.info("--------project_id:#{project.id}---------------")
|
||||
check_sync_project(project, sync_params)
|
||||
else #新建项目
|
||||
Rails.logger.info("=================begin_to_create_new_project========")
|
||||
SyncLog.sync_log("=================begin_to_create_new_project========")
|
||||
project_user = User.where(login: sync_params[:owner_login]).first
|
||||
project_params = {
|
||||
repository_name: sync_params[:identifier],
|
||||
|
@ -26,7 +25,7 @@ class SyncForgeController < ApplicationController
|
|||
sync_params.permit!
|
||||
score_params = sync_params[:project_score].merge(project_id: project.id)
|
||||
new_project_score = ProjectScore.create(score_params)
|
||||
Rails.logger.info("=================new_project_score:#{new_project_score.try(:id)}========")
|
||||
SyncLog.sync_log("=================new_project_score:#{new_project_score.try(:id)}========")
|
||||
end
|
||||
|
||||
SyncRepositoryJob.perform_later(sync_params[:owner_login], sync_params[:identifier], sync_params[:repository], get_sudomain) if sync_params[:repository].present?
|
||||
|
@ -82,7 +81,7 @@ class SyncForgeController < ApplicationController
|
|||
if request.subdomain === 'forgeplus'
|
||||
gitea_main = "https://trustie.net"
|
||||
end
|
||||
Rails.logger.info("----begin_to_check_sync_project----project_id:#{project.id}---------------")
|
||||
SyncLog.sync_log("----begin_to_check_sync_project----project_id:#{project.id}---------------")
|
||||
change_project_score(project, sync_params[:project_score], sync_params[:repository]) if sync_params[:repository].present? #更新project_score
|
||||
change_project_issues(project, sync_params[:issues],project.id, gitea_main)
|
||||
change_project_members(project, sync_params[:members],gitea_main)
|
||||
|
@ -90,13 +89,13 @@ class SyncForgeController < ApplicationController
|
|||
change_project_watchers(project, sync_params[:project_watchers],gitea_main)
|
||||
change_project_praises(project, sync_params[:praise_trends],gitea_main)
|
||||
rescue => e
|
||||
Rails.logger.info("=========check_sync_project_errors:#{e}===================")
|
||||
SyncLog.sync_log("=========check_sync_project_errors:#{e}===================")
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
def check_new_project(project,sync_params)
|
||||
Rails.logger.info("***8. begin_to_sync_new_project---------------")
|
||||
SyncLog.sync_log("***8. begin_to_sync_new_project---------------")
|
||||
sync_projects_params = {
|
||||
type: "Project",
|
||||
ids: sync_params[:id],
|
||||
|
@ -111,11 +110,11 @@ class SyncForgeController < ApplicationController
|
|||
end
|
||||
|
||||
SyncProjectsJob.perform_later(sync_projects_params, gitea_main)
|
||||
Rails.logger.info("***8. end_to_sync_new_project---------------")
|
||||
SyncLog.sync_log("***8. end_to_sync_new_project---------------")
|
||||
end
|
||||
|
||||
def change_project_praises(project, praises,gitea_main)
|
||||
Rails.logger.info("***6. begin_to_sync_parises---------------")
|
||||
SyncLog.sync_log("***6. begin_to_sync_parises---------------")
|
||||
forge_praises_ids = project&.praise_treads&.select(:id)&.pluck(:id)
|
||||
diff_target_ids = praises[:ids] - forge_praises_ids
|
||||
if diff_target_ids.size > 0
|
||||
|
@ -127,13 +126,13 @@ class SyncForgeController < ApplicationController
|
|||
}
|
||||
SyncProjectsJob.perform_later(sync_projects_params,gitea_main)
|
||||
|
||||
Rails.logger.info("***6. end_to_sync_parises---------------")
|
||||
SyncLog.sync_log("***6. end_to_sync_parises---------------")
|
||||
end
|
||||
end
|
||||
|
||||
#检查repository和project_score
|
||||
def change_project_score(project, project_scores, repository_params)
|
||||
Rails.logger.info("***1. begin_to_sync_project_score---------------")
|
||||
SyncLog.sync_log("***1. begin_to_sync_project_score---------------")
|
||||
begin
|
||||
pre_project_score = project.project_score
|
||||
if pre_project_score.present?
|
||||
|
@ -151,14 +150,14 @@ class SyncForgeController < ApplicationController
|
|||
else
|
||||
ProjectScore.create!(project_scores.merge(project_id: project.id))
|
||||
end
|
||||
Rails.logger.info("***1. end_to_sync_project_score---------------")
|
||||
SyncLog.sync_log("***1. end_to_sync_project_score---------------")
|
||||
rescue Exception => e
|
||||
Rails.logger.info("=========change_project_score_errors:#{e}===================")
|
||||
SyncLog.sync_log("=========change_project_score_errors:#{e}===================")
|
||||
end
|
||||
end
|
||||
|
||||
def change_project_issues(project, old_issues_params,project_id, gitea_main)
|
||||
Rails.logger.info("***2. begin_to_syncissues---------------")
|
||||
SyncLog.sync_log("***2. begin_to_syncissues---------------")
|
||||
begin
|
||||
forge_issue_ids = project&.issues&.select(:id)&.pluck(:id)
|
||||
forge_journal_ids = Journal.select([:id, :journalized_id, :journalized_type]).where(journalized_id: forge_issue_ids).pluck(:id)
|
||||
|
@ -183,14 +182,14 @@ class SyncForgeController < ApplicationController
|
|||
}
|
||||
end
|
||||
SyncProjectsJob.perform_later(sync_projects_params, gitea_main) if sync_projects_params.present?
|
||||
Rails.logger.info("***2. end_to_syncissues---------------")
|
||||
SyncLog.sync_log("***2. end_to_syncissues---------------")
|
||||
rescue Exception => e
|
||||
Rails.logger.info("=========change_project_issues_errors:#{e}===================")
|
||||
SyncLog.sync_log("=========change_project_issues_errors:#{e}===================")
|
||||
end
|
||||
end
|
||||
|
||||
def change_project_watchers(project, watchers,gitea_main)
|
||||
Rails.logger.info("***5. begin_to_sync_watchers---------------")
|
||||
SyncLog.sync_log("***5. begin_to_sync_watchers---------------")
|
||||
forge_watchers_ids = project&.watchers&.select(:id)&.pluck(:id)
|
||||
diff_target_ids = watchers[:ids] - forge_watchers_ids
|
||||
if diff_target_ids.size > 0
|
||||
|
@ -201,13 +200,13 @@ class SyncForgeController < ApplicationController
|
|||
parent_id: project.id
|
||||
}
|
||||
SyncProjectsJob.perform_later(sync_projects_params,gitea_main)
|
||||
Rails.logger.info("***5. begin_to_sync_watchers---------------")
|
||||
SyncLog.sync_log("***5. begin_to_sync_watchers---------------")
|
||||
|
||||
end
|
||||
end
|
||||
|
||||
def change_project_versions(project, versions,gitea_main)
|
||||
Rails.logger.info("***4. begin_to_sync_versions---------------")
|
||||
SyncLog.sync_log("***4. begin_to_sync_versions---------------")
|
||||
forge_version_ids = project&.versions&.select(:id)&.pluck(:id)
|
||||
diff_version_ids = versions[:ids] - forge_version_ids
|
||||
if diff_version_ids.size > 0
|
||||
|
@ -218,12 +217,12 @@ class SyncForgeController < ApplicationController
|
|||
parent_id: project.id
|
||||
}
|
||||
SyncProjectsJob.perform_later(sync_projects_params,gitea_main)
|
||||
Rails.logger.info("***4. end_to_sync_versions---------------")
|
||||
SyncLog.sync_log("***4. end_to_sync_versions---------------")
|
||||
end
|
||||
end
|
||||
|
||||
def change_project_members(project, members,gitea_main)
|
||||
Rails.logger.info("***3. begin_to_sync_members---------------")
|
||||
SyncLog.sync_log("***3. begin_to_sync_members---------------")
|
||||
forge_member_ids = project&.members&.select(:id)&.pluck(:id)
|
||||
diff_member_ids = members[:ids] - forge_member_ids
|
||||
if diff_member_ids.size > 0
|
||||
|
@ -234,7 +233,7 @@ class SyncForgeController < ApplicationController
|
|||
parent_id: project.id
|
||||
}
|
||||
SyncProjectsJob.perform_later(sync_projects_params,gitea_main)
|
||||
Rails.logger.info("***3. end_to_sync_members---------------")
|
||||
SyncLog.sync_log("***3. end_to_sync_members---------------")
|
||||
end
|
||||
end
|
||||
|
||||
|
@ -250,7 +249,7 @@ class SyncForgeController < ApplicationController
|
|||
end
|
||||
|
||||
def get_sudomain
|
||||
Rails.logger.info("=================request.subdomain:#{request.subdomain}========")
|
||||
SyncLog.sync_log("=================request.subdomain:#{request.subdomain}========")
|
||||
gitea_main = "testgitea.trustie.net"
|
||||
if request.subdomain === 'testforgeplus'
|
||||
gitea_main = "testgitea2.trustie.net"
|
||||
|
|
|
@ -146,6 +146,44 @@ class UsersController < ApplicationController
|
|||
render_ok
|
||||
end
|
||||
|
||||
def trustie_related_projects
|
||||
projects = Project.includes(:owner, :members, :project_score).where(id: params[:ids]).order("updated_on desc")
|
||||
projects_json = []
|
||||
if projects.present?
|
||||
projects.each do |p|
|
||||
pj = {
|
||||
id: p.id,
|
||||
name: p.name,
|
||||
is_public: p.is_public,
|
||||
updated_on: p.updated_on.strftime("%Y-%m-%d"),
|
||||
owner: {
|
||||
name: p.owner.try(:show_real_name),
|
||||
login: p.owner.login
|
||||
},
|
||||
members_count: p&.members.size,
|
||||
issues_count: p.issues_count - p.pull_requests_count,
|
||||
commits_count: p&.project_score&.changeset_num.to_i
|
||||
}
|
||||
projects_json.push(pj)
|
||||
end
|
||||
end
|
||||
Rails.logger.info("==========projects_json========+########{projects_json}")
|
||||
render json: { projects: projects_json }
|
||||
end
|
||||
|
||||
def trustie_projects
|
||||
user_id = User.select(:id, :login).where(login: params[:login])&.first&.id
|
||||
projects = Project.visible
|
||||
|
||||
projects = projects.joins(:members).where(members: { user_id: user_id })
|
||||
|
||||
search = params[:search].to_s.strip
|
||||
projects = projects.where('projects.name LIKE ?', "%#{search}%") if search.present?
|
||||
|
||||
projects = projects.select(:id, :name).limit(10).as_json
|
||||
render json: { projects: projects }
|
||||
end
|
||||
|
||||
def projects
|
||||
is_current_admin_user = User.current.logged? && (current_user&.admin? || current_user.id == @user.id)
|
||||
scope = Projects::ListMyQuery.call(params, @user,is_current_admin_user)
|
||||
|
|
|
@ -5,12 +5,11 @@ class SyncRepositoryJob < ApplicationJob
|
|||
|
||||
def perform(user_login, identifier, repository_params, gitea_main)
|
||||
#创建临时文件夹 clone 并强推代码
|
||||
SyncLog.sync_log("=================begin to sync request trustie repository:#{repository_params}=====================")
|
||||
SyncLog.sync_log("=================begin to sync request trustie repository=====================")
|
||||
path = "#{Rails.root}/public/cache_repository"
|
||||
image_url = repository_params[:git_url]
|
||||
gitlab_branches = repository_params[:gitlab_branches]
|
||||
image_repo_name = image_url.to_s.split('/')&.last&.chomp('.git')
|
||||
SyncLog.sync_project_log("========gitlab_branches:#{gitlab_branches}===================")
|
||||
unless File.directory?(path)
|
||||
FileUtils.mkdir_p(path)
|
||||
end
|
||||
|
@ -20,15 +19,11 @@ class SyncRepositoryJob < ApplicationJob
|
|||
end
|
||||
|
||||
check_clone = system("cd #{path} && git clone #{image_url}")
|
||||
SyncLog.sync_log("========check_clone:====cd #{path} && git clone #{image_url}=====success?:#{check_clone}==============")
|
||||
if check_clone
|
||||
|
||||
new_gitlab_url = "http://root:_Trustie_10010@#{gitea_main}/#{user_login}/#{identifier}.git"
|
||||
shell_remote_1 = system("cd #{path}/#{image_repo_name} && git remote set-url origin #{new_gitlab_url}")
|
||||
gitlab_branches.each do |branch|
|
||||
SyncLog.sync_log("========checkout_branch:#{branch}===================")
|
||||
shell5 = system("cd #{path}/#{image_repo_name} && git checkout #{branch} && git push --force --set-upstream origin #{branch}")
|
||||
SyncLog.sync_log("========checkout_branch_shell5:#{shell5}===================")
|
||||
if !shell5
|
||||
SyncLog.sync_project_log("=============force_push_erros==#{path}/#{image_repo_name}++branch:#{branch}")
|
||||
else
|
||||
|
|
|
@ -170,6 +170,8 @@ Rails.application.routes.draw do
|
|||
post :sync_token
|
||||
post :sync_gitea_pwd
|
||||
post :sync_salt
|
||||
get :trustie_projects
|
||||
get :trustie_related_projects
|
||||
end
|
||||
|
||||
scope module: :users do
|
||||
|
|
Loading…
Reference in New Issue