{-# 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.APIGateway.UpdateModel
(
UpdateModel (..),
newUpdateModel,
updateModel_patchOperations,
updateModel_restApiId,
updateModel_modelName,
Model (..),
newModel,
model_contentType,
model_description,
model_id,
model_name,
model_schema,
)
where
import Amazonka.APIGateway.Types
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data UpdateModel = UpdateModel'
{
UpdateModel -> Maybe [PatchOperation]
patchOperations :: Prelude.Maybe [PatchOperation],
UpdateModel -> Text
restApiId :: Prelude.Text,
UpdateModel -> Text
modelName :: Prelude.Text
}
deriving (UpdateModel -> UpdateModel -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UpdateModel -> UpdateModel -> Bool
$c/= :: UpdateModel -> UpdateModel -> Bool
== :: UpdateModel -> UpdateModel -> Bool
$c== :: UpdateModel -> UpdateModel -> Bool
Prelude.Eq, ReadPrec [UpdateModel]
ReadPrec UpdateModel
Int -> ReadS UpdateModel
ReadS [UpdateModel]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [UpdateModel]
$creadListPrec :: ReadPrec [UpdateModel]
readPrec :: ReadPrec UpdateModel
$creadPrec :: ReadPrec UpdateModel
readList :: ReadS [UpdateModel]
$creadList :: ReadS [UpdateModel]
readsPrec :: Int -> ReadS UpdateModel
$creadsPrec :: Int -> ReadS UpdateModel
Prelude.Read, Int -> UpdateModel -> ShowS
[UpdateModel] -> ShowS
UpdateModel -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UpdateModel] -> ShowS
$cshowList :: [UpdateModel] -> ShowS
show :: UpdateModel -> String
$cshow :: UpdateModel -> String
showsPrec :: Int -> UpdateModel -> ShowS
$cshowsPrec :: Int -> UpdateModel -> ShowS
Prelude.Show, forall x. Rep UpdateModel x -> UpdateModel
forall x. UpdateModel -> Rep UpdateModel x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep UpdateModel x -> UpdateModel
$cfrom :: forall x. UpdateModel -> Rep UpdateModel x
Prelude.Generic)
newUpdateModel ::
Prelude.Text ->
Prelude.Text ->
UpdateModel
newUpdateModel :: Text -> Text -> UpdateModel
newUpdateModel Text
pRestApiId_ Text
pModelName_ =
UpdateModel'
{ $sel:patchOperations:UpdateModel' :: Maybe [PatchOperation]
patchOperations = forall a. Maybe a
Prelude.Nothing,
$sel:restApiId:UpdateModel' :: Text
restApiId = Text
pRestApiId_,
$sel:modelName:UpdateModel' :: Text
modelName = Text
pModelName_
}
updateModel_patchOperations :: Lens.Lens' UpdateModel (Prelude.Maybe [PatchOperation])
updateModel_patchOperations :: Lens' UpdateModel (Maybe [PatchOperation])
updateModel_patchOperations = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateModel' {Maybe [PatchOperation]
patchOperations :: Maybe [PatchOperation]
$sel:patchOperations:UpdateModel' :: UpdateModel -> Maybe [PatchOperation]
patchOperations} -> Maybe [PatchOperation]
patchOperations) (\s :: UpdateModel
s@UpdateModel' {} Maybe [PatchOperation]
a -> UpdateModel
s {$sel:patchOperations:UpdateModel' :: Maybe [PatchOperation]
patchOperations = Maybe [PatchOperation]
a} :: UpdateModel) 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
updateModel_restApiId :: Lens.Lens' UpdateModel Prelude.Text
updateModel_restApiId :: Lens' UpdateModel Text
updateModel_restApiId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateModel' {Text
restApiId :: Text
$sel:restApiId:UpdateModel' :: UpdateModel -> Text
restApiId} -> Text
restApiId) (\s :: UpdateModel
s@UpdateModel' {} Text
a -> UpdateModel
s {$sel:restApiId:UpdateModel' :: Text
restApiId = Text
a} :: UpdateModel)
updateModel_modelName :: Lens.Lens' UpdateModel Prelude.Text
updateModel_modelName :: Lens' UpdateModel Text
updateModel_modelName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateModel' {Text
modelName :: Text
$sel:modelName:UpdateModel' :: UpdateModel -> Text
modelName} -> Text
modelName) (\s :: UpdateModel
s@UpdateModel' {} Text
a -> UpdateModel
s {$sel:modelName:UpdateModel' :: Text
modelName = Text
a} :: UpdateModel)
instance Core.AWSRequest UpdateModel where
type AWSResponse UpdateModel = Model
request :: (Service -> Service) -> UpdateModel -> Request UpdateModel
request Service -> Service
overrides =
forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.patchJSON (Service -> Service
overrides Service
defaultService)
response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy UpdateModel
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse UpdateModel)))
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 UpdateModel where
hashWithSalt :: Int -> UpdateModel -> Int
hashWithSalt Int
_salt UpdateModel' {Maybe [PatchOperation]
Text
modelName :: Text
restApiId :: Text
patchOperations :: Maybe [PatchOperation]
$sel:modelName:UpdateModel' :: UpdateModel -> Text
$sel:restApiId:UpdateModel' :: UpdateModel -> Text
$sel:patchOperations:UpdateModel' :: UpdateModel -> Maybe [PatchOperation]
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [PatchOperation]
patchOperations
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
restApiId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
modelName
instance Prelude.NFData UpdateModel where
rnf :: UpdateModel -> ()
rnf UpdateModel' {Maybe [PatchOperation]
Text
modelName :: Text
restApiId :: Text
patchOperations :: Maybe [PatchOperation]
$sel:modelName:UpdateModel' :: UpdateModel -> Text
$sel:restApiId:UpdateModel' :: UpdateModel -> Text
$sel:patchOperations:UpdateModel' :: UpdateModel -> Maybe [PatchOperation]
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe [PatchOperation]
patchOperations
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
restApiId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
modelName
instance Data.ToHeaders UpdateModel where
toHeaders :: UpdateModel -> ResponseHeaders
toHeaders =
forall a b. a -> b -> a
Prelude.const
( forall a. Monoid a => [a] -> a
Prelude.mconcat
[ HeaderName
"Accept"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# (ByteString
"application/json" :: Prelude.ByteString)
]
)
instance Data.ToJSON UpdateModel where
toJSON :: UpdateModel -> Value
toJSON UpdateModel' {Maybe [PatchOperation]
Text
modelName :: Text
restApiId :: Text
patchOperations :: Maybe [PatchOperation]
$sel:modelName:UpdateModel' :: UpdateModel -> Text
$sel:restApiId:UpdateModel' :: UpdateModel -> Text
$sel:patchOperations:UpdateModel' :: UpdateModel -> Maybe [PatchOperation]
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Key
"patchOperations" 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 [PatchOperation]
patchOperations
]
)
instance Data.ToPath UpdateModel where
toPath :: UpdateModel -> ByteString
toPath UpdateModel' {Maybe [PatchOperation]
Text
modelName :: Text
restApiId :: Text
patchOperations :: Maybe [PatchOperation]
$sel:modelName:UpdateModel' :: UpdateModel -> Text
$sel:restApiId:UpdateModel' :: UpdateModel -> Text
$sel:patchOperations:UpdateModel' :: UpdateModel -> Maybe [PatchOperation]
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ ByteString
"/restapis/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
restApiId,
ByteString
"/models/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
modelName
]
instance Data.ToQuery UpdateModel where
toQuery :: UpdateModel -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty