{-# 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.Rekognition.DeleteCollection
(
deleteCollection
, DeleteCollection
, dcCollectionId
, deleteCollectionResponse
, DeleteCollectionResponse
, dcrsStatusCode
, dcrsResponseStatus
) where
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Rekognition.Types
import Network.AWS.Rekognition.Types.Product
import Network.AWS.Request
import Network.AWS.Response
newtype DeleteCollection = DeleteCollection'
{ _dcCollectionId :: Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
deleteCollection
:: Text
-> DeleteCollection
deleteCollection pCollectionId_ =
DeleteCollection' {_dcCollectionId = pCollectionId_}
dcCollectionId :: Lens' DeleteCollection Text
dcCollectionId = lens _dcCollectionId (\ s a -> s{_dcCollectionId = a})
instance AWSRequest DeleteCollection where
type Rs DeleteCollection = DeleteCollectionResponse
request = postJSON rekognition
response
= receiveJSON
(\ s h x ->
DeleteCollectionResponse' <$>
(x .?> "StatusCode") <*> (pure (fromEnum s)))
instance Hashable DeleteCollection where
instance NFData DeleteCollection where
instance ToHeaders DeleteCollection where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("RekognitionService.DeleteCollection" ::
ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON DeleteCollection where
toJSON DeleteCollection'{..}
= object
(catMaybes
[Just ("CollectionId" .= _dcCollectionId)])
instance ToPath DeleteCollection where
toPath = const "/"
instance ToQuery DeleteCollection where
toQuery = const mempty
data DeleteCollectionResponse = DeleteCollectionResponse'
{ _dcrsStatusCode :: !(Maybe Nat)
, _dcrsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
deleteCollectionResponse
:: Int
-> DeleteCollectionResponse
deleteCollectionResponse pResponseStatus_ =
DeleteCollectionResponse'
{_dcrsStatusCode = Nothing, _dcrsResponseStatus = pResponseStatus_}
dcrsStatusCode :: Lens' DeleteCollectionResponse (Maybe Natural)
dcrsStatusCode = lens _dcrsStatusCode (\ s a -> s{_dcrsStatusCode = a}) . mapping _Nat
dcrsResponseStatus :: Lens' DeleteCollectionResponse Int
dcrsResponseStatus = lens _dcrsResponseStatus (\ s a -> s{_dcrsResponseStatus = a})
instance NFData DeleteCollectionResponse where