Merge branch 'release' into encrypt2
This commit is contained in:
commit
2f0c344a57
|
@ -150,6 +150,7 @@ class DashboardTable(tables.Table):
|
||||||
model = Event
|
model = Event
|
||||||
template_name = "idhub/custom_table.html"
|
template_name = "idhub/custom_table.html"
|
||||||
fields = ("type", "message", "created")
|
fields = ("type", "message", "created")
|
||||||
|
empty_text = "No events available"
|
||||||
|
|
||||||
|
|
||||||
class CredentialTable(tables.Table):
|
class CredentialTable(tables.Table):
|
||||||
|
|
|
@ -127,6 +127,36 @@ class DashboardView(AdminView, SingleTableView):
|
||||||
section = "Home"
|
section = "Home"
|
||||||
model = Event
|
model = Event
|
||||||
|
|
||||||
|
def get_queryset(self):
|
||||||
|
"""
|
||||||
|
Override the get_queryset method to filter events based on the user type.
|
||||||
|
"""
|
||||||
|
events_for_admins = self.get_admin_events()
|
||||||
|
return Event.objects.filter(type__in=events_for_admins)
|
||||||
|
|
||||||
|
def get_admin_events(self):
|
||||||
|
return [
|
||||||
|
Event.Types.EV_USR_REGISTERED, # User registered
|
||||||
|
Event.Types.EV_USR_UPDATED_BY_ADMIN, # User's data updated by admin
|
||||||
|
Event.Types.EV_USR_DELETED_BY_ADMIN, # User deactivated by admin
|
||||||
|
Event.Types.EV_DID_CREATED_BY_USER, # DID created by user
|
||||||
|
Event.Types.EV_CREDENTIAL_DELETED_BY_USER, # Credential deleted by user
|
||||||
|
Event.Types.EV_CREDENTIAL_ISSUED_FOR_USER, # Credential issued for user
|
||||||
|
Event.Types.EV_CREDENTIAL_PRESENTED_BY_USER, # Credential presented by user
|
||||||
|
Event.Types.EV_CREDENTIAL_ENABLED, # Credential enabled
|
||||||
|
Event.Types.EV_CREDENTIAL_REVOKED_BY_ADMIN, # Credential revoked by admin
|
||||||
|
Event.Types.EV_ROLE_CREATED_BY_ADMIN, # Role created by admin
|
||||||
|
Event.Types.EV_ROLE_MODIFIED_BY_ADMIN, # Role modified by admin
|
||||||
|
Event.Types.EV_ROLE_DELETED_BY_ADMIN, # Role deleted by admin
|
||||||
|
Event.Types.EV_SERVICE_CREATED_BY_ADMIN, # Service created by admin
|
||||||
|
Event.Types.EV_SERVICE_MODIFIED_BY_ADMIN, # Service modified by admin
|
||||||
|
Event.Types.EV_SERVICE_DELETED_BY_ADMIN, # Service deleted by admin
|
||||||
|
Event.Types.EV_ORG_DID_CREATED_BY_ADMIN, # Organisational DID created by admin
|
||||||
|
Event.Types.EV_ORG_DID_DELETED_BY_ADMIN, # Organisational DID deleted by admin
|
||||||
|
Event.Types.EV_USR_DEACTIVATED_BY_ADMIN, # User deactivated
|
||||||
|
Event.Types.EV_DATA_UPDATE_REQUESTED, # Data update requested. Pending approval by administrator
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
class People(AdminView):
|
class People(AdminView):
|
||||||
title = _("User management")
|
title = _("User management")
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
from django.urls import reverse
|
|
||||||
from django.test import TestCase, RequestFactory
|
from django.test import TestCase, RequestFactory
|
||||||
|
from django.urls import reverse
|
||||||
|
|
||||||
from idhub_auth.models import User
|
from idhub_auth.models import User
|
||||||
|
from idhub.models import Event
|
||||||
from idhub.admin.views import PeopleListView
|
from idhub.admin.views import PeopleListView
|
||||||
|
|
||||||
|
|
||||||
|
@ -59,6 +60,41 @@ class AdminDashboardViewTest(TestCase):
|
||||||
|
|
||||||
self.assertTemplateUsed(response, 'idhub/admin/dashboard.html')
|
self.assertTemplateUsed(response, 'idhub/admin/dashboard.html')
|
||||||
|
|
||||||
|
def test_admin_event_filtering(self):
|
||||||
|
# Create a test admin user
|
||||||
|
admin_user = User.objects.create_superuser(email='admin@example.org', password='test')
|
||||||
|
admin_user.accept_gdpr = True
|
||||||
|
admin_user.save()
|
||||||
|
self.client.login(email='admin@example.org', password='test')
|
||||||
|
|
||||||
|
# Create test events, including some that should not be visible to admins
|
||||||
|
Event.objects.create(type=Event.Types.EV_USR_REGISTERED, message="User registered")
|
||||||
|
Event.objects.create(type=Event.Types.EV_USR_WELCOME, message="User welcomed") # Should not appear
|
||||||
|
|
||||||
|
# Fetch the dashboard view
|
||||||
|
response = self.client.get('/admin/dashboard/')
|
||||||
|
events = response.context['event_list']
|
||||||
|
|
||||||
|
# Check that only admin-visible events are included
|
||||||
|
self.assertIn(Event.Types.EV_USR_REGISTERED, [event.type for event in events])
|
||||||
|
self.assertNotIn(Event.Types.EV_USR_WELCOME, [event.type for event in events])
|
||||||
|
|
||||||
|
def test_access_control_redirects_when_normal_user(self):
|
||||||
|
# Attempt to access the dashboard as a non-admin user
|
||||||
|
regular_user = User.objects.create_user(email='user', password='test')
|
||||||
|
self.client.login(email='user@example.org', password='test')
|
||||||
|
response = self.client.get('/admin/dashboard/')
|
||||||
|
self.assertEqual(response.status_code, 302) # Or 403 if not redirected
|
||||||
|
|
||||||
|
def test_access_control_accepted_when_admin(self):
|
||||||
|
# Access as an admin
|
||||||
|
admin_user = User.objects.create_superuser(email='admin@example.org', password='test')
|
||||||
|
admin_user.accept_gdpr=True
|
||||||
|
admin_user.save()
|
||||||
|
self.client.login(email='admin@example.org', password='test')
|
||||||
|
response = self.client.get('/admin/dashboard/')
|
||||||
|
self.assertEqual(response.status_code, 200)
|
||||||
|
|
||||||
|
|
||||||
class PeopleListViewTest(TestCase):
|
class PeopleListViewTest(TestCase):
|
||||||
|
|
||||||
|
@ -104,3 +140,67 @@ class PeopleListViewTest(TestCase):
|
||||||
|
|
||||||
# Assuming 2 users in the database
|
# Assuming 2 users in the database
|
||||||
self.assertEqual(queryset.count(), 2)
|
self.assertEqual(queryset.count(), 2)
|
||||||
|
|
||||||
|
|
||||||
|
class UserDashboardViewTests(TestCase):
|
||||||
|
def setUp(self):
|
||||||
|
# Create test users
|
||||||
|
self.admin_user = User.objects.create_superuser('admin@example.org', 'password')
|
||||||
|
self.admin_user.accept_gdpr=True
|
||||||
|
self.admin_user.save()
|
||||||
|
self.regular_user = User.objects.create_user('regular@example.org', 'password')
|
||||||
|
self.regular_user.accept_gdpr=True
|
||||||
|
self.regular_user.save()
|
||||||
|
|
||||||
|
# Create events visible to users
|
||||||
|
self.visible_events_types = [
|
||||||
|
Event.Types.EV_USR_WELCOME,
|
||||||
|
Event.Types.EV_USR_UPDATED,
|
||||||
|
Event.Types.EV_DID_CREATED,
|
||||||
|
Event.Types.EV_DID_DELETED,
|
||||||
|
Event.Types.EV_CREDENTIAL_DELETED,
|
||||||
|
Event.Types.EV_CREDENTIAL_ISSUED,
|
||||||
|
Event.Types.EV_CREDENTIAL_PRESENTED,
|
||||||
|
Event.Types.EV_CREDENTIAL_CAN_BE_REQUESTED,
|
||||||
|
Event.Types.EV_CREDENTIAL_REVOKED,
|
||||||
|
]
|
||||||
|
|
||||||
|
# Create events for both users
|
||||||
|
for event_type in self.visible_events_types:
|
||||||
|
Event.objects.create(type=event_type, message=f"Test event for {event_type.label}", user=self.regular_user)
|
||||||
|
|
||||||
|
# Create an event that should not be visible to a regular user
|
||||||
|
Event.objects.create(type=Event.Types.EV_USR_REGISTERED, message="Admin only event", user=self.regular_user)
|
||||||
|
|
||||||
|
def test_events_visibility_for_regular_user(self):
|
||||||
|
self.client.login(email='regular@example.org', password='password')
|
||||||
|
response = self.client.get(reverse('idhub:user_dashboard'))
|
||||||
|
# Ensure the response contains only the events that should be visible
|
||||||
|
for event in Event.objects.filter(user=self.regular_user, type__in=self.visible_events_types):
|
||||||
|
self.assertContains(response, event.message)
|
||||||
|
# Ensure the response does not contain the admin only event
|
||||||
|
self.assertNotContains(response, "Admin only event")
|
||||||
|
|
||||||
|
def test_no_events_for_regular_user(self):
|
||||||
|
# Delete all events for the setup user
|
||||||
|
Event.objects.filter(user=self.regular_user).delete()
|
||||||
|
self.client.login(email='regular@example.org', password='password')
|
||||||
|
response = self.client.get(reverse('idhub:user_dashboard'))
|
||||||
|
# Verify that the response indicates no events are available
|
||||||
|
self.assertContains(response, "No events available") # Adjust based on your actual no-events message
|
||||||
|
|
||||||
|
def test_events_visibility_for_new_user(self):
|
||||||
|
# Create a new user who has no events
|
||||||
|
new_user = User.objects.create_user('new@example.org', 'password')
|
||||||
|
new_user.accept_gdpr = True
|
||||||
|
new_user.save()
|
||||||
|
self.client.login(email='new@example.org', password='password')
|
||||||
|
response = self.client.get(reverse('idhub:user_dashboard'))
|
||||||
|
# Verify that the response correctly indicates no events for the new user
|
||||||
|
self.assertContains(response, "No events available") # Adjust based on your actual no-events message
|
||||||
|
|
||||||
|
def test_unauthorized_access(self):
|
||||||
|
# Attempt to access the dashboard without logging in
|
||||||
|
response = self.client.get(reverse('idhub:user_dashboard'), follow=True)
|
||||||
|
# Ensure the response redirects to the login page
|
||||||
|
self.assertTemplateUsed(response, 'auth/login.html')
|
||||||
|
|
|
@ -27,6 +27,7 @@ class DashboardTable(tables.Table):
|
||||||
model = Event
|
model = Event
|
||||||
template_name = "idhub/custom_table.html"
|
template_name = "idhub/custom_table.html"
|
||||||
fields = ("type", "message", "created")
|
fields = ("type", "message", "created")
|
||||||
|
empty_text="No events available"
|
||||||
|
|
||||||
|
|
||||||
class PersonalInfoTable(tables.Table):
|
class PersonalInfoTable(tables.Table):
|
||||||
|
|
|
@ -63,11 +63,26 @@ class DashboardView(UserView, SingleTableView):
|
||||||
section = "Home"
|
section = "Home"
|
||||||
|
|
||||||
def get_queryset(self, **kwargs):
|
def get_queryset(self, **kwargs):
|
||||||
|
events_for_users = self.get_user_events()
|
||||||
queryset = Event.objects.select_related('user').filter(
|
queryset = Event.objects.select_related('user').filter(
|
||||||
user=self.request.user)
|
user=self.request.user).filter(type__in=events_for_users)
|
||||||
|
|
||||||
return queryset
|
return queryset
|
||||||
|
|
||||||
|
def get_user_events(self):
|
||||||
|
events_for_users = [
|
||||||
|
Event.Types.EV_USR_WELCOME, # User welcomed
|
||||||
|
Event.Types.EV_USR_UPDATED, # Your data updated by admin
|
||||||
|
Event.Types.EV_DID_CREATED, # DID created
|
||||||
|
Event.Types.EV_DID_DELETED, # DID deleted
|
||||||
|
Event.Types.EV_CREDENTIAL_DELETED, # Credential deleted
|
||||||
|
Event.Types.EV_CREDENTIAL_ISSUED, # Credential issued
|
||||||
|
Event.Types.EV_CREDENTIAL_PRESENTED, # Credential presented
|
||||||
|
Event.Types.EV_CREDENTIAL_CAN_BE_REQUESTED, # Credential available
|
||||||
|
Event.Types.EV_CREDENTIAL_REVOKED, # Credential revoked
|
||||||
|
]
|
||||||
|
return events_for_users
|
||||||
|
|
||||||
|
|
||||||
class ProfileView(MyProfile, UpdateView, SingleTableView):
|
class ProfileView(MyProfile, UpdateView, SingleTableView):
|
||||||
template_name = "idhub/user/profile.html"
|
template_name = "idhub/user/profile.html"
|
||||||
|
|
Loading…
Reference in a new issue