aws_iam_users resource
Use the aws_iam_users InSpec audit resource to test properties of some or all AWS IAM Users.
Syntax
An aws_iam_users resource block returns all IAM Users and allows the testing of that group of Users.
describe aws_iam_users do
  its('usernames') { should include 'payroll-admin' }
end
Parameters
This resource does not expect any parameters.
See also the AWS documentation on IAM Users.
Properties
| Property | Description | 
|---|---|
| usernames | The usernames of the returned Users. | 
| user_arns | The Amazon Resource Names of the returned Users. | 
| user_ids | The IDs of the returned Users. | 
| access_keys | Array of Access Keys belonging to each User. | 
| has_attached_policies | Whether or not the User has IAM Policies attached. | 
| attached_policy_names | The names (if any) of the IAM Policies attached to the User. | 
| attached_policy_arns | The Amazon Resource Names (if any) of the IAM Policies attached to the User. | 
| has_console_password | Whether or not the User has a console password set. | 
| has_inline_policies | Boolean indicating whether or not the User has policies set directly on them. | 
| inline_policy_names | The names of the policies (if any) which are directly on the User. | 
| has_mfa_enabled | Boolean indicating whether the User has MFA enabled or not. | 
| password_ever_used? | Whether the user has even used their console password. | 
| password_last_used_days_ago | How long ago, in days, since the user last used their console password. Returns -1if the password has never been used. | 
| entries | Provides access to the raw results of the query, which can be treated as an array of hashes. | 
Examples
Ensure there are no Users who do not have MFA enabled.
describe aws_iam_users.where( has_mfa_enabled: false) do
  it { should_not exist }
end
Ensure there are no Users with inline policies
describe aws_iam_users.where(has_inline_policies: true) do
  its('usernames') { should be_empty }
end
Ensure there are no Users with attached policies
describe aws_iam_users.where(has_attached_policies: true) do
  its('usernames') { should be_empty }
end
Matchers
For a full list of available matchers, please visit our matchers page.
exist
The control will pass if the describe returns at least one result.
Use should_not to test the entity should not exist.
describe aws_iam_users.where( <property>: <value>) do
  it { should exist }
end
describe aws_iam_users.where( <property>: <value>) do
  it { should_not exist }
end
AWS Permissions
Your Principal will need the following permissions set to Allow: iam:GetLoginProfile iam:ListUsers iam:ListMFADevices iam:ListAccessKeys iam:ListUserPolicies iam:ListAttachedUserPolicies
    © Chef Software, Inc.
Licensed under the Creative Commons Attribution 3.0 Unported License.
The Chef™ Mark and Chef Logo are either registered trademarks/service marks or trademarks/servicemarks of Chef, in the United States and other countries and are used with Chef Inc's permission.
We are not affiliated with, endorsed or sponsored by Chef Inc.
    https://docs.chef.io/inspec/resources/aws_iam_users/