{-# 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.PinpointSmsVoiceV2.DeleteVoiceMessageSpendLimitOverride
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Deletes an account level monthly spend limit override for sending voice
-- messages. Deleting a spend limit override sets the @EnforcedLimit@ equal
-- to the @MaxLimit@, which is controlled by Amazon Web Services. For more
-- information on spending limits (quotas) see
-- <https://docs.aws.amazon.com/pinpoint/latest/developerguide/quotas.html Amazon Pinpoint quotas>
-- in the /Amazon Pinpoint Developer Guide/.
module Amazonka.PinpointSmsVoiceV2.DeleteVoiceMessageSpendLimitOverride
  ( -- * Creating a Request
    DeleteVoiceMessageSpendLimitOverride (..),
    newDeleteVoiceMessageSpendLimitOverride,

    -- * Destructuring the Response
    DeleteVoiceMessageSpendLimitOverrideResponse (..),
    newDeleteVoiceMessageSpendLimitOverrideResponse,

    -- * Response Lenses
    deleteVoiceMessageSpendLimitOverrideResponse_monthlyLimit,
    deleteVoiceMessageSpendLimitOverrideResponse_httpStatus,
  )
where

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

-- | /See:/ 'newDeleteVoiceMessageSpendLimitOverride' smart constructor.
data DeleteVoiceMessageSpendLimitOverride = DeleteVoiceMessageSpendLimitOverride'
  {
  }
  deriving (DeleteVoiceMessageSpendLimitOverride
-> DeleteVoiceMessageSpendLimitOverride -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteVoiceMessageSpendLimitOverride
-> DeleteVoiceMessageSpendLimitOverride -> Bool
$c/= :: DeleteVoiceMessageSpendLimitOverride
-> DeleteVoiceMessageSpendLimitOverride -> Bool
== :: DeleteVoiceMessageSpendLimitOverride
-> DeleteVoiceMessageSpendLimitOverride -> Bool
$c== :: DeleteVoiceMessageSpendLimitOverride
-> DeleteVoiceMessageSpendLimitOverride -> Bool
Prelude.Eq, ReadPrec [DeleteVoiceMessageSpendLimitOverride]
ReadPrec DeleteVoiceMessageSpendLimitOverride
Int -> ReadS DeleteVoiceMessageSpendLimitOverride
ReadS [DeleteVoiceMessageSpendLimitOverride]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteVoiceMessageSpendLimitOverride]
$creadListPrec :: ReadPrec [DeleteVoiceMessageSpendLimitOverride]
readPrec :: ReadPrec DeleteVoiceMessageSpendLimitOverride
$creadPrec :: ReadPrec DeleteVoiceMessageSpendLimitOverride
readList :: ReadS [DeleteVoiceMessageSpendLimitOverride]
$creadList :: ReadS [DeleteVoiceMessageSpendLimitOverride]
readsPrec :: Int -> ReadS DeleteVoiceMessageSpendLimitOverride
$creadsPrec :: Int -> ReadS DeleteVoiceMessageSpendLimitOverride
Prelude.Read, Int -> DeleteVoiceMessageSpendLimitOverride -> ShowS
[DeleteVoiceMessageSpendLimitOverride] -> ShowS
DeleteVoiceMessageSpendLimitOverride -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteVoiceMessageSpendLimitOverride] -> ShowS
$cshowList :: [DeleteVoiceMessageSpendLimitOverride] -> ShowS
show :: DeleteVoiceMessageSpendLimitOverride -> String
$cshow :: DeleteVoiceMessageSpendLimitOverride -> String
showsPrec :: Int -> DeleteVoiceMessageSpendLimitOverride -> ShowS
$cshowsPrec :: Int -> DeleteVoiceMessageSpendLimitOverride -> ShowS
Prelude.Show, forall x.
Rep DeleteVoiceMessageSpendLimitOverride x
-> DeleteVoiceMessageSpendLimitOverride
forall x.
DeleteVoiceMessageSpendLimitOverride
-> Rep DeleteVoiceMessageSpendLimitOverride x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DeleteVoiceMessageSpendLimitOverride x
-> DeleteVoiceMessageSpendLimitOverride
$cfrom :: forall x.
DeleteVoiceMessageSpendLimitOverride
-> Rep DeleteVoiceMessageSpendLimitOverride x
Prelude.Generic)

-- |
-- Create a value of 'DeleteVoiceMessageSpendLimitOverride' 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.
newDeleteVoiceMessageSpendLimitOverride ::
  DeleteVoiceMessageSpendLimitOverride
newDeleteVoiceMessageSpendLimitOverride :: DeleteVoiceMessageSpendLimitOverride
newDeleteVoiceMessageSpendLimitOverride =
  DeleteVoiceMessageSpendLimitOverride
DeleteVoiceMessageSpendLimitOverride'

instance
  Core.AWSRequest
    DeleteVoiceMessageSpendLimitOverride
  where
  type
    AWSResponse DeleteVoiceMessageSpendLimitOverride =
      DeleteVoiceMessageSpendLimitOverrideResponse
  request :: (Service -> Service)
-> DeleteVoiceMessageSpendLimitOverride
-> Request DeleteVoiceMessageSpendLimitOverride
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 DeleteVoiceMessageSpendLimitOverride
-> ClientResponse ClientBody
-> m (Either
        Error
        (ClientResponse
           (AWSResponse DeleteVoiceMessageSpendLimitOverride)))
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 Natural
-> Int -> DeleteVoiceMessageSpendLimitOverrideResponse
DeleteVoiceMessageSpendLimitOverrideResponse'
            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
"MonthlyLimit")
            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
    DeleteVoiceMessageSpendLimitOverride
  where
  hashWithSalt :: Int -> DeleteVoiceMessageSpendLimitOverride -> Int
hashWithSalt Int
_salt DeleteVoiceMessageSpendLimitOverride
_ =
    Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` ()

instance
  Prelude.NFData
    DeleteVoiceMessageSpendLimitOverride
  where
  rnf :: DeleteVoiceMessageSpendLimitOverride -> ()
rnf DeleteVoiceMessageSpendLimitOverride
_ = ()

instance
  Data.ToHeaders
    DeleteVoiceMessageSpendLimitOverride
  where
  toHeaders :: DeleteVoiceMessageSpendLimitOverride -> 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
"PinpointSMSVoiceV2.DeleteVoiceMessageSpendLimitOverride" ::
                          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
    DeleteVoiceMessageSpendLimitOverride
  where
  toJSON :: DeleteVoiceMessageSpendLimitOverride -> Value
toJSON = forall a b. a -> b -> a
Prelude.const (Object -> Value
Data.Object forall a. Monoid a => a
Prelude.mempty)

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

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

-- | /See:/ 'newDeleteVoiceMessageSpendLimitOverrideResponse' smart constructor.
data DeleteVoiceMessageSpendLimitOverrideResponse = DeleteVoiceMessageSpendLimitOverrideResponse'
  { -- | The current monthly limit, in US dollars.
    DeleteVoiceMessageSpendLimitOverrideResponse -> Maybe Natural
monthlyLimit :: Prelude.Maybe Prelude.Natural,
    -- | The response's http status code.
    DeleteVoiceMessageSpendLimitOverrideResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DeleteVoiceMessageSpendLimitOverrideResponse
-> DeleteVoiceMessageSpendLimitOverrideResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteVoiceMessageSpendLimitOverrideResponse
-> DeleteVoiceMessageSpendLimitOverrideResponse -> Bool
$c/= :: DeleteVoiceMessageSpendLimitOverrideResponse
-> DeleteVoiceMessageSpendLimitOverrideResponse -> Bool
== :: DeleteVoiceMessageSpendLimitOverrideResponse
-> DeleteVoiceMessageSpendLimitOverrideResponse -> Bool
$c== :: DeleteVoiceMessageSpendLimitOverrideResponse
-> DeleteVoiceMessageSpendLimitOverrideResponse -> Bool
Prelude.Eq, ReadPrec [DeleteVoiceMessageSpendLimitOverrideResponse]
ReadPrec DeleteVoiceMessageSpendLimitOverrideResponse
Int -> ReadS DeleteVoiceMessageSpendLimitOverrideResponse
ReadS [DeleteVoiceMessageSpendLimitOverrideResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteVoiceMessageSpendLimitOverrideResponse]
$creadListPrec :: ReadPrec [DeleteVoiceMessageSpendLimitOverrideResponse]
readPrec :: ReadPrec DeleteVoiceMessageSpendLimitOverrideResponse
$creadPrec :: ReadPrec DeleteVoiceMessageSpendLimitOverrideResponse
readList :: ReadS [DeleteVoiceMessageSpendLimitOverrideResponse]
$creadList :: ReadS [DeleteVoiceMessageSpendLimitOverrideResponse]
readsPrec :: Int -> ReadS DeleteVoiceMessageSpendLimitOverrideResponse
$creadsPrec :: Int -> ReadS DeleteVoiceMessageSpendLimitOverrideResponse
Prelude.Read, Int -> DeleteVoiceMessageSpendLimitOverrideResponse -> ShowS
[DeleteVoiceMessageSpendLimitOverrideResponse] -> ShowS
DeleteVoiceMessageSpendLimitOverrideResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteVoiceMessageSpendLimitOverrideResponse] -> ShowS
$cshowList :: [DeleteVoiceMessageSpendLimitOverrideResponse] -> ShowS
show :: DeleteVoiceMessageSpendLimitOverrideResponse -> String
$cshow :: DeleteVoiceMessageSpendLimitOverrideResponse -> String
showsPrec :: Int -> DeleteVoiceMessageSpendLimitOverrideResponse -> ShowS
$cshowsPrec :: Int -> DeleteVoiceMessageSpendLimitOverrideResponse -> ShowS
Prelude.Show, forall x.
Rep DeleteVoiceMessageSpendLimitOverrideResponse x
-> DeleteVoiceMessageSpendLimitOverrideResponse
forall x.
DeleteVoiceMessageSpendLimitOverrideResponse
-> Rep DeleteVoiceMessageSpendLimitOverrideResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DeleteVoiceMessageSpendLimitOverrideResponse x
-> DeleteVoiceMessageSpendLimitOverrideResponse
$cfrom :: forall x.
DeleteVoiceMessageSpendLimitOverrideResponse
-> Rep DeleteVoiceMessageSpendLimitOverrideResponse x
Prelude.Generic)

-- |
-- Create a value of 'DeleteVoiceMessageSpendLimitOverrideResponse' 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:
--
-- 'monthlyLimit', 'deleteVoiceMessageSpendLimitOverrideResponse_monthlyLimit' - The current monthly limit, in US dollars.
--
-- 'httpStatus', 'deleteVoiceMessageSpendLimitOverrideResponse_httpStatus' - The response's http status code.
newDeleteVoiceMessageSpendLimitOverrideResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DeleteVoiceMessageSpendLimitOverrideResponse
newDeleteVoiceMessageSpendLimitOverrideResponse :: Int -> DeleteVoiceMessageSpendLimitOverrideResponse
newDeleteVoiceMessageSpendLimitOverrideResponse
  Int
pHttpStatus_ =
    DeleteVoiceMessageSpendLimitOverrideResponse'
      { $sel:monthlyLimit:DeleteVoiceMessageSpendLimitOverrideResponse' :: Maybe Natural
monthlyLimit =
          forall a. Maybe a
Prelude.Nothing,
        $sel:httpStatus:DeleteVoiceMessageSpendLimitOverrideResponse' :: Int
httpStatus = Int
pHttpStatus_
      }

-- | The current monthly limit, in US dollars.
deleteVoiceMessageSpendLimitOverrideResponse_monthlyLimit :: Lens.Lens' DeleteVoiceMessageSpendLimitOverrideResponse (Prelude.Maybe Prelude.Natural)
deleteVoiceMessageSpendLimitOverrideResponse_monthlyLimit :: Lens' DeleteVoiceMessageSpendLimitOverrideResponse (Maybe Natural)
deleteVoiceMessageSpendLimitOverrideResponse_monthlyLimit = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteVoiceMessageSpendLimitOverrideResponse' {Maybe Natural
monthlyLimit :: Maybe Natural
$sel:monthlyLimit:DeleteVoiceMessageSpendLimitOverrideResponse' :: DeleteVoiceMessageSpendLimitOverrideResponse -> Maybe Natural
monthlyLimit} -> Maybe Natural
monthlyLimit) (\s :: DeleteVoiceMessageSpendLimitOverrideResponse
s@DeleteVoiceMessageSpendLimitOverrideResponse' {} Maybe Natural
a -> DeleteVoiceMessageSpendLimitOverrideResponse
s {$sel:monthlyLimit:DeleteVoiceMessageSpendLimitOverrideResponse' :: Maybe Natural
monthlyLimit = Maybe Natural
a} :: DeleteVoiceMessageSpendLimitOverrideResponse)

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

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