2022-10-06 16:46:51 -04:00
// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
// SPDX-License-Identifier: Apache-2.0
/**
* Before running this C++ code example, set up your development environment, including your credentials.
*
* For more information, see the following documentation topic:
2022-10-14 09:27:14 -04:00
* https://docs.aws.amazon.com/sdk-for-cpp/v1/developer-guide/getting-started.html.
2022-10-06 16:46:51 -04:00
*
2022-10-12 14:52:10 -04:00
* For information on the structure of the code examples and how to build and run the examples, see
* https://docs.aws.amazon.com/sdk-for-cpp/v1/developer-guide/getting-started-code-examples.html.
*
2022-10-06 16:46:51 -04:00
* Purpose
*
* Demonstrates deleting an IAM user.
2022-10-20 15:00:56 -04:00
* This API only works for users with no associated resources, such as groups and policies.
2022-10-14 09:27:14 -04:00
* To delete a user in the non-trivial case, use the DeleteUser operation within the
2022-10-20 15:00:56 -04:00
* aws-cpp-sdk-access-management high-level SDK.
2022-10-06 16:46:51 -04:00
*
*/
2022-10-07 15:58:01 -04:00
// snippet-start:[iam.cpp.delete_user.inc]
# include <aws/core/Aws.h>
# include <aws/iam/IAMClient.h>
# include <aws/iam/model/DeleteUserRequest.h>
# include <aws/iam/model/GetUserRequest.h>
# include <aws/iam/model/GetUserResult.h>
# include <iostream>
# include "iam_samples.h"
// snippet-end:[iam.cpp.delete_user.inc]
//! Deletes an IAM user.
2022-10-06 16:46:51 -04:00
/*!
2022-10-07 15:58:01 -04:00
\sa deleteUser()
\param userName: The user name.
2022-10-06 16:46:51 -04:00
\param clientConfig: Aws client configuration.
\return bool: Successful completion.
*/
2022-10-07 15:58:01 -04:00
bool AwsDoc : : IAM : : deleteUser ( const Aws : : String & userName ,
const Aws : : Client : : ClientConfiguration & clientConfig ) {
2021-11-15 13:15:43 +00:00
// snippet-start:[iam.cpp.delete_user01.code]
2022-10-07 15:58:01 -04:00
Aws : : IAM : : IAMClient iam ( clientConfig ) ;
2021-11-15 13:15:43 +00:00
// snippet-end:[iam.cpp.delete_user01.code]
Aws : : IAM : : Model : : GetUserRequest get_request ;
2022-10-07 15:58:01 -04:00
get_request . SetUserName ( userName ) ;
2021-11-15 13:15:43 +00:00
auto get_outcome = iam . GetUser ( get_request ) ;
2022-10-07 15:58:01 -04:00
if ( ! get_outcome . IsSuccess ( ) ) {
2021-11-15 13:15:43 +00:00
if ( get_outcome . GetError ( ) . GetErrorType ( ) = =
2022-10-07 15:58:01 -04:00
Aws : : IAM : : IAMErrors : : NO_SUCH_ENTITY ) {
std : : cout < < " IAM user " < < userName < < " does not exist " < <
std : : endl ;
2021-11-15 13:15:43 +00:00
}
2022-10-07 15:58:01 -04:00
else {
std : : cerr < < " Error checking existence of IAM user " < < userName < <
" : " < < get_outcome . GetError ( ) . GetMessage ( ) < < std : : endl ;
2021-11-15 13:15:43 +00:00
}
2022-10-07 15:58:01 -04:00
return false ;
2021-11-15 13:15:43 +00:00
}
// snippet-start:[iam.cpp.delete_user02.code]
Aws : : IAM : : Model : : DeleteUserRequest request ;
2022-10-07 15:58:01 -04:00
request . SetUserName ( userName ) ;
2021-11-15 13:15:43 +00:00
auto outcome = iam . DeleteUser ( request ) ;
2022-10-07 15:58:01 -04:00
if ( ! outcome . IsSuccess ( ) ) {
std : : cerr < < " Error deleting IAM user " < < userName < < " : " < <
outcome . GetError ( ) . GetMessage ( ) < < std : : endl ; ;
2021-11-15 13:15:43 +00:00
}
2022-10-07 15:58:01 -04:00
else {
std : : cout < < " Successfully deleted IAM user " < < userName < < std : : endl ;
}
return outcome . IsSuccess ( ) ;
2021-11-15 13:15:43 +00:00
// snippet-end:[iam.cpp.delete_user02.code]
}
2022-10-07 15:58:01 -04:00
/*
*
* main function
*
* Prerequisites: Existing IAM user name.
*
* Usage: 'run_delete_user <user_name>'
*
2021-11-15 13:15:43 +00:00
*/
2022-10-07 15:58:01 -04:00
# ifndef TESTING_BUILD
int main ( int argc , char * * argv ) {
if ( argc ! = 2 ) {
std : : cout < < " Usage: run_delete_user <user_name> " < < std : : endl ;
2021-11-15 13:15:43 +00:00
return 1 ;
}
Aws : : SDKOptions options ;
Aws : : InitAPI ( options ) ;
{
Aws : : String user_name ( argv [ 1 ] ) ;
2022-10-07 15:58:01 -04:00
Aws : : Client : : ClientConfiguration clientConfig ;
// Optional: Set to the AWS Region in which the bucket was created (overrides config file).
// clientConfig.region = "us-east-1";
AwsDoc : : IAM : : deleteUser ( user_name , clientConfig ) ;
2021-11-15 13:15:43 +00:00
}
Aws : : ShutdownAPI ( options ) ;
return 0 ;
}
2022-10-07 15:58:01 -04:00
# endif // TESTING_BUILD