{-# 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.UpdateFileSystem
(
UpdateFileSystem (..),
newUpdateFileSystem,
updateFileSystem_provisionedThroughputInMibps,
updateFileSystem_throughputMode,
updateFileSystem_fileSystemId,
FileSystemDescription (..),
newFileSystemDescription,
fileSystemDescription_availabilityZoneId,
fileSystemDescription_provisionedThroughputInMibps,
fileSystemDescription_availabilityZoneName,
fileSystemDescription_fileSystemArn,
fileSystemDescription_encrypted,
fileSystemDescription_throughputMode,
fileSystemDescription_kmsKeyId,
fileSystemDescription_name,
fileSystemDescription_ownerId,
fileSystemDescription_creationToken,
fileSystemDescription_fileSystemId,
fileSystemDescription_creationTime,
fileSystemDescription_lifeCycleState,
fileSystemDescription_numberOfMountTargets,
fileSystemDescription_sizeInBytes,
fileSystemDescription_performanceMode,
fileSystemDescription_tags,
)
where
import qualified Amazonka.Core as Core
import Amazonka.EFS.Types
import qualified Amazonka.Lens as Lens
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data UpdateFileSystem = UpdateFileSystem'
{
UpdateFileSystem -> Maybe Double
provisionedThroughputInMibps :: Prelude.Maybe Prelude.Double,
UpdateFileSystem -> Maybe ThroughputMode
throughputMode :: Prelude.Maybe ThroughputMode,
UpdateFileSystem -> Text
fileSystemId :: Prelude.Text
}
deriving (UpdateFileSystem -> UpdateFileSystem -> Bool
(UpdateFileSystem -> UpdateFileSystem -> Bool)
-> (UpdateFileSystem -> UpdateFileSystem -> Bool)
-> Eq UpdateFileSystem
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UpdateFileSystem -> UpdateFileSystem -> Bool
$c/= :: UpdateFileSystem -> UpdateFileSystem -> Bool
== :: UpdateFileSystem -> UpdateFileSystem -> Bool
$c== :: UpdateFileSystem -> UpdateFileSystem -> Bool
Prelude.Eq, ReadPrec [UpdateFileSystem]
ReadPrec UpdateFileSystem
Int -> ReadS UpdateFileSystem
ReadS [UpdateFileSystem]
(Int -> ReadS UpdateFileSystem)
-> ReadS [UpdateFileSystem]
-> ReadPrec UpdateFileSystem
-> ReadPrec [UpdateFileSystem]
-> Read UpdateFileSystem
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [UpdateFileSystem]
$creadListPrec :: ReadPrec [UpdateFileSystem]
readPrec :: ReadPrec UpdateFileSystem
$creadPrec :: ReadPrec UpdateFileSystem
readList :: ReadS [UpdateFileSystem]
$creadList :: ReadS [UpdateFileSystem]
readsPrec :: Int -> ReadS UpdateFileSystem
$creadsPrec :: Int -> ReadS UpdateFileSystem
Prelude.Read, Int -> UpdateFileSystem -> ShowS
[UpdateFileSystem] -> ShowS
UpdateFileSystem -> String
(Int -> UpdateFileSystem -> ShowS)
-> (UpdateFileSystem -> String)
-> ([UpdateFileSystem] -> ShowS)
-> Show UpdateFileSystem
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UpdateFileSystem] -> ShowS
$cshowList :: [UpdateFileSystem] -> ShowS
show :: UpdateFileSystem -> String
$cshow :: UpdateFileSystem -> String
showsPrec :: Int -> UpdateFileSystem -> ShowS
$cshowsPrec :: Int -> UpdateFileSystem -> ShowS
Prelude.Show, (forall x. UpdateFileSystem -> Rep UpdateFileSystem x)
-> (forall x. Rep UpdateFileSystem x -> UpdateFileSystem)
-> Generic UpdateFileSystem
forall x. Rep UpdateFileSystem x -> UpdateFileSystem
forall x. UpdateFileSystem -> Rep UpdateFileSystem x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep UpdateFileSystem x -> UpdateFileSystem
$cfrom :: forall x. UpdateFileSystem -> Rep UpdateFileSystem x
Prelude.Generic)
newUpdateFileSystem ::
Prelude.Text ->
UpdateFileSystem
newUpdateFileSystem :: Text -> UpdateFileSystem
newUpdateFileSystem Text
pFileSystemId_ =
UpdateFileSystem' :: Maybe Double -> Maybe ThroughputMode -> Text -> UpdateFileSystem
UpdateFileSystem'
{ $sel:provisionedThroughputInMibps:UpdateFileSystem' :: Maybe Double
provisionedThroughputInMibps =
Maybe Double
forall a. Maybe a
Prelude.Nothing,
$sel:throughputMode:UpdateFileSystem' :: Maybe ThroughputMode
throughputMode = Maybe ThroughputMode
forall a. Maybe a
Prelude.Nothing,
$sel:fileSystemId:UpdateFileSystem' :: Text
fileSystemId = Text
pFileSystemId_
}
updateFileSystem_provisionedThroughputInMibps :: Lens.Lens' UpdateFileSystem (Prelude.Maybe Prelude.Double)
updateFileSystem_provisionedThroughputInMibps :: (Maybe Double -> f (Maybe Double))
-> UpdateFileSystem -> f UpdateFileSystem
updateFileSystem_provisionedThroughputInMibps = (UpdateFileSystem -> Maybe Double)
-> (UpdateFileSystem -> Maybe Double -> UpdateFileSystem)
-> Lens
UpdateFileSystem UpdateFileSystem (Maybe Double) (Maybe Double)
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateFileSystem' {Maybe Double
provisionedThroughputInMibps :: Maybe Double
$sel:provisionedThroughputInMibps:UpdateFileSystem' :: UpdateFileSystem -> Maybe Double
provisionedThroughputInMibps} -> Maybe Double
provisionedThroughputInMibps) (\s :: UpdateFileSystem
s@UpdateFileSystem' {} Maybe Double
a -> UpdateFileSystem
s {$sel:provisionedThroughputInMibps:UpdateFileSystem' :: Maybe Double
provisionedThroughputInMibps = Maybe Double
a} :: UpdateFileSystem)
updateFileSystem_throughputMode :: Lens.Lens' UpdateFileSystem (Prelude.Maybe ThroughputMode)
updateFileSystem_throughputMode :: (Maybe ThroughputMode -> f (Maybe ThroughputMode))
-> UpdateFileSystem -> f UpdateFileSystem
updateFileSystem_throughputMode = (UpdateFileSystem -> Maybe ThroughputMode)
-> (UpdateFileSystem -> Maybe ThroughputMode -> UpdateFileSystem)
-> Lens
UpdateFileSystem
UpdateFileSystem
(Maybe ThroughputMode)
(Maybe ThroughputMode)
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateFileSystem' {Maybe ThroughputMode
throughputMode :: Maybe ThroughputMode
$sel:throughputMode:UpdateFileSystem' :: UpdateFileSystem -> Maybe ThroughputMode
throughputMode} -> Maybe ThroughputMode
throughputMode) (\s :: UpdateFileSystem
s@UpdateFileSystem' {} Maybe ThroughputMode
a -> UpdateFileSystem
s {$sel:throughputMode:UpdateFileSystem' :: Maybe ThroughputMode
throughputMode = Maybe ThroughputMode
a} :: UpdateFileSystem)
updateFileSystem_fileSystemId :: Lens.Lens' UpdateFileSystem Prelude.Text
updateFileSystem_fileSystemId :: (Text -> f Text) -> UpdateFileSystem -> f UpdateFileSystem
updateFileSystem_fileSystemId = (UpdateFileSystem -> Text)
-> (UpdateFileSystem -> Text -> UpdateFileSystem)
-> Lens UpdateFileSystem UpdateFileSystem Text Text
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateFileSystem' {Text
fileSystemId :: Text
$sel:fileSystemId:UpdateFileSystem' :: UpdateFileSystem -> Text
fileSystemId} -> Text
fileSystemId) (\s :: UpdateFileSystem
s@UpdateFileSystem' {} Text
a -> UpdateFileSystem
s {$sel:fileSystemId:UpdateFileSystem' :: Text
fileSystemId = Text
a} :: UpdateFileSystem)
instance Core.AWSRequest UpdateFileSystem where
type
AWSResponse UpdateFileSystem =
FileSystemDescription
request :: UpdateFileSystem -> Request UpdateFileSystem
request = Service -> UpdateFileSystem -> Request UpdateFileSystem
forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.putJSON Service
defaultService
response :: Logger
-> Service
-> Proxy UpdateFileSystem
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse UpdateFileSystem)))
response =
(Int
-> ResponseHeaders
-> Object
-> Either String (AWSResponse UpdateFileSystem))
-> Logger
-> Service
-> Proxy UpdateFileSystem
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse UpdateFileSystem)))
forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> Object -> Either String (AWSResponse a))
-> Logger
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveJSON
(\Int
s ResponseHeaders
h Object
x -> Object -> Either String FileSystemDescription
forall a. FromJSON a => Object -> Either String a
Core.eitherParseJSON Object
x)
instance Prelude.Hashable UpdateFileSystem
instance Prelude.NFData UpdateFileSystem
instance Core.ToHeaders UpdateFileSystem where
toHeaders :: UpdateFileSystem -> ResponseHeaders
toHeaders = ResponseHeaders -> UpdateFileSystem -> ResponseHeaders
forall a b. a -> b -> a
Prelude.const ResponseHeaders
forall a. Monoid a => a
Prelude.mempty
instance Core.ToJSON UpdateFileSystem where
toJSON :: UpdateFileSystem -> Value
toJSON UpdateFileSystem' {Maybe Double
Maybe ThroughputMode
Text
fileSystemId :: Text
throughputMode :: Maybe ThroughputMode
provisionedThroughputInMibps :: Maybe Double
$sel:fileSystemId:UpdateFileSystem' :: UpdateFileSystem -> Text
$sel:throughputMode:UpdateFileSystem' :: UpdateFileSystem -> Maybe ThroughputMode
$sel:provisionedThroughputInMibps:UpdateFileSystem' :: UpdateFileSystem -> Maybe Double
..} =
[Pair] -> Value
Core.object
( [Maybe Pair] -> [Pair]
forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Text
"ProvisionedThroughputInMibps" Text -> Double -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Core..=)
(Double -> Pair) -> Maybe Double -> Maybe Pair
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Double
provisionedThroughputInMibps,
(Text
"ThroughputMode" Text -> ThroughputMode -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Core..=)
(ThroughputMode -> Pair) -> Maybe ThroughputMode -> Maybe Pair
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe ThroughputMode
throughputMode
]
)
instance Core.ToPath UpdateFileSystem where
toPath :: UpdateFileSystem -> ByteString
toPath UpdateFileSystem' {Maybe Double
Maybe ThroughputMode
Text
fileSystemId :: Text
throughputMode :: Maybe ThroughputMode
provisionedThroughputInMibps :: Maybe Double
$sel:fileSystemId:UpdateFileSystem' :: UpdateFileSystem -> Text
$sel:throughputMode:UpdateFileSystem' :: UpdateFileSystem -> Maybe ThroughputMode
$sel:provisionedThroughputInMibps:UpdateFileSystem' :: UpdateFileSystem -> Maybe Double
..} =
[ByteString] -> ByteString
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ByteString
"/2015-02-01/file-systems/", Text -> ByteString
forall a. ToByteString a => a -> ByteString
Core.toBS Text
fileSystemId]
instance Core.ToQuery UpdateFileSystem where
toQuery :: UpdateFileSystem -> QueryString
toQuery = QueryString -> UpdateFileSystem -> QueryString
forall a b. a -> b -> a
Prelude.const QueryString
forall a. Monoid a => a
Prelude.mempty