diff --git a/mkdocs/docs/configuration.md b/mkdocs/docs/configuration.md index 9455c3e8d2..2404f28b30 100644 --- a/mkdocs/docs/configuration.md +++ b/mkdocs/docs/configuration.md @@ -347,7 +347,7 @@ catalog: !!! warning "Removed Properties" - The properties `profile_name`, `region_name`, `botocore_session`, `aws_access_key_id`, `aws_secret_access_key`, and `aws_session_token` were deprecated and removed in 0.8.0 + The properties `profile_name`, `region_name`, `aws_access_key_id`, `aws_secret_access_key`, and `aws_session_token` were deprecated and removed in 0.8.0 @@ -403,7 +403,7 @@ catalog: !!! warning "Removed Properties" - The properties `profile_name`, `region_name`, `botocore_session`, `aws_access_key_id`, `aws_secret_access_key`, and `aws_session_token` were deprecated and removed in 0.8.0 + The properties `profile_name`, `region_name`, `aws_access_key_id`, `aws_secret_access_key`, and `aws_session_token` were deprecated and removed in 0.8.0 diff --git a/pyiceberg/catalog/__init__.py b/pyiceberg/catalog/__init__.py index 2104fcab7a..b189b4094d 100644 --- a/pyiceberg/catalog/__init__.py +++ b/pyiceberg/catalog/__init__.py @@ -106,6 +106,8 @@ re.X, ) +DEPRECATED_BOTOCORE_SESSION = "botocore_session" + class CatalogType(Enum): REST = "rest" @@ -779,6 +781,13 @@ class MetastoreCatalog(Catalog, ABC): def __init__(self, name: str, **properties: str): super().__init__(name, **properties) + if self.properties.get(DEPRECATED_BOTOCORE_SESSION): + deprecation_message( + deprecated_in="0.8.0", + removed_in="0.9.0", + help_message=f"The property {DEPRECATED_BOTOCORE_SESSION} is deprecated and will be removed.", + ) + def create_table_transaction( self, identifier: Union[str, Identifier], diff --git a/pyiceberg/catalog/dynamodb.py b/pyiceberg/catalog/dynamodb.py index 68e2e62305..9c0d31af87 100644 --- a/pyiceberg/catalog/dynamodb.py +++ b/pyiceberg/catalog/dynamodb.py @@ -30,6 +30,7 @@ import boto3 from pyiceberg.catalog import ( + DEPRECATED_BOTOCORE_SESSION, ICEBERG, METADATA_LOCATION, PREVIOUS_METADATA_LOCATION, @@ -98,6 +99,7 @@ def __init__(self, name: str, **properties: str): session = boto3.Session( profile_name=properties.get(DYNAMODB_PROFILE_NAME), region_name=get_first_property_value(properties, DYNAMODB_REGION, AWS_REGION), + botocore_session=properties.get(DEPRECATED_BOTOCORE_SESSION), aws_access_key_id=get_first_property_value(properties, DYNAMODB_ACCESS_KEY_ID, AWS_ACCESS_KEY_ID), aws_secret_access_key=get_first_property_value(properties, DYNAMODB_SECRET_ACCESS_KEY, AWS_SECRET_ACCESS_KEY), aws_session_token=get_first_property_value(properties, DYNAMODB_SESSION_TOKEN, AWS_SESSION_TOKEN), diff --git a/pyiceberg/catalog/glue.py b/pyiceberg/catalog/glue.py index c050f73b9f..79cb2a71f3 100644 --- a/pyiceberg/catalog/glue.py +++ b/pyiceberg/catalog/glue.py @@ -40,6 +40,7 @@ ) from pyiceberg.catalog import ( + DEPRECATED_BOTOCORE_SESSION, EXTERNAL_TABLE, ICEBERG, LOCATION, @@ -299,6 +300,7 @@ def __init__(self, name: str, **properties: Any): session = boto3.Session( profile_name=properties.get(GLUE_PROFILE_NAME), region_name=get_first_property_value(properties, GLUE_REGION, AWS_REGION), + botocore_session=properties.get(DEPRECATED_BOTOCORE_SESSION), aws_access_key_id=get_first_property_value(properties, GLUE_ACCESS_KEY_ID, AWS_ACCESS_KEY_ID), aws_secret_access_key=get_first_property_value(properties, GLUE_SECRET_ACCESS_KEY, AWS_SECRET_ACCESS_KEY), aws_session_token=get_first_property_value(properties, GLUE_SESSION_TOKEN, AWS_SESSION_TOKEN), diff --git a/tests/catalog/test_dynamodb.py b/tests/catalog/test_dynamodb.py index 865e348cf7..951ffe7485 100644 --- a/tests/catalog/test_dynamodb.py +++ b/tests/catalog/test_dynamodb.py @@ -585,6 +585,7 @@ def test_passing_glue_session_properties() -> None: aws_session_token="dynamodb.session-token", region_name="dynamodb.region", profile_name="dynamodb.profile-name", + botocore_session=None, ) assert test_catalog.dynamodb is mock_session().client() @@ -608,6 +609,7 @@ def test_passing_unified_session_properties_to_dynamodb() -> None: aws_session_token="client.session-token", region_name="client.region", profile_name="dynamodb.profile-name", + botocore_session=None, ) assert test_catalog.dynamodb is mock_session().client() diff --git a/tests/catalog/test_glue.py b/tests/catalog/test_glue.py index 8258f7e209..32ae89163b 100644 --- a/tests/catalog/test_glue.py +++ b/tests/catalog/test_glue.py @@ -654,6 +654,7 @@ def test_passing_glue_session_properties() -> None: aws_session_token="glue.session-token", region_name="glue.region", profile_name="glue.profile-name", + botocore_session=None, ) assert test_catalog.glue is mock_session().client() @@ -674,6 +675,7 @@ def test_passing_unified_session_properties_to_glue() -> None: aws_session_token="client.session-token", region_name="client.region", profile_name="glue.profile-name", + botocore_session=None, ) assert test_catalog.glue is mock_session().client()