{-# 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 #-}
module Amazonka.DrS.TerminateRecoveryInstances
(
TerminateRecoveryInstances (..),
newTerminateRecoveryInstances,
terminateRecoveryInstances_recoveryInstanceIDs,
TerminateRecoveryInstancesResponse (..),
newTerminateRecoveryInstancesResponse,
terminateRecoveryInstancesResponse_job,
terminateRecoveryInstancesResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.DrS.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data TerminateRecoveryInstances = TerminateRecoveryInstances'
{
TerminateRecoveryInstances -> NonEmpty Text
recoveryInstanceIDs :: Prelude.NonEmpty Prelude.Text
}
deriving (TerminateRecoveryInstances -> TerminateRecoveryInstances -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: TerminateRecoveryInstances -> TerminateRecoveryInstances -> Bool
$c/= :: TerminateRecoveryInstances -> TerminateRecoveryInstances -> Bool
== :: TerminateRecoveryInstances -> TerminateRecoveryInstances -> Bool
$c== :: TerminateRecoveryInstances -> TerminateRecoveryInstances -> Bool
Prelude.Eq, ReadPrec [TerminateRecoveryInstances]
ReadPrec TerminateRecoveryInstances
Int -> ReadS TerminateRecoveryInstances
ReadS [TerminateRecoveryInstances]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [TerminateRecoveryInstances]
$creadListPrec :: ReadPrec [TerminateRecoveryInstances]
readPrec :: ReadPrec TerminateRecoveryInstances
$creadPrec :: ReadPrec TerminateRecoveryInstances
readList :: ReadS [TerminateRecoveryInstances]
$creadList :: ReadS [TerminateRecoveryInstances]
readsPrec :: Int -> ReadS TerminateRecoveryInstances
$creadsPrec :: Int -> ReadS TerminateRecoveryInstances
Prelude.Read, Int -> TerminateRecoveryInstances -> ShowS
[TerminateRecoveryInstances] -> ShowS
TerminateRecoveryInstances -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [TerminateRecoveryInstances] -> ShowS
$cshowList :: [TerminateRecoveryInstances] -> ShowS
show :: TerminateRecoveryInstances -> String
$cshow :: TerminateRecoveryInstances -> String
showsPrec :: Int -> TerminateRecoveryInstances -> ShowS
$cshowsPrec :: Int -> TerminateRecoveryInstances -> ShowS
Prelude.Show, forall x.
Rep TerminateRecoveryInstances x -> TerminateRecoveryInstances
forall x.
TerminateRecoveryInstances -> Rep TerminateRecoveryInstances x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep TerminateRecoveryInstances x -> TerminateRecoveryInstances
$cfrom :: forall x.
TerminateRecoveryInstances -> Rep TerminateRecoveryInstances x
Prelude.Generic)
newTerminateRecoveryInstances ::
Prelude.NonEmpty Prelude.Text ->
TerminateRecoveryInstances
newTerminateRecoveryInstances :: NonEmpty Text -> TerminateRecoveryInstances
newTerminateRecoveryInstances NonEmpty Text
pRecoveryInstanceIDs_ =
TerminateRecoveryInstances'
{ $sel:recoveryInstanceIDs:TerminateRecoveryInstances' :: NonEmpty Text
recoveryInstanceIDs =
forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced forall t b. AReview t b -> b -> t
Lens.# NonEmpty Text
pRecoveryInstanceIDs_
}
terminateRecoveryInstances_recoveryInstanceIDs :: Lens.Lens' TerminateRecoveryInstances (Prelude.NonEmpty Prelude.Text)
terminateRecoveryInstances_recoveryInstanceIDs :: Lens' TerminateRecoveryInstances (NonEmpty Text)
terminateRecoveryInstances_recoveryInstanceIDs = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\TerminateRecoveryInstances' {NonEmpty Text
recoveryInstanceIDs :: NonEmpty Text
$sel:recoveryInstanceIDs:TerminateRecoveryInstances' :: TerminateRecoveryInstances -> NonEmpty Text
recoveryInstanceIDs} -> NonEmpty Text
recoveryInstanceIDs) (\s :: TerminateRecoveryInstances
s@TerminateRecoveryInstances' {} NonEmpty Text
a -> TerminateRecoveryInstances
s {$sel:recoveryInstanceIDs:TerminateRecoveryInstances' :: NonEmpty Text
recoveryInstanceIDs = NonEmpty Text
a} :: TerminateRecoveryInstances) 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 TerminateRecoveryInstances where
type
AWSResponse TerminateRecoveryInstances =
TerminateRecoveryInstancesResponse
request :: (Service -> Service)
-> TerminateRecoveryInstances -> Request TerminateRecoveryInstances
request Service -> Service
overrides =
forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.postJSON (Service -> Service
overrides Service
defaultService)
response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy TerminateRecoveryInstances
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse TerminateRecoveryInstances)))
response =
forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> Object -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveJSON
( \Int
s ResponseHeaders
h Object
x ->
Maybe Job -> Int -> TerminateRecoveryInstancesResponse
TerminateRecoveryInstancesResponse'
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"job")
forall (f :: * -> *) a b. Applicative f => 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))
)
instance Prelude.Hashable TerminateRecoveryInstances where
hashWithSalt :: Int -> TerminateRecoveryInstances -> Int
hashWithSalt Int
_salt TerminateRecoveryInstances' {NonEmpty Text
recoveryInstanceIDs :: NonEmpty Text
$sel:recoveryInstanceIDs:TerminateRecoveryInstances' :: TerminateRecoveryInstances -> NonEmpty Text
..} =
Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` NonEmpty Text
recoveryInstanceIDs
instance Prelude.NFData TerminateRecoveryInstances where
rnf :: TerminateRecoveryInstances -> ()
rnf TerminateRecoveryInstances' {NonEmpty Text
recoveryInstanceIDs :: NonEmpty Text
$sel:recoveryInstanceIDs:TerminateRecoveryInstances' :: TerminateRecoveryInstances -> NonEmpty Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf NonEmpty Text
recoveryInstanceIDs
instance Data.ToHeaders TerminateRecoveryInstances where
toHeaders :: TerminateRecoveryInstances -> ResponseHeaders
toHeaders =
forall a b. a -> b -> a
Prelude.const
( forall a. Monoid a => [a] -> a
Prelude.mconcat
[ HeaderName
"Content-Type"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
Prelude.ByteString
)
]
)
instance Data.ToJSON TerminateRecoveryInstances where
toJSON :: TerminateRecoveryInstances -> Value
toJSON TerminateRecoveryInstances' {NonEmpty Text
recoveryInstanceIDs :: NonEmpty Text
$sel:recoveryInstanceIDs:TerminateRecoveryInstances' :: TerminateRecoveryInstances -> NonEmpty Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ forall a. a -> Maybe a
Prelude.Just
(Key
"recoveryInstanceIDs" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= NonEmpty Text
recoveryInstanceIDs)
]
)
instance Data.ToPath TerminateRecoveryInstances where
toPath :: TerminateRecoveryInstances -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/TerminateRecoveryInstances"
instance Data.ToQuery TerminateRecoveryInstances where
toQuery :: TerminateRecoveryInstances -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data TerminateRecoveryInstancesResponse = TerminateRecoveryInstancesResponse'
{
TerminateRecoveryInstancesResponse -> Maybe Job
job :: Prelude.Maybe Job,
TerminateRecoveryInstancesResponse -> Int
httpStatus :: Prelude.Int
}
deriving (TerminateRecoveryInstancesResponse
-> TerminateRecoveryInstancesResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: TerminateRecoveryInstancesResponse
-> TerminateRecoveryInstancesResponse -> Bool
$c/= :: TerminateRecoveryInstancesResponse
-> TerminateRecoveryInstancesResponse -> Bool
== :: TerminateRecoveryInstancesResponse
-> TerminateRecoveryInstancesResponse -> Bool
$c== :: TerminateRecoveryInstancesResponse
-> TerminateRecoveryInstancesResponse -> Bool
Prelude.Eq, Int -> TerminateRecoveryInstancesResponse -> ShowS
[TerminateRecoveryInstancesResponse] -> ShowS
TerminateRecoveryInstancesResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [TerminateRecoveryInstancesResponse] -> ShowS
$cshowList :: [TerminateRecoveryInstancesResponse] -> ShowS
show :: TerminateRecoveryInstancesResponse -> String
$cshow :: TerminateRecoveryInstancesResponse -> String
showsPrec :: Int -> TerminateRecoveryInstancesResponse -> ShowS
$cshowsPrec :: Int -> TerminateRecoveryInstancesResponse -> ShowS
Prelude.Show, forall x.
Rep TerminateRecoveryInstancesResponse x
-> TerminateRecoveryInstancesResponse
forall x.
TerminateRecoveryInstancesResponse
-> Rep TerminateRecoveryInstancesResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep TerminateRecoveryInstancesResponse x
-> TerminateRecoveryInstancesResponse
$cfrom :: forall x.
TerminateRecoveryInstancesResponse
-> Rep TerminateRecoveryInstancesResponse x
Prelude.Generic)
newTerminateRecoveryInstancesResponse ::
Prelude.Int ->
TerminateRecoveryInstancesResponse
newTerminateRecoveryInstancesResponse :: Int -> TerminateRecoveryInstancesResponse
newTerminateRecoveryInstancesResponse Int
pHttpStatus_ =
TerminateRecoveryInstancesResponse'
{ $sel:job:TerminateRecoveryInstancesResponse' :: Maybe Job
job =
forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:TerminateRecoveryInstancesResponse' :: Int
httpStatus = Int
pHttpStatus_
}
terminateRecoveryInstancesResponse_job :: Lens.Lens' TerminateRecoveryInstancesResponse (Prelude.Maybe Job)
terminateRecoveryInstancesResponse_job :: Lens' TerminateRecoveryInstancesResponse (Maybe Job)
terminateRecoveryInstancesResponse_job = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\TerminateRecoveryInstancesResponse' {Maybe Job
job :: Maybe Job
$sel:job:TerminateRecoveryInstancesResponse' :: TerminateRecoveryInstancesResponse -> Maybe Job
job} -> Maybe Job
job) (\s :: TerminateRecoveryInstancesResponse
s@TerminateRecoveryInstancesResponse' {} Maybe Job
a -> TerminateRecoveryInstancesResponse
s {$sel:job:TerminateRecoveryInstancesResponse' :: Maybe Job
job = Maybe Job
a} :: TerminateRecoveryInstancesResponse)
terminateRecoveryInstancesResponse_httpStatus :: Lens.Lens' TerminateRecoveryInstancesResponse Prelude.Int
terminateRecoveryInstancesResponse_httpStatus :: Lens' TerminateRecoveryInstancesResponse Int
terminateRecoveryInstancesResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\TerminateRecoveryInstancesResponse' {Int
httpStatus :: Int
$sel:httpStatus:TerminateRecoveryInstancesResponse' :: TerminateRecoveryInstancesResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: TerminateRecoveryInstancesResponse
s@TerminateRecoveryInstancesResponse' {} Int
a -> TerminateRecoveryInstancesResponse
s {$sel:httpStatus:TerminateRecoveryInstancesResponse' :: Int
httpStatus = Int
a} :: TerminateRecoveryInstancesResponse)
instance
Prelude.NFData
TerminateRecoveryInstancesResponse
where
rnf :: TerminateRecoveryInstancesResponse -> ()
rnf TerminateRecoveryInstancesResponse' {Int
Maybe Job
httpStatus :: Int
job :: Maybe Job
$sel:httpStatus:TerminateRecoveryInstancesResponse' :: TerminateRecoveryInstancesResponse -> Int
$sel:job:TerminateRecoveryInstancesResponse' :: TerminateRecoveryInstancesResponse -> Maybe Job
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Job
job
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus