mirror of
https://gitlab.ub.uni-bielefeld.de/sfb1288inf/nopaque.git
synced 2025-01-06 00:04:19 +00:00
83 lines
2.0 KiB
Python
83 lines
2.0 KiB
Python
|
from flask_login import current_user
|
||
|
from flask_socketio import join_room, leave_room
|
||
|
from app import hashids, socketio
|
||
|
from app.decorators import socketio_login_required
|
||
|
from app.models import User
|
||
|
|
||
|
|
||
|
@socketio.on('users.get_user')
|
||
|
@socketio_login_required
|
||
|
def get_user(user_hashid: str) -> dict:
|
||
|
user_id = hashids.decode(user_hashid)
|
||
|
|
||
|
if not isinstance(user_id, int):
|
||
|
return {'status': 400, 'statusText': 'Bad Request'}
|
||
|
|
||
|
user = User.query.get(user_id)
|
||
|
|
||
|
if user is None:
|
||
|
return {'status': 404, 'statusText': 'Not found'}
|
||
|
|
||
|
if not (
|
||
|
user == current_user
|
||
|
or current_user.is_administrator
|
||
|
):
|
||
|
return {'status': 403, 'statusText': 'Forbidden'}
|
||
|
|
||
|
return {
|
||
|
'body': user.to_json_serializeable(
|
||
|
backrefs=True,
|
||
|
relationships=True
|
||
|
),
|
||
|
'status': 200,
|
||
|
'statusText': 'OK'
|
||
|
}
|
||
|
|
||
|
|
||
|
@socketio.on('users.subscribe_user')
|
||
|
@socketio_login_required
|
||
|
def subscribe_user(user_hashid: str) -> dict:
|
||
|
user_id = hashids.decode(user_hashid)
|
||
|
|
||
|
if not isinstance(user_id, int):
|
||
|
return {'status': 400, 'statusText': 'Bad Request'}
|
||
|
|
||
|
user = User.query.get(user_id)
|
||
|
|
||
|
if user is None:
|
||
|
return {'status': 404, 'statusText': 'Not found'}
|
||
|
|
||
|
if not (
|
||
|
user == current_user
|
||
|
or current_user.is_administrator
|
||
|
):
|
||
|
return {'status': 403, 'statusText': 'Forbidden'}
|
||
|
|
||
|
join_room(f'/users/{user.hashid}')
|
||
|
|
||
|
return {'status': 200, 'statusText': 'OK'}
|
||
|
|
||
|
|
||
|
@socketio.on('users.unsubscribe_user')
|
||
|
@socketio_login_required
|
||
|
def on_unsubscribe_user(user_hashid: str) -> dict:
|
||
|
user_id = hashids.decode(user_hashid)
|
||
|
|
||
|
if not isinstance(user_id, int):
|
||
|
return {'status': 400, 'statusText': 'Bad Request'}
|
||
|
|
||
|
user = User.query.get(user_id)
|
||
|
|
||
|
if user is None:
|
||
|
return {'status': 404, 'statusText': 'Not found'}
|
||
|
|
||
|
if not (
|
||
|
user == current_user
|
||
|
or current_user.is_administrator
|
||
|
):
|
||
|
return {'status': 403, 'statusText': 'Forbidden'}
|
||
|
|
||
|
leave_room(f'/users/{user.hashid}')
|
||
|
|
||
|
return {'status': 200, 'statusText': 'OK'}
|