Skip to content

Commit

Permalink
Merge pull request ansible-collections#1761 from alinabuzachis/promot…
Browse files Browse the repository at this point in the history
…e_iam_mfa_device_info

Promote iam_mfa_device_info
  • Loading branch information
gravesm authored Oct 9, 2023
2 parents af2c7d6 + 2656318 commit bb742a5
Show file tree
Hide file tree
Showing 3 changed files with 109 additions and 0 deletions.
4 changes: 4 additions & 0 deletions changelogs/fragments/migrate_iam_mfa_device_info.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
major_changes:
- iam_mfa_device_info - The module has been migrated from the ``community.aws`` collection.
Playbooks using the Fully Qualified Collection Name for this module should be updated
to use ``amazon.aws.iam_mfa_device_info`` (https://github.com/ansible-collections/amazon.aws/pull/1761).
1 change: 1 addition & 0 deletions meta/runtime.yml
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,7 @@ action_groups:
- iam_instance_profile
- iam_instance_profile_info
- iam_managed_policy
- iam_mfa_device_info
- iam_policy
- iam_policy_info
- iam_role
Expand Down
104 changes: 104 additions & 0 deletions plugins/modules/iam_mfa_device_info.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,104 @@
#!/usr/bin/python
# -*- coding: utf-8 -*-

# Copyright: Ansible Project
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)

DOCUMENTATION = r"""
---
module: iam_mfa_device_info
version_added: 1.0.0
version_added_collection: community.aws
short_description: List the MFA (Multi-Factor Authentication) devices registered for a user
description:
- List the MFA (Multi-Factor Authentication) devices registered for a user
author:
- Victor Costan (@pwnall)
options:
user_name:
description:
- The name of the user whose MFA devices will be listed
type: str
extends_documentation_fragment:
- amazon.aws.common.modules
- amazon.aws.region.modules
- amazon.aws.boto3
"""

RETURN = r"""
mfa_devices:
description: The MFA devices registered for the given user
returned: always
type: list
sample:
- enable_date: "2016-03-11T23:25:36+00:00"
serial_number: arn:aws:iam::123456789012:mfa/example
user_name: example
- enable_date: "2016-03-11T23:25:37+00:00"
serial_number: arn:aws:iam::123456789012:mfa/example
user_name: example
"""

EXAMPLES = r"""
# Note: These examples do not set authentication details, see the AWS Guide for details.
# more details: https://docs.aws.amazon.com/IAM/latest/APIReference/API_ListMFADevices.html
- name: List MFA devices
amazon.aws.iam_mfa_device_info:
register: mfa_devices
# more details: https://docs.aws.amazon.com/STS/latest/APIReference/API_AssumeRole.html
- name: Assume an existing role
community.aws.sts_assume_role:
mfa_serial_number: "{{ mfa_devices.mfa_devices[0].serial_number }}"
role_arn: "arn:aws:iam::123456789012:role/someRole"
role_session_name: "someRoleSession"
register: assumed_role
"""

try:
import botocore
from botocore.exceptions import ClientError
except ImportError:
pass # Handled by AnsibleAWSModule

from ansible.module_utils.common.dict_transformations import camel_dict_to_snake_dict

from ansible_collections.amazon.aws.plugins.module_utils.modules import AnsibleAWSModule


def list_mfa_devices(connection, module):
user_name = module.params.get("user_name")
changed = False

args = {}
if user_name is not None:
args["UserName"] = user_name
try:
response = connection.list_mfa_devices(**args)
except ClientError as e:
module.fail_json_aws(e, msg="Failed to list MFA devices")

module.exit_json(changed=changed, **camel_dict_to_snake_dict(response))


def main():
argument_spec = dict(
user_name=dict(required=False, default=None),
)

module = AnsibleAWSModule(
argument_spec=argument_spec,
supports_check_mode=True,
)

try:
connection = module.client("iam")
except (botocore.exceptions.ClientError, botocore.exceptions.BotoCoreError) as e:
module.fail_json_aws(e, msg="Failed to connect to AWS")

list_mfa_devices(connection, module)


if __name__ == "__main__":
main()

0 comments on commit bb742a5

Please sign in to comment.