Skip to content

Commit

Permalink
feat(openapi): allow Bearer token
Browse files Browse the repository at this point in the history
  • Loading branch information
Dimitri GRISARD committed Jan 19, 2024
1 parent dadd51e commit 1754819
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 6 deletions.
8 changes: 5 additions & 3 deletions metadata-ingestion/src/datahub/ingestion/source/openapi.py
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,7 @@ class OpenApiConfig(ConfigModel):
)
forced_examples: dict = Field(default={}, description="")
token: Optional[str] = Field(default=None, description="")
bearer_token: Optional[bool] = Field(default=False, description="Use Bearer token")
get_token: dict = Field(default={}, description="")

def get_swagger(self) -> Dict:
Expand Down Expand Up @@ -99,6 +100,7 @@ def get_swagger(self) -> Dict:
sw_dict = get_swag_json(
self.url,
token=self.token,
bearer_token=self.bearer_token,
swagger_file=self.swagger_file,
proxies=self.proxies,
) # load the swagger file
Expand Down Expand Up @@ -271,7 +273,7 @@ def get_workunits_internal(self) -> Iterable[ApiWorkUnit]: # noqa: C901

if config.token:
response = request_call(
tot_url, token=config.token, proxies=config.proxies
tot_url, token=config.token, bearer_token=config.bearer_token, proxies=config.proxies
)
else:
response = request_call(
Expand Down Expand Up @@ -299,7 +301,7 @@ def get_workunits_internal(self) -> Iterable[ApiWorkUnit]: # noqa: C901
tot_url = clean_url(config.url + self.url_basepath + url_guess)
if config.token:
response = request_call(
tot_url, token=config.token, proxies=config.proxies
tot_url, token=config.token, bearer_token=config.bearer_token, proxies=config.proxies
)
else:
response = request_call(
Expand Down Expand Up @@ -327,7 +329,7 @@ def get_workunits_internal(self) -> Iterable[ApiWorkUnit]: # noqa: C901
tot_url = clean_url(config.url + self.url_basepath + composed_url)
if config.token:
response = request_call(
tot_url, token=config.token, proxies=config.proxies
tot_url, token=config.token, bearer_token=config.bearer_token, proxies=config.proxies
)
else:
response = request_call(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -49,17 +49,20 @@ def flatten2list(d: dict) -> list:
def request_call(
url: str,
token: Optional[str] = None,
bearer_token: Optional[bool] = False,
username: Optional[str] = None,
password: Optional[str] = None,
proxies: Optional[dict] = None,
) -> requests.Response:
headers = {"accept": "application/json"}

if username is not None and password is not None:
return requests.get(
url, headers=headers, auth=HTTPBasicAuth(username, password)
)

elif token is not None and bearer_token is True:
headers["Authorization"] = f"Bearer {token}"
return requests.get(url, proxies=proxies, headers=headers)
elif token is not None:
headers["Authorization"] = f"{token}"
return requests.get(url, proxies=proxies, headers=headers)
Expand All @@ -70,14 +73,15 @@ def request_call(
def get_swag_json(
url: str,
token: Optional[str] = None,
bearer_token: Optional[bool] = False,
username: Optional[str] = None,
password: Optional[str] = None,
swagger_file: str = "",
proxies: Optional[dict] = None,
) -> Dict:
tot_url = url + swagger_file
if token is not None:
response = request_call(url=tot_url, token=token, proxies=proxies)
response = request_call(url=tot_url, token=token, bearer_token=bearer_token, proxies=proxies)
else:
response = request_call(
url=tot_url, username=username, password=password, proxies=proxies
Expand Down Expand Up @@ -122,7 +126,7 @@ def get_endpoints(sw_dict: dict) -> dict: # noqa: C901
"""
url_details = {}

check_sw_version(sw_dict)
#check_sw_version(sw_dict)

for p_k, p_o in sw_dict["paths"].items():
method = list(p_o)[0]
Expand Down

0 comments on commit 1754819

Please sign in to comment.