{-# 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.EMRContainers.CreateVirtualCluster
(
CreateVirtualCluster (..),
newCreateVirtualCluster,
createVirtualCluster_tags,
createVirtualCluster_name,
createVirtualCluster_containerProvider,
createVirtualCluster_clientToken,
CreateVirtualClusterResponse (..),
newCreateVirtualClusterResponse,
createVirtualClusterResponse_arn,
createVirtualClusterResponse_id,
createVirtualClusterResponse_name,
createVirtualClusterResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.EMRContainers.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data CreateVirtualCluster = CreateVirtualCluster'
{
CreateVirtualCluster -> Maybe (HashMap Text Text)
tags :: Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text),
CreateVirtualCluster -> Text
name :: Prelude.Text,
CreateVirtualCluster -> ContainerProvider
containerProvider :: ContainerProvider,
CreateVirtualCluster -> Text
clientToken :: Prelude.Text
}
deriving (CreateVirtualCluster -> CreateVirtualCluster -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateVirtualCluster -> CreateVirtualCluster -> Bool
$c/= :: CreateVirtualCluster -> CreateVirtualCluster -> Bool
== :: CreateVirtualCluster -> CreateVirtualCluster -> Bool
$c== :: CreateVirtualCluster -> CreateVirtualCluster -> Bool
Prelude.Eq, ReadPrec [CreateVirtualCluster]
ReadPrec CreateVirtualCluster
Int -> ReadS CreateVirtualCluster
ReadS [CreateVirtualCluster]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateVirtualCluster]
$creadListPrec :: ReadPrec [CreateVirtualCluster]
readPrec :: ReadPrec CreateVirtualCluster
$creadPrec :: ReadPrec CreateVirtualCluster
readList :: ReadS [CreateVirtualCluster]
$creadList :: ReadS [CreateVirtualCluster]
readsPrec :: Int -> ReadS CreateVirtualCluster
$creadsPrec :: Int -> ReadS CreateVirtualCluster
Prelude.Read, Int -> CreateVirtualCluster -> ShowS
[CreateVirtualCluster] -> ShowS
CreateVirtualCluster -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateVirtualCluster] -> ShowS
$cshowList :: [CreateVirtualCluster] -> ShowS
show :: CreateVirtualCluster -> String
$cshow :: CreateVirtualCluster -> String
showsPrec :: Int -> CreateVirtualCluster -> ShowS
$cshowsPrec :: Int -> CreateVirtualCluster -> ShowS
Prelude.Show, forall x. Rep CreateVirtualCluster x -> CreateVirtualCluster
forall x. CreateVirtualCluster -> Rep CreateVirtualCluster x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep CreateVirtualCluster x -> CreateVirtualCluster
$cfrom :: forall x. CreateVirtualCluster -> Rep CreateVirtualCluster x
Prelude.Generic)
newCreateVirtualCluster ::
Prelude.Text ->
ContainerProvider ->
Prelude.Text ->
CreateVirtualCluster
newCreateVirtualCluster :: Text -> ContainerProvider -> Text -> CreateVirtualCluster
newCreateVirtualCluster
Text
pName_
ContainerProvider
pContainerProvider_
Text
pClientToken_ =
CreateVirtualCluster'
{ $sel:tags:CreateVirtualCluster' :: Maybe (HashMap Text Text)
tags = forall a. Maybe a
Prelude.Nothing,
$sel:name:CreateVirtualCluster' :: Text
name = Text
pName_,
$sel:containerProvider:CreateVirtualCluster' :: ContainerProvider
containerProvider = ContainerProvider
pContainerProvider_,
$sel:clientToken:CreateVirtualCluster' :: Text
clientToken = Text
pClientToken_
}
createVirtualCluster_tags :: Lens.Lens' CreateVirtualCluster (Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text))
createVirtualCluster_tags :: Lens' CreateVirtualCluster (Maybe (HashMap Text Text))
createVirtualCluster_tags = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVirtualCluster' {Maybe (HashMap Text Text)
tags :: Maybe (HashMap Text Text)
$sel:tags:CreateVirtualCluster' :: CreateVirtualCluster -> Maybe (HashMap Text Text)
tags} -> Maybe (HashMap Text Text)
tags) (\s :: CreateVirtualCluster
s@CreateVirtualCluster' {} Maybe (HashMap Text Text)
a -> CreateVirtualCluster
s {$sel:tags:CreateVirtualCluster' :: Maybe (HashMap Text Text)
tags = Maybe (HashMap Text Text)
a} :: CreateVirtualCluster) 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
createVirtualCluster_name :: Lens.Lens' CreateVirtualCluster Prelude.Text
createVirtualCluster_name :: Lens' CreateVirtualCluster Text
createVirtualCluster_name = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVirtualCluster' {Text
name :: Text
$sel:name:CreateVirtualCluster' :: CreateVirtualCluster -> Text
name} -> Text
name) (\s :: CreateVirtualCluster
s@CreateVirtualCluster' {} Text
a -> CreateVirtualCluster
s {$sel:name:CreateVirtualCluster' :: Text
name = Text
a} :: CreateVirtualCluster)
createVirtualCluster_containerProvider :: Lens.Lens' CreateVirtualCluster ContainerProvider
createVirtualCluster_containerProvider :: Lens' CreateVirtualCluster ContainerProvider
createVirtualCluster_containerProvider = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVirtualCluster' {ContainerProvider
containerProvider :: ContainerProvider
$sel:containerProvider:CreateVirtualCluster' :: CreateVirtualCluster -> ContainerProvider
containerProvider} -> ContainerProvider
containerProvider) (\s :: CreateVirtualCluster
s@CreateVirtualCluster' {} ContainerProvider
a -> CreateVirtualCluster
s {$sel:containerProvider:CreateVirtualCluster' :: ContainerProvider
containerProvider = ContainerProvider
a} :: CreateVirtualCluster)
createVirtualCluster_clientToken :: Lens.Lens' CreateVirtualCluster Prelude.Text
createVirtualCluster_clientToken :: Lens' CreateVirtualCluster Text
createVirtualCluster_clientToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVirtualCluster' {Text
clientToken :: Text
$sel:clientToken:CreateVirtualCluster' :: CreateVirtualCluster -> Text
clientToken} -> Text
clientToken) (\s :: CreateVirtualCluster
s@CreateVirtualCluster' {} Text
a -> CreateVirtualCluster
s {$sel:clientToken:CreateVirtualCluster' :: Text
clientToken = Text
a} :: CreateVirtualCluster)
instance Core.AWSRequest CreateVirtualCluster where
type
AWSResponse CreateVirtualCluster =
CreateVirtualClusterResponse
request :: (Service -> Service)
-> CreateVirtualCluster -> Request CreateVirtualCluster
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 CreateVirtualCluster
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse CreateVirtualCluster)))
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 -> CreateVirtualClusterResponse
CreateVirtualClusterResponse'
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
"arn")
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
"id")
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
"name")
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 CreateVirtualCluster where
hashWithSalt :: Int -> CreateVirtualCluster -> Int
hashWithSalt Int
_salt CreateVirtualCluster' {Maybe (HashMap Text Text)
Text
ContainerProvider
clientToken :: Text
containerProvider :: ContainerProvider
name :: Text
tags :: Maybe (HashMap Text Text)
$sel:clientToken:CreateVirtualCluster' :: CreateVirtualCluster -> Text
$sel:containerProvider:CreateVirtualCluster' :: CreateVirtualCluster -> ContainerProvider
$sel:name:CreateVirtualCluster' :: CreateVirtualCluster -> Text
$sel:tags:CreateVirtualCluster' :: CreateVirtualCluster -> Maybe (HashMap Text Text)
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe (HashMap Text Text)
tags
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
name
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` ContainerProvider
containerProvider
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
clientToken
instance Prelude.NFData CreateVirtualCluster where
rnf :: CreateVirtualCluster -> ()
rnf CreateVirtualCluster' {Maybe (HashMap Text Text)
Text
ContainerProvider
clientToken :: Text
containerProvider :: ContainerProvider
name :: Text
tags :: Maybe (HashMap Text Text)
$sel:clientToken:CreateVirtualCluster' :: CreateVirtualCluster -> Text
$sel:containerProvider:CreateVirtualCluster' :: CreateVirtualCluster -> ContainerProvider
$sel:name:CreateVirtualCluster' :: CreateVirtualCluster -> Text
$sel:tags:CreateVirtualCluster' :: CreateVirtualCluster -> Maybe (HashMap Text Text)
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe (HashMap Text Text)
tags
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
name
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf ContainerProvider
containerProvider
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
clientToken
instance Data.ToHeaders CreateVirtualCluster where
toHeaders :: CreateVirtualCluster -> 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 CreateVirtualCluster where
toJSON :: CreateVirtualCluster -> Value
toJSON CreateVirtualCluster' {Maybe (HashMap Text Text)
Text
ContainerProvider
clientToken :: Text
containerProvider :: ContainerProvider
name :: Text
tags :: Maybe (HashMap Text Text)
$sel:clientToken:CreateVirtualCluster' :: CreateVirtualCluster -> Text
$sel:containerProvider:CreateVirtualCluster' :: CreateVirtualCluster -> ContainerProvider
$sel:name:CreateVirtualCluster' :: CreateVirtualCluster -> Text
$sel:tags:CreateVirtualCluster' :: CreateVirtualCluster -> Maybe (HashMap Text Text)
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Key
"tags" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe (HashMap Text Text)
tags,
forall a. a -> Maybe a
Prelude.Just (Key
"name" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
name),
forall a. a -> Maybe a
Prelude.Just
(Key
"containerProvider" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= ContainerProvider
containerProvider),
forall a. a -> Maybe a
Prelude.Just (Key
"clientToken" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
clientToken)
]
)
instance Data.ToPath CreateVirtualCluster where
toPath :: CreateVirtualCluster -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/virtualclusters"
instance Data.ToQuery CreateVirtualCluster where
toQuery :: CreateVirtualCluster -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data CreateVirtualClusterResponse = CreateVirtualClusterResponse'
{
CreateVirtualClusterResponse -> Maybe Text
arn :: Prelude.Maybe Prelude.Text,
CreateVirtualClusterResponse -> Maybe Text
id :: Prelude.Maybe Prelude.Text,
CreateVirtualClusterResponse -> Maybe Text
name :: Prelude.Maybe Prelude.Text,
CreateVirtualClusterResponse -> Int
httpStatus :: Prelude.Int
}
deriving (CreateVirtualClusterResponse
-> CreateVirtualClusterResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateVirtualClusterResponse
-> CreateVirtualClusterResponse -> Bool
$c/= :: CreateVirtualClusterResponse
-> CreateVirtualClusterResponse -> Bool
== :: CreateVirtualClusterResponse
-> CreateVirtualClusterResponse -> Bool
$c== :: CreateVirtualClusterResponse
-> CreateVirtualClusterResponse -> Bool
Prelude.Eq, ReadPrec [CreateVirtualClusterResponse]
ReadPrec CreateVirtualClusterResponse
Int -> ReadS CreateVirtualClusterResponse
ReadS [CreateVirtualClusterResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateVirtualClusterResponse]
$creadListPrec :: ReadPrec [CreateVirtualClusterResponse]
readPrec :: ReadPrec CreateVirtualClusterResponse
$creadPrec :: ReadPrec CreateVirtualClusterResponse
readList :: ReadS [CreateVirtualClusterResponse]
$creadList :: ReadS [CreateVirtualClusterResponse]
readsPrec :: Int -> ReadS CreateVirtualClusterResponse
$creadsPrec :: Int -> ReadS CreateVirtualClusterResponse
Prelude.Read, Int -> CreateVirtualClusterResponse -> ShowS
[CreateVirtualClusterResponse] -> ShowS
CreateVirtualClusterResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateVirtualClusterResponse] -> ShowS
$cshowList :: [CreateVirtualClusterResponse] -> ShowS
show :: CreateVirtualClusterResponse -> String
$cshow :: CreateVirtualClusterResponse -> String
showsPrec :: Int -> CreateVirtualClusterResponse -> ShowS
$cshowsPrec :: Int -> CreateVirtualClusterResponse -> ShowS
Prelude.Show, forall x.
Rep CreateVirtualClusterResponse x -> CreateVirtualClusterResponse
forall x.
CreateVirtualClusterResponse -> Rep CreateVirtualClusterResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep CreateVirtualClusterResponse x -> CreateVirtualClusterResponse
$cfrom :: forall x.
CreateVirtualClusterResponse -> Rep CreateVirtualClusterResponse x
Prelude.Generic)
newCreateVirtualClusterResponse ::
Prelude.Int ->
CreateVirtualClusterResponse
newCreateVirtualClusterResponse :: Int -> CreateVirtualClusterResponse
newCreateVirtualClusterResponse Int
pHttpStatus_ =
CreateVirtualClusterResponse'
{ $sel:arn:CreateVirtualClusterResponse' :: Maybe Text
arn =
forall a. Maybe a
Prelude.Nothing,
$sel:id:CreateVirtualClusterResponse' :: Maybe Text
id = forall a. Maybe a
Prelude.Nothing,
$sel:name:CreateVirtualClusterResponse' :: Maybe Text
name = forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:CreateVirtualClusterResponse' :: Int
httpStatus = Int
pHttpStatus_
}
createVirtualClusterResponse_arn :: Lens.Lens' CreateVirtualClusterResponse (Prelude.Maybe Prelude.Text)
createVirtualClusterResponse_arn :: Lens' CreateVirtualClusterResponse (Maybe Text)
createVirtualClusterResponse_arn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVirtualClusterResponse' {Maybe Text
arn :: Maybe Text
$sel:arn:CreateVirtualClusterResponse' :: CreateVirtualClusterResponse -> Maybe Text
arn} -> Maybe Text
arn) (\s :: CreateVirtualClusterResponse
s@CreateVirtualClusterResponse' {} Maybe Text
a -> CreateVirtualClusterResponse
s {$sel:arn:CreateVirtualClusterResponse' :: Maybe Text
arn = Maybe Text
a} :: CreateVirtualClusterResponse)
createVirtualClusterResponse_id :: Lens.Lens' CreateVirtualClusterResponse (Prelude.Maybe Prelude.Text)
createVirtualClusterResponse_id :: Lens' CreateVirtualClusterResponse (Maybe Text)
createVirtualClusterResponse_id = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVirtualClusterResponse' {Maybe Text
id :: Maybe Text
$sel:id:CreateVirtualClusterResponse' :: CreateVirtualClusterResponse -> Maybe Text
id} -> Maybe Text
id) (\s :: CreateVirtualClusterResponse
s@CreateVirtualClusterResponse' {} Maybe Text
a -> CreateVirtualClusterResponse
s {$sel:id:CreateVirtualClusterResponse' :: Maybe Text
id = Maybe Text
a} :: CreateVirtualClusterResponse)
createVirtualClusterResponse_name :: Lens.Lens' CreateVirtualClusterResponse (Prelude.Maybe Prelude.Text)
createVirtualClusterResponse_name :: Lens' CreateVirtualClusterResponse (Maybe Text)
createVirtualClusterResponse_name = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVirtualClusterResponse' {Maybe Text
name :: Maybe Text
$sel:name:CreateVirtualClusterResponse' :: CreateVirtualClusterResponse -> Maybe Text
name} -> Maybe Text
name) (\s :: CreateVirtualClusterResponse
s@CreateVirtualClusterResponse' {} Maybe Text
a -> CreateVirtualClusterResponse
s {$sel:name:CreateVirtualClusterResponse' :: Maybe Text
name = Maybe Text
a} :: CreateVirtualClusterResponse)
createVirtualClusterResponse_httpStatus :: Lens.Lens' CreateVirtualClusterResponse Prelude.Int
createVirtualClusterResponse_httpStatus :: Lens' CreateVirtualClusterResponse Int
createVirtualClusterResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVirtualClusterResponse' {Int
httpStatus :: Int
$sel:httpStatus:CreateVirtualClusterResponse' :: CreateVirtualClusterResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: CreateVirtualClusterResponse
s@CreateVirtualClusterResponse' {} Int
a -> CreateVirtualClusterResponse
s {$sel:httpStatus:CreateVirtualClusterResponse' :: Int
httpStatus = Int
a} :: CreateVirtualClusterResponse)
instance Prelude.NFData CreateVirtualClusterResponse where
rnf :: CreateVirtualClusterResponse -> ()
rnf CreateVirtualClusterResponse' {Int
Maybe Text
httpStatus :: Int
name :: Maybe Text
id :: Maybe Text
arn :: Maybe Text
$sel:httpStatus:CreateVirtualClusterResponse' :: CreateVirtualClusterResponse -> Int
$sel:name:CreateVirtualClusterResponse' :: CreateVirtualClusterResponse -> Maybe Text
$sel:id:CreateVirtualClusterResponse' :: CreateVirtualClusterResponse -> Maybe Text
$sel:arn:CreateVirtualClusterResponse' :: CreateVirtualClusterResponse -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
arn
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
id
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
name
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus