be42c05054
Enables frozen string for the following: * app/controllers/dashboard/**/*.rb * app/controllers/explore/**/*.rb * app/controllers/google_api/**/*.rb * app/controllers/groups/**/*.rb * app/controllers/import/**/*.rb * app/controllers/instance_statistics/**/*.rb * app/controllers/ldap/**/*.rb * app/controllers/oauth/**/*.rb * app/controllers/profiles/**/*.rb Partially addresses #47424.
105 lines
2.8 KiB
Ruby
105 lines
2.8 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class Import::FogbugzController < Import::BaseController
|
|
before_action :verify_fogbugz_import_enabled
|
|
before_action :user_map, only: [:new_user_map, :create_user_map]
|
|
|
|
rescue_from Fogbugz::AuthenticationException, with: :fogbugz_unauthorized
|
|
|
|
def new
|
|
end
|
|
|
|
def callback
|
|
begin
|
|
res = Gitlab::FogbugzImport::Client.new(import_params.symbolize_keys)
|
|
rescue
|
|
# If the URI is invalid various errors can occur
|
|
return redirect_to new_import_fogbugz_path, alert: 'Could not connect to FogBugz, check your URL'
|
|
end
|
|
session[:fogbugz_token] = res.get_token
|
|
session[:fogbugz_uri] = params[:uri]
|
|
|
|
redirect_to new_user_map_import_fogbugz_path
|
|
end
|
|
|
|
def new_user_map
|
|
end
|
|
|
|
def create_user_map
|
|
user_map = params[:users]
|
|
|
|
unless user_map.is_a?(Hash) && user_map.all? { |k, v| !v[:name].blank? }
|
|
flash.now[:alert] = 'All users must have a name.'
|
|
|
|
return render 'new_user_map'
|
|
end
|
|
|
|
session[:fogbugz_user_map] = user_map
|
|
|
|
flash[:notice] = 'The user map has been saved. Continue by selecting the projects you want to import.'
|
|
|
|
redirect_to status_import_fogbugz_path
|
|
end
|
|
|
|
# rubocop: disable CodeReuse/ActiveRecord
|
|
def status
|
|
unless client.valid?
|
|
return redirect_to new_import_fogbugz_path
|
|
end
|
|
|
|
@repos = client.repos
|
|
|
|
@already_added_projects = find_already_added_projects('fogbugz')
|
|
already_added_projects_names = @already_added_projects.pluck(:import_source)
|
|
|
|
@repos.reject! { |repo| already_added_projects_names.include? repo.name }
|
|
end
|
|
# rubocop: enable CodeReuse/ActiveRecord
|
|
|
|
def jobs
|
|
render json: find_jobs('fogbugz')
|
|
end
|
|
|
|
def create
|
|
repo = client.repo(params[:repo_id])
|
|
fb_session = { uri: session[:fogbugz_uri], token: session[:fogbugz_token] }
|
|
umap = session[:fogbugz_user_map] || client.user_map
|
|
|
|
project = Gitlab::FogbugzImport::ProjectCreator.new(repo, fb_session, current_user.namespace, current_user, umap).execute
|
|
|
|
if project.persisted?
|
|
render json: ProjectSerializer.new.represent(project)
|
|
else
|
|
render json: { errors: project_save_error(project) }, status: :unprocessable_entity
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def client
|
|
@client ||= Gitlab::FogbugzImport::Client.new(token: session[:fogbugz_token], uri: session[:fogbugz_uri])
|
|
end
|
|
|
|
def user_map
|
|
@user_map ||= begin
|
|
user_map = client.user_map
|
|
|
|
stored_user_map = session[:fogbugz_user_map]
|
|
user_map.update(stored_user_map) if stored_user_map
|
|
|
|
user_map
|
|
end
|
|
end
|
|
|
|
def fogbugz_unauthorized(exception)
|
|
redirect_to new_import_fogbugz_path, alert: exception.message
|
|
end
|
|
|
|
def import_params
|
|
params.permit(:uri, :email, :password)
|
|
end
|
|
|
|
def verify_fogbugz_import_enabled
|
|
render_404 unless fogbugz_import_enabled?
|
|
end
|
|
end
|