From 84bcda6f0b6e0aab904a8abbe46169c8e6b703ee Mon Sep 17 00:00:00 2001 From: Ben Date: Sun, 3 Sep 2023 05:05:03 +0000 Subject: [PATCH] first commit --- Makefile | 16 ++ README.md | 0 luasrc/controller/seafile.lua | 15 ++ luasrc/model/cbi/seafile.lua | 47 ++++++ luasrc/model/seafile.lua | 55 +++++++ luasrc/view/seafile/status.htm | 31 ++++ root/etc/config/seafile | 5 + root/etc/uci-defaults/luci-app-seafile | 14 ++ root/usr/libexec/apps/seafile/seafile.sh | 138 ++++++++++++++++++ .../share/rpcd/acl.d/luci-app-seafile.json | 11 ++ 10 files changed, 332 insertions(+) create mode 100644 Makefile create mode 100644 README.md create mode 100644 luasrc/controller/seafile.lua create mode 100644 luasrc/model/cbi/seafile.lua create mode 100644 luasrc/model/seafile.lua create mode 100644 luasrc/view/seafile/status.htm create mode 100644 root/etc/config/seafile create mode 100644 root/etc/uci-defaults/luci-app-seafile create mode 100644 root/usr/libexec/apps/seafile/seafile.sh create mode 100644 root/usr/share/rpcd/acl.d/luci-app-seafile.json diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..b4816fd --- /dev/null +++ b/Makefile @@ -0,0 +1,16 @@ + + +include $(TOPDIR)/rules.mk + + +LUCI_TITLE:=LuCI support for seafile +LUCI_PKGARCH:=all +LUCI_DEPENDS:=+lsblk +docker +luci-lib-taskd + +define Package/luci-app-seafile/conffiles +/etc/config/seafile +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/seafile.lua b/luasrc/controller/seafile.lua new file mode 100644 index 0000000..cabf1f3 --- /dev/null +++ b/luasrc/controller/seafile.lua @@ -0,0 +1,15 @@ + +module("luci.controller.seafile", package.seeall) + +function index() + entry({"admin", "apps"}, firstchild(), _("Apps") , 45).dependent = false + if not nixio.fs.access("/etc/config/seafile") then + return + end + + local page = entry({"admin", "apps", "seafile"}, cbi("seafile"), _("seafile")) + page.order = 10 + page.dependent = true + page.acl_depends = { "luci-app-seafile" } + entry({"admin","apps","seafile","status"},call("act_status")).leaf=true +end diff --git a/luasrc/model/cbi/seafile.lua b/luasrc/model/cbi/seafile.lua new file mode 100644 index 0000000..8cc8c94 --- /dev/null +++ b/luasrc/model/cbi/seafile.lua @@ -0,0 +1,47 @@ +--[[ +LuCI - Lua Configuration Interface +]]-- + +local taskd = require "luci.model.tasks" +local seafile_model = require "luci.model.seafile" +local m, s, o + +m = taskd.docker_map("seafile", "seafile", "/usr/libexec/apps/seafile/seafile.sh", + translate("seafile"), + translate("Seafile is an open-source, cross-platform file-hosting software system. Files are stored on a central server and can be synchronized with personal computers and mobile devices through apps.") + .. translate("Official website:") .. ' https://www.seafile.com/en/home/') + +s = m:section(SimpleSection, translate("Service Status"), translate("seafile status:")) +s:append(Template("seafile/status")) + +s = m:section(TypedSection, "seafile", translate("Setup"), translate("Default user: me@example.com Default pass: asecret")) +s.addremove=false +s.anonymous=true + +o = s:option(Value, "port", translate("Port").."*") +o.rmempty = false +o.default = "8160" +o.datatype = "port" + +o = s:option(Value, "image_name", translate("Image").."*") +o.rmempty = false +o.datatype = "string" +o:value("seafileltd/seafile-mc:latest", "seafileltd/seafile-mc:latest") +o.default = "seafileltd/seafile-mc:latest" + +local blocks = seafile_model.blocks() +local home = seafile_model.home() + +o = s:option(Value, "config_path", translate("Config path").."*") +o.rmempty = false +o.datatype = "string" +o:value("/opt/docker2/compose/Config/Seafile", "/opt/docker2/compose/Config/Seafile") +o.default = "/opt/docker2/compose/Config/Seafile" + +local paths, default_path = seafile_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/seafile.lua b/luasrc/model/seafile.lua new file mode 100644 index 0000000..6ba938f --- /dev/null +++ b/luasrc/model/seafile.lua @@ -0,0 +1,55 @@ +local util = require "luci.util" +local jsonc = require "luci.jsonc" + +local seafile = {} + +seafile.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 + +seafile.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 + +seafile.find_paths = function(blocks, home_dirs, path_name) + local default_path = '' + local configs = {} + + default_path = home_dirs[path_name] .. "/seafile" + if #blocks == 0 then + table.insert(configs, default_path) + else + for _, val in pairs(blocks) do + table.insert(configs, val .. "/" .. path_name .. "/seafile") + end + local without_conf_dir = "/root/" .. path_name .. "/seafile" + if default_path == without_conf_dir then + default_path = configs[1] + end + end + + return configs, default_path +end + +return seafile diff --git a/luasrc/view/seafile/status.htm b/luasrc/view/seafile/status.htm new file mode 100644 index 0000000..cb94a41 --- /dev/null +++ b/luasrc/view/seafile/status.htm @@ -0,0 +1,31 @@ +<% +local util = require "luci.util" +local container_status = util.trim(util.exec("/usr/libexec/apps/seafile/seafile.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/seafile/seafile.sh port")) + if port == "" then + port="8160" + end +-%> +
+ +
+ + +
+
+<% end %> diff --git a/root/etc/config/seafile b/root/etc/config/seafile new file mode 100644 index 0000000..38f6334 --- /dev/null +++ b/root/etc/config/seafile @@ -0,0 +1,5 @@ +config seafile + option 'port' '8160' + option 'config_path' '/opt/docker2/Conf/seafile' + option 'image_name' 'seafileltd/seafile-mc:latest' + diff --git a/root/etc/uci-defaults/luci-app-seafile b/root/etc/uci-defaults/luci-app-seafile new file mode 100644 index 0000000..4edd311 --- /dev/null +++ b/root/etc/uci-defaults/luci-app-seafile @@ -0,0 +1,14 @@ +#!/bin/sh + +config_dir=`uci -q get seafile.@seafile[0].config_path` + +data_dir=`docker inspect --format '{{.Mounts}}' seafile | 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 seafile.@seafile[0].config_path="$data_dir" + commit seafile +EOF +fi + +exit 0 diff --git a/root/usr/libexec/apps/seafile/seafile.sh b/root/usr/libexec/apps/seafile/seafile.sh new file mode 100644 index 0000000..ca2cf95 --- /dev/null +++ b/root/usr/libexec/apps/seafile/seafile.sh @@ -0,0 +1,138 @@ +#!/bin/sh + +ACTION=${1} +shift 1 + +get_image() { + IMAGE_NAME="seafileltd/seafile-mc:latest" +} + +do_install_detail() { + local config=`uci get seafile.@seafile[0].config_path 2>/dev/null` + local port=`uci get seafile.@seafile[0].port 2>/dev/null` + local IMAGE_NAME=`uci get seafile.@seafile[0].image_name 2>/dev/null` + local username=`uci get seafile.@seafile[0].username 2>/dev/null` + local password=`uci get seafile.@seafile[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=8160 + [ -z "$IMAGE_NAME" ] && IMAGE_NAME=seafileltd/seafile-mc:latest + + + # Create Docker Compose file with custom variables + + # Create Docker Compose file with custom variables +touch docker-compose.yml +cat > docker-compose.yml <