57 lines
1.5 KiB
Python
57 lines
1.5 KiB
Python
|
from oauth.base import OAuthService
|
||
|
from util import slash_join
|
||
|
|
||
|
class GitLabOAuthService(OAuthService):
|
||
|
def __init__(self, config, key_name):
|
||
|
super(GitLabOAuthService, self).__init__(config, key_name)
|
||
|
|
||
|
def service_id(self):
|
||
|
return 'gitlab'
|
||
|
|
||
|
def service_name(self):
|
||
|
return 'GitLab'
|
||
|
|
||
|
def _endpoint(self):
|
||
|
return self.config.get('GITLAB_ENDPOINT', 'https://gitlab.com')
|
||
|
|
||
|
def user_endpoint(self):
|
||
|
raise NotImplementedError
|
||
|
|
||
|
def api_endpoint(self):
|
||
|
return self._endpoint()
|
||
|
|
||
|
def get_public_url(self, suffix):
|
||
|
return slash_join(self._endpoint(), suffix)
|
||
|
|
||
|
def authorize_endpoint(self):
|
||
|
return slash_join(self._endpoint(), '/oauth/authorize')
|
||
|
|
||
|
def token_endpoint(self):
|
||
|
return slash_join(self._endpoint(), '/oauth/token')
|
||
|
|
||
|
def validate_client_id_and_secret(self, http_client, app_config):
|
||
|
url = self.token_endpoint()
|
||
|
redirect_uri = self.get_redirect_uri(app_config, redirect_suffix='trigger')
|
||
|
data = {
|
||
|
'code': 'fakecode',
|
||
|
'client_id': self.client_id(),
|
||
|
'client_secret': self.client_secret(),
|
||
|
'grant_type': 'authorization_code',
|
||
|
'redirect_uri': redirect_uri
|
||
|
}
|
||
|
|
||
|
# We validate by checking the error code we receive from this call.
|
||
|
result = http_client.post(url, data=data, timeout=5)
|
||
|
value = result.json()
|
||
|
if not value:
|
||
|
return False
|
||
|
|
||
|
return value.get('error', '') != 'invalid_client'
|
||
|
|
||
|
def get_public_config(self):
|
||
|
return {
|
||
|
'CLIENT_ID': self.client_id(),
|
||
|
'AUTHORIZE_ENDPOINT': self.authorize_endpoint(),
|
||
|
'GITLAB_ENDPOINT': self._endpoint(),
|
||
|
}
|