{-# 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 #-}

-- Derived from AWS service descriptions, licensed under Apache 2.0.

-- |
-- Module      : Amazonka.AlexaBusiness.DisassociateSkillGroupFromRoom
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Disassociates a skill group from a specified room. This disables all
-- skills in the skill group on all devices in the room.
module Amazonka.AlexaBusiness.DisassociateSkillGroupFromRoom
  ( -- * Creating a Request
    DisassociateSkillGroupFromRoom (..),
    newDisassociateSkillGroupFromRoom,

    -- * Request Lenses
    disassociateSkillGroupFromRoom_roomArn,
    disassociateSkillGroupFromRoom_skillGroupArn,

    -- * Destructuring the Response
    DisassociateSkillGroupFromRoomResponse (..),
    newDisassociateSkillGroupFromRoomResponse,

    -- * Response Lenses
    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

-- | /See:/ 'newDisassociateSkillGroupFromRoom' smart constructor.
data DisassociateSkillGroupFromRoom = DisassociateSkillGroupFromRoom'
  { -- | The ARN of the room from which the skill group is to be disassociated.
    -- Required.
    DisassociateSkillGroupFromRoom -> Maybe Text
roomArn :: Prelude.Maybe Prelude.Text,
    -- | The ARN of the skill group to disassociate from a room. Required.
    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)

-- |
-- Create a value of 'DisassociateSkillGroupFromRoom' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'roomArn', 'disassociateSkillGroupFromRoom_roomArn' - The ARN of the room from which the skill group is to be disassociated.
-- Required.
--
-- 'skillGroupArn', 'disassociateSkillGroupFromRoom_skillGroupArn' - The ARN of the skill group to disassociate from a room. Required.
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
    }

-- | The ARN of the room from which the skill group is to be disassociated.
-- Required.
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)

-- | The ARN of the skill group to disassociate from a room. Required.
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

-- | /See:/ 'newDisassociateSkillGroupFromRoomResponse' smart constructor.
data DisassociateSkillGroupFromRoomResponse = DisassociateSkillGroupFromRoomResponse'
  { -- | The response's http status code.
    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)

-- |
-- Create a value of 'DisassociateSkillGroupFromRoomResponse' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'httpStatus', 'disassociateSkillGroupFromRoomResponse_httpStatus' - The response's http status code.
newDisassociateSkillGroupFromRoomResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DisassociateSkillGroupFromRoomResponse
newDisassociateSkillGroupFromRoomResponse :: Int -> DisassociateSkillGroupFromRoomResponse
newDisassociateSkillGroupFromRoomResponse
  Int
pHttpStatus_ =
    DisassociateSkillGroupFromRoomResponse'
      { $sel:httpStatus:DisassociateSkillGroupFromRoomResponse' :: Int
httpStatus =
          Int
pHttpStatus_
      }

-- | The response's http status code.
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