{-# 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.IAM.DeleteUser
(
deleteUser
, DeleteUser
, duUserName
, deleteUserResponse
, DeleteUserResponse
) where
import Network.AWS.IAM.Types
import Network.AWS.IAM.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
newtype DeleteUser = DeleteUser'
{ _duUserName :: Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
deleteUser
:: Text
-> DeleteUser
deleteUser pUserName_ = DeleteUser' {_duUserName = pUserName_}
duUserName :: Lens' DeleteUser Text
duUserName = lens _duUserName (\ s a -> s{_duUserName = a})
instance AWSRequest DeleteUser where
type Rs DeleteUser = DeleteUserResponse
request = postQuery iam
response = receiveNull DeleteUserResponse'
instance Hashable DeleteUser where
instance NFData DeleteUser where
instance ToHeaders DeleteUser where
toHeaders = const mempty
instance ToPath DeleteUser where
toPath = const "/"
instance ToQuery DeleteUser where
toQuery DeleteUser'{..}
= mconcat
["Action" =: ("DeleteUser" :: ByteString),
"Version" =: ("2010-05-08" :: ByteString),
"UserName" =: _duUserName]
data DeleteUserResponse =
DeleteUserResponse'
deriving (Eq, Read, Show, Data, Typeable, Generic)
deleteUserResponse
:: DeleteUserResponse
deleteUserResponse = DeleteUserResponse'
instance NFData DeleteUserResponse where