Table: aws_iam_account_password_policy - Query AWS IAM Account Password Policies using SQL
The AWS Identity and Access Management (IAM) Account Password Policy is a resource that allows you to manage the password policy for your AWS account. This includes settings like the minimum password length, whether to require symbols, numbers, or uppercase letters, and whether to allow users to change their own password. It can help you enforce strong password practices in your organization.
Table Usage Guide
The aws_iam_account_password_policy
table in Steampipe provides you with information about IAM account password policies within AWS Identity and Access Management (IAM). This table enables you, as a DevOps engineer, to query password policy-specific details, including minimum password length, password expiration period, and whether it requires at least one number or symbol. You can utilize this table to gather insights on password policies, such as password complexity requirements, password rotation policies, and more. The schema outlines the various attributes of the IAM account password policy, including the option for users to change password, hard expiry, and password reuse prevention.
Important Notes
- For more information about using a password policy, you can visit Managing an IAM Password Policy.
Examples
List the password policy for the account
Gain insights into your AWS account's security by examining its password policy. This query can help you understand the strength and complexity requirements of your passwords, which can aid in enhancing your account's security.
select allow_users_to_change_password, expire_passwords, hard_expiry, max_password_age, minimum_password_length, password_reuse_prevention, require_lowercase_characters, require_numbers, require_symbols, require_uppercase_charactersfrom aws_iam_account_password_policy;
select allow_users_to_change_password, expire_passwords, hard_expiry, max_password_age, minimum_password_length, password_reuse_prevention, require_lowercase_characters, require_numbers, require_symbols, require_uppercase_charactersfrom aws_iam_account_password_policy;
Ensure IAM password policy requires at least one uppercase letter (CIS v1.1.05)
Determine whether your AWS IAM account password policy mandates the inclusion of at least one uppercase letter, to ensure enhanced security and compliance with CIS v1.1.05 standards.
select require_uppercase_charactersfrom aws_iam_account_password_policy;
select require_uppercase_charactersfrom aws_iam_account_password_policy;
Ensure IAM password policy requires at least one lowercase letter (CIS v1.1.06)
Determine the areas in which your AWS IAM password policy mandates the inclusion of at least one lowercase letter. This query is useful for ensuring your password policy aligns with the CIS v1.1.06 benchmark, enhancing system security.
select require_lowercase_charactersfrom aws_iam_account_password_policy;
select require_lowercase_charactersfrom aws_iam_account_password_policy;
Ensure IAM password policy requires at least one symbol (CIS v1.1.07)
Determine the areas in which your AWS IAM account password policy mandates the inclusion of at least one symbol. This can be useful in enhancing the security of your system by enforcing stronger password requirements.
select require_symbolsfrom aws_iam_account_password_policy;
select require_symbolsfrom aws_iam_account_password_policy;
Ensure IAM password policy require at least one number (CIS v1.1.08)
Determine the areas in which your AWS IAM password policy mandates the inclusion of at least one numerical digit, which is a recommended security measure according to CIS v1.1.08.
select require_numbersfrom aws_iam_account_password_policy;
select require_numbersfrom aws_iam_account_password_policy;
Ensure IAM password policy requires minimum length of 14 or greater (CIS v1.1.09)
Determine the areas in which your AWS IAM account password policy adheres to the CIS v1.1.09 standard, which requires a minimum password length of 14 or greater. This query can help enhance security by ensuring password complexity.
select minimum_password_length >= 14from aws_iam_account_password_policy;
select minimum_password_length >= 14 as 'minimum_password_length'from aws_iam_account_password_policy;
Ensure IAM password policy prevents password reuse (CIS v1.1.10)
Determine the areas in which your AWS IAM password policy restricts reusing old passwords. This is crucial to reinforce security measures and mitigate the risk of unauthorized access.
select password_reuse_preventionfrom aws_iam_account_password_policy;
select password_reuse_preventionfrom aws_iam_account_password_policy;
Ensure IAM password policy expires passwords within 90 days or less (CIS v1.1.11)
Assess the elements within your AWS IAM account password policy to ensure that passwords expire within a 90-day period. This is crucial for maintaining a robust security posture and aligning with CIS benchmark recommendations.
select ( expire_passwords and max_password_age <= 90 )from aws_iam_account_password_policy;
select ( expire_passwords = 1 and max_password_age <= 90 )from aws_iam_account_password_policy;
Control examples
- All Controls > IAM > Password policies for IAM users should have strong configurations with minimum length of 8 or greater
- AWS Foundational Security Best Practices > IAM > 7 Password policies for IAM users should have strong configurations
- CIS v1.2.0 > 1 Identity and Access Management > 1.10 Ensure IAM password policy prevents password reuse
- CIS v1.2.0 > 1 Identity and Access Management > 1.11 Ensure IAM password policy expires passwords within 90 days or less
- CIS v1.2.0 > 1 Identity and Access Management > 1.5 Ensure IAM password policy requires at least one uppercase letter
- CIS v1.2.0 > 1 Identity and Access Management > 1.6 Ensure IAM password policy require at least one lowercase letter
- CIS v1.2.0 > 1 Identity and Access Management > 1.7 Ensure IAM password policy require at least one symbol
- CIS v1.2.0 > 1 Identity and Access Management > 1.8 Ensure IAM password policy require at least one number
- CIS v1.2.0 > 1 Identity and Access Management > 1.9 Ensure IAM password policy requires minimum length of 14 or greater
- CIS v1.3.0 > 1 Identity and Access Management > 1.8 Ensure IAM password policy requires minimum length of 14 or greater
- CIS v1.3.0 > 1 Identity and Access Management > 1.9 Ensure IAM password policy prevents password reuse
- CIS v1.4.0 > 1 Identity and Access Management > 1.8 Ensure IAM password policy requires minimum length of 14 or greater
- CIS v1.4.0 > 1 Identity and Access Management > 1.9 Ensure IAM password policy prevents password reuse
- CIS v1.5.0 > 1 Identity and Access Management > 1.8 Ensure IAM password policy requires minimum length of 14 or greater
- CIS v1.5.0 > 1 Identity and Access Management > 1.9 Ensure IAM password policy prevents password reuse
- CIS v2.0.0 > 1 Identity and Access Management > 1.8 Ensure IAM password policy requires minimum length of 14 or greater
- CIS v2.0.0 > 1 Identity and Access Management > 1.9 Ensure IAM password policy prevents password reuse
- CIS v3.0.0 > 1 Identity and Access Management > 1.8 Ensure IAM password policy requires minimum length of 14 or greater
- CIS v3.0.0 > 1 Identity and Access Management > 1.9 Ensure IAM password policy prevents password reuse
- CIS v4.0.0 > 1 Identity and Access Management > 1.8 Ensure IAM password policy requires minimum length of 14 or greater
- CIS v4.0.0 > 1 Identity and Access Management > 1.9 Ensure IAM password policy prevents password reuse
- Ensure IAM password policy expires passwords within 90 days or less
- Ensure IAM password policy prevents password reuse
- Ensure IAM password policy requires a minimum length of 14 or greater
- Ensure IAM password policy requires at least one lowercase letter
- Ensure IAM password policy requires at least one number
- Ensure IAM password policy requires at least one symbol
- Ensure IAM password policy requires at least one uppercase letter
- IAM password policies for users should have strong configurations
Schema for aws_iam_account_password_policy
Name | Type | Operators | Description |
---|---|---|---|
_ctx | jsonb | Steampipe context in JSON form. | |
account_id | text | =, !=, ~~, ~~*, !~~, !~~* | The AWS Account ID in which the resource is located. |
allow_users_to_change_password | boolean | Specifies whether IAM users are allowed to change their own password. | |
expire_passwords | boolean | Indicates whether passwords in the account expire. Returns true if MaxPasswordAge contains a value greater than 0. Returns false if MaxPasswordAge is 0 or not present. | |
hard_expiry | boolean | Specifies whether IAM users are prevented from setting a new password after. | |
max_password_age | bigint | The number of days that an IAM user password is valid. | |
minimum_password_length | bigint | Minimum length to require for IAM user passwords. | |
partition | text | The AWS partition in which the resource is located (aws, aws-cn, or aws-us-gov). | |
password_reuse_prevention | bigint | Specifies the number of previous passwords that IAM users are prevented from reusing. | |
region | text | The AWS Region in which the resource is located. | |
require_lowercase_characters | boolean | Specifies whether to require lowercase characters for IAM user passwords. | |
require_numbers | boolean | Specifies whether to require numbers for IAM user passwords. | |
require_symbols | boolean | Specifies whether to require symbols for IAM user passwords. | |
require_uppercase_characters | boolean | Specifies whether to require uppercase characters for IAM user passwords. | |
sp_connection_name | text | =, !=, ~~, ~~*, !~~, !~~* | Steampipe connection name. |
sp_ctx | jsonb | Steampipe context in JSON form. |
Export
This table is available as a standalone Exporter CLI. Steampipe exporters are stand-alone binaries that allow you to extract data using Steampipe plugins without a database.
You can download the tarball for your platform from the Releases page, but it is simplest to install them with the steampipe_export_installer.sh
script:
/bin/sh -c "$(curl -fsSL https://steampipe.io/install/export.sh)" -- aws
You can pass the configuration to the command with the --config
argument:
steampipe_export_aws --config '<your_config>' aws_iam_account_password_policy