first commit
commit
2f6585139f
@ -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
|
@ -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
|
@ -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:") .. ' <a href=\"https://www.jitsi.org/\" target=\"_blank\">https://www.jitsi.org/</a>')
|
||||
|
||||
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").."<b>*</b>")
|
||||
o.rmempty = false
|
||||
o.default = "8443"
|
||||
o.datatype = "port"
|
||||
|
||||
o = s:option(Value, "image_name", translate("Version").."<b>*</b>")
|
||||
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").."<b>*</b>")
|
||||
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
|
@ -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
|
@ -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"
|
||||
-%>
|
||||
<div class="cbi-value">
|
||||
<label class="cbi-value-title"><%:Status%></label>
|
||||
<div class="cbi-value-field">
|
||||
<% if container_running then %>
|
||||
<button class="cbi-button cbi-button-success" disabled="true"><%:jitsi is running%></button>
|
||||
<% else %>
|
||||
<button class="cbi-button cbi-button-negative" disabled="true"><%:jitsi is not running%></button>
|
||||
<% end %>
|
||||
</div>
|
||||
</div>
|
||||
<%
|
||||
if container_running then
|
||||
local port=util.trim(util.exec("/usr/libexec/apps/jitsi/jitsi.sh port"))
|
||||
if port == "" then
|
||||
port="8443"
|
||||
end
|
||||
-%>
|
||||
<div class="cbi-value cbi-value-last">
|
||||
<label class="cbi-value-title"> </label>
|
||||
<div class="cbi-value-field">
|
||||
|
||||
<input type="button" class="btn cbi-button cbi-button-apply" name="start" value="<%:Open jitsi%>" onclick="window.open('http://'+location.hostname+':<%=port%>/', '_blank')">
|
||||
</div>
|
||||
</div>
|
||||
<% end %>
|
@ -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'
|
||||
|
@ -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
|
@ -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
|
@ -0,0 +1,11 @@
|
||||
{
|
||||
"luci-app-jitsi": {
|
||||
"description": "Grant UCI access for luci-app-jitsi",
|
||||
"read": {
|
||||
"uci": [ "jitsi" ]
|
||||
},
|
||||
"write": {
|
||||
"uci": [ "jitsi" ]
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue