{-# 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.QuickSight.DescribeThemeAlias
-- 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 alias for a theme.
module Amazonka.QuickSight.DescribeThemeAlias
  ( -- * Creating a Request
    DescribeThemeAlias (..),
    newDescribeThemeAlias,

    -- * Request Lenses
    describeThemeAlias_awsAccountId,
    describeThemeAlias_themeId,
    describeThemeAlias_aliasName,

    -- * Destructuring the Response
    DescribeThemeAliasResponse (..),
    newDescribeThemeAliasResponse,

    -- * Response Lenses
    describeThemeAliasResponse_requestId,
    describeThemeAliasResponse_themeAlias,
    describeThemeAliasResponse_status,
  )
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 Amazonka.QuickSight.Types
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response

-- | /See:/ 'newDescribeThemeAlias' smart constructor.
data DescribeThemeAlias = DescribeThemeAlias'
  { -- | The ID of the Amazon Web Services account that contains the theme alias
    -- that you\'re describing.
    DescribeThemeAlias -> Text
awsAccountId :: Prelude.Text,
    -- | The ID for the theme.
    DescribeThemeAlias -> Text
themeId :: Prelude.Text,
    -- | The name of the theme alias that you want to describe.
    DescribeThemeAlias -> Text
aliasName :: Prelude.Text
  }
  deriving (DescribeThemeAlias -> DescribeThemeAlias -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeThemeAlias -> DescribeThemeAlias -> Bool
$c/= :: DescribeThemeAlias -> DescribeThemeAlias -> Bool
== :: DescribeThemeAlias -> DescribeThemeAlias -> Bool
$c== :: DescribeThemeAlias -> DescribeThemeAlias -> Bool
Prelude.Eq, ReadPrec [DescribeThemeAlias]
ReadPrec DescribeThemeAlias
Int -> ReadS DescribeThemeAlias
ReadS [DescribeThemeAlias]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeThemeAlias]
$creadListPrec :: ReadPrec [DescribeThemeAlias]
readPrec :: ReadPrec DescribeThemeAlias
$creadPrec :: ReadPrec DescribeThemeAlias
readList :: ReadS [DescribeThemeAlias]
$creadList :: ReadS [DescribeThemeAlias]
readsPrec :: Int -> ReadS DescribeThemeAlias
$creadsPrec :: Int -> ReadS DescribeThemeAlias
Prelude.Read, Int -> DescribeThemeAlias -> ShowS
[DescribeThemeAlias] -> ShowS
DescribeThemeAlias -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeThemeAlias] -> ShowS
$cshowList :: [DescribeThemeAlias] -> ShowS
show :: DescribeThemeAlias -> String
$cshow :: DescribeThemeAlias -> String
showsPrec :: Int -> DescribeThemeAlias -> ShowS
$cshowsPrec :: Int -> DescribeThemeAlias -> ShowS
Prelude.Show, forall x. Rep DescribeThemeAlias x -> DescribeThemeAlias
forall x. DescribeThemeAlias -> Rep DescribeThemeAlias x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeThemeAlias x -> DescribeThemeAlias
$cfrom :: forall x. DescribeThemeAlias -> Rep DescribeThemeAlias x
Prelude.Generic)

-- |
-- Create a value of 'DescribeThemeAlias' 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:
--
-- 'awsAccountId', 'describeThemeAlias_awsAccountId' - The ID of the Amazon Web Services account that contains the theme alias
-- that you\'re describing.
--
-- 'themeId', 'describeThemeAlias_themeId' - The ID for the theme.
--
-- 'aliasName', 'describeThemeAlias_aliasName' - The name of the theme alias that you want to describe.
newDescribeThemeAlias ::
  -- | 'awsAccountId'
  Prelude.Text ->
  -- | 'themeId'
  Prelude.Text ->
  -- | 'aliasName'
  Prelude.Text ->
  DescribeThemeAlias
newDescribeThemeAlias :: Text -> Text -> Text -> DescribeThemeAlias
newDescribeThemeAlias
  Text
pAwsAccountId_
  Text
pThemeId_
  Text
pAliasName_ =
    DescribeThemeAlias'
      { $sel:awsAccountId:DescribeThemeAlias' :: Text
awsAccountId = Text
pAwsAccountId_,
        $sel:themeId:DescribeThemeAlias' :: Text
themeId = Text
pThemeId_,
        $sel:aliasName:DescribeThemeAlias' :: Text
aliasName = Text
pAliasName_
      }

-- | The ID of the Amazon Web Services account that contains the theme alias
-- that you\'re describing.
describeThemeAlias_awsAccountId :: Lens.Lens' DescribeThemeAlias Prelude.Text
describeThemeAlias_awsAccountId :: Lens' DescribeThemeAlias Text
describeThemeAlias_awsAccountId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeThemeAlias' {Text
awsAccountId :: Text
$sel:awsAccountId:DescribeThemeAlias' :: DescribeThemeAlias -> Text
awsAccountId} -> Text
awsAccountId) (\s :: DescribeThemeAlias
s@DescribeThemeAlias' {} Text
a -> DescribeThemeAlias
s {$sel:awsAccountId:DescribeThemeAlias' :: Text
awsAccountId = Text
a} :: DescribeThemeAlias)

-- | The ID for the theme.
describeThemeAlias_themeId :: Lens.Lens' DescribeThemeAlias Prelude.Text
describeThemeAlias_themeId :: Lens' DescribeThemeAlias Text
describeThemeAlias_themeId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeThemeAlias' {Text
themeId :: Text
$sel:themeId:DescribeThemeAlias' :: DescribeThemeAlias -> Text
themeId} -> Text
themeId) (\s :: DescribeThemeAlias
s@DescribeThemeAlias' {} Text
a -> DescribeThemeAlias
s {$sel:themeId:DescribeThemeAlias' :: Text
themeId = Text
a} :: DescribeThemeAlias)

-- | The name of the theme alias that you want to describe.
describeThemeAlias_aliasName :: Lens.Lens' DescribeThemeAlias Prelude.Text
describeThemeAlias_aliasName :: Lens' DescribeThemeAlias Text
describeThemeAlias_aliasName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeThemeAlias' {Text
aliasName :: Text
$sel:aliasName:DescribeThemeAlias' :: DescribeThemeAlias -> Text
aliasName} -> Text
aliasName) (\s :: DescribeThemeAlias
s@DescribeThemeAlias' {} Text
a -> DescribeThemeAlias
s {$sel:aliasName:DescribeThemeAlias' :: Text
aliasName = Text
a} :: DescribeThemeAlias)

instance Core.AWSRequest DescribeThemeAlias where
  type
    AWSResponse DescribeThemeAlias =
      DescribeThemeAliasResponse
  request :: (Service -> Service)
-> DescribeThemeAlias -> Request DescribeThemeAlias
request Service -> Service
overrides =
    forall a. ToRequest a => Service -> a -> Request a
Request.get (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DescribeThemeAlias
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DescribeThemeAlias)))
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 Text -> Maybe ThemeAlias -> Int -> DescribeThemeAliasResponse
DescribeThemeAliasResponse'
            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
"RequestId")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"ThemeAlias")
            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 DescribeThemeAlias where
  hashWithSalt :: Int -> DescribeThemeAlias -> Int
hashWithSalt Int
_salt DescribeThemeAlias' {Text
aliasName :: Text
themeId :: Text
awsAccountId :: Text
$sel:aliasName:DescribeThemeAlias' :: DescribeThemeAlias -> Text
$sel:themeId:DescribeThemeAlias' :: DescribeThemeAlias -> Text
$sel:awsAccountId:DescribeThemeAlias' :: DescribeThemeAlias -> Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
awsAccountId
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
themeId
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
aliasName

instance Prelude.NFData DescribeThemeAlias where
  rnf :: DescribeThemeAlias -> ()
rnf DescribeThemeAlias' {Text
aliasName :: Text
themeId :: Text
awsAccountId :: Text
$sel:aliasName:DescribeThemeAlias' :: DescribeThemeAlias -> Text
$sel:themeId:DescribeThemeAlias' :: DescribeThemeAlias -> Text
$sel:awsAccountId:DescribeThemeAlias' :: DescribeThemeAlias -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
awsAccountId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
themeId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
aliasName

instance Data.ToHeaders DescribeThemeAlias where
  toHeaders :: DescribeThemeAlias -> 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.0" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToPath DescribeThemeAlias where
  toPath :: DescribeThemeAlias -> ByteString
toPath DescribeThemeAlias' {Text
aliasName :: Text
themeId :: Text
awsAccountId :: Text
$sel:aliasName:DescribeThemeAlias' :: DescribeThemeAlias -> Text
$sel:themeId:DescribeThemeAlias' :: DescribeThemeAlias -> Text
$sel:awsAccountId:DescribeThemeAlias' :: DescribeThemeAlias -> Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"/accounts/",
        forall a. ToByteString a => a -> ByteString
Data.toBS Text
awsAccountId,
        ByteString
"/themes/",
        forall a. ToByteString a => a -> ByteString
Data.toBS Text
themeId,
        ByteString
"/aliases/",
        forall a. ToByteString a => a -> ByteString
Data.toBS Text
aliasName
      ]

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

-- | /See:/ 'newDescribeThemeAliasResponse' smart constructor.
data DescribeThemeAliasResponse = DescribeThemeAliasResponse'
  { -- | The Amazon Web Services request ID for this operation.
    DescribeThemeAliasResponse -> Maybe Text
requestId :: Prelude.Maybe Prelude.Text,
    -- | Information about the theme alias.
    DescribeThemeAliasResponse -> Maybe ThemeAlias
themeAlias :: Prelude.Maybe ThemeAlias,
    -- | The HTTP status of the request.
    DescribeThemeAliasResponse -> Int
status :: Prelude.Int
  }
  deriving (DescribeThemeAliasResponse -> DescribeThemeAliasResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeThemeAliasResponse -> DescribeThemeAliasResponse -> Bool
$c/= :: DescribeThemeAliasResponse -> DescribeThemeAliasResponse -> Bool
== :: DescribeThemeAliasResponse -> DescribeThemeAliasResponse -> Bool
$c== :: DescribeThemeAliasResponse -> DescribeThemeAliasResponse -> Bool
Prelude.Eq, ReadPrec [DescribeThemeAliasResponse]
ReadPrec DescribeThemeAliasResponse
Int -> ReadS DescribeThemeAliasResponse
ReadS [DescribeThemeAliasResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeThemeAliasResponse]
$creadListPrec :: ReadPrec [DescribeThemeAliasResponse]
readPrec :: ReadPrec DescribeThemeAliasResponse
$creadPrec :: ReadPrec DescribeThemeAliasResponse
readList :: ReadS [DescribeThemeAliasResponse]
$creadList :: ReadS [DescribeThemeAliasResponse]
readsPrec :: Int -> ReadS DescribeThemeAliasResponse
$creadsPrec :: Int -> ReadS DescribeThemeAliasResponse
Prelude.Read, Int -> DescribeThemeAliasResponse -> ShowS
[DescribeThemeAliasResponse] -> ShowS
DescribeThemeAliasResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeThemeAliasResponse] -> ShowS
$cshowList :: [DescribeThemeAliasResponse] -> ShowS
show :: DescribeThemeAliasResponse -> String
$cshow :: DescribeThemeAliasResponse -> String
showsPrec :: Int -> DescribeThemeAliasResponse -> ShowS
$cshowsPrec :: Int -> DescribeThemeAliasResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeThemeAliasResponse x -> DescribeThemeAliasResponse
forall x.
DescribeThemeAliasResponse -> Rep DescribeThemeAliasResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeThemeAliasResponse x -> DescribeThemeAliasResponse
$cfrom :: forall x.
DescribeThemeAliasResponse -> Rep DescribeThemeAliasResponse x
Prelude.Generic)

-- |
-- Create a value of 'DescribeThemeAliasResponse' 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:
--
-- 'requestId', 'describeThemeAliasResponse_requestId' - The Amazon Web Services request ID for this operation.
--
-- 'themeAlias', 'describeThemeAliasResponse_themeAlias' - Information about the theme alias.
--
-- 'status', 'describeThemeAliasResponse_status' - The HTTP status of the request.
newDescribeThemeAliasResponse ::
  -- | 'status'
  Prelude.Int ->
  DescribeThemeAliasResponse
newDescribeThemeAliasResponse :: Int -> DescribeThemeAliasResponse
newDescribeThemeAliasResponse Int
pStatus_ =
  DescribeThemeAliasResponse'
    { $sel:requestId:DescribeThemeAliasResponse' :: Maybe Text
requestId =
        forall a. Maybe a
Prelude.Nothing,
      $sel:themeAlias:DescribeThemeAliasResponse' :: Maybe ThemeAlias
themeAlias = forall a. Maybe a
Prelude.Nothing,
      $sel:status:DescribeThemeAliasResponse' :: Int
status = Int
pStatus_
    }

-- | The Amazon Web Services request ID for this operation.
describeThemeAliasResponse_requestId :: Lens.Lens' DescribeThemeAliasResponse (Prelude.Maybe Prelude.Text)
describeThemeAliasResponse_requestId :: Lens' DescribeThemeAliasResponse (Maybe Text)
describeThemeAliasResponse_requestId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeThemeAliasResponse' {Maybe Text
requestId :: Maybe Text
$sel:requestId:DescribeThemeAliasResponse' :: DescribeThemeAliasResponse -> Maybe Text
requestId} -> Maybe Text
requestId) (\s :: DescribeThemeAliasResponse
s@DescribeThemeAliasResponse' {} Maybe Text
a -> DescribeThemeAliasResponse
s {$sel:requestId:DescribeThemeAliasResponse' :: Maybe Text
requestId = Maybe Text
a} :: DescribeThemeAliasResponse)

-- | Information about the theme alias.
describeThemeAliasResponse_themeAlias :: Lens.Lens' DescribeThemeAliasResponse (Prelude.Maybe ThemeAlias)
describeThemeAliasResponse_themeAlias :: Lens' DescribeThemeAliasResponse (Maybe ThemeAlias)
describeThemeAliasResponse_themeAlias = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeThemeAliasResponse' {Maybe ThemeAlias
themeAlias :: Maybe ThemeAlias
$sel:themeAlias:DescribeThemeAliasResponse' :: DescribeThemeAliasResponse -> Maybe ThemeAlias
themeAlias} -> Maybe ThemeAlias
themeAlias) (\s :: DescribeThemeAliasResponse
s@DescribeThemeAliasResponse' {} Maybe ThemeAlias
a -> DescribeThemeAliasResponse
s {$sel:themeAlias:DescribeThemeAliasResponse' :: Maybe ThemeAlias
themeAlias = Maybe ThemeAlias
a} :: DescribeThemeAliasResponse)

-- | The HTTP status of the request.
describeThemeAliasResponse_status :: Lens.Lens' DescribeThemeAliasResponse Prelude.Int
describeThemeAliasResponse_status :: Lens' DescribeThemeAliasResponse Int
describeThemeAliasResponse_status = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeThemeAliasResponse' {Int
status :: Int
$sel:status:DescribeThemeAliasResponse' :: DescribeThemeAliasResponse -> Int
status} -> Int
status) (\s :: DescribeThemeAliasResponse
s@DescribeThemeAliasResponse' {} Int
a -> DescribeThemeAliasResponse
s {$sel:status:DescribeThemeAliasResponse' :: Int
status = Int
a} :: DescribeThemeAliasResponse)

instance Prelude.NFData DescribeThemeAliasResponse where
  rnf :: DescribeThemeAliasResponse -> ()
rnf DescribeThemeAliasResponse' {Int
Maybe Text
Maybe ThemeAlias
status :: Int
themeAlias :: Maybe ThemeAlias
requestId :: Maybe Text
$sel:status:DescribeThemeAliasResponse' :: DescribeThemeAliasResponse -> Int
$sel:themeAlias:DescribeThemeAliasResponse' :: DescribeThemeAliasResponse -> Maybe ThemeAlias
$sel:requestId:DescribeThemeAliasResponse' :: DescribeThemeAliasResponse -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
requestId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe ThemeAlias
themeAlias
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
status