commit 62e3463029d5e65df42d14deedc08531bd50f086 Author: Ben Date: Sun Sep 3 05:13:46 2023 +0000 first commit diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..5aac54c --- /dev/null +++ b/Makefile @@ -0,0 +1,16 @@ + + +include $(TOPDIR)/rules.mk + + +LUCI_TITLE:=LuCI support for owncast +LUCI_PKGARCH:=all +LUCI_DEPENDS:=+lsblk +docker +luci-lib-taskd + +define Package/luci-app-owncast/conffiles +/etc/config/owncast +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/owncast.lua b/luasrc/controller/owncast.lua new file mode 100644 index 0000000..5bf0c39 --- /dev/null +++ b/luasrc/controller/owncast.lua @@ -0,0 +1,15 @@ + +module("luci.controller.owncast", package.seeall) + +function index() + entry({"admin", "apps"}, firstchild(), _("Apps") , 45).dependent = false + if not nixio.fs.access("/etc/config/owncast") then + return + end + + local page = entry({"admin", "apps", "owncast"}, cbi("owncast"), _("owncast")) + page.order = 10 + page.dependent = true + page.acl_depends = { "luci-app-owncast" } + entry({"admin","apps","owncast","status"},call("act_status")).leaf=true +end diff --git a/luasrc/model/cbi/owncast.lua b/luasrc/model/cbi/owncast.lua new file mode 100644 index 0000000..6cafe68 --- /dev/null +++ b/luasrc/model/cbi/owncast.lua @@ -0,0 +1,47 @@ +--[[ +LuCI - Lua Configuration Interface +]]-- + +local taskd = require "luci.model.tasks" +local owncast_model = require "luci.model.owncast" +local m, s, o + +m = taskd.docker_map("owncast", "owncast", "/usr/libexec/apps/owncast/owncast.sh", + translate("owncast"), + translate("Owncast is an open source, self-hosted live video and chat server for use with existing popular broadcasting software. With streaming + chat out of the box you can take control over your content by running it yourself. For hosting with TorGuard Wireguard make sure to fw internal and external tcp port 1935") + .. translate("Official website:") .. ' hhttps://owncast.online/') + +s = m:section(SimpleSection, translate("Service Status"), translate("owncast status:")) +s:append(Template("owncast/status")) + +s = m:section(TypedSection, "owncast", translate("Setup"), translate("admin/password is default login. Please make note of your stream key.")) +s.addremove=false +s.anonymous=true + +o = s:option(Value, "port", translate("Port").."*") +o.rmempty = false +o.default = "8387" +o.datatype = "port" + +o = s:option(Value, "image_name", translate("Image").."*") +o.rmempty = false +o.datatype = "string" +o:value("owncast/owncast:latest", "owncast/owncast:latest") +o.default = "owncast/owncast:latest" + +local blocks = owncast_model.blocks() +local home = owncast_model.home() + +o = s:option(Value, "config_path", translate("Config path").."*") +o.rmempty = false +o.datatype = "string" +o:value("/opt/docker2/compose/owncast", "/opt/docker2/compose/owncast") +o.default = "/opt/docker2/compose/owncast" + +local paths, default_path = owncast_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/owncast.lua b/luasrc/model/owncast.lua new file mode 100644 index 0000000..2ac9e0b --- /dev/null +++ b/luasrc/model/owncast.lua @@ -0,0 +1,55 @@ +local util = require "luci.util" +local jsonc = require "luci.jsonc" + +local owncast = {} + +owncast.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 + +owncast.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 + +owncast.find_paths = function(blocks, home_dirs, path_name) + local default_path = '' + local configs = {} + + default_path = home_dirs[path_name] .. "/owncast" + if #blocks == 0 then + table.insert(configs, default_path) + else + for _, val in pairs(blocks) do + table.insert(configs, val .. "/" .. path_name .. "/owncast") + end + local without_conf_dir = "/root/" .. path_name .. "/owncast" + if default_path == without_conf_dir then + default_path = configs[1] + end + end + + return configs, default_path +end + +return owncast diff --git a/luasrc/view/owncast/status.htm b/luasrc/view/owncast/status.htm new file mode 100644 index 0000000..a2b8cca --- /dev/null +++ b/luasrc/view/owncast/status.htm @@ -0,0 +1,31 @@ +<% +local util = require "luci.util" +local container_status = util.trim(util.exec("/usr/libexec/apps/owncast/owncast.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/owncast/owncast.sh port")) + if port == "" then + port="8387" + end +-%> +
+ +
+ + +
+
+<% end %> diff --git a/root/etc/config/owncast b/root/etc/config/owncast new file mode 100644 index 0000000..8d11498 --- /dev/null +++ b/root/etc/config/owncast @@ -0,0 +1,5 @@ +config owncast + option 'port' '8387' + option 'config_path' '/opt/docker2/compose/owncast' + option 'image_name' 'owncast/owncast:latest' + diff --git a/root/etc/uci-defaults/luci-app-owncast b/root/etc/uci-defaults/luci-app-owncast new file mode 100644 index 0000000..a4c6060 --- /dev/null +++ b/root/etc/uci-defaults/luci-app-owncast @@ -0,0 +1,14 @@ +#!/bin/sh + +config_dir=`uci -q get owncast.@owncast[0].config_path` + +data_dir=`docker inspect --format '{{.Mounts}}' owncast | 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 owncast.@owncast[0].config_path="$data_dir" + commit owncast +EOF +fi + +exit 0 diff --git a/root/usr/libexec/apps/owncast/owncast.sh b/root/usr/libexec/apps/owncast/owncast.sh new file mode 100644 index 0000000..0a1edd6 --- /dev/null +++ b/root/usr/libexec/apps/owncast/owncast.sh @@ -0,0 +1,113 @@ +#!/bin/sh + +ACTION=${1} +shift 1 + +get_image() { + IMAGE_NAME="owncast/owncast:latest" +} + +do_install_detail() { + local config=`uci get owncast.@owncast[0].config_path 2>/dev/null` + local port=`uci get owncast.@owncast[0].port 2>/dev/null` + local IMAGE_NAME=`uci get owncast.@owncast[0].image_name 2>/dev/null` + local username=`uci get owncast.@owncast[0].username 2>/dev/null` + local password=`uci get owncast.@owncast[0].password 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=8387 + [ -z "$IMAGE_NAME" ] && IMAGE_NAME=owncast/owncast:latest + + + # Create Docker Compose file with custom variables + + # Create Docker Compose file with custom variables +touch docker-compose.yml +cat > docker-compose.yml <