{-# 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.IoTFleetWise.CreateModelManifest
(
CreateModelManifest (..),
newCreateModelManifest,
createModelManifest_description,
createModelManifest_tags,
createModelManifest_name,
createModelManifest_nodes,
createModelManifest_signalCatalogArn,
CreateModelManifestResponse (..),
newCreateModelManifestResponse,
createModelManifestResponse_httpStatus,
createModelManifestResponse_name,
createModelManifestResponse_arn,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.IoTFleetWise.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data CreateModelManifest = CreateModelManifest'
{
CreateModelManifest -> Maybe Text
description :: Prelude.Maybe Prelude.Text,
CreateModelManifest -> Maybe [Tag]
tags :: Prelude.Maybe [Tag],
CreateModelManifest -> Text
name :: Prelude.Text,
CreateModelManifest -> [Text]
nodes :: [Prelude.Text],
CreateModelManifest -> Text
signalCatalogArn :: Prelude.Text
}
deriving (CreateModelManifest -> CreateModelManifest -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateModelManifest -> CreateModelManifest -> Bool
$c/= :: CreateModelManifest -> CreateModelManifest -> Bool
== :: CreateModelManifest -> CreateModelManifest -> Bool
$c== :: CreateModelManifest -> CreateModelManifest -> Bool
Prelude.Eq, ReadPrec [CreateModelManifest]
ReadPrec CreateModelManifest
Int -> ReadS CreateModelManifest
ReadS [CreateModelManifest]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateModelManifest]
$creadListPrec :: ReadPrec [CreateModelManifest]
readPrec :: ReadPrec CreateModelManifest
$creadPrec :: ReadPrec CreateModelManifest
readList :: ReadS [CreateModelManifest]
$creadList :: ReadS [CreateModelManifest]
readsPrec :: Int -> ReadS CreateModelManifest
$creadsPrec :: Int -> ReadS CreateModelManifest
Prelude.Read, Int -> CreateModelManifest -> ShowS
[CreateModelManifest] -> ShowS
CreateModelManifest -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateModelManifest] -> ShowS
$cshowList :: [CreateModelManifest] -> ShowS
show :: CreateModelManifest -> String
$cshow :: CreateModelManifest -> String
showsPrec :: Int -> CreateModelManifest -> ShowS
$cshowsPrec :: Int -> CreateModelManifest -> ShowS
Prelude.Show, forall x. Rep CreateModelManifest x -> CreateModelManifest
forall x. CreateModelManifest -> Rep CreateModelManifest x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep CreateModelManifest x -> CreateModelManifest
$cfrom :: forall x. CreateModelManifest -> Rep CreateModelManifest x
Prelude.Generic)
newCreateModelManifest ::
Prelude.Text ->
Prelude.Text ->
CreateModelManifest
newCreateModelManifest :: Text -> Text -> CreateModelManifest
newCreateModelManifest Text
pName_ Text
pSignalCatalogArn_ =
CreateModelManifest'
{ $sel:description:CreateModelManifest' :: Maybe Text
description = forall a. Maybe a
Prelude.Nothing,
$sel:tags:CreateModelManifest' :: Maybe [Tag]
tags = forall a. Maybe a
Prelude.Nothing,
$sel:name:CreateModelManifest' :: Text
name = Text
pName_,
$sel:nodes:CreateModelManifest' :: [Text]
nodes = forall a. Monoid a => a
Prelude.mempty,
$sel:signalCatalogArn:CreateModelManifest' :: Text
signalCatalogArn = Text
pSignalCatalogArn_
}
createModelManifest_description :: Lens.Lens' CreateModelManifest (Prelude.Maybe Prelude.Text)
createModelManifest_description :: Lens' CreateModelManifest (Maybe Text)
createModelManifest_description = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateModelManifest' {Maybe Text
description :: Maybe Text
$sel:description:CreateModelManifest' :: CreateModelManifest -> Maybe Text
description} -> Maybe Text
description) (\s :: CreateModelManifest
s@CreateModelManifest' {} Maybe Text
a -> CreateModelManifest
s {$sel:description:CreateModelManifest' :: Maybe Text
description = Maybe Text
a} :: CreateModelManifest)
createModelManifest_tags :: Lens.Lens' CreateModelManifest (Prelude.Maybe [Tag])
createModelManifest_tags :: Lens' CreateModelManifest (Maybe [Tag])
createModelManifest_tags = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateModelManifest' {Maybe [Tag]
tags :: Maybe [Tag]
$sel:tags:CreateModelManifest' :: CreateModelManifest -> Maybe [Tag]
tags} -> Maybe [Tag]
tags) (\s :: CreateModelManifest
s@CreateModelManifest' {} Maybe [Tag]
a -> CreateModelManifest
s {$sel:tags:CreateModelManifest' :: Maybe [Tag]
tags = Maybe [Tag]
a} :: CreateModelManifest) 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
createModelManifest_name :: Lens.Lens' CreateModelManifest Prelude.Text
createModelManifest_name :: Lens' CreateModelManifest Text
createModelManifest_name = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateModelManifest' {Text
name :: Text
$sel:name:CreateModelManifest' :: CreateModelManifest -> Text
name} -> Text
name) (\s :: CreateModelManifest
s@CreateModelManifest' {} Text
a -> CreateModelManifest
s {$sel:name:CreateModelManifest' :: Text
name = Text
a} :: CreateModelManifest)
createModelManifest_nodes :: Lens.Lens' CreateModelManifest [Prelude.Text]
createModelManifest_nodes :: Lens' CreateModelManifest [Text]
createModelManifest_nodes = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateModelManifest' {[Text]
nodes :: [Text]
$sel:nodes:CreateModelManifest' :: CreateModelManifest -> [Text]
nodes} -> [Text]
nodes) (\s :: CreateModelManifest
s@CreateModelManifest' {} [Text]
a -> CreateModelManifest
s {$sel:nodes:CreateModelManifest' :: [Text]
nodes = [Text]
a} :: CreateModelManifest) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced
createModelManifest_signalCatalogArn :: Lens.Lens' CreateModelManifest Prelude.Text
createModelManifest_signalCatalogArn :: Lens' CreateModelManifest Text
createModelManifest_signalCatalogArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateModelManifest' {Text
signalCatalogArn :: Text
$sel:signalCatalogArn:CreateModelManifest' :: CreateModelManifest -> Text
signalCatalogArn} -> Text
signalCatalogArn) (\s :: CreateModelManifest
s@CreateModelManifest' {} Text
a -> CreateModelManifest
s {$sel:signalCatalogArn:CreateModelManifest' :: Text
signalCatalogArn = Text
a} :: CreateModelManifest)
instance Core.AWSRequest CreateModelManifest where
type
AWSResponse CreateModelManifest =
CreateModelManifestResponse
request :: (Service -> Service)
-> CreateModelManifest -> Request CreateModelManifest
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 CreateModelManifest
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse CreateModelManifest)))
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 ->
Int -> Text -> Text -> CreateModelManifestResponse
CreateModelManifestResponse'
forall (f :: * -> *) a b. Functor 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))
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"name")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"arn")
)
instance Prelude.Hashable CreateModelManifest where
hashWithSalt :: Int -> CreateModelManifest -> Int
hashWithSalt Int
_salt CreateModelManifest' {[Text]
Maybe [Tag]
Maybe Text
Text
signalCatalogArn :: Text
nodes :: [Text]
name :: Text
tags :: Maybe [Tag]
description :: Maybe Text
$sel:signalCatalogArn:CreateModelManifest' :: CreateModelManifest -> Text
$sel:nodes:CreateModelManifest' :: CreateModelManifest -> [Text]
$sel:name:CreateModelManifest' :: CreateModelManifest -> Text
$sel:tags:CreateModelManifest' :: CreateModelManifest -> Maybe [Tag]
$sel:description:CreateModelManifest' :: CreateModelManifest -> Maybe Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
description
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [Tag]
tags
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
name
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` [Text]
nodes
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
signalCatalogArn
instance Prelude.NFData CreateModelManifest where
rnf :: CreateModelManifest -> ()
rnf CreateModelManifest' {[Text]
Maybe [Tag]
Maybe Text
Text
signalCatalogArn :: Text
nodes :: [Text]
name :: Text
tags :: Maybe [Tag]
description :: Maybe Text
$sel:signalCatalogArn:CreateModelManifest' :: CreateModelManifest -> Text
$sel:nodes:CreateModelManifest' :: CreateModelManifest -> [Text]
$sel:name:CreateModelManifest' :: CreateModelManifest -> Text
$sel:tags:CreateModelManifest' :: CreateModelManifest -> Maybe [Tag]
$sel:description:CreateModelManifest' :: CreateModelManifest -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
description
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [Tag]
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 [Text]
nodes
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
signalCatalogArn
instance Data.ToHeaders CreateModelManifest where
toHeaders :: CreateModelManifest -> ResponseHeaders
toHeaders =
forall a b. a -> b -> a
Prelude.const
( forall a. Monoid a => [a] -> a
Prelude.mconcat
[ HeaderName
"X-Amz-Target"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"IoTAutobahnControlPlane.CreateModelManifest" ::
Prelude.ByteString
),
HeaderName
"Content-Type"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.0" ::
Prelude.ByteString
)
]
)
instance Data.ToJSON CreateModelManifest where
toJSON :: CreateModelManifest -> Value
toJSON CreateModelManifest' {[Text]
Maybe [Tag]
Maybe Text
Text
signalCatalogArn :: Text
nodes :: [Text]
name :: Text
tags :: Maybe [Tag]
description :: Maybe Text
$sel:signalCatalogArn:CreateModelManifest' :: CreateModelManifest -> Text
$sel:nodes:CreateModelManifest' :: CreateModelManifest -> [Text]
$sel:name:CreateModelManifest' :: CreateModelManifest -> Text
$sel:tags:CreateModelManifest' :: CreateModelManifest -> Maybe [Tag]
$sel:description:CreateModelManifest' :: CreateModelManifest -> Maybe Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Key
"description" 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
description,
(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 [Tag]
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
"nodes" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= [Text]
nodes),
forall a. a -> Maybe a
Prelude.Just
(Key
"signalCatalogArn" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
signalCatalogArn)
]
)
instance Data.ToPath CreateModelManifest where
toPath :: CreateModelManifest -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery CreateModelManifest where
toQuery :: CreateModelManifest -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data CreateModelManifestResponse = CreateModelManifestResponse'
{
CreateModelManifestResponse -> Int
httpStatus :: Prelude.Int,
CreateModelManifestResponse -> Text
name :: Prelude.Text,
CreateModelManifestResponse -> Text
arn :: Prelude.Text
}
deriving (CreateModelManifestResponse -> CreateModelManifestResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateModelManifestResponse -> CreateModelManifestResponse -> Bool
$c/= :: CreateModelManifestResponse -> CreateModelManifestResponse -> Bool
== :: CreateModelManifestResponse -> CreateModelManifestResponse -> Bool
$c== :: CreateModelManifestResponse -> CreateModelManifestResponse -> Bool
Prelude.Eq, ReadPrec [CreateModelManifestResponse]
ReadPrec CreateModelManifestResponse
Int -> ReadS CreateModelManifestResponse
ReadS [CreateModelManifestResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateModelManifestResponse]
$creadListPrec :: ReadPrec [CreateModelManifestResponse]
readPrec :: ReadPrec CreateModelManifestResponse
$creadPrec :: ReadPrec CreateModelManifestResponse
readList :: ReadS [CreateModelManifestResponse]
$creadList :: ReadS [CreateModelManifestResponse]
readsPrec :: Int -> ReadS CreateModelManifestResponse
$creadsPrec :: Int -> ReadS CreateModelManifestResponse
Prelude.Read, Int -> CreateModelManifestResponse -> ShowS
[CreateModelManifestResponse] -> ShowS
CreateModelManifestResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateModelManifestResponse] -> ShowS
$cshowList :: [CreateModelManifestResponse] -> ShowS
show :: CreateModelManifestResponse -> String
$cshow :: CreateModelManifestResponse -> String
showsPrec :: Int -> CreateModelManifestResponse -> ShowS
$cshowsPrec :: Int -> CreateModelManifestResponse -> ShowS
Prelude.Show, forall x.
Rep CreateModelManifestResponse x -> CreateModelManifestResponse
forall x.
CreateModelManifestResponse -> Rep CreateModelManifestResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep CreateModelManifestResponse x -> CreateModelManifestResponse
$cfrom :: forall x.
CreateModelManifestResponse -> Rep CreateModelManifestResponse x
Prelude.Generic)
newCreateModelManifestResponse ::
Prelude.Int ->
Prelude.Text ->
Prelude.Text ->
CreateModelManifestResponse
newCreateModelManifestResponse :: Int -> Text -> Text -> CreateModelManifestResponse
newCreateModelManifestResponse
Int
pHttpStatus_
Text
pName_
Text
pArn_ =
CreateModelManifestResponse'
{ $sel:httpStatus:CreateModelManifestResponse' :: Int
httpStatus =
Int
pHttpStatus_,
$sel:name:CreateModelManifestResponse' :: Text
name = Text
pName_,
$sel:arn:CreateModelManifestResponse' :: Text
arn = Text
pArn_
}
createModelManifestResponse_httpStatus :: Lens.Lens' CreateModelManifestResponse Prelude.Int
createModelManifestResponse_httpStatus :: Lens' CreateModelManifestResponse Int
createModelManifestResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateModelManifestResponse' {Int
httpStatus :: Int
$sel:httpStatus:CreateModelManifestResponse' :: CreateModelManifestResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: CreateModelManifestResponse
s@CreateModelManifestResponse' {} Int
a -> CreateModelManifestResponse
s {$sel:httpStatus:CreateModelManifestResponse' :: Int
httpStatus = Int
a} :: CreateModelManifestResponse)
createModelManifestResponse_name :: Lens.Lens' CreateModelManifestResponse Prelude.Text
createModelManifestResponse_name :: Lens' CreateModelManifestResponse Text
createModelManifestResponse_name = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateModelManifestResponse' {Text
name :: Text
$sel:name:CreateModelManifestResponse' :: CreateModelManifestResponse -> Text
name} -> Text
name) (\s :: CreateModelManifestResponse
s@CreateModelManifestResponse' {} Text
a -> CreateModelManifestResponse
s {$sel:name:CreateModelManifestResponse' :: Text
name = Text
a} :: CreateModelManifestResponse)
createModelManifestResponse_arn :: Lens.Lens' CreateModelManifestResponse Prelude.Text
createModelManifestResponse_arn :: Lens' CreateModelManifestResponse Text
createModelManifestResponse_arn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateModelManifestResponse' {Text
arn :: Text
$sel:arn:CreateModelManifestResponse' :: CreateModelManifestResponse -> Text
arn} -> Text
arn) (\s :: CreateModelManifestResponse
s@CreateModelManifestResponse' {} Text
a -> CreateModelManifestResponse
s {$sel:arn:CreateModelManifestResponse' :: Text
arn = Text
a} :: CreateModelManifestResponse)
instance Prelude.NFData CreateModelManifestResponse where
rnf :: CreateModelManifestResponse -> ()
rnf CreateModelManifestResponse' {Int
Text
arn :: Text
name :: Text
httpStatus :: Int
$sel:arn:CreateModelManifestResponse' :: CreateModelManifestResponse -> Text
$sel:name:CreateModelManifestResponse' :: CreateModelManifestResponse -> Text
$sel:httpStatus:CreateModelManifestResponse' :: CreateModelManifestResponse -> Int
..} =
forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus
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 Text
arn