debian-mirror-gitlab/app/controllers/oauth/jira_dvcs/authorizations_controller.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

73 lines
2.5 KiB
Ruby
Raw Normal View History

2020-11-24 15:15:51 +05:30
# frozen_string_literal: true
# This controller's role is to mimic and rewire the GitLab OAuth
# flow routes for Jira DVCS integration.
# See https://gitlab.com/gitlab-org/gitlab/issues/2381
#
2022-06-21 17:19:12 +05:30
class Oauth::JiraDvcs::AuthorizationsController < ApplicationController
2020-11-24 15:15:51 +05:30
skip_before_action :authenticate_user!
skip_before_action :verify_authenticity_token
2023-03-04 22:38:38 +05:30
before_action :validate_redirect_uri, only: :new
2021-01-03 14:25:43 +05:30
feature_category :integrations
2020-11-24 15:15:51 +05:30
# 1. Rewire Jira OAuth initial request to our stablished OAuth authorization URL.
def new
session[:redirect_uri] = params['redirect_uri']
redirect_to oauth_authorization_path(client_id: params['client_id'],
response_type: 'code',
2021-06-08 01:23:25 +05:30
scope: normalize_scope(params['scope']),
2022-06-21 17:19:12 +05:30
redirect_uri: oauth_jira_dvcs_callback_url)
2020-11-24 15:15:51 +05:30
end
# 2. Handle the callback call as we were a Github Enterprise instance client.
def callback
# Handling URI query params concatenation.
redirect_uri = URI.parse(session['redirect_uri'])
new_query = URI.decode_www_form(String(redirect_uri.query)) << ['code', params[:code]]
redirect_uri.query = URI.encode_www_form(new_query)
redirect_to redirect_uri.to_s
end
# 3. Rewire and adjust access_token request accordingly.
def access_token
# We have to modify request.parameters because Doorkeeper::Server reads params from there
2022-06-21 17:19:12 +05:30
request.parameters[:redirect_uri] = oauth_jira_dvcs_callback_url
2020-11-24 15:15:51 +05:30
strategy = Doorkeeper::Server.new(self).token_request('authorization_code')
response = strategy.authorize
if response.status == :ok
access_token, scope, token_type = response.body.values_at('access_token', 'scope', 'token_type')
render body: "access_token=#{access_token}&scope=#{scope}&token_type=#{token_type}"
else
render status: response.status, body: response.body
end
rescue Doorkeeper::Errors::DoorkeeperError => e
render status: :unauthorized, body: e.type
end
2021-06-08 01:23:25 +05:30
private
# When using the GitHub Enterprise connector in Jira we receive the "repo" scope,
# this doesn't exist in GitLab but we can map it to our "api" scope.
def normalize_scope(scope)
scope == 'repo' ? 'api' : scope
end
2023-03-04 22:38:38 +05:30
def validate_redirect_uri
client = Doorkeeper::OAuth::Client.find(params[:client_id])
return render_404 unless client
return true if Doorkeeper::OAuth::Helpers::URIChecker.valid_for_authorization?(
params['redirect_uri'], client.redirect_uri
)
render_403
end
2020-11-24 15:15:51 +05:30
end