{-# 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.GetBucketVersioning
(
GetBucketVersioning (..),
newGetBucketVersioning,
getBucketVersioning_expectedBucketOwner,
getBucketVersioning_bucket,
GetBucketVersioningResponse (..),
newGetBucketVersioningResponse,
getBucketVersioningResponse_mfaDelete,
getBucketVersioningResponse_status,
getBucketVersioningResponse_httpStatus,
)
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 GetBucketVersioning = GetBucketVersioning'
{
GetBucketVersioning -> Maybe Text
expectedBucketOwner :: Prelude.Maybe Prelude.Text,
GetBucketVersioning -> BucketName
bucket :: BucketName
}
deriving (GetBucketVersioning -> GetBucketVersioning -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GetBucketVersioning -> GetBucketVersioning -> Bool
$c/= :: GetBucketVersioning -> GetBucketVersioning -> Bool
== :: GetBucketVersioning -> GetBucketVersioning -> Bool
$c== :: GetBucketVersioning -> GetBucketVersioning -> Bool
Prelude.Eq, ReadPrec [GetBucketVersioning]
ReadPrec GetBucketVersioning
Int -> ReadS GetBucketVersioning
ReadS [GetBucketVersioning]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GetBucketVersioning]
$creadListPrec :: ReadPrec [GetBucketVersioning]
readPrec :: ReadPrec GetBucketVersioning
$creadPrec :: ReadPrec GetBucketVersioning
readList :: ReadS [GetBucketVersioning]
$creadList :: ReadS [GetBucketVersioning]
readsPrec :: Int -> ReadS GetBucketVersioning
$creadsPrec :: Int -> ReadS GetBucketVersioning
Prelude.Read, Int -> GetBucketVersioning -> ShowS
[GetBucketVersioning] -> ShowS
GetBucketVersioning -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetBucketVersioning] -> ShowS
$cshowList :: [GetBucketVersioning] -> ShowS
show :: GetBucketVersioning -> String
$cshow :: GetBucketVersioning -> String
showsPrec :: Int -> GetBucketVersioning -> ShowS
$cshowsPrec :: Int -> GetBucketVersioning -> ShowS
Prelude.Show, forall x. Rep GetBucketVersioning x -> GetBucketVersioning
forall x. GetBucketVersioning -> Rep GetBucketVersioning x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep GetBucketVersioning x -> GetBucketVersioning
$cfrom :: forall x. GetBucketVersioning -> Rep GetBucketVersioning x
Prelude.Generic)
newGetBucketVersioning ::
BucketName ->
GetBucketVersioning
newGetBucketVersioning :: BucketName -> GetBucketVersioning
newGetBucketVersioning BucketName
pBucket_ =
GetBucketVersioning'
{ $sel:expectedBucketOwner:GetBucketVersioning' :: Maybe Text
expectedBucketOwner =
forall a. Maybe a
Prelude.Nothing,
$sel:bucket:GetBucketVersioning' :: BucketName
bucket = BucketName
pBucket_
}
getBucketVersioning_expectedBucketOwner :: Lens.Lens' GetBucketVersioning (Prelude.Maybe Prelude.Text)
getBucketVersioning_expectedBucketOwner :: Lens' GetBucketVersioning (Maybe Text)
getBucketVersioning_expectedBucketOwner = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetBucketVersioning' {Maybe Text
expectedBucketOwner :: Maybe Text
$sel:expectedBucketOwner:GetBucketVersioning' :: GetBucketVersioning -> Maybe Text
expectedBucketOwner} -> Maybe Text
expectedBucketOwner) (\s :: GetBucketVersioning
s@GetBucketVersioning' {} Maybe Text
a -> GetBucketVersioning
s {$sel:expectedBucketOwner:GetBucketVersioning' :: Maybe Text
expectedBucketOwner = Maybe Text
a} :: GetBucketVersioning)
getBucketVersioning_bucket :: Lens.Lens' GetBucketVersioning BucketName
getBucketVersioning_bucket :: Lens' GetBucketVersioning BucketName
getBucketVersioning_bucket = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetBucketVersioning' {BucketName
bucket :: BucketName
$sel:bucket:GetBucketVersioning' :: GetBucketVersioning -> BucketName
bucket} -> BucketName
bucket) (\s :: GetBucketVersioning
s@GetBucketVersioning' {} BucketName
a -> GetBucketVersioning
s {$sel:bucket:GetBucketVersioning' :: BucketName
bucket = BucketName
a} :: GetBucketVersioning)
instance Core.AWSRequest GetBucketVersioning where
type
AWSResponse GetBucketVersioning =
GetBucketVersioningResponse
request :: (Service -> Service)
-> GetBucketVersioning -> Request GetBucketVersioning
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.get (Service -> Service
overrides Service
defaultService)
response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy GetBucketVersioning
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse GetBucketVersioning)))
response =
forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> [Node] -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveXML
( \Int
s ResponseHeaders
h [Node]
x ->
Maybe MFADeleteStatus
-> Maybe BucketVersioningStatus
-> Int
-> GetBucketVersioningResponse
GetBucketVersioningResponse'
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"MfaDelete")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"Status")
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 GetBucketVersioning where
hashWithSalt :: Int -> GetBucketVersioning -> Int
hashWithSalt Int
_salt GetBucketVersioning' {Maybe Text
BucketName
bucket :: BucketName
expectedBucketOwner :: Maybe Text
$sel:bucket:GetBucketVersioning' :: GetBucketVersioning -> BucketName
$sel:expectedBucketOwner:GetBucketVersioning' :: GetBucketVersioning -> 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 GetBucketVersioning where
rnf :: GetBucketVersioning -> ()
rnf GetBucketVersioning' {Maybe Text
BucketName
bucket :: BucketName
expectedBucketOwner :: Maybe Text
$sel:bucket:GetBucketVersioning' :: GetBucketVersioning -> BucketName
$sel:expectedBucketOwner:GetBucketVersioning' :: GetBucketVersioning -> 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 GetBucketVersioning where
toHeaders :: GetBucketVersioning -> ResponseHeaders
toHeaders GetBucketVersioning' {Maybe Text
BucketName
bucket :: BucketName
expectedBucketOwner :: Maybe Text
$sel:bucket:GetBucketVersioning' :: GetBucketVersioning -> BucketName
$sel:expectedBucketOwner:GetBucketVersioning' :: GetBucketVersioning -> Maybe Text
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ HeaderName
"x-amz-expected-bucket-owner"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# Maybe Text
expectedBucketOwner
]
instance Data.ToPath GetBucketVersioning where
toPath :: GetBucketVersioning -> ByteString
toPath GetBucketVersioning' {Maybe Text
BucketName
bucket :: BucketName
expectedBucketOwner :: Maybe Text
$sel:bucket:GetBucketVersioning' :: GetBucketVersioning -> BucketName
$sel:expectedBucketOwner:GetBucketVersioning' :: GetBucketVersioning -> Maybe Text
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat [ByteString
"/", forall a. ToByteString a => a -> ByteString
Data.toBS BucketName
bucket]
instance Data.ToQuery GetBucketVersioning where
toQuery :: GetBucketVersioning -> QueryString
toQuery =
forall a b. a -> b -> a
Prelude.const (forall a. Monoid a => [a] -> a
Prelude.mconcat [QueryString
"versioning"])
data GetBucketVersioningResponse = GetBucketVersioningResponse'
{
GetBucketVersioningResponse -> Maybe MFADeleteStatus
mfaDelete :: Prelude.Maybe MFADeleteStatus,
GetBucketVersioningResponse -> Maybe BucketVersioningStatus
status :: Prelude.Maybe BucketVersioningStatus,
GetBucketVersioningResponse -> Int
httpStatus :: Prelude.Int
}
deriving (GetBucketVersioningResponse -> GetBucketVersioningResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GetBucketVersioningResponse -> GetBucketVersioningResponse -> Bool
$c/= :: GetBucketVersioningResponse -> GetBucketVersioningResponse -> Bool
== :: GetBucketVersioningResponse -> GetBucketVersioningResponse -> Bool
$c== :: GetBucketVersioningResponse -> GetBucketVersioningResponse -> Bool
Prelude.Eq, ReadPrec [GetBucketVersioningResponse]
ReadPrec GetBucketVersioningResponse
Int -> ReadS GetBucketVersioningResponse
ReadS [GetBucketVersioningResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GetBucketVersioningResponse]
$creadListPrec :: ReadPrec [GetBucketVersioningResponse]
readPrec :: ReadPrec GetBucketVersioningResponse
$creadPrec :: ReadPrec GetBucketVersioningResponse
readList :: ReadS [GetBucketVersioningResponse]
$creadList :: ReadS [GetBucketVersioningResponse]
readsPrec :: Int -> ReadS GetBucketVersioningResponse
$creadsPrec :: Int -> ReadS GetBucketVersioningResponse
Prelude.Read, Int -> GetBucketVersioningResponse -> ShowS
[GetBucketVersioningResponse] -> ShowS
GetBucketVersioningResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetBucketVersioningResponse] -> ShowS
$cshowList :: [GetBucketVersioningResponse] -> ShowS
show :: GetBucketVersioningResponse -> String
$cshow :: GetBucketVersioningResponse -> String
showsPrec :: Int -> GetBucketVersioningResponse -> ShowS
$cshowsPrec :: Int -> GetBucketVersioningResponse -> ShowS
Prelude.Show, forall x.
Rep GetBucketVersioningResponse x -> GetBucketVersioningResponse
forall x.
GetBucketVersioningResponse -> Rep GetBucketVersioningResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep GetBucketVersioningResponse x -> GetBucketVersioningResponse
$cfrom :: forall x.
GetBucketVersioningResponse -> Rep GetBucketVersioningResponse x
Prelude.Generic)
newGetBucketVersioningResponse ::
Prelude.Int ->
GetBucketVersioningResponse
newGetBucketVersioningResponse :: Int -> GetBucketVersioningResponse
newGetBucketVersioningResponse Int
pHttpStatus_ =
GetBucketVersioningResponse'
{ $sel:mfaDelete:GetBucketVersioningResponse' :: Maybe MFADeleteStatus
mfaDelete =
forall a. Maybe a
Prelude.Nothing,
$sel:status:GetBucketVersioningResponse' :: Maybe BucketVersioningStatus
status = forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:GetBucketVersioningResponse' :: Int
httpStatus = Int
pHttpStatus_
}
getBucketVersioningResponse_mfaDelete :: Lens.Lens' GetBucketVersioningResponse (Prelude.Maybe MFADeleteStatus)
getBucketVersioningResponse_mfaDelete :: Lens' GetBucketVersioningResponse (Maybe MFADeleteStatus)
getBucketVersioningResponse_mfaDelete = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetBucketVersioningResponse' {Maybe MFADeleteStatus
mfaDelete :: Maybe MFADeleteStatus
$sel:mfaDelete:GetBucketVersioningResponse' :: GetBucketVersioningResponse -> Maybe MFADeleteStatus
mfaDelete} -> Maybe MFADeleteStatus
mfaDelete) (\s :: GetBucketVersioningResponse
s@GetBucketVersioningResponse' {} Maybe MFADeleteStatus
a -> GetBucketVersioningResponse
s {$sel:mfaDelete:GetBucketVersioningResponse' :: Maybe MFADeleteStatus
mfaDelete = Maybe MFADeleteStatus
a} :: GetBucketVersioningResponse)
getBucketVersioningResponse_status :: Lens.Lens' GetBucketVersioningResponse (Prelude.Maybe BucketVersioningStatus)
getBucketVersioningResponse_status :: Lens' GetBucketVersioningResponse (Maybe BucketVersioningStatus)
getBucketVersioningResponse_status = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetBucketVersioningResponse' {Maybe BucketVersioningStatus
status :: Maybe BucketVersioningStatus
$sel:status:GetBucketVersioningResponse' :: GetBucketVersioningResponse -> Maybe BucketVersioningStatus
status} -> Maybe BucketVersioningStatus
status) (\s :: GetBucketVersioningResponse
s@GetBucketVersioningResponse' {} Maybe BucketVersioningStatus
a -> GetBucketVersioningResponse
s {$sel:status:GetBucketVersioningResponse' :: Maybe BucketVersioningStatus
status = Maybe BucketVersioningStatus
a} :: GetBucketVersioningResponse)
getBucketVersioningResponse_httpStatus :: Lens.Lens' GetBucketVersioningResponse Prelude.Int
getBucketVersioningResponse_httpStatus :: Lens' GetBucketVersioningResponse Int
getBucketVersioningResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetBucketVersioningResponse' {Int
httpStatus :: Int
$sel:httpStatus:GetBucketVersioningResponse' :: GetBucketVersioningResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: GetBucketVersioningResponse
s@GetBucketVersioningResponse' {} Int
a -> GetBucketVersioningResponse
s {$sel:httpStatus:GetBucketVersioningResponse' :: Int
httpStatus = Int
a} :: GetBucketVersioningResponse)
instance Prelude.NFData GetBucketVersioningResponse where
rnf :: GetBucketVersioningResponse -> ()
rnf GetBucketVersioningResponse' {Int
Maybe BucketVersioningStatus
Maybe MFADeleteStatus
httpStatus :: Int
status :: Maybe BucketVersioningStatus
mfaDelete :: Maybe MFADeleteStatus
$sel:httpStatus:GetBucketVersioningResponse' :: GetBucketVersioningResponse -> Int
$sel:status:GetBucketVersioningResponse' :: GetBucketVersioningResponse -> Maybe BucketVersioningStatus
$sel:mfaDelete:GetBucketVersioningResponse' :: GetBucketVersioningResponse -> Maybe MFADeleteStatus
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe MFADeleteStatus
mfaDelete
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe BucketVersioningStatus
status
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus