{-# LANGUAGE DeriveDataTypeable #-}
{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE TypeFamilies #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-binds #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}
module Network.AWS.MediaStore.DescribeContainer
(
describeContainer
, DescribeContainer
, dContainerName
, describeContainerResponse
, DescribeContainerResponse
, drsContainer
, drsResponseStatus
) where
import Network.AWS.Lens
import Network.AWS.MediaStore.Types
import Network.AWS.MediaStore.Types.Product
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
newtype DescribeContainer = DescribeContainer'
{ _dContainerName :: Maybe Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
describeContainer
:: DescribeContainer
describeContainer = DescribeContainer' {_dContainerName = Nothing}
dContainerName :: Lens' DescribeContainer (Maybe Text)
dContainerName = lens _dContainerName (\ s a -> s{_dContainerName = a})
instance AWSRequest DescribeContainer where
type Rs DescribeContainer = DescribeContainerResponse
request = postJSON mediaStore
response
= receiveJSON
(\ s h x ->
DescribeContainerResponse' <$>
(x .?> "Container") <*> (pure (fromEnum s)))
instance Hashable DescribeContainer where
instance NFData DescribeContainer where
instance ToHeaders DescribeContainer where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("MediaStore_20170901.DescribeContainer" ::
ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON DescribeContainer where
toJSON DescribeContainer'{..}
= object
(catMaybes
[("ContainerName" .=) <$> _dContainerName])
instance ToPath DescribeContainer where
toPath = const "/"
instance ToQuery DescribeContainer where
toQuery = const mempty
data DescribeContainerResponse = DescribeContainerResponse'
{ _drsContainer :: !(Maybe Container)
, _drsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
describeContainerResponse
:: Int
-> DescribeContainerResponse
describeContainerResponse pResponseStatus_ =
DescribeContainerResponse'
{_drsContainer = Nothing, _drsResponseStatus = pResponseStatus_}
drsContainer :: Lens' DescribeContainerResponse (Maybe Container)
drsContainer = lens _drsContainer (\ s a -> s{_drsContainer = a})
drsResponseStatus :: Lens' DescribeContainerResponse Int
drsResponseStatus = lens _drsResponseStatus (\ s a -> s{_drsResponseStatus = a})
instance NFData DescribeContainerResponse where