From b907485778590e37945fe8caad49eb88d50e1b62 Mon Sep 17 00:00:00 2001
From: Michael Jerger <michael.jerger@meissa-gmbh.de>
Date: Tue, 18 Feb 2025 12:56:37 +0100
Subject: [PATCH] web is no longer neded

---
 infrastructure/web/build.py                   |  57 --
 infrastructure/web/image/Dockerfile           |   6 -
 .../web/image/resources/install-debug.sh      |   3 -
 infrastructure/web/image/resources/install.sh |  17 -
 .../settings-config-stable-10008.orig         | 630 -----------------
 .../web/image/resources/settings-config.js    | 637 ------------------
 6 files changed, 1350 deletions(-)
 delete mode 100644 infrastructure/web/build.py
 delete mode 100644 infrastructure/web/image/Dockerfile
 delete mode 100644 infrastructure/web/image/resources/install-debug.sh
 delete mode 100755 infrastructure/web/image/resources/install.sh
 delete mode 100644 infrastructure/web/image/resources/settings-config-stable-10008.orig
 delete mode 100644 infrastructure/web/image/resources/settings-config.js

diff --git a/infrastructure/web/build.py b/infrastructure/web/build.py
deleted file mode 100644
index 7d3b2d5..0000000
--- a/infrastructure/web/build.py
+++ /dev/null
@@ -1,57 +0,0 @@
-from os import environ
-from datetime import datetime
-from pybuilder.core import task, init
-from ddadevops import *
-
-name = "c4k-jitsi"
-MODULE = "web"
-PROJECT_ROOT_PATH = "../.."
-version = "2.2.1-dev"
-
-
-@init
-def initialize(project):
-    image_tag = version
-    if "dev" in image_tag:
-        image_tag += datetime.now().strftime("%Y-%m-%d-%H-%M-%S")
-
-    input = {
-        "name": name,
-        "module": MODULE,
-        "stage": "notused",
-        "project_root_path": PROJECT_ROOT_PATH,
-        "build_types": ["IMAGE"],
-        "mixin_types": [],
-        "image_naming": "NAME_AND_MODULE",
-        "image_tag": f"{image_tag}",
-    }
-
-    project.build_depends_on("ddadevops>=4.7.0")
-
-    build = DevopsImageBuild(project, input)
-    build.initialize_build_dir()
-
-
-@task
-def image(project):
-    build = get_devops_build(project)
-    build.image()
-
-
-@task
-def drun(project):
-    build = get_devops_build(project)
-    build.drun()
-
-
-@task
-def test(project):
-    build = get_devops_build(project)
-    build.test()
-
-
-@task
-def publish(project):
-    build = get_devops_build(project)
-    build.dockerhub_login()
-    build.dockerhub_publish()
diff --git a/infrastructure/web/image/Dockerfile b/infrastructure/web/image/Dockerfile
deleted file mode 100644
index 221f975..0000000
--- a/infrastructure/web/image/Dockerfile
+++ /dev/null
@@ -1,6 +0,0 @@
-# IMPORTANT: In case of base image update, "./resources/settings-config.js" also has to be updated manually!
-FROM jitsi/web:stable-9646
-
-# Prepare Configuration
-ADD resources /tmp
-RUN /tmp/install.sh
diff --git a/infrastructure/web/image/resources/install-debug.sh b/infrastructure/web/image/resources/install-debug.sh
deleted file mode 100644
index a5b8ce8..0000000
--- a/infrastructure/web/image/resources/install-debug.sh
+++ /dev/null
@@ -1,3 +0,0 @@
-#!/bin/bash
-
-apt update && apt -qqy install vim bash-completion less
diff --git a/infrastructure/web/image/resources/install.sh b/infrastructure/web/image/resources/install.sh
deleted file mode 100755
index 696a6be..0000000
--- a/infrastructure/web/image/resources/install.sh
+++ /dev/null
@@ -1,17 +0,0 @@
-#!/bin/bash
-
-set -exo pipefail
-
-function main() {
-    {
-        upgradeSystem
-    } > /dev/null
-
-    install -m 0700 /tmp/install-debug.sh /usr/local/bin/
-    install -m 0644 /tmp/settings-config.js /defaults/settings-config.js
-
-    cleanupDocker
-}
-
-source /tmp/install_functions_debian.sh
-DEBIAN_FRONTEND=noninteractive DEBCONF_NOWARNINGS=yes main
\ No newline at end of file
diff --git a/infrastructure/web/image/resources/settings-config-stable-10008.orig b/infrastructure/web/image/resources/settings-config-stable-10008.orig
deleted file mode 100644
index da286f9..0000000
--- a/infrastructure/web/image/resources/settings-config-stable-10008.orig
+++ /dev/null
@@ -1,630 +0,0 @@
-{{ $ENABLE_ADAPTIVE_MODE := .Env.ENABLE_ADAPTIVE_MODE | default "true" | toBool -}}
-{{ $ENABLE_AUDIO_PROCESSING := .Env.ENABLE_AUDIO_PROCESSING | default "true" | toBool -}}
-{{ $ENABLE_AUTOMATIC_GAIN_CONTROL := .Env.ENABLE_AUTOMATIC_GAIN_CONTROL | default "true" | toBool -}}
-{{ $ENABLE_BREAKOUT_ROOMS := .Env.ENABLE_BREAKOUT_ROOMS | default "true" | toBool -}}
-{{ $ENABLE_CALENDAR := .Env.ENABLE_CALENDAR | default "false" | toBool -}}
-{{ $ENABLE_FILE_RECORDING_SHARING := .Env.ENABLE_FILE_RECORDING_SHARING | default "false" | toBool -}}
-{{ $ENABLE_NO_AUDIO_DETECTION := .Env.ENABLE_NO_AUDIO_DETECTION | default "true" | toBool -}}
-{{ $ENABLE_P2P := .Env.ENABLE_P2P | default "true" | toBool -}}
-{{ $ENABLE_PREJOIN_PAGE := .Env.ENABLE_PREJOIN_PAGE | default "true" | toBool -}}
-{{ $ENABLE_WELCOME_PAGE := .Env.ENABLE_WELCOME_PAGE | default "true" | toBool -}}
-{{ $ENABLE_CLOSE_PAGE := .Env.ENABLE_CLOSE_PAGE | default "false" | toBool -}}
-{{ $ENABLE_RECORDING := .Env.ENABLE_RECORDING | default "false" | toBool -}}
-{{ $ENABLE_SERVICE_RECORDING := .Env.ENABLE_SERVICE_RECORDING | default ($ENABLE_RECORDING | printf "%t") | toBool -}}
-{{ $ENABLE_LIVESTREAMING := .Env.ENABLE_LIVESTREAMING | default "false" | toBool -}}
-{{ $ENABLE_LIVESTREAMING_DATA_PRIVACY_LINK := .Env.ENABLE_LIVESTREAMING_DATA_PRIVACY_LINK | default "https://policies.google.com/privacy" -}}
-{{ $ENABLE_LIVESTREAMING_HELP_LINK := .Env.ENABLE_LIVESTREAMING_HELP_LINK | default "https://jitsi.org/live" -}}
-{{ $ENABLE_LIVESTREAMING_TERMS_LINK := .Env.ENABLE_LIVESTREAMING_TERMS_LINK | default "https://www.youtube.com/t/terms" -}}
-{{ $ENABLE_LIVESTREAMING_VALIDATOR_REGEXP_STRING := .Env.ENABLE_LIVESTREAMING_VALIDATOR_REGEXP_STRING | default "^(?:[a-zA-Z0-9]{4}(?:-(?!$)|$)){4}" -}}
-{{ $ENABLE_REMB := .Env.ENABLE_REMB | default "true" | toBool -}}
-{{ $ENABLE_REQUIRE_DISPLAY_NAME := .Env.ENABLE_REQUIRE_DISPLAY_NAME | default "false" | toBool -}}
-{{ $ENABLE_SIMULCAST := .Env.ENABLE_SIMULCAST | default "true" | toBool -}}
-{{ $ENABLE_STEREO := .Env.ENABLE_STEREO | default "false" | toBool -}}
-{{ $ENABLE_OPUS_RED := .Env.ENABLE_OPUS_RED | default "false" | toBool -}}
-{{ $ENABLE_TALK_WHILE_MUTED := .Env.ENABLE_TALK_WHILE_MUTED | default "false" | toBool -}}
-{{ $ENABLE_TCC := .Env.ENABLE_TCC | default "true" | toBool -}}
-{{ $ENABLE_TRANSCRIPTIONS := .Env.ENABLE_TRANSCRIPTIONS | default "false" | toBool -}}
-{{ $TRANSLATION_LANGUAGES := .Env.TRANSLATION_LANGUAGES | default "[]" -}}
-{{ $TRANSLATION_LANGUAGES_HEAD := .Env.TRANSLATION_LANGUAGES_HEAD | default "['en']" -}}
-{{ $USE_APP_LANGUAGE := .Env.USE_APP_LANGUAGE | default "true" | toBool -}}
-{{ $PREFERRED_LANGUAGE := .Env.PREFERRED_LANGUAGE | default "en-US" -}}
-{{ $DISABLE_START_FOR_ALL := .Env.DISABLE_START_FOR_ALL | default "false" | toBool -}}
-{{ $AUTO_CAPTION_ON_RECORD := .Env.AUTO_CAPTION_ON_RECORD | default "false" | toBool -}}
-{{ $ENABLE_JAAS_COMPONENTS := .Env.ENABLE_JAAS_COMPONENTS | default "0" | toBool }}
-{{ $HIDE_PREJOIN_DISPLAY_NAME := .Env.HIDE_PREJOIN_DISPLAY_NAME | default "false" | toBool -}}
-{{ $PUBLIC_URL := .Env.PUBLIC_URL | default "https://localhost:8443" -}}
-{{ $RESOLUTION := .Env.RESOLUTION | default "720" -}}
-{{ $RESOLUTION_MIN := .Env.RESOLUTION_MIN | default "180" -}}
-{{ $RESOLUTION_WIDTH := .Env.RESOLUTION_WIDTH | default "1280" -}}
-{{ $RESOLUTION_WIDTH_MIN := .Env.RESOLUTION_WIDTH_MIN | default "320" -}}
-{{ $START_AUDIO_ONLY := .Env.START_AUDIO_ONLY | default "false" | toBool -}}
-{{ $START_AUDIO_MUTED := .Env.START_AUDIO_MUTED | default 10 -}}
-{{ $START_WITH_AUDIO_MUTED := .Env.START_WITH_AUDIO_MUTED | default "false" | toBool -}}
-{{ $START_SILENT := .Env.START_SILENT | default "false" | toBool -}}
-{{ $DISABLE_AUDIO_LEVELS := .Env.DISABLE_AUDIO_LEVELS | default "false" | toBool -}}
-{{ $ENABLE_NOISY_MIC_DETECTION := .Env.ENABLE_NOISY_MIC_DETECTION | default "true" | toBool -}}
-{{ $START_VIDEO_MUTED := .Env.START_VIDEO_MUTED | default 10 -}}
-{{ $START_WITH_VIDEO_MUTED := .Env.START_WITH_VIDEO_MUTED | default "false" | toBool -}}
-{{ $DESKTOP_SHARING_FRAMERATE_AUTO := .Env.DESKTOP_SHARING_FRAMERATE_AUTO | default "true" | toBool -}}
-{{ $DESKTOP_SHARING_FRAMERATE_MIN := .Env.DESKTOP_SHARING_FRAMERATE_MIN | default 5 -}}
-{{ $DESKTOP_SHARING_FRAMERATE_MAX := .Env.DESKTOP_SHARING_FRAMERATE_MAX | default 5 -}}
-{{ $XMPP_DOMAIN := .Env.XMPP_DOMAIN | default "meet.jitsi" -}}
-{{ $XMPP_HIDDEN_DOMAIN := .Env.XMPP_HIDDEN_DOMAIN | default "hidden.meet.jitsi" -}}
-{{ $DISABLE_DEEP_LINKING  := .Env.DISABLE_DEEP_LINKING | default "false" | toBool -}}
-{{ $DISABLE_POLLS := .Env.DISABLE_POLLS | default "false" | toBool -}}
-{{ $DISABLE_REACTIONS := .Env.DISABLE_REACTIONS | default "false" | toBool -}}
-{{ $DISABLE_REMOTE_VIDEO_MENU := .Env.DISABLE_REMOTE_VIDEO_MENU | default "false" | toBool -}}
-{{ $DISABLE_PRIVATE_CHAT:= .Env.DISABLE_PRIVATE_CHAT | default "false" | toBool -}}
-{{ $DISABLE_KICKOUT := .Env.DISABLE_KICKOUT | default "false" | toBool -}}
-{{ $DISABLE_GRANT_MODERATOR := .Env.DISABLE_GRANT_MODERATOR | default "false" | toBool -}}
-{{ $ENABLE_E2EPING := .Env.ENABLE_E2EPING | default "false" | toBool -}}
-{{ $DISABLE_LOCAL_RECORDING := .Env.DISABLE_LOCAL_RECORDING | default "false" | toBool -}}
-{{ $ENABLE_LOCAL_RECORDING_NOTIFY_ALL_PARTICIPANT := .Env.ENABLE_LOCAL_RECORDING_NOTIFY_ALL_PARTICIPANT | default "false" | toBool -}}
-{{ $ENABLE_LOCAL_RECORDING_SELF_START := .Env.ENABLE_LOCAL_RECORDING_SELF_START | default "false" | toBool -}}
-{{ $DISABLE_PROFILE := .Env.DISABLE_PROFILE | default "false" | toBool -}}
-{{ $ROOM_PASSWORD_DIGITS := .Env.ROOM_PASSWORD_DIGITS | default "false" -}}
-{{ $WHITEBOARD_ENABLED := or (.Env.WHITEBOARD_COLLAB_SERVER_PUBLIC_URL | default "" | toBool) (.Env.WHITEBOARD_COLLAB_SERVER_URL_BASE | default "" | toBool) }}
-{{ $CODEC_ORDER_JVB := .Env.CODEC_ORDER_JVB | default "[\"AV1\", \"VP9\", \"VP8\", \"H264\"]" -}}
-{{ $CODEC_ORDER_JVB_MOBILE := .Env.CODEC_ORDER_JVB_MOBILE | default "[\"VP8\", \"VP9\", \"H264\", \"AV1\"]" -}}
-{{ $CODEC_ORDER_P2P := .Env.CODEC_ORDER_JVB | default "[\"AV1\", \"VP9\", \"VP8\", \"H264\"]" -}}
-{{ $CODEC_ORDER_P2P_MOBILE := .Env.CODEC_ORDER_JVB_MOBILE | default "[\"VP8\", \"VP9\", \"H264\", \"AV1\"]" -}}
-
-// Video configuration.
-//
-
-config.resolution = {{ $RESOLUTION }};
-config.constraints = {
-    video: {
-        height: { ideal: {{ $RESOLUTION }}, max: {{ $RESOLUTION }}, min: {{ $RESOLUTION_MIN }} },
-        width: { ideal: {{ $RESOLUTION_WIDTH }}, max: {{ $RESOLUTION_WIDTH }}, min: {{ $RESOLUTION_WIDTH_MIN }}},
-    }
-};
-
-{{ if not $ENABLE_SIMULCAST -}}
-config.disableSimulcast = true;
-{{ end -}}
-config.startVideoMuted = {{ $START_VIDEO_MUTED }};
-config.startWithVideoMuted = {{ $START_WITH_VIDEO_MUTED }};
-
-config.flags = {
-    sourceNameSignaling: true,
-    sendMultipleVideoStreams: true,
-    receiveMultipleVideoStreams: true
-};
-
-// ScreenShare Configuration.
-//
-
-{{ if not $DESKTOP_SHARING_FRAMERATE_AUTO -}}
-config.desktopSharingFrameRate = {
-    min: {{ $DESKTOP_SHARING_FRAMERATE_MIN }},
-    max: {{ $DESKTOP_SHARING_FRAMERATE_MAX }}
-};
-{{ end -}}
-
-// Audio configuration.
-//
-
-config.enableNoAudioDetection = {{ $ENABLE_NO_AUDIO_DETECTION }};
-config.enableTalkWhileMuted = {{ $ENABLE_TALK_WHILE_MUTED }};
-config.disableAP = {{ not $ENABLE_AUDIO_PROCESSING }};
-config.disableAGC = {{ not $ENABLE_AUTOMATIC_GAIN_CONTROL }};
-
-config.audioQuality = {
-    stereo: {{ $ENABLE_STEREO }}
-};
-
-{{ if .Env.AUDIO_QUALITY_OPUS_BITRATE -}}
-config.audioQuality.opusMaxAverageBitrate = '{{ .Env.AUDIO_QUALITY_OPUS_BITRATE }}';
-{{ end -}}
-
-config.startAudioOnly = {{ $START_AUDIO_ONLY }};
-config.startAudioMuted = {{ $START_AUDIO_MUTED }};
-config.startWithAudioMuted = {{ $START_WITH_AUDIO_MUTED }};
-config.startSilent = {{ $START_SILENT }};
-config.enableOpusRed = {{ $ENABLE_OPUS_RED }};
-config.disableAudioLevels = {{ $DISABLE_AUDIO_LEVELS }};
-config.enableNoisyMicDetection = {{ $ENABLE_NOISY_MIC_DETECTION }};
-
-
-// Peer-to-Peer options.
-//
-
-config.p2p = {
-    enabled: {{ $ENABLE_P2P }},
-    codecPreferenceOrder: {{ $CODEC_ORDER_P2P }},
-    mobileCodecPreferenceOrder: {{ $CODEC_ORDER_P2P_MOBILE }}
-};
-
-{{ if .Env.P2P_STUN_SERVERS -}}
-config.p2p.stunServers = '{{ .Env.P2P_STUN_SERVERS }}'.split(',').map(url => ({ urls: 'stun:' + url }));
-
-{{ end -}}
-
-// Breakout Rooms
-//
-
-config.hideAddRoomButton = {{ $ENABLE_BREAKOUT_ROOMS | not }};
-
-
-// Etherpad
-//
-
-{{ if .Env.ETHERPAD_PUBLIC_URL -}}
-config.etherpad_base = '{{ .Env.ETHERPAD_PUBLIC_URL }}';
-{{ else if .Env.ETHERPAD_URL_BASE -}}
-config.etherpad_base = '{{ $PUBLIC_URL }}/etherpad/p/';
-{{ end -}}
-
-
-// Recording.
-//
-
-{{ if or $ENABLE_RECORDING $ENABLE_TRANSCRIPTIONS  -}}
-
-config.hiddenDomain = '{{ $XMPP_HIDDEN_DOMAIN }}';
-{{ end -}}
-
-{{ if $ENABLE_RECORDING -}}
-
-config.recordingService = {
-    // Whether to enable file recording or not using the "service" defined by the finalizer in Jibri
-    enabled: {{ $ENABLE_SERVICE_RECORDING }},
-
-    // Whether to show the possibility to share file recording with other people
-    // (e.g. meeting participants), based on the actual implementation
-    // on the backend.
-    sharingEnabled: {{ $ENABLE_FILE_RECORDING_SHARING }}
-};
-
-// Live streaming configuration.
-config.liveStreaming = {
-    enabled: {{ $ENABLE_LIVESTREAMING }},
-    dataPrivacyLink: '{{ $ENABLE_LIVESTREAMING_DATA_PRIVACY_LINK }}',
-    helpLink: '{{ $ENABLE_LIVESTREAMING_HELP_LINK }}',
-    termsLink: '{{ $ENABLE_LIVESTREAMING_TERMS_LINK }}',
-    validatorRegExpString: '{{ $ENABLE_LIVESTREAMING_VALIDATOR_REGEXP_STRING }}'
-};
-
-
-{{ if .Env.DROPBOX_APPKEY -}}
-// Enable the dropbox integration.
-config.dropbox = {
-    appKey: '{{ .Env.DROPBOX_APPKEY }}'
-};
-
-{{ if .Env.DROPBOX_REDIRECT_URI -}}
-// A URL to redirect the user to, after authenticating
-// by default uses:
-// 'https://jitsi-meet.example.com/static/oauth.html'
-config.dropbox.redirectURI = '{{ .Env.DROPBOX_REDIRECT_URI }}';
-{{ end -}}
-{{ end -}}
-
-{{ end -}}
-
-// Local recording configuration.
-config.localRecording = {
-    disable: {{ $DISABLE_LOCAL_RECORDING }},
-    notifyAllParticipants: {{ $ENABLE_LOCAL_RECORDING_NOTIFY_ALL_PARTICIPANT }},
-    disableSelfRecording: {{ $ENABLE_LOCAL_RECORDING_SELF_START }}
-};
-
-
-// Analytics.
-//
-
-config.analytics = {};
-
-{{ if .Env.AMPLITUDE_ID -}}
-// The Amplitude APP Key:
-config.analytics.amplitudeAPPKey = '{{ .Env.AMPLITUDE_ID }}';
-{{ end -}}
-
-{{ if .Env.GOOGLE_ANALYTICS_ID -}}
-// The Google Analytics Tracking ID:
-config.analytics.googleAnalyticsTrackingId = '{{ .Env.GOOGLE_ANALYTICS_ID }}';
-{{ end -}}
-
-{{ if .Env.MATOMO_ENDPOINT -}}
-// Matomo endpoint:
-config.analytics.matomoEndpoint = '{{ .Env.MATOMO_ENDPOINT }}';
-{{ end -}}
-
-{{ if .Env.MATOMO_SITE_ID -}}
-// Matomo site ID:
-config.analytics.matomoSiteID = '{{ .Env.MATOMO_SITE_ID }}';
-{{ end -}}
-
-{{ if .Env.ANALYTICS_SCRIPT_URLS -}}
-// Array of script URLs to load as lib-jitsi-meet "analytics handlers".
-config.analytics.scriptURLs = [ '{{ join "','" (splitList "," .Env.ANALYTICS_SCRIPT_URLS | compact) }}' ];
-{{ end -}}
-
-{{ if .Env.ANALYTICS_WHITELISTED_EVENTS -}}
-config.analytics.whiteListedEvents = [ '{{ join "','" (splitList "," .Env.ANALYTICS_WHITELISTED_EVENTS | compact) }}' ];
-{{ end -}}
-
-
-// Dial in/out services.
-//
-
-{{ if $ENABLE_JAAS_COMPONENTS }}
-config.dialInConfCodeUrl = 'https://conference-mapper.jitsi.net/v1/access';
-config.dialInNumbersUrl = 'https://conference-mapper.jitsi.net/v1/access/dids';
-{{ else }}
-{{ if .Env.CONFCODE_URL -}}
-config.dialInConfCodeUrl = '{{ .Env.CONFCODE_URL }}';
-{{ end -}}
-{{ if .Env.DIALIN_NUMBERS_URL -}}
-config.dialInNumbersUrl = '{{ .Env.DIALIN_NUMBERS_URL }}';
-{{ end -}}
-{{ end -}}
-
-{{ if .Env.DIALOUT_AUTH_URL -}}
-config.dialOutAuthUrl = '{{ .Env.DIALOUT_AUTH_URL }}';
-{{ end -}}
-
-{{ if .Env.DIALOUT_CODES_URL -}}
-config.dialOutCodesUrl = '{{ .Env.DIALOUT_CODES_URL }}';
-{{ end -}}
-
-
-// Calendar service integration.
-//
-
-config.enableCalendarIntegration = {{ $ENABLE_CALENDAR }};
-
-{{ if .Env.GOOGLE_API_APP_CLIENT_ID -}}
-config.googleApiApplicationClientID = '{{ .Env.GOOGLE_API_APP_CLIENT_ID }}';
-{{ end -}}
-
-{{ if .Env.MICROSOFT_API_APP_CLIENT_ID -}}
-config.microsoftApiApplicationClientID = '{{ .Env.MICROSOFT_API_APP_CLIENT_ID }}';
-{{ end -}}
-
-
-// Invitation service.
-//
-
-{{ if .Env.INVITE_SERVICE_URL -}}
-config.inviteServiceUrl = '{{ .Env.INVITE_SERVICE_URL }}';
-{{ end -}}
-
-{{ if .Env.PEOPLE_SEARCH_URL -}}
-config.peopleSearchUrl = '{{ .Env.PEOPLE_SEARCH_URL }}';
-config.peopleSearchQueryTypes = ['user','conferenceRooms'];
-{{ end -}}
-
-
-// Miscellaneous.
-//
-
-// Prejoin page.
-config.prejoinConfig = {
-    enabled: {{ $ENABLE_PREJOIN_PAGE }},
-
-    // Hides the participant name editing field in the prejoin screen.
-    hideDisplayName: {{ $HIDE_PREJOIN_DISPLAY_NAME }}
-};
-
-// List of buttons to hide from the extra join options dropdown on prejoin screen.
-{{ if .Env.HIDE_PREJOIN_EXTRA_BUTTONS -}}
-config.prejoinConfig.hideExtraJoinButtons = [ '{{ join "','" (splitList "," .Env.HIDE_PREJOIN_EXTRA_BUTTONS | compact) }}' ];
-{{ end -}}
-
-// Welcome page.
-config.welcomePage = {
-    disabled: {{ not $ENABLE_WELCOME_PAGE }}
-};
-
-// Close page.
-config.enableClosePage = {{ $ENABLE_CLOSE_PAGE }};
-
-// Default language.
-{{ if .Env.DEFAULT_LANGUAGE -}}
-config.defaultLanguage = '{{ .Env.DEFAULT_LANGUAGE }}';
-{{ end -}}
-
-// Require users to always specify a display name.
-config.requireDisplayName = {{ $ENABLE_REQUIRE_DISPLAY_NAME }};
-
-// Chrome extension banner.
-{{ if .Env.CHROME_EXTENSION_BANNER_JSON -}}
-config.chromeExtensionBanner = {{ .Env.CHROME_EXTENSION_BANNER_JSON }};
-{{ end -}}
-
-// Disables profile and the edit of all fields from the profile settings (display name and email)
-config.disableProfile = {{ $DISABLE_PROFILE }};
-
-// Room password (false for anything, number for max digits)
-{{ if $ENABLE_JAAS_COMPONENTS -}}
-config.roomPasswordNumberOfDigits = 10;
-{{ else -}}
-config.roomPasswordNumberOfDigits = {{ $ROOM_PASSWORD_DIGITS }};
-{{ end -}}
-
-// Advanced.
-//
-
-{{ if not $ENABLE_REMB -}}
-config.enableRemb = false;
-{{ end -}}
-{{ if not $ENABLE_TCC -}}
-config.enableTcc = false;
-{{ end -}}
-
-
-// Transcriptions (subtitles and buttons can be configured in interface_config)
-config.transcription = {
-    enabled: {{ $ENABLE_TRANSCRIPTIONS }},
-    translationLanguages: {{ $TRANSLATION_LANGUAGES }},
-    translationLanguagesHead: {{ $TRANSLATION_LANGUAGES_HEAD }},
-    useAppLanguage: {{ $USE_APP_LANGUAGE }},
-    preferredLanguage: '{{ $PREFERRED_LANGUAGE }}',
-    disableStartForAll: {{ $DISABLE_START_FOR_ALL }},
-    autoCaptionOnRecord: {{ $AUTO_CAPTION_ON_RECORD }},
-};
-
-// Dynamic branding
-{{ if .Env.DYNAMIC_BRANDING_URL -}}
-// External API url used to receive branding specific information.
-config.dynamicBrandingUrl = '{{ .Env.DYNAMIC_BRANDING_URL }}';
-{{ else if .Env.BRANDING_DATA_URL  -}}
-config.brandingDataUrl = '{{ .Env.BRANDING_DATA_URL }}';
-{{ end -}}
-
-{{ if .Env.TOKEN_AUTH_URL -}}
-// Authenticate using external service
-config.tokenAuthUrl = '{{ .Env.TOKEN_AUTH_URL }}';
-{{ end -}}
-
-
-// Deployment information.
-//
-
-config.deploymentInfo = {};
-
-{{ if .Env.DEPLOYMENTINFO_ENVIRONMENT -}}
-config.deploymentInfo.environment = '{{ .Env.DEPLOYMENTINFO_ENVIRONMENT }}';
-{{ end -}}
-
-{{ if .Env.DEPLOYMENTINFO_SHARD -}}
-config.deploymentInfo.shard = '{{ .Env.DEPLOYMENTINFO_SHARD }}';
-{{ end -}}
-
-{{ if .Env.DEPLOYMENTINFO_ENVIRONMENT_TYPE -}}
-config.deploymentInfo.envType = '{{ .Env.DEPLOYMENTINFO_ENVIRONMENT_TYPE }}';
-{{ end -}}
-
-{{ if .Env.DEPLOYMENTINFO_REGION -}}
-config.deploymentInfo.region = '{{ .Env.DEPLOYMENTINFO_REGION }}';
-{{ end -}}
-
-// Deep Linking
-config.disableDeepLinking = {{ $DISABLE_DEEP_LINKING }};
-
-// P2P preferred codec
-{{ if .Env.P2P_PREFERRED_CODEC -}}
-config.p2p.preferredCodec = '{{ .Env.P2P_PREFERRED_CODEC }}';
-{{ end -}}
-
-// Video quality settings.
-//
-
-config.videoQuality = {};
-config.videoQuality.codecPreferenceOrder = {{ $CODEC_ORDER_JVB }};
-config.videoQuality.mobileCodecPreferenceOrder = {{ $CODEC_ORDER_JVB_MOBILE }};
-config.videoQuality.enableAdaptiveMode = {{ $ENABLE_ADAPTIVE_MODE }};
-
-{{ if .Env.VIDEOQUALITY_PREFERRED_CODEC -}}
-config.videoQuality.preferredCodec = '{{ .Env.VIDEOQUALITY_PREFERRED_CODEC }}';
-{{ end -}}
-
-config.videoQuality.av1 = {};
-
-{{ if .Env.VIDEOQUALITY_BITRATE_AV1_LOW }}
-config.videoQuality.av1.low = {{ .Env.VIDEOQUALITY_BITRATE_AV1_LOW }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_AV1_STANDARD }}
-config.videoQuality.av1.standard = {{ .Env.VIDEOQUALITY_BITRATE_AV1_STANDARD }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_AV1_HIGH }}
-config.videoQuality.av1.high = {{ .Env.VIDEOQUALITY_BITRATE_AV1_HIGH }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_AV1_FULL }}
-config.videoQuality.av1.fullHd = {{ .Env.VIDEOQUALITY_BITRATE_AV1_FULL }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_AV1_ULTRA }}
-config.videoQuality.av1.ultraHd = {{ .Env.VIDEOQUALITY_BITRATE_AV1_ULTRA }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_AV1_SS_HIGH }}
-config.videoQuality.av1.ssHigh = {{ .Env.VIDEOQUALITY_BITRATE_AV1_SS_HIGH }};
-{{ end -}}
-
-config.videoQuality.h264 = {};
-
-{{ if .Env.VIDEOQUALITY_BITRATE_H264_LOW }}
-config.videoQuality.h264.low = {{ .Env.VIDEOQUALITY_BITRATE_H264_LOW }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_H264_STANDARD }}
-config.videoQuality.h264.standard = {{ .Env.VIDEOQUALITY_BITRATE_H264_STANDARD }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_H264_HIGH }}
-config.videoQuality.h264.high = {{ .Env.VIDEOQUALITY_BITRATE_H264_HIGH }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_H264_FULL }}
-config.videoQuality.h264.fullHd = {{ .Env.VIDEOQUALITY_BITRATE_H264_FULL }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_H264_ULTRA }}
-config.videoQuality.h264.ultraHd = {{ .Env.VIDEOQUALITY_BITRATE_H264_ULTRA }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_H264_SS_HIGH }}
-config.videoQuality.h264.ssHigh = {{ .Env.VIDEOQUALITY_BITRATE_H264_SS_HIGH }};
-{{ end -}}
-
-config.videoQuality.vp8 = {};
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP8_LOW }}
-config.videoQuality.vp8.low = {{ .Env.VIDEOQUALITY_BITRATE_VP8_LOW }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP8_STANDARD }}
-config.videoQuality.vp8.standard = {{ .Env.VIDEOQUALITY_BITRATE_VP8_STANDARD }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP8_HIGH }}
-config.videoQuality.vp8.high = {{ .Env.VIDEOQUALITY_BITRATE_VP8_HIGH }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP8_FULL }}
-config.videoQuality.vp8.fullHd = {{ .Env.VIDEOQUALITY_BITRATE_VP8_FULL }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP8_ULTRA }}
-config.videoQuality.vp8.ultraHd = {{ .Env.VIDEOQUALITY_BITRATE_VP8_ULTRA }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP8_SS_HIGH }}
-config.videoQuality.vp8.ssHigh = {{ .Env.VIDEOQUALITY_BITRATE_VP8_SS_HIGH }};
-{{ end -}}
-
-config.videoQuality.vp9 = {};
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP9_LOW }}
-config.videoQuality.vp9.low = {{ .Env.VIDEOQUALITY_BITRATE_VP9_LOW }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP9_STANDARD }}
-config.videoQuality.vp9.standard = {{ .Env.VIDEOQUALITY_BITRATE_VP9_STANDARD }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP9_HIGH }}
-config.videoQuality.vp9.high = {{ .Env.VIDEOQUALITY_BITRATE_VP9_HIGH }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP9_FULL }}
-config.videoQuality.vp9.fullHd = {{ .Env.VIDEOQUALITY_BITRATE_VP9_FULL }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP9_ULTRA }}
-config.videoQuality.vp9.ultraHd = {{ .Env.VIDEOQUALITY_BITRATE_VP9_ULTRA }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP9_SS_HIGH }}
-config.videoQuality.vp9.ssHigh = {{ .Env.VIDEOQUALITY_BITRATE_VP9_SS_HIGH }};
-{{ end -}}
-
- // Reactions
-config.disableReactions = {{ $DISABLE_REACTIONS }};
-
-// Polls
-config.disablePolls = {{ $DISABLE_POLLS }};
-
-// Configure toolbar buttons
-{{ if .Env.TOOLBAR_BUTTONS -}}
-config.toolbarButtons = [ '{{ join "','" (splitList "," .Env.TOOLBAR_BUTTONS | compact) }}' ];
-{{ end -}}
-
-// Hides the buttons at pre-join screen
-{{ if .Env.HIDE_PREMEETING_BUTTONS -}}
-config.hiddenPremeetingButtons = [ '{{ join "','" (splitList "," .Env.HIDE_PREMEETING_BUTTONS | compact) }}' ];
-{{ end -}}
-
-// Configure remote participant video menu
-config.remoteVideoMenu = {
-    disabled: {{ $DISABLE_REMOTE_VIDEO_MENU }},
-    disableKick: {{ $DISABLE_KICKOUT }},
-    disableGrantModerator: {{ $DISABLE_GRANT_MODERATOR }},
-    disablePrivateChat: {{ $DISABLE_PRIVATE_CHAT }}
-};
-
-// Configure e2eping
-config.e2eping = {
-    enabled: {{ $ENABLE_E2EPING }}
-};
-
-{{ if .Env.E2EPING_NUM_REQUESTS -}}
-config.e2eping.numRequests = {{ .Env.E2EPING_NUM_REQUESTS }};
-{{ end -}}
-{{ if .Env.E2EPING_MAX_CONFERENCE_SIZE -}}
-config.e2eping.maxConferenceSize = {{ .Env.E2EPING_MAX_CONFERENCE_SIZE }};
-{{ end -}}
-{{ if .Env.E2EPING_MAX_MESSAGE_PER_SECOND -}}
-config.e2eping.maxMessagePerSecond = {{ .Env.E2EPING_MAX_MESSAGE_PER_SECOND }};
-{{ end }}
-
-// Settings for the Excalidraw whiteboard integration.
-config.whiteboard = {
-    enabled: {{ $WHITEBOARD_ENABLED }},
-{{ if .Env.WHITEBOARD_COLLAB_SERVER_PUBLIC_URL -}}
-    collabServerBaseUrl: '{{ .Env.WHITEBOARD_COLLAB_SERVER_PUBLIC_URL }}'
-{{ else if .Env.WHITEBOARD_COLLAB_SERVER_URL_BASE -}}
-    collabServerBaseUrl: '{{ $PUBLIC_URL }}'
-{{ end -}}
-};
-
-// JaaS support: pre-configure image if JAAS_APP_ID was set.
-{{ if .Env.JAAS_APP_ID -}}
-{{ $JAAS_USE_STAGING := .Env.JAAS_USE_STAGING | default "false" | toBool -}}
-{{ $JAAS_DOMAIN := $JAAS_USE_STAGING | ternary "stage.8x8.vc" "8x8.vc" -}}
-
-config.hosts.domain = '{{ $JAAS_DOMAIN }}';
-config.hosts.muc = 'conference.{{ .Env.JAAS_APP_ID }}.{{ $JAAS_DOMAIN }}';
-config.hosts.focus = 'focus.{{ $JAAS_DOMAIN }}';
-
-config.analytics.rtcstatsEnabled = true;
-config.analytics.rtcstatsStoreLogs = true;
-config.analytics.rtcstatsUseLegacy = false;
-config.analytics.rtcstatsEndpoint = 'wss://rtcstats-server-8x8.jitsi.net/';
-config.analytics.rtcstatsPollInterval = 10000;
-config.analytics.rtcstatsSendSdp = true;
-
-config.bosh = 'https://{{ $JAAS_DOMAIN }}/{{ .Env.JAAS_APP_ID }}/http-bind';
-config.websocket = 'wss://{{ $JAAS_DOMAIN }}/{{ .Env.JAAS_APP_ID }}/xmpp-websocket';
-config.websocketKeepAliveUrl = 'https://{{ $JAAS_DOMAIN }}/{{ .Env.JAAS_APP_ID }}/_unlock';
-config.conferenceRequestUrl = 'https://{{ $JAAS_DOMAIN }}/{{ .Env.JAAS_APP_ID }}/conference-request/v1';
-
-config.hiddenDomain = 'recorder.{{ $JAAS_DOMAIN }}';
-config.hiddenFromRecorderFeatureEnabled = true;
-config.enableEmailInStats = true;
-
-config.jaasActuatorUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/jaas-actuator';
-config.jaasTokenUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/token-mapping';
-config.jaasConferenceCreatorUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/vmms-conference-mapper/v1/access/conference-creator';
-config.webhookProxyUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/webhook-proxy';
-config.billingCounterUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/billing-counter/v1/connection';
-config.brandingDataUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/branding/public/v1/conferences';
-config.dialInNumbersUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/vmms-conference-mapper/access/v1/dids';
-config.dialInConfCodeUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/vmms-conference-mapper/v1/access';
-config.dialOutAuthUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/phone-authorize';
-config.dialOutRegionUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/customer-configs/v1/outbound-destination';
-config.peopleSearchUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/v1/directory/search';
-config.inviteServiceUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/v1/meeting/invite';
-config.recordingSharingUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/jaas-recordings/link';
-config.peopleSearchQueryTypes = ['user','conferenceRooms'];
-config.sipInviteUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/sip-jibri-gateway/jibris/invite';
-config.jaasFeedbackMetadataURL = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/webhook-proxy/feedback';
-
-{{ if $JAAS_USE_STAGING -}}
-config.whiteboard.collabServerBaseUrl = 'https://eght-excalidraw-backend-pilot.cloudflare.jitsi.net';
-{{ else -}}
-config.whiteboard.collabServerBaseUrl = 'https://eght-excalidraw-backend.cloudflare.jitsi.net';
-{{ end -}}
-config.whiteboard.userLimit = 25;
-{{ end -}}
-
-// Testing
-config.testing = {
-    enableCodecSelectionAPI: true
-};
diff --git a/infrastructure/web/image/resources/settings-config.js b/infrastructure/web/image/resources/settings-config.js
deleted file mode 100644
index 3334b24..0000000
--- a/infrastructure/web/image/resources/settings-config.js
+++ /dev/null
@@ -1,637 +0,0 @@
-//https://github.com/jitsi/docker-jitsi-meet/blob/master/web/rootfs/defaults/settings-config.js
-
-{{ $ENABLE_ADAPTIVE_MODE := .Env.ENABLE_ADAPTIVE_MODE | default "true" | toBool -}}
-{{ $ENABLE_AUDIO_PROCESSING := .Env.ENABLE_AUDIO_PROCESSING | default "true" | toBool -}}
-{{ $ENABLE_AUTOMATIC_GAIN_CONTROL := .Env.ENABLE_AUTOMATIC_GAIN_CONTROL | default "true" | toBool -}}
-{{ $ENABLE_BREAKOUT_ROOMS := .Env.ENABLE_BREAKOUT_ROOMS | default "true" | toBool -}}
-{{ $ENABLE_CALENDAR := .Env.ENABLE_CALENDAR | default "false" | toBool -}}
-{{ $ENABLE_FILE_RECORDING_SHARING := .Env.ENABLE_FILE_RECORDING_SHARING | default "false" | toBool -}}
-{{ $ENABLE_NO_AUDIO_DETECTION := .Env.ENABLE_NO_AUDIO_DETECTION | default "true" | toBool -}}
-{{ $ENABLE_P2P := .Env.ENABLE_P2P | default "true" | toBool -}}
-{{ $ENABLE_PREJOIN_PAGE := .Env.ENABLE_PREJOIN_PAGE | default "true" | toBool -}}
-{{ $ENABLE_WELCOME_PAGE := .Env.ENABLE_WELCOME_PAGE | default "true" | toBool -}}
-{{ $ENABLE_CLOSE_PAGE := .Env.ENABLE_CLOSE_PAGE | default "false" | toBool -}}
-{{ $ENABLE_RECORDING := .Env.ENABLE_RECORDING | default "false" | toBool -}}
-{{ $ENABLE_SERVICE_RECORDING := .Env.ENABLE_SERVICE_RECORDING | default ($ENABLE_RECORDING | printf "%t") | toBool -}}
-{{ $ENABLE_LIVESTREAMING := .Env.ENABLE_LIVESTREAMING | default "false" | toBool -}}
-{{ $ENABLE_LIVESTREAMING_DATA_PRIVACY_LINK := .Env.ENABLE_LIVESTREAMING_DATA_PRIVACY_LINK | default "https://policies.google.com/privacy" -}}
-{{ $ENABLE_LIVESTREAMING_HELP_LINK := .Env.ENABLE_LIVESTREAMING_HELP_LINK | default "https://jitsi.org/live" -}}
-{{ $ENABLE_LIVESTREAMING_TERMS_LINK := .Env.ENABLE_LIVESTREAMING_TERMS_LINK | default "https://www.youtube.com/t/terms" -}}
-{{ $ENABLE_LIVESTREAMING_VALIDATOR_REGEXP_STRING := .Env.ENABLE_LIVESTREAMING_VALIDATOR_REGEXP_STRING | default "^(?:[a-zA-Z0-9]{4}(?:-(?!$)|$)){4}" -}}
-{{ $ENABLE_REMB := .Env.ENABLE_REMB | default "true" | toBool -}}
-{{ $ENABLE_REQUIRE_DISPLAY_NAME := .Env.ENABLE_REQUIRE_DISPLAY_NAME | default "false" | toBool -}}
-{{ $ENABLE_SIMULCAST := .Env.ENABLE_SIMULCAST | default "true" | toBool -}}
-{{ $ENABLE_STEREO := .Env.ENABLE_STEREO | default "false" | toBool -}}
-{{ $ENABLE_OPUS_RED := .Env.ENABLE_OPUS_RED | default "false" | toBool -}}
-{{ $ENABLE_TALK_WHILE_MUTED := .Env.ENABLE_TALK_WHILE_MUTED | default "false" | toBool -}}
-{{ $ENABLE_TCC := .Env.ENABLE_TCC | default "true" | toBool -}}
-{{ $ENABLE_TRANSCRIPTIONS := .Env.ENABLE_TRANSCRIPTIONS | default "false" | toBool -}}
-{{ $TRANSLATION_LANGUAGES := .Env.TRANSLATION_LANGUAGES | default "[]" -}}
-{{ $TRANSLATION_LANGUAGES_HEAD := .Env.TRANSLATION_LANGUAGES_HEAD | default "['en']" -}}
-{{ $USE_APP_LANGUAGE := .Env.USE_APP_LANGUAGE | default "true" | toBool -}}
-{{ $PREFERRED_LANGUAGE := .Env.PREFERRED_LANGUAGE | default "en-US" -}}
-{{ $DISABLE_START_FOR_ALL := .Env.DISABLE_START_FOR_ALL | default "false" | toBool -}}
-{{ $AUTO_CAPTION_ON_RECORD := .Env.AUTO_CAPTION_ON_RECORD | default "false" | toBool -}}
-{{ $ENABLE_JAAS_COMPONENTS := .Env.ENABLE_JAAS_COMPONENTS | default "0" | toBool }}
-{{ $HIDE_PREJOIN_DISPLAY_NAME := .Env.HIDE_PREJOIN_DISPLAY_NAME | default "false" | toBool -}}
-{{ $PUBLIC_URL := .Env.PUBLIC_URL | default "https://localhost:8443" -}}
-{{ $RESOLUTION := .Env.RESOLUTION | default "720" -}}
-{{ $RESOLUTION_MIN := .Env.RESOLUTION_MIN | default "180" -}}
-{{ $RESOLUTION_WIDTH := .Env.RESOLUTION_WIDTH | default "1280" -}}
-{{ $RESOLUTION_WIDTH_MIN := .Env.RESOLUTION_WIDTH_MIN | default "320" -}}
-{{ $START_AUDIO_ONLY := .Env.START_AUDIO_ONLY | default "false" | toBool -}}
-{{ $START_AUDIO_MUTED := .Env.START_AUDIO_MUTED | default 10 -}}
-{{ $START_WITH_AUDIO_MUTED := .Env.START_WITH_AUDIO_MUTED | default "false" | toBool -}}
-{{ $START_SILENT := .Env.START_SILENT | default "false" | toBool -}}
-{{ $DISABLE_AUDIO_LEVELS := .Env.DISABLE_AUDIO_LEVELS | default "false" | toBool -}}
-{{ $ENABLE_NOISY_MIC_DETECTION := .Env.ENABLE_NOISY_MIC_DETECTION | default "true" | toBool -}}
-{{ $START_VIDEO_MUTED := .Env.START_VIDEO_MUTED | default 10 -}}
-{{ $START_WITH_VIDEO_MUTED := .Env.START_WITH_VIDEO_MUTED | default "false" | toBool -}}
-{{ $DESKTOP_SHARING_FRAMERATE_AUTO := .Env.DESKTOP_SHARING_FRAMERATE_AUTO | default "true" | toBool -}}
-{{ $DESKTOP_SHARING_FRAMERATE_MIN := .Env.DESKTOP_SHARING_FRAMERATE_MIN | default 5 -}}
-{{ $DESKTOP_SHARING_FRAMERATE_MAX := .Env.DESKTOP_SHARING_FRAMERATE_MAX | default 5 -}}
-{{ $XMPP_DOMAIN := .Env.XMPP_DOMAIN | default "meet.jitsi" -}}
-{{ $XMPP_HIDDEN_DOMAIN := .Env.XMPP_HIDDEN_DOMAIN | default "hidden.meet.jitsi" -}}
-{{ $DISABLE_DEEP_LINKING  := .Env.DISABLE_DEEP_LINKING | default "false" | toBool -}}
-{{ $DISABLE_POLLS := .Env.DISABLE_POLLS | default "false" | toBool -}}
-{{ $DISABLE_REACTIONS := .Env.DISABLE_REACTIONS | default "false" | toBool -}}
-{{ $DISABLE_REMOTE_VIDEO_MENU := .Env.DISABLE_REMOTE_VIDEO_MENU | default "false" | toBool -}}
-{{ $DISABLE_PRIVATE_CHAT:= .Env.DISABLE_PRIVATE_CHAT | default "false" | toBool -}}
-{{ $DISABLE_KICKOUT := .Env.DISABLE_KICKOUT | default "false" | toBool -}}
-{{ $DISABLE_GRANT_MODERATOR := .Env.DISABLE_GRANT_MODERATOR | default "false" | toBool -}}
-{{ $ENABLE_E2EPING := .Env.ENABLE_E2EPING | default "false" | toBool -}}
-{{ $DISABLE_LOCAL_RECORDING := .Env.DISABLE_LOCAL_RECORDING | default "false" | toBool -}}
-{{ $ENABLE_LOCAL_RECORDING_NOTIFY_ALL_PARTICIPANT := .Env.ENABLE_LOCAL_RECORDING_NOTIFY_ALL_PARTICIPANT | default "false" | toBool -}}
-{{ $ENABLE_LOCAL_RECORDING_SELF_START := .Env.ENABLE_LOCAL_RECORDING_SELF_START | default "false" | toBool -}}
-{{ $DISABLE_PROFILE := .Env.DISABLE_PROFILE | default "false" | toBool -}}
-{{ $ROOM_PASSWORD_DIGITS := .Env.ROOM_PASSWORD_DIGITS | default "false" -}}
-{{ $WHITEBOARD_ENABLED := or (.Env.WHITEBOARD_COLLAB_SERVER_PUBLIC_URL | default "" | toBool) (.Env.WHITEBOARD_COLLAB_SERVER_URL_BASE | default "" | toBool) }}
-{{ $CODEC_ORDER_JVB := .Env.CODEC_ORDER_JVB | default "[\"AV1\", \"VP9\", \"VP8\", \"H264\"]" -}}
-{{ $CODEC_ORDER_JVB_MOBILE := .Env.CODEC_ORDER_JVB_MOBILE | default "[\"VP8\", \"VP9\", \"H264\", \"AV1\"]" -}}
-{{ $CODEC_ORDER_P2P := .Env.CODEC_ORDER_JVB | default "[\"AV1\", \"VP9\", \"VP8\", \"H264\"]" -}}
-{{ $CODEC_ORDER_P2P_MOBILE := .Env.CODEC_ORDER_JVB_MOBILE | default "[\"VP8\", \"VP9\", \"H264\", \"AV1\"]" -}}
-
-// Video configuration.
-//
-
-config.resolution = {{ $RESOLUTION }};
-config.constraints = {
-    video: {
-        height: { ideal: {{ $RESOLUTION }}, max: {{ $RESOLUTION }}, min: {{ $RESOLUTION_MIN }} },
-        width: { ideal: {{ $RESOLUTION_WIDTH }}, max: {{ $RESOLUTION_WIDTH }}, min: {{ $RESOLUTION_WIDTH_MIN }}},
-    }
-};
-
-{{ if not $ENABLE_SIMULCAST -}}
-config.disableSimulcast = true;
-{{ end -}}
-config.startVideoMuted = {{ $START_VIDEO_MUTED }};
-config.startWithVideoMuted = {{ $START_WITH_VIDEO_MUTED }};
-
-config.flags = {
-    sourceNameSignaling: true,
-    sendMultipleVideoStreams: true,
-    receiveMultipleVideoStreams: true
-};
-
-// ScreenShare Configuration.
-//
-
-{{ if not $DESKTOP_SHARING_FRAMERATE_AUTO -}}
-config.desktopSharingFrameRate = {
-    min: {{ $DESKTOP_SHARING_FRAMERATE_MIN }},
-    max: {{ $DESKTOP_SHARING_FRAMERATE_MAX }}
-};
-{{ end -}}
-
-// Audio configuration.
-//
-
-config.enableNoAudioDetection = {{ $ENABLE_NO_AUDIO_DETECTION }};
-config.enableTalkWhileMuted = {{ $ENABLE_TALK_WHILE_MUTED }};
-config.disableAP = {{ not $ENABLE_AUDIO_PROCESSING }};
-config.disableAGC = {{ not $ENABLE_AUTOMATIC_GAIN_CONTROL }};
-
-config.audioQuality = {
-    stereo: {{ $ENABLE_STEREO }}
-};
-
-{{ if .Env.AUDIO_QUALITY_OPUS_BITRATE -}}
-config.audioQuality.opusMaxAverageBitrate = '{{ .Env.AUDIO_QUALITY_OPUS_BITRATE }}';
-{{ end -}}
-
-config.startAudioOnly = {{ $START_AUDIO_ONLY }};
-config.startAudioMuted = {{ $START_AUDIO_MUTED }};
-config.startWithAudioMuted = {{ $START_WITH_AUDIO_MUTED }};
-config.startSilent = {{ $START_SILENT }};
-config.enableOpusRed = {{ $ENABLE_OPUS_RED }};
-config.disableAudioLevels = {{ $DISABLE_AUDIO_LEVELS }};
-config.enableNoisyMicDetection = {{ $ENABLE_NOISY_MIC_DETECTION }};
-
-
-// Peer-to-Peer options.
-//
-
-config.p2p = {
-    enabled: {{ $ENABLE_P2P }},
-    codecPreferenceOrder: {{ $CODEC_ORDER_P2P }},
-    mobileCodecPreferenceOrder: {{ $CODEC_ORDER_P2P_MOBILE }}
-};
-
-{{ if .Env.P2P_STUN_SERVERS -}}
-config.p2p.stunServers = '{{ .Env.P2P_STUN_SERVERS }}'.split(',').map(url => ({ urls: 'stun:' + url }));
-
-{{ end -}}
-
-// Breakout Rooms
-//
-
-config.hideAddRoomButton = {{ $ENABLE_BREAKOUT_ROOMS | not }};
-
-
-// Etherpad
-//
-
-{{ if .Env.ETHERPAD_PUBLIC_URL -}}
-config.etherpad_base = '{{ .Env.ETHERPAD_PUBLIC_URL }}';
-{{ else if .Env.ETHERPAD_URL_BASE -}}
-config.etherpad_base = '{{ $PUBLIC_URL }}/etherpad/p/';
-{{ end -}}
-
-
-// Recording.
-//
-
-{{ if or $ENABLE_RECORDING $ENABLE_TRANSCRIPTIONS  -}}
-
-config.hiddenDomain = '{{ $XMPP_HIDDEN_DOMAIN }}';
-{{ end -}}
-
-{{ if $ENABLE_RECORDING -}}
-
-config.recordingService = {
-    // Whether to enable file recording or not using the "service" defined by the finalizer in Jibri
-    enabled: {{ $ENABLE_SERVICE_RECORDING }},
-
-    // Whether to show the possibility to share file recording with other people
-    // (e.g. meeting participants), based on the actual implementation
-    // on the backend.
-    sharingEnabled: {{ $ENABLE_FILE_RECORDING_SHARING }}
-};
-
-// Live streaming configuration.
-config.liveStreaming = {
-    enabled: {{ $ENABLE_LIVESTREAMING }},
-    dataPrivacyLink: '{{ $ENABLE_LIVESTREAMING_DATA_PRIVACY_LINK }}',
-    helpLink: '{{ $ENABLE_LIVESTREAMING_HELP_LINK }}',
-    termsLink: '{{ $ENABLE_LIVESTREAMING_TERMS_LINK }}',
-    validatorRegExpString: '{{ $ENABLE_LIVESTREAMING_VALIDATOR_REGEXP_STRING }}'
-};
-
-
-{{ if .Env.DROPBOX_APPKEY -}}
-// Enable the dropbox integration.
-config.dropbox = {
-    appKey: '{{ .Env.DROPBOX_APPKEY }}'
-};
-
-{{ if .Env.DROPBOX_REDIRECT_URI -}}
-// A URL to redirect the user to, after authenticating
-// by default uses:
-// 'https://jitsi-meet.example.com/static/oauth.html'
-config.dropbox.redirectURI = '{{ .Env.DROPBOX_REDIRECT_URI }}';
-{{ end -}}
-{{ end -}}
-
-{{ end -}}
-
-// Local recording configuration.
-config.localRecording = {
-    disable: {{ $DISABLE_LOCAL_RECORDING }},
-    notifyAllParticipants: {{ $ENABLE_LOCAL_RECORDING_NOTIFY_ALL_PARTICIPANT }},
-    disableSelfRecording: {{ $ENABLE_LOCAL_RECORDING_SELF_START }}
-};
-
-
-// Analytics.
-//
-
-config.analytics = {};
-
-{{ if .Env.AMPLITUDE_ID -}}
-// The Amplitude APP Key:
-config.analytics.amplitudeAPPKey = '{{ .Env.AMPLITUDE_ID }}';
-{{ end -}}
-
-{{ if .Env.GOOGLE_ANALYTICS_ID -}}
-// The Google Analytics Tracking ID:
-config.analytics.googleAnalyticsTrackingId = '{{ .Env.GOOGLE_ANALYTICS_ID }}';
-{{ end -}}
-
-{{ if .Env.MATOMO_ENDPOINT -}}
-// Matomo endpoint:
-config.analytics.matomoEndpoint = '{{ .Env.MATOMO_ENDPOINT }}';
-{{ end -}}
-
-{{ if .Env.MATOMO_SITE_ID -}}
-// Matomo site ID:
-config.analytics.matomoSiteID = '{{ .Env.MATOMO_SITE_ID }}';
-{{ end -}}
-
-{{ if .Env.ANALYTICS_SCRIPT_URLS -}}
-// Array of script URLs to load as lib-jitsi-meet "analytics handlers".
-config.analytics.scriptURLs = [ '{{ join "','" (splitList "," .Env.ANALYTICS_SCRIPT_URLS | compact) }}' ];
-{{ end -}}
-
-{{ if .Env.ANALYTICS_WHITELISTED_EVENTS -}}
-config.analytics.whiteListedEvents = [ '{{ join "','" (splitList "," .Env.ANALYTICS_WHITELISTED_EVENTS | compact) }}' ];
-{{ end -}}
-
-
-// Dial in/out services.
-//
-
-{{ if $ENABLE_JAAS_COMPONENTS }}
-config.dialInConfCodeUrl = 'https://conference-mapper.jitsi.net/v1/access';
-config.dialInNumbersUrl = 'https://conference-mapper.jitsi.net/v1/access/dids';
-{{ else }}
-{{ if .Env.CONFCODE_URL -}}
-config.dialInConfCodeUrl = '{{ .Env.CONFCODE_URL }}';
-{{ end -}}
-{{ if .Env.DIALIN_NUMBERS_URL -}}
-config.dialInNumbersUrl = '{{ .Env.DIALIN_NUMBERS_URL }}';
-{{ end -}}
-{{ end -}}
-
-{{ if .Env.DIALOUT_AUTH_URL -}}
-config.dialOutAuthUrl = '{{ .Env.DIALOUT_AUTH_URL }}';
-{{ end -}}
-
-{{ if .Env.DIALOUT_CODES_URL -}}
-config.dialOutCodesUrl = '{{ .Env.DIALOUT_CODES_URL }}';
-{{ end -}}
-
-
-// Calendar service integration.
-//
-
-config.enableCalendarIntegration = {{ $ENABLE_CALENDAR }};
-
-{{ if .Env.GOOGLE_API_APP_CLIENT_ID -}}
-config.googleApiApplicationClientID = '{{ .Env.GOOGLE_API_APP_CLIENT_ID }}';
-{{ end -}}
-
-{{ if .Env.MICROSOFT_API_APP_CLIENT_ID -}}
-config.microsoftApiApplicationClientID = '{{ .Env.MICROSOFT_API_APP_CLIENT_ID }}';
-{{ end -}}
-
-
-// Invitation service.
-//
-
-{{ if .Env.INVITE_SERVICE_URL -}}
-config.inviteServiceUrl = '{{ .Env.INVITE_SERVICE_URL }}';
-{{ end -}}
-
-{{ if .Env.PEOPLE_SEARCH_URL -}}
-config.peopleSearchUrl = '{{ .Env.PEOPLE_SEARCH_URL }}';
-config.peopleSearchQueryTypes = ['user','conferenceRooms'];
-{{ end -}}
-
-
-// Miscellaneous.
-//
-
-// Prejoin page.
-config.prejoinConfig = {
-    enabled: {{ $ENABLE_PREJOIN_PAGE }},
-
-    // Hides the participant name editing field in the prejoin screen.
-    hideDisplayName: {{ $HIDE_PREJOIN_DISPLAY_NAME }}
-};
-
-// List of buttons to hide from the extra join options dropdown on prejoin screen.
-{{ if .Env.HIDE_PREJOIN_EXTRA_BUTTONS -}}
-config.prejoinConfig.hideExtraJoinButtons = [ '{{ join "','" (splitList "," .Env.HIDE_PREJOIN_EXTRA_BUTTONS | compact) }}' ];
-{{ end -}}
-
-// Welcome page.
-config.welcomePage = {
-    disabled: {{ not $ENABLE_WELCOME_PAGE }}
-};
-
-// Close page.
-config.enableClosePage = {{ $ENABLE_CLOSE_PAGE }};
-
-// Default language.
-{{ if .Env.DEFAULT_LANGUAGE -}}
-config.defaultLanguage = '{{ .Env.DEFAULT_LANGUAGE }}';
-{{ end -}}
-
-// Require users to always specify a display name.
-config.requireDisplayName = {{ $ENABLE_REQUIRE_DISPLAY_NAME }};
-
-// Chrome extension banner.
-{{ if .Env.CHROME_EXTENSION_BANNER_JSON -}}
-config.chromeExtensionBanner = {{ .Env.CHROME_EXTENSION_BANNER_JSON }};
-{{ end -}}
-
-// Disables profile and the edit of all fields from the profile settings (display name and email)
-config.disableProfile = {{ $DISABLE_PROFILE }};
-
-// Room password (false for anything, number for max digits)
-{{ if $ENABLE_JAAS_COMPONENTS -}}
-config.roomPasswordNumberOfDigits = 10;
-{{ else -}}
-config.roomPasswordNumberOfDigits = {{ $ROOM_PASSWORD_DIGITS }};
-{{ end -}}
-
-// Advanced.
-//
-
-{{ if not $ENABLE_REMB -}}
-config.enableRemb = false;
-{{ end -}}
-{{ if not $ENABLE_TCC -}}
-config.enableTcc = false;
-{{ end -}}
-
-
-// Transcriptions (subtitles and buttons can be configured in interface_config)
-config.transcription = {
-    enabled: {{ $ENABLE_TRANSCRIPTIONS }},
-    translationLanguages: {{ $TRANSLATION_LANGUAGES }},
-    translationLanguagesHead: {{ $TRANSLATION_LANGUAGES_HEAD }},
-    useAppLanguage: {{ $USE_APP_LANGUAGE }},
-    preferredLanguage: '{{ $PREFERRED_LANGUAGE }}',
-    disableStartForAll: {{ $DISABLE_START_FOR_ALL }},
-    autoCaptionOnRecord: {{ $AUTO_CAPTION_ON_RECORD }},
-};
-
-// Dynamic branding
-{{ if .Env.DYNAMIC_BRANDING_URL -}}
-// External API url used to receive branding specific information.
-config.dynamicBrandingUrl = '{{ .Env.DYNAMIC_BRANDING_URL }}';
-{{ else if .Env.BRANDING_DATA_URL  -}}
-config.brandingDataUrl = '{{ .Env.BRANDING_DATA_URL }}';
-{{ end -}}
-
-{{ if .Env.TOKEN_AUTH_URL -}}
-// Authenticate using external service
-config.tokenAuthUrl = '{{ .Env.TOKEN_AUTH_URL }}';
-{{ end -}}
-
-
-// Deployment information.
-//
-
-config.deploymentInfo = {};
-
-{{ if .Env.DEPLOYMENTINFO_ENVIRONMENT -}}
-config.deploymentInfo.environment = '{{ .Env.DEPLOYMENTINFO_ENVIRONMENT }}';
-{{ end -}}
-
-{{ if .Env.DEPLOYMENTINFO_SHARD -}}
-config.deploymentInfo.shard = '{{ .Env.DEPLOYMENTINFO_SHARD }}';
-{{ end -}}
-
-{{ if .Env.DEPLOYMENTINFO_ENVIRONMENT_TYPE -}}
-config.deploymentInfo.envType = '{{ .Env.DEPLOYMENTINFO_ENVIRONMENT_TYPE }}';
-{{ end -}}
-
-{{ if .Env.DEPLOYMENTINFO_REGION -}}
-config.deploymentInfo.region = '{{ .Env.DEPLOYMENTINFO_REGION }}';
-{{ end -}}
-
-// Deep Linking
-config.disableDeepLinking = {{ $DISABLE_DEEP_LINKING }};
-
-// P2P preferred codec
-{{ if .Env.P2P_PREFERRED_CODEC -}}
-config.p2p.preferredCodec = '{{ .Env.P2P_PREFERRED_CODEC }}';
-{{ end -}}
-
-// Video quality settings.
-//
-
-config.videoQuality = {};
-config.videoQuality.codecPreferenceOrder = {{ $CODEC_ORDER_JVB }};
-config.videoQuality.mobileCodecPreferenceOrder = {{ $CODEC_ORDER_JVB_MOBILE }};
-config.videoQuality.enableAdaptiveMode = {{ $ENABLE_ADAPTIVE_MODE }};
-
-{{ if .Env.VIDEOQUALITY_PREFERRED_CODEC -}}
-config.videoQuality.preferredCodec = '{{ .Env.VIDEOQUALITY_PREFERRED_CODEC }}';
-{{ end -}}
-
-config.videoQuality.av1 = {};
-
-{{ if .Env.VIDEOQUALITY_BITRATE_AV1_LOW }}
-config.videoQuality.av1.low = {{ .Env.VIDEOQUALITY_BITRATE_AV1_LOW }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_AV1_STANDARD }}
-config.videoQuality.av1.standard = {{ .Env.VIDEOQUALITY_BITRATE_AV1_STANDARD }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_AV1_HIGH }}
-config.videoQuality.av1.high = {{ .Env.VIDEOQUALITY_BITRATE_AV1_HIGH }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_AV1_FULL }}
-config.videoQuality.av1.fullHd = {{ .Env.VIDEOQUALITY_BITRATE_AV1_FULL }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_AV1_ULTRA }}
-config.videoQuality.av1.ultraHd = {{ .Env.VIDEOQUALITY_BITRATE_AV1_ULTRA }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_AV1_SS_HIGH }}
-config.videoQuality.av1.ssHigh = {{ .Env.VIDEOQUALITY_BITRATE_AV1_SS_HIGH }};
-{{ end -}}
-
-config.videoQuality.h264 = {};
-
-{{ if .Env.VIDEOQUALITY_BITRATE_H264_LOW }}
-config.videoQuality.h264.low = {{ .Env.VIDEOQUALITY_BITRATE_H264_LOW }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_H264_STANDARD }}
-config.videoQuality.h264.standard = {{ .Env.VIDEOQUALITY_BITRATE_H264_STANDARD }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_H264_HIGH }}
-config.videoQuality.h264.high = {{ .Env.VIDEOQUALITY_BITRATE_H264_HIGH }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_H264_FULL }}
-config.videoQuality.h264.fullHd = {{ .Env.VIDEOQUALITY_BITRATE_H264_FULL }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_H264_ULTRA }}
-config.videoQuality.h264.ultraHd = {{ .Env.VIDEOQUALITY_BITRATE_H264_ULTRA }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_H264_SS_HIGH }}
-config.videoQuality.h264.ssHigh = {{ .Env.VIDEOQUALITY_BITRATE_H264_SS_HIGH }};
-{{ end -}}
-
-config.videoQuality.vp8 = {};
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP8_LOW }}
-config.videoQuality.vp8.low = {{ .Env.VIDEOQUALITY_BITRATE_VP8_LOW }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP8_STANDARD }}
-config.videoQuality.vp8.standard = {{ .Env.VIDEOQUALITY_BITRATE_VP8_STANDARD }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP8_HIGH }}
-config.videoQuality.vp8.high = {{ .Env.VIDEOQUALITY_BITRATE_VP8_HIGH }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP8_FULL }}
-config.videoQuality.vp8.fullHd = {{ .Env.VIDEOQUALITY_BITRATE_VP8_FULL }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP8_ULTRA }}
-config.videoQuality.vp8.ultraHd = {{ .Env.VIDEOQUALITY_BITRATE_VP8_ULTRA }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP8_SS_HIGH }}
-config.videoQuality.vp8.ssHigh = {{ .Env.VIDEOQUALITY_BITRATE_VP8_SS_HIGH }};
-{{ end -}}
-
-config.videoQuality.vp9 = {};
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP9_LOW }}
-config.videoQuality.vp9.low = {{ .Env.VIDEOQUALITY_BITRATE_VP9_LOW }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP9_STANDARD }}
-config.videoQuality.vp9.standard = {{ .Env.VIDEOQUALITY_BITRATE_VP9_STANDARD }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP9_HIGH }}
-config.videoQuality.vp9.high = {{ .Env.VIDEOQUALITY_BITRATE_VP9_HIGH }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP9_FULL }}
-config.videoQuality.vp9.fullHd = {{ .Env.VIDEOQUALITY_BITRATE_VP9_FULL }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP9_ULTRA }}
-config.videoQuality.vp9.ultraHd = {{ .Env.VIDEOQUALITY_BITRATE_VP9_ULTRA }};
-{{ end -}}
-
-{{ if .Env.VIDEOQUALITY_BITRATE_VP9_SS_HIGH }}
-config.videoQuality.vp9.ssHigh = {{ .Env.VIDEOQUALITY_BITRATE_VP9_SS_HIGH }};
-{{ end -}}
-
- // Reactions
-config.disableReactions = {{ $DISABLE_REACTIONS }};
-
-// Polls
-config.disablePolls = {{ $DISABLE_POLLS }};
-
-// Configure toolbar buttons
-{{ if .Env.TOOLBAR_BUTTONS -}}
-config.toolbarButtons = [ '{{ join "','" (splitList "," .Env.TOOLBAR_BUTTONS | compact) }}' ];
-{{ end -}}
-
-// Hides the buttons at pre-join screen
-{{ if .Env.HIDE_PREMEETING_BUTTONS -}}
-config.hiddenPremeetingButtons = [ '{{ join "','" (splitList "," .Env.HIDE_PREMEETING_BUTTONS | compact) }}' ];
-{{ end -}}
-
-// Configure remote participant video menu
-config.remoteVideoMenu = {
-    disabled: {{ $DISABLE_REMOTE_VIDEO_MENU }},
-    disableKick: {{ $DISABLE_KICKOUT }},
-    disableGrantModerator: {{ $DISABLE_GRANT_MODERATOR }},
-    disablePrivateChat: {{ $DISABLE_PRIVATE_CHAT }}
-};
-
-// Configure e2eping
-config.e2eping = {
-    enabled: {{ $ENABLE_E2EPING }}
-};
-
-{{ if .Env.E2EPING_NUM_REQUESTS -}}
-config.e2eping.numRequests = {{ .Env.E2EPING_NUM_REQUESTS }};
-{{ end -}}
-{{ if .Env.E2EPING_MAX_CONFERENCE_SIZE -}}
-config.e2eping.maxConferenceSize = {{ .Env.E2EPING_MAX_CONFERENCE_SIZE }};
-{{ end -}}
-{{ if .Env.E2EPING_MAX_MESSAGE_PER_SECOND -}}
-config.e2eping.maxMessagePerSecond = {{ .Env.E2EPING_MAX_MESSAGE_PER_SECOND }};
-{{ end }}
-
-// Settings for the Excalidraw whiteboard integration.
-config.whiteboard = {
-    enabled: {{ $WHITEBOARD_ENABLED }},
-{{ if .Env.WHITEBOARD_COLLAB_SERVER_PUBLIC_URL -}}
-    collabServerBaseUrl: '{{ .Env.WHITEBOARD_COLLAB_SERVER_PUBLIC_URL }}'
-{{ else if .Env.WHITEBOARD_COLLAB_SERVER_URL_BASE -}}
-    collabServerBaseUrl: '{{ $PUBLIC_URL }}'
-{{ end -}}
-};
-
-// JaaS support: pre-configure image if JAAS_APP_ID was set.
-{{ if .Env.JAAS_APP_ID -}}
-{{ $JAAS_USE_STAGING := .Env.JAAS_USE_STAGING | default "false" | toBool -}}
-{{ $JAAS_DOMAIN := $JAAS_USE_STAGING | ternary "stage.8x8.vc" "8x8.vc" -}}
-
-config.hosts.domain = '{{ $JAAS_DOMAIN }}';
-config.hosts.muc = 'conference.{{ .Env.JAAS_APP_ID }}.{{ $JAAS_DOMAIN }}';
-config.hosts.focus = 'focus.{{ $JAAS_DOMAIN }}';
-
-config.analytics.rtcstatsEnabled = true;
-config.analytics.rtcstatsStoreLogs = true;
-config.analytics.rtcstatsUseLegacy = false;
-config.analytics.rtcstatsEndpoint = 'wss://rtcstats-server-8x8.jitsi.net/';
-config.analytics.rtcstatsPollInterval = 10000;
-config.analytics.rtcstatsSendSdp = true;
-
-config.bosh = 'https://{{ $JAAS_DOMAIN }}/{{ .Env.JAAS_APP_ID }}/http-bind';
-config.websocket = 'wss://{{ $JAAS_DOMAIN }}/{{ .Env.JAAS_APP_ID }}/xmpp-websocket';
-config.websocketKeepAliveUrl = 'https://{{ $JAAS_DOMAIN }}/{{ .Env.JAAS_APP_ID }}/_unlock';
-config.conferenceRequestUrl = 'https://{{ $JAAS_DOMAIN }}/{{ .Env.JAAS_APP_ID }}/conference-request/v1';
-
-config.hiddenDomain = 'recorder.{{ $JAAS_DOMAIN }}';
-config.hiddenFromRecorderFeatureEnabled = true;
-config.enableEmailInStats = true;
-
-config.jaasActuatorUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/jaas-actuator';
-config.jaasTokenUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/token-mapping';
-config.jaasConferenceCreatorUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/vmms-conference-mapper/v1/access/conference-creator';
-config.webhookProxyUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/webhook-proxy';
-config.billingCounterUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/billing-counter/v1/connection';
-config.brandingDataUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/branding/public/v1/conferences';
-config.dialInNumbersUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/vmms-conference-mapper/access/v1/dids';
-config.dialInConfCodeUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/vmms-conference-mapper/v1/access';
-config.dialOutAuthUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/phone-authorize';
-config.dialOutRegionUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/customer-configs/v1/outbound-destination';
-config.peopleSearchUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/v1/directory/search';
-config.inviteServiceUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/v1/meeting/invite';
-config.recordingSharingUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/jaas-recordings/link';
-config.peopleSearchQueryTypes = ['user','conferenceRooms'];
-config.sipInviteUrl = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/sip-jibri-gateway/jibris/invite';
-config.jaasFeedbackMetadataURL = 'https://{{ $JAAS_DOMAIN }}/v1/_jaas/webhook-proxy/feedback';
-
-{{ if $JAAS_USE_STAGING -}}
-config.whiteboard.collabServerBaseUrl = 'https://eght-excalidraw-backend-pilot.cloudflare.jitsi.net';
-{{ else -}}
-config.whiteboard.collabServerBaseUrl = 'https://eght-excalidraw-backend.cloudflare.jitsi.net';
-{{ end -}}
-config.whiteboard.userLimit = 25;
-{{ end -}}
-
-// Testing
-config.testing = {
-    enableAv1Support: {{ $TESTING_AV1_SUPPORT }}
-};
-
-// CUSTOM ADJUSTMENTS
-config.disableThirdPartyRequests = true;
-config.channelLastN = 8;
-config.enableLayerSuspension = true;
\ No newline at end of file