|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
ACTION=${1}
|
|
|
|
shift 1
|
|
|
|
|
|
|
|
get_image() {
|
|
|
|
IMAGE_NAME="stable-8922"
|
|
|
|
}
|
|
|
|
|
|
|
|
do_install_detail() {
|
|
|
|
local config=`uci get jitsi.@jitsi[0].config_path 2>/dev/null`
|
|
|
|
local port=`uci get jitsi.@jitsi[0].port 2>/dev/null`
|
|
|
|
local IMAGE_NAME=`uci get jitsi.@jitsi[0].image_name 2>/dev/null`
|
|
|
|
local username=`uci get jitsi.@jitsi[0].username 2>/dev/null`
|
|
|
|
local password=`uci get jitsi.@jitsi[0].password 2>/dev/null`
|
|
|
|
local wireguard=`uci get jitsi.@jitsi[0].wireguard 2>/dev/null`
|
|
|
|
local domain=`uci get jitsi.@jitsi[0].domain 2>/dev/null`
|
|
|
|
|
|
|
|
#Generate the generic environment variables for the docker-compose
|
|
|
|
|
|
|
|
GEN_PASS=$(< /dev/urandom tr -dc A-Za-z0-9 2>/dev/null | head -c14; echo)
|
|
|
|
GEN_PASS2=$(< /dev/urandom tr -dc A-Za-z0-9 2>/dev/null | head -c14; echo)
|
|
|
|
|
|
|
|
# Get our local LAN IP Address
|
|
|
|
LAN_IP=$(uci get network.lan.ipaddr)
|
|
|
|
# Strip trailing network mask
|
|
|
|
LAN_IP="${LAN_IP%/*}"
|
|
|
|
|
|
|
|
if [ -z "$config" ]; then
|
|
|
|
echo "config path is empty!"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
[ -z "$port" ] && port=8443
|
|
|
|
[ -z "$IMAGE_NAME" ] && IMAGE_NAME=stable-8922
|
|
|
|
[ -z "$username" ] && username=admin
|
|
|
|
[ -z "$password" ] && password=password
|
|
|
|
[ -z "$wireguard" ] && wireguard=$LAN_IP
|
|
|
|
[ -z "$domain" ] && domain=privatecloud.lan
|
|
|
|
|
|
|
|
|
|
|
|
echo "downloading Jitsi..."
|
|
|
|
wget https://github.com/jitsi/docker-jitsi-meet/archive/refs/tags/$IMAGE_NAME.tar.gz
|
|
|
|
|
|
|
|
chmod 777 $IMAGE_NAME.tar.gz
|
|
|
|
|
|
|
|
echo "extracting Jitsi..."
|
|
|
|
tar xzvf $config/jitsi/$IMAGE_NAME.tar.gz -C $config/jitsi/
|
|
|
|
|
|
|
|
cd $config/jitsi/docker-jitsi-meet-$IMAGE_NAME/
|
|
|
|
|
|
|
|
cp $config/jitsi/docker-jitsi-meet-$IMAGE_NAME/env.example $config/jitsi/docker-jitsi-meet-$IMAGE_NAME/.env
|
|
|
|
|
|
|
|
echo "changing env variables..."
|
|
|
|
# Edit our .env to enable public URL (required)
|
|
|
|
sed -i -e "s/#PUBLIC_URL=/PUBLIC_URL=/g" "$config/jitsi/docker-jitsi-meet-$IMAGE_NAME/.env"
|
|
|
|
|
|
|
|
# Edit our .env to set public URL (required)
|
|
|
|
sed -i -e "s/meet.example.com/$domain/g" "$config/jitsi/docker-jitsi-meet-$IMAGE_NAME/.env"
|
|
|
|
|
|
|
|
# Change JVB http port
|
|
|
|
#sed -i -e "s/# JaaS Components (beta)/JVB_COLIBRI_PORT=8088/g" "$config/jitsi/docker-jitsi-meet-$IMAGE_NAME/.env"
|
|
|
|
|
|
|
|
# Set local IP and Wireguard for WebRTC
|
|
|
|
sed -i -e "s/#JVB_ADVERTISE_IPS=192.168.1.1,1.2.3.4/JVB_ADVERTISE_IPS=LAN_IP,$LAN_IP,$wireguard/g" "$config/jitsi/docker-jitsi-meet-$IMAGE_NAME/.env"
|
|
|
|
|
|
|
|
# Set container restart policy
|
|
|
|
sed -i -e "s/#RESTART_POLICY=unless-stopped/RESTART_POLICY=unless-stopped/g" "$config/jitsi/docker-jitsi-meet-$IMAGE_NAME/.env"
|
|
|
|
|
|
|
|
# Enable Auth
|
|
|
|
sed -i -e "s/#ENABLE_AUTH=1/ENABLE_AUTH=1/g" "$config/jitsi/docker-jitsi-meet-$IMAGE_NAME/.env"
|
|
|
|
|
|
|
|
# Enable guest access
|
|
|
|
sed -i -e "s/#ENABLE_GUESTS=1/ENABLE_GUESTS=1/g" "$config/jitsi/docker-jitsi-meet-$IMAGE_NAME/.env"
|
|
|
|
|
|
|
|
# Set Auth type to internal
|
|
|
|
sed -i -e "s/#AUTH_TYPE=internal/AUTH_TYPE=internal/g" "$config/jitsi/docker-jitsi-meet-$IMAGE_NAME/.env"
|
|
|
|
|
|
|
|
echo "Setting strong passwords..."
|
|
|
|
#Set strong passwordss
|
|
|
|
./gen-passwords.sh
|
|
|
|
|
|
|
|
#make config directory
|
|
|
|
mkdir -p ~/.jitsi-meet-cfg/{web,transcripts,prosody/config,prosody/prosody-plugins-custom,jicofo,jvb,jigasi,jibri}
|
|
|
|
|
|
|
|
echo "Installing..."
|
|
|
|
docker-compose up -d
|
|
|
|
|
|
|
|
echo "Setting Host Password..."
|
|
|
|
docker-compose exec prosody /bin/bash -c "prosodyctl --config /config/prosody.cfg.lua register $username meet.jitsi $password"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Add a new list option to the "shortcutmenu" configuration file
|
|
|
|
uci add shortcutmenu lists
|
|
|
|
uci set shortcutmenu.@lists[-1].webname="$IMAGE_NAME"
|
|
|
|
uci set shortcutmenu.@lists[-1].weburl="$LAN_IP:$port"
|
|
|
|
uci set shortcutmenu.@lists[-1].webpath="/"
|
|
|
|
uci commit shortcutmenu
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
usage() {
|
|
|
|
echo "usage: $0 sub-command"
|
|
|
|
echo "where sub-command is one of:"
|
|
|
|
echo " install Install jitsi"
|
|
|
|
echo " upgrade Upgrade jitsi"
|
|
|
|
echo " rm/start/stop/restart Remove/Start/Stop/Restart jitsi"
|
|
|
|
echo " status jitsi status"
|
|
|
|
echo " port jitsi port"
|
|
|
|
}
|
|
|
|
|
|
|
|
case ${ACTION} in
|
|
|
|
"install")
|
|
|
|
get_image
|
|
|
|
do_install_detail
|
|
|
|
;;
|
|
|
|
"upgrade")
|
|
|
|
get_image
|
|
|
|
do_install_detail
|
|
|
|
;;
|
|
|
|
"rm")
|
|
|
|
docker rm -f jitsi
|
|
|
|
;;
|
|
|
|
"start" | "stop" | "restart")
|
|
|
|
docker ${ACTION} jitsi
|
|
|
|
;;
|
|
|
|
"status")
|
|
|
|
docker ps --all -f 'name=jitsi' --format '{{.State}}'
|
|
|
|
;;
|
|
|
|
"port")
|
|
|
|
docker ps --all -f 'name=jitsi' --format '{{.Ports}}' | grep -om1 '0.0.0.0:[0-9]*' | sed 's/0.0.0.0://'
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
usage
|
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|