From 3db93af5fd11724cc40e217a2ac4c3e835d3b0de Mon Sep 17 00:00:00 2001 From: Md Azam Date: Thu, 28 Sep 2023 17:16:33 -0300 Subject: [PATCH] Fixing authentication token handling (#1583) --- .../okta/stix_transmission/api_client.py | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/stix_shifter_modules/okta/stix_transmission/api_client.py b/stix_shifter_modules/okta/stix_transmission/api_client.py index b683c9ab0..5323181b8 100644 --- a/stix_shifter_modules/okta/stix_transmission/api_client.py +++ b/stix_shifter_modules/okta/stix_transmission/api_client.py @@ -7,7 +7,16 @@ class APIClient: def __init__(self, connection, configuration): auth = configuration.get('auth') - self.headers = {'Authorization': auth['api_token'], + """ + The Okta API requires the custom HTTP authentication scheme SSWS for API token (API key) authentication. + Requests must have a valid API token specified in the HTTP Authorization header with the SSWS scheme. + Ref: https://developer.okta.com/docs/reference/core-okta-api/#api-token-authentication + """ + if 'SSWS' in auth['api_token']: #this check is for backward compatibility + self.api_token = auth['api_token'] + else: + self.api_token = 'SSWS '+ auth['api_token'] + self.headers = {'Authorization': self.api_token, 'Content-Type': 'application/json', 'Accept': 'application/json'} self.client = RestApiClientAsync(connection.get('host'), port=None, headers=self.headers)