{-# 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.LookoutVision.DescribeModel
(
DescribeModel (..),
newDescribeModel,
describeModel_projectName,
describeModel_modelVersion,
DescribeModelResponse (..),
newDescribeModelResponse,
describeModelResponse_modelDescription,
describeModelResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.LookoutVision.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data DescribeModel = DescribeModel'
{
DescribeModel -> Text
projectName :: Prelude.Text,
DescribeModel -> Text
modelVersion :: Prelude.Text
}
deriving (DescribeModel -> DescribeModel -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeModel -> DescribeModel -> Bool
$c/= :: DescribeModel -> DescribeModel -> Bool
== :: DescribeModel -> DescribeModel -> Bool
$c== :: DescribeModel -> DescribeModel -> Bool
Prelude.Eq, ReadPrec [DescribeModel]
ReadPrec DescribeModel
Int -> ReadS DescribeModel
ReadS [DescribeModel]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeModel]
$creadListPrec :: ReadPrec [DescribeModel]
readPrec :: ReadPrec DescribeModel
$creadPrec :: ReadPrec DescribeModel
readList :: ReadS [DescribeModel]
$creadList :: ReadS [DescribeModel]
readsPrec :: Int -> ReadS DescribeModel
$creadsPrec :: Int -> ReadS DescribeModel
Prelude.Read, Int -> DescribeModel -> ShowS
[DescribeModel] -> ShowS
DescribeModel -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeModel] -> ShowS
$cshowList :: [DescribeModel] -> ShowS
show :: DescribeModel -> String
$cshow :: DescribeModel -> String
showsPrec :: Int -> DescribeModel -> ShowS
$cshowsPrec :: Int -> DescribeModel -> ShowS
Prelude.Show, forall x. Rep DescribeModel x -> DescribeModel
forall x. DescribeModel -> Rep DescribeModel x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeModel x -> DescribeModel
$cfrom :: forall x. DescribeModel -> Rep DescribeModel x
Prelude.Generic)
newDescribeModel ::
Prelude.Text ->
Prelude.Text ->
DescribeModel
newDescribeModel :: Text -> Text -> DescribeModel
newDescribeModel Text
pProjectName_ Text
pModelVersion_ =
DescribeModel'
{ $sel:projectName:DescribeModel' :: Text
projectName = Text
pProjectName_,
$sel:modelVersion:DescribeModel' :: Text
modelVersion = Text
pModelVersion_
}
describeModel_projectName :: Lens.Lens' DescribeModel Prelude.Text
describeModel_projectName :: Lens' DescribeModel Text
describeModel_projectName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeModel' {Text
projectName :: Text
$sel:projectName:DescribeModel' :: DescribeModel -> Text
projectName} -> Text
projectName) (\s :: DescribeModel
s@DescribeModel' {} Text
a -> DescribeModel
s {$sel:projectName:DescribeModel' :: Text
projectName = Text
a} :: DescribeModel)
describeModel_modelVersion :: Lens.Lens' DescribeModel Prelude.Text
describeModel_modelVersion :: Lens' DescribeModel Text
describeModel_modelVersion = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeModel' {Text
modelVersion :: Text
$sel:modelVersion:DescribeModel' :: DescribeModel -> Text
modelVersion} -> Text
modelVersion) (\s :: DescribeModel
s@DescribeModel' {} Text
a -> DescribeModel
s {$sel:modelVersion:DescribeModel' :: Text
modelVersion = Text
a} :: DescribeModel)
instance Core.AWSRequest DescribeModel where
type
AWSResponse DescribeModel =
DescribeModelResponse
request :: (Service -> Service) -> DescribeModel -> Request DescribeModel
request Service -> Service
overrides =
forall a. ToRequest a => Service -> a -> Request a
Request.get (Service -> Service
overrides Service
defaultService)
response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DescribeModel
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DescribeModel)))
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 ModelDescription -> Int -> DescribeModelResponse
DescribeModelResponse'
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
"ModelDescription")
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 DescribeModel where
hashWithSalt :: Int -> DescribeModel -> Int
hashWithSalt Int
_salt DescribeModel' {Text
modelVersion :: Text
projectName :: Text
$sel:modelVersion:DescribeModel' :: DescribeModel -> Text
$sel:projectName:DescribeModel' :: DescribeModel -> Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
projectName
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
modelVersion
instance Prelude.NFData DescribeModel where
rnf :: DescribeModel -> ()
rnf DescribeModel' {Text
modelVersion :: Text
projectName :: Text
$sel:modelVersion:DescribeModel' :: DescribeModel -> Text
$sel:projectName:DescribeModel' :: DescribeModel -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
projectName
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
modelVersion
instance Data.ToHeaders DescribeModel where
toHeaders :: DescribeModel -> 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.ToPath DescribeModel where
toPath :: DescribeModel -> ByteString
toPath DescribeModel' {Text
modelVersion :: Text
projectName :: Text
$sel:modelVersion:DescribeModel' :: DescribeModel -> Text
$sel:projectName:DescribeModel' :: DescribeModel -> Text
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ ByteString
"/2020-11-20/projects/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
projectName,
ByteString
"/models/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
modelVersion
]
instance Data.ToQuery DescribeModel where
toQuery :: DescribeModel -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DescribeModelResponse = DescribeModelResponse'
{
DescribeModelResponse -> Maybe ModelDescription
modelDescription :: Prelude.Maybe ModelDescription,
DescribeModelResponse -> Int
httpStatus :: Prelude.Int
}
deriving (DescribeModelResponse -> DescribeModelResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeModelResponse -> DescribeModelResponse -> Bool
$c/= :: DescribeModelResponse -> DescribeModelResponse -> Bool
== :: DescribeModelResponse -> DescribeModelResponse -> Bool
$c== :: DescribeModelResponse -> DescribeModelResponse -> Bool
Prelude.Eq, ReadPrec [DescribeModelResponse]
ReadPrec DescribeModelResponse
Int -> ReadS DescribeModelResponse
ReadS [DescribeModelResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeModelResponse]
$creadListPrec :: ReadPrec [DescribeModelResponse]
readPrec :: ReadPrec DescribeModelResponse
$creadPrec :: ReadPrec DescribeModelResponse
readList :: ReadS [DescribeModelResponse]
$creadList :: ReadS [DescribeModelResponse]
readsPrec :: Int -> ReadS DescribeModelResponse
$creadsPrec :: Int -> ReadS DescribeModelResponse
Prelude.Read, Int -> DescribeModelResponse -> ShowS
[DescribeModelResponse] -> ShowS
DescribeModelResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeModelResponse] -> ShowS
$cshowList :: [DescribeModelResponse] -> ShowS
show :: DescribeModelResponse -> String
$cshow :: DescribeModelResponse -> String
showsPrec :: Int -> DescribeModelResponse -> ShowS
$cshowsPrec :: Int -> DescribeModelResponse -> ShowS
Prelude.Show, forall x. Rep DescribeModelResponse x -> DescribeModelResponse
forall x. DescribeModelResponse -> Rep DescribeModelResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeModelResponse x -> DescribeModelResponse
$cfrom :: forall x. DescribeModelResponse -> Rep DescribeModelResponse x
Prelude.Generic)
newDescribeModelResponse ::
Prelude.Int ->
DescribeModelResponse
newDescribeModelResponse :: Int -> DescribeModelResponse
newDescribeModelResponse Int
pHttpStatus_ =
DescribeModelResponse'
{ $sel:modelDescription:DescribeModelResponse' :: Maybe ModelDescription
modelDescription =
forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:DescribeModelResponse' :: Int
httpStatus = Int
pHttpStatus_
}
describeModelResponse_modelDescription :: Lens.Lens' DescribeModelResponse (Prelude.Maybe ModelDescription)
describeModelResponse_modelDescription :: Lens' DescribeModelResponse (Maybe ModelDescription)
describeModelResponse_modelDescription = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeModelResponse' {Maybe ModelDescription
modelDescription :: Maybe ModelDescription
$sel:modelDescription:DescribeModelResponse' :: DescribeModelResponse -> Maybe ModelDescription
modelDescription} -> Maybe ModelDescription
modelDescription) (\s :: DescribeModelResponse
s@DescribeModelResponse' {} Maybe ModelDescription
a -> DescribeModelResponse
s {$sel:modelDescription:DescribeModelResponse' :: Maybe ModelDescription
modelDescription = Maybe ModelDescription
a} :: DescribeModelResponse)
describeModelResponse_httpStatus :: Lens.Lens' DescribeModelResponse Prelude.Int
describeModelResponse_httpStatus :: Lens' DescribeModelResponse Int
describeModelResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeModelResponse' {Int
httpStatus :: Int
$sel:httpStatus:DescribeModelResponse' :: DescribeModelResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DescribeModelResponse
s@DescribeModelResponse' {} Int
a -> DescribeModelResponse
s {$sel:httpStatus:DescribeModelResponse' :: Int
httpStatus = Int
a} :: DescribeModelResponse)
instance Prelude.NFData DescribeModelResponse where
rnf :: DescribeModelResponse -> ()
rnf DescribeModelResponse' {Int
Maybe ModelDescription
httpStatus :: Int
modelDescription :: Maybe ModelDescription
$sel:httpStatus:DescribeModelResponse' :: DescribeModelResponse -> Int
$sel:modelDescription:DescribeModelResponse' :: DescribeModelResponse -> Maybe ModelDescription
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe ModelDescription
modelDescription
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus