|
# Copyright 2014 Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"). You
|
|
# may not use this file except in compliance with the License. A copy of
|
|
# the License is located at
|
|
#
|
|
# http://aws.amazon.com/apache2.0/
|
|
#
|
|
# or in the "license" file accompanying this file. This file 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.
|
|
|
|
# All exceptions in this class should subclass from Boto3Error.
|
|
import botocore.exceptions
|
|
|
|
|
|
# All exceptions should subclass from Boto3Error in this module.
|
|
class Boto3Error(Exception):
|
|
"""Base class for all Boto3 errors."""
|
|
|
|
|
|
class ResourceLoadException(Boto3Error):
|
|
pass
|
|
|
|
|
|
# NOTE: This doesn't appear to be used anywhere.
|
|
# It's probably safe to remove this.
|
|
class NoVersionFound(Boto3Error):
|
|
pass
|
|
|
|
|
|
# We're subclassing from botocore.exceptions.DataNotFoundError
|
|
# to keep backwards compatibility with anyone that was catching
|
|
# this low level Botocore error before this exception was
|
|
# introduced in boto3.
|
|
# Same thing for ResourceNotExistsError below.
|
|
class UnknownAPIVersionError(Boto3Error,
|
|
botocore.exceptions.DataNotFoundError):
|
|
def __init__(self, service_name, bad_api_version,
|
|
available_api_versions):
|
|
msg = (
|
|
"The '%s' resource does not an API version of: %s\n"
|
|
"Valid API versions are: %s"
|
|
% (service_name, bad_api_version, available_api_versions)
|
|
)
|
|
# Not using super because we don't want the DataNotFoundError
|
|
# to be called, it has a different __init__ signature.
|
|
Boto3Error.__init__(self, msg)
|
|
|
|
|
|
class ResourceNotExistsError(Boto3Error,
|
|
botocore.exceptions.DataNotFoundError):
|
|
"""Raised when you attempt to create a resource that does not exist."""
|
|
def __init__(self, service_name, available_services, has_low_level_client):
|
|
msg = (
|
|
"The '%s' resource does not exist.\n"
|
|
"The available resources are:\n"
|
|
" - %s\n" % (service_name, '\n - '.join(available_services))
|
|
)
|
|
if has_low_level_client:
|
|
msg += (
|
|
"\nConsider using a boto3.client('%s') instead "
|
|
"of a resource for '%s'" % (service_name, service_name))
|
|
# Not using super because we don't want the DataNotFoundError
|
|
# to be called, it has a different __init__ signature.
|
|
Boto3Error.__init__(self, msg)
|
|
|
|
|
|
class RetriesExceededError(Boto3Error):
|
|
def __init__(self, last_exception, msg='Max Retries Exceeded'):
|
|
super(RetriesExceededError, self).__init__(msg)
|
|
self.last_exception = last_exception
|
|
|
|
|
|
class S3TransferFailedError(Boto3Error):
|
|
pass
|
|
|
|
|
|
class S3UploadFailedError(Boto3Error):
|
|
pass
|
|
|
|
|
|
class DynamoDBOperationNotSupportedError(Boto3Error):
|
|
"""Raised for operantions that are not supported for an operand"""
|
|
def __init__(self, operation, value):
|
|
msg = (
|
|
'%s operation cannot be applied to value %s of type %s directly. '
|
|
'Must use AttributeBase object methods (i.e. Attr().eq()). to '
|
|
'generate ConditionBase instances first.' %
|
|
(operation, value, type(value)))
|
|
Exception.__init__(self, msg)
|
|
|
|
# FIXME: Backward compatibility
|
|
DynanmoDBOperationNotSupportedError = DynamoDBOperationNotSupportedError
|
|
|
|
|
|
class DynamoDBNeedsConditionError(Boto3Error):
|
|
"""Raised when input is not a condition"""
|
|
def __init__(self, value):
|
|
msg = (
|
|
'Expecting a ConditionBase object. Got %s of type %s. '
|
|
'Use AttributeBase object methods (i.e. Attr().eq()). to '
|
|
'generate ConditionBase instances.' % (value, type(value)))
|
|
Exception.__init__(self, msg)
|
|
|
|
|
|
class DynamoDBNeedsKeyConditionError(Boto3Error):
|
|
pass
|