Zoom Discourse

:discourse2: Summary Discourse Zoom empowers Discourse administrators and users with a paid Zoom subscription to schedule, manage, and participate in Zoom webinars directly from their Discourse platform.
:hammer_and_wrench: Repository Link https://github.com/discourse/discourse-zoom
:open_book: Install Guide How to install plugins in Discourse

Overview

This plugin integrates Zoom webinars into a Discourse instance. Zoom webinars can be associated with topics, Discourse users can register for webinars and join them when they start.

:warning: Due to Zoom deprecating JWT authentication, as of August 1st 2023, the plugin’s authentication mechanism has changed from JWT (now deprecated, Zoom will remove on September 1st) to Server-to-Server OAuth. Existing users of the plugin need to update their settings.

Features

  • When a Zoom webinar starts, the “Register” button automatically switches to “Join”, and clicking it launches the webinar using the Zoom SDK in a dedicated endpoint inside your Discourse community
  • Automatically reminds webinar registrants N minutes before the event (N is configurable in the plugin settings, by default reminders are turned off)
  • Administrators can add panelists to a webinar in Discourse
  • Administrators can add a link to video recordings of the webinar in Discourse, which is then displayed to users after the event has ended
  • Zoom event hosts and panelists are associated with Discourse user accounts

Usage

To use the Discourse Zoom plugin, you first need to install it in your Discourse instance and configure it with your Zoom Server-to-Server OAuth app credentials. Once the plugin is set up, you can create a new Zoom webinar by creating a new topic and associating it with the webinar. Users can then register for the webinar directly from the topic.

Installation

Step 1: Install the plugin in your Discourse instance

You can install the plugin to your Discourse instance by following the instructions here.

Step 2: Create a Server-to-Server OAuth app in the Zoom Marketplace


To get started, you’ll need to create a Server-to-Server OAuth app in the Zoom Marketplace. This app will be needed to make requests to the Zoom API and to receive events notifications via Webhooks


Step 3: Configure the plugin

Once the plugin is installed, go to your Discourse site settings and check the zoom enabled checkbox and save.

From the Zoom Marketplace go to the App Credentials tab:

Then copy and paste the values into the corresponding site settings on your Discourse instance:

  • zoom s2s account id
  • zoom s2s client id
  • zoom s2s client secret

Step 4: Set the webhook secret token

On the Feature tab of your Zoom Server-to-Server OAuth app, copy the “Secret Token” and add it to your Discourse site’s zoom webhooks secret token site setting.

Step 5: Enable event subscriptions

While still on the Feature tab of your Zoom Server-to-Server OAuth app, enable “Event Subscriptions” and and select the Add Event Subscription button:

Next, set the “Event notification endpoint URL” to:

https://YOURSITE.COM/zoom/webhooks/webinars.json

then select the + Add Events button:

Open the Webinar tab from the event types list and check all of the events that listed. If you can’t see the Webinar event permissions, check how to enable the permissions.

Under the “Event notification endpoint URL” your set earlier, find the Validate button:

It should show A checkmark icon with "Validated" in green if everything worked.

Finally select the Save button at the bottom of the page

Step 6: Scopes

Once you have set the event subscriptions move to the Scopes tab, and click on the Add Scopes button. Here you will select the following scopes by either searching by the values given in the tables, manually or using partial values, for example instead of searching for webinar:read:list_panelists:admin search for webinar:read: this will narrow down the elements show so it is easier to find the required ones.

In the Server to server OAuth app under the scopes tab click on the Add Scopes button and a window will show up:

In the search scope search by full or partial name, to facilitate this, you can copy-paste each of the scopes into the following tables or search for them under the corresponding tab:

Users

scope desc
user:read:user:admin View a user
user:read:email:admin Verify a user’s email
user:read:list_users:admin View users

Webinar

scope desc
webinar:read:list_panelists:admin View a webinar’s panelists
webinar:read:list_absentees:admin View a past webinar’s absentees
webinar:read:webinar:admin View a webinar
webinar:read:registrant:admin View a webinar’s registrant
webinar:read:list_registrants:admin View a webinar’s registrants
webinar:write:batch_registrants:admin Add registrants to a webinar
webinar:delete:webinar:admin Delete a webinar
webinar:write:panelist Add panelists to a webinar
webinar:delete:registrant Remove a webinar’s registrant
webinar:write:webinar Create a webinar for a user
webinar:update:status Update a webinar’s status
webinar:delete:panelist Remove a webinar’s panelist
webinar:update:webinar Update a webinar
webinar:write:registrant Add a registrant to a webinar

Webinar

scope desc
webinar:read:list_panelists:admin View a webinar’s panelists
webinar:read:list_absentees:admin View a past webinar’s absentees
webinar:read:webinar:admin View a webinar
webinar:read:registrant:admin View a webinar’s registrant
webinar:read:list_registrants:admin View a webinar’s registrants
webinar:write:batch_registrants:admin Add registrants to a webinar
webinar:delete:webinar:admin Delete a webinar
webinar:write:panelist Add panelists to a webinar
webinar:delete:registrant Remove a webinar’s registrant
webinar:write:webinar Create a webinar for a user
webinar:update:status Update a webinar’s status
webinar:delete:panelist Remove a webinar’s panelist
webinar:update:webinar Update a webinar
webinar:write:registrant Add a registrant to a webinar

Step 7: Create a Meeting SDK App

:warning: Zoom has changed things on their side, we are working on getting the guide updated.


The SDK meeting app authenticates the user so the user can join the webinar meeting


Start by creating a General App, and under the Select how the app is managed, select User-managed.

Under the Basic Information tab in your General App, copy and paste the Client ID/ SDK key into the zoom sdk key field, and the Client Secret/SDK secret into the zoom sdk secret field.

Scrolling down, you will find the OAuth Information section, in the OAuth Redirect URL place the URL of your site, for example, https://YOURSITE.com.

Step 8: Specify your app usage

Under the Features tab select the Embed sub-tab, enable the Meeting SDK

Limitations

The plugin only works with webinars that do not require registration in Zoom.

Notice about breaking Changes

Due to deprecations in the Zoom API, old instances of the plugin will need to be configured following the steps mentioned in this post.

:discourse2: Hosted by us? This plugin is available on our Enterprise plans.

Last edited by @nat 2024-10-03T13:27:22Z

Check documentPerform check on document:
63 Mi Piace

Thanks so much for working on this, great feature!

I was able to install the plugin, create the JWT app in Zoom, and configure my discourse as described.
However, I am running into problems when using the Zoom Webinar button in the composer to associate a scheduled meeting with the post.

It would be great if you could please add an explanation what exactly one has to enter in the text input under “Add Webinar” . Neither the meeting ID or full URL seem to work for me.

Another minor issue I noticed: The repository URL linked to in the “Plugins” page of the admin dashboard points to https://github.com/discourse-org/discourse-zoom, whereas it should be linking to GitHub - discourse/discourse-zoom: Integrate Zoom events in Discourse.

2 Mi Piace

Interesting concept, and looks like a nice experience for community members!

I’m curious if there’s been any thought yet to allowing a more generic (vendor-agnostic) workflow with this plugin; basically to offer the same embedding of a countdown timer to a specific time and date, specifying a host and/or panelist, link to the webinar URL, later links to recordings, etc.

Jiti (open source) would be the example that I had in mind but there are obviously several options in this space.

2 Mi Piace

You need to enter the webinar ID. In your site’s logs in /logs, you should be able to see more details if it still can’t add the event in the modal window. I also fixed the URL issue you mentioned, thanks for reporting that.

Unfortunately, no, this currently does not provide a vendor-agnostic workflow. The Zoom API calls are abstracted though, so it’s possible to add support for another vendor with a bit of effort (although, the plugin would need to be renamed to something less zoom-y).

8 Mi Piace

Is there any possibility of adding meeting support w/out registration to this plugin as well as webinars? Great work!

7 Mi Piace

Ora che Zoom richiede una password per tutte le riunioni e i webinar, penso che il plugin non funzioni. Ho provato a creare un webinar e quando provo a entrarci ricevo questo errore: ‘La connessione è scaduta e non puoi entrare nella riunione. Verifica la connettività di rete e riprova’.

3 Mi Piace

Ci darò un’occhiata oggi. È possibile che si tratti di un problema temporaneo: il client web di Zoom è contrassegnato come “in manutenzione” sulla loro pagina di stato all’indirizzo status.zoom.us.

5 Mi Piace

Voglio solo precisare che l’uso dei webinar richiede un abbonamento minimo di 40,00 al mese per l'attivazione, più il piano Pro da 14,99 al mese. Saluti.

2 Mi Piace

SĂŹ, purtroppo sembra che il Web SDK di Zoom sia offline al momento. Dicono che stanno lavorando per riportarlo online (non sono del tutto sicuro di cosa significhi).

Per il momento, quindi, ho aggiunto una soluzione alternativa al plugin: quando si partecipa a un webinar, se il tentativo di accesso tramite SDK fallisce, verrĂ  mostrata questa schermata:

8 Mi Piace

Per tua informazione, una cooperativa che ho co-fondato ha scelto https://bigbluebutton.org/. L’auto-ospitazione ci è costata molto meno di un account webinar di Zoom.

11 Mi Piace

Ciao Penar, ho appena notato che c’è una scheda Webinar nel profilo degli utenti. Come amministratore, posso visualizzarla come previsto, ma come utente regolare ricevo questo errore:

Accesso negato

mentre si tenta di caricare [/topics/webinar-registrations/chris_murray.json](https://community.naturephotographers.network/topics/webinar-registrations/chris_murray.json)

Dai log:

Errore: Vietato
URL: https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js
Riga: 1
Colonna: 267206
Posizione della finestra: https://community.naturephotographers.network/u/chris_murray/activity


o/t</<@https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js:1:267206
o/t<@https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js:1:267309
o@https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js:1:267390
trigger@https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js:1:545370
A</e._onError/<@https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js:1:550247
f</t.invoke@https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js:1:490055
f</t.flush@https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js:1:489055
p</t.flush@https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js:1:491070
t</t._end@https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js:1:496499
t</t.end@https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js:1:493035
t</t._run@https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js:1:497037
t</t.run@https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js:1:493643
c@https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js:1:359842
i/r.error@https://community.naturephotographers.network/assets/application-54c82e8fd96fa4eb82fa7465a602da175078108feb909cfeec95f696f02b5854.js:1:203298
i@https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js:1:27754
fireWith@https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js:1:28522
l@https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js:1:78753
o/<@https://community.naturephotographers.network/assets/ember_jquery-57d09ec67e9e407d9b0d42aa1fefd1a470c45310d953b07793a3ca8adc6ec599.js:1:81055

1 Mi Piace

Non riesco a riprodurlo. Ho testato su piĂš siti con diversi nomi utente, incluso localmente con un nome utente contenente un trattino basso.

SĂŹ, il plugin utilizza il WebSDK di Zoom e presenta problemi in alcuni browser.

1 Mi Piace

Per tua informazione, ho appena tenuto un webinar usando questa funzione e il pulsante “Unisciti” non ha funzionato per nulla: tutti hanno ricevuto un timeout da Zoom, ma ho indirizzato tutti al link regolare di Zoom, che ha funzionato perfettamente. Sembra quindi che il WebSDK stia avendo molti problemi. Forse potremmo aggiungere un’opzione per inserire manualmente l’URL nel pulsante “Unisciti”, invece di fare affidamento sul WebSDK, dato che sta fallendo?

1 Mi Piace

L’SDK di Zoom dovrebbe funzionare se fai il deploy: ho aggiornato il plugin la settimana scorsa. Tuttavia, hanno bloccato tutte le versioni precedenti, quindi se non hai effettuato il deploy di recente, questo potrebbe spiegarlo. Inoltre, aggiungere il link di Zoom come opzione ha senso.

2 Mi Piace

Grazie, Penar, non sapevo che ci fosse un aggiornamento; speriamo che questo risolva il problema per la prossima volta.

Una domanda sul video che puoi aggiungere in seguito: funziona solo per le registrazioni cloud di Zoom? Se uso Vimeo o YouTube, mi dice che non è un formato supportato. Solo per curiosità, non è un grosso problema dato che posso semplicemente includerlo nel post.

1 Mi Piace

Sì, assolutamente. Quel campo funziona solo con un URL a un file video diretto. YouTube o Vimeo non funzionano, ma come hai detto, è molto più semplice utilizzare l’oneboxing per gli URL di YouTube/Vimeo.

3 Mi Piace

Vedi: BigBlueButton video conference

1 Mi Piace

Solo un piccolo feedback dopo averlo utilizzato alcune volte.

  1. Il pulsante “Unisciti” nascosto fino all’inizio del webinar non è user-friendly. Ricevo diverse email prima dell’inizio del webinar che chiedono dove si trovi il link per unirsi, anche se l’ho specificato chiaramente nella descrizione del webinar e nella notifica che apparirà all’inizio. La gente semplicemente non legge. Personalmente, preferirei avere il pulsante “Unisciti” sempre visibile; se qualcuno ci clicca in anticipo, gli verrà semplicemente comunicato che il webinar non è ancora iniziato e tornerà a controllare l’orario effettivo di inizio.

  2. Sarebbe possibile supportare le sessioni di prova? Con i webinar, esiste l’opzione per questo: l’host e i panelisti possono parlare tra loro prima senza essere in diretta per i partecipanti. Possono cliccare sul link della riunione Zoom durante questo periodo e riceveranno un avviso che indica che la riunione non è ancora iniziata, ma si trovano in una sorta di sala d’attesa; si uniranno automaticamente non appena andremo in diretta. Questo risolverebbe molti problemi per gli utenti.

3 Mi Piace

Scusa per il ritardo, David.

C’è un’impostazione che probabilmente può aiutarti:

Se imposti questo valore a 30, il pulsante apparirà 30 minuti prima dell’orario programmato del webinar.

Dovresti poter utilizzare anche questo con l’impostazione sopra. L’ultima volta che ho controllato, i webhook di Zoom non vengono attivati quando la sessione di prova diventa un evento completo, il che rende un po’ complicata l’altra dinamica.

3 Mi Piace

Grazie Penar, ma non è proprio quello il problema.

Per prima cosa, il mio pulsante “Iscriviti ora” non funziona più affatto:

In passato funzionava, ma questo problema è iniziato nelle ultime due settimane. Inoltre, non vedo nemmeno che appaia il link di fallback.

Poi, c’è un problema separato che ho già descritto prima: il problema della modalità prova. Quando avevo il problema menzionato in precedenza, funzionava così: quando avviavo il webinar in modalità prova, il pulsante “Unisciti” non appariva, indipendentemente da come era impostato zoom join x mins before start; appariva solo quando iniziavo effettivamente la trasmissione, cosa che preferisco fare solo 5 minuti prima dell’inizio. Idealmente, il pulsante “Unisciti” dovrebbe apparire non appena viene impostato il tempo previsto, così gli utenti riceverebbero la notifica di Zoom che il webinar non è ancora iniziato.

Pensi che potresti aggiungere un’opzione per cambiare semplicemente il pulsante di registrazione in “Unisciti” al tempo impostato, usando direttamente il link di Zoom? Non un link di fallback, ma un link forzato per aggirare completamente questo problema. Grazie ancora, Penar!