| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289 |
- #!/bin/bash
- clear
- clear
- [[ "$(whoami)" != "root" ]] && {
- echo -e "\033[1;33m[\033[1;31m| NO HAS INICIADO CORRECTAMENTE EL SCRIPT, DEVES INICIAR COMO USUARIO ROOT |\033[1;33m] \033[1;37mDEVES EJECUTAR EL SIGUIENTE COMANDO \033[1;33msudo -i\033[0m"
- exit 0
- }
- declare -A cor=([0]="\033[1;37m" [1]="\033[1;34m" [2]="\033[1;31m" [3]="\033[1;33m" [4]="\033[1;32m")
- sudo sysctl -w net.ipv6.conf.all.disable_ipv6=1 >/dev/null 2>&1
- sudo sysctl -w net.ipv6.conf.default.disable_ipv6=1 >/dev/null 2>&1
- sudo sysctl -w net.ipv6.conf.lo.disable_ipv6=1 >/dev/null 2>&1
- _hora=$(printf '%(%D-%H:%M:%S)T')
- red=$(tput setaf 1)
- gren=$(tput setaf 2)
- yellow=$(tput setaf 3)
- SCPdir="/etc/VPS-MX" && [[ ! -d ${SCPdir} ]] && exit 1
- DIR="/etc/VPS-MX"
- SCPusr="${SCPdir}/controlador"
- SCPfrm="${SCPdir}/herramientas"
- SCPinst="${SCPdir}/protocolos"
- SCPidioma="${SCPdir}/idioma"
- _core=$(printf '%-1s' "$(grep -c cpu[0-9] /proc/stat)")
- _usop=$(top -bn1 | sed -rn '3s/[^0-9]* ([0-9\.]+) .*/\1/p;4s/.*, ([0-9]+) .*/\1/p' | tr '\n' ' ')
- ram1=$(free -h | grep -i mem | awk {'print $2'})
- ram2=$(free -h | grep -i mem | awk {'print $4'})
- ram3=$(free -h | grep -i mem | awk {'print $3'})
- _ram=$(printf ' %-9s' "$(free -h | grep -i mem | awk {'print $2'})")
- _usor=$(printf '%-8s' "$(free -m | awk 'NR==2{printf "%.2f%%", $3*100/$2 }')")
- if [[ -e /etc/bash.bashrc-bakup ]]; then
- AutoRun="\033[1;32m[ON]"
- elif [[ -e /etc/bash.bashrc ]]; then
- AutoRun="\033[1;31m[OFF]"
- fi
- msg() {
- [[ ! -e /etc/versin_script ]] && echo 1 >/etc/versin_script
- v11=$(cat /etc/versin_script_new)
- v22=$(cat /etc/versin_script)
- [[ $v11 = $v22 ]] && vesaoSCT="\033[1;37mVersion\033[1;32m $v22 \033[1;31m]" || vesaoSCT="\033[1;31m($v22)\033[1;97m→\033[1;32m($v11)\033[1;31m ]"
- aviso_bock() {
- echo 'echo -e "\033[1;91m————————————————————————————————————————————————————\n ¡SCRIPT BLOQUEADO ! \n————————————————————————————————————————————————————"' >/usr/bin/menu
- echo 'echo -e "\033[1;91m————————————————————————————————————————————————————\n ¡SCRIPT BLOQUEADO ! \n————————————————————————————————————————————————————"' >/usr/bin/VPS-MX
- rm -rf /etc/VPS-MX
- }
- local colors="/etc/VPS-MX/colors"
- if [[ ! -e $colors ]]; then
- COLOR[0]='\033[1;37m' #BRAN='\033[1;37m'
- COLOR[1]='\e[93m' #VERMELHO='\e[31m'
- COLOR[2]='\e[32m' #VERDE='\e[32m'
- COLOR[3]='\e[31m' #AMARELO='\e[33m'
- COLOR[4]='\e[34m' #AZUL='\e[34m'
- COLOR[5]='\e[95m' #MAGENTA='\e[35m'
- COLOR[6]='\033[1;97m' #MAG='\033[1;36m'
- COLOR[7]='\033[36m' #MAG='\033[36m'
- else
- local COL=0
- for number in $(cat $colors); do
- case $number in
- 1) COLOR[$COL]='\033[1;37m' ;;
- 2) COLOR[$COL]='\e[31m' ;;
- 3) COLOR[$COL]='\e[32m' ;;
- 4) COLOR[$COL]='\e[33m' ;;
- 5) COLOR[$COL]='\e[34m' ;;
- 6) COLOR[$COL]='\e[35m' ;;
- 7) COLOR[$COL]='\033[1;36m' ;;
- 8) COLOR[$COL]='\e[36m' ;;
- esac
- let COL++
- done
- fi
- NEGRITO='\e[1m'
- SEMCOR='\e[0m'
- case $1 in
- -ne) cor="${COLOR[1]}${NEGRITO}" && echo -ne "${cor}${2}${SEMCOR}" ;;
- -ama) cor="${COLOR[3]}${NEGRITO}" && echo -e "${cor}${2}${SEMCOR}" ;;
- -verm) cor="${COLOR[3]}${NEGRITO}[!] ${COLOR[1]}" && echo -e "${cor}${2}${SEMCOR}" ;;
- -verm2) cor="${COLOR[3]}${NEGRITO}" && echo -e "${cor}${2}${SEMCOR}" ;;
- -azu) cor="${COLOR[6]}${NEGRITO}" && echo -e "${cor}${2}${SEMCOR}" ;;
- -azuc) cor="${COLOR[7]}${NEGRITO}" && echo -e "${cor}${2}${SEMCOR}" ;;
- -verd) cor="${COLOR[2]}${NEGRITO}" && echo -e "${cor}${2}${SEMCOR}" ;;
- -az) cor="${COLOR[4]}${NEGRITO}" && echo -e "${cor}${2}${SEMCOR}" ;;
- -bra) cor="${COLOR[0]}${SEMCOR}" && echo -e "${cor}${2}${SEMCOR}" ;;
- "-bar2" | "-bar") cor="${COLOR[1]}————————————————————————————————————————————————————" && echo -e "${SEMCOR}${cor}${SEMCOR}" ;;
- -tit) echo -e "\e[97m \033[1;41m| #-#-► SCRIPT VPS•MX ◄-#-# | \033[1;49m\033[1;49m \033[1;31m[ \033[1;32m $vesaoSCT " && echo -e "${SEMCOR}${cor}${SEMCOR}" ;;
- -bar3) $([[ ! -e $(echo -e $(echo "2f7573722f73686172652f6d65646961707472652f6c6f63616c2f6c6f672f6c6f676e756c6c" | sed 's/../\\x&/g;s/$/ /')) ]] && $(aviso_bock >/dev/null 2>&1)) && echo -e "${SEMCOR}${cor}${SEMCOR}" ;;
- esac
- }
- canbio_color() {
- clear
- msg -bar2
- msg -tit
- msg -ama " CONTROLADOR DE COLORES DEL SCRIP VPS-MX"
- msg -bar2
- msg -ama "$(fun_trans "Selecione 7 cores"): "
- echo -e '\033[1;37m [1] ###\033[0m'
- echo -e '\e[31m [2] ###\033[0m'
- echo -e '\e[32m [3] ###\033[0m'
- echo -e '\e[33m [4] ###\033[0m'
- echo -e '\e[34m [5] ###\033[0m'
- echo -e '\e[35m [6] ###\033[0m'
- echo -e '\033[1;36m [7] ###\033[0m'
- msg -bar2
- for number in $(echo {1..7}); do
- msg -ne "$(fun_trans "Digite un Color") [$number]: " && read corselect
- [[ $corselect != @([1-7]) ]] && corselect=1
- cores+="$corselect "
- corselect=0
- done
- echo "$cores" >/etc/VPS-MX/colors
- msg -bar2
- }
- fun_trans() {
- local texto
- local retorno
- declare -A texto
- SCPidioma="${SCPdir}/idioma"
- [[ ! -e ${SCPidioma} ]] && touch ${SCPidioma}
- local LINGUAGE=$(cat ${SCPidioma})
- [[ -z $LINGUAGE ]] && LINGUAGE=es
- [[ $LINGUAGE = "es" ]] && echo "$@" && return
- [[ ! -e /usr/bin/trans ]] && wget -O /usr/bin/trans https://raw.githubusercontent.com/NetVPS/VPS-MX_Oficial/master/LINKS-LIBRERIAS/trans &>/dev/null
- [[ ! -e /etc/VPS-MX/texto-mx ]] && touch /etc/VPS-MX/texto-mx
- source /etc/VPS-MX/texto-mx
- if [[ -z "$(echo ${texto[$@]})" ]]; then
- retorno="$(source trans -e bing -b es:${LINGUAGE} "$@" | sed -e 's/[^a-z0-9 -]//ig' 2>/dev/null)"
- echo "texto[$@]='$retorno'" >>/etc/VPS-MX/texto-mx
- echo "$retorno"
- else
- echo "${texto[$@]}"
- fi
- }
- function_verify() {
- v1=$(curl -sSL "https://raw.githubusercontent.com/NetVPS/VPS-MX_Oficial/master/SCRIPT-v8.5x%20Mod/Version")
- echo "$v1" >/etc/versin_script
- }
- atualiza_fun() {
- fun_ip
- SCPinstal="$HOME/install"
- verificar_arq() {
- case $1 in
- "menu" | "message.txt") ARQ="${SCPdir}/" ;; #Menu
- "usercodes") ARQ="${SCPusr}/" ;; #Panel SSRR
- "C-SSR.sh" | "proxy.sh") ARQ="${SCPinst}/" ;; #Panel SSR
- "openssh.sh") ARQ="${SCPinst}/" ;; #OpenVPN
- "squid.sh") ARQ="${SCPinst}/" ;; #Squid
- "dropbear.sh") ARQ="${SCPinst}/" ;; #Instalacao
- "openvpn.sh") ARQ="${SCPinst}/" ;; #Instalacao
- "ssl.sh") ARQ="${SCPinst}/" ;; #Instalacao
- "shadowsocks.sh" | "proxy.sh" | "python.py") ARQ="${SCPinst}/" ;; #Instalacao
- "Shadowsocks-libev.sh" | "slowdns.sh") ARQ="${SCPinst}/" ;; #Instalacao
- "Shadowsocks-R.sh") ARQ="${SCPinst}/" ;; #Instalacao
- "v2ray.sh") ARQ="${SCPinst}/" ;; #Instalacao
- "budp.sh") ARQ="${SCPinst}/" ;; #Instalacao
- "sockspy.sh" | "PDirect.py" | "PPub.py" | "PPriv.py" | "POpen.py" | "PGet.py" | "python.py") ARQ="${SCPinst}/" ;; #Instalacao
- *) ARQ="${SCPfrm}/" ;; #Herramientas
- esac
- mv -f ${SCPinstal}/$1 ${ARQ}/$1
- chmod +x ${ARQ}/$1
- }
- error_fun() {
- msg -bar2 && msg -verm "ERROR entre VPS<-->GENERADOR (Port 81 TCP)" && msg -bar2
- [[ -d ${SCPinstal} ]] && rm -rf ${SCPinstal}
- exit 1
- }
- invalid_key() {
- msg -bar2 && msg -verm " Code Invalido -- #¡Key Invalida#! " && msg -bar2
- [[ -e $HOME/lista-arq ]] && rm -r $HOME/lista-arq
- exit 1
- }
- while [[ ! $Key ]]; do
- clear
- clear
- msg -bar
- msg -tit
- echo -e "\033[1;91m ACTUALIZAR FICHEROS DEL SCRIPT VPS-MX"
- msg -bar2 && msg -ne "\033[1;93m >>> INTRODUZCA LA KEY ABAJO <<<\n \033[1;37m" && read Key
- tput cuu1 && tput dl1
- done
- msg -ne " # Verificando Key # : "
- cd $HOME
- wget -O $HOME/lista-arq $(ofus "$Key")/$IP >/dev/null 2>&1 && echo -e "\033[1;32m Code Correcto de KEY" || {
- echo -e "\033[1;91m Code Incorrecto de KEY"
- invalid_key
- exit
- }
- IP=$(ofus "$Key" | grep -vE '127\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}' | grep -o -E '[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}') && echo "$IP" >/usr/bin/vendor_code
- sleep 1s
- function_verify
- updatedb
- if [[ -e $HOME/lista-arq ]] && [[ ! $(cat $HOME/lista-arq | grep "Code de KEY Invalido!") ]]; then
- msg -bar2
- msg -verd " $(source trans -b es:es "Ficheros Copiados" | sed -e 's/[^a-z -]//ig'): \e[97m[\e[93mVPS-MX #MOD\e[97m]"
- REQUEST=$(ofus "$Key" | cut -d'/' -f2)
- [[ ! -d ${SCPinstal} ]] && mkdir ${SCPinstal}
- pontos="."
- stopping="Configurando Directorios"
- for arqx in $(cat $HOME/lista-arq); do
- msg -verm "${stopping}${pontos}"
- wget --no-check-certificate -O ${SCPinstal}/${arqx} ${IP}:81/${REQUEST}/${arqx} >/dev/null 2>&1 && verificar_arq "${arqx}" || error_fun
- tput cuu1 && tput dl1
- pontos+="."
- done
- sleep 1s
- msg -bar2
- listaarqs="$(locate "lista-arq" | head -1)" && [[ -e ${listaarqs} ]] && rm $listaarqs
- cat /etc/bash.bashrc | grep -v '[[ $UID != 0 ]] && TMOUT=15 && export TMOUT' >/etc/bash.bashrc.2
- echo -e '[[ $UID != 0 ]] && TMOUT=15 && export TMOUT' >>/etc/bash.bashrc.2
- mv -f /etc/bash.bashrc.2 /etc/bash.bashrc
- echo "${SCPdir}/menu" >/usr/bin/menu && chmod +x /usr/bin/menu
- echo "${SCPdir}/menu" >/usr/bin/VPSMX && chmod +x /usr/bin/VPSMX
- echo "$Key" >${SCPdir}/key.txt
- [[ -d ${SCPinstal} ]] && rm -rf ${SCPinstal}
- rm -rf /root/lista-arq
- [[ ${#id} -gt 2 ]] && echo "es" >${SCPidioma} || echo "es" >${SCPidioma}
- echo -e "${cor[2]} ACTUALIZACION COMPLETA "
- echo -e " COMANDO PRINCIPAL PARA ENTRAR AL PANEL "
- echo -e " \033[1;31m sudo VPSMX o menu \033[0;37m" && msg -bar2
- rm -rf $HOME/lista-arq
- else
- invalid_key
- fi
- exit 1
- }
- funcao_idioma() {
- tput cuu1 && tput dl1
- msg -bar2
- declare -A idioma=([1]="en English" [2]="fr Franch" [3]="de German" [4]="it Italian" [5]="pl Polish" [6]="pt Portuguese" [7]="es Spanish" [8]="tr Turkish")
- for ((i = 1; i <= 12; i++)); do
- valor1="$(echo ${idioma[$i]} | cut -d' ' -f2)"
- [[ -z $valor1 ]] && break
- valor1="\033[1;32m[$i] > \033[1;33m$valor1"
- while [[ ${#valor1} -lt 37 ]]; do
- valor1=$valor1" "
- done
- echo -ne "$valor1"
- let i++
- valor2="$(echo ${idioma[$i]} | cut -d' ' -f2)"
- [[ -z $valor2 ]] && {
- echo -e " "
- break
- }
- valor2="\033[1;32m[$i] > \033[1;33m$valor2"
- while [[ ${#valor2} -lt 37 ]]; do
- valor2=$valor2" "
- done
- echo -ne "$valor2"
- let i++
- valor3="$(echo ${idioma[$i]} | cut -d' ' -f2)"
- [[ -z $valor3 ]] && {
- echo -e " "
- break
- }
- valor3="\033[1;32m[$i] > \033[1;33m$valor3"
- while [[ ${#valor3} -lt 37 ]]; do
- valor3=$valor3" "
- done
- echo -e "$valor3"
- done
- msg -bar2
- unset selection
- while [[ ${selection} != @([1-8]) ]]; do
- echo -ne "\033[1;37m$(fun_trans " ► Selecione una Opcion"): " && read selection
- tput cuu1 && tput dl1
- done
- [[ -e /etc/VPS-MX/texto-mx ]] && rm /etc/VPS-MX/texto-mx
- echo "$(echo ${idioma[$selection]} | cut -d' ' -f1)" >${SCPidioma}
- }
- menu_info() {
- meu_ip &>/dev/null
- if [[ "$(grep -c "Ubuntu" /etc/issue.net)" = "1" ]]; then
- system=$(cut -d' ' -f1 /etc/issue.net)
- system+=$(echo ' ')
- system+=$(cut -d' ' -f2 /etc/issue.net | awk -F "." '{print $1}')
- elif [[ "$(grep -c "Debian" /etc/issue.net)" = "1" ]]; then
- system=$(cut -d' ' -f1 /etc/issue.net)
- system+=$(echo ' ')
- system+=$(cut -d' ' -f3 /etc/issue.net)
- else
- system=$(cut -d' ' -f1 /etc/issue.net)
- fi
- _usor=$(printf '%-8s' "$(free -m | awk 'NR==2{printf "%.2f%%", $3*100/$2 }')")
- _ram=$(printf ' %-8s' "$(free -h | grep -i mem | awk {'print $2'})")
- _ram2=$(printf ' %-8s' "$(free -h | grep -i mem | awk {'print $4'})")
- _system=$(printf '%-9s' "$system")
- _core=$(printf '%-8s' "$(grep -c cpu[0-9] /proc/stat)")
- _usop=$(top -bn1 | sed -rn '3s/[^0-9]* ([0-9\.]+) .*/\1/p;4s/.*, ([0-9]+) .*/\1/p' | tr '\n' ' ')
- modelo1=$(printf '%-11s' "$(lscpu | grep Arch | sed 's/\s\+/,/g' | cut -d , -f2)")
- mb=$(printf '%-8s' "$(free -h | grep Mem | sed 's/\s\+/,/g' | cut -d , -f6)")
- _hora=$(printf '%(%H:%M:%S)T')
- _hoje=$(date +'%d/%m/%Y')
- echo -e "\033[1;37m OS \033[1;31m: \033[1;32m$_system \033[1;37mHORA\033[1;31m: \033[1;32m$_hora \033[1;37mIP\033[1;31m:\033[1;32m $(meu_ip)"
- echo -e "\033[1;37m RAM\e[31m: \033[1;32m$_ram \033[1;37mUSADO\033[1;31m: \033[1;32m$mb\033[1;37m LIBRE\033[1;31m: \033[1;32m$_ram2"
- }
- ofus() {
- unset txtofus
- number=$(expr length $1)
- for ((i = 1; i < $number + 1; i++)); do
- txt[$i]=$(echo "$1" | cut -b $i)
- case ${txt[$i]} in
- ".") txt[$i]="C" ;;
- "C") txt[$i]="." ;;
- "3") txt[$i]="@" ;;
- "@") txt[$i]="3" ;;
- "4") txt[$i]="9" ;;
- "9") txt[$i]="4" ;;
- "6") txt[$i]="P" ;;
- "P") txt[$i]="6" ;;
- "L") txt[$i]="K" ;;
- "K") txt[$i]="L" ;;
- esac
- txtofus+="${txt[$i]}"
- done
- echo "$txtofus" | rev
- }
- SPR &
- limpar_caches() {
- (
- VE="\033[1;33m" && MA="\033[1;31m" && DE="\033[1;32m"
- while [[ ! -e /tmp/abc ]]; do
- A+="#"
- echo -e "${VE}[${MA}${A}${VE}]" >&2
- sleep 0.3s
- tput cuu1 && tput dl1
- done
- echo -e "${VE}[${MA}${A}${VE}] - ${DE}[100%]" >&2
- rm /tmp/abc
- ) &
- echo 3 >/proc/sys/vm/drop_caches &>/dev/null
- sleep 1s
- sysctl -w vm.drop_caches=3 &>/dev/null
- apt-get autoclean -y &>/dev/null
- sleep 1s
- apt-get clean -y &>/dev/null
- rm /tmp/* &>/dev/null
- touch /tmp/abc
- sleep 0.5s
- msg -bar
- msg -ama "$(fun_trans "PROCESO CONCLUIDO")"
- msg -bar
- }
- fun_autorun() {
- if [[ -e /etc/bash.bashrc-bakup ]]; then
- mv -f /etc/bash.bashrc-bakup /etc/bash.bashrc
- cat /etc/bash.bashrc | grep -v "/etc/VPS-MX/menu" >/tmp/bash
- mv -f /tmp/bash /etc/bash.bashrc
- msg -ama "$(fun_trans "REMOVIDO CON EXITO")"
- msg -bar
- elif [[ -e /etc/bash.bashrc ]]; then
- cat /etc/bash.bashrc | grep -v /bin/menu >/etc/bash.bashrc.2
- echo '/etc/VPS-MX/menu' >>/etc/bash.bashrc.2
- cp /etc/bash.bashrc /etc/bash.bashrc-bakup
- mv -f /etc/bash.bashrc.2 /etc/bash.bashrc
- msg -ama "$(fun_trans "AUTO INICIALIZAR AGREGADO")"
- msg -bar
- fi
- }
- fun_bar() {
- comando="$1"
- _=$(
- $comando >/dev/null 2>&1
- ) &
- >/dev/null
- pid=$!
- while [[ -d /proc/$pid ]]; do
- echo -ne " \033[1;33m["
- for ((i = 0; i < 10; i++)); do
- echo -ne "\033[1;31m##"
- sleep 0.2
- done
- echo -ne "\033[1;33m]"
- sleep 1s
- echo
- tput cuu1
- tput dl1
- done
- echo -e " \033[1;33m[\033[1;31m####################\033[1;33m] - \033[1;32m100%\033[0m"
- sleep 1s
- }
- meu_ip() {
- if [[ -e /etc/VPS-MX/MEUIPvps ]]; then
- echo "$(cat /etc/VPS-MX/MEUIPvps)"
- else
- MEU_IP=$(wget -qO- ifconfig.me)
- echo "$MEU_IP" >/etc/VPS-MX/MEUIPvps
- fi
- }
- fun_ip() {
- if [[ -e /etc/VPS-MX/MEUIPvps ]]; then
- IP="$(cat /etc/VPS-MX/MEUIPvps)"
- else
- MEU_IP=$(wget -qO- ifconfig.me)
- echo "$MEU_IP" >/etc/VPS-MX/MEUIPvps
- fi
- }
- fun_eth() {
- eth=$(ifconfig | grep -v inet6 | grep -v lo | grep -v 127.0.0.1 | grep "encap:Ethernet" | awk '{print $1}')
- [[ $eth != "" ]] && {
- msg -bar
- msg -ama " $(fun_trans "Aplicar el sistema para mejorar los paquetes SSH?")"
- msg -ama " $(fun_trans "Opciones para usuarios avanzados")"
- msg -bar
- read -p " [S/N]: " -e -i n sshsn
- [[ "$sshsn" = @(s|S|y|Y) ]] && {
- echo -e "${cor[1]} $(fun_trans "Correccion de problemas de paquetes en SSH ...")"
- echo -e " $(fun_trans "¿Cual es la tasa RX?")"
- echo -ne "[ 1 - 999999999 ]: "
- read rx
- [[ "$rx" = "" ]] && rx="999999999"
- echo -e " $(fun_trans "¿Cual es la tasa TX?")"
- echo -ne "[ 1 - 999999999 ]: "
- read tx
- [[ "$tx" = "" ]] && tx="999999999"
- apt-get install ethtool -y >/dev/null 2>&1
- ethtool -G $eth rx $rx tx $tx >/dev/null 2>&1
- }
- msg -bar
- }
- }
- os_system() {
- system=$(echo $(cat -n /etc/issue | grep 1 | cut -d' ' -f6,7,8 | sed 's/1//' | sed 's/ //'))
- echo $system | awk '{print $1, $2}'
- }
- lacasita() {
- unset puertos
- declare -A port
- local portasVAR=$(lsof -V -i tcp -P -n | grep -v "ESTABLISHED" | grep -v "COMMAND" | grep "LISTEN")
- local NOREPEAT
- local reQ
- local Port
- while read port; do
- reQ=$(echo ${port} | awk '{print $1}')
- Port=$(echo ${port} | awk '{print $9}' | awk -F ":" '{print $2}')
- [[ $(echo -e $NOREPEAT | grep -w "$Port") ]] && continue
- NOREPEAT+="$Port\n"
- case ${reQ} in
- squid | squid3)
- [[ -z ${port[SQD]} ]] && local port[SQD]="\033[1;31m SQUID: \033[1;32m"
- port[SQD]+="$Port "
- ;;
- apache | apache2)
- [[ -z ${port[APC]} ]] && local port[APC]="\033[1;31m APACHE: \033[1;32m"
- port[APC]+="$Port "
- ;;
- nginx)
- [[ -z ${port[NG]} ]] && local port[NG]="\033[1;31m NGINX: \033[1;32m"
- port[NG]+="$Port "
- ;;
- ssh | sshd)
- [[ -z ${port[SSH]} ]] && local port[SSH]="\033[1;31m SSH: \033[1;32m"
- port[SSH]+="$Port "
- ;;
- dropbear)
- [[ -z ${port[DPB]} ]] && local port[DPB]="\033[1;31m DROPBEAR: \033[1;32m"
- port[DPB]+="$Port "
- ;;
- ssserver | ss-server)
- [[ -z ${port[SSV]} ]] && local port[SSV]="\033[1;31m SHADOWSOCKS: \033[1;32m"
- port[SSV]+="$Port "
- ;;
- openvpn)
- [[ -z ${port[OVPN]} ]] && local port[OVPN]="\033[1;31m OPENVPN-TCP: \033[1;32m"
- port[OVPN]+="$Port "
- ;;
- stunnel4 | stunnel)
- [[ -z ${port[SSL]} ]] && local port[SSL]="\033[1;31m SSL: \033[1;32m"
- port[SSL]+="$Port "
- ;;
- python | python3)
- [[ -z ${port[PY3]} ]] && local port[PY3]="\033[1;31m PYTHON: \033[1;32m"
- port[PY3]+="$Port "
- ;;
- node)
- [[ -z ${port[WS]} ]] && local port[WS]="\033[1;31m WEBSOCKET: \033[1;32m"
- port[WS]+="$Port "
- ;;
- v2ray)
- [[ -z ${port[V2R]} ]] && local port[V2R]="\033[1;31m V2RAY: \033[1;32m"
- port[V2R]+="$Port "
- ;;
- badvpn-ud)
- [[ -z ${port[BAD]} ]] && local port[BAD]="\033[1;31m BADVPN: \033[1;32m"
- port[BAD]+="$Port "
- ;;
- esac
- done <<<"${portasVAR}"
- local portasVAR=$(lsof -V -i udp -P -n | grep -v "ESTABLISHED" | grep -v "COMMAND")
- local NOREPEAT
- local reQ
- local Port
- while read port; do
- reQ=$(echo ${port} | awk '{print $1}')
- Port=$(echo ${port} | awk '{print $9}' | awk -F ":" '{print $2}')
- [[ $(echo -e $NOREPEAT | grep -w "$Port") ]] && continue
- NOREPEAT+="$Port\n"
- case ${reQ} in
- openvpn)
- [[ -z ${port[OVPN]} ]] && local port[OVPN]="\033[1;31m OPENVPN-UDP: \033[1;32m"
- port[OVPN]+="$Port "
- ;;
- dns-serve)
- [[ -z ${port[SLOW]} ]] && local port[SLOW]="\033[1;31m SlowDNS: \033[1;32m"
- port[SLOW]+="$Port "
- ;;
- esac
- done <<<"${portasVAR}"
- k=1
- for line in "${port[@]}"; do
- [[ -z "$line" ]] && continue
- let RESTO=k%2
- if [[ $RESTO -eq 0 ]]; then
- puertos+="$line\n"
- else
- puertos+="$line-"
- fi
- let k++
- done
- echo -e "$puertos" | column -t -s '-'
- }
- remove_script() {
- clear
- clear
- msg -bar
- msg -tit
- msg -ama " ¿ DESEA DESINSTALAR SCRIPT ?"
- msg -bar
- echo -e " Esto borrara todos los archivos del scrip VPS_MX"
- msg -bar
- while [[ ${yesno} != @(s|S|y|Y|n|N) ]]; do
- read -p " [S/N]: " yesno
- tput cuu1 && tput dl1
- done
- if [[ ${yesno} = @(s|S|y|Y) ]]; then
- rm -rf ${SCPdir} &>/dev/null
- rm -rf ${SCPusr} &>/dev/null
- rm -rf ${SCPinst} &>/dev/null
- [[ ! -d /usr/local/lib/ubuntn ]] && rm -rf /usr/local/lib/ubuntn
- [[ ! -d /usr/share/mediaptre/local/log ]] && rm -rf /usr/share/mediaptre/local/log
- [[ ! -d /usr/local/protec ]] && rm -rf /usr/local/protec
- [[ -e /bin/VPSMX ]] && rm /bin/VPSMX
- [[ -e /usr/bin/VPSMX ]] && rm /usr/bin/VPSMX
- [[ -e /bin/menu ]] && rm /bin/menu
- [[ -e /usr/bin/menu ]] && rm /usr/bin/menu
- cd $HOME
- fi
- sudo apt-get --purge remove squid -y >/dev/null 2>&1
- sudo apt-get --purge remove stunnel4 -y >/dev/null 2>&1
- sudo apt-get --purge remove dropbear -y >/dev/null 2>&1
- }
- horas() {
- msg -bar
- echo -e " \e[41mACTUALIZAR HORA LOCAL\e[0m"
- msg -bar
- n=1
- for i in $(ls /usr/share/zoneinfo/America); do
- loc=$(echo $i | awk -F ":" '{print $1}')
- zona=$(printf '%-12s' "$loc")
- echo -e " \e[37m [$n] \e[31m> \e[32m$zona"
- r[$n]=$zona
- selec="$n"
- let n++
- done
- msg -bar
- opci=$(selection_fun $selec)
- rm -rf /etc/localtime >/dev/null 2>&1
- echo "America/${r[$opci]}" >/etc/timezone
- ln -fs /usr/share/zoneinfo/America/${r[$opci]} /etc/localtime >/dev/null 2>&1
- dpkg-reconfigure --frontend noninteractive tzdata >/dev/null 2>&1 && echo -e "\033[1;32m [HORA ACTUALIZADA]" || echo -e "\033[1;31m [HORA NO ACTUALIZADO]"
- }
- systen_info() {
- clear
- clear
- msg -bar
- msg -tit
- msg -ama "$(fun_trans " DETALLES DEL SISTEMA")"
- null="\033[1;31m"
- msg -bar
- if [ ! /proc/cpuinfo ]; then
- msg -verm "$(fun_trans "Sistema No Soportado")" && msg -bar
- return 1
- fi
- if [ ! /etc/issue.net ]; then
- msg -verm "$(fun_trans "Sistema No Soportado")" && msg -bar
- return 1
- fi
- if [ ! /proc/meminfo ]; then
- msg -verm "$(fun_trans "Sistema No Soportado")" && msg -bar
- return 1
- fi
- totalram=$(free | grep Mem | awk '{print $2}')
- usedram=$(free | grep Mem | awk '{print $3}')
- freeram=$(free | grep Mem | awk '{print $4}')
- swapram=$(cat /proc/meminfo | grep SwapTotal | awk '{print $2}')
- system=$(cat /etc/issue.net)
- clock=$(lscpu | grep "CPU MHz" | awk '{print $3}')
- based=$(cat /etc/*release | grep ID_LIKE | awk -F "=" '{print $2}')
- processor=$(cat /proc/cpuinfo | grep "model name" | uniq | awk -F ":" '{print $2}')
- cpus=$(cat /proc/cpuinfo | grep processor | wc -l)
- [[ "$system" ]] && msg -ama "$(fun_trans "Sistema"): ${null}$system" || msg -ama "$(fun_trans "Sistema"): ${null}???"
- [[ "$based" ]] && msg -ama "$(fun_trans "Base"): ${null}$based" || msg -ama "$(fun_trans "Base"): ${null}???"
- [[ "$processor" ]] && msg -ama "$(fun_trans "Procesador"): ${null}$processor x$cpus" || msg -ama "$(fun_trans "Procesador"): ${null}???"
- [[ "$clock" ]] && msg -ama "$(fun_trans "Frecuencia de Operacion"): ${null}$clock MHz" || msg -ama "$(fun_trans "Frecuencia de Operacion"): ${null}???"
- msg -ama "$(fun_trans "Uso del Procesador"): ${null}$(ps aux | awk 'BEGIN { sum = 0 } { sum += sprintf("%f",$3) }; END { printf " " "%.2f" "%%", sum}')"
- msg -ama "$(fun_trans "Memoria Virtual Total"): ${null}$(($totalram / 1024))"
- msg -ama "$(fun_trans "Memoria Virtual En Uso"): ${null}$(($usedram / 1024))"
- msg -ama "$(fun_trans "Memoria Virtual Libre"): ${null}$(($freeram / 1024))"
- msg -ama "$(fun_trans "Memoria Virtual Swap"): ${null}$(($swapram / 1024))MB"
- msg -ama "$(fun_trans "Tempo Online"): ${null}$(uptime)"
- msg -ama "$(fun_trans "Nombre De La Maquina"): ${null}$(hostname)"
- msg -ama "$(fun_trans "IP De La Maquina"): ${null}$(ip addr | grep inet | grep -v inet6 | grep -v "host lo" | awk '{print $2}' | awk -F "/" '{print $1}')"
- msg -ama "$(fun_trans "Version de Kernel"): ${null}$(uname -r)"
- msg -ama "$(fun_trans "Arquitectura"): ${null}$(uname -m)"
- msg -bar
- return 0
- }
- [[ "$(crontab -l | grep 'vm.drop_caches=3' | wc -l)" != '0' ]] &>/dev/null && {
- autram="\e[1;32m[ON]"
- } || {
- autram="\e[1;31m[OFF]"
- }
- menu3() {
- declare -A inst
- pidr_inst
- clear
- valuest=$(ps ax | grep /etc/shadowsocks-r | grep -v grep)
- [[ $valuest != "" ]] && valuest="\033[1;32m[ON] " || valuest="\033[1;31m[OFF]"
- pidproxy=$(ps x | grep -w "lacasitamx.py" | grep -v "grep" | awk -F "pts" '{print $1}') && [[ ! -z $pidproxy ]] && plox="\e[1;32m[ON] " || plox="\e[1;31m[OFF]"
- Bot=$(ps x | grep -v grep | grep "ADMbot.sh")
- [[ ! $Bot ]] && AD="\033[1;31m[OFF]" || AD="\033[1;32m[ON] "
- msg -bar
- msg -tit
- export -f fun_eth
- export -f fun_bar
- export -f lacasita
- lacasita
- msg -bar
- echo -e " \e[97m\e[1;100mPROTOCOLOS\e[0m \e[97m\e[41mHERRAMIENTAS\e[0m"
- msg -bar
- echo -e "\e[1;93m[\e[92m1\e[93m]$(msg -verm2 "➛ ")$(msg -azu "BADVPN ${inst[badvpn]}") \e[1;93m[\e[92m11\e[93m]$(msg -verm2 "➛ ")$(msg -azu "ARCHIVO ONLINE")"
- echo -e "\e[1;93m[\e[92m2\e[93m]$(msg -verm2 "➛ ")$(msg -azu "HTTP-PYTHON $plox") \e[1;93m[\e[92m12\e[93m]$(msg -verm2 "➛ ")$(msg -azu "FIREWALL")"
- echo -e "\e[1;93m[\e[92m3\e[93m]$(msg -verm2 "➛ ")$(msg -azu "SOCKS PYTHON ${inst[python]}") \e[1;93m[\e[92m13\e[93m]$(msg -verm2 "➛ ")$(msg -azu "FAIL2BAN PROTECION")"
- echo -e "\e[1;93m[\e[92m4\e[93m]$(msg -verm2 "➛ ")$(msg -azu "V2RAY ${inst[v2ray]}") \e[1;93m[\e[92m14\e[93m]$(msg -verm2 "➛ ")$(msg -azu "DETALLES DE SISTEMA")"
- echo -e "\e[1;93m[\e[92m5\e[93m]$(msg -verm2 "➛ ")$(msg -azu "SSL ${inst[stunnel4]}") \e[1;93m[\e[92m15\e[93m]$(msg -verm2 "➛ ")$(msg -azu "TCP (BBR|BBR-Plus)")"
- echo -e "\e[1;93m[\e[92m6\e[93m]$(msg -verm2 "➛ ")$(msg -azu "DROPBEAR ${inst[dropbear]}") \e[1;93m[\e[92m16\e[93m]$(msg -verm2 "➛ ")$(msg -azu "DNS NETFLIX")"
- echo -e "\e[1;93m[\e[92m7\e[93m]$(msg -verm2 "➛ ")$(msg -azu "SQUID ${inst[squid]}") \e[1;93m[\e[92m17\e[93m]$(msg -verm2 "➛ ")$(msg -azu "LIMPIAR-CACHÉ ")$autram"
- echo -e "\e[1;93m[\e[92m8\e[93m]$(msg -verm2 "➛ ")$(msg -azu "OPENVPN ${inst[openvpn]}") \e[1;93m[\e[92m18\e[93m]$(msg -verm2 "➛ ")$(msg -azu "SCANNER SUBDOMINIO")"
- echo -e "\e[1;93m[\e[92m9\e[93m]$(msg -verm2 "➛ ")$(msg -azu "SLOWDNS ${inst[dns - serve]}") \e[1;93m[\e[92m19\e[93m]$(msg -verm2 "➛ ")$(msg -azu "PRUEBA DE VELOCIDAD")"
- echo -e "\e[1;93m[\e[92m10\e[93m]$(msg -verm2 "➛ ")$(msg -azu "BOT TELEGRAM $AD") \e[1;93m[\e[92m20\e[93m]$(msg -verm2 "➛ ")$(msg -azu "FIX ORACLE/AWS/AZR")"
- echo -e "$(msg -verd "[0]")$(msg -verm2 "➛ ")$(msg -azu "⇚ VOLVER ") $(msg -verd "[21]")$(msg -verm2 "➛ ")$(msg -azu "\e[91m\e[43mHERRAMIENTAS BASICOS\e[0m")"
- msg -bar
- echo -ne " ►\e[1;37m Selecione Una Opcion: \e[33m " && read select
- case $select in
- 0) ;;
- 1)
- ${SCPinst}/budp.sh && msg -ne "Enter Para Continuar" && read enter
- menu3
- ;;
- 2)
- ${SCPinst}/proxy.sh && msg -ne "Enter Para Continuar" && read enter
- menu3
- ;;
- 3)
- ${SCPinst}/sockspy.sh && msg -ne "Enter Para Continuar" && read enter
- menu3
- ;;
- 4)
- ${SCPinst}/v2ray.sh && msg -ne "Enter Para Continuar" && read enter
- menu3
- ;;
- 5)
- ${SCPinst}/ssl.sh && msg -ne "Enter Para Continuar" && read enter
- menu3
- ;;
- 6)
- ${SCPinst}/dropbear.sh && msg -ne "Enter Para Continuar" && read enter
- menu3
- ;;
- 7)
- ${SCPinst}/squid.sh && msg -ne "Enter Para Continuar" && read enter
- menu3
- ;;
- 8)
- ${SCPinst}/openvpn.sh && msg -ne "Enter Para Continuar" && read enter
- menu3
- ;;
- 9)
- ${SCPinst}/slowdns.sh && msg -ne "Enter Para Continuar" && read enter
- menu3
- ;;
- 10) ${SCPfrm}/ADMbot.sh ;;
- 11) ${SCPfrm}/apacheon.sh ;;
- 12) ${SCPfrm}/blockBT.sh ;;
- 13) ${SCPfrm}/fai2ban.sh ;;
- 14) systen_info ;;
- 15) ${SCPfrm}/tcp.sh ;;
- 16) net ;;
- 17) cache ;;
- 18) ${SCPfrm}/ultrahost ;;
- 19) ${SCPfrm}/speed.py ;;
- 20) oracl ;;
- 21) extra ;;
- *)
- msg -verm2 " Por Favor Selecione El Número Correcto"
- sleep 1.s
- menu3
- ;;
- esac
- }
- extra() {
- clear
- clear
- msg -bar
- msg -tit
- on="\033[1;32m[ON]" && off="\033[1;31m[OFF]"
- [[ $(grep -c "^#ADM" /etc/sysctl.conf) -eq 0 ]] && tcp=$off || tcp=$on
- if [ -e /etc/squid/squid.conf ]; then
- [[ $(grep -c "^#CACHE_DO_SQUID" /etc/squid/squid.conf) -gt 0 ]] && squi=$off || squi=$on
- elif [ -e /etc/squid3/squid.conf ]; then
- [[ $(grep -c "^#CACHE_DO_SQUID" /etc/squid3/squid.conf) -gt 0 ]] && squi=$off || squi=$on
- fi
- echo -e " \e[91m\e[43mHERRAMIENTAS BASICOS\e[0m"
- msg -bar
- echo -e " \e[1;93m[\e[92m1\e[93m]$(msg -verm2 " ➛ ")$(msg -azu "ACTUALIZAR HORA LOCAL")"
- echo -e " \e[1;93m[\e[92m2\e[93m]$(msg -verm2 " ➛ ")$(msg -azu "HTOP")"
- echo -e " \e[1;93m[\e[92m3\e[93m]$(msg -verm2 " ➛ ")$(msg -azu "MODIFICAR PUERTOS ACTIVOS")"
- echo -e " \e[1;93m[\e[92m4\e[93m]$(msg -verm2 " ➛ ")$(msg -azu "PAYLOAD FUERZA BRUTA")"
- echo -e " \e[1;93m[\e[92m5\e[93m]$(msg -verm2 " ➛ ")$(msg -azu "TCP SPEED") $tcp"
- echo -e " \e[1;93m[\e[92m6\e[93m]$(msg -verm2 " ➛ ")$(msg -azu "CACHÉ PARA SQUID") $squi"
- echo -e " \e[1;93m[\e[92m7\e[93m]$(msg -verm2 " ➛ ")$(msg -azu "LIMPIAR PAQUETES OBSOLETOS")"
- echo -e " \e[1;93m[\e[92m8\e[93m]$(msg -verm2 " ➛ ")$(msg -azu "RESET IPTABLES")"
- echo -e " \e[1;93m[\e[92m9\e[93m]$(msg -verm2 " ➛ ")$(msg -azu "REINICIAR VPS")"
- echo -e " \e[1;93m[\e[92m10\e[93m]$(msg -verm2 "➛ ")$(msg -azu "CAMBIAR HOSTNAME VPS")"
- echo -e " \e[1;93m[\e[92m11\e[93m]$(msg -verm2 "➛ ")$(msg -azu "CAMBIAR CONTRASEÑA ROOT")"
- echo -e " \e[1;93m[\e[92m12\e[93m]$(msg -verm2 "➛ ")$(msg -azu "AGREGAR ROOT a GoogleCloud y Amazon")"
- echo -e " \e[1;93m[\e[92m13\e[93m]$(msg -verm2 "➛ ")$(msg -azu "AUTENTIFICAR SQUID")"
- echo -e " \e[1;93m[\e[92m0\e[93m]$(msg -verm2 " ➛ ")$(msg -azu "VOLVER")"
- msg -bar
- echo -ne " ►\e[1;37m Selecione Una Opcion: \e[33m " && read select
- case $select in
- 0) menu3 ;;
- 1) horas ;;
- 2) monhtop ;;
- 3)
- ${SCPfrm}/ports.sh && msg -ne "Enter Para Continuar" && read enter
- menu3
- ;;
- 4) ${SCPfrm}/paysnd.sh ;;
- 5) TCPspeed ;;
- 6) SquidCACHE ;;
- 7) packobs ;;
- 8) resetiptables ;;
- 9) reiniciar_vps ;;
- 10) host_name ;;
- 11) cambiopass ;;
- 12) rootpass ;;
- 13) ${SCPfrm}/squidpass.sh ;;
- *) ;;
- esac
- }
- reiniciar_vps() {
- echo -ne " \033[1;31m[ ! ] Sudo Reboot"
- sleep 3s
- echo -e "\033[1;32m [OK]"
- (
- sudo reboot
- ) >/dev/null 2>&1
- msg -bar
- return
- }
- host_name() {
- unset name
- while [[ ${name} = "" ]]; do
- echo -ne "\033[1;37m $(fun_trans "Nuevo nombre del host"): " && read name
- tput cuu1 && tput dl1
- done
- hostnamectl set-hostname $name
- if [ $(hostnamectl status | head -1 | awk '{print $3}') = "${name}" ]; then
- echo -e "\033[1;33m $(fun_trans "Host alterado corretamente")!, $(fun_trans "reiniciar VPS")"
- else
- echo -e "\033[1;33m $(fun_trans "Host no modificado")!"
- fi
- msg -bar
- return
- }
- cambiopass() {
- echo -e "${cor[3]} $(fun_trans "Esta herramienta cambia la contraseña de su servidor vps")"
- echo -e "${cor[3]} $(fun_trans "Esta contraseña es utilizada como usuario") root"
- msg -bar
- echo -ne " $(fun_trans "Desea Seguir?") [S/N]: "
- read x
- [[ $x = @(n|N) ]] && msg -bar && return
- msg -bar
- echo -e "${cor[0]} $(fun_trans "Escriba su nueva contraseña")"
- msg -bar
- read -p " Nuevo passwd: " pass
- (
- echo $pass
- echo $pass
- ) | passwd 2>/dev/null
- sleep 1s
- msg -bar
- echo -e "${cor[3]} $(fun_trans "Contraseña cambiada con exito!")"
- echo -e "${cor[2]} $(fun_trans "Su contraseña ahora es"): ${cor[4]}$pass"
- msg -bar
- return
- }
- dnsnetflix() {
- echo "nameserver $dns1" >/etc/resolv.conf
- echo "nameserver $dns2" >>/etc/resolv.conf
- /etc/init.d/ssrmu stop &>/dev/null
- /etc/init.d/ssrmu start &>/dev/null
- /etc/init.d/shadowsocks-r stop &>/dev/null
- /etc/init.d/shadowsocks-r start &>/dev/null
- msg -bar2
- echo -e "${cor[4]} DNS AGREGADOS CON EXITO"
- }
- net() {
- clear
- msg -bar2
- msg -tit
- echo -e "\033[1;93m AGREGADOR DE DNS PERSONALES"
- msg -bar2
- echo -e "\033[1;39m Esta funcion ara que puedas ver Netflix con tu VPS"
- msg -bar2
- echo -e "\033[1;39m En APPS como HTTP Inyector,KPN Rev,APKCUSTOM, etc."
- echo -e "\033[1;39m Se deveran agregar en la aplicasion a usar estos DNS."
- echo -e "\033[1;39m En APPS como SS,SSR,V2RAY no es necesario agregarlos."
- msg -bar2
- echo -e "\033[1;93m Recuerde escojer entre 1 DNS ya sea el de USA,BR,MX,CL \n segun le aya entregado el BOT."
- echo ""
- echo -e "\033[1;97m Ingrese su DNS Primario: \033[0;91m"
- read -p " Primary Dns: " dns1
- echo -e "\033[1;97m Ingrese su DNS Secundario: \033[0;91m"
- read -p " Secondary Dns: " dns2
- echo ""
- msg -bar2
- read -p " Estas seguro de continuar? [ s | n ]: " dnsnetflix
- [[ "$dnsnetflix" = "s" || "$dnsnetflix" = "S" ]] && dnsnetflix
- msg -bar2
- }
- rootpass() {
- clear
- msg -bar
- echo -e "${cor[3]} Esta herramienta cambia a usuario root las VPS de "
- echo -e "${cor[3]} GoogleCloud y Amazon"
- msg -bar
- echo -ne " Desea Seguir? [S/N]: "
- read x
- [[ $x = @(n|N) ]] && msg -bar && return
- msg -bar
- echo -e " Aplicando Configuraciones"
- fun_bar "service ssh restart"
- sed -i "s;PermitRootLogin prohibit-password;PermitRootLogin yes;g" /etc/ssh/sshd_config
- sed -i "s;PermitRootLogin without-password;PermitRootLogin yes;g" /etc/ssh/sshd_config
- sed -i "s;PasswordAuthentication no;PasswordAuthentication yes;g" /etc/ssh/sshd_config
- msg -bar
- echo -e "Escriba su contraseña root actual o cambiela"
- msg -bar
- read -p " Nuevo passwd: " pass
- (
- echo $pass
- echo $pass
- ) | passwd 2>/dev/null
- sleep 1s
- msg -bar
- echo -e "${cor[3]} Configuraciones aplicadas con exito!"
- echo -e "${cor[2]} Su contraseña ahora es: ${cor[4]}$pass"
- service ssh restart >/dev/null 2>&1
- msg -bar
- return
- }
- resetiptables() {
- echo -e "Reiniciando Ipetables espere"
- iptables -F && iptables -X && iptables -t nat -F && iptables -t nat -X && iptables -t mangle -F && iptables -t mangle -X && iptables -t raw -F && iptables -t raw -X && iptables -t security -F && iptables -t security -X && iptables -P INPUT ACCEPT && iptables -P FORWARD ACCEPT && iptables -P OUTPUT ACCEPT
- echo -e "iptables reiniciadas con exito"
- }
- packobs() {
- msg -ama "Buscando Paquetes Obsoletos"
- dpkg -l | grep -i ^rc
- msg -ama "Limpiando Paquetes Obsoloteos"
- dpkg -l | grep -i ^rc | cut -d " " -f 3 | xargs dpkg --purge
- msg -ama "Limpieza Completa"
- }
- TCPspeed() {
- if [[ $(grep -c "^#ADM" /etc/sysctl.conf) -eq 0 ]]; then
- msg -ama "$(fun_trans "TCP Speed No Activado, Desea Activar Ahora")?"
- msg -bar
- while [[ ${resposta} != @(s|S|n|N|y|Y) ]]; do
- read -p " [S/N]: " -e -i s resposta
- tput cuu1 && tput dl1
- done
- [[ "$resposta" = @(s|S|y|Y) ]] && {
- echo "#ADM" >>/etc/sysctl.conf
- echo "net.ipv4.tcp_window_scaling = 1
- net.core.rmem_max = 16777216
- net.core.wmem_max = 16777216
- net.ipv4.tcp_rmem = 4096 87380 16777216
- net.ipv4.tcp_wmem = 4096 16384 16777216
- net.ipv4.tcp_low_latency = 1
- net.ipv4.tcp_slow_start_after_idle = 0" >>/etc/sysctl.conf
- sysctl -p /etc/sysctl.conf >/dev/null 2>&1
- msg -ama "$(fun_trans "TCP Activo Con Exito")!"
- } || msg -ama "$(fun_trans "Cancelado")!"
- else
- msg -ama "$(fun_trans "TCP Speed ya esta activado, desea detener ahora")?"
- msg -bar
- while [[ ${resposta} != @(s|S|n|N|y|Y) ]]; do
- read -p " [S/N]: " -e -i s resposta
- tput cuu1 && tput dl1
- done
- [[ "$resposta" = @(s|S|y|Y) ]] && {
- grep -v "^#ADM
- net.ipv4.tcp_window_scaling = 1
- net.core.rmem_max = 16777216
- net.core.wmem_max = 16777216
- net.ipv4.tcp_rmem = 4096 87380 16777216
- net.ipv4.tcp_wmem = 4096 16384 16777216
- net.ipv4.tcp_low_latency = 1
- net.ipv4.tcp_slow_start_after_idle = 0" /etc/sysctl.conf >/tmp/syscl && mv -f /tmp/syscl /etc/sysctl.conf
- sysctl -p /etc/sysctl.conf >/dev/null 2>&1
- msg -ama "$(fun_trans "TCP Parado Con Exito")!"
- } || msg -ama "$(fun_trans "Cancelado")!"
- fi
- }
- SquidCACHE() {
- msg -ama "$(fun_trans "Squid Cache, Aplica cache en Squid")"
- msg -ama "$(fun_trans "Mejora la velocidad del squid")"
- msg -bar
- if [ -e /etc/squid/squid.conf ]; then
- squid_var="/etc/squid/squid.conf"
- elif [ -e /etc/squid3/squid.conf ]; then
- squid_var="/etc/squid3/squid.conf"
- else
- msg -ama "$(fun_trans "Su sistema no tiene un squid")!" && return 1
- fi
- teste_cache="#CACHE_DO_SQUID"
- if [[ $(grep -c "^$teste_cache" $squid_var) -gt 0 ]]; then
- [[ -e ${squid_var}.bakk ]] && {
- msg -ama "$(fun_trans "Cache squid identificado, eliminando")!"
- mv -f ${squid_var}.bakk $squid_var
- msg -ama "$(fun_trans "Cache squid Removido")!"
- service squid restart >/dev/null 2>&1 &
- service squid3 restart >/dev/null 2>&1 &
- return 0
- }
- fi
- msg -ama "$(fun_trans "Aplicando Cache Squid")!"
- msg -bar
- _tmp="#CACHE_DO_SQUID\ncache_mem 200 MB\nmaximum_object_size_in_memory 32 KB\nmaximum_object_size 1024 MB\nminimum_object_size 0 KB\ncache_swap_low 90\ncache_swap_high 95"
- [[ "$squid_var" = "/etc/squid/squid.conf" ]] && _tmp+="\ncache_dir ufs /var/spool/squid 100 16 256\naccess_log /var/log/squid/access.log squid" || _tmp+="\ncache_dir ufs /var/spool/squid3 100 16 256\naccess_log /var/log/squid3/access.log squid"
- while read s_squid; do
- [[ "$s_squid" != "cache deny all" ]] && _tmp+="\n${s_squid}"
- done <$squid_var
- cp ${squid_var} ${squid_var}.bakk
- echo -e "${_tmp}" >$squid_var
- msg -ama "$(fun_trans "Cache Aplicado con Exito")!"
- service squid restart >/dev/null 2>&1 &
- service squid3 restart >/dev/null 2>&1 &
- }
- oracl() {
- clear
- msg -bar
- msg -tit
- msg -verm " FIREWALLD"
- msg -ama " ESTA HERRAMIENTA ES PARA LAS VPS ORACLE/AWS/AZR"
- msg -ama " TAMBIEN PARA OTRAS VPS QUE SON NECESARIO A UTILIZAR ESTA OPCION"
- echo -ne " Desea Continuar? [S/N]: "
- read x
- [[ $x = @(n|N) ]] && msg -bar && return
- msg -bar
- sudo apt update -y &>/dev/null
- sudo apt install firewalld -y &>/dev/null
- sudo apt install apache2 &>/dev/null
- sudo firewall-cmd --zone=public --permanent --add-port=80/tcp
- sudo firewall-cmd --zone=public --permanent --add-port=81/tcp
- sudo firewall-cmd --zone=public --permanent --add-port=90/tcp
- sudo firewall-cmd --zone=public --permanent --add-port=110/tcp
- sudo firewall-cmd --zone=public --permanent --add-port=143/tcp
- sudo firewall-cmd --zone=public --permanent --add-port=442/tcp
- sudo firewall-cmd --zone=public --permanent --add-port=443/tcp
- sudo firewall-cmd --zone=public --permanent --add-port=444/tcp
- sudo firewall-cmd --zone=public --permanent --add-port=8080/tcp
- sudo firewall-cmd --zone=public --permanent --add-port=8081/tcp
- sudo firewall-cmd --zone=public --permanent --add-port=5300/udp
- sudo firewall-cmd --zone=public --permanent --add-port=7200/udp
- sudo firewall-cmd --zone=public --permanent --add-port=7300/udp
- sudo firewall-cmd --reload
- sudo firewall-cmd --zone=public --list-ports &>/dev/null
- msg -azu " FIX AGREGADO"
- }
- cache() {
- clear
- msg -bar
- msg -verm " LIBERANDO CACHÉ/RAM"
- msg -bar
- me() {
- echo 3 >/proc/sys/vm/drop_caches &>/dev/null
- sysctl -w vm.drop_caches=3 &>/dev/null
- apt-get autoclean -y &>/dev/null
- apt-get clean -y &>/dev/null
- }
- me &>/dev/null && msg -ama " REFRESCANDO RAM" | pv -qL20
- sleep 2s
- if [[ ! -z $(crontab -l | grep -w "vm.drop_caches=3") ]]; then
- msg -azu " Auto limpieza programada cada $(msg -verd "[ $(crontab -l | grep -w "vm.drop_caches=3" | awk '{print $2}' | sed $'s/[^[:alnum:]\t]//g')HS ]")"
- msg -bar
- while :; do
- echo -ne "$(msg -azu " Detener Auto Limpieza [S/N]: ")" && read t_ram
- tput cuu1 && tput dl1
- case $t_ram in
- s | S)
- crontab -l >/root/cron && sed -i '/vm.drop_caches=3/ d' /root/cron && crontab /root/cron && rm /root/cron
- msg -azu " Auto-Limpeza Detenida!" && msg -bar && sleep 2
- return 1
- ;;
- n | N) return 1 ;;
- *) menu3 ;;
- esac
- done
- fi
- echo -ne "$(msg -azu "Desea programar El Auto-Limpieza [s/n]:") "
- read c_ram
- if [[ $c_ram = @(s|S|y|Y) ]]; then
- tput cuu1 && tput dl1
- echo -ne "$(msg -azu " PONGA UN NÚMERO, EJEMPLO [1-12HORAS]:") "
- read ram_c
- if [[ $ram_c =~ ^[0-9]+$ ]]; then
- crontab -l >/root/cron
- echo "0 */$ram_c * * * sudo sysctl -w vm.drop_caches=3 > /dev/null 2>&1" >>/root/cron
- crontab /root/cron
- rm /root/cron
- tput cuu1 && tput dl1
- msg -azu " Auto-Limpieza programada cada: $(msg -verd "${ram_c} HORAS")" && msg -bar && sleep 2
- else
- tput cuu1 && tput dl1
- msg -verm2 " ingresar solo numeros entre 1 y 12"
- sleep 2
- msg -bar
- fi
- fi
- return 1
- }
- pidr_inst() {
- proto="dropbear python stunnel4 v2ray node badvpn squid openvpn dns-serve ssserver ss-server"
- portas=$(lsof -V -i -P -n | grep -v "ESTABLISHED" | grep -v "COMMAND")
- for list in $proto; do
- case $list in
- dropbear | python | stunnel4 | v2ray | node | badvpn | squid | openvpn | ssserver | ss-server)
- portas2=$(echo $portas | grep -w "LISTEN" | grep -w "$list")
- [[ $(echo "${portas2}" | grep "$list") ]] && inst[$list]="\033[1;32m[ON] " || inst[$list]="\033[1;31m[OFF]"
- ;;
- dns-serve)
- portas2=$(echo $portas | grep -w "$list")
- [[ $(echo "${portas2}" | grep "$list") ]] && inst[$list]="\033[1;32m[ON] " || inst[$list]="\033[1;31m[OFF]"
- ;;
- esac
- done
- }
- menu_func() {
- local options=${#@}
- local array
- for ((num = 1; num <= $options; num++)); do
- echo -ne " $(msg -verd "\e[1;93m[\e[92m$num\e[93m]") $(msg -verm2 "➛ ") "
- array=(${!num})
- case ${array[0]} in
- "-vd") msg -verd "\033[1;33m[!]\033[1;32m $(fun_trans "${array[@]:1}")" | sed ':a;N;$!ba;s/\n/ /g' ;;
- "-vm") msg -verm2 "\033[1;33m[!]\033[1;31m $(fun_trans "${array[@]:1}")" | sed ':a;N;$!ba;s/\n/ /g' ;;
- "-fi") msg -azu "$(fun_trans "${array[@]:2}") ${array[1]}" | sed ':a;N;$!ba;s/\n/ /g' ;;
- *) msg -azu "$(fun_trans "${array[@]}")" | sed ':a;N;$!ba;s/\n/ /g' ;;
- esac
- done
- }
- selection_fun() {
- local selection="null"
- local range
- for ((i = 0; i <= $1; i++)); do range[$i]="$i "; done
- while [[ ! $(echo ${range[*]} | grep -w "$selection") ]]; do
- echo -ne "\033[1;37m$(fun_trans " ► Selecione una Opcion"): " >&2
- read selection
- tput cuu1 >&2 && tput dl1 >&2
- done
- echo $selection
- }
- export -f msg
- export -f selection_fun
- export -f fun_trans
- export -f menu_func
- export -f meu_ip
- export -f fun_ip
- export -f lacasita
- clear
- sudo sync
- sudo sysctl -w vm.drop_caches=3 >/dev/null 2>&1
- clear
- clear
- msg -bar
- msg -tit
- menu_info
- msg -bar
- title=$(echo -e "\033[1;96m$(cat ${SCPdir}/message.txt)")
- printf "%*s\n" $((($(echo -e "$title" | wc -c) + 55) / 2)) "$title"
- msg -bar
- monservi_fun() {
- clear
- clear
- monssh() {
- sed -i "57d" /bin/monitor.sh
- sed -i '57i EstadoServicio ssh' /bin/monitor.sh
- }
- mondropbear() {
- sed -i "59d" /bin/monitor.sh
- sed -i '59i EstadoServicio dropbear' /bin/monitor.sh
- }
- monssl() {
- sed -i "61d" /bin/monitor.sh
- sed -i '61i EstadoServicio stunnel4' /bin/monitor.sh
- }
- monsquid() {
- sed -i "63d" /bin/monitor.sh
- sed -i '63i [[ $(EstadoServicio squid) ]] && EstadoServicio squid3' /bin/monitor.sh
- }
- monapache() {
- sed -i "65d" /bin/monitor.sh
- sed -i '65i EstadoServicio apache2' /bin/monitor.sh
- }
- monv2ray() {
- sed -i "55d" /bin/monitor.sh
- sed -i '55i EstadoServicio v2ray' /bin/monitor.sh
- }
- msg -bar
- msg -tit
- echo -e "\033[1;32m MONITOR DE SERVICIONS PRINCIPALES"
- PIDVRF3="$(ps aux | grep "${SCPdir}/menu monitorservi" | grep -v grep | awk '{print $2}')"
- PIDVRF5="$(ps aux | grep "${SCPdir}/menu moni2" | grep -v grep | awk '{print $2}')"
- if [[ -z $PIDVRF3 ]]; then
- sed -i '5a\screen -dmS very3 /etc/VPS-MX/menu monitorservi' /bin/resetsshdrop
- msg -bar
- echo -e "\033[1;34m ¿Monitorear Protocolo SSH/SSHD?"
- msg -bar
- read -p " [ s | n ]: " monssh
- sed -i "57d" /bin/monitor.sh
- sed -i '57i #EstadoServicio ssh' /bin/monitor.sh
- [[ "$monssh" = "s" || "$monssh" = "S" ]] && monssh
- msg -bar
- echo -e "\033[1;34m ¿Monitorear Protocolo DROPBEAR?"
- msg -bar
- read -p " [ s | n ]: " mondropbear
- sed -i "59d" /bin/monitor.sh
- sed -i '59i #EstadoServicio dropbear' /bin/monitor.sh
- [[ "$mondropbear" = "s" || "$mondropbear" = "S" ]] && mondropbear
- msg -bar
- echo -e "\033[1;34m ¿Monitorear Protocolo SSL?"
- msg -bar
- read -p " [ s | n ]: " monssl
- sed -i "61d" /bin/monitor.sh
- sed -i '61i #EstadoServicio stunnel4' /bin/monitor.sh
- [[ "$monssl" = "s" || "$monssl" = "S" ]] && monssl
- msg -bar
- echo -e "\033[1;34m ¿Monitorear Protocolo SQUID?"
- msg -bar
- read -p " [ s | n ]: " monsquid
- sed -i "63d" /bin/monitor.sh
- sed -i '63i #[[ $(EstadoServicio squid) ]] && EstadoServicio squid3' /bin/monitor.sh
- [[ "$monsquid" = "s" || "$monsquid" = "S" ]] && monsquid
- msg -bar
- echo -e "\033[1;34m ¿Monitorear Protocolo APACHE?"
- msg -bar
- read -p " [ s | n ]: " monapache
- sed -i "65d" /bin/monitor.sh
- sed -i '65i #EstadoServicio apache2' /bin/monitor.sh
- [[ "$monapache" = "s" || "$monapache" = "S" ]] && monapache
- msg -bar
- echo -e "\033[1;34m ¿Monitorear Protocolo V2RAY?"
- msg -bar
- read -p " [ s | n ]: " monv2ray
- sed -i "55d" /bin/monitor.sh
- sed -i '55i #EstadoServicio v2ray' /bin/monitor.sh
- [[ "$monv2ray" = "s" || "$monv2ray" = "S" ]] && monv2ray
- cd ${SCPdir}
- screen -dmS very3 ${SCPdir}/menu monitorservi
- screen -dmS monis2 ${SCPdir}/menu moni2
- else
- for pid in $(echo $PIDVRF3); do
- kill -9 $pid &>/dev/null
- sed -i "6d" /bin/resetsshdrop
- done
- for pid in $(echo $PIDVRF5); do
- kill -9 $pid &>/dev/null
- done
- fi
- msg -bar
- echo -e " Puedes Monitorear desde:\n \033[1;32m http://$(meu_ip):81/monitor.html"
- msg -bar
- [[ -z ${VERY3} ]] && monitorservi="\033[1;32m ACTIVADO " || monitorservi="\033[1;31m DESACTIVADO "
- echo -e " $monitorservi -- CON EXITO"
- msg -bar
- }
- monitor_auto() {
- while true; do
- monitor.sh 2>/dev/null
- sleep 90s
- done
- }
- if [[ "$1" = "monitorservi" ]]; then
- monitor_auto
- exit
- fi
- pid_kill() {
- [[ -z $1 ]] && refurn 1
- pids="$@"
- for pid in $(echo $pids); do
- kill -9 $pid &>/dev/null
- done
- }
- monitorport_fun() {
- while true; do
- pidproxy3=$(ps x | grep "PDirect.py" | grep -v "grep" | awk -F "pts" '{print $1}') && [[ ! -z $pidproxy3 ]] && pid_kill $pidproxy3
- pidpyssl=$(ps x | grep "python.py" | grep -v "grep" | awk -F "pts" '{print $1}') && [[ ! -z $pidpyssl ]] && pid_kill $pidpyssl
- sleep 6h
- done
- }
- if [[ "$1" = "moni2" ]]; then
- monitorport_fun
- exit
- fi
- SSHN="$(grep -c home /etc/passwd)"
- echo "${SSHN}" | bc >/etc/VPS-MX/controlador/SSH20.log
- SSH3="$(less /etc/VPS-MX/controlador/SSH20.log)"
- SSH4="$(echo $SSH3)"
- user_info=$(cd /usr/local/shadowsocksr &>/dev/null && python mujson_mgr.py -l)
- user_total=$(echo "${user_info}" | wc -l)
- [[ ! -e /etc/VPS-MX/RegV2ray ]] && touch /etc/VPS-MX/RegV2ray
- vray=$(cat /etc/VPS-MX/RegV2ray | wc -l)
- on="\033[1;92m[ON]" && off="\033[1;31m[OFF]"
- echo -e "\033[1;97m SSH REG:\033[1;92m $SSH4 \033[1;97m SS-SSRR REG:\033[1;92m $user_total \033[1;97m V2RAY REG:\e[32m $vray"
- VERY="$(ps aux | grep "${SCPusr}/usercodes verificar" | grep -v grep)"
- VERY2="$(ps aux | grep "${SCPusr}/usercodes desbloqueo" | grep -v grep)"
- VERY3="$(ps aux | grep "${SCPdir}/menu monitorservi" | grep -v grep)"
- limseg="$(less /etc/VPS-MX/controlador/tiemlim.log)"
- [[ -z ${VERY} ]] && verificar="\033[1;31m[OFF]" || verificar="\033[1;32m[ON] "
- [[ -z ${VERY2} ]] && desbloqueo="\033[1;31m[OFF]" || desbloqueo="\033[1;32m[ON] "
- [[ -z ${VERY3} ]] && monitorservi="\033[1;31m[OFF]" || monitorservi="\033[1;32m[ON]"
- [[ -e ${SCPdir}/USRonlines ]] && msg -bar && msg -ne "\033[1;97m LIMITADOR:\033[1;92m$verificar \033[1;97m AUTO-DESBLOQUEO:\033[1;92m$desbloqueo \e[1;97mMONITOR:\e[34m${limseg}s\n \033[1;32mCONECTADOS: " && echo -ne "\033[1;97m$(cat ${SCPdir}/USRonlines) "
- [[ -e ${SCPdir}/USRexpired ]] && msg -ne " EXPIRADOS: " && echo -ne "\033[1;97m$(cat ${SCPdir}/USRexpired) " && msg -ne " \033[1;95m BLOQUEADOS: " && echo -e "\033[1;97m$(cat ${SCPdir}/USRbloqueados)" #\n\033[1;97m ACTULIZACION DE MONITOR CADA: \033[1;34m $limseg s"
- monhtop() {
- clear
- msg -bar
- msg -tit
- echo -ne " \033[1;93m MONITOR DE PROCESOS HTOP\n"
- msg -bar
- msg -bra " RECUERDA SALIR CON : \033[1;96m CTRL + C o FIN + F10 "
- [[ $(dpkg --get-selections | grep -w "htop" | head -1) ]] || apt-get install htop -y &>/dev/null
- msg -bar
- read -t 10 -n 1 -rsp $'\033[1;39m Preciona Enter Para continuar\n'
- clear
- sudo htop
- msg -bar
- echo -e "\e[97m \033[1;41m| #-#-► SCRIPT VPS•MX ◄-#-# | \033[1;49m\033[1;49m \033[1;31m[ \033[1;32m $vesaoSCT "
- echo -ne " \033[1;93m MONITOR DE PROCESOS HTOP\n"
- msg -bar
- echo -e "\e[97m FIN DEL MONITOR"
- msg -bar
- }
- [[ $(ps x | grep v2ray | grep -v grep | awk '{print $1}') ]] && vra=$on || vra=$off
- msg -bar
- msg -bar3
- on="\e[1;32m[ON]" && off="\e[1;31m[OFF]"
- echo -e " \e[1;93m[\e[92m1\e[93m] $(msg -verm2 "➛ ") $(msg -azu "ADMINISTRAR CUENTAS | SSH/SSL/DROPBEAR")"
- echo -e " \e[1;93m[\e[92m2\e[93m] $(msg -verm2 "➛ ") $(msg -azu "ADMINISTRAR CUENTAS | SS/SSRR")"
- echo -e " \e[1;93m[\e[92m3\e[93m] $(msg -verm2 "➛ ") $(msg -azu "ADMINISTRAR CUENTAS | V2RAY --> $vra")"
- echo -e " \e[1;93m[\e[92m4\e[93m] $(msg -verm2 "➛ ") \e[1;31m\033[47mPROTOCOLOS\e[0m \e[93m|| \e[1;37m\e[41mHERRAMIENTAS\e[0m"
- echo -e " \e[1;93m[\e[92m5\e[93m] $(msg -verm2 "➛ ") $(msg -azu "MONITOR DE PROTOCOLOS --------> ${monitorservi}")"
- echo -e " \e[1;93m[\e[92m6\e[93m] $(msg -verm2 "➛ ") $(msg -azu "AUTO INICIAR SCRIPT ----------> ${AutoRun}")"
- msg -bar
- echo -e " \e[1;93m[\e[92m7\e[93m] \e[97m$(msg -verm2 "➛ ") $(msg -verd "ACTUALIZAR") \e[1;93m [\e[92m8\e[93m]\e[97m$(msg -verm2 "➛ ")\033[1;31mDESINSTALAR \e[1;93m[\e[92m0\e[93m]$(msg -verm2 "➛ ") $(msg -bra "\e[97m\033[1;41mSALIR")"
- msg -bar
- selection=$(selection_fun 13)
- case ${selection} in
- 1) ${SCPusr}/usercodes "${idioma}" ;;
- 2) ${SCPinst}/C-SSR.sh ;;
- 3) ${SCPinst}/v2ray.sh ;;
- 4) menu3 ;;
- 5) monservi_fun ;;
- 6) fun_autorun ;;
- 7) atualiza_fun ;;
- 8) remove_script ;;
- 0) cd $HOME && exit 0 ;;
- esac
- msg -ne "Enter Para Continuar" && read enter
- ${SCPdir}/menu
|