module Network.AWS.DMS.DescribeCertificates
(
describeCertificates
, DescribeCertificates
, dFilters
, dMarker
, dMaxRecords
, describeCertificatesResponse
, DescribeCertificatesResponse
, dcrsCertificates
, dcrsMarker
, dcrsResponseStatus
) where
import Network.AWS.DMS.Types
import Network.AWS.DMS.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data DescribeCertificates = DescribeCertificates'
{ _dFilters :: !(Maybe [Filter])
, _dMarker :: !(Maybe Text)
, _dMaxRecords :: !(Maybe Int)
} deriving (Eq, Read, Show, Data, Typeable, Generic)
describeCertificates
:: DescribeCertificates
describeCertificates =
DescribeCertificates'
{_dFilters = Nothing, _dMarker = Nothing, _dMaxRecords = Nothing}
dFilters :: Lens' DescribeCertificates [Filter]
dFilters = lens _dFilters (\ s a -> s{_dFilters = a}) . _Default . _Coerce;
dMarker :: Lens' DescribeCertificates (Maybe Text)
dMarker = lens _dMarker (\ s a -> s{_dMarker = a});
dMaxRecords :: Lens' DescribeCertificates (Maybe Int)
dMaxRecords = lens _dMaxRecords (\ s a -> s{_dMaxRecords = a});
instance AWSRequest DescribeCertificates where
type Rs DescribeCertificates =
DescribeCertificatesResponse
request = postJSON dms
response
= receiveJSON
(\ s h x ->
DescribeCertificatesResponse' <$>
(x .?> "Certificates" .!@ mempty) <*>
(x .?> "Marker")
<*> (pure (fromEnum s)))
instance Hashable DescribeCertificates where
instance NFData DescribeCertificates where
instance ToHeaders DescribeCertificates where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("AmazonDMSv20160101.DescribeCertificates" ::
ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON DescribeCertificates where
toJSON DescribeCertificates'{..}
= object
(catMaybes
[("Filters" .=) <$> _dFilters,
("Marker" .=) <$> _dMarker,
("MaxRecords" .=) <$> _dMaxRecords])
instance ToPath DescribeCertificates where
toPath = const "/"
instance ToQuery DescribeCertificates where
toQuery = const mempty
data DescribeCertificatesResponse = DescribeCertificatesResponse'
{ _dcrsCertificates :: !(Maybe [Certificate])
, _dcrsMarker :: !(Maybe Text)
, _dcrsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
describeCertificatesResponse
:: Int
-> DescribeCertificatesResponse
describeCertificatesResponse pResponseStatus_ =
DescribeCertificatesResponse'
{ _dcrsCertificates = Nothing
, _dcrsMarker = Nothing
, _dcrsResponseStatus = pResponseStatus_
}
dcrsCertificates :: Lens' DescribeCertificatesResponse [Certificate]
dcrsCertificates = lens _dcrsCertificates (\ s a -> s{_dcrsCertificates = a}) . _Default . _Coerce;
dcrsMarker :: Lens' DescribeCertificatesResponse (Maybe Text)
dcrsMarker = lens _dcrsMarker (\ s a -> s{_dcrsMarker = a});
dcrsResponseStatus :: Lens' DescribeCertificatesResponse Int
dcrsResponseStatus = lens _dcrsResponseStatus (\ s a -> s{_dcrsResponseStatus = a});
instance NFData DescribeCertificatesResponse where