IAM Users and Groups
Explore two ways of providing access to AWS resources using IAM.
Let’s now learn more about the IAM identities, starting with IAM users and IAM groups.
IAM user
An IAM user is an identity we can use to provide account access to an individual entity. It is used when we want to provide long-term credentials to an entity. Using the IAM user credentials, the principal entity can authenticate itself with AWS and log in to the account. However, by default, the IAM users cannot perform any function besides logging into the account. To authorize the user to perform the required actions, we attach the IAM policy with the IAM user. The policy defines the scope of permissions of the user. So, the IAM user identity handles user authentication, while the attached policy is responsible for authorization.
When to use IAM users
Here are a couple of scenarios where we can use IAM users:
Secure the root account
The main account that we create on AWS is a root account. It has all the privileges and can perform all sorts of operations. Using this account for day-to-day operations is not recommended, as it can be used to change the account settings. So, to start off, we should create an IAM user with administrative access and use that account instead of the root account. Here are some of the sensitive operations that can only be performed using the root account:
Change our account configurations
Modify our billing settings
Close our AWS account
These are very rarely used and very sensitive operations, so by using an IAM account instead of the root account, we restrict the use of these operations.
Provide access to principal entities
An organization usually consists of different operational units. For example, there can be admins, developers, QA, and many other departments. We can provide each of them with an IAM account with permission to perform only their respective tasks. By doing so, not only are we providing them with the required access but also making sure that they do not have permission to do anything out of their scope of work.
IAM user workflow
When creating an IAM user, we provide a username and a password for the user. The specific entity can then use these credentials to log in to the AWS account. Along with these basic credentials, we can use some other credentials for authentication. The choice of authentication credentials depends upon the type of access required. Aside from the username and password that we use to log in to the AWS console, the other credentials are as follows:
Access keys: These credentials are useful when we make programmatic calls to AWS. They consist of
AWS ACCESS ID
andAWS SECRET KEY
.SSH keys for use with CodeCommit: This is a public SSH key that can be used to authenticate with CodeCommit.
Server certificates: These are SSL/TLS certificates that we can use to authenticate with some AWS services.
When a request is made with any of these credentials, the request is examined by IAM. It first authenticates the principal entity and then evaluates the request contents against the policy associated with the IAM user. If the user is permitted to execute the action, IAM grants authorization to proceed with the request. Otherwise, the request is rejected, and an appropriate error statement is returned as the response.
IAM groups
An IAM group is a collection of IAM users. These groups are used when multiple users require the same type of authorization. In such a case, instead of attaching a policy with each of these users, we attach the required policy with a group and add the users to that group. By doing so, we provide the users with the required permissions in one go. This makes managing the policy much easier.
Consider an organization with multiple departments having more than one user in each department. Attaching policies with the IAM users for these roles will not only be time-consuming but also might lead to inconsistencies in policies for the same kind of roles. To cope up with this issue, we can create an IAM group for each of these departments, and then instead of adding policies with the users, we can add the users in their respective groups.
Note: IAM groups cannot be used for authentication.
We can add a user in multiple groups. In such a scenario, the user will have permissions allowed to all the associated groups. Groups, however, cannot be cascaded.
Get hands-on with 1300+ tech skills courses.