{-# 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.LicenseManagerUserSubscriptions.DeregisterIdentityProvider
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Deregisters the identity provider from providing user-based
-- subscriptions.
module Amazonka.LicenseManagerUserSubscriptions.DeregisterIdentityProvider
  ( -- * Creating a Request
    DeregisterIdentityProvider (..),
    newDeregisterIdentityProvider,

    -- * Request Lenses
    deregisterIdentityProvider_identityProvider,
    deregisterIdentityProvider_product,

    -- * Destructuring the Response
    DeregisterIdentityProviderResponse (..),
    newDeregisterIdentityProviderResponse,

    -- * Response Lenses
    deregisterIdentityProviderResponse_httpStatus,
    deregisterIdentityProviderResponse_identityProviderSummary,
  )
where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.LicenseManagerUserSubscriptions.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response

-- | /See:/ 'newDeregisterIdentityProvider' smart constructor.
data DeregisterIdentityProvider = DeregisterIdentityProvider'
  { -- | An object that specifies details for the identity provider.
    DeregisterIdentityProvider -> IdentityProvider
identityProvider :: IdentityProvider,
    -- | The name of the user-based subscription product.
    DeregisterIdentityProvider -> Text
product :: Prelude.Text
  }
  deriving (DeregisterIdentityProvider -> DeregisterIdentityProvider -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeregisterIdentityProvider -> DeregisterIdentityProvider -> Bool
$c/= :: DeregisterIdentityProvider -> DeregisterIdentityProvider -> Bool
== :: DeregisterIdentityProvider -> DeregisterIdentityProvider -> Bool
$c== :: DeregisterIdentityProvider -> DeregisterIdentityProvider -> Bool
Prelude.Eq, ReadPrec [DeregisterIdentityProvider]
ReadPrec DeregisterIdentityProvider
Int -> ReadS DeregisterIdentityProvider
ReadS [DeregisterIdentityProvider]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeregisterIdentityProvider]
$creadListPrec :: ReadPrec [DeregisterIdentityProvider]
readPrec :: ReadPrec DeregisterIdentityProvider
$creadPrec :: ReadPrec DeregisterIdentityProvider
readList :: ReadS [DeregisterIdentityProvider]
$creadList :: ReadS [DeregisterIdentityProvider]
readsPrec :: Int -> ReadS DeregisterIdentityProvider
$creadsPrec :: Int -> ReadS DeregisterIdentityProvider
Prelude.Read, Int -> DeregisterIdentityProvider -> ShowS
[DeregisterIdentityProvider] -> ShowS
DeregisterIdentityProvider -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeregisterIdentityProvider] -> ShowS
$cshowList :: [DeregisterIdentityProvider] -> ShowS
show :: DeregisterIdentityProvider -> String
$cshow :: DeregisterIdentityProvider -> String
showsPrec :: Int -> DeregisterIdentityProvider -> ShowS
$cshowsPrec :: Int -> DeregisterIdentityProvider -> ShowS
Prelude.Show, forall x.
Rep DeregisterIdentityProvider x -> DeregisterIdentityProvider
forall x.
DeregisterIdentityProvider -> Rep DeregisterIdentityProvider x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DeregisterIdentityProvider x -> DeregisterIdentityProvider
$cfrom :: forall x.
DeregisterIdentityProvider -> Rep DeregisterIdentityProvider x
Prelude.Generic)

-- |
-- Create a value of 'DeregisterIdentityProvider' 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:
--
-- 'identityProvider', 'deregisterIdentityProvider_identityProvider' - An object that specifies details for the identity provider.
--
-- 'product', 'deregisterIdentityProvider_product' - The name of the user-based subscription product.
newDeregisterIdentityProvider ::
  -- | 'identityProvider'
  IdentityProvider ->
  -- | 'product'
  Prelude.Text ->
  DeregisterIdentityProvider
newDeregisterIdentityProvider :: IdentityProvider -> Text -> DeregisterIdentityProvider
newDeregisterIdentityProvider
  IdentityProvider
pIdentityProvider_
  Text
pProduct_ =
    DeregisterIdentityProvider'
      { $sel:identityProvider:DeregisterIdentityProvider' :: IdentityProvider
identityProvider =
          IdentityProvider
pIdentityProvider_,
        $sel:product:DeregisterIdentityProvider' :: Text
product = Text
pProduct_
      }

-- | An object that specifies details for the identity provider.
deregisterIdentityProvider_identityProvider :: Lens.Lens' DeregisterIdentityProvider IdentityProvider
deregisterIdentityProvider_identityProvider :: Lens' DeregisterIdentityProvider IdentityProvider
deregisterIdentityProvider_identityProvider = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeregisterIdentityProvider' {IdentityProvider
identityProvider :: IdentityProvider
$sel:identityProvider:DeregisterIdentityProvider' :: DeregisterIdentityProvider -> IdentityProvider
identityProvider} -> IdentityProvider
identityProvider) (\s :: DeregisterIdentityProvider
s@DeregisterIdentityProvider' {} IdentityProvider
a -> DeregisterIdentityProvider
s {$sel:identityProvider:DeregisterIdentityProvider' :: IdentityProvider
identityProvider = IdentityProvider
a} :: DeregisterIdentityProvider)

-- | The name of the user-based subscription product.
deregisterIdentityProvider_product :: Lens.Lens' DeregisterIdentityProvider Prelude.Text
deregisterIdentityProvider_product :: Lens' DeregisterIdentityProvider Text
deregisterIdentityProvider_product = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeregisterIdentityProvider' {Text
product :: Text
$sel:product:DeregisterIdentityProvider' :: DeregisterIdentityProvider -> Text
product} -> Text
product) (\s :: DeregisterIdentityProvider
s@DeregisterIdentityProvider' {} Text
a -> DeregisterIdentityProvider
s {$sel:product:DeregisterIdentityProvider' :: Text
product = Text
a} :: DeregisterIdentityProvider)

instance Core.AWSRequest DeregisterIdentityProvider where
  type
    AWSResponse DeregisterIdentityProvider =
      DeregisterIdentityProviderResponse
  request :: (Service -> Service)
-> DeregisterIdentityProvider -> Request DeregisterIdentityProvider
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 DeregisterIdentityProvider
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DeregisterIdentityProvider)))
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 ->
          Int
-> IdentityProviderSummary -> DeregisterIdentityProviderResponse
DeregisterIdentityProviderResponse'
            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))
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"IdentityProviderSummary")
      )

instance Prelude.Hashable DeregisterIdentityProvider where
  hashWithSalt :: Int -> DeregisterIdentityProvider -> Int
hashWithSalt Int
_salt DeregisterIdentityProvider' {Text
IdentityProvider
product :: Text
identityProvider :: IdentityProvider
$sel:product:DeregisterIdentityProvider' :: DeregisterIdentityProvider -> Text
$sel:identityProvider:DeregisterIdentityProvider' :: DeregisterIdentityProvider -> IdentityProvider
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` IdentityProvider
identityProvider
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
product

instance Prelude.NFData DeregisterIdentityProvider where
  rnf :: DeregisterIdentityProvider -> ()
rnf DeregisterIdentityProvider' {Text
IdentityProvider
product :: Text
identityProvider :: IdentityProvider
$sel:product:DeregisterIdentityProvider' :: DeregisterIdentityProvider -> Text
$sel:identityProvider:DeregisterIdentityProvider' :: DeregisterIdentityProvider -> IdentityProvider
..} =
    forall a. NFData a => a -> ()
Prelude.rnf IdentityProvider
identityProvider
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
product

instance Data.ToHeaders DeregisterIdentityProvider where
  toHeaders :: DeregisterIdentityProvider -> 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 DeregisterIdentityProvider where
  toJSON :: DeregisterIdentityProvider -> Value
toJSON DeregisterIdentityProvider' {Text
IdentityProvider
product :: Text
identityProvider :: IdentityProvider
$sel:product:DeregisterIdentityProvider' :: DeregisterIdentityProvider -> Text
$sel:identityProvider:DeregisterIdentityProvider' :: DeregisterIdentityProvider -> IdentityProvider
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ forall a. a -> Maybe a
Prelude.Just
              (Key
"IdentityProvider" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= IdentityProvider
identityProvider),
            forall a. a -> Maybe a
Prelude.Just (Key
"Product" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
product)
          ]
      )

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

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

-- | /See:/ 'newDeregisterIdentityProviderResponse' smart constructor.
data DeregisterIdentityProviderResponse = DeregisterIdentityProviderResponse'
  { -- | The response's http status code.
    DeregisterIdentityProviderResponse -> Int
httpStatus :: Prelude.Int,
    -- | Metadata that describes the results of an identity provider operation.
    DeregisterIdentityProviderResponse -> IdentityProviderSummary
identityProviderSummary :: IdentityProviderSummary
  }
  deriving (DeregisterIdentityProviderResponse
-> DeregisterIdentityProviderResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeregisterIdentityProviderResponse
-> DeregisterIdentityProviderResponse -> Bool
$c/= :: DeregisterIdentityProviderResponse
-> DeregisterIdentityProviderResponse -> Bool
== :: DeregisterIdentityProviderResponse
-> DeregisterIdentityProviderResponse -> Bool
$c== :: DeregisterIdentityProviderResponse
-> DeregisterIdentityProviderResponse -> Bool
Prelude.Eq, ReadPrec [DeregisterIdentityProviderResponse]
ReadPrec DeregisterIdentityProviderResponse
Int -> ReadS DeregisterIdentityProviderResponse
ReadS [DeregisterIdentityProviderResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeregisterIdentityProviderResponse]
$creadListPrec :: ReadPrec [DeregisterIdentityProviderResponse]
readPrec :: ReadPrec DeregisterIdentityProviderResponse
$creadPrec :: ReadPrec DeregisterIdentityProviderResponse
readList :: ReadS [DeregisterIdentityProviderResponse]
$creadList :: ReadS [DeregisterIdentityProviderResponse]
readsPrec :: Int -> ReadS DeregisterIdentityProviderResponse
$creadsPrec :: Int -> ReadS DeregisterIdentityProviderResponse
Prelude.Read, Int -> DeregisterIdentityProviderResponse -> ShowS
[DeregisterIdentityProviderResponse] -> ShowS
DeregisterIdentityProviderResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeregisterIdentityProviderResponse] -> ShowS
$cshowList :: [DeregisterIdentityProviderResponse] -> ShowS
show :: DeregisterIdentityProviderResponse -> String
$cshow :: DeregisterIdentityProviderResponse -> String
showsPrec :: Int -> DeregisterIdentityProviderResponse -> ShowS
$cshowsPrec :: Int -> DeregisterIdentityProviderResponse -> ShowS
Prelude.Show, forall x.
Rep DeregisterIdentityProviderResponse x
-> DeregisterIdentityProviderResponse
forall x.
DeregisterIdentityProviderResponse
-> Rep DeregisterIdentityProviderResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DeregisterIdentityProviderResponse x
-> DeregisterIdentityProviderResponse
$cfrom :: forall x.
DeregisterIdentityProviderResponse
-> Rep DeregisterIdentityProviderResponse x
Prelude.Generic)

-- |
-- Create a value of 'DeregisterIdentityProviderResponse' 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', 'deregisterIdentityProviderResponse_httpStatus' - The response's http status code.
--
-- 'identityProviderSummary', 'deregisterIdentityProviderResponse_identityProviderSummary' - Metadata that describes the results of an identity provider operation.
newDeregisterIdentityProviderResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  -- | 'identityProviderSummary'
  IdentityProviderSummary ->
  DeregisterIdentityProviderResponse
newDeregisterIdentityProviderResponse :: Int
-> IdentityProviderSummary -> DeregisterIdentityProviderResponse
newDeregisterIdentityProviderResponse
  Int
pHttpStatus_
  IdentityProviderSummary
pIdentityProviderSummary_ =
    DeregisterIdentityProviderResponse'
      { $sel:httpStatus:DeregisterIdentityProviderResponse' :: Int
httpStatus =
          Int
pHttpStatus_,
        $sel:identityProviderSummary:DeregisterIdentityProviderResponse' :: IdentityProviderSummary
identityProviderSummary =
          IdentityProviderSummary
pIdentityProviderSummary_
      }

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

-- | Metadata that describes the results of an identity provider operation.
deregisterIdentityProviderResponse_identityProviderSummary :: Lens.Lens' DeregisterIdentityProviderResponse IdentityProviderSummary
deregisterIdentityProviderResponse_identityProviderSummary :: Lens' DeregisterIdentityProviderResponse IdentityProviderSummary
deregisterIdentityProviderResponse_identityProviderSummary = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeregisterIdentityProviderResponse' {IdentityProviderSummary
identityProviderSummary :: IdentityProviderSummary
$sel:identityProviderSummary:DeregisterIdentityProviderResponse' :: DeregisterIdentityProviderResponse -> IdentityProviderSummary
identityProviderSummary} -> IdentityProviderSummary
identityProviderSummary) (\s :: DeregisterIdentityProviderResponse
s@DeregisterIdentityProviderResponse' {} IdentityProviderSummary
a -> DeregisterIdentityProviderResponse
s {$sel:identityProviderSummary:DeregisterIdentityProviderResponse' :: IdentityProviderSummary
identityProviderSummary = IdentityProviderSummary
a} :: DeregisterIdentityProviderResponse)

instance
  Prelude.NFData
    DeregisterIdentityProviderResponse
  where
  rnf :: DeregisterIdentityProviderResponse -> ()
rnf DeregisterIdentityProviderResponse' {Int
IdentityProviderSummary
identityProviderSummary :: IdentityProviderSummary
httpStatus :: Int
$sel:identityProviderSummary:DeregisterIdentityProviderResponse' :: DeregisterIdentityProviderResponse -> IdentityProviderSummary
$sel:httpStatus:DeregisterIdentityProviderResponse' :: DeregisterIdentityProviderResponse -> Int
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf IdentityProviderSummary
identityProviderSummary