Compare commits
8 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
f960358eb6 | ||
|
|
ba44966c02 | ||
|
|
615241aa37 | ||
|
|
9a3220d226 | ||
|
|
ec8d28857e | ||
|
|
26b49f5bbb | ||
|
|
0a7efb3169 | ||
|
|
468e51ee8e |
17
README.md
17
README.md
@@ -80,9 +80,15 @@ Luci: Services/podkop
|
|||||||
# ToDo
|
# ToDo
|
||||||
Этот раздел не означает задачи, которые нужно брать и делать. Это общий список хотелок. Если вы хотите помочь, пожалуйста, спросите сначала в телеграмме.
|
Этот раздел не означает задачи, которые нужно брать и делать. Это общий список хотелок. Если вы хотите помочь, пожалуйста, спросите сначала в телеграмме.
|
||||||
|
|
||||||
|
- [ ] Interface trigger
|
||||||
|
- [ ] Управление sing-box с помощью podkop. sing-box disable
|
||||||
- [ ] Сделать галку запрещающую подкопу редачить dhcp. Допилить в исключение вместе с пустыми полями proxy и vpn (нужно wiki)
|
- [ ] Сделать галку запрещающую подкопу редачить dhcp. Допилить в исключение вместе с пустыми полями proxy и vpn (нужно wiki)
|
||||||
- [ ] Рестарт сервиса без рестарта dnsmasq
|
- [ ] Рестарт сервиса без рестарта dnsmasq
|
||||||
- [ ] `ash: can't kill pid 9848: No such process` при обновлении
|
- [ ] `ash: can't kill pid 9848: No such process` при обновлении
|
||||||
|
- [ ] Luci: Добавить валидацию "Proxy Configuration URL". Если пустое, то ошибка. Как с интерфейсом.
|
||||||
|
- [ ] После выключения и включения может быть: `Dnsmasq save config error: server=127.0.0.42`
|
||||||
|
- [ ] Не грузится диагностика полностью при одной нерабочей комманде. Подумать как это можно дебажить легко. https://t.me/itdogchat/142500/378956
|
||||||
|
- [ ] DoH возможность добавлять сервера c path. Взять пример из NextDNS
|
||||||
|
|
||||||
Низкий приоритет
|
Низкий приоритет
|
||||||
- [ ] Галочка, которая режет доступ к doh серверам
|
- [ ] Галочка, которая режет доступ к doh серверам
|
||||||
@@ -94,6 +100,17 @@ Luci: Services/podkop
|
|||||||
- [ ] Unit тесты (BATS)
|
- [ ] Unit тесты (BATS)
|
||||||
- [ ] Интеграционые тесты бекенда (OpenWrt rootfs + BATS)
|
- [ ] Интеграционые тесты бекенда (OpenWrt rootfs + BATS)
|
||||||
|
|
||||||
|
# Don't touch my dhcp
|
||||||
|
Нужно в первую очередь, чтоб использовать опцию `server`.
|
||||||
|
|
||||||
|
В случае если опция активна, podkop не трогает /etc/config/dhcp. И вам требуется самостоятельно указать следующие значения:
|
||||||
|
```
|
||||||
|
option noresolv '1'
|
||||||
|
option cachesize '0'
|
||||||
|
list server '127.0.0.42'
|
||||||
|
```
|
||||||
|
Без этого podkop работать не будет.
|
||||||
|
|
||||||
# Разработка
|
# Разработка
|
||||||
Есть два варианта:
|
Есть два варианта:
|
||||||
- Просто поставить пакет на роутер или виртуалку и прям редактировать через SFTP (opkg install openssh-sftp-server)
|
- Просто поставить пакет на роутер или виртуалку и прям редактировать через SFTP (opkg install openssh-sftp-server)
|
||||||
|
|||||||
@@ -160,13 +160,13 @@ add_tunnel() {
|
|||||||
;;
|
;;
|
||||||
|
|
||||||
3)
|
3)
|
||||||
opkg install opkg install openvpn-openssl luci-app-openvpn
|
opkg install openvpn-openssl luci-app-openvpn
|
||||||
printf "\e[1;32mUse these instructions to configure https://itdog.info/nastrojka-klienta-openvpn-na-openwrt/\e[0m\n"
|
printf "\e[1;32mUse these instructions to configure https://itdog.info/nastrojka-klienta-openvpn-na-openwrt/\e[0m\n"
|
||||||
break
|
break
|
||||||
;;
|
;;
|
||||||
|
|
||||||
4)
|
4)
|
||||||
opkg install opkg install openconnect luci-proto-openconnect
|
opkg install openconnect luci-proto-openconnect
|
||||||
printf "\e[1;32mUse these instructions to configure https://itdog.info/nastrojka-klienta-openconnect-na-openwrt/\e[0m\n"
|
printf "\e[1;32mUse these instructions to configure https://itdog.info/nastrojka-klienta-openconnect-na-openwrt/\e[0m\n"
|
||||||
break
|
break
|
||||||
;;
|
;;
|
||||||
@@ -248,8 +248,8 @@ install_awg_packages() {
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if opkg list-installed | grep -q luci-app-amneziawg; then
|
if opkg list-installed | grep -qE 'luci-app-amneziawg|luci-proto-amneziawg'; then
|
||||||
echo "luci-app-amneziawg already installed"
|
echo "luci-app-amneziawg or luci-proto-amneziawg already installed"
|
||||||
else
|
else
|
||||||
LUCI_APP_AMNEZIAWG_FILENAME="luci-app-amneziawg${PKGPOSTFIX}"
|
LUCI_APP_AMNEZIAWG_FILENAME="luci-app-amneziawg${PKGPOSTFIX}"
|
||||||
DOWNLOAD_URL="${BASE_URL}v${VERSION}/${LUCI_APP_AMNEZIAWG_FILENAME}"
|
DOWNLOAD_URL="${BASE_URL}v${VERSION}/${LUCI_APP_AMNEZIAWG_FILENAME}"
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
include $(TOPDIR)/rules.mk
|
include $(TOPDIR)/rules.mk
|
||||||
|
|
||||||
PKG_NAME:=luci-app-podkop
|
PKG_NAME:=luci-app-podkop
|
||||||
PKG_VERSION:=0.3.34
|
PKG_VERSION:=0.3.36
|
||||||
PKG_RELEASE:=1
|
PKG_RELEASE:=1
|
||||||
|
|
||||||
LUCI_TITLE:=LuCI podkop app
|
LUCI_TITLE:=LuCI podkop app
|
||||||
|
|||||||
@@ -62,6 +62,23 @@ function getNetworkInterfaces(o, section_id, excludeInterfaces = []) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function getNetworkNetworks(o, section_id, excludeInterfaces = []) {
|
||||||
|
return network.getNetworks().then(networks => {
|
||||||
|
o.keylist = [];
|
||||||
|
o.vallist = [];
|
||||||
|
|
||||||
|
networks.forEach(net => {
|
||||||
|
const name = net.getName();
|
||||||
|
const ifname = net.getIfname();
|
||||||
|
if (name && !excludeInterfaces.includes(name)) {
|
||||||
|
o.value(name, ifname ? `${name} (${ifname})` : name);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}).catch(error => {
|
||||||
|
console.error('Failed to get networks:', error);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
function createConfigSection(section, map, network) {
|
function createConfigSection(section, map, network) {
|
||||||
const s = section;
|
const s = section;
|
||||||
|
|
||||||
@@ -1087,6 +1104,20 @@ return view.extend({
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
o = mainSection.taboption('additional', form.MultiValue, 'restart_ifaces', _('Interface for monitoring'), _('Select the WAN interfaces to be monitored'));
|
||||||
|
o.ucisection = 'main';
|
||||||
|
o.default = 'wan';
|
||||||
|
o.load = function (section_id) {
|
||||||
|
return getNetworkNetworks(this, section_id, ['lan', 'loopback']).then(() => {
|
||||||
|
return this.super('load', section_id);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
o = mainSection.taboption('additional', form.Flag, 'dont_touch_dhcp', _('Dont touch my DHCP!'), _('Podkop will not change the DHCP config'));
|
||||||
|
o.default = '0';
|
||||||
|
o.rmempty = false;
|
||||||
|
o.ucisection = 'main';
|
||||||
|
|
||||||
// Extra IPs and exclusions (main section)
|
// Extra IPs and exclusions (main section)
|
||||||
o = mainSection.taboption('basic', form.Flag, 'exclude_from_ip_enabled', _('IP for exclusion'), _('Specify local IP addresses that will never use the configured route'));
|
o = mainSection.taboption('basic', form.Flag, 'exclude_from_ip_enabled', _('IP for exclusion'), _('Specify local IP addresses that will never use the configured route'));
|
||||||
o.default = '0';
|
o.default = '0';
|
||||||
|
|||||||
@@ -88,8 +88,8 @@ msgstr "Введите имена доменов без протоколов (п
|
|||||||
msgid "User Domains List"
|
msgid "User Domains List"
|
||||||
msgstr "Список пользовательских доменов"
|
msgstr "Список пользовательских доменов"
|
||||||
|
|
||||||
msgid "Enter domain names separated by comma, space or newline (example: sub.example.com, example.com or one domain per line)"
|
msgid "Enter domain names separated by comma, space or newline. You can add comments after //"
|
||||||
msgstr "Введите имена доменов через запятую, пробел или новую строку (пример: sub.example.com, example.com или один домен на строку)"
|
msgstr "Введите имена доменов, разделяя их запятой, пробелом или с новой строки. Вы можете добавлять комментарии после //"
|
||||||
|
|
||||||
msgid "Local Domain Lists"
|
msgid "Local Domain Lists"
|
||||||
msgstr "Локальные списки доменов"
|
msgstr "Локальные списки доменов"
|
||||||
@@ -556,6 +556,9 @@ msgstr "Путь должен содержать хотя бы одну дире
|
|||||||
msgid "Invalid path format. Must be like /tmp/cache.db"
|
msgid "Invalid path format. Must be like /tmp/cache.db"
|
||||||
msgstr "Неверный формат пути. Пример: /tmp/cache.db"
|
msgstr "Неверный формат пути. Пример: /tmp/cache.db"
|
||||||
|
|
||||||
|
msgid "Select the network interface from which the traffic will originate"
|
||||||
|
msgstr "Выберите сетевой интерфейс, с которого будет исходить трафик"
|
||||||
|
|
||||||
msgid "Copy to Clipboard"
|
msgid "Copy to Clipboard"
|
||||||
msgstr "Копировать в буфер обмена"
|
msgstr "Копировать в буфер обмена"
|
||||||
|
|
||||||
@@ -812,4 +815,7 @@ msgid "available"
|
|||||||
msgstr "доступен"
|
msgstr "доступен"
|
||||||
|
|
||||||
msgid "unavailable"
|
msgid "unavailable"
|
||||||
msgstr "недоступен"
|
msgstr "недоступен"
|
||||||
|
|
||||||
|
msgid "Apply for SS2022"
|
||||||
|
msgstr "Применить для SS2022"
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
include $(TOPDIR)/rules.mk
|
include $(TOPDIR)/rules.mk
|
||||||
|
|
||||||
PKG_NAME:=podkop
|
PKG_NAME:=podkop
|
||||||
PKG_VERSION:=0.3.34
|
PKG_VERSION:=0.3.36
|
||||||
PKG_RELEASE:=1
|
PKG_RELEASE:=1
|
||||||
|
|
||||||
PKG_MAINTAINER:=ITDog <podkop@itdog.info>
|
PKG_MAINTAINER:=ITDog <podkop@itdog.info>
|
||||||
|
|||||||
@@ -36,4 +36,5 @@ config main 'main'
|
|||||||
option dns_rewrite_ttl '60'
|
option dns_rewrite_ttl '60'
|
||||||
option cache_file '/tmp/cache.db'
|
option cache_file '/tmp/cache.db'
|
||||||
list iface 'br-lan'
|
list iface 'br-lan'
|
||||||
|
list restart_ifaces 'wan'
|
||||||
option ss_uot '0'
|
option ss_uot '0'
|
||||||
@@ -6,38 +6,15 @@ USE_PROCD=1
|
|||||||
script=$(readlink "$initscript")
|
script=$(readlink "$initscript")
|
||||||
NAME="$(basename ${script:-$initscript})"
|
NAME="$(basename ${script:-$initscript})"
|
||||||
config_load "$NAME"
|
config_load "$NAME"
|
||||||
resolv_conf="/etc/resolv.conf"
|
|
||||||
|
|
||||||
start_service() {
|
start_service() {
|
||||||
echo "Start podkop"
|
echo "Start podkop"
|
||||||
|
|
||||||
sing_box_version=$(sing-box version | head -n 1 | awk '{print $3}')
|
config_get restart_ifaces "main" "restart_ifaces"
|
||||||
required_version="1.11.1"
|
|
||||||
resolv_conf="/etc/resolv.conf"
|
|
||||||
|
|
||||||
if [ "$(echo -e "$sing_box_version\n$required_version" | sort -V | head -n 1)" != "$required_version" ]; then
|
|
||||||
echo "The version of sing-box ($sing_box_version) is lower than the minimum version. Update sing-box: opkg update && opkg remove sing-box && opkg install sing-box"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if opkg list-installed | grep -q iptables-mod-extra; then
|
|
||||||
echo "Conflicting package detected: iptables-mod-extra"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if opkg list-installed | grep -q kmod-ipt-nat; then
|
|
||||||
echo "Conflicting package detected: kmod-ipt-nat"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if grep -qE 'doh_backup_noresolv|doh_backup_server|doh_server' /etc/config/dhcp; then
|
|
||||||
printf "\033[31;1mDetected https-dns-proxy. Disable or uninstall it for correct functionality.\033[0m\n"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! grep -q "search lan" "$resolv_conf" || ! grep -q "nameserver 127.0.0.1" "$resolv_conf" || ! grep -q "search tail" "$resolv_conf"; then
|
|
||||||
echo "/etc/resolv.conf does not contain 'search lan' or 'nameserver 127.0.0.1' entries"
|
|
||||||
fi
|
|
||||||
|
|
||||||
procd_open_instance
|
procd_open_instance
|
||||||
procd_set_param command /bin/sh -c "/usr/bin/podkop start"
|
procd_set_param command /usr/bin/podkop start
|
||||||
|
[ -z "$restart_ifaces" ] || procd_set_param netdev $restart_ifaces
|
||||||
procd_set_param stdout 1
|
procd_set_param stdout 1
|
||||||
procd_set_param stderr 1
|
procd_set_param stderr 1
|
||||||
procd_close_instance
|
procd_close_instance
|
||||||
@@ -47,17 +24,19 @@ stop_service() {
|
|||||||
/usr/bin/podkop stop
|
/usr/bin/podkop stop
|
||||||
}
|
}
|
||||||
|
|
||||||
restart_service() {
|
|
||||||
stop
|
|
||||||
start
|
|
||||||
}
|
|
||||||
|
|
||||||
reload_service() {
|
reload_service() {
|
||||||
stop
|
/usr/bin/podkop reload > /dev/null 2>&1
|
||||||
start
|
|
||||||
}
|
}
|
||||||
|
|
||||||
service_triggers() {
|
service_triggers() {
|
||||||
echo "service_triggers start"
|
echo "service_triggers start"
|
||||||
procd_add_config_trigger "config.change" "$NAME" "$initscript" reload 'on_config_change'
|
|
||||||
|
config_get restart_ifaces "main" "restart_ifaces"
|
||||||
|
procd_open_trigger
|
||||||
|
procd_add_config_trigger "config.change" "$NAME" "$initscript" reload 'on_config_change'
|
||||||
|
|
||||||
|
for iface in $restart_ifaces; do
|
||||||
|
procd_add_reload_interface_trigger $iface
|
||||||
|
done
|
||||||
|
procd_close_trigger
|
||||||
}
|
}
|
||||||
@@ -22,6 +22,7 @@ DNS_RESOLVERS="1.1.1.1 1.0.0.1 8.8.8.8 8.8.4.4 9.9.9.9 9.9.9.11 94.140.14.14 94.
|
|||||||
TEST_DOMAIN="fakeip.tech-domain.club"
|
TEST_DOMAIN="fakeip.tech-domain.club"
|
||||||
INTERFACES_LIST=""
|
INTERFACES_LIST=""
|
||||||
SRC_INTERFACE=""
|
SRC_INTERFACE=""
|
||||||
|
RESOLV_CONF="/etc/resolv.conf"
|
||||||
|
|
||||||
log() {
|
log() {
|
||||||
local message="$1"
|
local message="$1"
|
||||||
@@ -44,7 +45,7 @@ nolog() {
|
|||||||
echo -e "${CYAN}[$timestamp]${RESET} ${GREEN}$message${RESET}"
|
echo -e "${CYAN}[$timestamp]${RESET} ${GREEN}$message${RESET}"
|
||||||
}
|
}
|
||||||
|
|
||||||
start() {
|
start_main() {
|
||||||
log "Starting podkop"
|
log "Starting podkop"
|
||||||
|
|
||||||
# checking
|
# checking
|
||||||
@@ -60,16 +61,12 @@ start() {
|
|||||||
log "[critical] Conflicting package detected: iptables-mod-extra"
|
log "[critical] Conflicting package detected: iptables-mod-extra"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if opkg list-installed | grep -q kmod-ipt-nat; then
|
|
||||||
log "[critical] Conflicting package detected: kmod-ipt-nat"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if grep -qE 'doh_backup_noresolv|doh_backup_server|doh_server' /etc/config/dhcp; then
|
if grep -qE 'doh_backup_noresolv|doh_backup_server|doh_server' /etc/config/dhcp; then
|
||||||
log "[critical] Detected https-dns-proxy. Disable or uninstall it for correct functionality."
|
log "[critical] Detected https-dns-proxy. Disable or uninstall it for correct functionality."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if ! grep -q "search lan" "$resolv_conf" || ! grep -q "nameserver 127.0.0.1" "$resolv_conf" || ! grep -q "search tail" "$resolv_conf"; then
|
if grep -E "^nameserver\s+([0-9]{1,3}\.){3}[0-9]{1,3}" "$RESOLV_CONF" | grep -vqE "127\.0\.0\.1|0\.0\.0\.0"; then
|
||||||
log "[critical] /etc/resolv.conf does not contain 'search lan' or 'nameserver 127.0.0.1' entries"
|
log "[critical] /etc/resolv.conf contains an external nameserver"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
migration
|
migration
|
||||||
@@ -139,7 +136,12 @@ start() {
|
|||||||
|
|
||||||
sing_box_config_check
|
sing_box_config_check
|
||||||
/etc/init.d/sing-box start
|
/etc/init.d/sing-box start
|
||||||
/etc/init.d/sing-box enable
|
#/etc/init.d/sing-box enable
|
||||||
|
log "Nice"
|
||||||
|
}
|
||||||
|
|
||||||
|
start() {
|
||||||
|
start_main
|
||||||
|
|
||||||
config_get proxy_string "main" "proxy_string"
|
config_get proxy_string "main" "proxy_string"
|
||||||
config_get interface "main" "interface"
|
config_get interface "main" "interface"
|
||||||
@@ -153,7 +155,7 @@ start() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
stop() {
|
stop_main() {
|
||||||
log "Stopping the podkop"
|
log "Stopping the podkop"
|
||||||
|
|
||||||
if [ -f /var/run/podkop_list_update.pid ]; then
|
if [ -f /var/run/podkop_list_update.pid ]; then
|
||||||
@@ -167,11 +169,6 @@ stop() {
|
|||||||
|
|
||||||
remove_cron_job
|
remove_cron_job
|
||||||
|
|
||||||
config_get_bool dont_touch_dhcp "main" "dont_touch_dhcp" "0"
|
|
||||||
if [ "$dont_touch_dhcp" -eq 0 ]; then
|
|
||||||
dnsmasq_restore
|
|
||||||
fi
|
|
||||||
|
|
||||||
rm -rf /tmp/podkop/*.lst
|
rm -rf /tmp/podkop/*.lst
|
||||||
|
|
||||||
log "Flush nft"
|
log "Flush nft"
|
||||||
@@ -191,8 +188,22 @@ stop() {
|
|||||||
|
|
||||||
log "Stop sing-box"
|
log "Stop sing-box"
|
||||||
/etc/init.d/sing-box stop
|
/etc/init.d/sing-box stop
|
||||||
/etc/init.d/sing-box disable
|
#/etc/init.d/sing-box disable
|
||||||
|
}
|
||||||
|
|
||||||
|
stop() {
|
||||||
|
config_get_bool dont_touch_dhcp "main" "dont_touch_dhcp" "0"
|
||||||
|
if [ "$dont_touch_dhcp" -eq 0 ]; then
|
||||||
|
dnsmasq_restore
|
||||||
|
fi
|
||||||
|
|
||||||
|
stop_main
|
||||||
|
}
|
||||||
|
|
||||||
|
reload() {
|
||||||
|
log "Podkop reload"
|
||||||
|
stop_main
|
||||||
|
start_main
|
||||||
}
|
}
|
||||||
|
|
||||||
# Migrations and validation funcs
|
# Migrations and validation funcs
|
||||||
@@ -595,10 +606,12 @@ sing_box_uci() {
|
|||||||
log "Change sing-box UCI config"
|
log "Change sing-box UCI config"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if grep -q '#\s*list ifaces' "$config"; then
|
[ -f /etc/rc.d/S99sing-box ] && log "Disable sing-box" && /etc/init.d/sing-box disable
|
||||||
sed -i '/ifaces/s/#//g' $config
|
|
||||||
log "Uncommented list ifaces"
|
# if grep -q '#\s*list ifaces' "$config"; then
|
||||||
fi
|
# sed -i '/ifaces/s/#//g' $config
|
||||||
|
# log "Uncommented list ifaces"
|
||||||
|
# fi
|
||||||
}
|
}
|
||||||
|
|
||||||
add_socks5_for_section() {
|
add_socks5_for_section() {
|
||||||
@@ -2159,9 +2172,8 @@ case "$1" in
|
|||||||
stop)
|
stop)
|
||||||
stop
|
stop
|
||||||
;;
|
;;
|
||||||
restart)
|
reload)
|
||||||
stop
|
reload
|
||||||
start
|
|
||||||
;;
|
;;
|
||||||
main)
|
main)
|
||||||
main
|
main
|
||||||
@@ -2221,7 +2233,7 @@ case "$1" in
|
|||||||
check_dns_available
|
check_dns_available
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
echo "Usage: $0 {start|stop|restart|reload|enable|disable|main|list_update|check_proxy|check_nft|check_github|check_logs|check_sing_box_connections|check_sing_box_logs|check_fakeip|check_dnsmasq|show_config|show_version|show_sing_box_config|show_luci_version|show_sing_box_version|show_system_info|get_status|get_sing_box_status|check_dns_available}"
|
echo "Usage: $0 {start|stop|reload|enable|disable|main|list_update|check_proxy|check_nft|check_github|check_logs|check_sing_box_connections|check_sing_box_logs|check_fakeip|check_dnsmasq|show_config|show_version|show_sing_box_config|show_luci_version|show_sing_box_version|show_system_info|get_status|get_sing_box_status|check_dns_available}"
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
Reference in New Issue
Block a user