commit 8d859e2403321637510ee387c0eb955c643a8953 Author: Ben Date: Fri Sep 8 20:03:30 2023 +0000 first commit diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..ce4f5a2 --- /dev/null +++ b/Makefile @@ -0,0 +1,16 @@ + + +include $(TOPDIR)/rules.mk + + +LUCI_TITLE:=LuCI support for btcpayserver +LUCI_PKGARCH:=all +LUCI_DEPENDS:=+lsblk +docker +luci-lib-taskd + +define Package/luci-app-btcpayserver/conffiles +/etc/config/btcpayserver +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/btcpayserver.lua b/luasrc/controller/btcpayserver.lua new file mode 100644 index 0000000..d07306e --- /dev/null +++ b/luasrc/controller/btcpayserver.lua @@ -0,0 +1,15 @@ + +module("luci.controller.btcpayserver", package.seeall) + +function index() + entry({"admin", "apps"}, firstchild(), _("Apps") , 45).dependent = false + if not nixio.fs.access("/etc/config/btcpayserver") then + return + end + + local page = entry({"admin", "apps", "btcpayserver"}, cbi("btcpayserver"), _("BTCPay Server")) + page.order = 10 + page.dependent = true + page.acl_depends = { "luci-app-btcpayserver" } + entry({"admin","apps","btcpayserver","status"},call("act_status")).leaf=true +end diff --git a/luasrc/model/btcpayserver.lua b/luasrc/model/btcpayserver.lua new file mode 100644 index 0000000..dc4feac --- /dev/null +++ b/luasrc/model/btcpayserver.lua @@ -0,0 +1,55 @@ +local util = require "luci.util" +local jsonc = require "luci.jsonc" + +local btcpayserver = {} + +btcpayserver.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 + +btcpayserver.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 + +btcpayserver.find_paths = function(blocks, home_dirs, path_name) + local default_path = '' + local configs = {} + + default_path = home_dirs[path_name] .. "/btcpayserver" + if #blocks == 0 then + table.insert(configs, default_path) + else + for _, val in pairs(blocks) do + table.insert(configs, val .. "/" .. path_name .. "/btcpayserver") + end + local without_conf_dir = "/root/" .. path_name .. "/btcpayserver" + if default_path == without_conf_dir then + default_path = configs[1] + end + end + + return configs, default_path +end + +return btcpayserver diff --git a/luasrc/model/cbi/btcpayserver.lua b/luasrc/model/cbi/btcpayserver.lua new file mode 100644 index 0000000..54a8725 --- /dev/null +++ b/luasrc/model/cbi/btcpayserver.lua @@ -0,0 +1,49 @@ +--[[ +LuCI - Lua Configuration Interface +]]-- + +local taskd = require "luci.model.tasks" +local btcpayserver_model = require "luci.model.btcpayserver" +local m, s, o + +m = taskd.docker_map("btcpayserver", "btcpayserver", "/usr/libexec/apps/btcpayserver/btcpayserver.sh", + translate("btcpayserver"), + translate("Get Virtual Desktops of all flavors, Alpine, Ubuntu, Fedora, and Arch based containers containing full desktop environments in officially supported versions accessible via any modern web browser.") + .. translate("Official website:") .. ' hhttps://docs.linuxserver.io/images/docker-btcpayserver/') + +s = m:section(SimpleSection, translate("Service Status"), translate("btcpayserver status:")) +s:append(Template("btcpayserver/status")) + +s = m:section(TypedSection, "btcpayserver", translate("Setup"), translate("The following parameters will only take effect during installation or upgrade:")) +s.addremove=false +s.anonymous=true + +o = s:option(Value, "port", translate("Port").."*") +o.rmempty = false +o.default = "8888" +o.datatype = "port" + +o = s:option(Value, "image_name", translate("Lightning").."*") +o.rmempty = false +o.datatype = "string" +o:value("clightning", "clightning") +o:value("lnd", "lnd") +o.default = "clightning" + +local blocks = btcpayserver_model.blocks() +local home = btcpayserver_model.home() + +o = s:option(Value, "config_path", translate("Network").."*") +o.rmempty = false +o.datatype = "string" +o:value("mainnet", "mainnet") +o:value("testnet", "testnet") +o.default = "mainnet" + +local paths, default_path = btcpayserver_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/view/btcpayserver/status.htm b/luasrc/view/btcpayserver/status.htm new file mode 100644 index 0000000..bf99d86 --- /dev/null +++ b/luasrc/view/btcpayserver/status.htm @@ -0,0 +1,31 @@ +<% +local util = require "luci.util" +local container_status = util.trim(util.exec("/usr/libexec/apps/btcpayserver/btcpayserver.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/btcpayserver/btcpayserver.sh port")) + if port == "" then + port="3000" + end +-%> +
+ +
+ + +
+
+<% end %> diff --git a/root/etc/config/btcpayserver b/root/etc/config/btcpayserver new file mode 100644 index 0000000..1b619a4 --- /dev/null +++ b/root/etc/config/btcpayserver @@ -0,0 +1,4 @@ +config btcpayserver + option 'port' '8888' + option 'config_path' 'mainnet' + option 'image_name' 'clightning' diff --git a/root/etc/uci-defaults/luci-app-btcpayserver b/root/etc/uci-defaults/luci-app-btcpayserver new file mode 100644 index 0000000..21aaf6e --- /dev/null +++ b/root/etc/uci-defaults/luci-app-btcpayserver @@ -0,0 +1,14 @@ +#!/bin/sh + +config_dir=`uci -q get btcpayserver.@btcpayserver[0].config_path` + +data_dir=`docker inspect --format '{{.Mounts}}' btcpayserver | 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 btcpayserver.@btcpayserver[0].config_path="$data_dir" + commit btcpayserver +EOF +fi + +exit 0 diff --git a/root/usr/libexec/apps/btcpayserver/btcpayserver.sh b/root/usr/libexec/apps/btcpayserver/btcpayserver.sh new file mode 100644 index 0000000..e82d46e --- /dev/null +++ b/root/usr/libexec/apps/btcpayserver/btcpayserver.sh @@ -0,0 +1,107 @@ +#!/bin/sh + +ACTION=${1} +shift 1 + +get_image() { + local IMAGE_NAME=$(uci get btcpayserver.@btcpayserver[0].image_name 2>/dev/null) +} + +do_install_detail() { + local config=$(uci get btcpayserver.@btcpayserver[0].config_path 2>/dev/null) + local port=$(uci get btcpayserver.@btcpayserver[0].port 2>/dev/null) + local IMAGE_NAME=$(uci get btcpayserver.@btcpayserver[0].image_name 2>/dev/null) + + GEN_PASS=$(head -c14 /dev/urandom | tr -dc A-Za-z0-9) + GEN_PASS2=$(head -c14 /dev/urandom | tr -dc A-Za-z0-9) + + LAN_IP=$(uci get network.lan.ipaddr) + LAN_IP="${LAN_IP%/*}" + + [ -z "$config" ] && { echo "config path is empty!"; exit 1; } + [ -z "$port" ] && port=8888 + [ -z "$IMAGE_NAME" ] && IMAGE_NAME=clightning + +setup_btcpayserver() { + git clone https://github.com/btcpayserver/btcpayserver-docker /opt/docker2/compose/btcpayserver/btcpayserver-docker/ + + touch /opt/docker2/compose/btcpayserver/btcpayserver-docker/go.sh + chmod +x /opt/docker2/compose/btcpayserver/btcpayserver-docker/go.sh + cat > /opt/docker2/compose/btcpayserver/btcpayserver-docker/go.sh <