Skip to content

Commit

Permalink
Functionality to view events without authentication (#13)
Browse files Browse the repository at this point in the history
* Added form_link, timestamp of team registration, check for is_registration_on

* Added solo event view

* added view of events without auth

* fixed duplicacy
  • Loading branch information
rohithpeddi7 authored Feb 3, 2024
1 parent 2dda2ff commit 30beb8e
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 15 deletions.
14 changes: 14 additions & 0 deletions website/serializers.py
Original file line number Diff line number Diff line change
Expand Up @@ -229,6 +229,20 @@ def delete(self):
team = data["team"]
team.leave_team(data["member"])
return team

class DisplayEventSerializer(serializers.ModelSerializer):
class Meta:
model = Event
fields = [
"id",
"name",
"slug",
"is_registration_on",
"min_members",
"max_members",
"form_link",
]



class EventSerializer(serializers.ModelSerializer):
Expand Down
34 changes: 19 additions & 15 deletions website/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,26 +20,30 @@


class EventListView(generics.ListAPIView):
permission_classes = [permissions.IsAuthenticated]
authentication_classes = [
authentication.TokenAuthentication,
authentication.SessionAuthentication,
]
serializer_class = EventSerializer
queryset = Event.objects.all()
authentication_classes = [authentication.TokenAuthentication, authentication.SessionAuthentication]
permission_classes = [permissions.IsAuthenticatedOrReadOnly]

def get_serializer_class(self):
if self.request.user.is_authenticated:
return EventSerializer
else:
return DisplayEventSerializer

def get_queryset(self):
return Event.objects.all()

class EventDetailView(generics.RetrieveAPIView):
permission_classes = [permissions.IsAuthenticated]
authentication_classes = [
authentication.TokenAuthentication,
authentication.SessionAuthentication,
]
serializer_class = EventSerializer
authentication_classes = [authentication.TokenAuthentication, authentication.SessionAuthentication]
permission_classes = [permissions.IsAuthenticatedOrReadOnly]
lookup_field = "pk"
queryset = Event.objects.all()

def get_serializer_class(self):
if self.request.user.is_authenticated:
return EventSerializer
else:
return DisplayEventSerializer

def get_queryset(self):
return Event.objects.all()

class ProfileView(generics.RetrieveUpdateAPIView):
permission_classes = [permissions.IsAuthenticated]
Expand Down

0 comments on commit 30beb8e

Please sign in to comment.