Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Automatic moderation is not turned off #1977

Closed
EbubekirYucel opened this issue Dec 10, 2024 · 2 comments
Closed

Automatic moderation is not turned off #1977

EbubekirYucel opened this issue Dec 10, 2024 · 2 comments

Comments

@EbubekirYucel
Copy link

When the owner (moderator) logs out, I want to wait for a certain period of time and turn it off automatically if it does not come, but it makes any user a moderator, how can I solve it?

I checked prosody-plugins and opened the necessary modules but this situation still persists.

Below you can find my .env file.

# shellcheck disable=SC2034

################################################################################
################################################################################
# Welcome to the Jitsi Meet Docker setup!
#
# This sample .env file contains some basic options to get you started.
# The full options reference can be found here:
# https://jitsi.github.io/handbook/docs/devops-guide/devops-guide-docker
################################################################################
################################################################################


#
# Basic configuration options
#

# Directory where all configuration will be stored
CONFIG=~/.jitsi-meet-cfg

# Exposed HTTP port (will redirect to HTTPS port)
HTTP_PORT=8000

# Exposed HTTPS port
HTTPS_PORT=8443

# System time zone
TZ=UTC

# Public URL for the web service (required)
# Keep in mind that if you use a non-standard HTTPS port, it has to appear in the public URL
#PUBLIC_URL=https://meet.example.com:${HTTPS_PORT}

# Media IP addresses to advertise by the JVB
# This setting deprecates DOCKER_HOST_ADDRESS, and supports a comma separated list of IPs
# See the "Running behind NAT or on a LAN environment" section in the Handbook:
# https://jitsi.github.io/handbook/docs/devops-guide/devops-guide-docker#running-behind-nat-or-on-a-lan-environment
#JVB_ADVERTISE_IPS=192.168.1.1,1.2.3.4

#
# Memory limits for Java components
#

#JICOFO_MAX_MEMORY=3072m
#VIDEOBRIDGE_MAX_MEMORY=3072m

#
# JaaS Components (beta)
# https://jaas.8x8.vc
#

# Enable JaaS Components (hosted Jigasi)
# NOTE: if Let's Encrypt is enabled a JaaS account will be automatically created, using the provided email in LETSENCRYPT_EMAIL
#ENABLE_JAAS_COMPONENTS=0

#
# Let's Encrypt configuration
#

# Enable Let's Encrypt certificate generation
#ENABLE_LETSENCRYPT=1

# Domain for which to generate the certificate
#LETSENCRYPT_DOMAIN=meet.example.com

# E-Mail for receiving important account notifications (mandatory)
#[email protected]

# Use the staging server (for avoiding rate limits while testing)
#LETSENCRYPT_USE_STAGING=1


#
# Etherpad integration (for document sharing)
#

# Set the etherpad-lite URL in the docker local network (uncomment to enable)
#ETHERPAD_URL_BASE=http://etherpad.meet.jitsi:9001

# Set etherpad-lite public URL, including /p/ pad path fragment (uncomment to enable)
#ETHERPAD_PUBLIC_URL=https://etherpad.my.domain/p/


#
# Whiteboard integration
#

# Set the excalidraw-backend URL in the docker local network (uncomment to enable)
#WHITEBOARD_COLLAB_SERVER_URL_BASE=http://whiteboard.meet.jitsi

# Set the excalidraw-backend public URL (uncomment to enable)
#WHITEBOARD_COLLAB_SERVER_PUBLIC_URL=https://whiteboard.meet.my.domain


#
# Basic Jigasi configuration options (needed for SIP gateway support)
#

# SIP URI for incoming / outgoing calls
#[email protected]

# Password for the specified SIP account as a clear text
#JIGASI_SIP_PASSWORD=passw0rd

# SIP server (use the SIP account domain if in doubt)
#JIGASI_SIP_SERVER=sip2sip.info

# SIP server port
#JIGASI_SIP_PORT=5060

# SIP server transport
#JIGASI_SIP_TRANSPORT=UDP


#
# Authentication configuration (see handbook for details)
#

# Enable authentication (will ask for login and password to join the meeting)
ENABLE_AUTH=1

# Enable guest access (if authentication is enabled, this allows for users to be held in lobby until registered user lets them in)
ENABLE_GUESTS=0

# Select authentication type: internal, jwt, ldap or matrix
AUTH_TYPE=jwt

# JWT authentication
#

# Application identifier
JWT_APP_ID=my_jitsi_app_id

# Application secret known only to your token generator
JWT_APP_SECRET=my_jitsi_app_secret

# (Optional) Set asap_accepted_issuers as a comma separated list
# JWT_ACCEPTED_ISSUERS=my_web_client,my_app_client,my_jitsi_app_id

# (Optional) Set asap_accepted_audiences as a comma separated list
# JWT_ACCEPTED_AUDIENCES=my_server1,my_server2,my_jitsi_app_id

# LDAP authentication (for more information see the Cyrus SASL saslauthd.conf man page)
#

# LDAP url for connection
#LDAP_URL=ldaps://ldap.domain.com/

# LDAP base DN. Can be empty
#LDAP_BASE=DC=example,DC=domain,DC=com

# LDAP user DN. Do not specify this parameter for the anonymous bind
#LDAP_BINDDN=CN=binduser,OU=users,DC=example,DC=domain,DC=com

# LDAP user password. Do not specify this parameter for the anonymous bind
#LDAP_BINDPW=LdapUserPassw0rd

# LDAP filter. Tokens example:
# %1-9 - if the input key is [email protected], then %1 is com, %2 is domain and %3 is mail
# %s - %s is replaced by the complete service string
# %r - %r is replaced by the complete realm string
#LDAP_FILTER=(sAMAccountName=%u)

# LDAP authentication method
#LDAP_AUTH_METHOD=bind

# LDAP version
#LDAP_VERSION=3

# LDAP TLS using
#LDAP_USE_TLS=1

# List of SSL/TLS ciphers to allow
#LDAP_TLS_CIPHERS=SECURE256:SECURE128:!AES-128-CBC:!ARCFOUR-128:!CAMELLIA-128-CBC:!3DES-CBC:!CAMELLIA-128-CBC

# Require and verify server certificate
#LDAP_TLS_CHECK_PEER=1

# Path to CA cert file. Used when server certificate verify is enabled
#LDAP_TLS_CACERT_FILE=/etc/ssl/certs/ca-certificates.crt

# Path to CA certs directory. Used when server certificate verify is enabled
#LDAP_TLS_CACERT_DIR=/etc/ssl/certs

# Wether to use starttls, implies LDAPv3 and requires ldap:// instead of ldaps://
# LDAP_START_TLS=1


#
# Security
#
# Set these to strong passwords to avoid intruders from impersonating a service account
# The service(s) won't start unless these are specified
# Running ./gen-passwords.sh will update .env with strong passwords
# You may skip the Jigasi and Jibri passwords if you are not using those
# DO NOT reuse passwords
#

# XMPP password for Jicofo client connections
JICOFO_AUTH_PASSWORD=<secret_token>

# XMPP password for JVB client connections
JVB_AUTH_PASSWORD=<secret_token>

# XMPP password for Jigasi MUC client connections
JIGASI_XMPP_PASSWORD=<secret_token>

# XMPP password for Jigasi transcriber client connections
JIGASI_TRANSCRIBER_PASSWORD=<secret_token>

# XMPP recorder password for Jibri client connections
JIBRI_RECORDER_PASSWORD=<secret_token>

# XMPP password for Jibri client connections
JIBRI_XMPP_PASSWORD=<secret_token>

#
# Docker Compose options
#

# Container restart policy
#RESTART_POLICY=unless-stopped

# Jitsi image version (useful for local development)
#JITSI_IMAGE_VERSION=latest


ENABLE_BREAKOUT_ROOMS=0
ENABLE_WELCOME_PAGE=0
ENABLE_PREJOIN_PAGE=0
ENABLE_LOBBY=0
ENABLE_AV_MODERATION=1
TOOLBAR_BUTTONS=microphone,hangup,camera,toggle-camera,chat,participants-pane,fullscreen

ENABLE_AUTO_OWNER=0
ENABLE_MODERATOR_CHECKS=1

XMPP_MUC_MODULES=token_affiliation,token_owner_party,owner_restricted

This is the payload I use for JWT
Member:

{
  "aud": "my_jitsi_app_id",
  "iss": "my_jitsi_app_id",
  "room": "123",
  "exp": 1733839599,
  "moderator": false,
  "context": {
    "user": {
      "name": "Akın KARPUZ",
      "email": "[email protected]",
      "moderator": false,
      "affiliation": "member"
    },
    "moderator": false
  }
}

Owner(moderator)

{
  "aud": "my_jitsi_app_id",
  "iss": "my_jitsi_app_id",
  "room": "123",
  "exp": 1733839636,
  "moderator": true,
  "context": {
    "user": {
      "name": "KEVIN",
      "email": "[email protected]",
      "moderator": true,
      "affiliation": "owner"
    },
    "moderator": true
  }
}
@sakiphan
Copy link

Hi Ebubekir

JWT_TOKEN_AUTH_MODULE=token_affiliation

Can you try it this way?

@EbubekirYucel
Copy link
Author

@sakiphan thank you for contacting us. We forgot to close Issues.

We solved the problem. Our solution is JICOFO_ENABLE_AUTH=0 and XMPP_MUC_CONFIGURATION we reached the solution by making adjustments.

.env file we reached the solution

JICOFO_ENABLE_AUTH=0
ENABLE_AUTO_OWNER=0

ENABLE_LOBBY=0
ENABLE_BREAKOUT_ROOMS=0
ENABLE_WELCOME_PAGE=0
ENABLE_PREJOIN_PAGE=0
ENABLE_AV_MODERATION=1
TOOLBAR_BUTTONS=microphone,hangup,camera,toggle-camera,chat,participants-pane,fullscreen,desktop,raisehand

XMPP_MUC_MODULES=token_affiliation,owner_restricted,time_restricted,token_owner_party
XMPP_MODULES=frozen_nick

XMPP_MUC_CONFIGURATION=conference_max_minutes=60,role_timeout=60,party_check_timeout=60

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants