{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE DuplicateRecordFields #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE StrictData #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE NoImplicitPrelude #-}
{-# OPTIONS_GHC -fno-warn-unused-binds #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}

-- Derived from AWS service descriptions, licensed under Apache 2.0.

-- |
-- Module      : Amazonka.SQS.ChangeMessageVisibilityBatch
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Changes the visibility timeout of multiple messages. This is a batch
-- version of @ @@ChangeMessageVisibility@@.@ The result of the action on
-- each message is reported individually in the response. You can send up
-- to 10 @ @@ChangeMessageVisibility@@ @ requests with each
-- @ChangeMessageVisibilityBatch@ action.
--
-- Because the batch request can result in a combination of successful and
-- unsuccessful actions, you should check for batch errors even when the
-- call returns an HTTP status code of @200@.
--
-- Some actions take lists of parameters. These lists are specified using
-- the @param.n@ notation. Values of @n@ are integers starting from 1. For
-- example, a parameter list with two elements looks like this:
--
-- @&AttributeName.1=first@
--
-- @&AttributeName.2=second@
module Amazonka.SQS.ChangeMessageVisibilityBatch
  ( -- * Creating a Request
    ChangeMessageVisibilityBatch (..),
    newChangeMessageVisibilityBatch,

    -- * Request Lenses
    changeMessageVisibilityBatch_queueUrl,
    changeMessageVisibilityBatch_entries,

    -- * Destructuring the Response
    ChangeMessageVisibilityBatchResponse (..),
    newChangeMessageVisibilityBatchResponse,

    -- * Response Lenses
    changeMessageVisibilityBatchResponse_httpStatus,
    changeMessageVisibilityBatchResponse_successful,
    changeMessageVisibilityBatchResponse_failed,
  )
where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
import Amazonka.SQS.Types

-- |
--
-- /See:/ 'newChangeMessageVisibilityBatch' smart constructor.
data ChangeMessageVisibilityBatch = ChangeMessageVisibilityBatch'
  { -- | The URL of the Amazon SQS queue whose messages\' visibility is changed.
    --
    -- Queue URLs and names are case-sensitive.
    ChangeMessageVisibilityBatch -> Text
queueUrl :: Prelude.Text,
    -- | A list of receipt handles of the messages for which the visibility
    -- timeout must be changed.
    ChangeMessageVisibilityBatch
-> [ChangeMessageVisibilityBatchRequestEntry]
entries :: [ChangeMessageVisibilityBatchRequestEntry]
  }
  deriving (ChangeMessageVisibilityBatch
-> ChangeMessageVisibilityBatch -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ChangeMessageVisibilityBatch
-> ChangeMessageVisibilityBatch -> Bool
$c/= :: ChangeMessageVisibilityBatch
-> ChangeMessageVisibilityBatch -> Bool
== :: ChangeMessageVisibilityBatch
-> ChangeMessageVisibilityBatch -> Bool
$c== :: ChangeMessageVisibilityBatch
-> ChangeMessageVisibilityBatch -> Bool
Prelude.Eq, ReadPrec [ChangeMessageVisibilityBatch]
ReadPrec ChangeMessageVisibilityBatch
Int -> ReadS ChangeMessageVisibilityBatch
ReadS [ChangeMessageVisibilityBatch]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ChangeMessageVisibilityBatch]
$creadListPrec :: ReadPrec [ChangeMessageVisibilityBatch]
readPrec :: ReadPrec ChangeMessageVisibilityBatch
$creadPrec :: ReadPrec ChangeMessageVisibilityBatch
readList :: ReadS [ChangeMessageVisibilityBatch]
$creadList :: ReadS [ChangeMessageVisibilityBatch]
readsPrec :: Int -> ReadS ChangeMessageVisibilityBatch
$creadsPrec :: Int -> ReadS ChangeMessageVisibilityBatch
Prelude.Read, Int -> ChangeMessageVisibilityBatch -> ShowS
[ChangeMessageVisibilityBatch] -> ShowS
ChangeMessageVisibilityBatch -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ChangeMessageVisibilityBatch] -> ShowS
$cshowList :: [ChangeMessageVisibilityBatch] -> ShowS
show :: ChangeMessageVisibilityBatch -> String
$cshow :: ChangeMessageVisibilityBatch -> String
showsPrec :: Int -> ChangeMessageVisibilityBatch -> ShowS
$cshowsPrec :: Int -> ChangeMessageVisibilityBatch -> ShowS
Prelude.Show, forall x.
Rep ChangeMessageVisibilityBatch x -> ChangeMessageVisibilityBatch
forall x.
ChangeMessageVisibilityBatch -> Rep ChangeMessageVisibilityBatch x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep ChangeMessageVisibilityBatch x -> ChangeMessageVisibilityBatch
$cfrom :: forall x.
ChangeMessageVisibilityBatch -> Rep ChangeMessageVisibilityBatch x
Prelude.Generic)

-- |
-- Create a value of 'ChangeMessageVisibilityBatch' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'queueUrl', 'changeMessageVisibilityBatch_queueUrl' - The URL of the Amazon SQS queue whose messages\' visibility is changed.
--
-- Queue URLs and names are case-sensitive.
--
-- 'entries', 'changeMessageVisibilityBatch_entries' - A list of receipt handles of the messages for which the visibility
-- timeout must be changed.
newChangeMessageVisibilityBatch ::
  -- | 'queueUrl'
  Prelude.Text ->
  ChangeMessageVisibilityBatch
newChangeMessageVisibilityBatch :: Text -> ChangeMessageVisibilityBatch
newChangeMessageVisibilityBatch Text
pQueueUrl_ =
  ChangeMessageVisibilityBatch'
    { $sel:queueUrl:ChangeMessageVisibilityBatch' :: Text
queueUrl =
        Text
pQueueUrl_,
      $sel:entries:ChangeMessageVisibilityBatch' :: [ChangeMessageVisibilityBatchRequestEntry]
entries = forall a. Monoid a => a
Prelude.mempty
    }

-- | The URL of the Amazon SQS queue whose messages\' visibility is changed.
--
-- Queue URLs and names are case-sensitive.
changeMessageVisibilityBatch_queueUrl :: Lens.Lens' ChangeMessageVisibilityBatch Prelude.Text
changeMessageVisibilityBatch_queueUrl :: Lens' ChangeMessageVisibilityBatch Text
changeMessageVisibilityBatch_queueUrl = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ChangeMessageVisibilityBatch' {Text
queueUrl :: Text
$sel:queueUrl:ChangeMessageVisibilityBatch' :: ChangeMessageVisibilityBatch -> Text
queueUrl} -> Text
queueUrl) (\s :: ChangeMessageVisibilityBatch
s@ChangeMessageVisibilityBatch' {} Text
a -> ChangeMessageVisibilityBatch
s {$sel:queueUrl:ChangeMessageVisibilityBatch' :: Text
queueUrl = Text
a} :: ChangeMessageVisibilityBatch)

-- | A list of receipt handles of the messages for which the visibility
-- timeout must be changed.
changeMessageVisibilityBatch_entries :: Lens.Lens' ChangeMessageVisibilityBatch [ChangeMessageVisibilityBatchRequestEntry]
changeMessageVisibilityBatch_entries :: Lens'
  ChangeMessageVisibilityBatch
  [ChangeMessageVisibilityBatchRequestEntry]
changeMessageVisibilityBatch_entries = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ChangeMessageVisibilityBatch' {[ChangeMessageVisibilityBatchRequestEntry]
entries :: [ChangeMessageVisibilityBatchRequestEntry]
$sel:entries:ChangeMessageVisibilityBatch' :: ChangeMessageVisibilityBatch
-> [ChangeMessageVisibilityBatchRequestEntry]
entries} -> [ChangeMessageVisibilityBatchRequestEntry]
entries) (\s :: ChangeMessageVisibilityBatch
s@ChangeMessageVisibilityBatch' {} [ChangeMessageVisibilityBatchRequestEntry]
a -> ChangeMessageVisibilityBatch
s {$sel:entries:ChangeMessageVisibilityBatch' :: [ChangeMessageVisibilityBatchRequestEntry]
entries = [ChangeMessageVisibilityBatchRequestEntry]
a} :: ChangeMessageVisibilityBatch) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

instance Core.AWSRequest ChangeMessageVisibilityBatch where
  type
    AWSResponse ChangeMessageVisibilityBatch =
      ChangeMessageVisibilityBatchResponse
  request :: (Service -> Service)
-> ChangeMessageVisibilityBatch
-> Request ChangeMessageVisibilityBatch
request Service -> Service
overrides =
    forall a. ToRequest a => Service -> a -> Request a
Request.postQuery (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy ChangeMessageVisibilityBatch
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse ChangeMessageVisibilityBatch)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
Text
-> (Int
    -> ResponseHeaders -> [Node] -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveXMLWrapper
      Text
"ChangeMessageVisibilityBatchResult"
      ( \Int
s ResponseHeaders
h [Node]
x ->
          Int
-> [ChangeMessageVisibilityBatchResultEntry]
-> [BatchResultErrorEntry]
-> ChangeMessageVisibilityBatchResponse
ChangeMessageVisibilityBatchResponse'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ( forall a. FromXML a => Text -> [Node] -> Either String [a]
Data.parseXMLList
                            Text
"ChangeMessageVisibilityBatchResultEntry"
                            [Node]
x
                        )
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (forall a. FromXML a => Text -> [Node] -> Either String [a]
Data.parseXMLList Text
"BatchResultErrorEntry" [Node]
x)
      )

instance
  Prelude.Hashable
    ChangeMessageVisibilityBatch
  where
  hashWithSalt :: Int -> ChangeMessageVisibilityBatch -> Int
hashWithSalt Int
_salt ChangeMessageVisibilityBatch' {[ChangeMessageVisibilityBatchRequestEntry]
Text
entries :: [ChangeMessageVisibilityBatchRequestEntry]
queueUrl :: Text
$sel:entries:ChangeMessageVisibilityBatch' :: ChangeMessageVisibilityBatch
-> [ChangeMessageVisibilityBatchRequestEntry]
$sel:queueUrl:ChangeMessageVisibilityBatch' :: ChangeMessageVisibilityBatch -> Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
queueUrl
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` [ChangeMessageVisibilityBatchRequestEntry]
entries

instance Prelude.NFData ChangeMessageVisibilityBatch where
  rnf :: ChangeMessageVisibilityBatch -> ()
rnf ChangeMessageVisibilityBatch' {[ChangeMessageVisibilityBatchRequestEntry]
Text
entries :: [ChangeMessageVisibilityBatchRequestEntry]
queueUrl :: Text
$sel:entries:ChangeMessageVisibilityBatch' :: ChangeMessageVisibilityBatch
-> [ChangeMessageVisibilityBatchRequestEntry]
$sel:queueUrl:ChangeMessageVisibilityBatch' :: ChangeMessageVisibilityBatch -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
queueUrl
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf [ChangeMessageVisibilityBatchRequestEntry]
entries

instance Data.ToHeaders ChangeMessageVisibilityBatch where
  toHeaders :: ChangeMessageVisibilityBatch -> ResponseHeaders
toHeaders = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

instance Data.ToPath ChangeMessageVisibilityBatch where
  toPath :: ChangeMessageVisibilityBatch -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

instance Data.ToQuery ChangeMessageVisibilityBatch where
  toQuery :: ChangeMessageVisibilityBatch -> QueryString
toQuery ChangeMessageVisibilityBatch' {[ChangeMessageVisibilityBatchRequestEntry]
Text
entries :: [ChangeMessageVisibilityBatchRequestEntry]
queueUrl :: Text
$sel:entries:ChangeMessageVisibilityBatch' :: ChangeMessageVisibilityBatch
-> [ChangeMessageVisibilityBatchRequestEntry]
$sel:queueUrl:ChangeMessageVisibilityBatch' :: ChangeMessageVisibilityBatch -> Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"Action"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: ( ByteString
"ChangeMessageVisibilityBatch" ::
                      Prelude.ByteString
                  ),
        ByteString
"Version"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2012-11-05" :: Prelude.ByteString),
        ByteString
"QueueUrl" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Text
queueUrl,
        forall a.
(IsList a, ToQuery (Item a)) =>
ByteString -> a -> QueryString
Data.toQueryList
          ByteString
"ChangeMessageVisibilityBatchRequestEntry"
          [ChangeMessageVisibilityBatchRequestEntry]
entries
      ]

-- | For each message in the batch, the response contains a
-- @ @@ChangeMessageVisibilityBatchResultEntry@@ @ tag if the message
-- succeeds or a @ @@BatchResultErrorEntry@@ @ tag if the message fails.
--
-- /See:/ 'newChangeMessageVisibilityBatchResponse' smart constructor.
data ChangeMessageVisibilityBatchResponse = ChangeMessageVisibilityBatchResponse'
  { -- | The response's http status code.
    ChangeMessageVisibilityBatchResponse -> Int
httpStatus :: Prelude.Int,
    -- | A list of @ @@ChangeMessageVisibilityBatchResultEntry@@ @ items.
    ChangeMessageVisibilityBatchResponse
-> [ChangeMessageVisibilityBatchResultEntry]
successful :: [ChangeMessageVisibilityBatchResultEntry],
    -- | A list of @ @@BatchResultErrorEntry@@ @ items.
    ChangeMessageVisibilityBatchResponse -> [BatchResultErrorEntry]
failed :: [BatchResultErrorEntry]
  }
  deriving (ChangeMessageVisibilityBatchResponse
-> ChangeMessageVisibilityBatchResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ChangeMessageVisibilityBatchResponse
-> ChangeMessageVisibilityBatchResponse -> Bool
$c/= :: ChangeMessageVisibilityBatchResponse
-> ChangeMessageVisibilityBatchResponse -> Bool
== :: ChangeMessageVisibilityBatchResponse
-> ChangeMessageVisibilityBatchResponse -> Bool
$c== :: ChangeMessageVisibilityBatchResponse
-> ChangeMessageVisibilityBatchResponse -> Bool
Prelude.Eq, ReadPrec [ChangeMessageVisibilityBatchResponse]
ReadPrec ChangeMessageVisibilityBatchResponse
Int -> ReadS ChangeMessageVisibilityBatchResponse
ReadS [ChangeMessageVisibilityBatchResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ChangeMessageVisibilityBatchResponse]
$creadListPrec :: ReadPrec [ChangeMessageVisibilityBatchResponse]
readPrec :: ReadPrec ChangeMessageVisibilityBatchResponse
$creadPrec :: ReadPrec ChangeMessageVisibilityBatchResponse
readList :: ReadS [ChangeMessageVisibilityBatchResponse]
$creadList :: ReadS [ChangeMessageVisibilityBatchResponse]
readsPrec :: Int -> ReadS ChangeMessageVisibilityBatchResponse
$creadsPrec :: Int -> ReadS ChangeMessageVisibilityBatchResponse
Prelude.Read, Int -> ChangeMessageVisibilityBatchResponse -> ShowS
[ChangeMessageVisibilityBatchResponse] -> ShowS
ChangeMessageVisibilityBatchResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ChangeMessageVisibilityBatchResponse] -> ShowS
$cshowList :: [ChangeMessageVisibilityBatchResponse] -> ShowS
show :: ChangeMessageVisibilityBatchResponse -> String
$cshow :: ChangeMessageVisibilityBatchResponse -> String
showsPrec :: Int -> ChangeMessageVisibilityBatchResponse -> ShowS
$cshowsPrec :: Int -> ChangeMessageVisibilityBatchResponse -> ShowS
Prelude.Show, forall x.
Rep ChangeMessageVisibilityBatchResponse x
-> ChangeMessageVisibilityBatchResponse
forall x.
ChangeMessageVisibilityBatchResponse
-> Rep ChangeMessageVisibilityBatchResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep ChangeMessageVisibilityBatchResponse x
-> ChangeMessageVisibilityBatchResponse
$cfrom :: forall x.
ChangeMessageVisibilityBatchResponse
-> Rep ChangeMessageVisibilityBatchResponse x
Prelude.Generic)

-- |
-- Create a value of 'ChangeMessageVisibilityBatchResponse' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'httpStatus', 'changeMessageVisibilityBatchResponse_httpStatus' - The response's http status code.
--
-- 'successful', 'changeMessageVisibilityBatchResponse_successful' - A list of @ @@ChangeMessageVisibilityBatchResultEntry@@ @ items.
--
-- 'failed', 'changeMessageVisibilityBatchResponse_failed' - A list of @ @@BatchResultErrorEntry@@ @ items.
newChangeMessageVisibilityBatchResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  ChangeMessageVisibilityBatchResponse
newChangeMessageVisibilityBatchResponse :: Int -> ChangeMessageVisibilityBatchResponse
newChangeMessageVisibilityBatchResponse Int
pHttpStatus_ =
  ChangeMessageVisibilityBatchResponse'
    { $sel:httpStatus:ChangeMessageVisibilityBatchResponse' :: Int
httpStatus =
        Int
pHttpStatus_,
      $sel:successful:ChangeMessageVisibilityBatchResponse' :: [ChangeMessageVisibilityBatchResultEntry]
successful = forall a. Monoid a => a
Prelude.mempty,
      $sel:failed:ChangeMessageVisibilityBatchResponse' :: [BatchResultErrorEntry]
failed = forall a. Monoid a => a
Prelude.mempty
    }

-- | The response's http status code.
changeMessageVisibilityBatchResponse_httpStatus :: Lens.Lens' ChangeMessageVisibilityBatchResponse Prelude.Int
changeMessageVisibilityBatchResponse_httpStatus :: Lens' ChangeMessageVisibilityBatchResponse Int
changeMessageVisibilityBatchResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ChangeMessageVisibilityBatchResponse' {Int
httpStatus :: Int
$sel:httpStatus:ChangeMessageVisibilityBatchResponse' :: ChangeMessageVisibilityBatchResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: ChangeMessageVisibilityBatchResponse
s@ChangeMessageVisibilityBatchResponse' {} Int
a -> ChangeMessageVisibilityBatchResponse
s {$sel:httpStatus:ChangeMessageVisibilityBatchResponse' :: Int
httpStatus = Int
a} :: ChangeMessageVisibilityBatchResponse)

-- | A list of @ @@ChangeMessageVisibilityBatchResultEntry@@ @ items.
changeMessageVisibilityBatchResponse_successful :: Lens.Lens' ChangeMessageVisibilityBatchResponse [ChangeMessageVisibilityBatchResultEntry]
changeMessageVisibilityBatchResponse_successful :: Lens'
  ChangeMessageVisibilityBatchResponse
  [ChangeMessageVisibilityBatchResultEntry]
changeMessageVisibilityBatchResponse_successful = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ChangeMessageVisibilityBatchResponse' {[ChangeMessageVisibilityBatchResultEntry]
successful :: [ChangeMessageVisibilityBatchResultEntry]
$sel:successful:ChangeMessageVisibilityBatchResponse' :: ChangeMessageVisibilityBatchResponse
-> [ChangeMessageVisibilityBatchResultEntry]
successful} -> [ChangeMessageVisibilityBatchResultEntry]
successful) (\s :: ChangeMessageVisibilityBatchResponse
s@ChangeMessageVisibilityBatchResponse' {} [ChangeMessageVisibilityBatchResultEntry]
a -> ChangeMessageVisibilityBatchResponse
s {$sel:successful:ChangeMessageVisibilityBatchResponse' :: [ChangeMessageVisibilityBatchResultEntry]
successful = [ChangeMessageVisibilityBatchResultEntry]
a} :: ChangeMessageVisibilityBatchResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

-- | A list of @ @@BatchResultErrorEntry@@ @ items.
changeMessageVisibilityBatchResponse_failed :: Lens.Lens' ChangeMessageVisibilityBatchResponse [BatchResultErrorEntry]
changeMessageVisibilityBatchResponse_failed :: Lens' ChangeMessageVisibilityBatchResponse [BatchResultErrorEntry]
changeMessageVisibilityBatchResponse_failed = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ChangeMessageVisibilityBatchResponse' {[BatchResultErrorEntry]
failed :: [BatchResultErrorEntry]
$sel:failed:ChangeMessageVisibilityBatchResponse' :: ChangeMessageVisibilityBatchResponse -> [BatchResultErrorEntry]
failed} -> [BatchResultErrorEntry]
failed) (\s :: ChangeMessageVisibilityBatchResponse
s@ChangeMessageVisibilityBatchResponse' {} [BatchResultErrorEntry]
a -> ChangeMessageVisibilityBatchResponse
s {$sel:failed:ChangeMessageVisibilityBatchResponse' :: [BatchResultErrorEntry]
failed = [BatchResultErrorEntry]
a} :: ChangeMessageVisibilityBatchResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

instance
  Prelude.NFData
    ChangeMessageVisibilityBatchResponse
  where
  rnf :: ChangeMessageVisibilityBatchResponse -> ()
rnf ChangeMessageVisibilityBatchResponse' {Int
[BatchResultErrorEntry]
[ChangeMessageVisibilityBatchResultEntry]
failed :: [BatchResultErrorEntry]
successful :: [ChangeMessageVisibilityBatchResultEntry]
httpStatus :: Int
$sel:failed:ChangeMessageVisibilityBatchResponse' :: ChangeMessageVisibilityBatchResponse -> [BatchResultErrorEntry]
$sel:successful:ChangeMessageVisibilityBatchResponse' :: ChangeMessageVisibilityBatchResponse
-> [ChangeMessageVisibilityBatchResultEntry]
$sel:httpStatus:ChangeMessageVisibilityBatchResponse' :: ChangeMessageVisibilityBatchResponse -> Int
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf [ChangeMessageVisibilityBatchResultEntry]
successful
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf [BatchResultErrorEntry]
failed