From 2f6585139f1467085108b39d76fe5023ed147f35 Mon Sep 17 00:00:00 2001 From: ben Date: Wed, 6 Sep 2023 20:28:25 -0400 Subject: [PATCH] first commit --- Makefile | 16 ++ README.md | 0 luasrc/controller/jitsi.lua | 15 ++ luasrc/model/cbi/jitsi.lua | 64 ++++++++ luasrc/model/jitsi.lua | 55 +++++++ luasrc/view/jitsi/status.htm | 31 ++++ root/etc/config/jitsi | 9 ++ root/etc/uci-defaults/luci-app-jitsi | 14 ++ root/usr/libexec/apps/jitsi/jitsi.sh | 138 ++++++++++++++++++ root/usr/share/rpcd/acl.d/luci-app-jitsi.json | 11 ++ 10 files changed, 353 insertions(+) create mode 100644 Makefile create mode 100644 README.md create mode 100755 luasrc/controller/jitsi.lua create mode 100644 luasrc/model/cbi/jitsi.lua create mode 100644 luasrc/model/jitsi.lua create mode 100644 luasrc/view/jitsi/status.htm create mode 100644 root/etc/config/jitsi create mode 100644 root/etc/uci-defaults/luci-app-jitsi create mode 100755 root/usr/libexec/apps/jitsi/jitsi.sh create mode 100644 root/usr/share/rpcd/acl.d/luci-app-jitsi.json diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..77ffe2a --- /dev/null +++ b/Makefile @@ -0,0 +1,16 @@ + + +include $(TOPDIR)/rules.mk + + +LUCI_TITLE:=LuCI support for jitsi +LUCI_PKGARCH:=all +LUCI_DEPENDS:=+lsblk +docker +luci-lib-taskd + +define Package/luci-app-jitsi/conffiles +/etc/config/jitsi +endef + +include $(TOPDIR)/feeds/luci/luci.mk + +# call BuildPackage - OpenWrt buildroot signature diff --git a/README.md b/README.md new file mode 100644 index 0000000..e69de29 diff --git a/luasrc/controller/jitsi.lua b/luasrc/controller/jitsi.lua new file mode 100755 index 0000000..ff0eef6 --- /dev/null +++ b/luasrc/controller/jitsi.lua @@ -0,0 +1,15 @@ + +module("luci.controller.jitsi", package.seeall) + +function index() + entry({"admin", "apps"}, firstchild(), _("Apps") , 45).dependent = false + if not nixio.fs.access("/etc/config/jitsi") then + return + end + + local page = entry({"admin", "apps", "jitsi"}, cbi("jitsi"), _("jitsi")) + page.order = 10 + page.dependent = true + page.acl_depends = { "luci-app-jitsi" } + entry({"admin","apps","jitsi","status"},call("act_status")).leaf=true +end diff --git a/luasrc/model/cbi/jitsi.lua b/luasrc/model/cbi/jitsi.lua new file mode 100644 index 0000000..7acc9cd --- /dev/null +++ b/luasrc/model/cbi/jitsi.lua @@ -0,0 +1,64 @@ +--[[ +LuCI - Lua Configuration Interface +]]-- + +local taskd = require "luci.model.tasks" +local jitsi_model = require "luci.model.jitsi" +local m, s, o + +m = taskd.docker_map("jitsi", "jitsi", "/usr/libexec/apps/jitsi/jitsi.sh", + translate("jitsi"), + translate("More secure, more flexible, and completely free video conferencing.") + .. translate("Official website:") .. ' https://www.jitsi.org/') + +s = m:section(SimpleSection, translate("Service Status"), translate("jitsi status:")) +s:append(Template("jitsi/status")) + +s = m:section(TypedSection, "jitsi", translate("Setup"), translate("Refresh to update settings.")) +s.addremove=false +s.anonymous=true + +o = s:option(Value, "port", translate("Port").."*") +o.rmempty = false +o.default = "8443" +o.datatype = "port" + +o = s:option(Value, "image_name", translate("Version").."*") +o.rmempty = false +o.datatype = "string" +o:value("stable-8319", "stable-8319") +o.default = "stable-8319" + +o = s:option(Value, "username", translate("Jitsi Admin Username")) +o.rmempty = false +o.datatype = "string" + +o = s:option(Value, "password", translate("Jitsi Admin Password")) +o.rmempty = false +o.datatype = "string" +o.password = true + +o = s:option(Value, "domain", translate("Public Jitsi domain")) +o.rmempty = false +o.datatype = "string" + +o = s:option(Value, "wireguard", translate("WireGuard VPN IP")) +o.rmempty = false +o.datatype = "string" + +local blocks = jitsi_model.blocks() +local home = jitsi_model.home() + +o = s:option(Value, "config_path", translate("Install path").."*") +o.rmempty = false +o.datatype = "string" +o:value("/opt/docker2/compose/jitsi", "/opt/docker2/compose/jitsi") +o.default = "/opt/docker2/compose/jitsi" + +local paths, default_path = jitsi_model.find_paths(blocks, home, "Configs") +for _, val in pairs(paths) do + o:value(val, val) +end +o.default = default_path + +return m diff --git a/luasrc/model/jitsi.lua b/luasrc/model/jitsi.lua new file mode 100644 index 0000000..927a938 --- /dev/null +++ b/luasrc/model/jitsi.lua @@ -0,0 +1,55 @@ +local util = require "luci.util" +local jsonc = require "luci.jsonc" + +local jitsi = {} + +jitsi.blocks = function() + local f = io.popen("lsblk -s -f -b -o NAME,FSSIZE,MOUNTPOINT --json", "r") + local vals = {} + if f then + local ret = f:read("*all") + f:close() + local obj = jsonc.parse(ret) + for _, val in pairs(obj["blockdevices"]) do + local fsize = val["fssize"] + if fsize ~= nil and string.len(fsize) > 10 and val["mountpoint"] then + -- fsize > 1G + vals[#vals+1] = val["mountpoint"] + end + end + end + return vals +end + +jitsi.home = function() + local uci = require "luci.model.uci".cursor() + local home_dirs = {} + home_dirs["main_dir"] = uci:get_first("quickstart", "main", "main_dir", "/root") + home_dirs["Configs"] = uci:get_first("quickstart", "main", "conf_dir", home_dirs["main_dir"].."/Configs") + home_dirs["Public"] = uci:get_first("quickstart", "main", "pub_dir", home_dirs["main_dir"].."/Public") + home_dirs["Downloads"] = uci:get_first("quickstart", "main", "dl_dir", home_dirs["Public"].."/Downloads") + home_dirs["Caches"] = uci:get_first("quickstart", "main", "tmp_dir", home_dirs["main_dir"].."/Caches") + return home_dirs +end + +jitsi.find_paths = function(blocks, home_dirs, path_name) + local default_path = '' + local configs = {} + + default_path = home_dirs[path_name] .. "/jitsi" + if #blocks == 0 then + table.insert(configs, default_path) + else + for _, val in pairs(blocks) do + table.insert(configs, val .. "/" .. path_name .. "/jitsi") + end + local without_conf_dir = "/root/" .. path_name .. "/jitsi" + if default_path == without_conf_dir then + default_path = configs[1] + end + end + + return configs, default_path +end + +return jitsi diff --git a/luasrc/view/jitsi/status.htm b/luasrc/view/jitsi/status.htm new file mode 100644 index 0000000..5b54409 --- /dev/null +++ b/luasrc/view/jitsi/status.htm @@ -0,0 +1,31 @@ +<% +local util = require "luci.util" +local container_status = util.trim(util.exec("/usr/libexec/apps/jitsi/jitsi.sh status")) +local container_install = (string.len(container_status) > 0) +local container_running = container_status == "running" +-%> +
+ +
+ <% if container_running then %> + + <% else %> + + <% end %> +
+
+<% +if container_running then + local port=util.trim(util.exec("/usr/libexec/apps/jitsi/jitsi.sh port")) + if port == "" then + port="8443" + end +-%> +
+ +
+ + +
+
+<% end %> diff --git a/root/etc/config/jitsi b/root/etc/config/jitsi new file mode 100644 index 0000000..7f2c8dd --- /dev/null +++ b/root/etc/config/jitsi @@ -0,0 +1,9 @@ +config jitsi + option 'port' '8443' + option 'config_path' '/opt/docker2/Conf/jitsi' + option 'image_name' 'stable-8319' + option 'username' 'admin + option 'password' 'password' + option 'wireguard' '1.2.3.4' + option 'domain' 'mydomain.com' + diff --git a/root/etc/uci-defaults/luci-app-jitsi b/root/etc/uci-defaults/luci-app-jitsi new file mode 100644 index 0000000..f7db6cd --- /dev/null +++ b/root/etc/uci-defaults/luci-app-jitsi @@ -0,0 +1,14 @@ +#!/bin/sh + +config_dir=`uci -q get jitsi.@jitsi[0].config_path` + +data_dir=`docker inspect --format '{{.Mounts}}' jitsi | grep -Eom1 '[^ ]+/_data /var/www/html local true ' | cut -d' ' -f1` + +if [ -n "$data_dir" -a "$data_dir" != "$config_dir" ]; then + uci -q batch <<-EOF >/dev/null + set jitsi.@jitsi[0].config_path="$data_dir" + commit jitsi +EOF +fi + +exit 0 diff --git a/root/usr/libexec/apps/jitsi/jitsi.sh b/root/usr/libexec/apps/jitsi/jitsi.sh new file mode 100755 index 0000000..fac2121 --- /dev/null +++ b/root/usr/libexec/apps/jitsi/jitsi.sh @@ -0,0 +1,138 @@ +#!/bin/sh + +ACTION=${1} +shift 1 + +get_image() { + IMAGE_NAME="stable-8319" +} + +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-8319 + [ -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 diff --git a/root/usr/share/rpcd/acl.d/luci-app-jitsi.json b/root/usr/share/rpcd/acl.d/luci-app-jitsi.json new file mode 100644 index 0000000..f4ce8c8 --- /dev/null +++ b/root/usr/share/rpcd/acl.d/luci-app-jitsi.json @@ -0,0 +1,11 @@ +{ + "luci-app-jitsi": { + "description": "Grant UCI access for luci-app-jitsi", + "read": { + "uci": [ "jitsi" ] + }, + "write": { + "uci": [ "jitsi" ] + } + } +}