mirror of
https://github.com/lemeow125/StudE-Backend.git
synced 2025-01-18 22:53:00 +08:00
Fixed student status websocket
This commit is contained in:
parent
295798b965
commit
18679541be
1 changed files with 38 additions and 10 deletions
|
@ -14,10 +14,13 @@ from djangochannelsrestframework.mixins import (
|
|||
from djangochannelsrestframework.permissions import IsAuthenticated
|
||||
from channels.layers import get_channel_layer
|
||||
from asgiref.sync import async_to_sync
|
||||
from django.contrib.gis.measure import Distance
|
||||
from django.contrib.gis.db.models.functions import Distance
|
||||
from django.contrib.gis.geos import fromstr
|
||||
from .models import StudentStatus
|
||||
from accounts.models import CustomUser
|
||||
from django.contrib.auth.models import AnonymousUser
|
||||
from rest_framework import generics, viewsets, exceptions
|
||||
from channels.exceptions import DenyConnection
|
||||
|
||||
|
||||
class StudentStatusConsumer(
|
||||
|
@ -26,7 +29,7 @@ class StudentStatusConsumer(
|
|||
GenericAsyncAPIConsumer,
|
||||
):
|
||||
permission_classes = [IsAuthenticated]
|
||||
queryset = StudentStatus.objects.filter(active=True)
|
||||
queryset = StudentStatus.objects.none()
|
||||
serializer_class = StudentStatusSerializer
|
||||
|
||||
async def send_status_update(self, event):
|
||||
|
@ -34,19 +37,44 @@ class StudentStatusConsumer(
|
|||
await self.send(text_data=json.dumps(data))
|
||||
|
||||
async def websocket_connect(self, message):
|
||||
await self.channel_layer.group_add('student_status_group', self.channel_name)
|
||||
await self.accept()
|
||||
self.send_updates_task = asyncio.create_task(self.send_updates())
|
||||
if isinstance(self.scope['user'], AnonymousUser):
|
||||
await self.close()
|
||||
else:
|
||||
student_status_isactive = await self.get_student_status()
|
||||
if not student_status_isactive:
|
||||
await self.close()
|
||||
await self.channel_layer.group_add('student_status_group', self.channel_name)
|
||||
await self.accept()
|
||||
self.send_updates_task = asyncio.create_task(self.send_updates())
|
||||
|
||||
async def websocket_disconnect(self, message):
|
||||
# ...
|
||||
await self.channel_layer.group_discard('student_status_group', self.channel_name)
|
||||
self.send_updates_task.cancel()
|
||||
if not isinstance(self.scope['user'], AnonymousUser):
|
||||
await self.channel_layer.group_discard('student_status_group', self.channel_name)
|
||||
self.send_updates_task.cancel()
|
||||
|
||||
@database_sync_to_async
|
||||
def get_student_status(self):
|
||||
user = self.scope["user"]
|
||||
user_status = StudentStatus.objects.filter(user=user).first()
|
||||
return user_status.active
|
||||
|
||||
@database_sync_to_async
|
||||
def get_student_statuses(self):
|
||||
queryset = self.get_queryset()
|
||||
user = self.scope['user']
|
||||
user_status = StudentStatus.objects.filter(user=user).first()
|
||||
user_status_active = StudentStatus.objects.filter(
|
||||
user=user).values_list('active').first()
|
||||
user_location = fromstr(
|
||||
user_status.location, srid=4326)
|
||||
|
||||
if user_status.active is False:
|
||||
queryset = StudentStatus.objects.none()
|
||||
return StudentStatusSerializer(queryset, many=True).data
|
||||
|
||||
user_subject_names = user.subjects.values_list('subject', flat=True)
|
||||
queryset = StudentStatus.objects.exclude(user=user).filter(active=True).filter(subject__name__in=user_subject_names).annotate(
|
||||
distance=Distance('location', user_location)).filter(distance__lte=50)
|
||||
return StudentStatusSerializer(queryset, many=True).data
|
||||
|
||||
async def send_updates(self):
|
||||
|
@ -54,9 +82,9 @@ class StudentStatusConsumer(
|
|||
|
||||
while True:
|
||||
try:
|
||||
print('attempting to get')
|
||||
# print('attempting to get')
|
||||
data = await self.get_student_statuses()
|
||||
print(f"Sending update: {data}")
|
||||
# print(f"Sending update: {data}")
|
||||
await channel_layer.group_send(
|
||||
'student_status_group',
|
||||
{
|
||||
|
|
Loading…
Reference in a new issue