2022-09-02 13:07:30 +02:00
|
|
|
from flask_login import current_user
|
|
|
|
from flask_socketio import join_room, leave_room
|
2022-07-04 14:09:17 +02:00
|
|
|
from app import hashids, socketio
|
2024-04-18 15:35:41 +02:00
|
|
|
from app.extensions.flask_socketio_extras import login_required
|
2022-07-04 14:09:17 +02:00
|
|
|
from app.models import User
|
|
|
|
|
|
|
|
|
2022-12-22 13:57:55 +01:00
|
|
|
@socketio.on('GET /users/<user_id>')
|
2024-04-18 15:35:41 +02:00
|
|
|
@login_required
|
2023-07-24 10:02:35 +02:00
|
|
|
def get_user(user_hashid):
|
2022-12-22 13:57:55 +01:00
|
|
|
user_id = hashids.decode(user_hashid)
|
|
|
|
user = User.query.get(user_id)
|
|
|
|
if user is None:
|
|
|
|
return {'status': 404, 'statusText': 'Not found'}
|
2024-04-11 14:33:47 +02:00
|
|
|
if not (user == current_user or current_user.is_administrator):
|
2022-12-22 13:57:55 +01:00
|
|
|
return {'status': 403, 'statusText': 'Forbidden'}
|
|
|
|
return {
|
2023-07-24 10:02:35 +02:00
|
|
|
'body': user.to_json_serializeable(backrefs=True, relationships=True),
|
2022-12-22 13:57:55 +01:00
|
|
|
'status': 200,
|
2023-07-24 10:02:35 +02:00
|
|
|
'statusText': 'OK'
|
2022-12-22 13:57:55 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-07-08 11:46:47 +02:00
|
|
|
@socketio.on('SUBSCRIBE /users/<user_id>')
|
2024-04-18 15:35:41 +02:00
|
|
|
@login_required
|
2022-07-08 11:46:47 +02:00
|
|
|
def subscribe_user(user_hashid):
|
|
|
|
user_id = hashids.decode(user_hashid)
|
|
|
|
user = User.query.get(user_id)
|
|
|
|
if user is None:
|
2022-12-22 13:57:55 +01:00
|
|
|
return {'status': 404, 'statusText': 'Not found'}
|
2024-04-11 14:33:47 +02:00
|
|
|
if not (user == current_user or current_user.is_administrator):
|
2022-12-22 13:57:55 +01:00
|
|
|
return {'status': 403, 'statusText': 'Forbidden'}
|
2022-07-08 11:46:47 +02:00
|
|
|
join_room(f'/users/{user.hashid}')
|
2022-12-22 13:57:55 +01:00
|
|
|
return {'status': 200, 'statusText': 'OK'}
|
2022-07-08 11:46:47 +02:00
|
|
|
|
|
|
|
|
2022-07-04 14:09:17 +02:00
|
|
|
@socketio.on('UNSUBSCRIBE /users/<user_id>')
|
2024-04-18 15:35:41 +02:00
|
|
|
@login_required
|
2022-07-08 15:52:15 +02:00
|
|
|
def unsubscribe_user(user_hashid):
|
2022-07-04 14:09:17 +02:00
|
|
|
user_id = hashids.decode(user_hashid)
|
|
|
|
user = User.query.get(user_id)
|
|
|
|
if user is None:
|
2022-12-22 13:57:55 +01:00
|
|
|
return {'status': 404, 'statusText': 'Not found'}
|
2024-04-11 14:33:47 +02:00
|
|
|
if not (user == current_user or current_user.is_administrator):
|
2022-12-22 13:57:55 +01:00
|
|
|
return {'status': 403, 'statusText': 'Forbidden'}
|
2022-07-04 14:09:17 +02:00
|
|
|
leave_room(f'/users/{user.hashid}')
|
2022-12-22 13:57:55 +01:00
|
|
|
return {'status': 200, 'statusText': 'OK'}
|