{-# 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.Route53RecoveryControlConfig.DescribeControlPanel
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Displays details about a control panel.
module Amazonka.Route53RecoveryControlConfig.DescribeControlPanel
  ( -- * Creating a Request
    DescribeControlPanel (..),
    newDescribeControlPanel,

    -- * Request Lenses
    describeControlPanel_controlPanelArn,

    -- * Destructuring the Response
    DescribeControlPanelResponse (..),
    newDescribeControlPanelResponse,

    -- * Response Lenses
    describeControlPanelResponse_controlPanel,
    describeControlPanelResponse_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.Route53RecoveryControlConfig.Types

-- | /See:/ 'newDescribeControlPanel' smart constructor.
data DescribeControlPanel = DescribeControlPanel'
  { -- | The Amazon Resource Name (ARN) of the control panel.
    DescribeControlPanel -> Text
controlPanelArn :: Prelude.Text
  }
  deriving (DescribeControlPanel -> DescribeControlPanel -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeControlPanel -> DescribeControlPanel -> Bool
$c/= :: DescribeControlPanel -> DescribeControlPanel -> Bool
== :: DescribeControlPanel -> DescribeControlPanel -> Bool
$c== :: DescribeControlPanel -> DescribeControlPanel -> Bool
Prelude.Eq, ReadPrec [DescribeControlPanel]
ReadPrec DescribeControlPanel
Int -> ReadS DescribeControlPanel
ReadS [DescribeControlPanel]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeControlPanel]
$creadListPrec :: ReadPrec [DescribeControlPanel]
readPrec :: ReadPrec DescribeControlPanel
$creadPrec :: ReadPrec DescribeControlPanel
readList :: ReadS [DescribeControlPanel]
$creadList :: ReadS [DescribeControlPanel]
readsPrec :: Int -> ReadS DescribeControlPanel
$creadsPrec :: Int -> ReadS DescribeControlPanel
Prelude.Read, Int -> DescribeControlPanel -> ShowS
[DescribeControlPanel] -> ShowS
DescribeControlPanel -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeControlPanel] -> ShowS
$cshowList :: [DescribeControlPanel] -> ShowS
show :: DescribeControlPanel -> String
$cshow :: DescribeControlPanel -> String
showsPrec :: Int -> DescribeControlPanel -> ShowS
$cshowsPrec :: Int -> DescribeControlPanel -> ShowS
Prelude.Show, forall x. Rep DescribeControlPanel x -> DescribeControlPanel
forall x. DescribeControlPanel -> Rep DescribeControlPanel x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeControlPanel x -> DescribeControlPanel
$cfrom :: forall x. DescribeControlPanel -> Rep DescribeControlPanel x
Prelude.Generic)

-- |
-- Create a value of 'DescribeControlPanel' 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:
--
-- 'controlPanelArn', 'describeControlPanel_controlPanelArn' - The Amazon Resource Name (ARN) of the control panel.
newDescribeControlPanel ::
  -- | 'controlPanelArn'
  Prelude.Text ->
  DescribeControlPanel
newDescribeControlPanel :: Text -> DescribeControlPanel
newDescribeControlPanel Text
pControlPanelArn_ =
  DescribeControlPanel'
    { $sel:controlPanelArn:DescribeControlPanel' :: Text
controlPanelArn =
        Text
pControlPanelArn_
    }

-- | The Amazon Resource Name (ARN) of the control panel.
describeControlPanel_controlPanelArn :: Lens.Lens' DescribeControlPanel Prelude.Text
describeControlPanel_controlPanelArn :: Lens' DescribeControlPanel Text
describeControlPanel_controlPanelArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeControlPanel' {Text
controlPanelArn :: Text
$sel:controlPanelArn:DescribeControlPanel' :: DescribeControlPanel -> Text
controlPanelArn} -> Text
controlPanelArn) (\s :: DescribeControlPanel
s@DescribeControlPanel' {} Text
a -> DescribeControlPanel
s {$sel:controlPanelArn:DescribeControlPanel' :: Text
controlPanelArn = Text
a} :: DescribeControlPanel)

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

instance Prelude.NFData DescribeControlPanel where
  rnf :: DescribeControlPanel -> ()
rnf DescribeControlPanel' {Text
controlPanelArn :: Text
$sel:controlPanelArn:DescribeControlPanel' :: DescribeControlPanel -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
controlPanelArn

instance Data.ToHeaders DescribeControlPanel where
  toHeaders :: DescribeControlPanel -> 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.ToPath DescribeControlPanel where
  toPath :: DescribeControlPanel -> ByteString
toPath DescribeControlPanel' {Text
controlPanelArn :: Text
$sel:controlPanelArn:DescribeControlPanel' :: DescribeControlPanel -> Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ByteString
"/controlpanel/", forall a. ToByteString a => a -> ByteString
Data.toBS Text
controlPanelArn]

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

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

-- |
-- Create a value of 'DescribeControlPanelResponse' 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:
--
-- 'controlPanel', 'describeControlPanelResponse_controlPanel' - Information about the control panel.
--
-- 'httpStatus', 'describeControlPanelResponse_httpStatus' - The response's http status code.
newDescribeControlPanelResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DescribeControlPanelResponse
newDescribeControlPanelResponse :: Int -> DescribeControlPanelResponse
newDescribeControlPanelResponse Int
pHttpStatus_ =
  DescribeControlPanelResponse'
    { $sel:controlPanel:DescribeControlPanelResponse' :: Maybe ControlPanel
controlPanel =
        forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DescribeControlPanelResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | Information about the control panel.
describeControlPanelResponse_controlPanel :: Lens.Lens' DescribeControlPanelResponse (Prelude.Maybe ControlPanel)
describeControlPanelResponse_controlPanel :: Lens' DescribeControlPanelResponse (Maybe ControlPanel)
describeControlPanelResponse_controlPanel = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeControlPanelResponse' {Maybe ControlPanel
controlPanel :: Maybe ControlPanel
$sel:controlPanel:DescribeControlPanelResponse' :: DescribeControlPanelResponse -> Maybe ControlPanel
controlPanel} -> Maybe ControlPanel
controlPanel) (\s :: DescribeControlPanelResponse
s@DescribeControlPanelResponse' {} Maybe ControlPanel
a -> DescribeControlPanelResponse
s {$sel:controlPanel:DescribeControlPanelResponse' :: Maybe ControlPanel
controlPanel = Maybe ControlPanel
a} :: DescribeControlPanelResponse)

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

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