Skip to content

Commit

Permalink
openshift: fix fetching of default openshift_auth_api_url
Browse files Browse the repository at this point in the history
  • Loading branch information
consideRatio committed Oct 16, 2023
1 parent 2fa1c48 commit 17a1676
Showing 1 changed file with 20 additions and 9 deletions.
29 changes: 20 additions & 9 deletions oauthenticator/openshift.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
"""
A JupyterHub authenticator class for use with OpenShift as an identity provider.
"""
import concurrent.futures
import json
import os

Expand Down Expand Up @@ -81,15 +82,25 @@ def _http_request_kwargs_default(self):
def _openshift_auth_api_url_default(self):
auth_info_url = f"{self.openshift_url}/.well-known/oauth-authorization-server"

# Makes a request like OAuthenticator.httpfetch would but non-async as
# this code run during startup when we can't yet use async
# functionality.
client = HTTPClient()
req = HTTPRequest(auth_info_url, **self.http_request_kwargs)
resp = client.fetch(req)
resp_json = json.loads(resp.body.decode("utf8", "replace"))

return resp_json.get('issuer')
# This code run during startup when we can't yet use async
# functionality. Due to this, Tornado's HTTPClient instead of
# AsyncHTTPClient is used. With HTTPClient we can still re-use
# `http_request_args` specific to Tornado's HTTP clients.
#
# A dedicated thread is used for HTTPClient because of
# https://github.com/tornadoweb/tornado/issues/2325#issuecomment-375972739.
#
def fetch_auth_info():
client = HTTPClient()
req = HTTPRequest(auth_info_url, **self.http_request_kwargs)
resp = client.fetch(req)
resp_json = json.loads(resp.body.decode("utf8", "replace"))
return resp_json

with concurrent.futures.ThreadPoolExecutor() as executor:
future = executor.submit(fetch_auth_info)
return_value = future.result()
return return_value.get("issuer")

@default("authorize_url")
def _authorize_url_default(self):
Expand Down

0 comments on commit 17a1676

Please sign in to comment.