{-# 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.DeleteBucket
(
DeleteBucket (..),
newDeleteBucket,
deleteBucket_expectedBucketOwner,
deleteBucket_bucket,
DeleteBucketResponse (..),
newDeleteBucketResponse,
)
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 DeleteBucket = DeleteBucket'
{
DeleteBucket -> Maybe Text
expectedBucketOwner :: Prelude.Maybe Prelude.Text,
DeleteBucket -> BucketName
bucket :: BucketName
}
deriving (DeleteBucket -> DeleteBucket -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteBucket -> DeleteBucket -> Bool
$c/= :: DeleteBucket -> DeleteBucket -> Bool
== :: DeleteBucket -> DeleteBucket -> Bool
$c== :: DeleteBucket -> DeleteBucket -> Bool
Prelude.Eq, ReadPrec [DeleteBucket]
ReadPrec DeleteBucket
Int -> ReadS DeleteBucket
ReadS [DeleteBucket]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteBucket]
$creadListPrec :: ReadPrec [DeleteBucket]
readPrec :: ReadPrec DeleteBucket
$creadPrec :: ReadPrec DeleteBucket
readList :: ReadS [DeleteBucket]
$creadList :: ReadS [DeleteBucket]
readsPrec :: Int -> ReadS DeleteBucket
$creadsPrec :: Int -> ReadS DeleteBucket
Prelude.Read, Int -> DeleteBucket -> ShowS
[DeleteBucket] -> ShowS
DeleteBucket -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteBucket] -> ShowS
$cshowList :: [DeleteBucket] -> ShowS
show :: DeleteBucket -> String
$cshow :: DeleteBucket -> String
showsPrec :: Int -> DeleteBucket -> ShowS
$cshowsPrec :: Int -> DeleteBucket -> ShowS
Prelude.Show, forall x. Rep DeleteBucket x -> DeleteBucket
forall x. DeleteBucket -> Rep DeleteBucket x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteBucket x -> DeleteBucket
$cfrom :: forall x. DeleteBucket -> Rep DeleteBucket x
Prelude.Generic)
newDeleteBucket ::
BucketName ->
DeleteBucket
newDeleteBucket :: BucketName -> DeleteBucket
newDeleteBucket BucketName
pBucket_ =
DeleteBucket'
{ $sel:expectedBucketOwner:DeleteBucket' :: Maybe Text
expectedBucketOwner =
forall a. Maybe a
Prelude.Nothing,
$sel:bucket:DeleteBucket' :: BucketName
bucket = BucketName
pBucket_
}
deleteBucket_expectedBucketOwner :: Lens.Lens' DeleteBucket (Prelude.Maybe Prelude.Text)
deleteBucket_expectedBucketOwner :: Lens' DeleteBucket (Maybe Text)
deleteBucket_expectedBucketOwner = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteBucket' {Maybe Text
expectedBucketOwner :: Maybe Text
$sel:expectedBucketOwner:DeleteBucket' :: DeleteBucket -> Maybe Text
expectedBucketOwner} -> Maybe Text
expectedBucketOwner) (\s :: DeleteBucket
s@DeleteBucket' {} Maybe Text
a -> DeleteBucket
s {$sel:expectedBucketOwner:DeleteBucket' :: Maybe Text
expectedBucketOwner = Maybe Text
a} :: DeleteBucket)
deleteBucket_bucket :: Lens.Lens' DeleteBucket BucketName
deleteBucket_bucket :: Lens' DeleteBucket BucketName
deleteBucket_bucket = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteBucket' {BucketName
bucket :: BucketName
$sel:bucket:DeleteBucket' :: DeleteBucket -> BucketName
bucket} -> BucketName
bucket) (\s :: DeleteBucket
s@DeleteBucket' {} BucketName
a -> DeleteBucket
s {$sel:bucket:DeleteBucket' :: BucketName
bucket = BucketName
a} :: DeleteBucket)
instance Core.AWSRequest DeleteBucket where
type AWSResponse DeleteBucket = DeleteBucketResponse
request :: (Service -> Service) -> DeleteBucket -> Request DeleteBucket
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 DeleteBucket
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DeleteBucket)))
response = forall (m :: * -> *) a.
MonadResource m =>
AWSResponse a
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveNull DeleteBucketResponse
DeleteBucketResponse'
instance Prelude.Hashable DeleteBucket where
hashWithSalt :: Int -> DeleteBucket -> Int
hashWithSalt Int
_salt DeleteBucket' {Maybe Text
BucketName
bucket :: BucketName
expectedBucketOwner :: Maybe Text
$sel:bucket:DeleteBucket' :: DeleteBucket -> BucketName
$sel:expectedBucketOwner:DeleteBucket' :: DeleteBucket -> 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 DeleteBucket where
rnf :: DeleteBucket -> ()
rnf DeleteBucket' {Maybe Text
BucketName
bucket :: BucketName
expectedBucketOwner :: Maybe Text
$sel:bucket:DeleteBucket' :: DeleteBucket -> BucketName
$sel:expectedBucketOwner:DeleteBucket' :: DeleteBucket -> 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 DeleteBucket where
toHeaders :: DeleteBucket -> [Header]
toHeaders DeleteBucket' {Maybe Text
BucketName
bucket :: BucketName
expectedBucketOwner :: Maybe Text
$sel:bucket:DeleteBucket' :: DeleteBucket -> BucketName
$sel:expectedBucketOwner:DeleteBucket' :: DeleteBucket -> 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 DeleteBucket where
toPath :: DeleteBucket -> ByteString
toPath DeleteBucket' {Maybe Text
BucketName
bucket :: BucketName
expectedBucketOwner :: Maybe Text
$sel:bucket:DeleteBucket' :: DeleteBucket -> BucketName
$sel:expectedBucketOwner:DeleteBucket' :: DeleteBucket -> Maybe Text
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat [ByteString
"/", forall a. ToByteString a => a -> ByteString
Data.toBS BucketName
bucket]
instance Data.ToQuery DeleteBucket where
toQuery :: DeleteBucket -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DeleteBucketResponse = DeleteBucketResponse'
{
}
deriving (DeleteBucketResponse -> DeleteBucketResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteBucketResponse -> DeleteBucketResponse -> Bool
$c/= :: DeleteBucketResponse -> DeleteBucketResponse -> Bool
== :: DeleteBucketResponse -> DeleteBucketResponse -> Bool
$c== :: DeleteBucketResponse -> DeleteBucketResponse -> Bool
Prelude.Eq, ReadPrec [DeleteBucketResponse]
ReadPrec DeleteBucketResponse
Int -> ReadS DeleteBucketResponse
ReadS [DeleteBucketResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteBucketResponse]
$creadListPrec :: ReadPrec [DeleteBucketResponse]
readPrec :: ReadPrec DeleteBucketResponse
$creadPrec :: ReadPrec DeleteBucketResponse
readList :: ReadS [DeleteBucketResponse]
$creadList :: ReadS [DeleteBucketResponse]
readsPrec :: Int -> ReadS DeleteBucketResponse
$creadsPrec :: Int -> ReadS DeleteBucketResponse
Prelude.Read, Int -> DeleteBucketResponse -> ShowS
[DeleteBucketResponse] -> ShowS
DeleteBucketResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteBucketResponse] -> ShowS
$cshowList :: [DeleteBucketResponse] -> ShowS
show :: DeleteBucketResponse -> String
$cshow :: DeleteBucketResponse -> String
showsPrec :: Int -> DeleteBucketResponse -> ShowS
$cshowsPrec :: Int -> DeleteBucketResponse -> ShowS
Prelude.Show, forall x. Rep DeleteBucketResponse x -> DeleteBucketResponse
forall x. DeleteBucketResponse -> Rep DeleteBucketResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteBucketResponse x -> DeleteBucketResponse
$cfrom :: forall x. DeleteBucketResponse -> Rep DeleteBucketResponse x
Prelude.Generic)
newDeleteBucketResponse ::
DeleteBucketResponse
newDeleteBucketResponse :: DeleteBucketResponse
newDeleteBucketResponse = DeleteBucketResponse
DeleteBucketResponse'
instance Prelude.NFData DeleteBucketResponse where
rnf :: DeleteBucketResponse -> ()
rnf DeleteBucketResponse
_ = ()