{-# 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 #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Network.AWS.IAM.UpdateUser -- Copyright : (c) 2013-2016 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Updates the name and\/or the path of the specified user. -- -- You should understand the implications of changing a user\'s path or name. For more information, see and in the /IAM User Guide/. -- -- To change a user name the requester must have appropriate permissions on both the source object and the target object. For example, to change Bob to Robert, the entity making the request must have permission on Bob and Robert, or must have permission on all (*). For more information about permissions, see . module Network.AWS.IAM.UpdateUser ( -- * Creating a Request updateUser , UpdateUser -- * Request Lenses , uuNewUserName , uuNewPath , uuUserName -- * Destructuring the Response , updateUserResponse , UpdateUserResponse ) 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 -- | /See:/ 'updateUser' smart constructor. data UpdateUser = UpdateUser' { _uuNewUserName :: !(Maybe Text) , _uuNewPath :: !(Maybe Text) , _uuUserName :: !Text } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'UpdateUser' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'uuNewUserName' -- -- * 'uuNewPath' -- -- * 'uuUserName' updateUser :: Text -- ^ 'uuUserName' -> UpdateUser updateUser pUserName_ = UpdateUser' { _uuNewUserName = Nothing , _uuNewPath = Nothing , _uuUserName = pUserName_ } -- | New name for the user. Include this parameter only if you\'re changing the user\'s name. uuNewUserName :: Lens' UpdateUser (Maybe Text) uuNewUserName = lens _uuNewUserName (\ s a -> s{_uuNewUserName = a}); -- | New path for the user. Include this parameter only if you\'re changing the user\'s path. uuNewPath :: Lens' UpdateUser (Maybe Text) uuNewPath = lens _uuNewPath (\ s a -> s{_uuNewPath = a}); -- | Name of the user to update. If you\'re changing the name of the user, this is the original user name. uuUserName :: Lens' UpdateUser Text uuUserName = lens _uuUserName (\ s a -> s{_uuUserName = a}); instance AWSRequest UpdateUser where type Rs UpdateUser = UpdateUserResponse request = postQuery iam response = receiveNull UpdateUserResponse' instance Hashable UpdateUser instance NFData UpdateUser instance ToHeaders UpdateUser where toHeaders = const mempty instance ToPath UpdateUser where toPath = const "/" instance ToQuery UpdateUser where toQuery UpdateUser'{..} = mconcat ["Action" =: ("UpdateUser" :: ByteString), "Version" =: ("2010-05-08" :: ByteString), "NewUserName" =: _uuNewUserName, "NewPath" =: _uuNewPath, "UserName" =: _uuUserName] -- | /See:/ 'updateUserResponse' smart constructor. data UpdateUserResponse = UpdateUserResponse' deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'UpdateUserResponse' with the minimum fields required to make a request. -- updateUserResponse :: UpdateUserResponse updateUserResponse = UpdateUserResponse' instance NFData UpdateUserResponse