From e0219e84c923ef82e7489b695ec90a8aeadb66ab Mon Sep 17 00:00:00 2001
From: Patrick Jentsch <p.jentsch@uni-bielefeld.de>
Date: Wed, 22 Sep 2021 13:52:51 +0200
Subject: [PATCH] Preliminary work for better socket.io event handling.

---
 app/events/socketio.py | 22 ++++++++++------------
 1 file changed, 10 insertions(+), 12 deletions(-)

diff --git a/app/events/socketio.py b/app/events/socketio.py
index 539680f8..ff7f787a 100644
--- a/app/events/socketio.py
+++ b/app/events/socketio.py
@@ -7,7 +7,7 @@ from ..models import User
 
 
 '''
-' A list containing session ids of connected Socket.IO sessions, to keep track
+' A list containing session ids of Socket.IO sessions, to keep track
 ' of all connected sessions, which can be used to determine the runtimes of
 ' associated background tasks.
 '''
@@ -22,21 +22,22 @@ sessions = []
 def socketio_connect():
     '''
     ' The Socket.IO module creates a session id (sid) for each request.
-    ' On connect the sid is saved in the connected sessions list.
+    ' On connect the sid is saved in the sessions list.
     '''
     sessions.append(request.sid)
+    return {'code': 200, 'msg': 'OK'}
 
 
 @socketio.on('disconnect')
 def socketio_disconnect():
     '''
-    ' On disconnect the session id gets removed from the connected sessions
-    ' list.
+    ' On disconnect the session id gets removed from the sessions list.
     '''
     try:
         sessions.remove(request.sid)
     except ValueError:
         pass
+    return {'code': 200, 'msg': 'OK'}
 
 
 @socketio.on('start_user_session')
@@ -58,18 +59,15 @@ def socketio_start_user_session(user_id):
         join_room(room)
 
 
-@socketio.on('stop_user_session')
+@socketio.on('users.request')
 @socketio_login_required
-def socketio_stop_user_session(user_id):
+def socketio_start_session(user_id):
     user = User.query.get(user_id)
     if user is None:
         response = {'code': 404, 'msg': 'Not found'}
-        socketio.emit('stop_user_session', response, room=request.sid)
     elif not (user == current_user or current_user.is_administrator):
         response = {'code': 403, 'msg': 'Forbidden'}
-        socketio.emit('stop_user_session', response, room=request.sid)
     else:
-        response = {'code': 200, 'msg': 'OK'}
-        socketio.emit('stop_user_session', response, room=request.sid)
-        room = 'user_{}'.format(user.id)
-        leave_room(room)
+        response = {'code': 200, 'msg': 'OK', 'payload': user.to_dict()}
+        join_room('users.{}'.format(user.id))
+    return response
-- 
GitLab