You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
62 lines
2.6 KiB
62 lines
2.6 KiB
#!/usr/bin/env bash
|
|
#
|
|
# Author: Dmitry Razumov <asmeron@ublinux.com>
|
|
# Copyright (c) 2021-2025 UBLinux <support@ublinux.com>
|
|
#
|
|
# Initial script for Linux UBLinux
|
|
# This script are launching before starting init from initrd script
|
|
# Current dir allways must be set to root (/)
|
|
# All system path must be relative, except initrd dirs
|
|
|
|
ENABLED=yes
|
|
[[ ${ENABLED} == "yes" ]] || exit 0
|
|
DEBUGMODE=no
|
|
|
|
PATH=.:/:/usr/bin:/usr/local/bin:/usr/local/sbin
|
|
|
|
[[ -d /usr/lib/ublinux ]] && { ROOTFS= ; CMD_CHROOT= ; } || { [[ -d /sysroot ]] && ROOTFS="/sysroot" || ROOTFS="."; CMD_CHROOT="chroot ${ROOTFS}"; }
|
|
SOURCE=${ROOTFS}/usr/lib/ublinux/functions; [[ -f ${SOURCE} ]] && . ${SOURCE} 2>/dev/null || exit 0
|
|
SOURCE=${ROOTFS}/usr/lib/ublinux/default; [[ -f ${SOURCE} ]] && . ${SOURCE} 2>/dev/null || exit 0
|
|
debug_mode "$0" "$@"
|
|
|
|
SYSCONF="${ROOTFS}${SYSCONF}"
|
|
SOURCE=${SYSCONF}/config; [[ -f ${SOURCE} ]] && . ${SOURCE} 2>/dev/null
|
|
SOURCE=${SYSCONF}/system; [[ -f ${SOURCE} ]] && . ${SOURCE} 2>/dev/null
|
|
SOURCE=${SYSCONF}/network; [[ -f ${SOURCE} ]] && . ${SOURCE} 2>/dev/null
|
|
|
|
## Установка системных прокси для HTTP,HTTPS,FTP,SOCKS,RSYNC и адреса исключений EXCLUDE
|
|
## Для применения требуется перелогиниться
|
|
## PROXY_SYSTEM[%PROTOCOL%]=%SERVER%
|
|
|
|
## Проверить текущий IP: curl icanhazip.com | curl https://httpbin.org/ip
|
|
|
|
exec_proxy_system(){
|
|
FILE_SH_PROXY=${ROOTFS}/etc/profile.d/proxy_ubconfig.sh
|
|
FILE_CSH_PROXY=${ROOTFS}/etc/profile.d/proxy_ubconfig.csh
|
|
if [[ -z ${PROXY_SYSTEM[@]} || ${PROXY_SYSTEM[0],,} == @(n|no|none|disable) ]]; then
|
|
rm -f ${FILE_SH_PROXY} 2>/dev/null
|
|
rm -f ${FILE_CSH_PROXY} 2>/dev/null
|
|
elif [[ -n ${PROXY_SYSTEM[@]} ]]; then
|
|
true > ${FILE_SH_PROXY}
|
|
true > ${FILE_CSH_PROXY}
|
|
chmod 644 ${FILE_SH_PROXY} ${FILE_CSH_PROXY}
|
|
for PROTOCOL in http https ftp socks rsync all exclude; do
|
|
if [[ ${PROXY_SYSTEM[${PROTOCOL}],,} == @(n|no|none|disable) ]]; then
|
|
[[ ${PROTOCOL,,} == "exclude" ]] && PROTOCOL_PREFIX="no" || PROTOCOL_PREFIX="${PROTOCOL,,}"
|
|
sed "/^${PROTOCOL_PREFIX}_proxy=/d; /^export ${PROTOCOL_PREFIX}_proxy/d" -i ${FILE_SH_PROXY}
|
|
sed "/^setenv ${PROTOCOL_PREFIX}_proxy/d" -i ${FILE_CSH_PROXY}
|
|
elif [[ -n ${PROXY_SYSTEM[${PROTOCOL}]} ]]; then
|
|
[[ ${PROTOCOL,,} == "exclude" ]] && PROTOCOL_PREFIX="no" || PROTOCOL_PREFIX="${PROTOCOL,,}"
|
|
echo -e "${PROTOCOL_PREFIX}_proxy=${PROXY_SYSTEM[${PROTOCOL}]}\nexport ${PROTOCOL_PREFIX}_proxy" >> ${FILE_SH_PROXY}
|
|
echo "setenv ${PROTOCOL_PREFIX}_proxy ${PROXY_SYSTEM[${PROTOCOL}]}" >> ${FILE_CSH_PROXY}
|
|
fi
|
|
done
|
|
fi
|
|
}
|
|
|
|
################
|
|
##### MAIN #####
|
|
################
|
|
|
|
exec_proxy_system $@
|