Ensure AWS IAM users have no more than one active Access Key
Each IAM user can have up to two access keys. Having two access keys (instead of one), increases the risk of unauthorized access and compromise of credentials. It is also recommended to delete unused access keys.
Risk Level: High
Cloud Entity: IAM User
CloudGuard Rule ID: D9.AWS.IAM.51
Category: Security, Identity, & Compliance
GSL LOGIC
IamUser should not have firstAccessKey.isActive=true and secondAccessKey.isActive=true
REMEDIATION
From Portal
Perform the following to delete or disable active root access keys being Via the AWS Console :
- Sign in to the AWS Management Console as Root and open the IAM console at https://console.aws.amazon.com/iam/.
- Click Users in the navigation pane
- For the identified IAM user which has two active Access Keys, based on policies of your company, take appropriate action
- Delete one of the unused Access Keys
From TF
resource "aws_iam_access_key" "positive1" {
+ user = "root"
- id = "some_id_that_exists"
+ status = "Inactive"
}
From Command Line
To disable one of the active access keys, run:
aws iam update-access-key --access-key-id ACCESS_KEY_ID --status Inactive --user-name USERNAME
References
- https://docs.aws.amazon.com/config/latest/developerguide/operational-best-practices-for-cis_aws_benchmark_level_1.html
- https://d0.awsstatic.com/whitepapers/compliance/AWS_CIS_Foundations_Benchmark.pdf
- https://docs.aws.amazon.com/general/latest/gr/aws-sec-cred-types.html#access-keys-and-secret-access-keys
- https://docs.aws.amazon.com/cli/latest/reference/iam/delete-access-key.html
IAM User
An IAM user is an entity that you create in AWS to represent the person or service that uses it to interact with AWS. A user in AWS consists of a name and credentials.
Compliance Frameworks
- AWS CIS Foundations v. 1.3.0
- AWS CIS Foundations v. 1.4.0
- AWS CIS Foundations v. 1.5.0
- AWS CloudGuard Best Practices
- AWS CloudGuard SOC2 based on AICPA TSC 2017
- AWS CloudGuard Well Architected Framework
- AWS HITRUST
- AWS HITRUST v11.0.0
- AWS MAS TRM Framework
- AWS MITRE ATT&CK Framework v10
- AWS MITRE ATT&CK Framework v11.3
- AWS NIST 800-53 Rev 5
- AWS Security Risk Management
Updated about 1 year ago