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 AWS DynamoDB hook"""fromtypingimportIterable,List,Optionalfromairflow.exceptionsimportAirflowExceptionfromairflow.providers.amazon.aws.hooks.base_awsimportAwsBaseHook
[docs]classAwsDynamoDBHook(AwsBaseHook):""" Interact with AWS DynamoDB. 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` :param table_keys: partition key and sort key :type table_keys: list :param table_name: target DynamoDB table :type table_name: str """def__init__(self,*args,table_keys:Optional[List]=None,table_name:Optional[str]=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."""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)}")