{-# 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.VoiceId.DescribeSpeaker
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Describes the specified speaker.
module Amazonka.VoiceId.DescribeSpeaker
  ( -- * Creating a Request
    DescribeSpeaker (..),
    newDescribeSpeaker,

    -- * Request Lenses
    describeSpeaker_domainId,
    describeSpeaker_speakerId,

    -- * Destructuring the Response
    DescribeSpeakerResponse (..),
    newDescribeSpeakerResponse,

    -- * Response Lenses
    describeSpeakerResponse_speaker,
    describeSpeakerResponse_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.VoiceId.Types

-- | /See:/ 'newDescribeSpeaker' smart constructor.
data DescribeSpeaker = DescribeSpeaker'
  { -- | The identifier of the domain that contains the speaker.
    DescribeSpeaker -> Text
domainId :: Prelude.Text,
    -- | The identifier of the speaker you are describing.
    DescribeSpeaker -> Sensitive Text
speakerId :: Data.Sensitive Prelude.Text
  }
  deriving (DescribeSpeaker -> DescribeSpeaker -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeSpeaker -> DescribeSpeaker -> Bool
$c/= :: DescribeSpeaker -> DescribeSpeaker -> Bool
== :: DescribeSpeaker -> DescribeSpeaker -> Bool
$c== :: DescribeSpeaker -> DescribeSpeaker -> Bool
Prelude.Eq, Int -> DescribeSpeaker -> ShowS
[DescribeSpeaker] -> ShowS
DescribeSpeaker -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeSpeaker] -> ShowS
$cshowList :: [DescribeSpeaker] -> ShowS
show :: DescribeSpeaker -> String
$cshow :: DescribeSpeaker -> String
showsPrec :: Int -> DescribeSpeaker -> ShowS
$cshowsPrec :: Int -> DescribeSpeaker -> ShowS
Prelude.Show, forall x. Rep DescribeSpeaker x -> DescribeSpeaker
forall x. DescribeSpeaker -> Rep DescribeSpeaker x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeSpeaker x -> DescribeSpeaker
$cfrom :: forall x. DescribeSpeaker -> Rep DescribeSpeaker x
Prelude.Generic)

-- |
-- Create a value of 'DescribeSpeaker' 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:
--
-- 'domainId', 'describeSpeaker_domainId' - The identifier of the domain that contains the speaker.
--
-- 'speakerId', 'describeSpeaker_speakerId' - The identifier of the speaker you are describing.
newDescribeSpeaker ::
  -- | 'domainId'
  Prelude.Text ->
  -- | 'speakerId'
  Prelude.Text ->
  DescribeSpeaker
newDescribeSpeaker :: Text -> Text -> DescribeSpeaker
newDescribeSpeaker Text
pDomainId_ Text
pSpeakerId_ =
  DescribeSpeaker'
    { $sel:domainId:DescribeSpeaker' :: Text
domainId = Text
pDomainId_,
      $sel:speakerId:DescribeSpeaker' :: Sensitive Text
speakerId = forall a. Iso' (Sensitive a) a
Data._Sensitive forall t b. AReview t b -> b -> t
Lens.# Text
pSpeakerId_
    }

-- | The identifier of the domain that contains the speaker.
describeSpeaker_domainId :: Lens.Lens' DescribeSpeaker Prelude.Text
describeSpeaker_domainId :: Lens' DescribeSpeaker Text
describeSpeaker_domainId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeSpeaker' {Text
domainId :: Text
$sel:domainId:DescribeSpeaker' :: DescribeSpeaker -> Text
domainId} -> Text
domainId) (\s :: DescribeSpeaker
s@DescribeSpeaker' {} Text
a -> DescribeSpeaker
s {$sel:domainId:DescribeSpeaker' :: Text
domainId = Text
a} :: DescribeSpeaker)

-- | The identifier of the speaker you are describing.
describeSpeaker_speakerId :: Lens.Lens' DescribeSpeaker Prelude.Text
describeSpeaker_speakerId :: Lens' DescribeSpeaker Text
describeSpeaker_speakerId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeSpeaker' {Sensitive Text
speakerId :: Sensitive Text
$sel:speakerId:DescribeSpeaker' :: DescribeSpeaker -> Sensitive Text
speakerId} -> Sensitive Text
speakerId) (\s :: DescribeSpeaker
s@DescribeSpeaker' {} Sensitive Text
a -> DescribeSpeaker
s {$sel:speakerId:DescribeSpeaker' :: Sensitive Text
speakerId = Sensitive Text
a} :: DescribeSpeaker) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a. Iso' (Sensitive a) a
Data._Sensitive

instance Core.AWSRequest DescribeSpeaker where
  type
    AWSResponse DescribeSpeaker =
      DescribeSpeakerResponse
  request :: (Service -> Service) -> DescribeSpeaker -> Request DescribeSpeaker
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 DescribeSpeaker
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DescribeSpeaker)))
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 Speaker -> Int -> DescribeSpeakerResponse
DescribeSpeakerResponse'
            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
"Speaker")
            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 DescribeSpeaker where
  hashWithSalt :: Int -> DescribeSpeaker -> Int
hashWithSalt Int
_salt DescribeSpeaker' {Text
Sensitive Text
speakerId :: Sensitive Text
domainId :: Text
$sel:speakerId:DescribeSpeaker' :: DescribeSpeaker -> Sensitive Text
$sel:domainId:DescribeSpeaker' :: DescribeSpeaker -> Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
domainId
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Sensitive Text
speakerId

instance Prelude.NFData DescribeSpeaker where
  rnf :: DescribeSpeaker -> ()
rnf DescribeSpeaker' {Text
Sensitive Text
speakerId :: Sensitive Text
domainId :: Text
$sel:speakerId:DescribeSpeaker' :: DescribeSpeaker -> Sensitive Text
$sel:domainId:DescribeSpeaker' :: DescribeSpeaker -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
domainId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Sensitive Text
speakerId

instance Data.ToHeaders DescribeSpeaker where
  toHeaders :: DescribeSpeaker -> 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
"VoiceID.DescribeSpeaker" :: Prelude.ByteString),
            HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.0" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToJSON DescribeSpeaker where
  toJSON :: DescribeSpeaker -> Value
toJSON DescribeSpeaker' {Text
Sensitive Text
speakerId :: Sensitive Text
domainId :: Text
$sel:speakerId:DescribeSpeaker' :: DescribeSpeaker -> Sensitive Text
$sel:domainId:DescribeSpeaker' :: DescribeSpeaker -> Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ forall a. a -> Maybe a
Prelude.Just (Key
"DomainId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
domainId),
            forall a. a -> Maybe a
Prelude.Just (Key
"SpeakerId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Sensitive Text
speakerId)
          ]
      )

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

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

-- | /See:/ 'newDescribeSpeakerResponse' smart constructor.
data DescribeSpeakerResponse = DescribeSpeakerResponse'
  { -- | Information about the specified speaker.
    DescribeSpeakerResponse -> Maybe Speaker
speaker :: Prelude.Maybe Speaker,
    -- | The response's http status code.
    DescribeSpeakerResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DescribeSpeakerResponse -> DescribeSpeakerResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeSpeakerResponse -> DescribeSpeakerResponse -> Bool
$c/= :: DescribeSpeakerResponse -> DescribeSpeakerResponse -> Bool
== :: DescribeSpeakerResponse -> DescribeSpeakerResponse -> Bool
$c== :: DescribeSpeakerResponse -> DescribeSpeakerResponse -> Bool
Prelude.Eq, Int -> DescribeSpeakerResponse -> ShowS
[DescribeSpeakerResponse] -> ShowS
DescribeSpeakerResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeSpeakerResponse] -> ShowS
$cshowList :: [DescribeSpeakerResponse] -> ShowS
show :: DescribeSpeakerResponse -> String
$cshow :: DescribeSpeakerResponse -> String
showsPrec :: Int -> DescribeSpeakerResponse -> ShowS
$cshowsPrec :: Int -> DescribeSpeakerResponse -> ShowS
Prelude.Show, forall x. Rep DescribeSpeakerResponse x -> DescribeSpeakerResponse
forall x. DescribeSpeakerResponse -> Rep DescribeSpeakerResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeSpeakerResponse x -> DescribeSpeakerResponse
$cfrom :: forall x. DescribeSpeakerResponse -> Rep DescribeSpeakerResponse x
Prelude.Generic)

-- |
-- Create a value of 'DescribeSpeakerResponse' 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:
--
-- 'speaker', 'describeSpeakerResponse_speaker' - Information about the specified speaker.
--
-- 'httpStatus', 'describeSpeakerResponse_httpStatus' - The response's http status code.
newDescribeSpeakerResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DescribeSpeakerResponse
newDescribeSpeakerResponse :: Int -> DescribeSpeakerResponse
newDescribeSpeakerResponse Int
pHttpStatus_ =
  DescribeSpeakerResponse'
    { $sel:speaker:DescribeSpeakerResponse' :: Maybe Speaker
speaker = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DescribeSpeakerResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | Information about the specified speaker.
describeSpeakerResponse_speaker :: Lens.Lens' DescribeSpeakerResponse (Prelude.Maybe Speaker)
describeSpeakerResponse_speaker :: Lens' DescribeSpeakerResponse (Maybe Speaker)
describeSpeakerResponse_speaker = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeSpeakerResponse' {Maybe Speaker
speaker :: Maybe Speaker
$sel:speaker:DescribeSpeakerResponse' :: DescribeSpeakerResponse -> Maybe Speaker
speaker} -> Maybe Speaker
speaker) (\s :: DescribeSpeakerResponse
s@DescribeSpeakerResponse' {} Maybe Speaker
a -> DescribeSpeakerResponse
s {$sel:speaker:DescribeSpeakerResponse' :: Maybe Speaker
speaker = Maybe Speaker
a} :: DescribeSpeakerResponse)

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

instance Prelude.NFData DescribeSpeakerResponse where
  rnf :: DescribeSpeakerResponse -> ()
rnf DescribeSpeakerResponse' {Int
Maybe Speaker
httpStatus :: Int
speaker :: Maybe Speaker
$sel:httpStatus:DescribeSpeakerResponse' :: DescribeSpeakerResponse -> Int
$sel:speaker:DescribeSpeakerResponse' :: DescribeSpeakerResponse -> Maybe Speaker
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Speaker
speaker
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus