Skip to content

Commit

Permalink
feat: allow custom headers to be sent through http requests (#180)
Browse files Browse the repository at this point in the history
Co-authored-by: Mike Gouline <[email protected]>
  • Loading branch information
tanguyantoine and gouline authored Oct 6, 2023
1 parent 2d9f76f commit 297ab1f
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 1 deletion.
15 changes: 14 additions & 1 deletion dbtmetabase/__init__.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import logging
import functools
from pathlib import Path
from typing import Iterable, Optional, Callable, Any
from typing import Iterable, Optional, Callable, Any, Dict
import os

import click
Expand Down Expand Up @@ -282,6 +282,13 @@ def shared_opts(func: Callable) -> Callable:
type=int,
help="Synchronization timeout (in secs). If set, we will fail hard on synchronization failure; if not set, we will proceed after attempting sync regardless of success. Only valid if sync is enabled",
)
@click.option(
"--http_extra_headers",
cls=OptionAcceptableFromConfig,
type=(str, str),
multiple=True,
help="Additional HTTP request header to be sent to Metabase.",
)
@functools.wraps(func)
def wrapper(*args, **kwargs):
return func(*args, **kwargs)
Expand Down Expand Up @@ -555,6 +562,7 @@ def models(
dbt_include_tags: bool = True,
dbt_docs_url: Optional[str] = None,
verbose: bool = False,
http_extra_headers: Optional[Dict[Any, Any]] = None,
):
"""Exports model documentation and semantic types from dbt to Metabase.
Expand All @@ -579,6 +587,7 @@ def models(
metabase_exclude_sources (bool, optional): Flag to skip exporting sources to Metabase. Defaults to False.
dbt_include_tags (bool, optional): Flag to append tags to table descriptions in Metabase. Defaults to True.
dbt_docs_url (Optional[str], optional): Pass in URL to dbt docs site. Appends dbt docs URL for each model to Metabase table description. Defaults to None.
http_extra_headers (Optional[str], optional): Additional HTTP request headers to be sent to Metabase. Defaults to None.
verbose (bool, optional): Flag which signals verbose output. Defaults to False.
"""

Expand Down Expand Up @@ -615,6 +624,7 @@ def models(
sync=metabase_sync,
sync_timeout=metabase_sync_timeout,
exclude_sources=metabase_exclude_sources,
http_extra_headers=http_extra_headers,
)

# Load client
Expand Down Expand Up @@ -679,6 +689,7 @@ def exposures(
output_name: str = "metabase_exposures.yml",
include_personal_collections: bool = False,
collection_excludes: Optional[Iterable] = None,
http_extra_headers: Optional[Dict[Any, Any]] = None,
verbose: bool = False,
) -> None:
"""Extracts and imports exposures from Metabase to dbt.
Expand All @@ -704,6 +715,7 @@ def exposures(
output_name (str): Output name for generated exposure yaml. Defaults to metabase_exposures.yml.
include_personal_collections (bool, optional): Flag to include Personal Collections during exposure parsing. Defaults to False.
collection_excludes (Iterable, optional): Collection names to exclude. Defaults to None.
http_extra_headers (Optional[str], optional): Additional HTTP request headers to be sent to Metabase. Defaults to None.
verbose (bool, optional): Flag which signals verbose output. Defaults to False.
"""

Expand Down Expand Up @@ -736,6 +748,7 @@ def exposures(
database=metabase_database,
sync=metabase_sync,
sync_timeout=metabase_sync_timeout,
http_extra_headers=http_extra_headers,
)

# Load client
Expand Down
4 changes: 4 additions & 0 deletions dbtmetabase/metabase.py
Original file line number Diff line number Diff line change
Expand Up @@ -127,6 +127,7 @@ def __init__(
sync: Optional[bool] = True,
sync_timeout: Optional[int] = None,
exclude_sources: bool = False,
http_extra_headers: Optional[dict] = None,
):
"""Constructor.
Expand All @@ -142,12 +143,15 @@ def __init__(
session_id {str} -- Metabase session ID. (default: {None})
sync (bool, optional): Attempt to synchronize Metabase schema with local models. Defaults to True.
sync_timeout (Optional[int], optional): Synchronization timeout (in secs). Defaults to None.
http_extra_headers {dict} -- HTTP headers to be used by the Metabase client. (default: {None})
exclude_sources {bool} -- Exclude exporting sources. (default: {False})
"""
self.base_url = f"{'http' if use_http else 'https'}://{host}"
self.session = requests.Session()
self.session.verify = verify
self.session.cert = cert
if http_extra_headers is not None:
self.session.headers.update(http_extra_headers)
adaptor = HTTPAdapter(max_retries=Retry(total=3, backoff_factor=0.5))
self.session.mount(self.base_url, adaptor)
session_header = session_id or self.get_session_id(user, password)
Expand Down
4 changes: 4 additions & 0 deletions dbtmetabase/models/interface.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ def __init__(
sync: bool = True,
sync_timeout: Optional[int] = None,
exclude_sources: bool = False,
http_extra_headers: Optional[dict] = None,
):
"""Constructor.
Expand All @@ -47,6 +48,7 @@ def __init__(
sync (bool, optional): Attempt to synchronize Metabase schema with local models. Defaults to True.
sync_timeout (Optional[int], optional): Synchronization timeout (in secs). Defaults to None.
exclude_sources (bool, optional): Exclude exporting sources. Defaults to False.
http_extra_headers (Optional[dict], optional): HTTP headers to be used by the Metabase client. Defaults to None.
"""

# Metabase Client
Expand All @@ -59,6 +61,7 @@ def __init__(
self.use_http = use_http
self.verify = verify
self.cert = cert
self.http_extra_headers = dict(http_extra_headers) if http_extra_headers else {}
# Metabase Sync
self.sync = sync
self.sync_timeout = sync_timeout
Expand Down Expand Up @@ -101,6 +104,7 @@ def prepare_metabase_client(self, dbt_models: Optional[List[MetabaseModel]] = No
use_http=self.use_http,
verify=self.verify,
cert=self.cert,
http_extra_headers=self.http_extra_headers,
session_id=self.session_id,
sync=self.sync,
sync_timeout=self.sync_timeout,
Expand Down

0 comments on commit 297ab1f

Please sign in to comment.