{-# 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.Connect.DescribeHoursOfOperation
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- This API is in preview release for Amazon Connect and is subject to
-- change.
--
-- Describes the hours of operation.
module Amazonka.Connect.DescribeHoursOfOperation
  ( -- * Creating a Request
    DescribeHoursOfOperation (..),
    newDescribeHoursOfOperation,

    -- * Request Lenses
    describeHoursOfOperation_instanceId,
    describeHoursOfOperation_hoursOfOperationId,

    -- * Destructuring the Response
    DescribeHoursOfOperationResponse (..),
    newDescribeHoursOfOperationResponse,

    -- * Response Lenses
    describeHoursOfOperationResponse_hoursOfOperation,
    describeHoursOfOperationResponse_httpStatus,
  )
where

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

-- | /See:/ 'newDescribeHoursOfOperation' smart constructor.
data DescribeHoursOfOperation = DescribeHoursOfOperation'
  { -- | The identifier of the Amazon Connect instance. You can find the
    -- instanceId in the ARN of the instance.
    DescribeHoursOfOperation -> Text
instanceId :: Prelude.Text,
    -- | The identifier for the hours of operation.
    DescribeHoursOfOperation -> Text
hoursOfOperationId :: Prelude.Text
  }
  deriving (DescribeHoursOfOperation -> DescribeHoursOfOperation -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeHoursOfOperation -> DescribeHoursOfOperation -> Bool
$c/= :: DescribeHoursOfOperation -> DescribeHoursOfOperation -> Bool
== :: DescribeHoursOfOperation -> DescribeHoursOfOperation -> Bool
$c== :: DescribeHoursOfOperation -> DescribeHoursOfOperation -> Bool
Prelude.Eq, ReadPrec [DescribeHoursOfOperation]
ReadPrec DescribeHoursOfOperation
Int -> ReadS DescribeHoursOfOperation
ReadS [DescribeHoursOfOperation]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeHoursOfOperation]
$creadListPrec :: ReadPrec [DescribeHoursOfOperation]
readPrec :: ReadPrec DescribeHoursOfOperation
$creadPrec :: ReadPrec DescribeHoursOfOperation
readList :: ReadS [DescribeHoursOfOperation]
$creadList :: ReadS [DescribeHoursOfOperation]
readsPrec :: Int -> ReadS DescribeHoursOfOperation
$creadsPrec :: Int -> ReadS DescribeHoursOfOperation
Prelude.Read, Int -> DescribeHoursOfOperation -> ShowS
[DescribeHoursOfOperation] -> ShowS
DescribeHoursOfOperation -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeHoursOfOperation] -> ShowS
$cshowList :: [DescribeHoursOfOperation] -> ShowS
show :: DescribeHoursOfOperation -> String
$cshow :: DescribeHoursOfOperation -> String
showsPrec :: Int -> DescribeHoursOfOperation -> ShowS
$cshowsPrec :: Int -> DescribeHoursOfOperation -> ShowS
Prelude.Show, forall x.
Rep DescribeHoursOfOperation x -> DescribeHoursOfOperation
forall x.
DescribeHoursOfOperation -> Rep DescribeHoursOfOperation x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeHoursOfOperation x -> DescribeHoursOfOperation
$cfrom :: forall x.
DescribeHoursOfOperation -> Rep DescribeHoursOfOperation x
Prelude.Generic)

-- |
-- Create a value of 'DescribeHoursOfOperation' 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:
--
-- 'instanceId', 'describeHoursOfOperation_instanceId' - The identifier of the Amazon Connect instance. You can find the
-- instanceId in the ARN of the instance.
--
-- 'hoursOfOperationId', 'describeHoursOfOperation_hoursOfOperationId' - The identifier for the hours of operation.
newDescribeHoursOfOperation ::
  -- | 'instanceId'
  Prelude.Text ->
  -- | 'hoursOfOperationId'
  Prelude.Text ->
  DescribeHoursOfOperation
newDescribeHoursOfOperation :: Text -> Text -> DescribeHoursOfOperation
newDescribeHoursOfOperation
  Text
pInstanceId_
  Text
pHoursOfOperationId_ =
    DescribeHoursOfOperation'
      { $sel:instanceId:DescribeHoursOfOperation' :: Text
instanceId =
          Text
pInstanceId_,
        $sel:hoursOfOperationId:DescribeHoursOfOperation' :: Text
hoursOfOperationId = Text
pHoursOfOperationId_
      }

-- | The identifier of the Amazon Connect instance. You can find the
-- instanceId in the ARN of the instance.
describeHoursOfOperation_instanceId :: Lens.Lens' DescribeHoursOfOperation Prelude.Text
describeHoursOfOperation_instanceId :: Lens' DescribeHoursOfOperation Text
describeHoursOfOperation_instanceId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeHoursOfOperation' {Text
instanceId :: Text
$sel:instanceId:DescribeHoursOfOperation' :: DescribeHoursOfOperation -> Text
instanceId} -> Text
instanceId) (\s :: DescribeHoursOfOperation
s@DescribeHoursOfOperation' {} Text
a -> DescribeHoursOfOperation
s {$sel:instanceId:DescribeHoursOfOperation' :: Text
instanceId = Text
a} :: DescribeHoursOfOperation)

-- | The identifier for the hours of operation.
describeHoursOfOperation_hoursOfOperationId :: Lens.Lens' DescribeHoursOfOperation Prelude.Text
describeHoursOfOperation_hoursOfOperationId :: Lens' DescribeHoursOfOperation Text
describeHoursOfOperation_hoursOfOperationId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeHoursOfOperation' {Text
hoursOfOperationId :: Text
$sel:hoursOfOperationId:DescribeHoursOfOperation' :: DescribeHoursOfOperation -> Text
hoursOfOperationId} -> Text
hoursOfOperationId) (\s :: DescribeHoursOfOperation
s@DescribeHoursOfOperation' {} Text
a -> DescribeHoursOfOperation
s {$sel:hoursOfOperationId:DescribeHoursOfOperation' :: Text
hoursOfOperationId = Text
a} :: DescribeHoursOfOperation)

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

instance Prelude.NFData DescribeHoursOfOperation where
  rnf :: DescribeHoursOfOperation -> ()
rnf DescribeHoursOfOperation' {Text
hoursOfOperationId :: Text
instanceId :: Text
$sel:hoursOfOperationId:DescribeHoursOfOperation' :: DescribeHoursOfOperation -> Text
$sel:instanceId:DescribeHoursOfOperation' :: DescribeHoursOfOperation -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
instanceId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
hoursOfOperationId

instance Data.ToHeaders DescribeHoursOfOperation where
  toHeaders :: DescribeHoursOfOperation -> 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 DescribeHoursOfOperation where
  toPath :: DescribeHoursOfOperation -> ByteString
toPath DescribeHoursOfOperation' {Text
hoursOfOperationId :: Text
instanceId :: Text
$sel:hoursOfOperationId:DescribeHoursOfOperation' :: DescribeHoursOfOperation -> Text
$sel:instanceId:DescribeHoursOfOperation' :: DescribeHoursOfOperation -> Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"/hours-of-operations/",
        forall a. ToByteString a => a -> ByteString
Data.toBS Text
instanceId,
        ByteString
"/",
        forall a. ToByteString a => a -> ByteString
Data.toBS Text
hoursOfOperationId
      ]

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

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

-- |
-- Create a value of 'DescribeHoursOfOperationResponse' 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:
--
-- 'hoursOfOperation', 'describeHoursOfOperationResponse_hoursOfOperation' - The hours of operation.
--
-- 'httpStatus', 'describeHoursOfOperationResponse_httpStatus' - The response's http status code.
newDescribeHoursOfOperationResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DescribeHoursOfOperationResponse
newDescribeHoursOfOperationResponse :: Int -> DescribeHoursOfOperationResponse
newDescribeHoursOfOperationResponse Int
pHttpStatus_ =
  DescribeHoursOfOperationResponse'
    { $sel:hoursOfOperation:DescribeHoursOfOperationResponse' :: Maybe HoursOfOperation
hoursOfOperation =
        forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DescribeHoursOfOperationResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | The hours of operation.
describeHoursOfOperationResponse_hoursOfOperation :: Lens.Lens' DescribeHoursOfOperationResponse (Prelude.Maybe HoursOfOperation)
describeHoursOfOperationResponse_hoursOfOperation :: Lens' DescribeHoursOfOperationResponse (Maybe HoursOfOperation)
describeHoursOfOperationResponse_hoursOfOperation = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeHoursOfOperationResponse' {Maybe HoursOfOperation
hoursOfOperation :: Maybe HoursOfOperation
$sel:hoursOfOperation:DescribeHoursOfOperationResponse' :: DescribeHoursOfOperationResponse -> Maybe HoursOfOperation
hoursOfOperation} -> Maybe HoursOfOperation
hoursOfOperation) (\s :: DescribeHoursOfOperationResponse
s@DescribeHoursOfOperationResponse' {} Maybe HoursOfOperation
a -> DescribeHoursOfOperationResponse
s {$sel:hoursOfOperation:DescribeHoursOfOperationResponse' :: Maybe HoursOfOperation
hoursOfOperation = Maybe HoursOfOperation
a} :: DescribeHoursOfOperationResponse)

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

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