This commit is contained in:
Kilton937342 2022-06-24 17:29:24 +02:00
parent 29c99334b2
commit bf62ac718b
8 changed files with 50 additions and 52 deletions

View File

@ -24,6 +24,6 @@ class ExosFilter(django_filters.FilterSet):
withAllTags = list(filter(lambda t: all( withAllTags = list(filter(lambda t: all(
i in [t.id_code for t in t.tags.all()] for i in tags ), withT)) i in [t.id_code for t in t.tags.all()] for i in tags ), withT))
withAllTagsQ = parent.filter(id_code__in = [e.id_code for e in withAllTags]) withAllTagsQ = parent.filter(id_code__in = [e.id_code for e in withAllTags])
print('WIRHA', withAllTagsQ)
return withAllTagsQ.filter(name__icontains=search) return withAllTagsQ.filter(name__icontains=search)

View File

@ -40,16 +40,16 @@ def pdf_settings(path, number_in_serie, consigne):
def page_settings(exos): def page_settings(exos):
# print(exos) #
max = 100 max = 100
total = 10 + 3 + 8 total = 10 + 3 + 8
pages = [{'exos': [], 'index': 1, 'jump': 0}] pages = [{'exos': [], 'index': 1, 'jump': 0}]
page_num = 0 page_num = 0
for ex in list(map(lambda e: e['exos'], exos)): for ex in list(map(lambda e: e['exos'], exos)):
#print(ex) #
for e in ex: for e in ex:
if (total) + (len(e['exercice'][0])) <= max: if (total) + (len(e['exercice'][0])) <= max:
#print(total + len(e['exercice'][0]) + 2, #
#total + len(e['exercice'][0]) + 2 < max, e['index']) #total + len(e['exercice'][0]) + 2 < max, e['index'])
total += (len(e['exercice'][0]) * 2 * 2) + 4 + 3 total += (len(e['exercice'][0]) * 2 * 2) + 4 + 3
e['notLast'] = True e['notLast'] = True
@ -59,14 +59,14 @@ def page_settings(exos):
pages[page_num]['exos']) - 1]['notLast'] = False pages[page_num]['exos']) - 1]['notLast'] = False
rest = max - (total - 1) rest = max - (total - 1)
pages[page_num]['jump'] = rest pages[page_num]['jump'] = rest
#print('tot', pages[page_num]['jump']) #
id = pages[page_num]['index'] id = pages[page_num]['index']
page_num += 1 page_num += 1
pages.append({'exos': [], 'index': id + 1, 'jump': 0}) pages.append({'exos': [], 'index': id + 1, 'jump': 0})
pages[page_num]['exos'].append(e) pages[page_num]['exos'].append(e)
total = (len(e['exercice'][0]) * 2 * 2) + 4 + 10 + 3 + 3 + 8 total = (len(e['exercice'][0]) * 2 * 2) + 4 + 10 + 3 + 3 + 8
#print('pgages', len(pages)) #
pages[len(pages) - 1]['exos'][len(pages[len(pages) - 1] pages[len(pages) - 1]['exos'][len(pages[len(pages) - 1]
['exos']) - 1]['notLast'] = False ['exos']) - 1]['notLast'] = False
#print(list(map(lambda e:e['exos'],exos))) #
return pages return pages

View File

@ -17,7 +17,7 @@ def auto_delete_file_on_delete(sender, instance, **kwargs):
Deletes file from filesystem Deletes file from filesystem
when corresponding `MediaFile` object is deleted. when corresponding `MediaFile` object is deleted.
""" """
print(instance, instance.exo_model.path, instance.id_code)
if instance.exo_model: if instance.exo_model:
if os.path.isfile(instance.exo_model.path): if os.path.isfile(instance.exo_model.path):
os.remove(instance.exo_model.path) os.remove(instance.exo_model.path)

View File

@ -111,7 +111,7 @@ class ExerciceAPI(APIView):
# sleep(2) # sleep(2)
return Response({"status": "200", "errors": {}, "data": {**ExerciceSerializer(new_exo).data, "author": UserSerializer(new_exo.author).data if new_exo.author != None else None, 'exo_model': {'filename': new_exo.exo_model.name.split('/')[-1], "data": open(new_exo.exo_model.name, 'r').read()}, "tags": [{**TagSerializer(t).data, 'value': t.id_code, 'label': t.name} for t in new_exo.tags.all()]}}, status=status.HTTP_200_OK) return Response({"status": "200", "errors": {}, "data": {**ExerciceSerializer(new_exo).data, "author": UserSerializer(new_exo.author).data if new_exo.author != None else None, 'exo_model': {'filename': new_exo.exo_model.name.split('/')[-1], "data": open(new_exo.exo_model.name, 'r').read()}, "tags": [{**TagSerializer(t).data, 'value': t.id_code, 'label': t.name} for t in new_exo.tags.all()]}}, status=status.HTTP_200_OK)
print(create_serializer.errors, 'errs')
return Response({"status": "400", "errors": create_serializer.errors}, status=status.HTTP_400_BAD_REQUEST) return Response({"status": "400", "errors": create_serializer.errors}, status=status.HTTP_400_BAD_REQUEST)
@method_decorator(login_required) @method_decorator(login_required)
@ -241,7 +241,7 @@ def getExoModelFile(request):
return Response({'errors': 'Not found'}, status=status.HTTP_404_NOT_FOUND) return Response({'errors': 'Not found'}, status=status.HTTP_404_NOT_FOUND)
exo = exo[0] exo = exo[0]
model = exo.exo_model model = exo.exo_model
print(model.name)
with open(model.name, 'r') as f: with open(model.name, 'r') as f:
response = HttpResponse(f.read(), content_type='text/x-python') response = HttpResponse(f.read(), content_type='text/x-python')
@ -259,7 +259,7 @@ def fav(request):
originExo = exo[0] originExo = exo[0]
exo = exo[0] exo = exo[0]
with open(exo.exo_model.path, 'r') as f: with open(exo.exo_model.path, 'r') as f:
print(f.name.split('/')[-1])
exo.pk = None exo.pk = None
exo.id = None exo.id = None
exo.id_code = generate_unique_code_step() exo.id_code = generate_unique_code_step()
@ -291,7 +291,7 @@ class TagsAPI(APIView):
tagsList = [] tagsList = []
for o in options: for o in options:
# print(o) #
if o['value'].startswith('new_opt'): if o['value'].startswith('new_opt'):
newTag = Tag(name=o['label'], newTag = Tag(name=o['label'],
color=o['color'], user=request.user) color=o['color'], user=request.user)
@ -347,7 +347,7 @@ class Editor(APIView):
script.write(code) script.write(code)
proc = subprocess.Popen(['python3.10', 'tmp.py', ], proc = subprocess.Popen(['python3.10', 'tmp.py', ],
stdout=subprocess.PIPE, stderr=subprocess.PIPE, cwd=tempdir) stdout=subprocess.PIPE, stderr=subprocess.PIPE, cwd=tempdir)
print(open(os.path.join(tempdir, "tmp.py"), 'r').read())
out, err = proc.communicate() out, err = proc.communicate()
out = out.decode().splitlines() out = out.decode().splitlines()
return Response({"out": out, "error": err.decode('utf-8').splitlines()}, status=status.HTTP_200_OK) return Response({"out": out, "error": err.decode('utf-8').splitlines()}, status=status.HTTP_200_OK)
@ -382,7 +382,7 @@ def pdfGen(request):
for e in range(len(exos)): for e in range(len(exos)):
for exo in range(len(exos[e]['exos'])): for exo in range(len(exos[e]['exos'])):
# print(exos[e]['exos'][exo]) #
exos[e]['exos'][exo]['calcul'] = sympy.latex( exos[e]['exos'][exo]['calcul'] = sympy.latex(
exos[e]['exos'][exo]['calcul']) exos[e]['exos'][exo]['calcul'])
@ -447,11 +447,11 @@ def pdfGen(request):
fich_name = request.data.get('file') fich_name = request.data.get('file')
if fich_name.count('.') >= 1: if fich_name.count('.') >= 1:
ext = fich_name.split('.')[-1] ext = fich_name.split('.')[-1]
# print(ext) #
if ext == 'pdf': if ext == 'pdf':
fich_name = fich_name fich_name = fich_name
elif ext != 'pdf': elif ext != 'pdf':
# print('nipe') #
fich_name = fich_name.replace(f'.{ext}', '.pdf') fich_name = fich_name.replace(f'.{ext}', '.pdf')
else: else:
fich_name = fich_name + '.pdf' fich_name = fich_name + '.pdf'
@ -463,7 +463,7 @@ class PDF(APIView):
exos = list(map(lambda ex: pdf_settings( exos = list(map(lambda ex: pdf_settings(
Exercice.objects.filter(id_code=ex['id_code'])[0].exo_model.name, 14, int(ex['numberInExo']), int(ex['numberOfExo']), 1, ex['consigne']), request.data.get('exos'))) Exercice.objects.filter(id_code=ex['id_code'])[0].exo_model.name, 14, int(ex['numberInExo']), int(ex['numberOfExo']), 1, ex['consigne']), request.data.get('exos')))
# print(exos) #
# dans str mettre space(0.5) replace by \hspace{0.5cm} # dans str mettre space(0.5) replace by \hspace{0.5cm}
template_name = 'test.tex' template_name = 'test.tex'
symbols = { symbols = {
@ -475,7 +475,7 @@ class PDF(APIView):
# a refaire pour supp les symbols # a refaire pour supp les symbols
for e in range(len(exos)): for e in range(len(exos)):
for exo in range(len(exos[e]['exos'])): for exo in range(len(exos[e]['exos'])):
# print(exos[e]['exos'][exo]) #
exos[e]['exos'][exo]['calcul'] = sympy.latex( exos[e]['exos'][exo]['calcul'] = sympy.latex(
exos[e]['exos'][exo]['calcul']) exos[e]['exos'][exo]['calcul'])
@ -509,7 +509,7 @@ class PDF(APIView):
template = get_template('test.tex') template = get_template('test.tex')
latex = template.render(context) # latex to compile latex = template.render(context) # latex to compile
# print(latex) #
with tempfile.TemporaryDirectory() as tempdir: with tempfile.TemporaryDirectory() as tempdir:
direct = tempdir direct = tempdir
with open(os.path.join(direct, 'tmp.tex'), 'x', encoding='utf-8') as f: with open(os.path.join(direct, 'tmp.tex'), 'x', encoding='utf-8') as f:
@ -541,11 +541,11 @@ class PDF(APIView):
fich_name = request.data.get('file') fich_name = request.data.get('file')
if fich_name.count('.') >= 1: if fich_name.count('.') >= 1:
ext = fich_name.split('.')[-1] ext = fich_name.split('.')[-1]
# print(ext) #
if ext == 'pdf': if ext == 'pdf':
fich_name = fich_name fich_name = fich_name
elif ext != 'pdf': elif ext != 'pdf':
# print('nipe') #
fich_name = fich_name.replace(f'.{ext}', '.pdf') fich_name = fich_name.replace(f'.{ext}', '.pdf')
else: else:
fich_name = fich_name + '.pdf' fich_name = fich_name + '.pdf'
@ -560,7 +560,7 @@ class Test(APIView):
code = "VZRKLZ" code = "VZRKLZ"
ex = Exercice.objects.filter(id_code=code)[0] ex = Exercice.objects.filter(id_code=code)[0]
model = ex.exo_model model = ex.exo_model
print('model', model.name)
oplist = Generateur(model.name, 2, 'calcul') oplist = Generateur(model.name, 2, 'calcul')
return Response({"data": oplist}, status=status.HTTP_200_OK) return Response({"data": oplist}, status=status.HTTP_200_OK)
@ -569,6 +569,6 @@ class ExoModelApi(APIView):
def get(self, request, format=None): def get(self, request, format=None):
code = request.GET.get('id_code') code = request.GET.get('id_code')
exo = Exercice.objects.filter(id_code=code)[0] exo = Exercice.objects.filter(id_code=code)[0]
print(exo.exo_model.name)
model = open(exo.exo_model.name, 'rb') model = open(exo.exo_model.name, 'rb')
return FileResponse(model, status=status.HTTP_200_OK) return FileResponse(model, status=status.HTTP_200_OK)

View File

@ -19,21 +19,21 @@ class RoomConsumer(AsyncWebsocketConsumer):
self.user = None self.user = None
try: try:
self.room = await self.get_room() self.room = await self.get_room()
print('Connected')
await self.accept() await self.accept()
await self.send(json.dumps({'type': 'connect', "clientId": self.clientId})) await self.send(json.dumps({'type': 'connect', "clientId": self.clientId}))
except: except:
print('closed')
await self.close() await self.close()
async def receive(self, text_data): async def receive(self, text_data):
text_data_json = json.loads(text_data) text_data_json = json.loads(text_data)
type = text_data_json['data']['type'] type = text_data_json['data']['type']
print("EVENT", type)
print('USER', self.scope['user'])
if type == "login": if type == "login":
print('LOF', self.scope['user'])
participants = await self.get_participants() participants = await self.get_participants()
if self.scope['user'].is_anonymous: if self.scope['user'].is_anonymous:
nick = text_data_json['data']['nick'] nick = text_data_json['data']['nick']
@ -84,7 +84,7 @@ class RoomConsumer(AsyncWebsocketConsumer):
new_participant = await self.add_participant(nick, str(uuid4())) new_participant = await self.add_participant(nick, str(uuid4()))
else: else:
new_participant = await self.add_user(code) new_participant = await self.add_user(code)
print(new_participant)
await self.del_waiter_db(code) await self.del_waiter_db(code)
await self.channel_layer.group_send(f'waiter__{code}', {"type": "accept_room", 'id_code': self.room_id, 'code': new_participant['code']}) await self.channel_layer.group_send(f'waiter__{code}', {"type": "accept_room", 'id_code': self.room_id, 'code': new_participant['code']})
@ -118,7 +118,7 @@ class RoomConsumer(AsyncWebsocketConsumer):
participant = list( participant = list(
filter(lambda p: p['code'] == code, participants))[0] filter(lambda p: p['code'] == code, participants))[0]
await self.channel_layer.group_discard(f'waiter__{code}', self.channel_name) await self.channel_layer.group_discard(f'waiter__{code}', self.channel_name)
print('new user', participant)
self.clientId = participant['clientId'] self.clientId = participant['clientId']
await self.channel_layer.group_add(self.room_id, self.channel_name) await self.channel_layer.group_add(self.room_id, self.channel_name)
self.user = participant self.user = participant
@ -179,7 +179,7 @@ class RoomConsumer(AsyncWebsocketConsumer):
elif type == "reconnect": elif type == "reconnect":
client = text_data_json['data']['clientId'] client = text_data_json['data']['clientId']
print("reconeect", self.scope['user'].is_anonymous)
if not self.scope['user'].is_anonymous: if not self.scope['user'].is_anonymous:
userInRoom = await self.userInRoom() userInRoom = await self.userInRoom()
if not userInRoom: if not userInRoom:
@ -199,7 +199,7 @@ class RoomConsumer(AsyncWebsocketConsumer):
await self.connect_participant() await self.connect_participant()
self.clientId = self.scope['user'].clientId self.clientId = self.scope['user'].clientId
print('SENDING')
await self.send(json.dumps({'type': "reconnected", "clientId": self.scope['user'].clientId, 'id_code': self.room_id, 'identity': self.user})) await self.send(json.dumps({'type': "reconnected", "clientId": self.scope['user'].clientId, 'id_code': self.room_id, 'identity': self.user}))
await self.channel_layer.group_send(self.room_id, {"type": "reconnect.event", 'nick': self.user['nick']}) await self.channel_layer.group_send(self.room_id, {"type": "reconnect.event", 'nick': self.user['nick']})
await self.channel_layer.group_send(f'owner__{self.room_id}', {"type": "reconnect.event", 'nick': self.user['nick']}) await self.channel_layer.group_send(f'owner__{self.room_id}', {"type": "reconnect.event", 'nick': self.user['nick']})
@ -214,10 +214,10 @@ class RoomConsumer(AsyncWebsocketConsumer):
filter(lambda p: p['clientId'] == client, participants))[0] filter(lambda p: p['clientId'] == client, participants))[0]
if participant['clientId'] == self.room.owner['clientId'] and participant['code'] == self.room.owner['code']: if participant['clientId'] == self.room.owner['clientId'] and participant['code'] == self.room.owner['code']:
print('add in admin')
await self.channel_layer.group_add(f'owner__{self.room_id}', self.channel_name) await self.channel_layer.group_add(f'owner__{self.room_id}', self.channel_name)
else: else:
print('add in users')
await self.channel_layer.group_add(self.room_id, self.channel_name) await self.channel_layer.group_add(self.room_id, self.channel_name)
participant['online'] = True participant['online'] = True
self.user = participant self.user = participant
@ -245,11 +245,11 @@ class RoomConsumer(AsyncWebsocketConsumer):
clientId = text_data_json['data']["clientId"] clientId = text_data_json['data']["clientId"]
status = 'anonymous' if len(code) == 6 else 'user' status = 'anonymous' if len(code) == 6 else 'user'
print('EST')
if status == 'anonymous': if status == 'anonymous':
participants = await self.get_participants() participants = await self.get_participants()
participant = [p for p in participants if p['code'] == code] participant = [p for p in participants if p['code'] == code]
print('PARTICIPANR', participant)
if len(participant) == 0: if len(participant) == 0:
pass pass
else: else:
@ -259,7 +259,7 @@ class RoomConsumer(AsyncWebsocketConsumer):
await self.channel_layer.group_send(f'owner__{self.room_id}', {'type': "ban_participant", "code": code, "nick": nick}) await self.channel_layer.group_send(f'owner__{self.room_id}', {'type': "ban_participant", "code": code, "nick": nick})
else: else:
user = await self.get_user(code) user = await self.get_user(code)
print('USER', user, code)
if self.scope['user'] == user: if self.scope['user'] == user:
await self.del_user(code) await self.del_user(code)
await self.channel_layer.group_send(self.room_id, {'type': "ban_participant", "code": code, "nick": nick}) await self.channel_layer.group_send(self.room_id, {'type': "ban_participant", "code": code, "nick": nick})
@ -346,7 +346,7 @@ class RoomConsumer(AsyncWebsocketConsumer):
id_code=self.room.id_code)) != 0 id_code=self.room.id_code)) != 0
async def disconnect(self, close_code): async def disconnect(self, close_code):
print('Disconnect')
if self.waiter == False and self.user != None: if self.waiter == False and self.user != None:
await self.disconnect_participant() await self.disconnect_participant()
await self.channel_layer.group_discard(self.room_id, self.channel_name) await self.channel_layer.group_discard(self.room_id, self.channel_name)

View File

@ -115,12 +115,10 @@ class RoomManager(models.Manager):
return None return None
waiters = room.waiters waiters = room.waiters
print('NEWNAME', new_name, new_name in list(
map(lambda p: p['nick'], waiters)), list(map(lambda p: p['nick'], waiters)), waiters)
if new_name in list(map(lambda p: p['nick'], waiters)): if new_name in list(map(lambda p: p['nick'], waiters)):
return None return None
print('PASSED')
if code == None: if code == None:
while True: while True:
code = ''.join(random.choices(string.ascii_uppercase, k=6)) code = ''.join(random.choices(string.ascii_uppercase, k=6))
@ -232,7 +230,7 @@ class ParcoursManager(models.Manager):
challengers = parcours.challenger challengers = parcours.challenger
challengers = [c for c in challengers if c['code'] == user_code] challengers = [c for c in challengers if c['code'] == user_code]
if len(challengers) == 0: if len(challengers) == 0:
print('NOPE', user_code)
return None return None
c = challengers[0] c = challengers[0]
return {'value': round(functools.reduce(lambda a, b: a+b, [e['note']['value'] for e in c['exos']])/len(c['exos']), 2), 'total': c['exos'][0]['note']['total']} return {'value': round(functools.reduce(lambda a, b: a+b, [e['note']['value'] for e in c['exos']])/len(c['exos']), 2), 'total': c['exos'][0]['note']['total']}

View File

@ -105,7 +105,7 @@ class ParcoursCreateSerializer(serializers.ModelSerializer):
'timer', 'exercices', 'success_condition') # + challenger ? 'timer', 'exercices', 'success_condition') # + challenger ?
def validate_exercices(self, value): def validate_exercices(self, value):
print('EXOS', value)
if len(value) == 0: if len(value) == 0:
raise serializers.ValidationError('Aucun exercice séléctioné') raise serializers.ValidationError('Aucun exercice séléctioné')
return value return value

View File

@ -104,7 +104,7 @@ class RoomAPI(APIView):
else: else:
return Response({'error': 'Unauthorized'}, status=status.HTTP_401_UNAUTHORIZED) return Response({'error': 'Unauthorized'}, status=status.HTTP_401_UNAUTHORIZED)
else: else:
print('CLIENTID', clientId, room.owner)
if clientId == room.owner['clientId']: if clientId == room.owner['clientId']:
room.delete() room.delete()
else: else:
@ -122,7 +122,7 @@ class RoomAPI(APIView):
room = Room.objects.filter(id_code=code)[0] room = Room.objects.filter(id_code=code)[0]
except IndexError: except IndexError:
return Response({'error': 'No room'}, status=status.HTTP_502_BAD_GATEWAY) return Response({'error': 'No room'}, status=status.HTTP_502_BAD_GATEWAY)
# print(room)
if 'roomsJoined' not in request.session: if 'roomsJoined' not in request.session:
request.session['roomsJoined'] = [] request.session['roomsJoined'] = []
elif 'roomsJoined' in request.session: elif 'roomsJoined' in request.session:
@ -224,7 +224,7 @@ def getEditParcours(request):
@api_view(['POST']) @api_view(['POST'])
def lockRoom(request): def lockRoom(request):
print('DATA', request.data)
room_id = request.data['id_code'] room_id = request.data['id_code']
if request.user.is_authenticated: if request.user.is_authenticated:
@ -245,7 +245,7 @@ def lockRoom(request):
@api_view(['POST']) @api_view(['POST'])
def publicResultToggler(request): def publicResultToggler(request):
print('DATA', request.data)
room_id = request.data['id_code'] room_id = request.data['id_code']
if request.user.is_authenticated: if request.user.is_authenticated:
@ -267,7 +267,7 @@ def publicResultToggler(request):
@api_view(['POST']) @api_view(['POST'])
def changeRoomName(request): def changeRoomName(request):
print('DATA', request.data)
room_id = request.data['id_code'] room_id = request.data['id_code']
if request.user.is_authenticated: if request.user.is_authenticated:
@ -396,10 +396,10 @@ class ChallengeAPI(APIView):
filter(lambda c: c['order'] == a['order'], correctionExos['exos']))[0] filter(lambda c: c['order'] == a['order'], correctionExos['exos']))[0]
correctInputs = exoCorrect['inputs'] correctInputs = exoCorrect['inputs']
print('correcti', correctInputs)
studentsInput = sorted( studentsInput = sorted(
a['inputs'], key=lambda i: i.get('order')) a['inputs'], key=lambda i: i.get('order'))
print('correctiinnnn\n\n', studentsInput)
corrigedInputs = [{**inp, "value": studentsInput[inp['order']]['value'], "isCorrect": (str(studentsInput[inp['order']]['value']) == str( corrigedInputs = [{**inp, "value": studentsInput[inp['order']]['value'], "isCorrect": (str(studentsInput[inp['order']]['value']) == str(
inp['correction'])) if inp['correction'] != "" else None} for inp in correctInputs] inp['correction'])) if inp['correction'] != "" else None} for inp in correctInputs]
corrigedList.append({**a, 'inputs': corrigedInputs}) corrigedList.append({**a, 'inputs': corrigedInputs})
@ -486,7 +486,7 @@ class ParcoursAPI(APIView):
id_code = request.data.get('id_code') id_code = request.data.get('id_code')
code = request.data.get('code') code = request.data.get('code')
print(f'id_code={id_code};code={code}')
parcours = Parcours.objects.filter(id_code=id_code) parcours = Parcours.objects.filter(id_code=id_code)
if len(parcours) == 0: if len(parcours) == 0:
@ -527,7 +527,7 @@ class ParcoursAPI(APIView):
if not serial.is_valid(): if not serial.is_valid():
return Response(serial.errors, status=status.HTTP_400_BAD_REQUEST) return Response(serial.errors, status=status.HTTP_400_BAD_REQUEST)
parcours = serial.create(serial.validated_data) parcours = serial.create(serial.validated_data)
print('PARCOURS', parcours)
layer = get_channel_layer() layer = get_channel_layer()
async_to_sync(layer.group_send)(room_code, { async_to_sync(layer.group_send)(room_code, {
'type': 'new_parcours', 'parcours': ParcoursFullSerializer(parcours).data}) 'type': 'new_parcours', 'parcours': ParcoursFullSerializer(parcours).data})