gitlab-org--gitlab-foss/lib/gitlab/phabricator_import/conduit/client.rb
Bob Van Landuyt 589b2db06c Setup Phabricator import
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.
2019-05-31 09:40:54 +02:00

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