Source code for airflow.providers.amazon.aws.hooks.dynamodb
## Licensed to the Apache Software Foundation (ASF) under one# or more contributor license agreements. See the NOTICE file# distributed with this work for additional information# regarding copyright ownership. The ASF licenses this file# to you under the Apache License, Version 2.0 (the# "License"); you may not use this file except in compliance# with the License. You may obtain a copy of the License at## http://www.apache.org/licenses/LICENSE-2.0## Unless required by applicable law or agreed to in writing,# software distributed under the License is distributed on an# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY# KIND, either express or implied. See the License for the# specific language governing permissions and limitations# under the License."""This module contains the Amazon DynamoDB Hook"""from__future__importannotationsfromtypingimportIterablefromairflow.exceptionsimportAirflowExceptionfromairflow.providers.amazon.aws.hooks.base_awsimportAwsBaseHook
[docs]classDynamoDBHook(AwsBaseHook):""" Interact with Amazon DynamoDB. Provide thick wrapper around :external+boto3:py:class:`boto3.resource("dynamodb") <DynamoDB.ServiceResource>`. :param table_keys: partition key and sort key :param table_name: target DynamoDB table Additional arguments (such as ``aws_conn_id``) may be specified and are passed down to the underlying AwsBaseHook. .. seealso:: - :class:`airflow.providers.amazon.aws.hooks.base_aws.AwsBaseHook` """def__init__(self,*args,table_keys:list|None=None,table_name:str|None=None,**kwargs)->None:self.table_keys=table_keysself.table_name=table_namekwargs["resource_type"]="dynamodb"super().__init__(*args,**kwargs)
[docs]defwrite_batch_data(self,items:Iterable)->bool:""" Write batch items to DynamoDB table with provisioned throughout capacity. .. seealso:: - :external+boto3:py:meth:`DynamoDB.ServiceResource.Table` - :external+boto3:py:meth:`DynamoDB.Table.batch_writer` - :external+boto3:py:meth:`DynamoDB.Table.put_item` :param items: list of DynamoDB items. """try:table=self.get_conn().Table(self.table_name)withtable.batch_writer(overwrite_by_pkeys=self.table_keys)asbatch:foriteminitems:batch.put_item(Item=item)returnTrueexceptExceptionasgeneral_error:raiseAirflowException(f"Failed to insert items in dynamodb, error: {str(general_error)}")