You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

139 lines
4.2 KiB
Bash

1 year ago
#!/bin/sh
ACTION=${1}
shift 1
get_image() {
IMAGE_NAME="stable-8922"
1 year ago
}
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
1 year ago
[ -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