From 09581e13be6dacd5bc1acfd039343827f10b562b Mon Sep 17 00:00:00 2001 From: coolsnowwolf Date: Sat, 21 Oct 2017 12:00:53 +0800 Subject: [PATCH] add new luci-app-haproxy-tcp package --- package/lean/he-6in4/Makefile | 2 - package/lean/luci-app-haproxy-tcp/Makefile | 51 +++++++ package/lean/luci-app-haproxy-tcp/README.md | 54 ++++++++ .../files/etc/config/haproxy | 29 ++++ .../files/etc/haproxy_init.sh | 129 ++++++++++++++++++ .../files/etc/haproxy_start | 73 ++++++++++ .../usr/lib/lua/luci/controller/haproxy.lua | 7 + .../usr/lib/lua/luci/model/cbi/haproxy.lua | 67 +++++++++ .../i18n/zh-cn/haproxy.zh-cn.po | 34 +++++ .../tools/po2lmo/Makefile | 0 .../tools/po2lmo/src/po2lmo | Bin 0 -> 19272 bytes .../tools/po2lmo/src/po2lmo.c | 0 .../tools/po2lmo/src/template_lmo.c | 0 .../tools/po2lmo/src/template_lmo.h | 0 package/lean/luci-app-haproxy/LICENSE | 21 --- package/lean/luci-app-haproxy/Makefile | 86 ------------ .../files/luci/controller/haproxy-tcp.lua | 7 - .../files/luci/i18n/haproxy-tcp.zh-cn.po | 35 ----- .../files/luci/model/cbi/haproxy-tcp.lua | 57 -------- .../files/root/etc/config/haproxy-tcp | 9 -- .../files/root/etc/init.d/haproxy-tcp | 74 ---------- .../root/etc/uci-defaults/luci-haproxy-tcp | 15 -- 22 files changed, 444 insertions(+), 306 deletions(-) create mode 100644 package/lean/luci-app-haproxy-tcp/Makefile create mode 100644 package/lean/luci-app-haproxy-tcp/README.md create mode 100644 package/lean/luci-app-haproxy-tcp/files/etc/config/haproxy create mode 100755 package/lean/luci-app-haproxy-tcp/files/etc/haproxy_init.sh create mode 100755 package/lean/luci-app-haproxy-tcp/files/etc/haproxy_start create mode 100644 package/lean/luci-app-haproxy-tcp/files/usr/lib/lua/luci/controller/haproxy.lua create mode 100644 package/lean/luci-app-haproxy-tcp/files/usr/lib/lua/luci/model/cbi/haproxy.lua create mode 100755 package/lean/luci-app-haproxy-tcp/i18n/zh-cn/haproxy.zh-cn.po rename package/lean/{luci-app-haproxy => luci-app-haproxy-tcp}/tools/po2lmo/Makefile (100%) create mode 100755 package/lean/luci-app-haproxy-tcp/tools/po2lmo/src/po2lmo rename package/lean/{luci-app-haproxy => luci-app-haproxy-tcp}/tools/po2lmo/src/po2lmo.c (100%) rename package/lean/{luci-app-haproxy => luci-app-haproxy-tcp}/tools/po2lmo/src/template_lmo.c (100%) rename package/lean/{luci-app-haproxy => luci-app-haproxy-tcp}/tools/po2lmo/src/template_lmo.h (100%) delete mode 100644 package/lean/luci-app-haproxy/LICENSE delete mode 100644 package/lean/luci-app-haproxy/Makefile delete mode 100644 package/lean/luci-app-haproxy/files/luci/controller/haproxy-tcp.lua delete mode 100644 package/lean/luci-app-haproxy/files/luci/i18n/haproxy-tcp.zh-cn.po delete mode 100644 package/lean/luci-app-haproxy/files/luci/model/cbi/haproxy-tcp.lua delete mode 100644 package/lean/luci-app-haproxy/files/root/etc/config/haproxy-tcp delete mode 100644 package/lean/luci-app-haproxy/files/root/etc/init.d/haproxy-tcp delete mode 100644 package/lean/luci-app-haproxy/files/root/etc/uci-defaults/luci-haproxy-tcp diff --git a/package/lean/he-6in4/Makefile b/package/lean/he-6in4/Makefile index 8dcb6978c..9c3f362c4 100644 --- a/package/lean/he-6in4/Makefile +++ b/package/lean/he-6in4/Makefile @@ -21,8 +21,6 @@ include $(INCLUDE_DIR)/package.mk define Package/he-6in4 SECTION:=ipv6 - CATEGORY:=Gmod - SUBMENU:=Network TITLE:=Dynamic Update he.net of ip PKGARCH:=all DEPENDS:=+luci-proto-ipv6 +6in4 +curl diff --git a/package/lean/luci-app-haproxy-tcp/Makefile b/package/lean/luci-app-haproxy-tcp/Makefile new file mode 100644 index 000000000..8163fa267 --- /dev/null +++ b/package/lean/luci-app-haproxy-tcp/Makefile @@ -0,0 +1,51 @@ +include $(TOPDIR)/rules.mk + +PKG_NAME:=luci-app-haproxy-tcp +PKG_VERSION=1.4 +PKG_RELEASE:=1 +PKG_MAINTAINER:=Alex Zhuo <1886090@gmail.com> + +PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME) + +include $(INCLUDE_DIR)/package.mk + +define Package/$(PKG_NAME) + CATEGORY:=Utilities + SUBMENU:=Luci + TITLE:=luci for haproxy and shadowsocks + PKGARCH:=all + DEPENDS:=+haproxy +endef + +define Package/$(PKG_NAME)/description + A luci app for haproxy with shadowsocks +endef + +define Package/$(PKG_NAME)/postinst +#!/bin/sh +rm -rf /tmp/luci* +echo stopping haproxy +/etc/init.d/haproxy stop +/etc/init.d/haproxy disable +echo haproxy disabled +endef + +define Build/Prepare + $(foreach po,$(wildcard ${CURDIR}/i18n/zh-cn/*.po), \ + po2lmo $(po) $(PKG_BUILD_DIR)/$(patsubst %.po,%.lmo,$(notdir $(po)));) +endef + +define Build/Configure +endef + +define Build/Compile +endef + +define Package/$(PKG_NAME)/install + $(INSTALL_DIR) $(1)/usr/lib/lua/luci/i18n + $(INSTALL_DATA) $(PKG_BUILD_DIR)/*.*.lmo $(1)/usr/lib/lua/luci/i18n/ + $(CP) ./files/* $(1)/ + +endef + +$(eval $(call BuildPackage,$(PKG_NAME))) diff --git a/package/lean/luci-app-haproxy-tcp/README.md b/package/lean/luci-app-haproxy-tcp/README.md new file mode 100644 index 000000000..d95f46844 --- /dev/null +++ b/package/lean/luci-app-haproxy-tcp/README.md @@ -0,0 +1,54 @@ +# luci-app-haproxy-tcp +OpenWrt HAProxy的Luci配置页面,已在[该固件][A]中使用 + +简介 +--- + +本软件包为OpenWRT HAPrxoy的 LuCI 控制界面,用于Shadowsocks在多服务器条件下实现负载均衡和高可用 + +可以设置多个主服务器或多个备用服务器. 默认监听端口127.0.0.1:2222 后台监控页面端口0.0.0.0:1111,后台监控页面地址192.168.1.1:1111/haproxy + +多主服务器是将所有TCP流量分流,并可以设置每个服务器的分流比例;多备用服务器是在检测到主服务器A宕机之后切换至备用服务器B,B宕机之后切换到服务器C...依次类推,可以防止因为单个服务器或者线路故障导致的断网问题。 +使用效果和更多使用方法请[点击这里][A] + + +依赖 +--- + +显式依赖 `haproxy`, 安装完毕该luci包后会stop并disable当前op的haproxy,点击“保存&应用”后会修改HAProxy默认配置文件/etc/haproxy.cfg并自动重启,支持开机自启. + + +配置 +--- + +如果有需要,可以修改/etc/haproxy_init.sh ,不要直接修改/etc/haproxy.cfg,否则会被覆盖 + +编译 +--- + +从 OpenWrt 的 [SDK][openwrt-sdk] 编译 +```bash +# 解压下载好的 SDK +tar xjf OpenWrt-SDK-ar71xx-for-linux-x86_64-gcc-4.8-linaro_uClibc-0.9.33.2.tar.bz2 +cd OpenWrt-SDK-ar71xx-* +# Clone 项目 +git clone https://github.com/AlexZhuo/luci-app-haproxy-tcp package/luci-app-haproxy-tcp +# 编译 po2lmo (如果有po2lmo可跳过) +pushd package/luci-app-haproxy-tcp/tools/po2lmo +make && sudo make install +popd +# 选择要编译的包 Utilities -> LuCI -> luci-app-haproxy-tcp +make menuconfig +# 开始编译 +make package/luci-app-haproxy-tcp/compile V=99 +``` + + +截图 +--- +![](https://github.com/AlexZhuo/BreakwallOpenWrt/raw/master/screenshots/haproxy.png) + +[A]: http://www.right.com.cn/forum/thread-198649-1-1.html +[openwrt-sdk]: http://wiki.openwrt.org/doc/howto/obtain.firmware.sdk + + diff --git a/package/lean/luci-app-haproxy-tcp/files/etc/config/haproxy b/package/lean/luci-app-haproxy-tcp/files/etc/config/haproxy new file mode 100644 index 000000000..5d324ca3f --- /dev/null +++ b/package/lean/luci-app-haproxy-tcp/files/etc/config/haproxy @@ -0,0 +1,29 @@ + +config arguments + option enabled '0' + +config main_server + option server_weight '10' + option server_ip '1.2.3.4' + option server_port '443' + option server_name 'JP1' + option validate '1' + +config backup_server + option server_name 'JP2' + option server_ip '2.2.2.2' + option server_port '8038' + option validate '1' + +config backup_server + option server_name 'JP3' + option server_ip '3.3.3.3' + option server_port '443' + option validate '1' + +config backup_server + option server_name 'JP4' + option server_ip '4.4.4.4' + option server_port '443' + option validate '1' + diff --git a/package/lean/luci-app-haproxy-tcp/files/etc/haproxy_init.sh b/package/lean/luci-app-haproxy-tcp/files/etc/haproxy_init.sh new file mode 100755 index 000000000..d40e52da5 --- /dev/null +++ b/package/lean/luci-app-haproxy-tcp/files/etc/haproxy_init.sh @@ -0,0 +1,129 @@ +#!/bin/sh /etc/rc.common + +CFG_FILE=/etc/haproxy.cfg +stop(){ + logger -t alex stopping haproxy + echo "stopping haproxy" + /etc/init.d/haproxy disable + /etc/init.d/haproxy stop + [ -f /etc/haproxy_backup ] && { + cp /etc/haproxy_backup /etc/init.d/haproxy + } + iptables -t nat -D OUTPUT -j HAPROXY &> /dev/null + iptables -t nat -F HAPROXY &> /dev/null + sleep 1 + iptables -t nat -X HAPROXY &> /dev/null +} +start(){ + echo "starting haproxy" + logger -t alex restarting haproxy + echo global > $CFG_FILE + cat >> $CFG_FILE </dev/null` + local server_name=`uci get haproxy.@main_server[$COUNTER].server_name 2>/dev/null` + local server_port=`uci get haproxy.@main_server[$COUNTER].server_port 2>/dev/null` + local server_weight=`uci get haproxy.@main_server[$COUNTER].server_weight 2>/dev/null` + local validate=`uci get haproxy.@main_server[$COUNTER].validate 2>/dev/null` + if [ -z "$server_ip" ] || [ -z "$server_name" ] || [ -z "$server_port" ] || [ -z "$server_weight" ]; then + echo break + break + fi + echo the main server $COUNTER $server_ip $server_name $server_port $server_weight + [ "$validate" = 1 ] && { + echo server $server_name $server_ip:$server_port weight $server_weight maxconn 1024 check inter 1500 rise 3 fall 3 >> $CFG_FILE + } + iptables -t nat -A HAPROXY -p tcp -d $server_ip -j ACCEPT + COUNTER=$(($COUNTER+1)) + done + COUNTER=0 + #添加备用服务器 + while true + do + local server_ip=`uci get haproxy.@backup_server[$COUNTER].server_ip 2>/dev/null` + local server_name=`uci get haproxy.@backup_server[$COUNTER].server_name 2>/dev/null` + local server_port=`uci get haproxy.@backup_server[$COUNTER].server_port 2>/dev/null` + local validate=`uci get haproxy.@backup_server[$COUNTER].validate 2>/dev/null` + if [ -z "$server_ip" ] || [ -z "$server_name" ] || [ -z "$server_port" ]; then + echo break + break + fi + echo the backup server $COUNTER $server_ip $server_name $server_port + [ "$validate" = 1 ] && { + echo server $server_name $server_ip:$server_port weight 10 check backup inter 1500 rise 3 fall 3 >> $CFG_FILE + } + iptables -t nat -A HAPROXY -p tcp -d $server_ip -j ACCEPT + COUNTER=$(($COUNTER+1)) + done + iptables -t nat -I OUTPUT -j HAPROXY + /etc/init.d/haproxy enable + /etc/init.d/haproxy restart + cp /etc/init.d/haproxy /etc/haproxy_backup + cp /etc/haproxy_start /etc/init.d/haproxy +} + +restart(){ + echo luci for haproxy + sleep 1s + local vt_enabled=`uci get haproxy.@arguments[0].enabled 2>/dev/null` + logger -t alex !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!haproxy is initializing enabled is $vt_enabled + echo $vt_enabled + if [ "$vt_enabled" = 1 ]; then + [ -f /etc/haproxy_backup ] && { + cp /etc/haproxy_backup /etc/init.d/haproxy + } + iptables -t nat -D OUTPUT -j HAPROXY &> /dev/null + iptables -t nat -F HAPROXY &> /dev/null + sleep 1 + iptables -t nat -X HAPROXY &> /dev/null + start; + else + stop; + fi +} \ No newline at end of file diff --git a/package/lean/luci-app-haproxy-tcp/files/etc/haproxy_start b/package/lean/luci-app-haproxy-tcp/files/etc/haproxy_start new file mode 100755 index 000000000..f0c9e52b1 --- /dev/null +++ b/package/lean/luci-app-haproxy-tcp/files/etc/haproxy_start @@ -0,0 +1,73 @@ +#!/bin/sh /etc/rc.common +# Copyright (C) 2009-2010 OpenWrt.org + +START=99 +STOP=80 + +SERVICE_USE_PID=1 + +HAPROXY_BIN="/usr/sbin/haproxy" +HAPROXY_CONFIG="/etc/haproxy.cfg" +HAPROXY_PID="/var/run/haproxy.pid" + +start() { + service_start $HAPROXY_BIN -q -D -f "$HAPROXY_CONFIG" -p "$HAPROXY_PID" + local COUNTER=0 + #添加主服务器 + iptables -t nat -D OUTPUT -j HAPROXY &> /dev/null + iptables -t nat -X HAPROXY + iptables -t nat -N HAPROXY + iptables -t nat -F HAPROXY + + while true + do + local server_ip=`uci get haproxy.@main_server[$COUNTER].server_ip 2>/dev/null` + local server_name=`uci get haproxy.@main_server[$COUNTER].server_name 2>/dev/null` + local server_port=`uci get haproxy.@main_server[$COUNTER].server_port 2>/dev/null` + local server_weight=`uci get haproxy.@main_server[$COUNTER].server_weight 2>/dev/null` + local validate=`uci get haproxy.@main_server[$COUNTER].validate 2>/dev/null` + if [ -z "$server_ip" ] || [ -z "$server_name" ] || [ -z "$server_port" ] || [ -z "$server_weight" ]; then + echo break + break + fi + echo the main2 server $COUNTER $server_ip $server_name $server_port $server_weight + [ "$validate" = 1 ] && { + iptables -t nat -A HAPROXY -p tcp -d $server_ip -j ACCEPT + } + COUNTER=$(($COUNTER+1)) + done + COUNTER=0 + #添加备用服务器 + while true + do + local server_ip=`uci get haproxy.@backup_server[$COUNTER].server_ip 2>/dev/null` + local server_name=`uci get haproxy.@backup_server[$COUNTER].server_name 2>/dev/null` + local server_port=`uci get haproxy.@backup_server[$COUNTER].server_port 2>/dev/null` + local validate=`uci get haproxy.@backup_server[$COUNTER].validate 2>/dev/null` + if [ -z "$server_ip" ] || [ -z "$server_name" ] || [ -z "$server_port" ]; then + echo break + break + fi + echo the backup2 server $COUNTER $server_ip $server_name $server_port + [ "$validate" = 1 ] && { + iptables -t nat -A HAPROXY -p tcp -d $server_ip -j ACCEPT + } + COUNTER=$(($COUNTER+1)) + done + + iptables -t nat -I OUTPUT -j HAPROXY +} + +stop() { + kill -9 $(cat $HAPROXY_PID | tr "\n" " ") + service_stop $HAPROXY_BIN + iptables -t nat -D OUTPUT -j HAPROXY &> /dev/null + iptables -t nat -F HAPROXY &> /dev/null + sleep 1 + iptables -t nat -X HAPROXY &> /dev/null +} + +reload() { + $HAPROXY_BIN -D -q -f $HAPROXY_CONFIG -p $HAPROXY_PID -sf $(cat $HAPROXY_PID | tr "\n" " ") + #$HAPROXY_BIN -D -q -f $HAPROXY_CONFIG -p $HAPROXY_PID -sf $(cat $HAPROXY_PID) +} diff --git a/package/lean/luci-app-haproxy-tcp/files/usr/lib/lua/luci/controller/haproxy.lua b/package/lean/luci-app-haproxy-tcp/files/usr/lib/lua/luci/controller/haproxy.lua new file mode 100644 index 000000000..5549e754b --- /dev/null +++ b/package/lean/luci-app-haproxy-tcp/files/usr/lib/lua/luci/controller/haproxy.lua @@ -0,0 +1,7 @@ +module("luci.controller.haproxy", package.seeall) +function index() + if not nixio.fs.access("/etc/config/haproxy") then + return + end + entry({"admin", "services", "haproxy"}, cbi("haproxy"), _("HAProxy")).dependent = true +end \ No newline at end of file diff --git a/package/lean/luci-app-haproxy-tcp/files/usr/lib/lua/luci/model/cbi/haproxy.lua b/package/lean/luci-app-haproxy-tcp/files/usr/lib/lua/luci/model/cbi/haproxy.lua new file mode 100644 index 000000000..381b1951b --- /dev/null +++ b/package/lean/luci-app-haproxy-tcp/files/usr/lib/lua/luci/model/cbi/haproxy.lua @@ -0,0 +1,67 @@ +--Alex<1886090@gmail.com> +local fs = require "nixio.fs" + +function sync_value_to_file(value, file) --用来写入文件的函数,目前这种方式已经弃用 + value = value:gsub("\r\n?", "\n") + local old_value = nixio.fs.readfile(file) + if value ~= old_value then + nixio.fs.writefile(file, value) + end +end +local state_msg = "" +local haproxy_on = (luci.sys.call("pidof haproxy > /dev/null") == 0) +local router_ip = luci.sys.exec("uci get network.lan.ipaddr") +if haproxy_on then + state_msg = "" .. translate("Running") .. "" +else + state_msg = "" .. translate("Not running") .. "" +end +m=Map("haproxy",translate("HAProxy"),translate("HAProxy能够检测Shadowsocks服务器的连通情况,从而实现负载均衡和高可用的功能,支持主备用服务器宕机自动切换,并且可以设置多个主服务器用于分流,规定每个分流节点的流量比例等。前提条件是你的所有Shadowsocks服务器的【加密方式】和【密码】一致。

使用方法:配置好你的Shadowsocks服务器ip地址和端口,然后开启Shadowsocks服务,将服务器地址填写为【127.0.0.1】,端口【2222】,其他参数和之前一样即可,你可以通过访问【路由器的IP:1111/haproxy】输入用户名admin,密码root来观察各节点健康状况,红色为宕机,绿色正常,使用说明请点击这里") .. "

后台监控页面:" .. router_ip .. ":1111/haproxy 用户名admin,密码root" .. "

状态 - " .. state_msg) +s=m:section(TypedSection,"arguments","") + s.addremove=false + s.anonymous=true + view_enable = s:option(Flag,"enabled",translate("Enable")) + --通过读写配置文件控制HAProxy这种方式已经弃用 + --view_cfg = s:option(TextValue, "1", nil) + --view_cfg.rmempty = false + --view_cfg.rows = 43 + + --function view_cfg.cfgvalue() + -- return nixio.fs.readfile("/etc/haproxy.cfg") or "" + --end + --function view_cfg.write(self, section, value) + -- sync_value_to_file(value, "/etc/haproxy.cfg") + --end +s=m:section(TypedSection,"main_server","" .. translate("Main Server List") .. "") + s.anonymous=true + s.addremove=true + o=s:option(Value,"server_name",translate("Display Name"),translate("Only English Characters,No spaces")) + o.rmempty = false + + o=s:option(Flag,"validate",translate("validate")) + + o=s:option(Value,"server_ip",translate("Proxy Server IP")) + o.datatype="ip4addr" + o=s:option(Value,"server_port",translate("Proxy Server Port")) + o.datatype="uinteger" + o=s:option(Value,"server_weight",translate("Weight")) + o.datatype="uinteger" + +s=m:section(TypedSection,"backup_server","" .. translate("Backup Server List") .. "") + s.anonymous=true + s.addremove=true + o=s:option(Value,"server_name",translate("Display Name"),translate("Only English Characters,No spaces")) + o.rmempty = false + + o=s:option(Flag,"validate",translate("validate")) + + o=s:option(Value,"server_ip",translate("Proxy Server IP")) + o.datatype="ip4addr" + o=s:option(Value,"server_port",translate("Proxy Server Port")) + o.datatype="uinteger" +-- --------------------------------------------------- +local apply = luci.http.formvalue("cbi.apply") +if apply then + os.execute("/etc/haproxy_init.sh restart >/dev/null 2>&1 &") +end +return m diff --git a/package/lean/luci-app-haproxy-tcp/i18n/zh-cn/haproxy.zh-cn.po b/package/lean/luci-app-haproxy-tcp/i18n/zh-cn/haproxy.zh-cn.po new file mode 100755 index 000000000..19a187d9d --- /dev/null +++ b/package/lean/luci-app-haproxy-tcp/i18n/zh-cn/haproxy.zh-cn.po @@ -0,0 +1,34 @@ +msgid "Running" +msgstr "运行中" + +msgid "Not running" +msgstr "未运行" + +msgid "Main Server List" +msgstr "主服务器列表" + +msgid "Display Name" +msgstr "服务器名称" + +msgid "Only English Characters,No spaces" +msgstr "仅限英文字母,不要有空格" + +msgid "Proxy Server IP" +msgstr "代理服务器IP" + +msgid "Proxy Server Port" +msgstr "代理服务器端口" + +msgid "Weight" +msgstr "分流权重" + +msgid "Backup Server List" +msgstr "备用服务器列表" + +msgid "validate" +msgstr "生效" + + + + + diff --git a/package/lean/luci-app-haproxy/tools/po2lmo/Makefile b/package/lean/luci-app-haproxy-tcp/tools/po2lmo/Makefile similarity index 100% rename from package/lean/luci-app-haproxy/tools/po2lmo/Makefile rename to package/lean/luci-app-haproxy-tcp/tools/po2lmo/Makefile diff --git a/package/lean/luci-app-haproxy-tcp/tools/po2lmo/src/po2lmo b/package/lean/luci-app-haproxy-tcp/tools/po2lmo/src/po2lmo new file mode 100755 index 0000000000000000000000000000000000000000..68d4c13aca2d2894ac62de3c5f4425cf99ed84fd GIT binary patch literal 19272 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 kl(^b literal 0 HcmV?d00001 diff --git a/package/lean/luci-app-haproxy/tools/po2lmo/src/po2lmo.c b/package/lean/luci-app-haproxy-tcp/tools/po2lmo/src/po2lmo.c similarity index 100% rename from package/lean/luci-app-haproxy/tools/po2lmo/src/po2lmo.c rename to package/lean/luci-app-haproxy-tcp/tools/po2lmo/src/po2lmo.c diff --git a/package/lean/luci-app-haproxy/tools/po2lmo/src/template_lmo.c b/package/lean/luci-app-haproxy-tcp/tools/po2lmo/src/template_lmo.c similarity index 100% rename from package/lean/luci-app-haproxy/tools/po2lmo/src/template_lmo.c rename to package/lean/luci-app-haproxy-tcp/tools/po2lmo/src/template_lmo.c diff --git a/package/lean/luci-app-haproxy/tools/po2lmo/src/template_lmo.h b/package/lean/luci-app-haproxy-tcp/tools/po2lmo/src/template_lmo.h similarity index 100% rename from package/lean/luci-app-haproxy/tools/po2lmo/src/template_lmo.h rename to package/lean/luci-app-haproxy-tcp/tools/po2lmo/src/template_lmo.h diff --git a/package/lean/luci-app-haproxy/LICENSE b/package/lean/luci-app-haproxy/LICENSE deleted file mode 100644 index e09a55e37..000000000 --- a/package/lean/luci-app-haproxy/LICENSE +++ /dev/null @@ -1,21 +0,0 @@ -MIT License - -Copyright (c) 2017 chenhw2 - -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is -furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in all -copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -SOFTWARE. diff --git a/package/lean/luci-app-haproxy/Makefile b/package/lean/luci-app-haproxy/Makefile deleted file mode 100644 index 3bb7287db..000000000 --- a/package/lean/luci-app-haproxy/Makefile +++ /dev/null @@ -1,86 +0,0 @@ -# -# Copyright (C) 2016 chenhw2 -# -# See /LICENSE for more information. -# - -include $(TOPDIR)/rules.mk - -PKG_NAME:=luci-app-haproxy-tcp -PKG_VERSION:=0.1.4 -PKG_RELEASE:=2 - -PKG_LICENSE:=MIT -PKG_LICENSE_FILES:=LICENSE -PKG_MAINTAINER:=chenhw2 - -PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME) - -include $(INCLUDE_DIR)/package.mk - -define Package/luci-app-haproxy-tcp - SECTION:=luci - CATEGORY:=LuCI - SUBMENU:=3. Applications - TITLE:=LuCI Support for HAProxy-TCP - PKGARCH:=all - DEPENDS:=+haproxy-nossl -endef - -define Package/luci-app-haproxy-tcp/description - LuCI Support for HAProxy-TCP. -endef - -define Build/Prepare - $(foreach po,$(wildcard ${CURDIR}/files/luci/i18n/*.po), \ - po2lmo $(po) $(PKG_BUILD_DIR)/$(patsubst %.po,%.lmo,$(notdir $(po)));) -endef - -define Build/Configure -endef - -define Build/Compile -endef - -define Package/luci-app-haproxy-tcp/postinst -#!/bin/sh -if [ -z "$${IPKG_INSTROOT}" ]; then - if [ -f /etc/uci-defaults/luci-haproxy-tcp ]; then - ( . /etc/uci-defaults/luci-haproxy-tcp ) && \ - rm -f /etc/uci-defaults/luci-haproxy-tcp - fi - rm -rf /tmp/luci-indexcache /tmp/luci-modulecache -fi -exit 0 -endef - -define Package/luci-app-haproxy-tcp/prerm -#!/bin/sh -/etc/init.d/haproxy-tcp disable -/etc/init.d/haproxy-tcp stop -rm -f /usr/sbin/haproxy-tcp -exit 0 -endef - -define Package/luci-app-haproxy-tcp/conffiles -/etc/config/haproxy-tcp -endef - -define Package/luci-app-haproxy-tcp/install - $(INSTALL_DIR) $(1)/usr/lib/lua/luci/i18n - $(INSTALL_DATA) $(PKG_BUILD_DIR)/haproxy-tcp.*.lmo $(1)/usr/lib/lua/luci/i18n/ - $(INSTALL_DIR) $(1)/usr/lib/lua/luci/controller - $(INSTALL_DATA) ./files/luci/controller/*.lua $(1)/usr/lib/lua/luci/controller/ - $(INSTALL_DIR) $(1)/usr/lib/lua/luci/model/cbi - $(INSTALL_DATA) ./files/luci/model/cbi/*.lua $(1)/usr/lib/lua/luci/model/cbi/ - $(INSTALL_DIR) $(1)/etc/config - $(INSTALL_DATA) ./files/root/etc/config/haproxy-tcp $(1)/etc/config/haproxy-tcp - $(INSTALL_DIR) $(1)/etc/init.d - $(INSTALL_BIN) ./files/root/etc/init.d/haproxy-tcp $(1)/etc/init.d/haproxy-tcp - $(INSTALL_DIR) $(1)/etc/uci-defaults - $(INSTALL_BIN) ./files/root/etc/uci-defaults/luci-haproxy-tcp $(1)/etc/uci-defaults/luci-haproxy-tcp - $(INSTALL_DIR) $(1)/usr/sbin - $(LN) haproxy $(1)/usr/sbin/haproxy-tcp -endef - -$(eval $(call BuildPackage,luci-app-haproxy-tcp)) diff --git a/package/lean/luci-app-haproxy/files/luci/controller/haproxy-tcp.lua b/package/lean/luci-app-haproxy/files/luci/controller/haproxy-tcp.lua deleted file mode 100644 index bb8318887..000000000 --- a/package/lean/luci-app-haproxy/files/luci/controller/haproxy-tcp.lua +++ /dev/null @@ -1,7 +0,0 @@ -module("luci.controller.haproxy-tcp", package.seeall) - -function index() - entry( - {"admin", "services", "haproxy-tcp"}, - cbi("haproxy-tcp"), _("HAProxy-TCP"), 55) -end diff --git a/package/lean/luci-app-haproxy/files/luci/i18n/haproxy-tcp.zh-cn.po b/package/lean/luci-app-haproxy/files/luci/i18n/haproxy-tcp.zh-cn.po deleted file mode 100644 index 0c2d3eb2d..000000000 --- a/package/lean/luci-app-haproxy/files/luci/i18n/haproxy-tcp.zh-cn.po +++ /dev/null @@ -1,35 +0,0 @@ -msgid "" -msgstr "Content-Type: text/plain; charset=UTF-8\n" - -msgid "%u seconds" -msgstr "%u 秒" - -msgid "Enable" -msgstr "启用" - -msgid "General Setting" -msgstr "基本设置" - -msgid "HAProxy-TCP" -msgstr "负载均衡-TCP" - -msgid "Listen Address:Port" -msgstr "服务地址" - -msgid "Retries" -msgstr "重试次数" - -msgid "Status Admin" -msgstr "状态管理" - -msgid "Startup Delay" -msgstr "自启动延时" - -msgid "Port" -msgstr "端口" - -msgid "Timeout Connect (ms)" -msgstr "连接超时 (毫秒)" - -msgid "UpStream Server" -msgstr "上游服务器" diff --git a/package/lean/luci-app-haproxy/files/luci/model/cbi/haproxy-tcp.lua b/package/lean/luci-app-haproxy/files/luci/model/cbi/haproxy-tcp.lua deleted file mode 100644 index 4bfdb8d47..000000000 --- a/package/lean/luci-app-haproxy/files/luci/model/cbi/haproxy-tcp.lua +++ /dev/null @@ -1,57 +0,0 @@ -local m, s, o - -if luci.sys.call("pgrep haproxy-tcp >/dev/null") == 0 then - m = Map("haproxy-tcp", translate("HAProxy-TCP"), "%s - %s" %{translate("HAProxy-TCP"), translate("RUNNING")}) -else - m = Map("haproxy-tcp", translate("HAProxy-TCP"), "%s - %s" %{translate("HAProxy-TCP"), translate("NOT RUNNING")}) -end - -s = m:section(TypedSection, "general", translate("General Setting"), - "%s" %{ - luci.sys.exec("uci get network.lan.ipaddr | tr -d '\r\n'"), - luci.sys.exec("uci get haproxy-tcp.general.admin_stats | tr -d '\r\n'"), - translate("Status Admin") - }) -s.anonymous = true - -o = s:option(Flag, "enable", translate("Enable")) -o.rmempty = false - -o = s:option(Value, "startup_delay", translate("Startup Delay")) -o:value(0, translate("Not enabled")) -for _, v in ipairs({5, 10, 15, 25, 40}) do - o:value(v, translate("%u seconds") %{v}) -end -o.datatype = "uinteger" -o.default = 0 -o.rmempty = false - -o = s:option(Value, "admin_stats", "%s%s" %{translate("Status Admin"), translate("Port")}) -o.placeholder = "7777" -o.default = "7777" -o.datatype = "port" -o.rmempty = false - -o = s:option(Value, "listen", translate("Listen Address:Port")) -o.placeholder = "0.0.0.0:6666" -o.default = "0.0.0.0:6666" -o.rmempty = false - -o = s:option(Value, "timeout", translate("Timeout Connect (ms)")) -o.placeholder = "666" -o.default = "666" -o.datatype = "range(33, 10000)" -o.rmempty = false - -o = s:option(Value, "retries", translate("Retries")) -o.placeholder = "1" -o.default = "1" -o.datatype = "range(1, 10)" -o.rmempty = false - - -o = s:option(DynamicList, "upstreams", translate("UpStream Server"), translate("e.g. [8.8.8.8:53 weight 100]")) -o.placeholder = "8.8.8.8:53" -o.rmempty = false - -return m diff --git a/package/lean/luci-app-haproxy/files/root/etc/config/haproxy-tcp b/package/lean/luci-app-haproxy/files/root/etc/config/haproxy-tcp deleted file mode 100644 index 833ca571d..000000000 --- a/package/lean/luci-app-haproxy/files/root/etc/config/haproxy-tcp +++ /dev/null @@ -1,9 +0,0 @@ - -config general 'general' - option enable '0' - option retries '1' - option timeout '1000' - option listen '0.0.0.0:6666' - option admin_stats '7777' - option startup_delay '5' - list upstreams '1.2.3.4:8388' diff --git a/package/lean/luci-app-haproxy/files/root/etc/init.d/haproxy-tcp b/package/lean/luci-app-haproxy/files/root/etc/init.d/haproxy-tcp deleted file mode 100644 index 1d978e314..000000000 --- a/package/lean/luci-app-haproxy/files/root/etc/init.d/haproxy-tcp +++ /dev/null @@ -1,74 +0,0 @@ -#!/bin/sh /etc/rc.common - -START=85 -NAME=haproxy-tcp - -genline_srv(){ - line="$1" - hash="$(echo -n $line | md5sum | cut -c1-6)" - hash="$(echo -n $line | tr -d '\t ' | cut -c1-8)__$hash" - echo " server $hash $line" | tr -d "\'" -} - -boot() { - local delay=$(uci -q get $NAME.general.startup_delay) - (sleep ${delay:-0} && start >/dev/null 2>&1) & - return 0 -} - -start() { - enable=$(uci -q get $NAME.general.enable) - [ "$enable" = 1 ] || return 0 - listen=$(uci -q get $NAME.general.listen) - admin_stats=$(uci -q get $NAME.general.admin_stats) - retries=$(uci -q get $NAME.general.retries) - timeout=$(uci -q get $NAME.general.timeout) - upstreams=$(uci -q get $NAME.general.upstreams) - - mkdir -p /var/etc - cat <<-EOF > /var/etc/$NAME.cfg - global - nbproc 2 - - defaults - mode tcp - retries ${retries:-2} - timeout connect ${timeout:-1000} - - listen admin_stats - bind 0.0.0.0:${admin_stats:-7777} - mode http - stats uri / - stats refresh 10s - - frontend tcp-in - bind ${listen:-0.0.0.0:6666} - default_backend tcp-out - - backend tcp-out - $( if [ 0 -lt $(grep -c weight /etc/config/$NAME) ]; then - echo " balance static-rr" - sed -n 's/.*upstreams[\t ]*//p' /etc/config/$NAME | - while read upstream; do - genline_srv "$upstream" - done - else - for upstream in $upstreams; do - genline_srv "$upstream" - done - fi - ) - -EOF - - /usr/sbin/$NAME -q -D -f /var/etc/$NAME.cfg -p /var/run/$NAME.pid -} - -kill_all() { - kill -9 $(pgrep -f $@) >/dev/null 2>&1 -} - -stop() { - kill_all "$NAME.pid" - rm -rf /var/etc/$NAME.cfg -} diff --git a/package/lean/luci-app-haproxy/files/root/etc/uci-defaults/luci-haproxy-tcp b/package/lean/luci-app-haproxy/files/root/etc/uci-defaults/luci-haproxy-tcp deleted file mode 100644 index a8923938c..000000000 --- a/package/lean/luci-app-haproxy/files/root/etc/uci-defaults/luci-haproxy-tcp +++ /dev/null @@ -1,15 +0,0 @@ -#!/bin/sh - -uci -q batch <<-EOF >/dev/null - delete ucitrack.@haproxy-tcp[-1] - add ucitrack haproxy-tcp - set ucitrack.@haproxy-tcp[-1].init=haproxy-tcp - commit ucitrack -EOF - -/etc/init.d/haproxy stop -/etc/init.d/haproxy disable - -/etc/init.d/haproxy-tcp enable - -exit 0