This repository was archived by the owner on Mar 27, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 10
This repository was archived by the owner on Mar 27, 2023. It is now read-only.
Deleting Hospitals from Approval page only deletes Hospital Model #542
Copy link
Copy link
Open
Labels
bugSomething isn't workingSomething isn't workingcontributionIssues opened from outside contributors :)Issues opened from outside contributors :)
Description
Describe the bug
When a staff member deletes an approval request only the hospital model object is deleted, the useraccount is still active. This leads to Error 500 when the user later logs in and tries to access any hospital related function, as the hospital cannot be found.
To Reproduce
Steps to reproduce the behavior:
- Create a new Facility User
- As a staff user, delete User from (1)
- Log on as User from (1) and open the profile page
- See error
Expected behavior
To be discussed, I think it might be a good idea to just set is_hospital to false. This way the user will still be able to login and get an error message. Otherwise they will probably just sign in again.
Log output
{
"status_code": 500,
"request": {
"path": "/ineedstudent/hospital_dashboard",
"method": "GET",
"get": {}
},
"level": "error",
"message": "[django.request]: Internal Server Error: /ineedstudent/hospital_dashboard",
"timestamp": "2020-07-22T09:06:27.287370",
"user": "***",
"exc_info": "Traceback (most recent call last):
File \"/usr/local/lib/python3.6/dist-packages/django/core/handlers/exception.py\", line 34, in inner
response = get_response(request)
File \"/usr/local/lib/python3.6/dist-packages/django/core/handlers/base.py\", line 115, in _get_response
response = self.process_exception_by_middleware(e, request)
File \"/usr/local/lib/python3.6/dist-packages/django/core/handlers/base.py\", line 113, in _get_response
response = wrapped_callback(request, *callback_args, **callback_kwargs)
File \"/usr/local/lib/python3.6/dist-packages/django/contrib/auth/decorators.py\", line 21, in _wrapped_view
return view_func(request, *args, **kwargs)
File \"/usr/local/lib/python3.6/dist-packages/django/contrib/auth/decorators.py\", line 21, in _wrapped_view
return view_func(request, *args, **kwargs)
File \"/match4healthcare-backend/apps/ineedstudent/views.py\", line 228, in hospital_dashboard
qs = request.user.hospital.emailtosend_set.all().values(
File \"/usr/local/lib/python3.6/dist-packages/django/utils/functional.py\", line 225, in inner
return func(self._wrapped, *args)
File \"/usr/local/lib/python3.6/dist-packages/django/db/models/fields/related_descriptors.py\", line 423, in get
self.related.get_accessor_name()
apps.accounts.models.User.hospital.RelatedObjectDoesNotExist: User has no hospital."
}
{
"status_code": 500,
"request": {
"path": "/accounts/profile_hospital",
"method": "GET",
"get": {}
},
"level": "error",
"message": "[django.request]: Internal Server Error: /accounts/profile_hospital",
"timestamp": "2020-07-22T09:06:44.151089",
"user": "***",
"exc_info": "Traceback (most recent call last):
File \"/usr/local/lib/python3.6/dist-packages/django/core/handlers/exception.py\", line 34, in inner
response = get_response(request)
File \"/usr/local/lib/python3.6/dist-packages/django/core/handlers/base.py\", line 115, in _get_response
response = self.process_exception_by_middleware(e, request)
File \"/usr/local/lib/python3.6/dist-packages/django/core/handlers/base.py\", line 113, in _get_response
response = wrapped_callback(request, *callback_args, **callback_kwargs)
File \"/usr/local/lib/python3.6/dist-packages/django/contrib/auth/decorators.py\", line 21, in _wrapped_view
return view_func(request, *args, **kwargs)
File \"/usr/local/lib/python3.6/dist-packages/django/contrib/auth/decorators.py\", line 21, in _wrapped_view
return view_func(request, *args, **kwargs)
File \"/match4healthcare-backend/apps/accounts/views.py\", line 195, in edit_hospital_profile
hospital = request.user.hospital
File \"/usr/local/lib/python3.6/dist-packages/django/utils/functional.py\", line 225, in inner
return func(self._wrapped, *args)
File \"/usr/local/lib/python3.6/dist-packages/django/db/models/fields/related_descriptors.py\", line 423, in get
self.related.get_accessor_name()
apps.accounts.models.User.hospital.RelatedObjectDoesNotExist: User has no hospital."
}
match4healthcare=# \x on
Expanded display is on.
match4healthcare=# select * from accounts_user where email = '***';
-[ RECORD 1 ]---------+-------------------------------------------------------------------------------
id | 99999999
password | ***
last_login | 2020-07-22 09:06:26.35629+00
is_superuser | f
username | ***
first_name |
last_name |
email | ***
is_staff | f
is_active | t
date_joined | 2020-07-16 12:01:19.740697+00
is_student | f
is_hospital | t
validated_email | t
email_validation_date | 2020-07-22 09:06:26.651782+00
match4healthcare=# select * from ineedstudent_hospital where user_id = 99999999;
(0 rows)
match4healthcare=#
Desktop (please complete the following information):
Smartphone (please complete the following information):
All affected
Additional context
- none
Metadata
Metadata
Assignees
Labels
bugSomething isn't workingSomething isn't workingcontributionIssues opened from outside contributors :)Issues opened from outside contributors :)