Source code for airflow.providers.amazon.aws.operators.glacier
#
# 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.
from __future__ import annotations
from typing import TYPE_CHECKING, Sequence
from airflow.models import BaseOperator
from airflow.providers.amazon.aws.hooks.glacier import GlacierHook
if TYPE_CHECKING:
from airflow.utils.context import Context
[docs]class GlacierCreateJobOperator(BaseOperator):
"""
Initiate an Amazon Glacier inventory-retrieval job
.. seealso::
For more information on how to use this operator, take a look at the guide:
:ref:`howto/operator:GlacierCreateJobOperator`
:param aws_conn_id: The reference to the AWS connection details
:param vault_name: the Glacier vault on which job is executed
"""
[docs] template_fields: Sequence[str] = ("vault_name",)
def __init__(
self,
*,
aws_conn_id="aws_default",
vault_name: str,
**kwargs,
):
super().__init__(**kwargs)
self.aws_conn_id = aws_conn_id
self.vault_name = vault_name
[docs] def execute(self, context: Context):
hook = GlacierHook(aws_conn_id=self.aws_conn_id)
return hook.retrieve_inventory(vault_name=self.vault_name)
[docs]class GlacierUploadArchiveOperator(BaseOperator):
"""
This operator add an archive to an Amazon S3 Glacier vault
.. seealso::
For more information on how to use this operator, take a look at the guide:
:ref:`howto/operator:GlacierUploadArchiveOperator`
:param vault_name: The name of the vault
:param body: A bytes or seekable file-like object. The data to upload.
:param checksum: The SHA256 tree hash of the data being uploaded.
This parameter is automatically populated if it is not provided
:param archive_description: The description of the archive you are uploading
:param account_id: (Optional) AWS account ID of the account that owns the vault.
Defaults to the credentials used to sign the request
:param aws_conn_id: The reference to the AWS connection details
"""
[docs] template_fields: Sequence[str] = ("vault_name",)
def __init__(
self,
*,
vault_name: str,
body: object,
checksum: str | None = None,
archive_description: str | None = None,
account_id: str | None = None,
aws_conn_id="aws_default",
**kwargs,
):
super().__init__(**kwargs)
self.aws_conn_id = aws_conn_id
self.account_id = account_id
self.vault_name = vault_name
self.body = body
self.checksum = checksum
self.archive_description = archive_description
[docs] def execute(self, context: Context):
hook = GlacierHook(aws_conn_id=self.aws_conn_id)
return hook.get_conn().upload_archive(
accountId=self.account_id,
vaultName=self.vault_name,
archiveDescription=self.archive_description,
body=self.body,
checksum=self.checksum,
)