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

Commit

Permalink
Removes checks for existing user home directory (#87)
Browse files Browse the repository at this point in the history
Removing the part of the code checking for the presence of a home directory for the authenticated user. This was dedicated for Jupyterhub running on a host machine before; however, we changed the implementation to containerized Jupyterhub which provisions a unified container for each user with its dedicated home dir.
  • Loading branch information
yassinkhalifa authored Oct 9, 2023
1 parent a4d7914 commit edd26f8
Show file tree
Hide file tree
Showing 3 changed files with 0 additions and 37 deletions.
1 change: 0 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,6 @@ Setting names and default values are provided in the table below:
| `username_header` | `"Cn"` | HTTP header name to inspect for the authenticated username - |
| `vpn_header` | `"isMemberOf"` | HTTP header name to inspect for the user VPN role(s). |
| `required_vpn_role` | `""` | Required VPN role for accessing the service. Ignored if an empty string. |
| `missing_user_redirect` | `""` | Redirect URL if the user has no home directory. Defaults to 404 if empty string. |
| `missing_role_redirect` | `""` | Redirect URL if the user is missing the required VPN header. Defaults to 404 if empty string. |

To modify a settings value, use the `c.Authenticator` object in the configuration file.
Expand Down
11 changes: 0 additions & 11 deletions crc_jupyter_auth/remote_user_auth.py
Original file line number Diff line number Diff line change
Expand Up @@ -48,12 +48,6 @@ def get(self):
self.redirect_or_raise(self.authenticator.missing_role_redirect)
return

# Check if the user has an existing home directory
user_home_dir = os.path.expanduser('~{}'.format(remote_user))
if not os.path.exists(user_home_dir):
self.redirect_or_raise(self.authenticator.missing_user_redirect)
return

# Facilitate user authentication
user = self.user_from_username(remote_user)
self.set_login_cookie(user)
Expand Down Expand Up @@ -100,11 +94,6 @@ class AuthenticatorSettings(HasTraits):
config=True,
help="Required VPN role for accessing the service.")

missing_user_redirect = Unicode(
default_value='',
config=True,
help="Url to redirect to if the user has no home directory.")

missing_role_redirect = Unicode(
default_value='',
config=True,
Expand Down
25 changes: 0 additions & 25 deletions tests/test_request_routing.py
Original file line number Diff line number Diff line change
Expand Up @@ -143,28 +143,3 @@ def test_incorrect_role_redirect(self, mock_redirect_call: MagicMock) -> None:
request_handler.get()

mock_redirect_call.assert_called_once_with(request_handler.authenticator.missing_role_redirect)


class RoutingByHomeDir(TestUtils, TestCase):
"""Test users without a home directory are redirect to the URL configured in settings"""

@patch('os.path.exists', lambda path: False)
@patch.object(RemoteUserLoginHandler, 'redirect', return_value=None)
def test_missing_home_dir_redirect(self, mock_redirect_call: MagicMock) -> None:
"""Test users are redirected to the ``missing_user_redirect`` URL if they do not have a home directory"""

request_handler = self.create_http_request_handler({AuthenticatorSettings().username_header: 'username'})
request_handler.authenticator.missing_user_redirect = 'www.google.com'
request_handler.get()

mock_redirect_call.assert_called_once_with(request_handler.authenticator.missing_user_redirect)

@patch('os.path.exists', lambda path: False)
def test_missing_home_dir_redirect_404(self) -> None:
"""Test a 404 is raised when ``missing_user_redirect`` is configured to a blank string"""

request_handler = self.create_http_request_handler({AuthenticatorSettings().username_header: 'username'})
with self.assertRaises(web.HTTPError) as http_exception:
request_handler.get()

self.assertEqual(404, http_exception.exception.status_code)

0 comments on commit edd26f8

Please sign in to comment.