{-# 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.UpdateFleet
(
UpdateFleet (..),
newUpdateFleet,
updateFleet_description,
updateFleet_fleetId,
UpdateFleetResponse (..),
newUpdateFleetResponse,
updateFleetResponse_arn,
updateFleetResponse_id,
updateFleetResponse_httpStatus,
)
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 UpdateFleet = UpdateFleet'
{
UpdateFleet -> Maybe Text
description :: Prelude.Maybe Prelude.Text,
UpdateFleet -> Text
fleetId :: Prelude.Text
}
deriving (UpdateFleet -> UpdateFleet -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UpdateFleet -> UpdateFleet -> Bool
$c/= :: UpdateFleet -> UpdateFleet -> Bool
== :: UpdateFleet -> UpdateFleet -> Bool
$c== :: UpdateFleet -> UpdateFleet -> Bool
Prelude.Eq, ReadPrec [UpdateFleet]
ReadPrec UpdateFleet
Int -> ReadS UpdateFleet
ReadS [UpdateFleet]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [UpdateFleet]
$creadListPrec :: ReadPrec [UpdateFleet]
readPrec :: ReadPrec UpdateFleet
$creadPrec :: ReadPrec UpdateFleet
readList :: ReadS [UpdateFleet]
$creadList :: ReadS [UpdateFleet]
readsPrec :: Int -> ReadS UpdateFleet
$creadsPrec :: Int -> ReadS UpdateFleet
Prelude.Read, Int -> UpdateFleet -> ShowS
[UpdateFleet] -> ShowS
UpdateFleet -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UpdateFleet] -> ShowS
$cshowList :: [UpdateFleet] -> ShowS
show :: UpdateFleet -> String
$cshow :: UpdateFleet -> String
showsPrec :: Int -> UpdateFleet -> ShowS
$cshowsPrec :: Int -> UpdateFleet -> ShowS
Prelude.Show, forall x. Rep UpdateFleet x -> UpdateFleet
forall x. UpdateFleet -> Rep UpdateFleet x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep UpdateFleet x -> UpdateFleet
$cfrom :: forall x. UpdateFleet -> Rep UpdateFleet x
Prelude.Generic)
newUpdateFleet ::
Prelude.Text ->
UpdateFleet
newUpdateFleet :: Text -> UpdateFleet
newUpdateFleet Text
pFleetId_ =
UpdateFleet'
{ $sel:description:UpdateFleet' :: Maybe Text
description = forall a. Maybe a
Prelude.Nothing,
$sel:fleetId:UpdateFleet' :: Text
fleetId = Text
pFleetId_
}
updateFleet_description :: Lens.Lens' UpdateFleet (Prelude.Maybe Prelude.Text)
updateFleet_description :: Lens' UpdateFleet (Maybe Text)
updateFleet_description = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateFleet' {Maybe Text
description :: Maybe Text
$sel:description:UpdateFleet' :: UpdateFleet -> Maybe Text
description} -> Maybe Text
description) (\s :: UpdateFleet
s@UpdateFleet' {} Maybe Text
a -> UpdateFleet
s {$sel:description:UpdateFleet' :: Maybe Text
description = Maybe Text
a} :: UpdateFleet)
updateFleet_fleetId :: Lens.Lens' UpdateFleet Prelude.Text
updateFleet_fleetId :: Lens' UpdateFleet Text
updateFleet_fleetId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateFleet' {Text
fleetId :: Text
$sel:fleetId:UpdateFleet' :: UpdateFleet -> Text
fleetId} -> Text
fleetId) (\s :: UpdateFleet
s@UpdateFleet' {} Text
a -> UpdateFleet
s {$sel:fleetId:UpdateFleet' :: Text
fleetId = Text
a} :: UpdateFleet)
instance Core.AWSRequest UpdateFleet where
type AWSResponse UpdateFleet = UpdateFleetResponse
request :: (Service -> Service) -> UpdateFleet -> Request UpdateFleet
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 UpdateFleet
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse UpdateFleet)))
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 Text -> Maybe Text -> Int -> UpdateFleetResponse
UpdateFleetResponse'
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
"arn")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"id")
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 UpdateFleet where
hashWithSalt :: Int -> UpdateFleet -> Int
hashWithSalt Int
_salt UpdateFleet' {Maybe Text
Text
fleetId :: Text
description :: Maybe Text
$sel:fleetId:UpdateFleet' :: UpdateFleet -> Text
$sel:description:UpdateFleet' :: UpdateFleet -> 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` Text
fleetId
instance Prelude.NFData UpdateFleet where
rnf :: UpdateFleet -> ()
rnf UpdateFleet' {Maybe Text
Text
fleetId :: Text
description :: Maybe Text
$sel:fleetId:UpdateFleet' :: UpdateFleet -> Text
$sel:description:UpdateFleet' :: UpdateFleet -> 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 Text
fleetId
instance Data.ToHeaders UpdateFleet where
toHeaders :: UpdateFleet -> 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.UpdateFleet" ::
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 UpdateFleet where
toJSON :: UpdateFleet -> Value
toJSON UpdateFleet' {Maybe Text
Text
fleetId :: Text
description :: Maybe Text
$sel:fleetId:UpdateFleet' :: UpdateFleet -> Text
$sel:description:UpdateFleet' :: UpdateFleet -> 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,
forall a. a -> Maybe a
Prelude.Just (Key
"fleetId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
fleetId)
]
)
instance Data.ToPath UpdateFleet where
toPath :: UpdateFleet -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery UpdateFleet where
toQuery :: UpdateFleet -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data UpdateFleetResponse = UpdateFleetResponse'
{
UpdateFleetResponse -> Maybe Text
arn :: Prelude.Maybe Prelude.Text,
UpdateFleetResponse -> Maybe Text
id :: Prelude.Maybe Prelude.Text,
UpdateFleetResponse -> Int
httpStatus :: Prelude.Int
}
deriving (UpdateFleetResponse -> UpdateFleetResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UpdateFleetResponse -> UpdateFleetResponse -> Bool
$c/= :: UpdateFleetResponse -> UpdateFleetResponse -> Bool
== :: UpdateFleetResponse -> UpdateFleetResponse -> Bool
$c== :: UpdateFleetResponse -> UpdateFleetResponse -> Bool
Prelude.Eq, ReadPrec [UpdateFleetResponse]
ReadPrec UpdateFleetResponse
Int -> ReadS UpdateFleetResponse
ReadS [UpdateFleetResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [UpdateFleetResponse]
$creadListPrec :: ReadPrec [UpdateFleetResponse]
readPrec :: ReadPrec UpdateFleetResponse
$creadPrec :: ReadPrec UpdateFleetResponse
readList :: ReadS [UpdateFleetResponse]
$creadList :: ReadS [UpdateFleetResponse]
readsPrec :: Int -> ReadS UpdateFleetResponse
$creadsPrec :: Int -> ReadS UpdateFleetResponse
Prelude.Read, Int -> UpdateFleetResponse -> ShowS
[UpdateFleetResponse] -> ShowS
UpdateFleetResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UpdateFleetResponse] -> ShowS
$cshowList :: [UpdateFleetResponse] -> ShowS
show :: UpdateFleetResponse -> String
$cshow :: UpdateFleetResponse -> String
showsPrec :: Int -> UpdateFleetResponse -> ShowS
$cshowsPrec :: Int -> UpdateFleetResponse -> ShowS
Prelude.Show, forall x. Rep UpdateFleetResponse x -> UpdateFleetResponse
forall x. UpdateFleetResponse -> Rep UpdateFleetResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep UpdateFleetResponse x -> UpdateFleetResponse
$cfrom :: forall x. UpdateFleetResponse -> Rep UpdateFleetResponse x
Prelude.Generic)
newUpdateFleetResponse ::
Prelude.Int ->
UpdateFleetResponse
newUpdateFleetResponse :: Int -> UpdateFleetResponse
newUpdateFleetResponse Int
pHttpStatus_ =
UpdateFleetResponse'
{ $sel:arn:UpdateFleetResponse' :: Maybe Text
arn = forall a. Maybe a
Prelude.Nothing,
$sel:id:UpdateFleetResponse' :: Maybe Text
id = forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:UpdateFleetResponse' :: Int
httpStatus = Int
pHttpStatus_
}
updateFleetResponse_arn :: Lens.Lens' UpdateFleetResponse (Prelude.Maybe Prelude.Text)
updateFleetResponse_arn :: Lens' UpdateFleetResponse (Maybe Text)
updateFleetResponse_arn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateFleetResponse' {Maybe Text
arn :: Maybe Text
$sel:arn:UpdateFleetResponse' :: UpdateFleetResponse -> Maybe Text
arn} -> Maybe Text
arn) (\s :: UpdateFleetResponse
s@UpdateFleetResponse' {} Maybe Text
a -> UpdateFleetResponse
s {$sel:arn:UpdateFleetResponse' :: Maybe Text
arn = Maybe Text
a} :: UpdateFleetResponse)
updateFleetResponse_id :: Lens.Lens' UpdateFleetResponse (Prelude.Maybe Prelude.Text)
updateFleetResponse_id :: Lens' UpdateFleetResponse (Maybe Text)
updateFleetResponse_id = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateFleetResponse' {Maybe Text
id :: Maybe Text
$sel:id:UpdateFleetResponse' :: UpdateFleetResponse -> Maybe Text
id} -> Maybe Text
id) (\s :: UpdateFleetResponse
s@UpdateFleetResponse' {} Maybe Text
a -> UpdateFleetResponse
s {$sel:id:UpdateFleetResponse' :: Maybe Text
id = Maybe Text
a} :: UpdateFleetResponse)
updateFleetResponse_httpStatus :: Lens.Lens' UpdateFleetResponse Prelude.Int
updateFleetResponse_httpStatus :: Lens' UpdateFleetResponse Int
updateFleetResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateFleetResponse' {Int
httpStatus :: Int
$sel:httpStatus:UpdateFleetResponse' :: UpdateFleetResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: UpdateFleetResponse
s@UpdateFleetResponse' {} Int
a -> UpdateFleetResponse
s {$sel:httpStatus:UpdateFleetResponse' :: Int
httpStatus = Int
a} :: UpdateFleetResponse)
instance Prelude.NFData UpdateFleetResponse where
rnf :: UpdateFleetResponse -> ()
rnf UpdateFleetResponse' {Int
Maybe Text
httpStatus :: Int
id :: Maybe Text
arn :: Maybe Text
$sel:httpStatus:UpdateFleetResponse' :: UpdateFleetResponse -> Int
$sel:id:UpdateFleetResponse' :: UpdateFleetResponse -> Maybe Text
$sel:arn:UpdateFleetResponse' :: UpdateFleetResponse -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
arn
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
id
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus