From 0d3b5eccebd927351ceb8ddb94bf3dd61da7fb5a Mon Sep 17 00:00:00 2001 From: William Juang Date: Tue, 30 Jan 2024 09:44:48 -0600 Subject: [PATCH 1/2] Add unenrolled user lockout setting to adminapi (#249) --- duo_client/admin.py | 7 +++++++ tests/admin/test_settings.py | 8 +++++++- 2 files changed, 14 insertions(+), 1 deletion(-) diff --git a/duo_client/admin.py b/duo_client/admin.py index d01163e..490e14b 100644 --- a/duo_client/admin.py +++ b/duo_client/admin.py @@ -114,6 +114,7 @@ 'user_managers_can_put_users_in_bypass': , 'email_activity_notification_enabled': , 'push_activity_notification_enabled': , + 'unenrolled_user_lockout_threshold': , } @@ -1985,6 +1986,7 @@ def update_settings(self, user_managers_can_put_users_in_bypass=None, email_activity_notification_enabled=None, push_activity_notification_enabled=None, + unenrolled_user_lockout_threshold=None, ): """ Update settings. @@ -2026,6 +2028,7 @@ def update_settings(self, user_managers_can_put_users_in_bypass - True|False|None email_activity_notification_enabled = True|False|None push_activity_notification_enabled = True|False|None + unenrolled_user_lockout_threshold = |0|None Returns updated settings object. @@ -2109,6 +2112,10 @@ def update_settings(self, params['push_activity_notification_enabled'] = ( '1' if push_activity_notification_enabled else '0' ) + if unenrolled_user_lockout_threshold is not None: + params['unenrolled_user_lockout_threshold'] = str( + unenrolled_user_lockout_threshold + ) if not params: raise TypeError("No settings were provided") diff --git a/tests/admin/test_settings.py b/tests/admin/test_settings.py index b92ffb1..908fec5 100644 --- a/tests/admin/test_settings.py +++ b/tests/admin/test_settings.py @@ -40,7 +40,10 @@ def test_update_settings(self): reactivation_url="https://www.example.com", reactivation_integration_key='DINTEGRATIONKEYTEST0', security_checkup_enabled=True, - user_managers_can_put_users_in_bypass=False + user_managers_can_put_users_in_bypass=False, + email_activity_notification_enabled=True, + push_activity_notification_enabled=True, + unenrolled_user_lockout_threshold=100, ) response = response[0] self.assertEqual(response['method'], 'POST') @@ -79,4 +82,7 @@ def test_update_settings(self): 'reactivation_integration_key': 'DINTEGRATIONKEYTEST0', 'security_checkup_enabled': '1', 'user_managers_can_put_users_in_bypass': '0', + 'email_activity_notification_enabled': '1', + 'push_activity_notification_enabled': '1', + 'unenrolled_user_lockout_threshold': '100', }) From d4c011a7258283a91225fc05cb196d3e7d1c1203 Mon Sep 17 00:00:00 2001 From: Jeffrey Parker Date: Wed, 7 Feb 2024 14:37:35 -0500 Subject: [PATCH 2/2] Add child_api_host to AccountAdmin tests to fix failing tests (#250) --- tests/accountAdmin/base.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/accountAdmin/base.py b/tests/accountAdmin/base.py index 882e404..ebc0eda 100644 --- a/tests/accountAdmin/base.py +++ b/tests/accountAdmin/base.py @@ -6,7 +6,7 @@ class TestAccountAdmin(unittest.TestCase): def setUp(self): - kwargs = {'ikey': 'test_ikey', 'skey': 'test_skey', 'host': 'example.com'} + kwargs = {'ikey': 'test_ikey', 'skey': 'test_skey', 'host': 'example.com', 'child_api_host': 'example2.com'} self.client = duo_client.admin.AccountAdmin( 'DA012345678901234567', **kwargs) # monkeypatch client's _connect()