{-# 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 #-}
module Amazonka.S3.DeleteBucketPolicy
(
DeleteBucketPolicy (..),
newDeleteBucketPolicy,
deleteBucketPolicy_expectedBucketOwner,
deleteBucketPolicy_bucket,
DeleteBucketPolicyResponse (..),
newDeleteBucketPolicyResponse,
)
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.S3.Types
data DeleteBucketPolicy = DeleteBucketPolicy'
{
DeleteBucketPolicy -> Maybe Text
expectedBucketOwner :: Prelude.Maybe Prelude.Text,
DeleteBucketPolicy -> BucketName
bucket :: BucketName
}
deriving (DeleteBucketPolicy -> DeleteBucketPolicy -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteBucketPolicy -> DeleteBucketPolicy -> Bool
$c/= :: DeleteBucketPolicy -> DeleteBucketPolicy -> Bool
== :: DeleteBucketPolicy -> DeleteBucketPolicy -> Bool
$c== :: DeleteBucketPolicy -> DeleteBucketPolicy -> Bool
Prelude.Eq, ReadPrec [DeleteBucketPolicy]
ReadPrec DeleteBucketPolicy
Int -> ReadS DeleteBucketPolicy
ReadS [DeleteBucketPolicy]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteBucketPolicy]
$creadListPrec :: ReadPrec [DeleteBucketPolicy]
readPrec :: ReadPrec DeleteBucketPolicy
$creadPrec :: ReadPrec DeleteBucketPolicy
readList :: ReadS [DeleteBucketPolicy]
$creadList :: ReadS [DeleteBucketPolicy]
readsPrec :: Int -> ReadS DeleteBucketPolicy
$creadsPrec :: Int -> ReadS DeleteBucketPolicy
Prelude.Read, Int -> DeleteBucketPolicy -> ShowS
[DeleteBucketPolicy] -> ShowS
DeleteBucketPolicy -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteBucketPolicy] -> ShowS
$cshowList :: [DeleteBucketPolicy] -> ShowS
show :: DeleteBucketPolicy -> String
$cshow :: DeleteBucketPolicy -> String
showsPrec :: Int -> DeleteBucketPolicy -> ShowS
$cshowsPrec :: Int -> DeleteBucketPolicy -> ShowS
Prelude.Show, forall x. Rep DeleteBucketPolicy x -> DeleteBucketPolicy
forall x. DeleteBucketPolicy -> Rep DeleteBucketPolicy x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteBucketPolicy x -> DeleteBucketPolicy
$cfrom :: forall x. DeleteBucketPolicy -> Rep DeleteBucketPolicy x
Prelude.Generic)
newDeleteBucketPolicy ::
BucketName ->
DeleteBucketPolicy
newDeleteBucketPolicy :: BucketName -> DeleteBucketPolicy
newDeleteBucketPolicy BucketName
pBucket_ =
DeleteBucketPolicy'
{ $sel:expectedBucketOwner:DeleteBucketPolicy' :: Maybe Text
expectedBucketOwner =
forall a. Maybe a
Prelude.Nothing,
$sel:bucket:DeleteBucketPolicy' :: BucketName
bucket = BucketName
pBucket_
}
deleteBucketPolicy_expectedBucketOwner :: Lens.Lens' DeleteBucketPolicy (Prelude.Maybe Prelude.Text)
deleteBucketPolicy_expectedBucketOwner :: Lens' DeleteBucketPolicy (Maybe Text)
deleteBucketPolicy_expectedBucketOwner = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteBucketPolicy' {Maybe Text
expectedBucketOwner :: Maybe Text
$sel:expectedBucketOwner:DeleteBucketPolicy' :: DeleteBucketPolicy -> Maybe Text
expectedBucketOwner} -> Maybe Text
expectedBucketOwner) (\s :: DeleteBucketPolicy
s@DeleteBucketPolicy' {} Maybe Text
a -> DeleteBucketPolicy
s {$sel:expectedBucketOwner:DeleteBucketPolicy' :: Maybe Text
expectedBucketOwner = Maybe Text
a} :: DeleteBucketPolicy)
deleteBucketPolicy_bucket :: Lens.Lens' DeleteBucketPolicy BucketName
deleteBucketPolicy_bucket :: Lens' DeleteBucketPolicy BucketName
deleteBucketPolicy_bucket = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteBucketPolicy' {BucketName
bucket :: BucketName
$sel:bucket:DeleteBucketPolicy' :: DeleteBucketPolicy -> BucketName
bucket} -> BucketName
bucket) (\s :: DeleteBucketPolicy
s@DeleteBucketPolicy' {} BucketName
a -> DeleteBucketPolicy
s {$sel:bucket:DeleteBucketPolicy' :: BucketName
bucket = BucketName
a} :: DeleteBucketPolicy)
instance Core.AWSRequest DeleteBucketPolicy where
type
AWSResponse DeleteBucketPolicy =
DeleteBucketPolicyResponse
request :: (Service -> Service)
-> DeleteBucketPolicy -> Request DeleteBucketPolicy
request Service -> Service
overrides =
forall a. Request a -> Request a
Request.s3vhost
forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. 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 DeleteBucketPolicy
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse DeleteBucketPolicy)))
response =
forall (m :: * -> *) a.
MonadResource m =>
AWSResponse a
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveNull DeleteBucketPolicyResponse
DeleteBucketPolicyResponse'
instance Prelude.Hashable DeleteBucketPolicy where
hashWithSalt :: Int -> DeleteBucketPolicy -> Int
hashWithSalt Int
_salt DeleteBucketPolicy' {Maybe Text
BucketName
bucket :: BucketName
expectedBucketOwner :: Maybe Text
$sel:bucket:DeleteBucketPolicy' :: DeleteBucketPolicy -> BucketName
$sel:expectedBucketOwner:DeleteBucketPolicy' :: DeleteBucketPolicy -> Maybe Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
expectedBucketOwner
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` BucketName
bucket
instance Prelude.NFData DeleteBucketPolicy where
rnf :: DeleteBucketPolicy -> ()
rnf DeleteBucketPolicy' {Maybe Text
BucketName
bucket :: BucketName
expectedBucketOwner :: Maybe Text
$sel:bucket:DeleteBucketPolicy' :: DeleteBucketPolicy -> BucketName
$sel:expectedBucketOwner:DeleteBucketPolicy' :: DeleteBucketPolicy -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
expectedBucketOwner
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf BucketName
bucket
instance Data.ToHeaders DeleteBucketPolicy where
toHeaders :: DeleteBucketPolicy -> [Header]
toHeaders DeleteBucketPolicy' {Maybe Text
BucketName
bucket :: BucketName
expectedBucketOwner :: Maybe Text
$sel:bucket:DeleteBucketPolicy' :: DeleteBucketPolicy -> BucketName
$sel:expectedBucketOwner:DeleteBucketPolicy' :: DeleteBucketPolicy -> Maybe Text
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ HeaderName
"x-amz-expected-bucket-owner"
forall a. ToHeader a => HeaderName -> a -> [Header]
Data.=# Maybe Text
expectedBucketOwner
]
instance Data.ToPath DeleteBucketPolicy where
toPath :: DeleteBucketPolicy -> ByteString
toPath DeleteBucketPolicy' {Maybe Text
BucketName
bucket :: BucketName
expectedBucketOwner :: Maybe Text
$sel:bucket:DeleteBucketPolicy' :: DeleteBucketPolicy -> BucketName
$sel:expectedBucketOwner:DeleteBucketPolicy' :: DeleteBucketPolicy -> Maybe Text
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat [ByteString
"/", forall a. ToByteString a => a -> ByteString
Data.toBS BucketName
bucket]
instance Data.ToQuery DeleteBucketPolicy where
toQuery :: DeleteBucketPolicy -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const (forall a. Monoid a => [a] -> a
Prelude.mconcat [QueryString
"policy"])
data DeleteBucketPolicyResponse = DeleteBucketPolicyResponse'
{
}
deriving (DeleteBucketPolicyResponse -> DeleteBucketPolicyResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteBucketPolicyResponse -> DeleteBucketPolicyResponse -> Bool
$c/= :: DeleteBucketPolicyResponse -> DeleteBucketPolicyResponse -> Bool
== :: DeleteBucketPolicyResponse -> DeleteBucketPolicyResponse -> Bool
$c== :: DeleteBucketPolicyResponse -> DeleteBucketPolicyResponse -> Bool
Prelude.Eq, ReadPrec [DeleteBucketPolicyResponse]
ReadPrec DeleteBucketPolicyResponse
Int -> ReadS DeleteBucketPolicyResponse
ReadS [DeleteBucketPolicyResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteBucketPolicyResponse]
$creadListPrec :: ReadPrec [DeleteBucketPolicyResponse]
readPrec :: ReadPrec DeleteBucketPolicyResponse
$creadPrec :: ReadPrec DeleteBucketPolicyResponse
readList :: ReadS [DeleteBucketPolicyResponse]
$creadList :: ReadS [DeleteBucketPolicyResponse]
readsPrec :: Int -> ReadS DeleteBucketPolicyResponse
$creadsPrec :: Int -> ReadS DeleteBucketPolicyResponse
Prelude.Read, Int -> DeleteBucketPolicyResponse -> ShowS
[DeleteBucketPolicyResponse] -> ShowS
DeleteBucketPolicyResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteBucketPolicyResponse] -> ShowS
$cshowList :: [DeleteBucketPolicyResponse] -> ShowS
show :: DeleteBucketPolicyResponse -> String
$cshow :: DeleteBucketPolicyResponse -> String
showsPrec :: Int -> DeleteBucketPolicyResponse -> ShowS
$cshowsPrec :: Int -> DeleteBucketPolicyResponse -> ShowS
Prelude.Show, forall x.
Rep DeleteBucketPolicyResponse x -> DeleteBucketPolicyResponse
forall x.
DeleteBucketPolicyResponse -> Rep DeleteBucketPolicyResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DeleteBucketPolicyResponse x -> DeleteBucketPolicyResponse
$cfrom :: forall x.
DeleteBucketPolicyResponse -> Rep DeleteBucketPolicyResponse x
Prelude.Generic)
newDeleteBucketPolicyResponse ::
DeleteBucketPolicyResponse
newDeleteBucketPolicyResponse :: DeleteBucketPolicyResponse
newDeleteBucketPolicyResponse =
DeleteBucketPolicyResponse
DeleteBucketPolicyResponse'
instance Prelude.NFData DeleteBucketPolicyResponse where
rnf :: DeleteBucketPolicyResponse -> ()
rnf DeleteBucketPolicyResponse
_ = ()