|
|
@@ -1,5 +1,7 @@
|
|
|
#!/bin/sh
|
|
|
+
|
|
|
. $IPKG_INSTROOT/etc/init.d/shadowsocksr
|
|
|
+
|
|
|
netflix() {
|
|
|
if [ -f "$TMP_DNSMASQ_PATH/gfw_list.conf" ]; then
|
|
|
for line in $(cat /etc/ssrplus/netflix.list); do sed -i "/$line/d" $TMP_DNSMASQ_PATH/gfw_list.conf; done
|
|
|
@@ -14,7 +16,14 @@ else
|
|
|
cp -rf /etc/ssrplus/gfw_list.conf $TMP_DNSMASQ_PATH/
|
|
|
cp -rf /etc/ssrplus/gfw_base.conf $TMP_DNSMASQ_PATH/
|
|
|
fi
|
|
|
-case "$(uci_get_by_type global netflix_server nil)" in
|
|
|
+if [ "$(uci_get_by_type global netflix_enable 0)" == "1" ]; then
|
|
|
+ # 只有开启 NetFlix分流 才需要取值
|
|
|
+ SHUNT_SERVER=$(uci_get_by_type global netflix_server nil)
|
|
|
+else
|
|
|
+ # 没有开启 设置为 nil
|
|
|
+ SHUNT_SERVER=nil
|
|
|
+fi
|
|
|
+case "$SHUNT_SERVER" in
|
|
|
nil)
|
|
|
rm -f $TMP_DNSMASQ_PATH/netflix_forward.conf
|
|
|
;;
|
|
|
@@ -25,12 +34,14 @@ $(uci_get_by_type global global_server nil) | $switch_server | same)
|
|
|
netflix $tmp_shunt_dns_port
|
|
|
;;
|
|
|
esac
|
|
|
-for line in $(cat /etc/ssrplus/black.list); do sed -i "/$line/d" $TMP_DNSMASQ_PATH/gfw_list.conf; done
|
|
|
-for line in $(cat /etc/ssrplus/black.list); do sed -i "/$line/d" $TMP_DNSMASQ_PATH/gfw_base.conf; done
|
|
|
-for line in $(cat /etc/ssrplus/white.list); do sed -i "/$line/d" $TMP_DNSMASQ_PATH/gfw_list.conf; done
|
|
|
-for line in $(cat /etc/ssrplus/white.list); do sed -i "/$line/d" $TMP_DNSMASQ_PATH/gfw_base.conf; done
|
|
|
-for line in $(cat /etc/ssrplus/deny.list); do sed -i "/$line/d" $TMP_DNSMASQ_PATH/gfw_list.conf; done
|
|
|
-for line in $(cat /etc/ssrplus/deny.list); do sed -i "/$line/d" $TMP_DNSMASQ_PATH/gfw_base.conf; done
|
|
|
+# 此处使用while方式读取 防止 /etc/ssrplus/ 目录下的 black.list white.list deny.list 等2个或多个文件一行中存在空格 比如:# abc.com 而丢失:server
|
|
|
+while read line; do sed -i "/$line/d" $TMP_DNSMASQ_PATH/gfw_list.conf; done < /etc/ssrplus/black.list
|
|
|
+while read line; do sed -i "/$line/d" $TMP_DNSMASQ_PATH/gfw_base.conf; done < /etc/ssrplus/black.list
|
|
|
+while read line; do sed -i "/$line/d" $TMP_DNSMASQ_PATH/gfw_list.conf; done < /etc/ssrplus/white.list
|
|
|
+while read line; do sed -i "/$line/d" $TMP_DNSMASQ_PATH/gfw_base.conf; done < /etc/ssrplus/white.list
|
|
|
+while read line; do sed -i "/$line/d" $TMP_DNSMASQ_PATH/gfw_list.conf; done < /etc/ssrplus/deny.list
|
|
|
+while read line; do sed -i "/$line/d" $TMP_DNSMASQ_PATH/gfw_base.conf; done < /etc/ssrplus/deny.list
|
|
|
+# 此处直接使用 cat 因为有 sed '/#/d' 删除了 数据
|
|
|
cat /etc/ssrplus/black.list | sed '/^$/d' | sed '/#/d' | sed "/.*/s/.*/server=\/&\/127.0.0.1#$dns_port\nipset=\/&\/blacklist/" >$TMP_DNSMASQ_PATH/blacklist_forward.conf
|
|
|
cat /etc/ssrplus/white.list | sed '/^$/d' | sed '/#/d' | sed "/.*/s/.*/server=\/&\/127.0.0.1\nipset=\/&\/whitelist/" >$TMP_DNSMASQ_PATH/whitelist_forward.conf
|
|
|
cat /etc/ssrplus/deny.list | sed '/^$/d' | sed '/#/d' | sed "/.*/s/.*/address=\/&\//" >$TMP_DNSMASQ_PATH/denylist.conf
|
|
|
@@ -45,3 +56,4 @@ if [ "$(uci_get_by_type global adblock 0)" == "1" ]; then
|
|
|
else
|
|
|
rm -f $TMP_DNSMASQ_PATH/ad.conf
|
|
|
fi
|
|
|
+
|