This plugin provides a token that proves its owner is a participant of an
ongoing Jitsi
meeting.
Let's say you have an API service and you want to allow this service to accept requests from the user only if they are an active participant of a meeting. In this case, you may use this module.
-
Copy this script to the Prosody plugins folder. It's the following folder on Debian:
cd /usr/share/jitsi-meet/prosody-plugins/ wget -O mod_access_token.lua https://raw.githubusercontent.com/jitsi-contrib/prosody-plugins/main/access_token/mod_access_token.lua
-
Enable module in your prosody config.
/etc/prosody/conf.d/meet.mydomain.com.cfg.lua
Component "conference.meet.mydomain.com" "muc" modules_enabled = { ... ... "access_token"; } access_token_key = "mysecretkey" access_token_alg = "HS256" access_token_exp = 60
-
Restart the services
systemctl restart prosody.service
Send an XMPP query
to get the token.
A sample javascript
code:
<script>
function getToken() {
const NS_ACCESS_TOKEN = "http://jabber.org/protocol/muc#access-token";
const iq = $iq({
type: "get",
to: APP.conference._room.room.focusMucJid,
});
iq.c("query", { xmlns: NS_ACCESS_TOKEN });
APP.connection.xmpp.connection.sendIQ(iq, (result) => {
const token_data = $(result).find("token").attr("data");
console.log(`token: ${token_data}`);
}, (error) => {
console.error(error);
});
}
</script>
Put the sample code into /usr/share/jitsi-meet/body.html
and run the following
command on the browser console after joining the meeting:
getToken();
A sample payload:
{
"exp": 1674310904,
"host": "jitsi.mydomain.corp",
"room": "myroom",
"userJid": "[email protected]/yMZO0YX8"
}