mirror of
				https://github.com/ae-utbm/sith.git
				synced 2025-10-25 22:23:53 +00:00 
			
		
		
		
	use django auth for subscription creation page
This commit is contained in:
		| @@ -125,6 +125,11 @@ class Command(BaseCommand): | ||||
|             unix_name=settings.SITH_MAIN_CLUB["unix_name"], | ||||
|             address=settings.SITH_MAIN_CLUB["address"], | ||||
|         ) | ||||
|         main_club.board_group.permissions.add( | ||||
|             *Permission.objects.filter( | ||||
|                 codename__in=["view_subscription", "add_subscription"] | ||||
|             ) | ||||
|         ) | ||||
|         bar_club = Club.objects.create( | ||||
|             id=2, | ||||
|             name=settings.SITH_BAR_MANAGER["name"], | ||||
|   | ||||
| @@ -417,29 +417,6 @@ class User(AbstractUser): | ||||
|     def is_board_member(self) -> bool: | ||||
|         return self.groups.filter(club_board=settings.SITH_MAIN_CLUB_ID).exists() | ||||
|  | ||||
|     @cached_property | ||||
|     def can_read_subscription_history(self) -> bool: | ||||
|         if self.is_root or self.is_board_member: | ||||
|             return True | ||||
|  | ||||
|         from club.models import Club | ||||
|  | ||||
|         for club in Club.objects.filter( | ||||
|             id__in=settings.SITH_CAN_READ_SUBSCRIPTION_HISTORY | ||||
|         ): | ||||
|             if club in self.clubs_with_rights: | ||||
|                 return True | ||||
|         return False | ||||
|  | ||||
|     @cached_property | ||||
|     def can_create_subscription(self) -> bool: | ||||
|         return self.is_root or ( | ||||
|             self.memberships.board() | ||||
|             .ongoing() | ||||
|             .filter(club_id__in=settings.SITH_CAN_CREATE_SUBSCRIPTIONS) | ||||
|             .exists() | ||||
|         ) | ||||
|  | ||||
|     @cached_property | ||||
|     def is_launderette_manager(self): | ||||
|         from club.models import Club | ||||
| @@ -679,14 +656,6 @@ class AnonymousUser(AuthAnonymousUser): | ||||
|     def __init__(self): | ||||
|         super().__init__() | ||||
|  | ||||
|     @property | ||||
|     def can_create_subscription(self): | ||||
|         return False | ||||
|  | ||||
|     @property | ||||
|     def can_read_subscription_history(self): | ||||
|         return False | ||||
|  | ||||
|     @property | ||||
|     def was_subscribed(self): | ||||
|         return False | ||||
|   | ||||
| @@ -166,7 +166,7 @@ | ||||
|   </div> | ||||
| {% endif %} | ||||
| <br> | ||||
| {% if profile.was_subscribed and (user == profile or user.can_read_subscription_history)%} | ||||
| {% if profile.was_subscribed and (user == profile or user.has_perm("subscription.view_subscription")) %} | ||||
|   <div class="collapse" :class="{'shadow': collapsed}" x-data="{collapsed: false}" x-cloak> | ||||
|     <div class="collapse-header clickable" @click="collapsed = !collapsed"> | ||||
|       <span class="collapse-header-text"> | ||||
|   | ||||
| @@ -13,7 +13,7 @@ | ||||
|     <h3>{% trans %}User Tools{% endtrans %}</h3> | ||||
|  | ||||
|     <div class="container"> | ||||
|       {% if user.can_create_subscription or user.is_root or user.is_board_member %} | ||||
|       {% if user.has_perm("subscription.add_subscription") or user.is_root or user.is_board_member %} | ||||
|         <div> | ||||
|           <h4>{% trans %}Sith management{% endtrans %}</h4> | ||||
|           <ul> | ||||
| @@ -26,7 +26,7 @@ | ||||
|             {% if user.has_perm("core.view_userban") %} | ||||
|               <li><a href="{{ url("rootplace:ban_list") }}">{% trans %}Bans{% endtrans %}</a></li> | ||||
|             {% endif %} | ||||
|             {% if user.can_create_subscription or user.is_root %} | ||||
|             {% if user.has_perm("subscription.add_subscription") %} | ||||
|               <li><a href="{{ url('subscription:subscription') }}">{% trans %}Subscriptions{% endtrans %}</a></li> | ||||
|             {% endif %} | ||||
|             {% if user.is_board_member or user.is_root %} | ||||
|   | ||||
| @@ -517,14 +517,6 @@ SITH_PRODUCT_SUBSCRIPTION_ONE_SEMESTER = 1 | ||||
| SITH_PRODUCT_SUBSCRIPTION_TWO_SEMESTERS = 2 | ||||
| SITH_PRODUCTTYPE_SUBSCRIPTION = 2 | ||||
|  | ||||
| # Defines which club lets its member the ability to make subscriptions | ||||
| # Elements of this list are club's id | ||||
| SITH_CAN_CREATE_SUBSCRIPTIONS = [1] | ||||
|  | ||||
| # Defines which clubs lets its members the ability to see users subscription history | ||||
| # Elements of this list are club's id | ||||
| SITH_CAN_READ_SUBSCRIPTION_HISTORY = [] | ||||
|  | ||||
| # Number of weeks before the end of a subscription when the subscriber can resubscribe | ||||
| SITH_SUBSCRIPTION_END = 10 | ||||
|  | ||||
|   | ||||
| @@ -5,6 +5,7 @@ from typing import Callable | ||||
|  | ||||
| import pytest | ||||
| from dateutil.relativedelta import relativedelta | ||||
| from django.contrib.auth.models import Permission | ||||
| from django.test import Client | ||||
| from django.urls import reverse | ||||
| from django.utils.timezone import localdate | ||||
| @@ -108,7 +109,12 @@ def test_page_access( | ||||
|  | ||||
| @pytest.mark.django_db | ||||
| def test_submit_form_existing_user(client: Client, settings: SettingsWrapper): | ||||
|     client.force_login(board_user.make()) | ||||
|     client.force_login( | ||||
|         baker.make( | ||||
|             User, | ||||
|             user_permissions=Permission.objects.filter(codename="add_subscription"), | ||||
|         ) | ||||
|     ) | ||||
|     user = old_subscriber_user.make() | ||||
|     response = client.post( | ||||
|         reverse("subscription:fragment-existing-user"), | ||||
| @@ -133,7 +139,12 @@ def test_submit_form_existing_user(client: Client, settings: SettingsWrapper): | ||||
|  | ||||
| @pytest.mark.django_db | ||||
| def test_submit_form_new_user(client: Client, settings: SettingsWrapper): | ||||
|     client.force_login(board_user.make()) | ||||
|     client.force_login( | ||||
|         baker.make( | ||||
|             User, | ||||
|             user_permissions=Permission.objects.filter(codename="add_subscription"), | ||||
|         ) | ||||
|     ) | ||||
|     response = client.post( | ||||
|         reverse("subscription:fragment-new-user"), | ||||
|         { | ||||
|   | ||||
| @@ -14,7 +14,7 @@ | ||||
| # | ||||
|  | ||||
| from django.conf import settings | ||||
| from django.contrib.auth.mixins import UserPassesTestMixin | ||||
| from django.contrib.auth.mixins import PermissionRequiredMixin | ||||
| from django.core.exceptions import PermissionDenied | ||||
| from django.urls import reverse, reverse_lazy | ||||
| from django.utils.timezone import localdate | ||||
| @@ -30,13 +30,9 @@ from subscription.forms import ( | ||||
| from subscription.models import Subscription | ||||
|  | ||||
|  | ||||
| class CanCreateSubscriptionMixin(UserPassesTestMixin): | ||||
|     def test_func(self): | ||||
|         return self.request.user.can_create_subscription | ||||
|  | ||||
|  | ||||
| class NewSubscription(CanCreateSubscriptionMixin, TemplateView): | ||||
| class NewSubscription(PermissionRequiredMixin, TemplateView): | ||||
|     template_name = "subscription/subscription.jinja" | ||||
|     permission_required = "subscription.add_subscription" | ||||
|  | ||||
|     def get_context_data(self, **kwargs): | ||||
|         return super().get_context_data(**kwargs) | { | ||||
| @@ -49,8 +45,9 @@ class NewSubscription(CanCreateSubscriptionMixin, TemplateView): | ||||
|         } | ||||
|  | ||||
|  | ||||
| class CreateSubscriptionFragment(CanCreateSubscriptionMixin, CreateView): | ||||
| class CreateSubscriptionFragment(PermissionRequiredMixin, CreateView): | ||||
|     template_name = "subscription/fragments/creation_form.jinja" | ||||
|     permission_required = "subscription.add_subscription" | ||||
|  | ||||
|     def get_success_url(self): | ||||
|         return reverse( | ||||
| @@ -72,8 +69,9 @@ class CreateSubscriptionNewUserFragment(CreateSubscriptionFragment): | ||||
|     extra_context = {"post_url": reverse_lazy("subscription:fragment-new-user")} | ||||
|  | ||||
|  | ||||
| class SubscriptionCreatedFragment(CanCreateSubscriptionMixin, DetailView): | ||||
| class SubscriptionCreatedFragment(PermissionRequiredMixin, DetailView): | ||||
|     template_name = "subscription/fragments/creation_success.jinja" | ||||
|     permission_required = "subscription.add_subscription" | ||||
|     model = Subscription | ||||
|     pk_url_kwarg = "subscription_id" | ||||
|     context_object_name = "subscription" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user