From 172e38ef4b909d6199a84ee1127c25d469c21baf Mon Sep 17 00:00:00 2001 From: Guilhem Allaman <40383801+gounux@users.noreply.github.com> Date: Thu, 24 Oct 2024 18:02:24 +0200 Subject: [PATCH] feature(qchat): handle users registration (#200) * feature(qchat): handle users registration * feature(qchat): set user registration optional * feature(qchat): notify when a user has left * refactor(qchat): rename registration to incognito mode * ui(qchat): set settings tooltips * ui(qchat): set qchat groupbox enabled --- qtribu/gui/dck_qchat.py | 53 ++++++++++++++++++++++++++++++++++ qtribu/gui/dck_qchat.ui | 36 ++++++++++++++++++----- qtribu/gui/dlg_settings.py | 2 ++ qtribu/gui/dlg_settings.ui | 26 +++++++++++++++-- qtribu/logic/qchat_client.py | 14 +++++++++ qtribu/toolbelt/preferences.py | 1 + 6 files changed, 122 insertions(+), 10 deletions(-) diff --git a/qtribu/gui/dck_qchat.py b/qtribu/gui/dck_qchat.py index 9093f1a2..034e2753 100644 --- a/qtribu/gui/dck_qchat.py +++ b/qtribu/gui/dck_qchat.py @@ -102,6 +102,12 @@ def __init__( self.on_custom_context_menu_requested ) + # list users signal listener + self.btn_list_users.pressed.connect(self.on_list_users_button_clicked) + self.btn_list_users.setIcon( + QIcon(QgsApplication.iconPath("processingResult.svg")) + ) + # clear chat signal listener self.btn_clear_chat.pressed.connect(self.on_clear_chat_button_clicked) self.btn_clear_chat.setIcon( @@ -305,6 +311,7 @@ def on_ws_connected(self, room: str) -> None: self.btn_connect.setText(self.tr("Disconnect")) self.lbl_status.setText("Connected") self.grb_room.setTitle(self.tr("Room: {room}").format(room=room)) + self.btn_list_users.setEnabled(True) self.grb_user.setEnabled(True) self.current_room = room @@ -321,6 +328,14 @@ def on_ws_connected(self, room: str) -> None: self.tr("Connected to room '{room}'").format(room=room) ) + # send newcomer message to websocket + if not self.settings.qchat_incognito_mode: + message = { + "author": INTERNAL_MESSAGE_AUTHOR, + "newcomer": self.settings.author_nickname, + } + self.ws_client.sendTextMessage(json.dumps(message)) + def disconnect_from_room(self, log: bool = True, close_ws: bool = True) -> None: """ Disconnect widget from the current room @@ -335,6 +350,7 @@ def disconnect_from_room(self, log: bool = True, close_ws: bool = True) -> None: self.lbl_status.setText("Disconnected") self.grb_room.setTitle(self.tr("Room")) self.grb_qchat.setTitle(self.tr("QChat")) + self.btn_list_users.setEnabled(False) self.grb_user.setEnabled(False) self.connected = False if close_ws: @@ -440,6 +456,24 @@ def handle_internal_message(self, message: dict[str, Any]) -> None: ) ) self.log(message=f"Internal message received: {nb_users} users in room") + if ( + "newcomer" in message + and self.settings.qchat_display_admin_messages + and message["newcomer"] != self.settings.author_nickname + ): + newcomer = message["newcomer"] + self.add_admin_message( + self.tr("{newcomer} has joined the room").format(newcomer=newcomer) + ) + if ( + "exiter" in message + and self.settings.qchat_display_admin_messages + and message["exiter"] != self.settings.author_nickname + ): + exiter = message["exiter"] + self.add_admin_message( + self.tr("{newcomer} has left the room").format(newcomer=exiter) + ) def on_message_double_clicked(self, item: QTreeWidgetItem, column: int) -> None: """ @@ -507,6 +541,25 @@ def on_hide_message(self, item: QTreeWidgetItem) -> None: root = self.twg_chat.invisibleRootItem() (item.parent() or root).removeChild(item) + def on_list_users_button_clicked(self) -> None: + """ + Action called when the list users button is clicked + """ + try: + users = self.qchat_client.get_registered_users(self.current_room) + QMessageBox.information( + self, + self.tr("Registered users"), + self.tr( + """Registered users in room ({room}): + +{users}""" + ).format(room=self.current_room, users=",".join(users)), + ) + except Exception as exc: + self.iface.messageBar().pushCritical(self.tr("QChat error"), str(exc)) + self.log(message=str(exc), log_level=Qgis.Critical) + def on_clear_chat_button_clicked(self) -> None: """ Action called when the clear chat button is clicked diff --git a/qtribu/gui/dck_qchat.ui b/qtribu/gui/dck_qchat.ui index f85814d2..bbc29f9e 100644 --- a/qtribu/gui/dck_qchat.ui +++ b/qtribu/gui/dck_qchat.ui @@ -152,6 +152,9 @@ + + true + 0 @@ -215,14 +218,31 @@ - - - PointingHandCursor - - - Clear - - + + + + + false + + + PointingHandCursor + + + List users + + + + + + + PointingHandCursor + + + Clear + + + + diff --git a/qtribu/gui/dlg_settings.py b/qtribu/gui/dlg_settings.py index 8fecbe92..0732f58d 100644 --- a/qtribu/gui/dlg_settings.py +++ b/qtribu/gui/dlg_settings.py @@ -118,6 +118,7 @@ def apply(self): self.ckb_display_admin_messages.isChecked() ) settings.qchat_show_avatars = self.ckb_show_avatars.isChecked() + settings.qchat_incognito_mode = self.ckb_incognito_mode.isChecked() settings.qchat_play_sounds = self.ckb_play_sounds.isChecked() settings.qchat_sound_volume = self.hsl_sound_volume.value() settings.qchat_ring_tone = self.cbb_ring_tone.currentText() @@ -166,6 +167,7 @@ def load_settings(self) -> None: settings.qchat_display_admin_messages ) self.ckb_show_avatars.setChecked(settings.qchat_show_avatars) + self.ckb_incognito_mode.setChecked(settings.qchat_incognito_mode) self.ckb_play_sounds.setChecked(settings.qchat_play_sounds) self.hsl_sound_volume.setValue(settings.qchat_sound_volume) beep_index = self.cbb_ring_tone.findText( diff --git a/qtribu/gui/dlg_settings.ui b/qtribu/gui/dlg_settings.ui index f03dac15..ecb66812 100644 --- a/qtribu/gui/dlg_settings.ui +++ b/qtribu/gui/dlg_settings.ui @@ -42,8 +42,8 @@ 0 0 - 875 - 577 + 877 + 579 @@ -389,13 +389,32 @@ + + + Show avatars + + + + + + + Incognito mode + + + false + + + + + + Display admin messages @@ -403,6 +422,9 @@ + + + Activate cheatcodes diff --git a/qtribu/logic/qchat_client.py b/qtribu/logic/qchat_client.py index d73b14a9..bb7c654f 100644 --- a/qtribu/logic/qchat_client.py +++ b/qtribu/logic/qchat_client.py @@ -82,3 +82,17 @@ def get_rooms(self) -> list[str]: ) data = json.loads(str(response, "UTF8")) return data + + def get_registered_users(self, room: str) -> list[str]: + """ + Get registered users in a room with an API HTTP CALL + """ + url = f"{self.instance_uri}/room/{room}/users" + response: QByteArray = self.qntwk.get_from_source( + headers=HEADERS, + url=url, + response_expected_content_type=CONTENT_TYPE_JSON, + use_cache=False, + ) + data = json.loads(str(response, "UTF8")) + return data diff --git a/qtribu/toolbelt/preferences.py b/qtribu/toolbelt/preferences.py index f4ae4f05..49caa1cc 100644 --- a/qtribu/toolbelt/preferences.py +++ b/qtribu/toolbelt/preferences.py @@ -43,6 +43,7 @@ class PlgSettingsStructure: qchat_activate_cheatcode: bool = True qchat_display_admin_messages: bool = False qchat_show_avatars: bool = True + qchat_incognito_mode: bool = False qchat_play_sounds: bool = True qchat_sound_volume: int = 33 qchat_ring_tone: str = "beep_1"