airflow.providers.amazon.aws.hooks.base_aws¶
This module contains Base AWS Hook.
See also
For more information on how to use this hook, take a look at the guide: Amazon Web Services Connection
Module Contents¶
Classes¶
| Base AWS Session Factory class to handle boto3 session creation. | |
| Interact with AWS. | |
| Interact with AWS. | 
Functions¶
| Resolves custom SessionFactory class | 
Attributes¶
- class airflow.providers.amazon.aws.hooks.base_aws.BaseSessionFactory(conn, region_name=None, config=None)[source]¶
- Bases: - airflow.utils.log.logging_mixin.LoggingMixin- Base AWS Session Factory class to handle boto3 session creation. It can handle most of the AWS supported authentication methods. - User can also derive from this class to have full control of boto3 session creation or to support custom federation. - See also 
- class airflow.providers.amazon.aws.hooks.base_aws.AwsGenericHook(aws_conn_id=default_conn_name, verify=None, region_name=None, client_type=None, resource_type=None, config=None)[source]¶
- Bases: - airflow.hooks.base.BaseHook,- Generic[- BaseAwsConnection]- Interact with AWS. This class is a thin wrapper around the boto3 python library. - Parameters
- aws_conn_id (str | None) – The Airflow connection used for AWS credentials. If this is None or empty then the default boto3 behaviour is used. If running Airflow in a distributed manner and aws_conn_id is None or empty, then default boto3 configuration would be used (and must be maintained on each worker node). 
- verify (bool | str | None) – Whether or not to verify SSL certificates. See: https://boto3.amazonaws.com/v1/documentation/api/latest/reference/core/session.html 
- region_name (str | None) – AWS region_name. If not specified then the default boto3 behaviour is used. 
- client_type (str | None) – boto3.client client_type. Eg ‘s3’, ‘emr’ etc 
- resource_type (str | None) – boto3.resource resource_type. Eg ‘dynamodb’ etc 
- config (Config | None) – Configuration for botocore client. See: https://botocore.amazonaws.com/v1/documentation/api/latest/reference/config.html 
 
 - property verify: bool | str | None[source]¶
- Verify or not SSL certificates boto3 client/resource read-only property. 
 - property conn_partition: str[source]¶
- Get associated AWS Region Partition from Hook connection (cached). 
 - get_session(region_name=None)[source]¶
- Get the underlying boto3.session.Session(region_name=region_name). 
 - get_client_type(region_name=None, config=None)[source]¶
- Get the underlying boto3 client using boto3 session 
 - get_resource_type(region_name=None, config=None)[source]¶
- Get the underlying boto3 resource using boto3 session 
 - conn()[source]¶
- Get the underlying boto3 client/resource (cached) - Returns
- boto3.client or boto3.resource 
- Return type
- BaseAwsConnection 
 
 - get_conn()[source]¶
- Get the underlying boto3 client/resource (cached) - Implemented so that caching works as intended. It exists for compatibility with subclasses that rely on a super().get_conn() method. - Returns
- boto3.client or boto3.resource 
- Return type
- BaseAwsConnection 
 
 - get_credentials(region_name=None)[source]¶
- Get the underlying botocore.Credentials object. - This contains the following authentication attributes: access_key, secret_key and token. By use this method also secret_key and token will mask in tasks logs. 
 - expand_role(role, region_name=None)[source]¶
- If the IAM role is a role name, get the Amazon Resource Name (ARN) for the role. If IAM role is already an IAM role ARN, no change is made. 
 
- class airflow.providers.amazon.aws.hooks.base_aws.AwsBaseHook(aws_conn_id=default_conn_name, verify=None, region_name=None, client_type=None, resource_type=None, config=None)[source]¶
- Bases: - AwsGenericHook[- Union[- boto3.client,- boto3.resource]]- Interact with AWS. This class is a thin wrapper around the boto3 python library with basic conn annotation. - See also 
