{-# 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.AlexaBusiness.DisassociateSkillGroupFromRoom
(
DisassociateSkillGroupFromRoom (..),
newDisassociateSkillGroupFromRoom,
disassociateSkillGroupFromRoom_roomArn,
disassociateSkillGroupFromRoom_skillGroupArn,
DisassociateSkillGroupFromRoomResponse (..),
newDisassociateSkillGroupFromRoomResponse,
disassociateSkillGroupFromRoomResponse_httpStatus,
)
where
import Amazonka.AlexaBusiness.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 DisassociateSkillGroupFromRoom = DisassociateSkillGroupFromRoom'
{
DisassociateSkillGroupFromRoom -> Maybe Text
roomArn :: Prelude.Maybe Prelude.Text,
DisassociateSkillGroupFromRoom -> Maybe Text
skillGroupArn :: Prelude.Maybe Prelude.Text
}
deriving (DisassociateSkillGroupFromRoom
-> DisassociateSkillGroupFromRoom -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DisassociateSkillGroupFromRoom
-> DisassociateSkillGroupFromRoom -> Bool
$c/= :: DisassociateSkillGroupFromRoom
-> DisassociateSkillGroupFromRoom -> Bool
== :: DisassociateSkillGroupFromRoom
-> DisassociateSkillGroupFromRoom -> Bool
$c== :: DisassociateSkillGroupFromRoom
-> DisassociateSkillGroupFromRoom -> Bool
Prelude.Eq, ReadPrec [DisassociateSkillGroupFromRoom]
ReadPrec DisassociateSkillGroupFromRoom
Int -> ReadS DisassociateSkillGroupFromRoom
ReadS [DisassociateSkillGroupFromRoom]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DisassociateSkillGroupFromRoom]
$creadListPrec :: ReadPrec [DisassociateSkillGroupFromRoom]
readPrec :: ReadPrec DisassociateSkillGroupFromRoom
$creadPrec :: ReadPrec DisassociateSkillGroupFromRoom
readList :: ReadS [DisassociateSkillGroupFromRoom]
$creadList :: ReadS [DisassociateSkillGroupFromRoom]
readsPrec :: Int -> ReadS DisassociateSkillGroupFromRoom
$creadsPrec :: Int -> ReadS DisassociateSkillGroupFromRoom
Prelude.Read, Int -> DisassociateSkillGroupFromRoom -> ShowS
[DisassociateSkillGroupFromRoom] -> ShowS
DisassociateSkillGroupFromRoom -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DisassociateSkillGroupFromRoom] -> ShowS
$cshowList :: [DisassociateSkillGroupFromRoom] -> ShowS
show :: DisassociateSkillGroupFromRoom -> String
$cshow :: DisassociateSkillGroupFromRoom -> String
showsPrec :: Int -> DisassociateSkillGroupFromRoom -> ShowS
$cshowsPrec :: Int -> DisassociateSkillGroupFromRoom -> ShowS
Prelude.Show, forall x.
Rep DisassociateSkillGroupFromRoom x
-> DisassociateSkillGroupFromRoom
forall x.
DisassociateSkillGroupFromRoom
-> Rep DisassociateSkillGroupFromRoom x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DisassociateSkillGroupFromRoom x
-> DisassociateSkillGroupFromRoom
$cfrom :: forall x.
DisassociateSkillGroupFromRoom
-> Rep DisassociateSkillGroupFromRoom x
Prelude.Generic)
newDisassociateSkillGroupFromRoom ::
DisassociateSkillGroupFromRoom
newDisassociateSkillGroupFromRoom :: DisassociateSkillGroupFromRoom
newDisassociateSkillGroupFromRoom =
DisassociateSkillGroupFromRoom'
{ $sel:roomArn:DisassociateSkillGroupFromRoom' :: Maybe Text
roomArn =
forall a. Maybe a
Prelude.Nothing,
$sel:skillGroupArn:DisassociateSkillGroupFromRoom' :: Maybe Text
skillGroupArn = forall a. Maybe a
Prelude.Nothing
}
disassociateSkillGroupFromRoom_roomArn :: Lens.Lens' DisassociateSkillGroupFromRoom (Prelude.Maybe Prelude.Text)
disassociateSkillGroupFromRoom_roomArn :: Lens' DisassociateSkillGroupFromRoom (Maybe Text)
disassociateSkillGroupFromRoom_roomArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DisassociateSkillGroupFromRoom' {Maybe Text
roomArn :: Maybe Text
$sel:roomArn:DisassociateSkillGroupFromRoom' :: DisassociateSkillGroupFromRoom -> Maybe Text
roomArn} -> Maybe Text
roomArn) (\s :: DisassociateSkillGroupFromRoom
s@DisassociateSkillGroupFromRoom' {} Maybe Text
a -> DisassociateSkillGroupFromRoom
s {$sel:roomArn:DisassociateSkillGroupFromRoom' :: Maybe Text
roomArn = Maybe Text
a} :: DisassociateSkillGroupFromRoom)
disassociateSkillGroupFromRoom_skillGroupArn :: Lens.Lens' DisassociateSkillGroupFromRoom (Prelude.Maybe Prelude.Text)
disassociateSkillGroupFromRoom_skillGroupArn :: Lens' DisassociateSkillGroupFromRoom (Maybe Text)
disassociateSkillGroupFromRoom_skillGroupArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DisassociateSkillGroupFromRoom' {Maybe Text
skillGroupArn :: Maybe Text
$sel:skillGroupArn:DisassociateSkillGroupFromRoom' :: DisassociateSkillGroupFromRoom -> Maybe Text
skillGroupArn} -> Maybe Text
skillGroupArn) (\s :: DisassociateSkillGroupFromRoom
s@DisassociateSkillGroupFromRoom' {} Maybe Text
a -> DisassociateSkillGroupFromRoom
s {$sel:skillGroupArn:DisassociateSkillGroupFromRoom' :: Maybe Text
skillGroupArn = Maybe Text
a} :: DisassociateSkillGroupFromRoom)
instance
Core.AWSRequest
DisassociateSkillGroupFromRoom
where
type
AWSResponse DisassociateSkillGroupFromRoom =
DisassociateSkillGroupFromRoomResponse
request :: (Service -> Service)
-> DisassociateSkillGroupFromRoom
-> Request DisassociateSkillGroupFromRoom
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 DisassociateSkillGroupFromRoom
-> ClientResponse ClientBody
-> m (Either
Error
(ClientResponse (AWSResponse DisassociateSkillGroupFromRoom)))
response =
forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> () -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveEmpty
( \Int
s ResponseHeaders
h ()
x ->
Int -> DisassociateSkillGroupFromRoomResponse
DisassociateSkillGroupFromRoomResponse'
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))
)
instance
Prelude.Hashable
DisassociateSkillGroupFromRoom
where
hashWithSalt :: Int -> DisassociateSkillGroupFromRoom -> Int
hashWithSalt
Int
_salt
DisassociateSkillGroupFromRoom' {Maybe Text
skillGroupArn :: Maybe Text
roomArn :: Maybe Text
$sel:skillGroupArn:DisassociateSkillGroupFromRoom' :: DisassociateSkillGroupFromRoom -> Maybe Text
$sel:roomArn:DisassociateSkillGroupFromRoom' :: DisassociateSkillGroupFromRoom -> Maybe Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
roomArn
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
skillGroupArn
instance
Prelude.NFData
DisassociateSkillGroupFromRoom
where
rnf :: DisassociateSkillGroupFromRoom -> ()
rnf DisassociateSkillGroupFromRoom' {Maybe Text
skillGroupArn :: Maybe Text
roomArn :: Maybe Text
$sel:skillGroupArn:DisassociateSkillGroupFromRoom' :: DisassociateSkillGroupFromRoom -> Maybe Text
$sel:roomArn:DisassociateSkillGroupFromRoom' :: DisassociateSkillGroupFromRoom -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
roomArn
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
skillGroupArn
instance
Data.ToHeaders
DisassociateSkillGroupFromRoom
where
toHeaders :: DisassociateSkillGroupFromRoom -> 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
"AlexaForBusiness.DisassociateSkillGroupFromRoom" ::
Prelude.ByteString
),
HeaderName
"Content-Type"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
Prelude.ByteString
)
]
)
instance Data.ToJSON DisassociateSkillGroupFromRoom where
toJSON :: DisassociateSkillGroupFromRoom -> Value
toJSON DisassociateSkillGroupFromRoom' {Maybe Text
skillGroupArn :: Maybe Text
roomArn :: Maybe Text
$sel:skillGroupArn:DisassociateSkillGroupFromRoom' :: DisassociateSkillGroupFromRoom -> Maybe Text
$sel:roomArn:DisassociateSkillGroupFromRoom' :: DisassociateSkillGroupFromRoom -> Maybe Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Key
"RoomArn" 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
roomArn,
(Key
"SkillGroupArn" 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
skillGroupArn
]
)
instance Data.ToPath DisassociateSkillGroupFromRoom where
toPath :: DisassociateSkillGroupFromRoom -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery DisassociateSkillGroupFromRoom where
toQuery :: DisassociateSkillGroupFromRoom -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DisassociateSkillGroupFromRoomResponse = DisassociateSkillGroupFromRoomResponse'
{
DisassociateSkillGroupFromRoomResponse -> Int
httpStatus :: Prelude.Int
}
deriving (DisassociateSkillGroupFromRoomResponse
-> DisassociateSkillGroupFromRoomResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DisassociateSkillGroupFromRoomResponse
-> DisassociateSkillGroupFromRoomResponse -> Bool
$c/= :: DisassociateSkillGroupFromRoomResponse
-> DisassociateSkillGroupFromRoomResponse -> Bool
== :: DisassociateSkillGroupFromRoomResponse
-> DisassociateSkillGroupFromRoomResponse -> Bool
$c== :: DisassociateSkillGroupFromRoomResponse
-> DisassociateSkillGroupFromRoomResponse -> Bool
Prelude.Eq, ReadPrec [DisassociateSkillGroupFromRoomResponse]
ReadPrec DisassociateSkillGroupFromRoomResponse
Int -> ReadS DisassociateSkillGroupFromRoomResponse
ReadS [DisassociateSkillGroupFromRoomResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DisassociateSkillGroupFromRoomResponse]
$creadListPrec :: ReadPrec [DisassociateSkillGroupFromRoomResponse]
readPrec :: ReadPrec DisassociateSkillGroupFromRoomResponse
$creadPrec :: ReadPrec DisassociateSkillGroupFromRoomResponse
readList :: ReadS [DisassociateSkillGroupFromRoomResponse]
$creadList :: ReadS [DisassociateSkillGroupFromRoomResponse]
readsPrec :: Int -> ReadS DisassociateSkillGroupFromRoomResponse
$creadsPrec :: Int -> ReadS DisassociateSkillGroupFromRoomResponse
Prelude.Read, Int -> DisassociateSkillGroupFromRoomResponse -> ShowS
[DisassociateSkillGroupFromRoomResponse] -> ShowS
DisassociateSkillGroupFromRoomResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DisassociateSkillGroupFromRoomResponse] -> ShowS
$cshowList :: [DisassociateSkillGroupFromRoomResponse] -> ShowS
show :: DisassociateSkillGroupFromRoomResponse -> String
$cshow :: DisassociateSkillGroupFromRoomResponse -> String
showsPrec :: Int -> DisassociateSkillGroupFromRoomResponse -> ShowS
$cshowsPrec :: Int -> DisassociateSkillGroupFromRoomResponse -> ShowS
Prelude.Show, forall x.
Rep DisassociateSkillGroupFromRoomResponse x
-> DisassociateSkillGroupFromRoomResponse
forall x.
DisassociateSkillGroupFromRoomResponse
-> Rep DisassociateSkillGroupFromRoomResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DisassociateSkillGroupFromRoomResponse x
-> DisassociateSkillGroupFromRoomResponse
$cfrom :: forall x.
DisassociateSkillGroupFromRoomResponse
-> Rep DisassociateSkillGroupFromRoomResponse x
Prelude.Generic)
newDisassociateSkillGroupFromRoomResponse ::
Prelude.Int ->
DisassociateSkillGroupFromRoomResponse
newDisassociateSkillGroupFromRoomResponse :: Int -> DisassociateSkillGroupFromRoomResponse
newDisassociateSkillGroupFromRoomResponse
Int
pHttpStatus_ =
DisassociateSkillGroupFromRoomResponse'
{ $sel:httpStatus:DisassociateSkillGroupFromRoomResponse' :: Int
httpStatus =
Int
pHttpStatus_
}
disassociateSkillGroupFromRoomResponse_httpStatus :: Lens.Lens' DisassociateSkillGroupFromRoomResponse Prelude.Int
disassociateSkillGroupFromRoomResponse_httpStatus :: Lens' DisassociateSkillGroupFromRoomResponse Int
disassociateSkillGroupFromRoomResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DisassociateSkillGroupFromRoomResponse' {Int
httpStatus :: Int
$sel:httpStatus:DisassociateSkillGroupFromRoomResponse' :: DisassociateSkillGroupFromRoomResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DisassociateSkillGroupFromRoomResponse
s@DisassociateSkillGroupFromRoomResponse' {} Int
a -> DisassociateSkillGroupFromRoomResponse
s {$sel:httpStatus:DisassociateSkillGroupFromRoomResponse' :: Int
httpStatus = Int
a} :: DisassociateSkillGroupFromRoomResponse)
instance
Prelude.NFData
DisassociateSkillGroupFromRoomResponse
where
rnf :: DisassociateSkillGroupFromRoomResponse -> ()
rnf DisassociateSkillGroupFromRoomResponse' {Int
httpStatus :: Int
$sel:httpStatus:DisassociateSkillGroupFromRoomResponse' :: DisassociateSkillGroupFromRoomResponse -> Int
..} =
forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus