From abb42a23d652d5762e65ba47ab98d13b5628c7d3 Mon Sep 17 00:00:00 2001 From: Adrian Moennich Date: Wed, 11 Dec 2024 10:42:13 +0100 Subject: [PATCH] VC/Zoom: s/rooms/meetings/ --- vc_zoom/README.md | 8 ++++++-- vc_zoom/indico_vc_zoom/cli.py | 4 ++-- vc_zoom/indico_vc_zoom/controllers.py | 4 ++-- vc_zoom/indico_vc_zoom/fixtures.py | 2 +- vc_zoom/indico_vc_zoom/forms.py | 6 +++--- vc_zoom/indico_vc_zoom/plugin.py | 17 +++++++++-------- .../templates/emails/remote_deleted.html | 2 +- vc_zoom/pyproject.toml | 2 +- 8 files changed, 25 insertions(+), 20 deletions(-) diff --git a/vc_zoom/README.md b/vc_zoom/README.md index 16f9879a4..b951e7994 100644 --- a/vc_zoom/README.md +++ b/vc_zoom/README.md @@ -11,6 +11,10 @@ ## Changelog +### 3.3.2 + +- Stop using the (incorrect) "room" terminology for Zoom meetings, and call them "meetings" instead + ### 3.3.1 - Adapt to Indico 3.3.5 changes @@ -96,7 +100,7 @@ - Improve logging when a Zoom API request fails - Fail more gracefully if no Zoom account could be found for a user -- Allow using the same name for multiple Zoom rooms +- Allow using the same name for multiple Zoom meetings - Update the join url when changing the passcode - Provide an alternative method of looking up the Zoom user corresponding to an Indico user - Always show the full join link and passcode to event managers @@ -107,7 +111,7 @@ - Show detailed error when deleting a meeting fails - Do not allow passcodes that are too long for zoom - Remove the "Assistant Zoom ID" logic due to problems with Zoom's API rate limits (all meetings created were counted against the assistant's rate limit instead of the host's); this means the host can no longer be changed, but Indico instead provides an option to event managers to make themselves a co-host. -- Fix an error when changing the linked object of a recurring Zoom room in Indico +- Fix an error when changing the linked object of a recurring Zoom meeting in Indico - Include Zoom join links in the event's ical export (note: only Zoom meetings with a public passcode are displayed unless you have at least Indico v2.3.3) - Skip deleted Zoom meetings when cloning events - Mark Zoom meetings as deleted when receiving the corresponding webhook event diff --git a/vc_zoom/indico_vc_zoom/cli.py b/vc_zoom/indico_vc_zoom/cli.py index 139740e0f..830ab5002 100644 --- a/vc_zoom/indico_vc_zoom/cli.py +++ b/vc_zoom/indico_vc_zoom/cli.py @@ -19,8 +19,8 @@ def cli(): @cli.command() @click.option('--status', type=click.Choice(['deleted', 'created'])) -def rooms(status=None): - """Lists all Zoom rooms""" +def meetings(status=None): + """Lists all Zoom meetings""" room_query = VCRoom.query.filter_by(type='zoom') table_data = [['ID', 'Name', 'Status', 'Zoom ID']] diff --git a/vc_zoom/indico_vc_zoom/controllers.py b/vc_zoom/indico_vc_zoom/controllers.py index d555f7e65..04d4008f0 100644 --- a/vc_zoom/indico_vc_zoom/controllers.py +++ b/vc_zoom/indico_vc_zoom/controllers.py @@ -91,13 +91,13 @@ def _handle_zoom_event(self, event, payload): if not vc_room: # This usually happens when a room wasn't created via indico - current_plugin.logger.debug('Action for unhandled Zoom room: %s', meeting_id) + current_plugin.logger.debug('Action for unhandled Zoom meeting: %s', meeting_id) return if event in ('meeting.updated', 'webinar.updated'): current_plugin.refresh_room(vc_room, None) elif event in ('meeting.deleted', 'webinar.deleted'): - current_plugin.logger.info('Zoom room deleted: %s', meeting_id) + current_plugin.logger.info('Zoom meeting deleted: %s', meeting_id) vc_room.status = VCRoomStatus.deleted else: current_plugin.logger.warning('Unhandled Zoom webhook payload: %s', event) diff --git a/vc_zoom/indico_vc_zoom/fixtures.py b/vc_zoom/indico_vc_zoom/fixtures.py index 327393ad5..c7cbc45a4 100644 --- a/vc_zoom/indico_vc_zoom/fixtures.py +++ b/vc_zoom/indico_vc_zoom/fixtures.py @@ -14,7 +14,7 @@ @pytest.fixture def zoom_plugin(app): - """Return a callable which lets you create dummy Zoom room occurrences.""" + """Return a callable which lets you create dummy Zoom meeting occurrences.""" from indico_vc_zoom.plugin import ZoomPlugin plugin = ZoomPlugin(plugin_engine, app) diff --git a/vc_zoom/indico_vc_zoom/forms.py b/vc_zoom/indico_vc_zoom/forms.py index 1dfb50654..5989a8149 100644 --- a/vc_zoom/indico_vc_zoom/forms.py +++ b/vc_zoom/indico_vc_zoom/forms.py @@ -69,15 +69,15 @@ class VCRoomForm(VCRoomFormBase): mute_audio = BooleanField(_('Mute audio'), widget=SwitchWidget(), - description=_('Participants will join the VC room muted by default ')) + description=_('Participants will join the meeting muted by default ')) mute_host_video = BooleanField(_('Mute video (host)'), widget=SwitchWidget(), - description=_('The host will join the VC room with video disabled')) + description=_('The host will join the meeting with video disabled')) mute_participant_video = BooleanField(_('Mute video (participants)'), widget=SwitchWidget(), - description=_('Participants will join the VC room with video disabled')) + description=_('Participants will join the meeting with video disabled')) waiting_room = BooleanField(_('Waiting room'), widget=SwitchWidget(), diff --git a/vc_zoom/indico_vc_zoom/plugin.py b/vc_zoom/indico_vc_zoom/plugin.py index fe68ef7bc..ee4338cbf 100644 --- a/vc_zoom/indico_vc_zoom/plugin.py +++ b/vc_zoom/indico_vc_zoom/plugin.py @@ -88,15 +88,15 @@ class PluginSettingsForm(VCPluginSettingsFormBase): mute_audio = BooleanField(_('Mute audio'), widget=SwitchWidget(), - description=_('Participants will join the VC room muted by default ')) + description=_('Participants will join the meeting muted by default ')) mute_host_video = BooleanField(_('Mute video (host)'), widget=SwitchWidget(), - description=_('The host will join the VC room with video disabled')) + description=_('The host will join the meeting with video disabled')) mute_participant_video = BooleanField(_('Mute video (participants)'), widget=SwitchWidget(), - description=_('Participants will join the VC room with video disabled')) + description=_('Participants will join the meeting with video disabled')) join_before_host = BooleanField(_('Join Before Host'), widget=SwitchWidget(), @@ -108,7 +108,8 @@ class PluginSettingsForm(VCPluginSettingsFormBase): description=_('Participants may be kept in a waiting room by the host')) creation_email_footer = TextAreaField(_('Creation email footer'), widget=TinyMCEWidget(), - description=_('Footer to append to emails sent upon creation of a VC room')) + description=_('Footer to append to emails sent upon creation of a Zoom ' + 'meeting')) send_host_url = BooleanField(_('Send host URL'), widget=SwitchWidget(), @@ -298,14 +299,14 @@ def update_data_vc_room(self, vc_room, data, is_new=False): flag_modified(vc_room, 'data') def create_room(self, vc_room, event): - """Create a new Zoom room for an event, given a VC room. + """Create a new Zoom meeting for an event, given a VC room. - In order to create the Zoom room, the function will try to get + In order to create the Zoom meeting, the function will try to get a valid e-mail address for the user in question, which can be use with the Zoom API. - :param vc_room: the VC room from which to create the Zoom room - :param event: the event to the Zoom room will be attached + :param vc_room: the VC room from which to create the Zoom meeting + :param event: the event to the Zoom meeting will be attached """ client = ZoomIndicoClient() host = principal_from_identifier(vc_room.data['host']) diff --git a/vc_zoom/indico_vc_zoom/templates/emails/remote_deleted.html b/vc_zoom/indico_vc_zoom/templates/emails/remote_deleted.html index 31904dfb9..bdeff7969 100644 --- a/vc_zoom/indico_vc_zoom/templates/emails/remote_deleted.html +++ b/vc_zoom/indico_vc_zoom/templates/emails/remote_deleted.html @@ -6,7 +6,7 @@ {% block header -%}

- The Zoom room "{{ vc_room.name }}" has been deleted from the Zoom server since it has not been used by any recent event. + The Zoom meeting "{{ vc_room.name }}" has been deleted from the Zoom server since it has not been used by any recent event.

You won't be able to attach it to any future events. If you need to do so, please create a new room. diff --git a/vc_zoom/pyproject.toml b/vc_zoom/pyproject.toml index bd060d2df..3405f0815 100644 --- a/vc_zoom/pyproject.toml +++ b/vc_zoom/pyproject.toml @@ -2,7 +2,7 @@ name = 'indico-plugin-vc-zoom' description = 'Zoom video-conferencing plugin for Indico' readme = 'README.md' -version = '3.3.1' +version = '3.3.2' license = 'MIT' authors = [ { name = 'Indico Team', email = 'indico-team@cern.ch' },