{-# 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.EC2.DeleteFleets
(
DeleteFleets (..),
newDeleteFleets,
deleteFleets_dryRun,
deleteFleets_fleetIds,
deleteFleets_terminateInstances,
DeleteFleetsResponse (..),
newDeleteFleetsResponse,
deleteFleetsResponse_successfulFleetDeletions,
deleteFleetsResponse_unsuccessfulFleetDeletions,
deleteFleetsResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.EC2.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data DeleteFleets = DeleteFleets'
{
DeleteFleets -> Maybe Bool
dryRun :: Prelude.Maybe Prelude.Bool,
DeleteFleets -> [Text]
fleetIds :: [Prelude.Text],
DeleteFleets -> Bool
terminateInstances :: Prelude.Bool
}
deriving (DeleteFleets -> DeleteFleets -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteFleets -> DeleteFleets -> Bool
$c/= :: DeleteFleets -> DeleteFleets -> Bool
== :: DeleteFleets -> DeleteFleets -> Bool
$c== :: DeleteFleets -> DeleteFleets -> Bool
Prelude.Eq, ReadPrec [DeleteFleets]
ReadPrec DeleteFleets
Int -> ReadS DeleteFleets
ReadS [DeleteFleets]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteFleets]
$creadListPrec :: ReadPrec [DeleteFleets]
readPrec :: ReadPrec DeleteFleets
$creadPrec :: ReadPrec DeleteFleets
readList :: ReadS [DeleteFleets]
$creadList :: ReadS [DeleteFleets]
readsPrec :: Int -> ReadS DeleteFleets
$creadsPrec :: Int -> ReadS DeleteFleets
Prelude.Read, Int -> DeleteFleets -> ShowS
[DeleteFleets] -> ShowS
DeleteFleets -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteFleets] -> ShowS
$cshowList :: [DeleteFleets] -> ShowS
show :: DeleteFleets -> String
$cshow :: DeleteFleets -> String
showsPrec :: Int -> DeleteFleets -> ShowS
$cshowsPrec :: Int -> DeleteFleets -> ShowS
Prelude.Show, forall x. Rep DeleteFleets x -> DeleteFleets
forall x. DeleteFleets -> Rep DeleteFleets x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteFleets x -> DeleteFleets
$cfrom :: forall x. DeleteFleets -> Rep DeleteFleets x
Prelude.Generic)
newDeleteFleets ::
Prelude.Bool ->
DeleteFleets
newDeleteFleets :: Bool -> DeleteFleets
newDeleteFleets Bool
pTerminateInstances_ =
DeleteFleets'
{ $sel:dryRun:DeleteFleets' :: Maybe Bool
dryRun = forall a. Maybe a
Prelude.Nothing,
$sel:fleetIds:DeleteFleets' :: [Text]
fleetIds = forall a. Monoid a => a
Prelude.mempty,
$sel:terminateInstances:DeleteFleets' :: Bool
terminateInstances = Bool
pTerminateInstances_
}
deleteFleets_dryRun :: Lens.Lens' DeleteFleets (Prelude.Maybe Prelude.Bool)
deleteFleets_dryRun :: Lens' DeleteFleets (Maybe Bool)
deleteFleets_dryRun = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteFleets' {Maybe Bool
dryRun :: Maybe Bool
$sel:dryRun:DeleteFleets' :: DeleteFleets -> Maybe Bool
dryRun} -> Maybe Bool
dryRun) (\s :: DeleteFleets
s@DeleteFleets' {} Maybe Bool
a -> DeleteFleets
s {$sel:dryRun:DeleteFleets' :: Maybe Bool
dryRun = Maybe Bool
a} :: DeleteFleets)
deleteFleets_fleetIds :: Lens.Lens' DeleteFleets [Prelude.Text]
deleteFleets_fleetIds :: Lens' DeleteFleets [Text]
deleteFleets_fleetIds = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteFleets' {[Text]
fleetIds :: [Text]
$sel:fleetIds:DeleteFleets' :: DeleteFleets -> [Text]
fleetIds} -> [Text]
fleetIds) (\s :: DeleteFleets
s@DeleteFleets' {} [Text]
a -> DeleteFleets
s {$sel:fleetIds:DeleteFleets' :: [Text]
fleetIds = [Text]
a} :: DeleteFleets) 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
deleteFleets_terminateInstances :: Lens.Lens' DeleteFleets Prelude.Bool
deleteFleets_terminateInstances :: Lens' DeleteFleets Bool
deleteFleets_terminateInstances = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteFleets' {Bool
terminateInstances :: Bool
$sel:terminateInstances:DeleteFleets' :: DeleteFleets -> Bool
terminateInstances} -> Bool
terminateInstances) (\s :: DeleteFleets
s@DeleteFleets' {} Bool
a -> DeleteFleets
s {$sel:terminateInstances:DeleteFleets' :: Bool
terminateInstances = Bool
a} :: DeleteFleets)
instance Core.AWSRequest DeleteFleets where
type AWSResponse DeleteFleets = DeleteFleetsResponse
request :: (Service -> Service) -> DeleteFleets -> Request DeleteFleets
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 DeleteFleets
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DeleteFleets)))
response =
forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> [Node] -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveXML
( \Int
s ResponseHeaders
h [Node]
x ->
Maybe [DeleteFleetSuccessItem]
-> Maybe [DeleteFleetErrorItem] -> Int -> DeleteFleetsResponse
DeleteFleetsResponse'
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> ( [Node]
x
forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"successfulFleetDeletionSet"
forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ forall a. Monoid a => a
Prelude.mempty
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
Prelude.>>= forall (f :: * -> *) a b.
Applicative f =>
([a] -> f b) -> [a] -> f (Maybe b)
Core.may (forall a. FromXML a => Text -> [Node] -> Either String [a]
Data.parseXMLList Text
"item")
)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ( [Node]
x
forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"unsuccessfulFleetDeletionSet"
forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ forall a. Monoid a => a
Prelude.mempty
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
Prelude.>>= forall (f :: * -> *) a b.
Applicative f =>
([a] -> f b) -> [a] -> f (Maybe b)
Core.may (forall a. FromXML a => Text -> [Node] -> Either String [a]
Data.parseXMLList Text
"item")
)
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 DeleteFleets where
hashWithSalt :: Int -> DeleteFleets -> Int
hashWithSalt Int
_salt DeleteFleets' {Bool
[Text]
Maybe Bool
terminateInstances :: Bool
fleetIds :: [Text]
dryRun :: Maybe Bool
$sel:terminateInstances:DeleteFleets' :: DeleteFleets -> Bool
$sel:fleetIds:DeleteFleets' :: DeleteFleets -> [Text]
$sel:dryRun:DeleteFleets' :: DeleteFleets -> Maybe Bool
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Bool
dryRun
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` [Text]
fleetIds
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Bool
terminateInstances
instance Prelude.NFData DeleteFleets where
rnf :: DeleteFleets -> ()
rnf DeleteFleets' {Bool
[Text]
Maybe Bool
terminateInstances :: Bool
fleetIds :: [Text]
dryRun :: Maybe Bool
$sel:terminateInstances:DeleteFleets' :: DeleteFleets -> Bool
$sel:fleetIds:DeleteFleets' :: DeleteFleets -> [Text]
$sel:dryRun:DeleteFleets' :: DeleteFleets -> Maybe Bool
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Bool
dryRun
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf [Text]
fleetIds
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Bool
terminateInstances
instance Data.ToHeaders DeleteFleets where
toHeaders :: DeleteFleets -> ResponseHeaders
toHeaders = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
instance Data.ToPath DeleteFleets where
toPath :: DeleteFleets -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery DeleteFleets where
toQuery :: DeleteFleets -> QueryString
toQuery DeleteFleets' {Bool
[Text]
Maybe Bool
terminateInstances :: Bool
fleetIds :: [Text]
dryRun :: Maybe Bool
$sel:terminateInstances:DeleteFleets' :: DeleteFleets -> Bool
$sel:fleetIds:DeleteFleets' :: DeleteFleets -> [Text]
$sel:dryRun:DeleteFleets' :: DeleteFleets -> Maybe Bool
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ ByteString
"Action"
forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"DeleteFleets" :: Prelude.ByteString),
ByteString
"Version"
forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2016-11-15" :: Prelude.ByteString),
ByteString
"DryRun" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Bool
dryRun,
forall a.
(IsList a, ToQuery (Item a)) =>
ByteString -> a -> QueryString
Data.toQueryList ByteString
"FleetId" [Text]
fleetIds,
ByteString
"TerminateInstances" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Bool
terminateInstances
]
data DeleteFleetsResponse = DeleteFleetsResponse'
{
DeleteFleetsResponse -> Maybe [DeleteFleetSuccessItem]
successfulFleetDeletions :: Prelude.Maybe [DeleteFleetSuccessItem],
DeleteFleetsResponse -> Maybe [DeleteFleetErrorItem]
unsuccessfulFleetDeletions :: Prelude.Maybe [DeleteFleetErrorItem],
DeleteFleetsResponse -> Int
httpStatus :: Prelude.Int
}
deriving (DeleteFleetsResponse -> DeleteFleetsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteFleetsResponse -> DeleteFleetsResponse -> Bool
$c/= :: DeleteFleetsResponse -> DeleteFleetsResponse -> Bool
== :: DeleteFleetsResponse -> DeleteFleetsResponse -> Bool
$c== :: DeleteFleetsResponse -> DeleteFleetsResponse -> Bool
Prelude.Eq, ReadPrec [DeleteFleetsResponse]
ReadPrec DeleteFleetsResponse
Int -> ReadS DeleteFleetsResponse
ReadS [DeleteFleetsResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteFleetsResponse]
$creadListPrec :: ReadPrec [DeleteFleetsResponse]
readPrec :: ReadPrec DeleteFleetsResponse
$creadPrec :: ReadPrec DeleteFleetsResponse
readList :: ReadS [DeleteFleetsResponse]
$creadList :: ReadS [DeleteFleetsResponse]
readsPrec :: Int -> ReadS DeleteFleetsResponse
$creadsPrec :: Int -> ReadS DeleteFleetsResponse
Prelude.Read, Int -> DeleteFleetsResponse -> ShowS
[DeleteFleetsResponse] -> ShowS
DeleteFleetsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteFleetsResponse] -> ShowS
$cshowList :: [DeleteFleetsResponse] -> ShowS
show :: DeleteFleetsResponse -> String
$cshow :: DeleteFleetsResponse -> String
showsPrec :: Int -> DeleteFleetsResponse -> ShowS
$cshowsPrec :: Int -> DeleteFleetsResponse -> ShowS
Prelude.Show, forall x. Rep DeleteFleetsResponse x -> DeleteFleetsResponse
forall x. DeleteFleetsResponse -> Rep DeleteFleetsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteFleetsResponse x -> DeleteFleetsResponse
$cfrom :: forall x. DeleteFleetsResponse -> Rep DeleteFleetsResponse x
Prelude.Generic)
newDeleteFleetsResponse ::
Prelude.Int ->
DeleteFleetsResponse
newDeleteFleetsResponse :: Int -> DeleteFleetsResponse
newDeleteFleetsResponse Int
pHttpStatus_ =
DeleteFleetsResponse'
{ $sel:successfulFleetDeletions:DeleteFleetsResponse' :: Maybe [DeleteFleetSuccessItem]
successfulFleetDeletions =
forall a. Maybe a
Prelude.Nothing,
$sel:unsuccessfulFleetDeletions:DeleteFleetsResponse' :: Maybe [DeleteFleetErrorItem]
unsuccessfulFleetDeletions = forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:DeleteFleetsResponse' :: Int
httpStatus = Int
pHttpStatus_
}
deleteFleetsResponse_successfulFleetDeletions :: Lens.Lens' DeleteFleetsResponse (Prelude.Maybe [DeleteFleetSuccessItem])
deleteFleetsResponse_successfulFleetDeletions :: Lens' DeleteFleetsResponse (Maybe [DeleteFleetSuccessItem])
deleteFleetsResponse_successfulFleetDeletions = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteFleetsResponse' {Maybe [DeleteFleetSuccessItem]
successfulFleetDeletions :: Maybe [DeleteFleetSuccessItem]
$sel:successfulFleetDeletions:DeleteFleetsResponse' :: DeleteFleetsResponse -> Maybe [DeleteFleetSuccessItem]
successfulFleetDeletions} -> Maybe [DeleteFleetSuccessItem]
successfulFleetDeletions) (\s :: DeleteFleetsResponse
s@DeleteFleetsResponse' {} Maybe [DeleteFleetSuccessItem]
a -> DeleteFleetsResponse
s {$sel:successfulFleetDeletions:DeleteFleetsResponse' :: Maybe [DeleteFleetSuccessItem]
successfulFleetDeletions = Maybe [DeleteFleetSuccessItem]
a} :: DeleteFleetsResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced
deleteFleetsResponse_unsuccessfulFleetDeletions :: Lens.Lens' DeleteFleetsResponse (Prelude.Maybe [DeleteFleetErrorItem])
deleteFleetsResponse_unsuccessfulFleetDeletions :: Lens' DeleteFleetsResponse (Maybe [DeleteFleetErrorItem])
deleteFleetsResponse_unsuccessfulFleetDeletions = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteFleetsResponse' {Maybe [DeleteFleetErrorItem]
unsuccessfulFleetDeletions :: Maybe [DeleteFleetErrorItem]
$sel:unsuccessfulFleetDeletions:DeleteFleetsResponse' :: DeleteFleetsResponse -> Maybe [DeleteFleetErrorItem]
unsuccessfulFleetDeletions} -> Maybe [DeleteFleetErrorItem]
unsuccessfulFleetDeletions) (\s :: DeleteFleetsResponse
s@DeleteFleetsResponse' {} Maybe [DeleteFleetErrorItem]
a -> DeleteFleetsResponse
s {$sel:unsuccessfulFleetDeletions:DeleteFleetsResponse' :: Maybe [DeleteFleetErrorItem]
unsuccessfulFleetDeletions = Maybe [DeleteFleetErrorItem]
a} :: DeleteFleetsResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced
deleteFleetsResponse_httpStatus :: Lens.Lens' DeleteFleetsResponse Prelude.Int
deleteFleetsResponse_httpStatus :: Lens' DeleteFleetsResponse Int
deleteFleetsResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteFleetsResponse' {Int
httpStatus :: Int
$sel:httpStatus:DeleteFleetsResponse' :: DeleteFleetsResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DeleteFleetsResponse
s@DeleteFleetsResponse' {} Int
a -> DeleteFleetsResponse
s {$sel:httpStatus:DeleteFleetsResponse' :: Int
httpStatus = Int
a} :: DeleteFleetsResponse)
instance Prelude.NFData DeleteFleetsResponse where
rnf :: DeleteFleetsResponse -> ()
rnf DeleteFleetsResponse' {Int
Maybe [DeleteFleetErrorItem]
Maybe [DeleteFleetSuccessItem]
httpStatus :: Int
unsuccessfulFleetDeletions :: Maybe [DeleteFleetErrorItem]
successfulFleetDeletions :: Maybe [DeleteFleetSuccessItem]
$sel:httpStatus:DeleteFleetsResponse' :: DeleteFleetsResponse -> Int
$sel:unsuccessfulFleetDeletions:DeleteFleetsResponse' :: DeleteFleetsResponse -> Maybe [DeleteFleetErrorItem]
$sel:successfulFleetDeletions:DeleteFleetsResponse' :: DeleteFleetsResponse -> Maybe [DeleteFleetSuccessItem]
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe [DeleteFleetSuccessItem]
successfulFleetDeletions
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [DeleteFleetErrorItem]
unsuccessfulFleetDeletions
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus