mirror of
https://github.com/routerich/RouterichAX3000_configs.git
synced 2026-01-29 13:40:32 +03:00
Check installed packeds and check podkop and configured
This commit is contained in:
232
awg_config.sh
232
awg_config.sh
@@ -1,5 +1,139 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
|
install_awg_packages() {
|
||||||
|
# Получение pkgarch с наибольшим приоритетом
|
||||||
|
PKGARCH=$(opkg print-architecture | awk 'BEGIN {max=0} {if ($3 > max) {max = $3; arch = $2}} END {print arch}')
|
||||||
|
|
||||||
|
TARGET=$(ubus call system board | jsonfilter -e '@.release.target' | cut -d '/' -f 1)
|
||||||
|
SUBTARGET=$(ubus call system board | jsonfilter -e '@.release.target' | cut -d '/' -f 2)
|
||||||
|
VERSION=$(ubus call system board | jsonfilter -e '@.release.version')
|
||||||
|
PKGPOSTFIX="_v${VERSION}_${PKGARCH}_${TARGET}_${SUBTARGET}.ipk"
|
||||||
|
BASE_URL="https://github.com/Slava-Shchipunov/awg-openwrt/releases/download/"
|
||||||
|
|
||||||
|
AWG_DIR="/tmp/amneziawg"
|
||||||
|
mkdir -p "$AWG_DIR"
|
||||||
|
|
||||||
|
if opkg list-installed | grep -q kmod-amneziawg; then
|
||||||
|
echo "kmod-amneziawg already installed"
|
||||||
|
else
|
||||||
|
KMOD_AMNEZIAWG_FILENAME="kmod-amneziawg${PKGPOSTFIX}"
|
||||||
|
DOWNLOAD_URL="${BASE_URL}v${VERSION}/${KMOD_AMNEZIAWG_FILENAME}"
|
||||||
|
wget -O "$AWG_DIR/$KMOD_AMNEZIAWG_FILENAME" "$DOWNLOAD_URL"
|
||||||
|
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
echo "kmod-amneziawg file downloaded successfully"
|
||||||
|
else
|
||||||
|
echo "Error downloading kmod-amneziawg. Please, install kmod-amneziawg manually and run the script again"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
opkg install "$AWG_DIR/$KMOD_AMNEZIAWG_FILENAME"
|
||||||
|
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
echo "kmod-amneziawg file downloaded successfully"
|
||||||
|
else
|
||||||
|
echo "Error installing kmod-amneziawg. Please, install kmod-amneziawg manually and run the script again"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if opkg list-installed | grep -q amneziawg-tools; then
|
||||||
|
echo "amneziawg-tools already installed"
|
||||||
|
else
|
||||||
|
AMNEZIAWG_TOOLS_FILENAME="amneziawg-tools${PKGPOSTFIX}"
|
||||||
|
DOWNLOAD_URL="${BASE_URL}v${VERSION}/${AMNEZIAWG_TOOLS_FILENAME}"
|
||||||
|
wget -O "$AWG_DIR/$AMNEZIAWG_TOOLS_FILENAME" "$DOWNLOAD_URL"
|
||||||
|
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
echo "amneziawg-tools file downloaded successfully"
|
||||||
|
else
|
||||||
|
echo "Error downloading amneziawg-tools. Please, install amneziawg-tools manually and run the script again"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
opkg install "$AWG_DIR/$AMNEZIAWG_TOOLS_FILENAME"
|
||||||
|
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
echo "amneziawg-tools file downloaded successfully"
|
||||||
|
else
|
||||||
|
echo "Error installing amneziawg-tools. Please, install amneziawg-tools manually and run the script again"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if opkg list-installed | grep -q luci-app-amneziawg; then
|
||||||
|
echo "luci-app-amneziawg already installed"
|
||||||
|
else
|
||||||
|
LUCI_APP_AMNEZIAWG_FILENAME="luci-app-amneziawg${PKGPOSTFIX}"
|
||||||
|
DOWNLOAD_URL="${BASE_URL}v${VERSION}/${LUCI_APP_AMNEZIAWG_FILENAME}"
|
||||||
|
wget -O "$AWG_DIR/$LUCI_APP_AMNEZIAWG_FILENAME" "$DOWNLOAD_URL"
|
||||||
|
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
echo "luci-app-amneziawg file downloaded successfully"
|
||||||
|
else
|
||||||
|
echo "Error downloading luci-app-amneziawg. Please, install luci-app-amneziawg manually and run the script again"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
opkg install "$AWG_DIR/$LUCI_APP_AMNEZIAWG_FILENAME"
|
||||||
|
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
echo "luci-app-amneziawg file downloaded successfully"
|
||||||
|
else
|
||||||
|
echo "Error installing luci-app-amneziawg. Please, install luci-app-amneziawg manually and run the script again"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
rm -rf "$AWG_DIR"
|
||||||
|
}
|
||||||
|
|
||||||
|
echo "opkg update"
|
||||||
|
opkg update
|
||||||
|
|
||||||
|
#проверка и установка пакетов AmneziaWG
|
||||||
|
install_awg_packages
|
||||||
|
|
||||||
|
#проверяем установлени ли библиотека jq
|
||||||
|
if opkg list-installed | grep -q jq; then
|
||||||
|
echo "jq already installed..."
|
||||||
|
else
|
||||||
|
echo "jq not installed. Installed jq..."
|
||||||
|
opkg install jq
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
echo "jq file downloaded successfully"
|
||||||
|
else
|
||||||
|
echo "Error installing jq. Please, install jq manually and run the script again"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
#проверяем установлени ли пакет dnsmasq-full
|
||||||
|
if opkg list-installed | grep -q dnsmasq-full; then
|
||||||
|
echo "dnsmasq-full already installed..."
|
||||||
|
else
|
||||||
|
echo "Installed dnsmasq-full..."
|
||||||
|
cd /tmp/ && opkg download dnsmasq-full
|
||||||
|
opkg remove dnsmasq && opkg install dnsmasq-full --cache /tmp/
|
||||||
|
|
||||||
|
[ -f /etc/config/dhcp-opkg ] && cp /etc/config/dhcp /etc/config/dhcp-old && mv /etc/config/dhcp-opkg /etc/config/dhcp
|
||||||
|
fi
|
||||||
|
|
||||||
|
#проверяем установлени ли пакет coreutils-base64
|
||||||
|
if opkg list-installed | grep -q coreutils-base64; then
|
||||||
|
echo "coreutils-base64 already installed..."
|
||||||
|
else
|
||||||
|
echo "Installed coreutils-base64"
|
||||||
|
opkg install coreutils-base64
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
echo "coreutils-base64 file downloaded successfully"
|
||||||
|
else
|
||||||
|
echo "Error installing coreutils-base64. Please, install coreutils-base64 manually and run the script again"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
#запрос конфигурации WARP
|
#запрос конфигурации WARP
|
||||||
result=$(curl 'https://warp.llimonix.pw/api/warp' \
|
result=$(curl 'https://warp.llimonix.pw/api/warp' \
|
||||||
-H 'Accept: */*' \
|
-H 'Accept: */*' \
|
||||||
@@ -17,34 +151,6 @@ result=$(curl 'https://warp.llimonix.pw/api/warp' \
|
|||||||
-H 'sec-ch-ua-platform: "Windows"' \
|
-H 'sec-ch-ua-platform: "Windows"' \
|
||||||
--data-raw '{"selectedServices":[],"siteMode":"all","deviceType":"computer"}')
|
--data-raw '{"selectedServices":[],"siteMode":"all","deviceType":"computer"}')
|
||||||
|
|
||||||
echo "opkg update"
|
|
||||||
opkg update
|
|
||||||
|
|
||||||
#проверяем установлени ли библиотека jq
|
|
||||||
test_json=$(echo "{ }" | jq)
|
|
||||||
if [ "$test_json" != "{}" ]; then
|
|
||||||
echo "jq not installed"
|
|
||||||
opkg install jq
|
|
||||||
fi
|
|
||||||
|
|
||||||
#проверяем установлени ли пакет dnsmasq-full
|
|
||||||
if opkg list-installed | grep -q dnsmasq-full; then
|
|
||||||
echo "dnsmasq-full already installed"
|
|
||||||
else
|
|
||||||
echo "Installed dnsmasq-full"
|
|
||||||
cd /tmp/ && opkg download dnsmasq-full
|
|
||||||
opkg remove dnsmasq && opkg install dnsmasq-full --cache /tmp/
|
|
||||||
|
|
||||||
[ -f /etc/config/dhcp-opkg ] && cp /etc/config/dhcp /etc/config/dhcp-old && mv /etc/config/dhcp-opkg /etc/config/dhcp
|
|
||||||
fi
|
|
||||||
|
|
||||||
#проверяем установлени ли пакет coreutils-base64
|
|
||||||
if opkg list-installed | grep -q coreutils-base64; then
|
|
||||||
echo "coreutils-base64 already installed"
|
|
||||||
else
|
|
||||||
echo "Installed coreutils-base64"
|
|
||||||
opkg install coreutils-base64
|
|
||||||
fi
|
|
||||||
|
|
||||||
#парсим результат запроса конфигурации WARP
|
#парсим результат запроса конфигурации WARP
|
||||||
content=$(echo $result | jq '.content')
|
content=$(echo $result | jq '.content')
|
||||||
@@ -132,37 +238,53 @@ if ! uci show firewall | grep -q "@forwarding.*name='${ZONE_NAME}'"; then
|
|||||||
uci commit firewall
|
uci commit firewall
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ -f "/etc/init.d/podkop" ]; then
|
||||||
|
path_podkop_config="/etc/config/podkop"
|
||||||
|
path_podkop_config_backup="/root/podkop"
|
||||||
|
URL="https://raw.githubusercontent.com/CodeRoK7/RouterichAX3000_configs/refs/heads/main"
|
||||||
|
printf "Podkop installed. Reconfigured on AWG WARP? (y/n): \n"
|
||||||
|
read is_reconfig_podkop
|
||||||
|
if [ "$is_reconfig_podkop" = "y" ] || [ "$is_reconfig_podkop" = "Y" ]; then
|
||||||
|
cp -f "$path_podkop_config" "$path_podkop_config_backup"
|
||||||
|
wget -O "$path_podkop_config" "$URL/podkop"
|
||||||
|
echo "Backup of your config in path '$path_podkop_config_backup'"
|
||||||
|
echo "Podkop reconfigured..."
|
||||||
|
echo "Service Podkop restart..."
|
||||||
|
service podkop restart
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
printf "\033[32;1mInstall and configure PODKOP (a tool for point routing of traffic)?? (y/n): \033[0m\n"
|
||||||
|
read is_install_podkop
|
||||||
|
|
||||||
printf "\033[32;1mInstall and configure PODKOP (a tool for point routing of traffic)?? (y/n): \033[0m\n"
|
if [ "$is_install_podkop" = "y" ] || [ "$is_install_podkop" = "Y" ]; then
|
||||||
read is_install_podkop
|
DOWNLOAD_DIR="/tmp/podkop"
|
||||||
|
mkdir -p "$DOWNLOAD_DIR"
|
||||||
|
REPO="https://api.github.com/repos/itdoginfo/podkop/releases/tags/v0.2.5"
|
||||||
|
wget -qO- "$REPO" | grep -o 'https://[^"]*\.ipk' | while read -r url; do
|
||||||
|
filename=$(basename "$url")
|
||||||
|
echo "Download $filename..."
|
||||||
|
wget -q -O "$DOWNLOAD_DIR/$filename" "$url"
|
||||||
|
done
|
||||||
|
opkg install $DOWNLOAD_DIR/podkop*.ipk
|
||||||
|
opkg install $DOWNLOAD_DIR/luci-app-podkop*.ipk
|
||||||
|
opkg install $DOWNLOAD_DIR/luci-i18n-podkop-ru*.ipk
|
||||||
|
rm -f $DOWNLOAD_DIR/podkop*.ipk $DOWNLOAD_DIR/luci-app-podkop*.ipk $DOWNLOAD_DIR/luci-i18n-podkop-ru*.ipk
|
||||||
|
|
||||||
if [ "$is_install_podkop" = "y" ] || [ "$is_install_podkop" = "Y" ]; then
|
uci set podkop.main.mode='vpn'
|
||||||
DOWNLOAD_DIR="/tmp/podkop"
|
uci set podkop.main.interface="$INTERFACE_NAME"
|
||||||
mkdir -p "$DOWNLOAD_DIR"
|
uci set podkop.main.domain_list_enabled='1'
|
||||||
REPO="https://api.github.com/repos/itdoginfo/podkop/releases/tags/v0.2.5"
|
uci set podkop.main.domain_list='ru_inside'
|
||||||
wget -qO- "$REPO" | grep -o 'https://[^"]*\.ipk' | while read -r url; do
|
uci set podkop.main.delist_domains_enabled='0'
|
||||||
filename=$(basename "$url")
|
uci add_list podkop.main.subnets='meta'
|
||||||
echo "Download $filename..."
|
uci add_list podkop.main.subnets='twitter'
|
||||||
wget -q -O "$DOWNLOAD_DIR/$filename" "$url"
|
uci add_list podkop.main.subnets='discord'
|
||||||
done
|
uci commit podkop
|
||||||
opkg install $DOWNLOAD_DIR/podkop*.ipk
|
echo "Service Podkop restart..."
|
||||||
opkg install $DOWNLOAD_DIR/luci-app-podkop*.ipk
|
service podkop restart
|
||||||
opkg install $DOWNLOAD_DIR/luci-i18n-podkop-ru*.ipk
|
fi
|
||||||
rm -f $DOWNLOAD_DIR/podkop*.ipk $DOWNLOAD_DIR/luci-app-podkop*.ipk $DOWNLOAD_DIR/luci-i18n-podkop-ru*.ipk
|
|
||||||
|
|
||||||
uci set podkop.main.mode='vpn'
|
|
||||||
uci set podkop.main.interface="$INTERFACE_NAME"
|
|
||||||
uci set podkop.main.domain_list_enabled='1'
|
|
||||||
uci set podkop.main.domain_list='ru_inside'
|
|
||||||
uci set podkop.main.delist_domains_enabled='0'
|
|
||||||
uci add_list podkop.main.subnets='meta'
|
|
||||||
uci add_list podkop.main.subnets='twitter'
|
|
||||||
uci add_list podkop.main.subnets='discord'
|
|
||||||
uci commit podkop
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
printf "\033[32;1mStop and disabled service 'youtubeUnblock'...\033[0m"
|
||||||
printf "\033[32;1mStop and disabled service 'youtubeUnblock'...\033[0m\n"
|
|
||||||
service youtubeUnblock stop
|
service youtubeUnblock stop
|
||||||
service youtubeUnblock disable
|
service youtubeUnblock disable
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user