{-# 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.Pinpoint.DeleteApp
(
deleteApp
, DeleteApp
, daApplicationId
, deleteAppResponse
, DeleteAppResponse
, darsResponseStatus
, darsApplicationResponse
) where
import Network.AWS.Lens
import Network.AWS.Pinpoint.Types
import Network.AWS.Pinpoint.Types.Product
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
newtype DeleteApp = DeleteApp'
{ _daApplicationId :: Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
deleteApp
:: Text
-> DeleteApp
deleteApp pApplicationId_ = DeleteApp' {_daApplicationId = pApplicationId_}
daApplicationId :: Lens' DeleteApp Text
daApplicationId = lens _daApplicationId (\ s a -> s{_daApplicationId = a})
instance AWSRequest DeleteApp where
type Rs DeleteApp = DeleteAppResponse
request = delete pinpoint
response
= receiveJSON
(\ s h x ->
DeleteAppResponse' <$>
(pure (fromEnum s)) <*> (eitherParseJSON x))
instance Hashable DeleteApp where
instance NFData DeleteApp where
instance ToHeaders DeleteApp where
toHeaders
= const
(mconcat
["Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToPath DeleteApp where
toPath DeleteApp'{..}
= mconcat ["/v1/apps/", toBS _daApplicationId]
instance ToQuery DeleteApp where
toQuery = const mempty
data DeleteAppResponse = DeleteAppResponse'
{ _darsResponseStatus :: !Int
, _darsApplicationResponse :: !ApplicationResponse
} deriving (Eq, Read, Show, Data, Typeable, Generic)
deleteAppResponse
:: Int
-> ApplicationResponse
-> DeleteAppResponse
deleteAppResponse pResponseStatus_ pApplicationResponse_ =
DeleteAppResponse'
{ _darsResponseStatus = pResponseStatus_
, _darsApplicationResponse = pApplicationResponse_
}
darsResponseStatus :: Lens' DeleteAppResponse Int
darsResponseStatus = lens _darsResponseStatus (\ s a -> s{_darsResponseStatus = a})
darsApplicationResponse :: Lens' DeleteAppResponse ApplicationResponse
darsApplicationResponse = lens _darsApplicationResponse (\ s a -> s{_darsApplicationResponse = a})
instance NFData DeleteAppResponse where