{-# 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.EFS.CreateMountTarget
(
CreateMountTarget (..),
newCreateMountTarget,
createMountTarget_ipAddress,
createMountTarget_securityGroups,
createMountTarget_fileSystemId,
createMountTarget_subnetId,
MountTargetDescription (..),
newMountTargetDescription,
mountTargetDescription_availabilityZoneId,
mountTargetDescription_availabilityZoneName,
mountTargetDescription_ipAddress,
mountTargetDescription_networkInterfaceId,
mountTargetDescription_ownerId,
mountTargetDescription_vpcId,
mountTargetDescription_mountTargetId,
mountTargetDescription_fileSystemId,
mountTargetDescription_subnetId,
mountTargetDescription_lifeCycleState,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.EFS.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data CreateMountTarget = CreateMountTarget'
{
CreateMountTarget -> Maybe Text
ipAddress :: Prelude.Maybe Prelude.Text,
CreateMountTarget -> Maybe [Text]
securityGroups :: Prelude.Maybe [Prelude.Text],
CreateMountTarget -> Text
fileSystemId :: Prelude.Text,
CreateMountTarget -> Text
subnetId :: Prelude.Text
}
deriving (CreateMountTarget -> CreateMountTarget -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateMountTarget -> CreateMountTarget -> Bool
$c/= :: CreateMountTarget -> CreateMountTarget -> Bool
== :: CreateMountTarget -> CreateMountTarget -> Bool
$c== :: CreateMountTarget -> CreateMountTarget -> Bool
Prelude.Eq, ReadPrec [CreateMountTarget]
ReadPrec CreateMountTarget
Int -> ReadS CreateMountTarget
ReadS [CreateMountTarget]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateMountTarget]
$creadListPrec :: ReadPrec [CreateMountTarget]
readPrec :: ReadPrec CreateMountTarget
$creadPrec :: ReadPrec CreateMountTarget
readList :: ReadS [CreateMountTarget]
$creadList :: ReadS [CreateMountTarget]
readsPrec :: Int -> ReadS CreateMountTarget
$creadsPrec :: Int -> ReadS CreateMountTarget
Prelude.Read, Int -> CreateMountTarget -> ShowS
[CreateMountTarget] -> ShowS
CreateMountTarget -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateMountTarget] -> ShowS
$cshowList :: [CreateMountTarget] -> ShowS
show :: CreateMountTarget -> String
$cshow :: CreateMountTarget -> String
showsPrec :: Int -> CreateMountTarget -> ShowS
$cshowsPrec :: Int -> CreateMountTarget -> ShowS
Prelude.Show, forall x. Rep CreateMountTarget x -> CreateMountTarget
forall x. CreateMountTarget -> Rep CreateMountTarget x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep CreateMountTarget x -> CreateMountTarget
$cfrom :: forall x. CreateMountTarget -> Rep CreateMountTarget x
Prelude.Generic)
newCreateMountTarget ::
Prelude.Text ->
Prelude.Text ->
CreateMountTarget
newCreateMountTarget :: Text -> Text -> CreateMountTarget
newCreateMountTarget Text
pFileSystemId_ Text
pSubnetId_ =
CreateMountTarget'
{ $sel:ipAddress:CreateMountTarget' :: Maybe Text
ipAddress = forall a. Maybe a
Prelude.Nothing,
$sel:securityGroups:CreateMountTarget' :: Maybe [Text]
securityGroups = forall a. Maybe a
Prelude.Nothing,
$sel:fileSystemId:CreateMountTarget' :: Text
fileSystemId = Text
pFileSystemId_,
$sel:subnetId:CreateMountTarget' :: Text
subnetId = Text
pSubnetId_
}
createMountTarget_ipAddress :: Lens.Lens' CreateMountTarget (Prelude.Maybe Prelude.Text)
createMountTarget_ipAddress :: Lens' CreateMountTarget (Maybe Text)
createMountTarget_ipAddress = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateMountTarget' {Maybe Text
ipAddress :: Maybe Text
$sel:ipAddress:CreateMountTarget' :: CreateMountTarget -> Maybe Text
ipAddress} -> Maybe Text
ipAddress) (\s :: CreateMountTarget
s@CreateMountTarget' {} Maybe Text
a -> CreateMountTarget
s {$sel:ipAddress:CreateMountTarget' :: Maybe Text
ipAddress = Maybe Text
a} :: CreateMountTarget)
createMountTarget_securityGroups :: Lens.Lens' CreateMountTarget (Prelude.Maybe [Prelude.Text])
createMountTarget_securityGroups :: Lens' CreateMountTarget (Maybe [Text])
createMountTarget_securityGroups = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateMountTarget' {Maybe [Text]
securityGroups :: Maybe [Text]
$sel:securityGroups:CreateMountTarget' :: CreateMountTarget -> Maybe [Text]
securityGroups} -> Maybe [Text]
securityGroups) (\s :: CreateMountTarget
s@CreateMountTarget' {} Maybe [Text]
a -> CreateMountTarget
s {$sel:securityGroups:CreateMountTarget' :: Maybe [Text]
securityGroups = Maybe [Text]
a} :: CreateMountTarget) 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
createMountTarget_fileSystemId :: Lens.Lens' CreateMountTarget Prelude.Text
createMountTarget_fileSystemId :: Lens' CreateMountTarget Text
createMountTarget_fileSystemId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateMountTarget' {Text
fileSystemId :: Text
$sel:fileSystemId:CreateMountTarget' :: CreateMountTarget -> Text
fileSystemId} -> Text
fileSystemId) (\s :: CreateMountTarget
s@CreateMountTarget' {} Text
a -> CreateMountTarget
s {$sel:fileSystemId:CreateMountTarget' :: Text
fileSystemId = Text
a} :: CreateMountTarget)
createMountTarget_subnetId :: Lens.Lens' CreateMountTarget Prelude.Text
createMountTarget_subnetId :: Lens' CreateMountTarget Text
createMountTarget_subnetId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateMountTarget' {Text
subnetId :: Text
$sel:subnetId:CreateMountTarget' :: CreateMountTarget -> Text
subnetId} -> Text
subnetId) (\s :: CreateMountTarget
s@CreateMountTarget' {} Text
a -> CreateMountTarget
s {$sel:subnetId:CreateMountTarget' :: Text
subnetId = Text
a} :: CreateMountTarget)
instance Core.AWSRequest CreateMountTarget where
type
AWSResponse CreateMountTarget =
MountTargetDescription
request :: (Service -> Service)
-> CreateMountTarget -> Request CreateMountTarget
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 CreateMountTarget
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse CreateMountTarget)))
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 -> forall a. FromJSON a => Object -> Either String a
Data.eitherParseJSON Object
x)
instance Prelude.Hashable CreateMountTarget where
hashWithSalt :: Int -> CreateMountTarget -> Int
hashWithSalt Int
_salt CreateMountTarget' {Maybe [Text]
Maybe Text
Text
subnetId :: Text
fileSystemId :: Text
securityGroups :: Maybe [Text]
ipAddress :: Maybe Text
$sel:subnetId:CreateMountTarget' :: CreateMountTarget -> Text
$sel:fileSystemId:CreateMountTarget' :: CreateMountTarget -> Text
$sel:securityGroups:CreateMountTarget' :: CreateMountTarget -> Maybe [Text]
$sel:ipAddress:CreateMountTarget' :: CreateMountTarget -> Maybe Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
ipAddress
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [Text]
securityGroups
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
fileSystemId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
subnetId
instance Prelude.NFData CreateMountTarget where
rnf :: CreateMountTarget -> ()
rnf CreateMountTarget' {Maybe [Text]
Maybe Text
Text
subnetId :: Text
fileSystemId :: Text
securityGroups :: Maybe [Text]
ipAddress :: Maybe Text
$sel:subnetId:CreateMountTarget' :: CreateMountTarget -> Text
$sel:fileSystemId:CreateMountTarget' :: CreateMountTarget -> Text
$sel:securityGroups:CreateMountTarget' :: CreateMountTarget -> Maybe [Text]
$sel:ipAddress:CreateMountTarget' :: CreateMountTarget -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
ipAddress
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [Text]
securityGroups
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
fileSystemId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
subnetId
instance Data.ToHeaders CreateMountTarget where
toHeaders :: CreateMountTarget -> ResponseHeaders
toHeaders = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
instance Data.ToJSON CreateMountTarget where
toJSON :: CreateMountTarget -> Value
toJSON CreateMountTarget' {Maybe [Text]
Maybe Text
Text
subnetId :: Text
fileSystemId :: Text
securityGroups :: Maybe [Text]
ipAddress :: Maybe Text
$sel:subnetId:CreateMountTarget' :: CreateMountTarget -> Text
$sel:fileSystemId:CreateMountTarget' :: CreateMountTarget -> Text
$sel:securityGroups:CreateMountTarget' :: CreateMountTarget -> Maybe [Text]
$sel:ipAddress:CreateMountTarget' :: CreateMountTarget -> Maybe Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Key
"IpAddress" 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 Text
ipAddress,
(Key
"SecurityGroups" 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 [Text]
securityGroups,
forall a. a -> Maybe a
Prelude.Just (Key
"FileSystemId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
fileSystemId),
forall a. a -> Maybe a
Prelude.Just (Key
"SubnetId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
subnetId)
]
)
instance Data.ToPath CreateMountTarget where
toPath :: CreateMountTarget -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/2015-02-01/mount-targets"
instance Data.ToQuery CreateMountTarget where
toQuery :: CreateMountTarget -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty