Added support for disabling ssl verification on gitlab backend

This commit is contained in:
root 2017-03-02 18:46:03 +00:00
parent 55737cf247
commit b9ba692a42
3 changed files with 18 additions and 14 deletions

View file

@ -53,7 +53,7 @@ def get_instance_url(operation):
try: try:
url = change_url(operation.instance) url = change_url(operation.instance)
except NoReverseMatch: except NoReverseMatch:
alt_repr = '%s-%i' % (operation.content_type, operation.object_id) alt_repr = '%s-%s' % (operation.content_type, operation.object_id)
return _("Deleted {0}").format(operation.instance_repr or alt_repr) return _("Deleted {0}").format(operation.instance_repr or alt_repr)
return orchestra_settings.ORCHESTRA_SITE_URL + url return orchestra_settings.ORCHESTRA_SITE_URL + url

View file

@ -15,9 +15,10 @@ class GitLabSaaSController(ServiceController):
serialize = True serialize = True
actions = ('save', 'delete', 'validate_creation') actions = ('save', 'delete', 'validate_creation')
doc_settings = (settings, doc_settings = (settings,
('SAAS_GITLAB_DOMAIN', 'SAAS_GITLAB_ROOT_PASSWORD'), ('SAAS_GITLAB_DOMAIN', 'SAAS_GITLAB_ROOT_PASSWORD', 'SAAS_GITLAB_VERIFY_SSL'),
) )
verify = settings.SAAS_GITLAB_VERIFY_SSL
def get_base_url(self): def get_base_url(self):
return 'https://%s/api/v3' % settings.SAAS_GITLAB_DOMAIN return 'https://%s/api/v3' % settings.SAAS_GITLAB_DOMAIN
@ -28,7 +29,7 @@ class GitLabSaaSController(ServiceController):
def validate_response(self, response, *status_codes): def validate_response(self, response, *status_codes):
if response.status_code not in status_codes: if response.status_code not in status_codes:
raise RuntimeError("[%i] %s" % (response.status_code, response.content)) raise RuntimeError("[%i] %s" % (response.status_code, response.content))
return json.loads(response.content.decode('utf8')) return response.json()
def authenticate(self): def authenticate(self):
login_url = self.get_base_url() + '/session' login_url = self.get_base_url() + '/session'
@ -36,7 +37,7 @@ class GitLabSaaSController(ServiceController):
'login': 'root', 'login': 'root',
'password': settings.SAAS_GITLAB_ROOT_PASSWORD, 'password': settings.SAAS_GITLAB_ROOT_PASSWORD,
} }
response = requests.post(login_url, data=data) response = requests.post(login_url, data=data, verify=self.verify)
session = self.validate_response(response, 201) session = self.validate_response(response, 201)
token = session['private_token'] token = session['private_token']
self.headers = { self.headers = {
@ -52,7 +53,7 @@ class GitLabSaaSController(ServiceController):
'username': saas.name, 'username': saas.name,
'name': saas.account.get_full_name(), 'name': saas.account.get_full_name(),
} }
response = requests.post(user_url, data=data, headers=self.headers) response = requests.post(user_url, data=data, headers=self.headers, verify=self.verify)
user = self.validate_response(response, 201) user = self.validate_response(response, 201)
saas.data['user_id'] = user['id'] saas.data['user_id'] = user['id']
# Using queryset update to avoid triggering backends with the post_save signal # Using queryset update to avoid triggering backends with the post_save signal
@ -62,11 +63,11 @@ class GitLabSaaSController(ServiceController):
def change_password(self, saas, server): def change_password(self, saas, server):
self.authenticate() self.authenticate()
user_url = self.get_user_url(saas) user_url = self.get_user_url(saas)
response = requests.get(user_url, headers=self.headers) response = requests.get(user_url, headers=self.headers, verify=self.verify)
user = self.validate_response(response, 200) user = self.validate_response(response, 200)
user = json.loads(response.content.decode('utf8')) user = response.json()
user['password'] = saas.password user['password'] = saas.password
response = requests.put(user_url, data=user, headers=self.headers) response = requests.put(user_url, data=user, headers=self.headers, verify=self.verify)
user = self.validate_response(response, 200) user = self.validate_response(response, 200)
print(json.dumps(user, indent=4)) print(json.dumps(user, indent=4))
@ -75,17 +76,17 @@ class GitLabSaaSController(ServiceController):
return return
self.authenticate() self.authenticate()
user_url = self.get_user_url(saas) user_url = self.get_user_url(saas)
response = requests.get(user_url, headers=self.headers) response = requests.get(user_url, headers=self.headers, verify=self.verify)
user = self.validate_response(response, 200) user = self.validate_response(response, 200)
user['state'] = 'active' if saas.active else 'blocked', user['state'] = 'active' if saas.active else 'blocked',
response = requests.patch(user_url, data=user, headers=self.headers) response = requests.patch(user_url, data=user, headers=self.headers, verify=self.verify)
user = self.validate_response(response, 200) user = self.validate_response(response, 200)
print(json.dumps(user, indent=4)) print(json.dumps(user, indent=4))
def delete_user(self, saas, server): def delete_user(self, saas, server):
self.authenticate() self.authenticate()
user_url = self.get_user_url(saas) user_url = self.get_user_url(saas)
response = requests.delete(user_url, headers=self.headers) response = requests.delete(user_url, headers=self.headers, verify=self.verify)
user = self.validate_response(response, 200, 404) user = self.validate_response(response, 200, 404)
print(json.dumps(user, indent=4)) print(json.dumps(user, indent=4))
@ -95,8 +96,8 @@ class GitLabSaaSController(ServiceController):
username = saas.name username = saas.name
email = saas.data['email'] email = saas.data['email']
users_url = self.get_base_url() + '/users/' users_url = self.get_base_url() + '/users/'
response = requests.get(users_url, headers=self.headers) response = requests.get(users_url, headers=self.headers, verify=self.verify)
users = json.loads(response.content.decode('utf8')) users = response.json()
for user in users: for user in users:
if user['username'] == username: if user['username'] == username:
print('ValidationError: user-exists') print('ValidationError: user-exists')

View file

@ -262,6 +262,9 @@ SAAS_GITLAB_DOMAIN = Setting('SAAS_GITLAB_DOMAIN',
help_text="Uses <tt>ORCHESTRA_BASE_DOMAIN</tt> by default.", help_text="Uses <tt>ORCHESTRA_BASE_DOMAIN</tt> by default.",
) )
SAAS_GITLAB_VERIFY_SSL = Setting('SAAS_GITLAB_VERIFY_SSL',
True,
)
# Moodle # Moodle