{-# 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.MediaTailor.DeleteChannelPolicy
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- The channel policy to delete.
module Amazonka.MediaTailor.DeleteChannelPolicy
  ( -- * Creating a Request
    DeleteChannelPolicy (..),
    newDeleteChannelPolicy,

    -- * Request Lenses
    deleteChannelPolicy_channelName,

    -- * Destructuring the Response
    DeleteChannelPolicyResponse (..),
    newDeleteChannelPolicyResponse,

    -- * Response Lenses
    deleteChannelPolicyResponse_httpStatus,
  )
where

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

-- | /See:/ 'newDeleteChannelPolicy' smart constructor.
data DeleteChannelPolicy = DeleteChannelPolicy'
  { -- | The name of the channel associated with this channel policy.
    DeleteChannelPolicy -> Text
channelName :: Prelude.Text
  }
  deriving (DeleteChannelPolicy -> DeleteChannelPolicy -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteChannelPolicy -> DeleteChannelPolicy -> Bool
$c/= :: DeleteChannelPolicy -> DeleteChannelPolicy -> Bool
== :: DeleteChannelPolicy -> DeleteChannelPolicy -> Bool
$c== :: DeleteChannelPolicy -> DeleteChannelPolicy -> Bool
Prelude.Eq, ReadPrec [DeleteChannelPolicy]
ReadPrec DeleteChannelPolicy
Int -> ReadS DeleteChannelPolicy
ReadS [DeleteChannelPolicy]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteChannelPolicy]
$creadListPrec :: ReadPrec [DeleteChannelPolicy]
readPrec :: ReadPrec DeleteChannelPolicy
$creadPrec :: ReadPrec DeleteChannelPolicy
readList :: ReadS [DeleteChannelPolicy]
$creadList :: ReadS [DeleteChannelPolicy]
readsPrec :: Int -> ReadS DeleteChannelPolicy
$creadsPrec :: Int -> ReadS DeleteChannelPolicy
Prelude.Read, Int -> DeleteChannelPolicy -> ShowS
[DeleteChannelPolicy] -> ShowS
DeleteChannelPolicy -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteChannelPolicy] -> ShowS
$cshowList :: [DeleteChannelPolicy] -> ShowS
show :: DeleteChannelPolicy -> String
$cshow :: DeleteChannelPolicy -> String
showsPrec :: Int -> DeleteChannelPolicy -> ShowS
$cshowsPrec :: Int -> DeleteChannelPolicy -> ShowS
Prelude.Show, forall x. Rep DeleteChannelPolicy x -> DeleteChannelPolicy
forall x. DeleteChannelPolicy -> Rep DeleteChannelPolicy x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteChannelPolicy x -> DeleteChannelPolicy
$cfrom :: forall x. DeleteChannelPolicy -> Rep DeleteChannelPolicy x
Prelude.Generic)

-- |
-- Create a value of 'DeleteChannelPolicy' 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:
--
-- 'channelName', 'deleteChannelPolicy_channelName' - The name of the channel associated with this channel policy.
newDeleteChannelPolicy ::
  -- | 'channelName'
  Prelude.Text ->
  DeleteChannelPolicy
newDeleteChannelPolicy :: Text -> DeleteChannelPolicy
newDeleteChannelPolicy Text
pChannelName_ =
  DeleteChannelPolicy' {$sel:channelName:DeleteChannelPolicy' :: Text
channelName = Text
pChannelName_}

-- | The name of the channel associated with this channel policy.
deleteChannelPolicy_channelName :: Lens.Lens' DeleteChannelPolicy Prelude.Text
deleteChannelPolicy_channelName :: Lens' DeleteChannelPolicy Text
deleteChannelPolicy_channelName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteChannelPolicy' {Text
channelName :: Text
$sel:channelName:DeleteChannelPolicy' :: DeleteChannelPolicy -> Text
channelName} -> Text
channelName) (\s :: DeleteChannelPolicy
s@DeleteChannelPolicy' {} Text
a -> DeleteChannelPolicy
s {$sel:channelName:DeleteChannelPolicy' :: Text
channelName = Text
a} :: DeleteChannelPolicy)

instance Core.AWSRequest DeleteChannelPolicy where
  type
    AWSResponse DeleteChannelPolicy =
      DeleteChannelPolicyResponse
  request :: (Service -> Service)
-> DeleteChannelPolicy -> Request DeleteChannelPolicy
request Service -> Service
overrides =
    forall a. ToRequest a => Service -> a -> Request a
Request.delete (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DeleteChannelPolicy
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DeleteChannelPolicy)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> () -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveEmpty
      ( \Int
s ResponseHeaders
h ()
x ->
          Int -> DeleteChannelPolicyResponse
DeleteChannelPolicyResponse'
            forall (f :: * -> *) a b. Functor 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 DeleteChannelPolicy where
  hashWithSalt :: Int -> DeleteChannelPolicy -> Int
hashWithSalt Int
_salt DeleteChannelPolicy' {Text
channelName :: Text
$sel:channelName:DeleteChannelPolicy' :: DeleteChannelPolicy -> Text
..} =
    Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
channelName

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

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

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

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

-- |
-- Create a value of 'DeleteChannelPolicyResponse' 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:
--
-- 'httpStatus', 'deleteChannelPolicyResponse_httpStatus' - The response's http status code.
newDeleteChannelPolicyResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DeleteChannelPolicyResponse
newDeleteChannelPolicyResponse :: Int -> DeleteChannelPolicyResponse
newDeleteChannelPolicyResponse Int
pHttpStatus_ =
  DeleteChannelPolicyResponse'
    { $sel:httpStatus:DeleteChannelPolicyResponse' :: Int
httpStatus =
        Int
pHttpStatus_
    }

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

instance Prelude.NFData DeleteChannelPolicyResponse where
  rnf :: DeleteChannelPolicyResponse -> ()
rnf DeleteChannelPolicyResponse' {Int
httpStatus :: Int
$sel:httpStatus:DeleteChannelPolicyResponse' :: DeleteChannelPolicyResponse -> Int
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus