change sync
This commit is contained in:
parent
8c1aedc6bd
commit
6e31352f8d
|
@ -26,8 +26,11 @@ class SyncProjectsJob < ApplicationJob
|
||||||
if response.status == 200
|
if response.status == 200
|
||||||
target_jsons = response.body
|
target_jsons = response.body
|
||||||
SyncLog.sync_log.info("=========target_jsons: #{target_jsons}============")
|
SyncLog.sync_log.info("=========target_jsons: #{target_jsons}============")
|
||||||
if target_jsons.present? && sync_params[:type]
|
target_jsons = eval(target_jsons)
|
||||||
create_target(eval(target_jsons), sync_params[:type].to_s)
|
if sync_params[:type] == "Project"
|
||||||
|
update_new_project(target_jsons, sync_params[:new_project_id])
|
||||||
|
else
|
||||||
|
create_target(project, eval(target_jsons), sync_params[:type].to_s)
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
SyncLog.sync_log.info("==========sync_project_to_forge_failed #{sync_params[:type]}============")
|
SyncLog.sync_log.info("==========sync_project_to_forge_failed #{sync_params[:type]}============")
|
||||||
|
@ -38,32 +41,38 @@ class SyncProjectsJob < ApplicationJob
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def update_new_project(re, project_id)
|
||||||
|
project = Project.find_by(id: project_id)
|
||||||
|
project.update(re[:target_params].compact!) if re[:target_params].present?
|
||||||
|
create_target(re[:issues_params], "Issue") if re[:issues_params].present?
|
||||||
|
create_target(re[:member_params], "Member") if re[:member_params].present?
|
||||||
|
create_target(re[:versions_params], "Version") if re[:versions_params].present?
|
||||||
|
create_target(re[:watcher_params], "Watcher") if re[:watcher_params].present?
|
||||||
|
create_target(re[:praise_treads], "PraiseTread") if re[:praise_treads].present?
|
||||||
|
end
|
||||||
|
|
||||||
def create_target(target_jsons, target_type)
|
|
||||||
|
def create_target(project, target_jsons, target_type)
|
||||||
Rails.logger.info("***111222. begin_to_create_target---------------")
|
Rails.logger.info("***111222. begin_to_create_target---------------")
|
||||||
target_jsons.each do |re|
|
target_jsons.each do |re|
|
||||||
Rails.logger.info("***user_login:#{re[:user_login]}----target_type:#{target_type}")
|
if re[:target_params].present?
|
||||||
u_id = User.select(:id, :login).where(login: re[:user_login]).pluck(:id).first
|
Rails.logger.info("***user_login:#{re[:user_login]}----target_type:#{target_type}")
|
||||||
|
u_id = User.select(:id, :login).where(login: re[:user_login]).pluck(:id).first
|
||||||
|
|
||||||
new_target = target_type.constantize.new(re[:target_params].merge(user_id: u_id))
|
new_target = target_type.constantize.new(re[:target_params].merge(user_id: u_id))
|
||||||
if target_type == "Project"
|
|
||||||
create_target(re[:issues_params], "Issue") if re[:issues_params].present?
|
if target_type == "Issue"
|
||||||
create_target(re[:member_params], "Member") if re[:member_params].present?
|
assing_u_id = User.select(:id, :login).where(login: re[:assign_login]).pluck(:id).first
|
||||||
create_target(re[:versions_params], "Version") if re[:versions_params].present?
|
new_target.assigned_to_id = assing_u_id
|
||||||
create_target(re[:watcher_params], "Watcher") if re[:watcher_params].present?
|
if re[:journals].present?
|
||||||
create_target(re[:praise_treads], "PraiseTread") if re[:praise_treads].present?
|
create_target(project, re[:journals], "Journal")
|
||||||
end
|
end
|
||||||
if target_type == "Issue"
|
|
||||||
assing_u_id = User.select(:id, :login).where(login: re[:assign_login]).pluck(:id).first
|
|
||||||
new_target.assigned_to_id = assing_u_id
|
|
||||||
if re[:journals].present?
|
|
||||||
create_target(re[:journals], "Journal")
|
|
||||||
end
|
end
|
||||||
end
|
if new_target.save!
|
||||||
if new_target.save!
|
if re[:journal_details].present?
|
||||||
if re[:journal_details].present?
|
re[:journal_details].each do |j|
|
||||||
re[:journal_details].each do |j|
|
JournalDetail.create!(j[:journal_detail].merge(journal_id: new_target.id))
|
||||||
JournalDetail.create!(j[:journal_detail].merge(journal_id: new_target.id))
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue