{-# LANGUAGE DisambiguateRecordFields #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.IoTData.Types -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) module Amazonka.IoTData.Types ( -- * Service Configuration defaultService, -- * Errors _ConflictException, _InternalFailureException, _InvalidRequestException, _MethodNotAllowedException, _RequestEntityTooLargeException, _ResourceNotFoundException, _ServiceUnavailableException, _ThrottlingException, _UnauthorizedException, _UnsupportedDocumentEncodingException, -- * PayloadFormatIndicator PayloadFormatIndicator (..), -- * RetainedMessageSummary RetainedMessageSummary (..), newRetainedMessageSummary, retainedMessageSummary_lastModifiedTime, retainedMessageSummary_payloadSize, retainedMessageSummary_qos, retainedMessageSummary_topic, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import Amazonka.IoTData.Types.PayloadFormatIndicator import Amazonka.IoTData.Types.RetainedMessageSummary import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Sign.V4 as Sign -- | API version @2015-05-28@ of the Amazon IoT Data Plane SDK configuration. defaultService :: Core.Service defaultService = Core.Service { Core.abbrev = "IoTData", Core.signer = Sign.v4, Core.endpointPrefix = "data-ats.iot", Core.signingName = "iotdata", Core.version = "2015-05-28", Core.s3AddressingStyle = Core.S3AddressingStyleAuto, Core.endpoint = Core.defaultEndpoint defaultService, Core.timeout = Prelude.Just 70, Core.check = Core.statusSuccess, Core.error = Core.parseJSONError "IoTData", Core.retry = retry } where retry = Core.Exponential { Core.base = 5.0e-2, Core.growth = 2, Core.attempts = 5, Core.check = check } check e | Lens.has (Core.hasStatus 502) e = Prelude.Just "bad_gateway" | Lens.has (Core.hasStatus 504) e = Prelude.Just "gateway_timeout" | Lens.has (Core.hasStatus 500) e = Prelude.Just "general_server_error" | Lens.has (Core.hasStatus 509) e = Prelude.Just "limit_exceeded" | Lens.has ( Core.hasCode "RequestThrottledException" Prelude.. Core.hasStatus 400 ) e = Prelude.Just "request_throttled_exception" | Lens.has (Core.hasStatus 503) e = Prelude.Just "service_unavailable" | Lens.has ( Core.hasCode "ThrottledException" Prelude.. Core.hasStatus 400 ) e = Prelude.Just "throttled_exception" | Lens.has ( Core.hasCode "Throttling" Prelude.. Core.hasStatus 400 ) e = Prelude.Just "throttling" | Lens.has ( Core.hasCode "ThrottlingException" Prelude.. Core.hasStatus 400 ) e = Prelude.Just "throttling_exception" | Lens.has ( Core.hasCode "ProvisionedThroughputExceededException" Prelude.. Core.hasStatus 400 ) e = Prelude.Just "throughput_exceeded" | Lens.has (Core.hasStatus 429) e = Prelude.Just "too_many_requests" | Prelude.otherwise = Prelude.Nothing -- | The specified version does not match the version of the document. _ConflictException :: (Core.AsError a) => Lens.Fold a Core.ServiceError _ConflictException = Core._MatchServiceError defaultService "ConflictException" Prelude.. Core.hasStatus 409 -- | An unexpected error has occurred. _InternalFailureException :: (Core.AsError a) => Lens.Fold a Core.ServiceError _InternalFailureException = Core._MatchServiceError defaultService "InternalFailureException" Prelude.. Core.hasStatus 500 -- | The request is not valid. _InvalidRequestException :: (Core.AsError a) => Lens.Fold a Core.ServiceError _InvalidRequestException = Core._MatchServiceError defaultService "InvalidRequestException" Prelude.. Core.hasStatus 400 -- | The specified combination of HTTP verb and URI is not supported. _MethodNotAllowedException :: (Core.AsError a) => Lens.Fold a Core.ServiceError _MethodNotAllowedException = Core._MatchServiceError defaultService "MethodNotAllowedException" Prelude.. Core.hasStatus 405 -- | The payload exceeds the maximum size allowed. _RequestEntityTooLargeException :: (Core.AsError a) => Lens.Fold a Core.ServiceError _RequestEntityTooLargeException = Core._MatchServiceError defaultService "RequestEntityTooLargeException" Prelude.. Core.hasStatus 413 -- | The specified resource does not exist. _ResourceNotFoundException :: (Core.AsError a) => Lens.Fold a Core.ServiceError _ResourceNotFoundException = Core._MatchServiceError defaultService "ResourceNotFoundException" Prelude.. Core.hasStatus 404 -- | The service is temporarily unavailable. _ServiceUnavailableException :: (Core.AsError a) => Lens.Fold a Core.ServiceError _ServiceUnavailableException = Core._MatchServiceError defaultService "ServiceUnavailableException" Prelude.. Core.hasStatus 503 -- | The rate exceeds the limit. _ThrottlingException :: (Core.AsError a) => Lens.Fold a Core.ServiceError _ThrottlingException = Core._MatchServiceError defaultService "ThrottlingException" Prelude.. Core.hasStatus 429 -- | You are not authorized to perform this operation. _UnauthorizedException :: (Core.AsError a) => Lens.Fold a Core.ServiceError _UnauthorizedException = Core._MatchServiceError defaultService "UnauthorizedException" Prelude.. Core.hasStatus 401 -- | The document encoding is not supported. _UnsupportedDocumentEncodingException :: (Core.AsError a) => Lens.Fold a Core.ServiceError _UnsupportedDocumentEncodingException = Core._MatchServiceError defaultService "UnsupportedDocumentEncodingException" Prelude.. Core.hasStatus 415