{-# 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.EMR.AddInstanceFleet
(
AddInstanceFleet (..),
newAddInstanceFleet,
addInstanceFleet_clusterId,
addInstanceFleet_instanceFleet,
AddInstanceFleetResponse (..),
newAddInstanceFleetResponse,
addInstanceFleetResponse_clusterArn,
addInstanceFleetResponse_clusterId,
addInstanceFleetResponse_instanceFleetId,
addInstanceFleetResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.EMR.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data AddInstanceFleet = AddInstanceFleet'
{
AddInstanceFleet -> Text
clusterId :: Prelude.Text,
AddInstanceFleet -> InstanceFleetConfig
instanceFleet :: InstanceFleetConfig
}
deriving (AddInstanceFleet -> AddInstanceFleet -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: AddInstanceFleet -> AddInstanceFleet -> Bool
$c/= :: AddInstanceFleet -> AddInstanceFleet -> Bool
== :: AddInstanceFleet -> AddInstanceFleet -> Bool
$c== :: AddInstanceFleet -> AddInstanceFleet -> Bool
Prelude.Eq, ReadPrec [AddInstanceFleet]
ReadPrec AddInstanceFleet
Int -> ReadS AddInstanceFleet
ReadS [AddInstanceFleet]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [AddInstanceFleet]
$creadListPrec :: ReadPrec [AddInstanceFleet]
readPrec :: ReadPrec AddInstanceFleet
$creadPrec :: ReadPrec AddInstanceFleet
readList :: ReadS [AddInstanceFleet]
$creadList :: ReadS [AddInstanceFleet]
readsPrec :: Int -> ReadS AddInstanceFleet
$creadsPrec :: Int -> ReadS AddInstanceFleet
Prelude.Read, Int -> AddInstanceFleet -> ShowS
[AddInstanceFleet] -> ShowS
AddInstanceFleet -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [AddInstanceFleet] -> ShowS
$cshowList :: [AddInstanceFleet] -> ShowS
show :: AddInstanceFleet -> String
$cshow :: AddInstanceFleet -> String
showsPrec :: Int -> AddInstanceFleet -> ShowS
$cshowsPrec :: Int -> AddInstanceFleet -> ShowS
Prelude.Show, forall x. Rep AddInstanceFleet x -> AddInstanceFleet
forall x. AddInstanceFleet -> Rep AddInstanceFleet x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep AddInstanceFleet x -> AddInstanceFleet
$cfrom :: forall x. AddInstanceFleet -> Rep AddInstanceFleet x
Prelude.Generic)
newAddInstanceFleet ::
Prelude.Text ->
InstanceFleetConfig ->
AddInstanceFleet
newAddInstanceFleet :: Text -> InstanceFleetConfig -> AddInstanceFleet
newAddInstanceFleet Text
pClusterId_ InstanceFleetConfig
pInstanceFleet_ =
AddInstanceFleet'
{ $sel:clusterId:AddInstanceFleet' :: Text
clusterId = Text
pClusterId_,
$sel:instanceFleet:AddInstanceFleet' :: InstanceFleetConfig
instanceFleet = InstanceFleetConfig
pInstanceFleet_
}
addInstanceFleet_clusterId :: Lens.Lens' AddInstanceFleet Prelude.Text
addInstanceFleet_clusterId :: Lens' AddInstanceFleet Text
addInstanceFleet_clusterId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AddInstanceFleet' {Text
clusterId :: Text
$sel:clusterId:AddInstanceFleet' :: AddInstanceFleet -> Text
clusterId} -> Text
clusterId) (\s :: AddInstanceFleet
s@AddInstanceFleet' {} Text
a -> AddInstanceFleet
s {$sel:clusterId:AddInstanceFleet' :: Text
clusterId = Text
a} :: AddInstanceFleet)
addInstanceFleet_instanceFleet :: Lens.Lens' AddInstanceFleet InstanceFleetConfig
addInstanceFleet_instanceFleet :: Lens' AddInstanceFleet InstanceFleetConfig
addInstanceFleet_instanceFleet = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AddInstanceFleet' {InstanceFleetConfig
instanceFleet :: InstanceFleetConfig
$sel:instanceFleet:AddInstanceFleet' :: AddInstanceFleet -> InstanceFleetConfig
instanceFleet} -> InstanceFleetConfig
instanceFleet) (\s :: AddInstanceFleet
s@AddInstanceFleet' {} InstanceFleetConfig
a -> AddInstanceFleet
s {$sel:instanceFleet:AddInstanceFleet' :: InstanceFleetConfig
instanceFleet = InstanceFleetConfig
a} :: AddInstanceFleet)
instance Core.AWSRequest AddInstanceFleet where
type
AWSResponse AddInstanceFleet =
AddInstanceFleetResponse
request :: (Service -> Service)
-> AddInstanceFleet -> Request AddInstanceFleet
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 AddInstanceFleet
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse AddInstanceFleet)))
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 Text
-> Maybe Text -> Maybe Text -> Int -> AddInstanceFleetResponse
AddInstanceFleetResponse'
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
"ClusterArn")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"ClusterId")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"InstanceFleetId")
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 AddInstanceFleet where
hashWithSalt :: Int -> AddInstanceFleet -> Int
hashWithSalt Int
_salt AddInstanceFleet' {Text
InstanceFleetConfig
instanceFleet :: InstanceFleetConfig
clusterId :: Text
$sel:instanceFleet:AddInstanceFleet' :: AddInstanceFleet -> InstanceFleetConfig
$sel:clusterId:AddInstanceFleet' :: AddInstanceFleet -> Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
clusterId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` InstanceFleetConfig
instanceFleet
instance Prelude.NFData AddInstanceFleet where
rnf :: AddInstanceFleet -> ()
rnf AddInstanceFleet' {Text
InstanceFleetConfig
instanceFleet :: InstanceFleetConfig
clusterId :: Text
$sel:instanceFleet:AddInstanceFleet' :: AddInstanceFleet -> InstanceFleetConfig
$sel:clusterId:AddInstanceFleet' :: AddInstanceFleet -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
clusterId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf InstanceFleetConfig
instanceFleet
instance Data.ToHeaders AddInstanceFleet where
toHeaders :: AddInstanceFleet -> ResponseHeaders
toHeaders =
forall a b. a -> b -> a
Prelude.const
( forall a. Monoid a => [a] -> a
Prelude.mconcat
[ HeaderName
"X-Amz-Target"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"ElasticMapReduce.AddInstanceFleet" ::
Prelude.ByteString
),
HeaderName
"Content-Type"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
Prelude.ByteString
)
]
)
instance Data.ToJSON AddInstanceFleet where
toJSON :: AddInstanceFleet -> Value
toJSON AddInstanceFleet' {Text
InstanceFleetConfig
instanceFleet :: InstanceFleetConfig
clusterId :: Text
$sel:instanceFleet:AddInstanceFleet' :: AddInstanceFleet -> InstanceFleetConfig
$sel:clusterId:AddInstanceFleet' :: AddInstanceFleet -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ forall a. a -> Maybe a
Prelude.Just (Key
"ClusterId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
clusterId),
forall a. a -> Maybe a
Prelude.Just
(Key
"InstanceFleet" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= InstanceFleetConfig
instanceFleet)
]
)
instance Data.ToPath AddInstanceFleet where
toPath :: AddInstanceFleet -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery AddInstanceFleet where
toQuery :: AddInstanceFleet -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data AddInstanceFleetResponse = AddInstanceFleetResponse'
{
AddInstanceFleetResponse -> Maybe Text
clusterArn :: Prelude.Maybe Prelude.Text,
AddInstanceFleetResponse -> Maybe Text
clusterId :: Prelude.Maybe Prelude.Text,
AddInstanceFleetResponse -> Maybe Text
instanceFleetId :: Prelude.Maybe Prelude.Text,
AddInstanceFleetResponse -> Int
httpStatus :: Prelude.Int
}
deriving (AddInstanceFleetResponse -> AddInstanceFleetResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: AddInstanceFleetResponse -> AddInstanceFleetResponse -> Bool
$c/= :: AddInstanceFleetResponse -> AddInstanceFleetResponse -> Bool
== :: AddInstanceFleetResponse -> AddInstanceFleetResponse -> Bool
$c== :: AddInstanceFleetResponse -> AddInstanceFleetResponse -> Bool
Prelude.Eq, ReadPrec [AddInstanceFleetResponse]
ReadPrec AddInstanceFleetResponse
Int -> ReadS AddInstanceFleetResponse
ReadS [AddInstanceFleetResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [AddInstanceFleetResponse]
$creadListPrec :: ReadPrec [AddInstanceFleetResponse]
readPrec :: ReadPrec AddInstanceFleetResponse
$creadPrec :: ReadPrec AddInstanceFleetResponse
readList :: ReadS [AddInstanceFleetResponse]
$creadList :: ReadS [AddInstanceFleetResponse]
readsPrec :: Int -> ReadS AddInstanceFleetResponse
$creadsPrec :: Int -> ReadS AddInstanceFleetResponse
Prelude.Read, Int -> AddInstanceFleetResponse -> ShowS
[AddInstanceFleetResponse] -> ShowS
AddInstanceFleetResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [AddInstanceFleetResponse] -> ShowS
$cshowList :: [AddInstanceFleetResponse] -> ShowS
show :: AddInstanceFleetResponse -> String
$cshow :: AddInstanceFleetResponse -> String
showsPrec :: Int -> AddInstanceFleetResponse -> ShowS
$cshowsPrec :: Int -> AddInstanceFleetResponse -> ShowS
Prelude.Show, forall x.
Rep AddInstanceFleetResponse x -> AddInstanceFleetResponse
forall x.
AddInstanceFleetResponse -> Rep AddInstanceFleetResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep AddInstanceFleetResponse x -> AddInstanceFleetResponse
$cfrom :: forall x.
AddInstanceFleetResponse -> Rep AddInstanceFleetResponse x
Prelude.Generic)
newAddInstanceFleetResponse ::
Prelude.Int ->
AddInstanceFleetResponse
newAddInstanceFleetResponse :: Int -> AddInstanceFleetResponse
newAddInstanceFleetResponse Int
pHttpStatus_ =
AddInstanceFleetResponse'
{ $sel:clusterArn:AddInstanceFleetResponse' :: Maybe Text
clusterArn =
forall a. Maybe a
Prelude.Nothing,
$sel:clusterId:AddInstanceFleetResponse' :: Maybe Text
clusterId = forall a. Maybe a
Prelude.Nothing,
$sel:instanceFleetId:AddInstanceFleetResponse' :: Maybe Text
instanceFleetId = forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:AddInstanceFleetResponse' :: Int
httpStatus = Int
pHttpStatus_
}
addInstanceFleetResponse_clusterArn :: Lens.Lens' AddInstanceFleetResponse (Prelude.Maybe Prelude.Text)
addInstanceFleetResponse_clusterArn :: Lens' AddInstanceFleetResponse (Maybe Text)
addInstanceFleetResponse_clusterArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AddInstanceFleetResponse' {Maybe Text
clusterArn :: Maybe Text
$sel:clusterArn:AddInstanceFleetResponse' :: AddInstanceFleetResponse -> Maybe Text
clusterArn} -> Maybe Text
clusterArn) (\s :: AddInstanceFleetResponse
s@AddInstanceFleetResponse' {} Maybe Text
a -> AddInstanceFleetResponse
s {$sel:clusterArn:AddInstanceFleetResponse' :: Maybe Text
clusterArn = Maybe Text
a} :: AddInstanceFleetResponse)
addInstanceFleetResponse_clusterId :: Lens.Lens' AddInstanceFleetResponse (Prelude.Maybe Prelude.Text)
addInstanceFleetResponse_clusterId :: Lens' AddInstanceFleetResponse (Maybe Text)
addInstanceFleetResponse_clusterId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AddInstanceFleetResponse' {Maybe Text
clusterId :: Maybe Text
$sel:clusterId:AddInstanceFleetResponse' :: AddInstanceFleetResponse -> Maybe Text
clusterId} -> Maybe Text
clusterId) (\s :: AddInstanceFleetResponse
s@AddInstanceFleetResponse' {} Maybe Text
a -> AddInstanceFleetResponse
s {$sel:clusterId:AddInstanceFleetResponse' :: Maybe Text
clusterId = Maybe Text
a} :: AddInstanceFleetResponse)
addInstanceFleetResponse_instanceFleetId :: Lens.Lens' AddInstanceFleetResponse (Prelude.Maybe Prelude.Text)
addInstanceFleetResponse_instanceFleetId :: Lens' AddInstanceFleetResponse (Maybe Text)
addInstanceFleetResponse_instanceFleetId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AddInstanceFleetResponse' {Maybe Text
instanceFleetId :: Maybe Text
$sel:instanceFleetId:AddInstanceFleetResponse' :: AddInstanceFleetResponse -> Maybe Text
instanceFleetId} -> Maybe Text
instanceFleetId) (\s :: AddInstanceFleetResponse
s@AddInstanceFleetResponse' {} Maybe Text
a -> AddInstanceFleetResponse
s {$sel:instanceFleetId:AddInstanceFleetResponse' :: Maybe Text
instanceFleetId = Maybe Text
a} :: AddInstanceFleetResponse)
addInstanceFleetResponse_httpStatus :: Lens.Lens' AddInstanceFleetResponse Prelude.Int
addInstanceFleetResponse_httpStatus :: Lens' AddInstanceFleetResponse Int
addInstanceFleetResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AddInstanceFleetResponse' {Int
httpStatus :: Int
$sel:httpStatus:AddInstanceFleetResponse' :: AddInstanceFleetResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: AddInstanceFleetResponse
s@AddInstanceFleetResponse' {} Int
a -> AddInstanceFleetResponse
s {$sel:httpStatus:AddInstanceFleetResponse' :: Int
httpStatus = Int
a} :: AddInstanceFleetResponse)
instance Prelude.NFData AddInstanceFleetResponse where
rnf :: AddInstanceFleetResponse -> ()
rnf AddInstanceFleetResponse' {Int
Maybe Text
httpStatus :: Int
instanceFleetId :: Maybe Text
clusterId :: Maybe Text
clusterArn :: Maybe Text
$sel:httpStatus:AddInstanceFleetResponse' :: AddInstanceFleetResponse -> Int
$sel:instanceFleetId:AddInstanceFleetResponse' :: AddInstanceFleetResponse -> Maybe Text
$sel:clusterId:AddInstanceFleetResponse' :: AddInstanceFleetResponse -> Maybe Text
$sel:clusterArn:AddInstanceFleetResponse' :: AddInstanceFleetResponse -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
clusterArn
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
clusterId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
instanceFleetId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus