From f493b964053bd452cb61bff08202d342075af1c8 Mon Sep 17 00:00:00 2001 From: Mark Tripod Date: Wed, 29 Nov 2023 13:21:26 -0500 Subject: [PATCH] doc: add report_user_by_email.py to examples --- examples/report_user_by_email.py | 53 ++++++++++++++++++++++++++++++++ 1 file changed, 53 insertions(+) create mode 100755 examples/report_user_by_email.py diff --git a/examples/report_user_by_email.py b/examples/report_user_by_email.py new file mode 100755 index 0000000..8704772 --- /dev/null +++ b/examples/report_user_by_email.py @@ -0,0 +1,53 @@ +#!/usr/bin/env python + +""" Script to illustrate how to retrieve a user from the Duo Admin API using the associated email address""" + +from __future__ import absolute_import, print_function +import sys +import getpass +from pprint import pprint + +import duo_client +from six.moves import input + +argv_iter = iter(sys.argv[1:]) + + +def get_next_arg(prompt, secure=False): + """Read information from STDIN, using getpass when sensitive information should not be echoed to tty""" + try: + return next(argv_iter) + except StopIteration: + if secure is True: + return getpass.getpass(prompt) + else: + return input(prompt) + + +def main(): + """ Primary script execution code """ + # Configuration and information about objects to create. + admin_api = duo_client.Admin( + ikey=get_next_arg('Admin API integration key ("DI..."): '), + skey=get_next_arg('integration secret key: ', secure=True), + host=get_next_arg('API hostname ("api-....duosecurity.com"): '), + ) + + # Retrieve user info from API: + email_address = get_next_arg('E-mail address of user to retrieve: ') + req_params = {"email": email_address} + # There is no get_user_by_email in the duo_client_python library, so we use the generic api_call + user = admin_api.json_api_call( + method='GET', + path='/admin/v1/users', + params=req_params + ) + + if user: + pprint(user, indent=2) + else: + print(f"User with email [{email_address}] could not be found.") + + +if __name__ == '__main__': + main()