{-# 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.WorkSpaces.DisassociateIpGroups
-- 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 the specified IP access control group from the specified
-- directory.
module Amazonka.WorkSpaces.DisassociateIpGroups
  ( -- * Creating a Request
    DisassociateIpGroups (..),
    newDisassociateIpGroups,

    -- * Request Lenses
    disassociateIpGroups_directoryId,
    disassociateIpGroups_groupIds,

    -- * Destructuring the Response
    DisassociateIpGroupsResponse (..),
    newDisassociateIpGroupsResponse,

    -- * Response Lenses
    disassociateIpGroupsResponse_httpStatus,
  )
where

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
import Amazonka.WorkSpaces.Types

-- | /See:/ 'newDisassociateIpGroups' smart constructor.
data DisassociateIpGroups = DisassociateIpGroups'
  { -- | The identifier of the directory.
    DisassociateIpGroups -> Text
directoryId :: Prelude.Text,
    -- | The identifiers of one or more IP access control groups.
    DisassociateIpGroups -> [Text]
groupIds :: [Prelude.Text]
  }
  deriving (DisassociateIpGroups -> DisassociateIpGroups -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DisassociateIpGroups -> DisassociateIpGroups -> Bool
$c/= :: DisassociateIpGroups -> DisassociateIpGroups -> Bool
== :: DisassociateIpGroups -> DisassociateIpGroups -> Bool
$c== :: DisassociateIpGroups -> DisassociateIpGroups -> Bool
Prelude.Eq, ReadPrec [DisassociateIpGroups]
ReadPrec DisassociateIpGroups
Int -> ReadS DisassociateIpGroups
ReadS [DisassociateIpGroups]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DisassociateIpGroups]
$creadListPrec :: ReadPrec [DisassociateIpGroups]
readPrec :: ReadPrec DisassociateIpGroups
$creadPrec :: ReadPrec DisassociateIpGroups
readList :: ReadS [DisassociateIpGroups]
$creadList :: ReadS [DisassociateIpGroups]
readsPrec :: Int -> ReadS DisassociateIpGroups
$creadsPrec :: Int -> ReadS DisassociateIpGroups
Prelude.Read, Int -> DisassociateIpGroups -> ShowS
[DisassociateIpGroups] -> ShowS
DisassociateIpGroups -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DisassociateIpGroups] -> ShowS
$cshowList :: [DisassociateIpGroups] -> ShowS
show :: DisassociateIpGroups -> String
$cshow :: DisassociateIpGroups -> String
showsPrec :: Int -> DisassociateIpGroups -> ShowS
$cshowsPrec :: Int -> DisassociateIpGroups -> ShowS
Prelude.Show, forall x. Rep DisassociateIpGroups x -> DisassociateIpGroups
forall x. DisassociateIpGroups -> Rep DisassociateIpGroups x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DisassociateIpGroups x -> DisassociateIpGroups
$cfrom :: forall x. DisassociateIpGroups -> Rep DisassociateIpGroups x
Prelude.Generic)

-- |
-- Create a value of 'DisassociateIpGroups' 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:
--
-- 'directoryId', 'disassociateIpGroups_directoryId' - The identifier of the directory.
--
-- 'groupIds', 'disassociateIpGroups_groupIds' - The identifiers of one or more IP access control groups.
newDisassociateIpGroups ::
  -- | 'directoryId'
  Prelude.Text ->
  DisassociateIpGroups
newDisassociateIpGroups :: Text -> DisassociateIpGroups
newDisassociateIpGroups Text
pDirectoryId_ =
  DisassociateIpGroups'
    { $sel:directoryId:DisassociateIpGroups' :: Text
directoryId = Text
pDirectoryId_,
      $sel:groupIds:DisassociateIpGroups' :: [Text]
groupIds = forall a. Monoid a => a
Prelude.mempty
    }

-- | The identifier of the directory.
disassociateIpGroups_directoryId :: Lens.Lens' DisassociateIpGroups Prelude.Text
disassociateIpGroups_directoryId :: Lens' DisassociateIpGroups Text
disassociateIpGroups_directoryId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DisassociateIpGroups' {Text
directoryId :: Text
$sel:directoryId:DisassociateIpGroups' :: DisassociateIpGroups -> Text
directoryId} -> Text
directoryId) (\s :: DisassociateIpGroups
s@DisassociateIpGroups' {} Text
a -> DisassociateIpGroups
s {$sel:directoryId:DisassociateIpGroups' :: Text
directoryId = Text
a} :: DisassociateIpGroups)

-- | The identifiers of one or more IP access control groups.
disassociateIpGroups_groupIds :: Lens.Lens' DisassociateIpGroups [Prelude.Text]
disassociateIpGroups_groupIds :: Lens' DisassociateIpGroups [Text]
disassociateIpGroups_groupIds = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DisassociateIpGroups' {[Text]
groupIds :: [Text]
$sel:groupIds:DisassociateIpGroups' :: DisassociateIpGroups -> [Text]
groupIds} -> [Text]
groupIds) (\s :: DisassociateIpGroups
s@DisassociateIpGroups' {} [Text]
a -> DisassociateIpGroups
s {$sel:groupIds:DisassociateIpGroups' :: [Text]
groupIds = [Text]
a} :: DisassociateIpGroups) 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

instance Core.AWSRequest DisassociateIpGroups where
  type
    AWSResponse DisassociateIpGroups =
      DisassociateIpGroupsResponse
  request :: (Service -> Service)
-> DisassociateIpGroups -> Request DisassociateIpGroups
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 DisassociateIpGroups
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DisassociateIpGroups)))
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 -> DisassociateIpGroupsResponse
DisassociateIpGroupsResponse'
            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 DisassociateIpGroups where
  hashWithSalt :: Int -> DisassociateIpGroups -> Int
hashWithSalt Int
_salt DisassociateIpGroups' {[Text]
Text
groupIds :: [Text]
directoryId :: Text
$sel:groupIds:DisassociateIpGroups' :: DisassociateIpGroups -> [Text]
$sel:directoryId:DisassociateIpGroups' :: DisassociateIpGroups -> Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
directoryId
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` [Text]
groupIds

instance Prelude.NFData DisassociateIpGroups where
  rnf :: DisassociateIpGroups -> ()
rnf DisassociateIpGroups' {[Text]
Text
groupIds :: [Text]
directoryId :: Text
$sel:groupIds:DisassociateIpGroups' :: DisassociateIpGroups -> [Text]
$sel:directoryId:DisassociateIpGroups' :: DisassociateIpGroups -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
directoryId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf [Text]
groupIds

instance Data.ToHeaders DisassociateIpGroups where
  toHeaders :: DisassociateIpGroups -> 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
"WorkspacesService.DisassociateIpGroups" ::
                          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 DisassociateIpGroups where
  toJSON :: DisassociateIpGroups -> Value
toJSON DisassociateIpGroups' {[Text]
Text
groupIds :: [Text]
directoryId :: Text
$sel:groupIds:DisassociateIpGroups' :: DisassociateIpGroups -> [Text]
$sel:directoryId:DisassociateIpGroups' :: DisassociateIpGroups -> Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ forall a. a -> Maybe a
Prelude.Just (Key
"DirectoryId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
directoryId),
            forall a. a -> Maybe a
Prelude.Just (Key
"GroupIds" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= [Text]
groupIds)
          ]
      )

instance Data.ToPath DisassociateIpGroups where
  toPath :: DisassociateIpGroups -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

instance Data.ToQuery DisassociateIpGroups where
  toQuery :: DisassociateIpGroups -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

-- | /See:/ 'newDisassociateIpGroupsResponse' smart constructor.
data DisassociateIpGroupsResponse = DisassociateIpGroupsResponse'
  { -- | The response's http status code.
    DisassociateIpGroupsResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DisassociateIpGroupsResponse
-> DisassociateIpGroupsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DisassociateIpGroupsResponse
-> DisassociateIpGroupsResponse -> Bool
$c/= :: DisassociateIpGroupsResponse
-> DisassociateIpGroupsResponse -> Bool
== :: DisassociateIpGroupsResponse
-> DisassociateIpGroupsResponse -> Bool
$c== :: DisassociateIpGroupsResponse
-> DisassociateIpGroupsResponse -> Bool
Prelude.Eq, ReadPrec [DisassociateIpGroupsResponse]
ReadPrec DisassociateIpGroupsResponse
Int -> ReadS DisassociateIpGroupsResponse
ReadS [DisassociateIpGroupsResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DisassociateIpGroupsResponse]
$creadListPrec :: ReadPrec [DisassociateIpGroupsResponse]
readPrec :: ReadPrec DisassociateIpGroupsResponse
$creadPrec :: ReadPrec DisassociateIpGroupsResponse
readList :: ReadS [DisassociateIpGroupsResponse]
$creadList :: ReadS [DisassociateIpGroupsResponse]
readsPrec :: Int -> ReadS DisassociateIpGroupsResponse
$creadsPrec :: Int -> ReadS DisassociateIpGroupsResponse
Prelude.Read, Int -> DisassociateIpGroupsResponse -> ShowS
[DisassociateIpGroupsResponse] -> ShowS
DisassociateIpGroupsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DisassociateIpGroupsResponse] -> ShowS
$cshowList :: [DisassociateIpGroupsResponse] -> ShowS
show :: DisassociateIpGroupsResponse -> String
$cshow :: DisassociateIpGroupsResponse -> String
showsPrec :: Int -> DisassociateIpGroupsResponse -> ShowS
$cshowsPrec :: Int -> DisassociateIpGroupsResponse -> ShowS
Prelude.Show, forall x.
Rep DisassociateIpGroupsResponse x -> DisassociateIpGroupsResponse
forall x.
DisassociateIpGroupsResponse -> Rep DisassociateIpGroupsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DisassociateIpGroupsResponse x -> DisassociateIpGroupsResponse
$cfrom :: forall x.
DisassociateIpGroupsResponse -> Rep DisassociateIpGroupsResponse x
Prelude.Generic)

-- |
-- Create a value of 'DisassociateIpGroupsResponse' 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', 'disassociateIpGroupsResponse_httpStatus' - The response's http status code.
newDisassociateIpGroupsResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DisassociateIpGroupsResponse
newDisassociateIpGroupsResponse :: Int -> DisassociateIpGroupsResponse
newDisassociateIpGroupsResponse Int
pHttpStatus_ =
  DisassociateIpGroupsResponse'
    { $sel:httpStatus:DisassociateIpGroupsResponse' :: Int
httpStatus =
        Int
pHttpStatus_
    }

-- | The response's http status code.
disassociateIpGroupsResponse_httpStatus :: Lens.Lens' DisassociateIpGroupsResponse Prelude.Int
disassociateIpGroupsResponse_httpStatus :: Lens' DisassociateIpGroupsResponse Int
disassociateIpGroupsResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DisassociateIpGroupsResponse' {Int
httpStatus :: Int
$sel:httpStatus:DisassociateIpGroupsResponse' :: DisassociateIpGroupsResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DisassociateIpGroupsResponse
s@DisassociateIpGroupsResponse' {} Int
a -> DisassociateIpGroupsResponse
s {$sel:httpStatus:DisassociateIpGroupsResponse' :: Int
httpStatus = Int
a} :: DisassociateIpGroupsResponse)

instance Prelude.NFData DisassociateIpGroupsResponse where
  rnf :: DisassociateIpGroupsResponse -> ()
rnf DisassociateIpGroupsResponse' {Int
httpStatus :: Int
$sel:httpStatus:DisassociateIpGroupsResponse' :: DisassociateIpGroupsResponse -> Int
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus