Skip to content

Commit

Permalink
modify auth
Browse files Browse the repository at this point in the history
  • Loading branch information
Jermiah committed Nov 18, 2023
1 parent c2b0119 commit 04b0c30
Show file tree
Hide file tree
Showing 4 changed files with 55 additions and 44 deletions.
81 changes: 43 additions & 38 deletions src/auth.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,48 +9,53 @@ def __init__(self,
self.username = username
self.password = password
self.access_token = None
self.api_headers = None

#username=nbia_guest&password=&client_id=NBIA&grant_type=password
def getToken(self):
# Check if the access token is valid and not expired
if self.access_token is not None and self.access_token != 401:
return self.access_token
elif self.access_token == 401:
print("Failed to get access token. Status code: 401")
else:
# Prepare the request data4
data = {
'username': self.username,
'password': self.password,
'client_id': self.client_id,
'grant_type': 'password'
}
token_url = 'https://services.cancerimagingarchive.net/nbia-api/oauth/token'
# Make a POST request to the token endpoint
response = requests.post(token_url, data=data)
# response.raise_for_status()
if self.access_token is not None:
return 401 if self.access_token == 401 else self.access_token

# Prepare the request data4
data = {
'username': self.username,
'password': self.password,
'client_id': self.client_id,
'grant_type': 'password'
}
token_url = 'https://services.cancerimagingarchive.net/nbia-api/oauth/token'

response = requests.post(token_url, data=data)

try:
response.raise_for_status()
except requests.exceptions.HTTPError as e:
print(f"HTTP Error occurred: {e}")
print(f"Failed to get access token. Status code: \
{response.status_code}")

# Check if the request was successful
if response.status_code == 200:
token_data = response.json()
self.access_token = token_data.get('access_token')
# save access token to self for later use
# self.api_headers = {
# 'Authorization': f'Bearer {self.access_token}',
# 'Accept': 'application/json'
# }
# TODO::implement refresh token functionality
self.expiry_time = time.ctime(
time.time() + token_data.get('expires_in') )
self.refresh_token = token_data.get('refresh_token')
self.refresh_expiry = token_data.get('refresh_expires_in')
self.scope = token_data.get('scope')
return self.access_token
else:
print(f"Failed to get access token. Status code: \
{response.status_code}")
self.access_token = response.status_code
return response.status_code

token_data = response.json()
self.access_token = token_data.get('access_token')

self.api_headers = {
'Authorization': f'Bearer {self.access_token}',
'Accept': 'application/json'
}

# TODO::implement refresh token functionality
self.expiry_time = time.ctime(
time.time() + token_data.get('expires_in') )
self.refresh_token = token_data.get('refresh_token')
self.refresh_expiry = token_data.get('refresh_expires_in')
self.scope = token_data.get('scope')
return self.api_headers

self.access_token = response.status_code
return response.status_code

# def logout(self):
# # Request for logout
# # curl -X -v -d "Authorization:Bearer YOUR_ACCESS_TOKEN" -k "https://services.cancerimagingarchive.net/nbia-api/logout"


3 changes: 1 addition & 2 deletions src/nbia.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,7 @@ def __init__(self,
# Setup OAuth2 client
self.logger.info("Setting up OAuth2 client... with username %s", username)
self._oauth2_client = OAuth2(username=username, password=password)
self.api_headers = {'Authorization': f'Bearer {self._oauth2_client.getToken()}'}

self.api_headers = self._oauth2_client.getToken()

def query_api(self, endpoint: NBIA_ENDPOINTS, params: dict = {}) -> dict:
base_url = "https://services.cancerimagingarchive.net/nbia-api/services/"
Expand Down
13 changes: 10 additions & 3 deletions src/tests/test_auth.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ def failed_oauth2():
return oauth

def test_getToken(oauth2):
assert (oauth2.access_token is not None and oauth2.access_token != 401)
assert oauth2.access_token is not None

def test_expiry(oauth2):
# expiry should be in the form of :'Tue Jun 29 13:58:57 2077'
Expand All @@ -39,6 +39,13 @@ def test_failed_oauth(failed_oauth2,capsys):
def test_failed_oauth_retried(failed_oauth2,capsys):
failed_oauth2.getToken()
captured = capsys.readouterr()

Check failure on line 41 in src/tests/test_auth.py

View workflow job for this annotation

GitHub Actions / build (ubuntu-latest, 3.11)

Ruff (F841)

src/tests/test_auth.py:41:5: F841 Local variable `captured` is assigned to but never used

Check failure on line 41 in src/tests/test_auth.py

View workflow job for this annotation

GitHub Actions / build (ubuntu-latest, 3.12)

Ruff (F841)

src/tests/test_auth.py:41:5: F841 Local variable `captured` is assigned to but never used

Check failure on line 41 in src/tests/test_auth.py

View workflow job for this annotation

GitHub Actions / build (macos-latest, 3.12)

Ruff (F841)

src/tests/test_auth.py:41:5: F841 Local variable `captured` is assigned to but never used

Check failure on line 41 in src/tests/test_auth.py

View workflow job for this annotation

GitHub Actions / build (ubuntu-latest, 3.10)

Ruff (F841)

src/tests/test_auth.py:41:5: F841 Local variable `captured` is assigned to but never used

Check failure on line 41 in src/tests/test_auth.py

View workflow job for this annotation

GitHub Actions / build (macos-latest, 3.10)

Ruff (F841)

src/tests/test_auth.py:41:5: F841 Local variable `captured` is assigned to but never used

Check failure on line 41 in src/tests/test_auth.py

View workflow job for this annotation

GitHub Actions / build (macos-latest, 3.11)

Ruff (F841)

src/tests/test_auth.py:41:5: F841 Local variable `captured` is assigned to but never used
assert captured.out == "Failed to get access token. Status code: 401\n"
assert failed_oauth2.access_token == 401


def test_getToken_valid_token(oauth2):
# Test if the access token is valid and not expired
assert oauth2.getToken() == oauth2.access_token

def test_getToken_failed_token(failed_oauth2, capsys):
# Test if the access token retrieval fails with incorrect credentials
assert failed_oauth2.getToken() == 401
captured = capsys.readouterr()

Check failure on line 51 in src/tests/test_auth.py

View workflow job for this annotation

GitHub Actions / build (ubuntu-latest, 3.11)

Ruff (F841)

src/tests/test_auth.py:51:5: F841 Local variable `captured` is assigned to but never used

Check failure on line 51 in src/tests/test_auth.py

View workflow job for this annotation

GitHub Actions / build (ubuntu-latest, 3.12)

Ruff (F841)

src/tests/test_auth.py:51:5: F841 Local variable `captured` is assigned to but never used

Check failure on line 51 in src/tests/test_auth.py

View workflow job for this annotation

GitHub Actions / build (macos-latest, 3.12)

Ruff (F841)

src/tests/test_auth.py:51:5: F841 Local variable `captured` is assigned to but never used

Check failure on line 51 in src/tests/test_auth.py

View workflow job for this annotation

GitHub Actions / build (ubuntu-latest, 3.10)

Ruff (F841)

src/tests/test_auth.py:51:5: F841 Local variable `captured` is assigned to but never used

Check failure on line 51 in src/tests/test_auth.py

View workflow job for this annotation

GitHub Actions / build (macos-latest, 3.10)

Ruff (F841)

src/tests/test_auth.py:51:5: F841 Local variable `captured` is assigned to but never used

Check failure on line 51 in src/tests/test_auth.py

View workflow job for this annotation

GitHub Actions / build (macos-latest, 3.11)

Ruff (F841)

src/tests/test_auth.py:51:5: F841 Local variable `captured` is assigned to but never used
2 changes: 1 addition & 1 deletion src/utils/nbia_endpoints.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ class NBIA_ENDPOINTS(Enum):
GET_COLLECTIONS = 'v2/getCollectionValues'
GET_BODY_PART_PATIENT_COUNT = 'getBodyPartValuesAndCounts'
GET_PATIENT_BY_COLLECTION_AND_MODALITY = 'v2/getPatientByCollectionAndModality'


# Helper functions
def __str__(self):
Expand Down

0 comments on commit 04b0c30

Please sign in to comment.