589b2db06c
This sets up all the basics for importing Phabricator tasks into GitLab issues. To import all tasks from a Phabricator instance into GitLab, we'll import all of them into a new project that will have its repository disabled. The import is hooked into a regular ProjectImport setup, but similar to the GitHub parallel importer takes care of all the imports itself. In this iteration, we're importing each page of tasks in a separate sidekiq job. The first thing we do when requesting a new page of tasks is schedule the next page to be imported. But to avoid deadlocks, we only allow a single job per worker type to run at the same time. For now we're only importing basic Issue information, this should be extended to richer information.
41 lines
1 KiB
Ruby
41 lines
1 KiB
Ruby
# frozen_string_literal: true
|
|
module Gitlab
|
|
module PhabricatorImport
|
|
module Conduit
|
|
class Client
|
|
def initialize(phabricator_url, api_token)
|
|
@phabricator_url = phabricator_url
|
|
@api_token = api_token
|
|
end
|
|
|
|
def get(path, params: {})
|
|
response = Gitlab::HTTP.get(build_url(path), body: build_params(params), headers: headers)
|
|
Response.parse!(response)
|
|
rescue *Gitlab::HTTP::HTTP_ERRORS => e
|
|
# Wrap all errors from the API into an API-error.
|
|
raise ApiError.new(e)
|
|
end
|
|
|
|
private
|
|
|
|
attr_reader :phabricator_url, :api_token
|
|
|
|
def headers
|
|
{ "Accept" => 'application/json' }
|
|
end
|
|
|
|
def build_url(path)
|
|
URI.join(phabricator_url, '/api/', path).to_s
|
|
end
|
|
|
|
def build_params(params)
|
|
params = params.dup
|
|
params.compact!
|
|
params.reverse_merge!("api.token" => api_token)
|
|
|
|
CGI.unescape(params.to_query)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|