Skip to content
This repository has been archived by the owner on Apr 26, 2024. It is now read-only.

Parse ui_auth.session_timeout as a duration (instead of treating it as ms) #9426

Merged
merged 13 commits into from
Feb 18, 2021
Merged
1 change: 1 addition & 0 deletions changelog.d/9426.bugfix
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
The `ui_auth.session_timeout` configuration setting can now be specified in terms of number of seconds/minutes/etc/. Contributed by Rishabh Arya.
6 changes: 3 additions & 3 deletions docs/sample_config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -2228,8 +2228,8 @@ password_config:
#require_uppercase: true

ui_auth:
# The number of milliseconds to allow a user-interactive authentication
# session to be active.
# The amount of time to allow a user-interactive authentication session
# to be active.
#
# This defaults to 0, meaning the user is queried for their credentials
# before every action, but this can be overridden to allow a single
Expand All @@ -2240,7 +2240,7 @@ ui_auth:
# Uncomment below to allow for credential validation to last for 15
# seconds.
#
#session_timeout: 15000
#session_timeout: "15s"


# Configuration for sending emails from Synapse.
Expand Down
10 changes: 6 additions & 4 deletions synapse/config/auth.py
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,9 @@ def read_config(self, config, **kwargs):

# User-interactive authentication
ui_auth = config.get("ui_auth") or {}
self.ui_auth_session_timeout = ui_auth.get("session_timeout", 0)
self.ui_auth_session_timeout = self.parse_duration(
ui_auth.get("session_timeout", 0)
)

def generate_config_section(self, config_dir_path, server_name, **kwargs):
return """\
Expand Down Expand Up @@ -93,8 +95,8 @@ def generate_config_section(self, config_dir_path, server_name, **kwargs):
#require_uppercase: true

ui_auth:
# The number of milliseconds to allow a user-interactive authentication
# session to be active.
# The amount of time to allow a user-interactive authentication session
# to be active.
#
# This defaults to 0, meaning the user is queried for their credentials
# before every action, but this can be overridden to allow a single
Expand All @@ -105,5 +107,5 @@ def generate_config_section(self, config_dir_path, server_name, **kwargs):
# Uncomment below to allow for credential validation to last for 15
# seconds.
#
#session_timeout: 15000
#session_timeout: "15s"
"""
2 changes: 1 addition & 1 deletion tests/rest/client/v2_alpha/test_auth.py
Original file line number Diff line number Diff line change
Expand Up @@ -343,7 +343,7 @@ def test_cannot_change_uri(self):
},
)

@unittest.override_config({"ui_auth": {"session_timeout": 5 * 1000}})
@unittest.override_config({"ui_auth": {"session_timeout": "5s"}})
def test_can_reuse_session(self):
"""
The session can be reused if configured.
Expand Down