{-# 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.Greengrass.UpdateConnectivityInfo
(
UpdateConnectivityInfo (..),
newUpdateConnectivityInfo,
updateConnectivityInfo_connectivityInfo,
updateConnectivityInfo_thingName,
UpdateConnectivityInfoResponse (..),
newUpdateConnectivityInfoResponse,
updateConnectivityInfoResponse_message,
updateConnectivityInfoResponse_version,
updateConnectivityInfoResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.Greengrass.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data UpdateConnectivityInfo = UpdateConnectivityInfo'
{
UpdateConnectivityInfo -> Maybe [ConnectivityInfo]
connectivityInfo :: Prelude.Maybe [ConnectivityInfo],
UpdateConnectivityInfo -> Text
thingName :: Prelude.Text
}
deriving (UpdateConnectivityInfo -> UpdateConnectivityInfo -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UpdateConnectivityInfo -> UpdateConnectivityInfo -> Bool
$c/= :: UpdateConnectivityInfo -> UpdateConnectivityInfo -> Bool
== :: UpdateConnectivityInfo -> UpdateConnectivityInfo -> Bool
$c== :: UpdateConnectivityInfo -> UpdateConnectivityInfo -> Bool
Prelude.Eq, ReadPrec [UpdateConnectivityInfo]
ReadPrec UpdateConnectivityInfo
Int -> ReadS UpdateConnectivityInfo
ReadS [UpdateConnectivityInfo]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [UpdateConnectivityInfo]
$creadListPrec :: ReadPrec [UpdateConnectivityInfo]
readPrec :: ReadPrec UpdateConnectivityInfo
$creadPrec :: ReadPrec UpdateConnectivityInfo
readList :: ReadS [UpdateConnectivityInfo]
$creadList :: ReadS [UpdateConnectivityInfo]
readsPrec :: Int -> ReadS UpdateConnectivityInfo
$creadsPrec :: Int -> ReadS UpdateConnectivityInfo
Prelude.Read, Int -> UpdateConnectivityInfo -> ShowS
[UpdateConnectivityInfo] -> ShowS
UpdateConnectivityInfo -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UpdateConnectivityInfo] -> ShowS
$cshowList :: [UpdateConnectivityInfo] -> ShowS
show :: UpdateConnectivityInfo -> String
$cshow :: UpdateConnectivityInfo -> String
showsPrec :: Int -> UpdateConnectivityInfo -> ShowS
$cshowsPrec :: Int -> UpdateConnectivityInfo -> ShowS
Prelude.Show, forall x. Rep UpdateConnectivityInfo x -> UpdateConnectivityInfo
forall x. UpdateConnectivityInfo -> Rep UpdateConnectivityInfo x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep UpdateConnectivityInfo x -> UpdateConnectivityInfo
$cfrom :: forall x. UpdateConnectivityInfo -> Rep UpdateConnectivityInfo x
Prelude.Generic)
newUpdateConnectivityInfo ::
Prelude.Text ->
UpdateConnectivityInfo
newUpdateConnectivityInfo :: Text -> UpdateConnectivityInfo
newUpdateConnectivityInfo Text
pThingName_ =
UpdateConnectivityInfo'
{ $sel:connectivityInfo:UpdateConnectivityInfo' :: Maybe [ConnectivityInfo]
connectivityInfo =
forall a. Maybe a
Prelude.Nothing,
$sel:thingName:UpdateConnectivityInfo' :: Text
thingName = Text
pThingName_
}
updateConnectivityInfo_connectivityInfo :: Lens.Lens' UpdateConnectivityInfo (Prelude.Maybe [ConnectivityInfo])
updateConnectivityInfo_connectivityInfo :: Lens' UpdateConnectivityInfo (Maybe [ConnectivityInfo])
updateConnectivityInfo_connectivityInfo = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateConnectivityInfo' {Maybe [ConnectivityInfo]
connectivityInfo :: Maybe [ConnectivityInfo]
$sel:connectivityInfo:UpdateConnectivityInfo' :: UpdateConnectivityInfo -> Maybe [ConnectivityInfo]
connectivityInfo} -> Maybe [ConnectivityInfo]
connectivityInfo) (\s :: UpdateConnectivityInfo
s@UpdateConnectivityInfo' {} Maybe [ConnectivityInfo]
a -> UpdateConnectivityInfo
s {$sel:connectivityInfo:UpdateConnectivityInfo' :: Maybe [ConnectivityInfo]
connectivityInfo = Maybe [ConnectivityInfo]
a} :: UpdateConnectivityInfo) 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
updateConnectivityInfo_thingName :: Lens.Lens' UpdateConnectivityInfo Prelude.Text
updateConnectivityInfo_thingName :: Lens' UpdateConnectivityInfo Text
updateConnectivityInfo_thingName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateConnectivityInfo' {Text
thingName :: Text
$sel:thingName:UpdateConnectivityInfo' :: UpdateConnectivityInfo -> Text
thingName} -> Text
thingName) (\s :: UpdateConnectivityInfo
s@UpdateConnectivityInfo' {} Text
a -> UpdateConnectivityInfo
s {$sel:thingName:UpdateConnectivityInfo' :: Text
thingName = Text
a} :: UpdateConnectivityInfo)
instance Core.AWSRequest UpdateConnectivityInfo where
type
AWSResponse UpdateConnectivityInfo =
UpdateConnectivityInfoResponse
request :: (Service -> Service)
-> UpdateConnectivityInfo -> Request UpdateConnectivityInfo
request Service -> Service
overrides =
forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.putJSON (Service -> Service
overrides Service
defaultService)
response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy UpdateConnectivityInfo
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse UpdateConnectivityInfo)))
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 -> UpdateConnectivityInfoResponse
UpdateConnectivityInfoResponse'
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
"message")
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
"Version")
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 UpdateConnectivityInfo where
hashWithSalt :: Int -> UpdateConnectivityInfo -> Int
hashWithSalt Int
_salt UpdateConnectivityInfo' {Maybe [ConnectivityInfo]
Text
thingName :: Text
connectivityInfo :: Maybe [ConnectivityInfo]
$sel:thingName:UpdateConnectivityInfo' :: UpdateConnectivityInfo -> Text
$sel:connectivityInfo:UpdateConnectivityInfo' :: UpdateConnectivityInfo -> Maybe [ConnectivityInfo]
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [ConnectivityInfo]
connectivityInfo
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
thingName
instance Prelude.NFData UpdateConnectivityInfo where
rnf :: UpdateConnectivityInfo -> ()
rnf UpdateConnectivityInfo' {Maybe [ConnectivityInfo]
Text
thingName :: Text
connectivityInfo :: Maybe [ConnectivityInfo]
$sel:thingName:UpdateConnectivityInfo' :: UpdateConnectivityInfo -> Text
$sel:connectivityInfo:UpdateConnectivityInfo' :: UpdateConnectivityInfo -> Maybe [ConnectivityInfo]
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe [ConnectivityInfo]
connectivityInfo
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
thingName
instance Data.ToHeaders UpdateConnectivityInfo where
toHeaders :: UpdateConnectivityInfo -> 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.ToJSON UpdateConnectivityInfo where
toJSON :: UpdateConnectivityInfo -> Value
toJSON UpdateConnectivityInfo' {Maybe [ConnectivityInfo]
Text
thingName :: Text
connectivityInfo :: Maybe [ConnectivityInfo]
$sel:thingName:UpdateConnectivityInfo' :: UpdateConnectivityInfo -> Text
$sel:connectivityInfo:UpdateConnectivityInfo' :: UpdateConnectivityInfo -> Maybe [ConnectivityInfo]
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Key
"ConnectivityInfo" 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 [ConnectivityInfo]
connectivityInfo
]
)
instance Data.ToPath UpdateConnectivityInfo where
toPath :: UpdateConnectivityInfo -> ByteString
toPath UpdateConnectivityInfo' {Maybe [ConnectivityInfo]
Text
thingName :: Text
connectivityInfo :: Maybe [ConnectivityInfo]
$sel:thingName:UpdateConnectivityInfo' :: UpdateConnectivityInfo -> Text
$sel:connectivityInfo:UpdateConnectivityInfo' :: UpdateConnectivityInfo -> Maybe [ConnectivityInfo]
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ ByteString
"/greengrass/things/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
thingName,
ByteString
"/connectivityInfo"
]
instance Data.ToQuery UpdateConnectivityInfo where
toQuery :: UpdateConnectivityInfo -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data UpdateConnectivityInfoResponse = UpdateConnectivityInfoResponse'
{
UpdateConnectivityInfoResponse -> Maybe Text
message :: Prelude.Maybe Prelude.Text,
UpdateConnectivityInfoResponse -> Maybe Text
version :: Prelude.Maybe Prelude.Text,
UpdateConnectivityInfoResponse -> Int
httpStatus :: Prelude.Int
}
deriving (UpdateConnectivityInfoResponse
-> UpdateConnectivityInfoResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UpdateConnectivityInfoResponse
-> UpdateConnectivityInfoResponse -> Bool
$c/= :: UpdateConnectivityInfoResponse
-> UpdateConnectivityInfoResponse -> Bool
== :: UpdateConnectivityInfoResponse
-> UpdateConnectivityInfoResponse -> Bool
$c== :: UpdateConnectivityInfoResponse
-> UpdateConnectivityInfoResponse -> Bool
Prelude.Eq, ReadPrec [UpdateConnectivityInfoResponse]
ReadPrec UpdateConnectivityInfoResponse
Int -> ReadS UpdateConnectivityInfoResponse
ReadS [UpdateConnectivityInfoResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [UpdateConnectivityInfoResponse]
$creadListPrec :: ReadPrec [UpdateConnectivityInfoResponse]
readPrec :: ReadPrec UpdateConnectivityInfoResponse
$creadPrec :: ReadPrec UpdateConnectivityInfoResponse
readList :: ReadS [UpdateConnectivityInfoResponse]
$creadList :: ReadS [UpdateConnectivityInfoResponse]
readsPrec :: Int -> ReadS UpdateConnectivityInfoResponse
$creadsPrec :: Int -> ReadS UpdateConnectivityInfoResponse
Prelude.Read, Int -> UpdateConnectivityInfoResponse -> ShowS
[UpdateConnectivityInfoResponse] -> ShowS
UpdateConnectivityInfoResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UpdateConnectivityInfoResponse] -> ShowS
$cshowList :: [UpdateConnectivityInfoResponse] -> ShowS
show :: UpdateConnectivityInfoResponse -> String
$cshow :: UpdateConnectivityInfoResponse -> String
showsPrec :: Int -> UpdateConnectivityInfoResponse -> ShowS
$cshowsPrec :: Int -> UpdateConnectivityInfoResponse -> ShowS
Prelude.Show, forall x.
Rep UpdateConnectivityInfoResponse x
-> UpdateConnectivityInfoResponse
forall x.
UpdateConnectivityInfoResponse
-> Rep UpdateConnectivityInfoResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep UpdateConnectivityInfoResponse x
-> UpdateConnectivityInfoResponse
$cfrom :: forall x.
UpdateConnectivityInfoResponse
-> Rep UpdateConnectivityInfoResponse x
Prelude.Generic)
newUpdateConnectivityInfoResponse ::
Prelude.Int ->
UpdateConnectivityInfoResponse
newUpdateConnectivityInfoResponse :: Int -> UpdateConnectivityInfoResponse
newUpdateConnectivityInfoResponse Int
pHttpStatus_ =
UpdateConnectivityInfoResponse'
{ $sel:message:UpdateConnectivityInfoResponse' :: Maybe Text
message =
forall a. Maybe a
Prelude.Nothing,
$sel:version:UpdateConnectivityInfoResponse' :: Maybe Text
version = forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:UpdateConnectivityInfoResponse' :: Int
httpStatus = Int
pHttpStatus_
}
updateConnectivityInfoResponse_message :: Lens.Lens' UpdateConnectivityInfoResponse (Prelude.Maybe Prelude.Text)
updateConnectivityInfoResponse_message :: Lens' UpdateConnectivityInfoResponse (Maybe Text)
updateConnectivityInfoResponse_message = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateConnectivityInfoResponse' {Maybe Text
message :: Maybe Text
$sel:message:UpdateConnectivityInfoResponse' :: UpdateConnectivityInfoResponse -> Maybe Text
message} -> Maybe Text
message) (\s :: UpdateConnectivityInfoResponse
s@UpdateConnectivityInfoResponse' {} Maybe Text
a -> UpdateConnectivityInfoResponse
s {$sel:message:UpdateConnectivityInfoResponse' :: Maybe Text
message = Maybe Text
a} :: UpdateConnectivityInfoResponse)
updateConnectivityInfoResponse_version :: Lens.Lens' UpdateConnectivityInfoResponse (Prelude.Maybe Prelude.Text)
updateConnectivityInfoResponse_version :: Lens' UpdateConnectivityInfoResponse (Maybe Text)
updateConnectivityInfoResponse_version = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateConnectivityInfoResponse' {Maybe Text
version :: Maybe Text
$sel:version:UpdateConnectivityInfoResponse' :: UpdateConnectivityInfoResponse -> Maybe Text
version} -> Maybe Text
version) (\s :: UpdateConnectivityInfoResponse
s@UpdateConnectivityInfoResponse' {} Maybe Text
a -> UpdateConnectivityInfoResponse
s {$sel:version:UpdateConnectivityInfoResponse' :: Maybe Text
version = Maybe Text
a} :: UpdateConnectivityInfoResponse)
updateConnectivityInfoResponse_httpStatus :: Lens.Lens' UpdateConnectivityInfoResponse Prelude.Int
updateConnectivityInfoResponse_httpStatus :: Lens' UpdateConnectivityInfoResponse Int
updateConnectivityInfoResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateConnectivityInfoResponse' {Int
httpStatus :: Int
$sel:httpStatus:UpdateConnectivityInfoResponse' :: UpdateConnectivityInfoResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: UpdateConnectivityInfoResponse
s@UpdateConnectivityInfoResponse' {} Int
a -> UpdateConnectivityInfoResponse
s {$sel:httpStatus:UpdateConnectivityInfoResponse' :: Int
httpStatus = Int
a} :: UpdateConnectivityInfoResponse)
instance
Prelude.NFData
UpdateConnectivityInfoResponse
where
rnf :: UpdateConnectivityInfoResponse -> ()
rnf UpdateConnectivityInfoResponse' {Int
Maybe Text
httpStatus :: Int
version :: Maybe Text
message :: Maybe Text
$sel:httpStatus:UpdateConnectivityInfoResponse' :: UpdateConnectivityInfoResponse -> Int
$sel:version:UpdateConnectivityInfoResponse' :: UpdateConnectivityInfoResponse -> Maybe Text
$sel:message:UpdateConnectivityInfoResponse' :: UpdateConnectivityInfoResponse -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
message
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
version
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus