From e0219e84c923ef82e7489b695ec90a8aeadb66ab Mon Sep 17 00:00:00 2001 From: Patrick Jentsch 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