#!/bin/bash clear clear msg -bar NOM=`less /etc/VPS-MX/controlador/nombre.log` > /dev/null 2>&1 NOM1=`echo $NOM` > /dev/null 2>&1 IDB=`less /etc/VPS-MX/controlador/IDT.log` > /dev/null 2>&1 IDB1=`echo $IDB` > /dev/null 2>&1 declare -A TIMEUS SCPdir="/etc/VPS-MX" SCPdir2="${SCPdir}/herramientas" SCPusr="${SCPdir}/controlador" MyPID="${SCPusr}/pid-vps-mx" MyTIME="${SCPusr}/time-vps-mx" USRdatabase="${SCPdir}/VPS-MXuser" USRdatabaseh="${SCPdir}/User-HWID" tokens="${SCPdir}/User-TOKEN" VERY="$(ps aux|grep "${SCPusr}/usercodes verificar"| grep -v grep)" VERY2="$(ps aux|grep "${SCPusr}/usercodes desbloqueo"| grep -v grep)" [[ -e ${MyPID} ]] && source ${MyPID} || touch ${MyPID} [[ -e ${MyTIME} ]] && source ${MyTIME} || touch ${MyTIME} [[ ! -e ${USRdatabase} ]] && touch ${USRdatabase} sort ${USRdatabase} | uniq > ${USRdatabase}tmp mv -f ${USRdatabase}tmp ${USRdatabase} newclient () { usermod -p $(openssl passwd -1 $2) $1 while [[ ${newfile} != @(s|S|y|Y|n|N) ]]; do msg -bar read -p "Crear Archivo OpenVPN? [S/N]: " -e -i S newfile tput cuu1 && tput dl1 done if [[ ${newfile} = @(s|S) ]]; then rm -rf /etc/openvpn/easy-rsa/pki/reqs/$1.req rm -rf /etc/openvpn/easy-rsa/pki/issued/$1.crt rm -rf /etc/openvpn/easy-rsa/pki/private/$1.key cd /etc/openvpn/easy-rsa/ ./easyrsa build-client-full $1 nopass > /dev/null 2>&1 cd cp /etc/openvpn/client-common.txt ~/$1.ovpn echo "" >> ~/$1.ovpn cat /etc/openvpn/easy-rsa/pki/ca.crt >> ~/$1.ovpn echo "" >> ~/$1.ovpn echo "" >> ~/$1.ovpn cat /etc/openvpn/easy-rsa/pki/issued/$1.crt >> ~/$1.ovpn echo "" >> ~/$1.ovpn echo "" >> ~/$1.ovpn cat /etc/openvpn/easy-rsa/pki/private/$1.key >> ~/$1.ovpn echo "" >> ~/$1.ovpn echo "" >> ~/$1.ovpn cat /etc/openvpn/ta.key >> ~/$1.ovpn echo "" >> ~/$1.ovpn while [[ ${ovpnauth} != @(s|S|y|Y|n|N) ]]; do read -p "$(fun_trans "Colocar autenticacion de usuario en el archivo")? [S/N]: " -e -i S ovpnauth tput cuu1 && tput dl1 done [[ ${ovpnauth} = @(s|S) ]] && sed -i "s;auth-user-pass;\n$1\n$2\n;g" ~/$1.ovpn cd $HOME zip ./$1.zip ./$1.ovpn > /dev/null 2>&1 rm ./$1.ovpn > /dev/null 2>&1 echo -e "\033[1;31m$(fun_trans "Archivo creado"): ($HOME/$1.zip)" fi } unlockall2 () { for user in $(cat /etc/passwd |awk -F : '$3 > 900 {print $1}' |grep -v "rick" |grep -vi "nobody") do userpid=$(ps -u $user |awk {'print $1'}) usermod -U $user &>/dev/null done } eliminar_all () { clear clear msg -bar msg -tit echo -e "\033[1;31m BORRAR TODOS LOS USUARIOS REGISTRADOS" msg -bar read -p " ►► Enter para Continuar o CTRL + C Cancelar ◄◄" echo "" service dropbear stop &>/dev/null service sshd stop &>/dev/null service ssh stop &>/dev/null service stunnel4 stop &>/dev/null service squid stop &>/dev/null for user in $(cat /etc/passwd |awk -F : '$3 > 900 {print $1}' |grep -v "rick" |grep -vi "nobody") do userpid=$(ps -u $user |awk {'print $1'}) kill "$userpid" 2>/dev/null userdel $user echo -e "\033[1;32mUSUARIO:\033[1;33m $user \033[1;31mEliminado" done rm -rf ${SCPdir}/VPS-MXuser service sshd restart &>/dev/null service ssh restart &>/dev/null service dropbear start &>/dev/null service stunnel4 start &>/dev/null service squid restart &>/dev/null rm -rf ${SCPdir}/VPS-MX-userlock &>/dev/null rm -rf /etc/VPS-MX/controlador/Limiter.log &>/dev/null unlockall2 msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } reset_contador () { clear clear msg -bar msg -tit echo -e "\033[1;33m REINICIAR CONTADOR DE BLOQUEOS" msg -bar echo -e "\033[1;97m !! Usar unicamente cuando en el apartado del contador\nmarque alguna cantidad erronea. ¡¡" echo "" echo -e "\033[1;91m ## Cancelar Precione CTRL+C" msg -bar read -p " ►► Presione enter para continuar ◄◄" rm -rf /etc/VPS-MX/VPS-MX-userlock rm -rf /etc/VPS-MX/controlador/Limiter.log unlockall2 msg -bar echo -e "\033[1;92m ¡¡CONTADORES REINICIADOS!!" msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } SPR & droppids () { local pids 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 dropbear) [[ -z $DPB ]] && local DPB="\033[1;31m DROPBEAR: \033[1;32m" DPB+="$Port ";; esac done <<< "${portasVAR}" [[ ! -z $DPB ]] && echo -e $DPB local port_dropbear="$DPB" cat /var/log/auth.log|tail -1000 > /var/log/authday.log local log=/var/log/authday.log local loginsukses='Password auth succeeded' [[ -z $port_dropbear ]] && return 1 for port in `echo $port_dropbear`; do for pidx in $(ps ax |grep dropbear |grep "$port" |awk -F" " '{print $1}'); do pids="${pids}$pidx\n" done done for pid in `echo -e "$pids"`; do pidlogs=`grep $pid $log |grep "$loginsukses" |awk -F" " '{print $3}'` i=0 for pidend in $pidlogs; do let i++ done if [[ $pidend ]]; then login=$(grep $pid $log |grep "$pidend" |grep "$loginsukses") PID=$pid user=`echo $login |awk -F" " '{print $10}' | sed -r "s/'//g"` waktu=$(echo $login |awk -F" " '{print $2"-"$1,$3}') [[ -z $user ]] && continue echo "$user|$PID|$waktu" fi done } block_userfun () { local USRloked="/etc/VPS-MX/VPS-MX-userlock" local LIMITERLOG="${USRdatabase}/Limiter.log" local LIMITERLOG2="${USRdatabase}/Limiter2.log" if [[ $2 = "-loked" ]]; then [[ $(cat ${USRloked}|grep -w "$1") ]] && return 1 echo " $1 (BLOCK-MULTILOGIN) $(date +%r--%d/%m/%y)" limseg="$(less /etc/VPS-MX/controlador/tiemdes.log)" KEY="2012880601:AAEJ3Kk18PGDzW57LpTMnVMn_pQYQKW3V9w" URL="https://api.telegram.org/bot$KEY/sendMessage" MSG="⚠️ AVISO DE VPS: $NOM1 ⚠️ 🔹 CUENTA: $1 ❗️📵 BLOCK FIJO/TEMPORAL 📵❗️ 🔓( AUTOUNLOCK EN $limseg SEGUNDOS) 🔓" curl -s --max-time 10 -d "chat_id=$IDB1&disable_web_page_preview=1&text=$MSG" $URL &>/dev/null pkill -u $1 &>/dev/null fi if [[ $(cat ${USRloked}|grep -w "$1") ]]; then usermod -U "$1" &>/dev/null [[ -e ${USRloked} ]] && { newbase=$(cat ${USRloked}|grep -w -v "$1") [[ -e ${USRloked} ]] && rm ${USRloked} for value in `echo ${newbase}`; do echo $value >> ${USRloked} done } [[ -e ${LIMITERLOG} ]] && [[ $(cat ${LIMITERLOG}|grep -w "$1") ]] && { newbase=$(cat ${LIMITERLOG}|grep -w -v "$1") [[ -e ${LIMITERLOG} ]] && rm ${LIMITERLOG} for value in `echo ${newbase}`; do echo $value >> ${LIMITERLOG} echo $value >> ${LIMITERLOG} done } return 1 else usermod -L "$1" &>/dev/null pkill -u $1 &>/dev/null droplim=`droppids|grep -w "$1"|cut -d'|' -f2` kill -9 $droplim &>/dev/null echo $1 >> ${USRloked} return 0 fi } block_user () { clear clear msg -bar local USRloked="/etc/VPS-MX/VPS-MX-userlock" [[ ! -e ${USRloked} ]] && touch ${USRloked} usuarios_ativos=($(mostrar_usuarios)) if [[ -z ${usuarios_ativos[@]} ]]; then msg -tit msg -verm "$(fun_trans " BLOCK/UNBLOCK | Ningun Usuario Registrado")" msg -bar return 1 else msg -tit msg -ama "$(fun_trans " BLOCK/UNBLOCK | UsuariosActivos del Servidor")" msg -bar Numb=0 for us in $(echo ${usuarios_ativos[@]}); do if [[ $(cat ${USRloked}|grep -w "${us}") ]]; then msg -ne "[$Numb] ->" && echo -e "\033[1;33m ${us} \033[1;31m[Loked]" else msg -ne "[$Numb] ->" && echo -e "\033[1;33m ${us} \033[1;32m[Unlocked]" fi let Numb++ done msg -bar fi msg -ama "$(fun_trans "Escriba o Seleccione Un Usuario")" msg -bar unset selection while [[ ${selection} = "" ]]; do echo -ne "\033[1;37mSeleccione: " && read selection tput cuu1 && tput dl1 done if [[ ! $(echo "${selection}" | egrep '[^0-9]') ]]; then usuario_del="${usuarios_ativos[$selection]}" else usuario_del="$selection" fi [[ -z $usuario_del ]] && { msg -verm "$(fun_trans "Error, Usuario Invalido")" msg -bar return 1 } [[ ! $(echo ${usuarios_ativos[@]}|grep -w "$usuario_del") ]] && { msg -verm "$(fun_trans "Error, Usuario Invalido")" msg -bar return 1 } msg -ne "$(fun_trans "Usuario Seleccionado"): " && echo -ne "$usuario_del " block_userfun "$usuario_del" && msg -verm "[$(fun_trans "Bloqueado")]" || msg -verd "[$(fun_trans "Desbloqueado")]" msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } msg -bar3 add_user () { Fecha=`date +%d-%m-%y-%R` [[ $(cat /etc/passwd |grep $1: |grep -vi [a-z]$1 |grep -v [0-9]$1 > /dev/null) ]] && return 1 valid=$(date '+%C%y-%m-%d' -d " +$3 days") && datexp=$(date "+%F" -d " + $3 days") if useradd -M -s /bin/false -e ${valid} -K PASS_MAX_DAYS=$3 -p $(openssl passwd -1 $2) -c sshm,$2 $1 ; then echo "$1|$2|${datexp}|$4" >> ${USRdatabase} msg -verd "$(fun_trans "Usuario Creado con Exito")" else msg -verm2 "$(fun_trans "Error, Usuario no creado")" msg -bar fi } add_hwid () { Fecha=`date +%d-%m-%y-%R` [[ $(cat /etc/passwd |grep $1: |grep -vi [a-z]$1 |grep -v [0-9]$1 > /dev/null) ]] && return 1 valid=$(date '+%C%y-%m-%d' -d " +$3 days") && datexp=$(date "+%F" -d " + $3 days") if useradd -M -s /bin/false -e ${valid} -K PASS_MAX_DAYS=$3 -p $(openssl passwd -1 $2) -c hwid,$1 $2 ; then echo "$1|$2|${datexp}" >> ${USRdatabaseh} msg -verd "$(fun_trans "Usuario Creado con Exito")" else msg -verm2 "$(fun_trans "Error, Usuario no creado")" msg -bar fi } add_token () { Fecha=`date +%d-%m-%y-%R` [[ $(cat /etc/passwd |grep $1: |grep -vi [a-z]$1 |grep -v [0-9]$1 > /dev/null) ]] && return 1 valid=$(date '+%C%y-%m-%d' -d " +$3 days") && datexp=$(date "+%F" -d " + $3 days") if useradd -M -s /bin/false -e ${valid} -K PASS_MAX_DAYS=$3 -p $(openssl passwd -1 $2) -c token,$1 $2 ; then echo "$1|$2|${datexp}" >> ${tokens} msg -verd "$(fun_trans "Usuario Creado con Exito")" else msg -verm2 "$(fun_trans "Error, Usuario no creado")" msg -bar fi } mostrar_usuario(){ for u in `cat /etc/passwd|grep 'home'|grep 'false'|grep -v 'syslog'|grep -w 'hwid'|awk -F ':' '{print $1}'`; do echo "$u" done } mostrar_token(){ for u in `cat /etc/passwd|grep 'home'|grep 'false'|grep -v 'syslog'|grep -w 'token'|awk -F ':' '{print $1}'`; do echo "$u" done } mostrar_all(){ for u in `cat /etc/passwd|grep 'home'|grep 'false'|grep -v 'syslog'|grep -v 'sshm'|grep -w 'hwid'|grep -v 'token'|awk -F ':' '{print $1}'`; do echo "$u" done } mostrar_user(){ for u in `cat /etc/passwd|grep 'home'|grep 'false'|grep -v 'syslog'|grep -w 'sshm'|awk -F ':' '{print $1}'`; do echo "$u" done } new_hwid () { clear clear msg -bar usuarios_ativo=($(cat ${USRdatabaseh}|cut -d'|' -f1)) usuarios_ativos=('' $(mostrar_usuario)) if [[ -z ${usuarios_ativos[@]} ]]; then msg -tit msg -ama " AGREGAR USUARIO HWID| Ningun Usuario Registrado" msg -bar else msg -tit msg -ama " AGREGAR USUARIO HWID| Usuarios Activos en Servidor" msg -bar for us in $(echo ${usuarios_ativos[@]}); do msg -ne " >> Usuario: " && echo "${us}" done msg -bar fi while true; do msg -ne "$(fun_trans "Nombre Del Usuario")" read -p ": " usuario usuario="$(echo $usuario|sed -e 's/[^a-z0-9 -]//ig')" if [[ -z $usuario ]]; then err_fun 1 && continue elif [[ "${#usuario}" -lt "3" ]]; then err_fun 2 && continue elif [[ "${#usuario}" -gt "12" ]]; then err_fun 3 && continue elif [[ "$(echo ${usuarios_ativos[@]}|grep -w "$usuario")" ]]; then err_fun 14 && continue fi break done while true; do msg -ne "$(fun_trans "Ingrese El HWID")" read -p ": " hwid if [[ -z $hwid ]]; then err_fun 4 && continue elif [[ "${#hwid}" -lt "29" ]]; then err_fun 5 && continue elif [[ "${#hwid}" -gt "36" ]]; then err_fun 6 && continue fi break done while true; do msg -ne "$(fun_trans "Tiempo de Duracion")" read -p ": " diasuser if [[ -z "$diasuser" ]]; then err_fun 7 && continue elif [[ "$diasuser" != +([0-9]) ]]; then err_fun 8 && continue elif [[ "$diasuser" -gt "360" ]]; then err_fun 9 && continue fi break done clear echo "" msg -bar add_hwid "${usuario}" "${hwid}" "${diasuser}" msg -ne "$(fun_trans " >> IP"): " && echo -e "$(meu_ip)" msg -ne "$(fun_trans " >> Usuario"): " && echo -e "$usuario" msg -ne "$(fun_trans " >> HWID"): " && echo -e "$hwid" msg -ne "$(fun_trans " >> Dias de Duracion"): " && echo -e "$diasuser" msg -ne "$(fun_trans " >> Fecha de Expiracion"): " && echo -e "$(date "+%F" -d " + $diasuser days")" msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } new_token () { clear clear msg -bar usuarios_ativo=($(cat ${tokens}|cut -d'|' -f1)) usuarios_ativos=('' $(mostrar_token)) if [[ -z ${usuarios_ativos[@]} ]]; then msg -tit msg -ama " AGREGAR USUARIO TOKEN| Ningun Usuario Registrado" msg -bar else msg -tit msg -ama " AGREGAR USUARIO TOKEN| Usuarios Activos en Servidor" msg -bar for us in $(echo ${usuarios_ativos[@]}); do msg -ne " >> Usuario: " && echo "${us}" done msg -bar fi while true; do msg -ne "$(fun_trans "Nombre Del Usuario")" read -p ": " usuario usuario="$(echo $usuario|sed -e 's/[^a-z0-9 -]//ig')" if [[ -z $usuario ]]; then err_fun 1 && continue elif [[ "${#usuario}" -lt "3" ]]; then err_fun 2 && continue elif [[ "${#usuario}" -gt "12" ]]; then err_fun 3 && continue elif [[ "$(echo ${usuarios_ativos[@]}|grep -w "$usuario")" ]]; then err_fun 14 && continue fi break done while true; do msg -ne "$(fun_trans "Ingrese su TOKEN")" read -p ": " toke if [[ -z $toke ]]; then err_fun 4 && continue elif [[ "${#toke}" -lt "6" ]]; then err_fun 5 && continue elif [[ "${#toke}" -gt "36" ]]; then err_fun 6 && continue fi break done while true; do msg -ne "$(fun_trans "Tiempo de Duracion")" read -p ": " diasuser if [[ -z "$diasuser" ]]; then err_fun 7 && continue elif [[ "$diasuser" != +([0-9]) ]]; then err_fun 8 && continue elif [[ "$diasuser" -gt "360" ]]; then err_fun 9 && continue fi break done clear echo "" msg -bar add_token "${usuario}" "${toke}" "${diasuser}" msg -ne "$(fun_trans " >> IP"): " && echo -e "$(meu_ip)" msg -ne "$(fun_trans " >> Usuario"): " && echo -e "$usuario" msg -ne "$(fun_trans " >> TOKEN"): " && echo -e "$toke" msg -ne "$(fun_trans " >> Dias de Duracion"): " && echo -e "$diasuser" msg -ne "$(fun_trans " >> Fecha de Expiracion"): " && echo -e "$(date "+%F" -d " + $diasuser days")" msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } renew_user_fun () { datexp=$(date "+%F" -d " + $2 days") && valid=$(date '+%C%y-%m-%d' -d " + $2 days") chage -E $valid $1 2> /dev/null || return 1 [[ -e ${USRdatabase} ]] && { newbase=$(cat ${USRdatabase}|grep -w -v "$1") useredit=$(cat ${USRdatabase}|grep -w "$1") pass=$(echo $useredit|cut -d'|' -f2) limit=$(echo $useredit|cut -d'|' -f4) echo "$1|$pass|${datexp}|$limit" > ${USRdatabase} for value in `echo ${newbase}`; do echo $value >> ${USRdatabase} done } } edit_user_fun () { (echo "$2" ; echo "$2" ) |passwd $1 > /dev/null 2>&1 || return 1 datexp=$(date "+%F" -d " + $3 days") && valid=$(date '+%C%y-%m-%d' -d " + $3 days") chage -E $valid $1 2> /dev/null || return 1 [[ -e ${USRdatabase} ]] && { newbase=$(cat ${USRdatabase}|grep -w -v "$1") echo "$1|$2|${datexp}|$4" > ${USRdatabase} for value in `echo ${newbase}`; do echo $value >> ${USRdatabase} done } || echo "$1|$2|${datexp}|$4" > ${USRdatabase} } rm_user () { userdel --force "$1" &>/dev/null || return 1 sed -i "/$1/d" ${USRdatabase} } rm_hwid () { userdel --force "$1" &>/dev/null || return 1 sed -i "/$1/d" ${USRdatabaseh} } rm_token () { userdel --force "$1" &>/dev/null || return 1 sed -i "/$1/d" ${tokens} } mostrar_usuarios () { for u in `awk -F : '$3 > 900 { print $1 }' /etc/passwd | grep -v "nobody" |grep -vi polkitd |grep -vi system-`; do echo "$u" done } dropbear_pids () { local pids 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 dropbear) [[ -z $DPB ]] && local DPB="" DPB+="$Port ";; esac done <<< "${portasVAR}" [[ ! -z $DPB ]] && echo -e $DPB local port_dropbear="$DPB" cat /var/log/auth.log|tail -1000 > /var/log/authday.log local log=/var/log/authday.log local loginsukses='Password auth succeeded' [[ -z $port_dropbear ]] && return 1 for port in `echo $port_dropbear`; do for pidx in $(ps ax |grep dropbear |grep "$port" |awk -F" " '{print $1}'); do pids="${pids}$pidx\n" done done for pid in `echo -e "$pids"`; do pidlogs=`grep $pid $log |grep "$loginsukses" |awk -F" " '{print $3}'` i=0 for pidend in $pidlogs; do let i++ done if [[ $pidend ]]; then login=$(grep $pid $log |grep "$pidend" |grep "$loginsukses") PID=$pid user=`echo $login |awk -F" " '{print $10}' | sed -r "s/'//g"` waktu=$(echo $login |awk -F" " '{print $2"-"$1,$3}') [[ -z $user ]] && continue echo "$user|$PID|$waktu" fi done } openvpn_pids () { byte () { while read B dummy; do [[ "$B" -lt 1024 ]] && echo "${B} bytes" && break KB=$(((B+512)/1024)) [[ "$KB" -lt 1024 ]] && echo "${KB} Kb" && break MB=$(((KB+512)/1024)) [[ "$MB" -lt 1024 ]] && echo "${MB} Mb" && break GB=$(((MB+512)/1024)) [[ "$GB" -lt 1024 ]] && echo "${GB} Gb" && break echo $(((GB+512)/1024)) terabytes done } for user in $(mostrar_usuarios); do user="$(echo $user|sed -e 's/[^a-z0-9 -]//ig')" [[ ! $(sed -n "/^${user},/p" /etc/openvpn/openvpn-status.log) ]] && continue i=0 unset RECIVED; unset SEND; unset HOUR while read line; do IDLOCAL=$(echo ${line}|cut -d',' -f2) RECIVED+="$(echo ${line}|cut -d',' -f3)+" SEND+="$(echo ${line}|cut -d',' -f4)+" DATESEC=$(date +%s --date="$(echo ${line}|cut -d',' -f5|cut -d' ' -f1,2,3,4)") TIMEON="$(($(date +%s)-${DATESEC}))" MIN=$(($TIMEON/60)) && SEC=$(($TIMEON-$MIN*60)) && HOR=$(($MIN/60)) && MIN=$(($MIN-$HOR*60)) HOUR+="${HOR}h:${MIN}m:${SEC}s\n" let i++ done <<< "$(sed -n "/^${user},/p" /etc/openvpn/openvpn-status.log)" RECIVED=$(echo $(echo ${RECIVED}0|bc)|byte) SEND=$(echo $(echo ${SEND}0|bc)|byte) HOUR=$(echo -e $HOUR|sort -n|tail -1) echo -e "$user|$i|$RECIVED|$SEND|$HOUR" done } err_fun () { case $1 in 1)msg -verm "$(fun_trans "Usuario Nulo")"; sleep 2s; tput cuu1; tput dl1; tput cuu1; tput dl1;; 2)msg -verm "$(fun_trans "Usuario con nombre muy corto")"; sleep 2s; tput cuu1; tput dl1; tput cuu1; tput dl1;; 3)msg -verm "$(fun_trans "Usuario con nombre muy grande")"; sleep 2s; tput cuu1; tput dl1; tput cuu1; tput dl1;; 4)msg -verm "$(fun_trans "Contraseña Nula")"; sleep 2s; tput cuu1; tput dl1; tput cuu1; tput dl1;; 5)msg -verm "$(fun_trans "Contraseña muy corta")"; sleep 2s; tput cuu1; tput dl1; tput cuu1; tput dl1;; 6)msg -verm "$(fun_trans "Contraseña muy grande")"; sleep 2s; tput cuu1; tput dl1; tput cuu1; tput dl1;; 7)msg -verm "$(fun_trans "Duracion Nula")"; sleep 2s; tput cuu1; tput dl1; tput cuu1; tput dl1;; 8)msg -verm "$(fun_trans "Duracion invalida utilize numeros")"; sleep 2s; tput cuu1; tput dl1; tput cuu1; tput dl1;; 9)msg -verm "$(fun_trans "Duracion maxima y de un año")"; sleep 2s; tput cuu1; tput dl1; tput cuu1; tput dl1;; 11)msg -verm "$(fun_trans "Limite Nulo")"; sleep 2s; tput cuu1; tput dl1; tput cuu1; tput dl1;; 12)msg -verm "$(fun_trans "Limite invalido utilize numeros")"; sleep 2s; tput cuu1; tput dl1; tput cuu1; tput dl1;; 13)msg -verm "$(fun_trans "Limite maximo de 999")"; sleep 2s; tput cuu1; tput dl1; tput cuu1; tput dl1;; 14)msg -verm "$(fun_trans "Usuario Ya Existe")"; sleep 2s; tput cuu1; tput dl1; tput cuu1; tput dl1;; 15)msg -verm "$(fun_trans "la contraseña que ingreso ya existe,deve de ingresarlo diferente o igual que el nombre del usuario")"; sleep 2s; tput cuu1; tput dl1; tput cuu1; tput dl1;; esac } new_user () { clear clear msg -bar usuarios_ativos=('' $(mostrar_user)) usuarios_pass=$(cat ${USRdatabase}|cut -d'|' -f2) if [[ -z ${usuarios_ativos[@]} ]]; then msg -tit msg -ama " AGREGAR USUARIO | Ningun Usuario Registrado" msg -bar else msg -tit msg -ama " AGREGAR USUARIO | Usuarios Activos en Servidor" msg -bar for us in $(echo ${usuarios_ativos[@]}); do msg -ne " >> Usuario: " && echo "${us}" done msg -bar fi while true; do msg -ne "$(fun_trans "Nombre Del Nuevo Usuario")" read -p ": " nomeuser nomeuser="$(echo $nomeuser|sed -e 's/[^a-z0-9 -]//ig')" if [[ -z $nomeuser ]]; then err_fun 1 && continue elif [[ "${#nomeuser}" -lt "4" ]]; then err_fun 2 && continue elif [[ "${#nomeuser}" -gt "24" ]]; then err_fun 3 && continue elif [[ "$(echo ${usuarios_ativos[@]}|grep -w "$nomeuser")" ]]; then err_fun 14 && continue fi break done while true; do msg -ne "$(fun_trans "Contraseña Del Nuevo Usuario")" read -p ": " senhauser if [[ -z $senhauser ]]; then err_fun 4 && continue elif [[ "${#senhauser}" -lt "6" ]]; then err_fun 5 && continue elif [[ "${#senhauser}" -gt "20" ]]; then err_fun 6 && continue elif [[ "$(echo ${usuarios_pass[@]}|grep -w "$senhauser")" ]]; then err_fun 15 && continue fi break done while true; do msg -ne "$(fun_trans "Tiempo de Duracion del Nuevo Usuario")" read -p ": " diasuser if [[ -z "$diasuser" ]]; then err_fun 7 && continue elif [[ "$diasuser" != +([0-9]) ]]; then err_fun 8 && continue elif [[ "$diasuser" -gt "360" ]]; then err_fun 9 && continue fi break done while true; do msg -ne "$(fun_trans "Limite de Conexiones del Nuevo Usuario")" read -p ": " limiteuser if [[ -z "$limiteuser" ]]; then err_fun 11 && continue elif [[ "$limiteuser" != +([0-9]) ]]; then err_fun 12 && continue elif [[ "$limiteuser" -gt "999" ]]; then err_fun 13 && continue fi break done echo "" clear add_user "${nomeuser}" "${senhauser}" "${diasuser}" "${limiteuser}" #&& msg -ama "$(fun_trans " Usuario Creado con Exito")" || msg -verm "$(fun_trans " Error, Usuario no creado")" msg -bar msg -ne "$(fun_trans " >> IP del Servidor"): " && echo -e "$(meu_ip)" msg -ne "$(fun_trans " >> Usuario"): " && echo -e "$nomeuser" msg -ne "$(fun_trans " >> Contraseña"): " && echo -e "$senhauser" msg -ne "$(fun_trans " >> Dias de Duracion"): " && echo -e "$diasuser" msg -ne "$(fun_trans " >> Fecha de Expiracion"): " && echo -e "$(date "+%F" -d " + $diasuser days")" msg -ne "$(fun_trans " >> Limite de Conexion"): " && echo -e "$limiteuser" [[ $(dpkg --get-selections|grep -w "openvpn"|head -1) ]] && [[ -e /etc/openvpn/openvpn-status.log ]] && newclient "$nomeuser" "$senhauser" msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } menu_crearuser(){ clear msg -bar msg -tit msg -ama " \e[1;33m[1] \e[37mCREAR CUENTA NORMAL \e[0m \n \e[1;33m[2] \e[37mCREAR CUENTA HWID \e[0m\n \e[1;33m[3] \e[37mCREAR CUENTA TOKEN \e[0m\n \e[1;31m[0] \e[1;37m<- VOLVER" msg -bar read -p " $(echo -e "\e[1;37mSeleccione Una Opcion [1/3]:\e[1;33m") " cuen case $cuen in 1)new_user;; 2)new_hwid;; 3)new_token;; 0) ;; esac } remove_user () { clear clear msg -bar usuarios_ativos=('' $(mostrar_user)) msg -ama "$(fun_trans "REMOVER USUARIOS")" msg -bar data_user msg -ama "$(fun_trans "Escriba o Seleccione un Usuario")" msg -bar unset selection while [[ -z ${selection} ]]; do msg -azu "$(fun_trans "Seleccione Una Opcion"): " && read selection tput cuu1 && tput dl1 done [[ ${selection} = "0" ]] && return if [[ ! $(echo "${selection}" | egrep '[^0-9]') ]]; then usuario_del="${usuarios_ativos[$selection]}" else usuario_del="$selection" fi [[ -z $usuario_del ]] && { msg -verm "$(fun_trans "Error, Usuario Invalido")" msg -bar return 1 } [[ ! $(echo ${usuarios_ativos[@]}|grep -w "$usuario_del") ]] && { msg -verm "$(fun_trans "Error, Usuario Invalido")" msg -bar return 1 } msg -ama "$(fun_trans "Usuario Seleccionado"): $usuario_del" pkill -u $usuario_del droplim=`droppids|grep -w "$usuario_del"|awk '{print $2}'` kill -9 $droplim &>/dev/null rm_user "$usuario_del" rm -rf /etc/VPS-MX/VPS-MX-userlock rm -rf /etc/VPS-MX/controlador/Limiter.log unlockall2 msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } remove_allus () { clear clear msg -bar usuarios_ativos=($(mostrar_usuarios)) if [[ -z ${usuarios_ativos[@]} ]]; then msg -tit msg -verm "$(fun_trans " BORAR USUARIO | Ningun usuario registrado")" msg -bar return 1 else msg -tit msg -ama "$(fun_trans " BORAR USUARIO | Usuarios Activos del Servidor")" msg -bar i=0 for us in $(echo ${usuarios_ativos[@]}); do msg -ne "[$i] ->" && echo -e "\033[1;33m ${us}" let i++ done msg -bar fi msg -ama "$(fun_trans "Escriba o Seleccione un Usuario")" msg -bar msg -ama "\033[1;31mSe recomienda desbloquear todas las cuentas \nbloqueadas antes de borrar algun usuario." msg -bar unset selection while [[ -z ${selection} ]]; do echo -ne "\033[1;37m$(fun_trans "Seleccione Una Opcion"): " && read selection tput cuu1 && tput dl1 done if [[ ! $(echo "${selection}" | egrep '[^0-9]') ]]; then usuario_del="${usuarios_ativos[$selection]}" else usuario_del="$selection" fi [[ -z $usuario_del ]] && { msg -verm "$(fun_trans "Error, Usuario Invalido")" msg -bar return 1 } [[ ! $(echo ${usuarios_ativos[@]}|grep -w "$usuario_del") ]] && { msg -verm "$(fun_trans "Error, Usuario Invalido")" msg -bar return 1 } msg -ne "$(fun_trans "Usuario Seleccionado"): " && echo -ne "$usuario_del" pkill -u $usuario_del droplim=`dropbear_pids|grep -w "$usuario_del"|cut -d'|' -f2` kill -9 $droplim &>/dev/null rm_user "$usuario_del" && msg -verd " [$(fun_trans "Removido")]" || msg -verm " [$(fun_trans "No Removido")]" rm -rf /etc/VPS-MX/VPS-MX-userlock rm -rf /etc/VPS-MX/controlador/Limiter.log unlockall2 msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } remove_hwid () { clear clear red=$(tput setaf 1) gren=$(tput setaf 2) yellow=$(tput setaf 3) msg -bar usuarios_ativos=('' $(mostrar_usuario)) msg -ama "$(fun_trans "REMOVER USUARIOS")" msg -bar data_hwid msg -ama "$(fun_trans "Escriba o Seleccione un Usuario")" msg -bar unset selection while [[ -z ${selection} ]]; do msg -azu "$(fun_trans "Seleccione Una Opcion"): " && read selection tput cuu1 && tput dl1 done [[ ${selection} = "0" ]] && return if [[ ! $(echo "${selection}" | egrep '[^0-9]') ]]; then usuario_del="${usuarios_ativos[$selection]}" else usuario_del="$selection" fi [[ -z $usuario_del ]] && { msg -verm "$(fun_trans "Error, Usuario Invalido")" msg -bar return 1 } [[ ! $(echo ${usuarios_ativos[@]}|grep -w "$usuario_del") ]] && { msg -verm "$(fun_trans "Error, Usuario Invalido")" msg -bar return 1 } msg -ama "$(fun_trans "Usuario Seleccionado"): $usuario_del" pkill -u $usuario_del droplim=`droppids|grep -w "$usuario_del"|awk '{print $2}'` kill -9 $droplim &>/dev/null rm_hwid "$usuario_del" msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } remove_token () { clear clear red=$(tput setaf 1) gren=$(tput setaf 2) yellow=$(tput setaf 3) msg -bar usuarios_ativos=('' $(mostrar_token)) msg -ama "$(fun_trans "REMOVER USUARIOS")" msg -bar data_token msg -ama "$(fun_trans "Escriba o Seleccione un Usuario")" msg -bar unset selection while [[ -z ${selection} ]]; do msg -azu "$(fun_trans "Seleccione Una Opcion"): " && read selection tput cuu1 && tput dl1 done [[ ${selection} = "0" ]] && return if [[ ! $(echo "${selection}" | egrep '[^0-9]') ]]; then usuario_del="${usuarios_ativos[$selection]}" else usuario_del="$selection" fi [[ -z $usuario_del ]] && { msg -verm "$(fun_trans "Error, Usuario Invalido")" msg -bar return 1 } [[ ! $(echo ${usuarios_ativos[@]}|grep -w "$usuario_del") ]] && { msg -verm "$(fun_trans "Error, Usuario Invalido")" msg -bar return 1 } msg -ama "$(fun_trans "Usuario Seleccionado"): $usuario_del" pkill -u $usuario_del droplim=`droppids|grep -w "$usuario_del"|awk '{print $2}'` kill -9 $droplim &>/dev/null rm_token "$usuario_del" msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } menudel(){ clear msg -bar msg -tit msg -ama " \e[1;33m[1] \e[1;31mREMOVER CUENTAS SSH \n \e[1;33m[2] \e[1;31mREMOVER CUENTAS HWID\n \e[1;33m[3] \e[1;31mREMOVER CUENTAS TOKEN\n \e[1;33m[4] \e[1;37mREMOVER CUENTAS SSH,HWID,TOKEN\n \e[1;31m[0] \e[1;37m<- VOLVER" msg -bar read -p " $(echo -e "\e[1;37mSeleccione Una Opcion [1/3]:\e[1;33m") " cuen case $cuen in 1)remove_user;; 2)remove_hwid;; 3)remove_token;; 4)remove_allus;; 0) ;; esac } renew_user () { clear clear msg -bar usuarios_ativos=($(mostrar_usuarios)) if [[ -z ${usuarios_ativos[@]} ]]; then msg -tit msg -verm "$(fun_trans " EDITAR USUARIO | Ningun usuario registrado")" msg -bar return 1 else msg -tit msg -ama "$(fun_trans " EDITAR USUARIO | Usuarios Activos en el Servidor")" msg -bar i=0 for us in $(echo ${usuarios_ativos[@]}); do msg -ne "[$i] ->" && echo -e "\033[1;33m ${us}" let i++ done msg -bar fi msg -ama "$(fun_trans "Escriba o seleccione un Usuario")" msg -bar unset selection while [[ -z ${selection} ]]; do echo -ne "\033[1;37m$(fun_trans "Seleccione una Opcion"): " && read selection tput cuu1 tput dl1 done if [[ ! $(echo "${selection}" | egrep '[^0-9]') ]]; then useredit="${usuarios_ativos[$selection]}" else useredit="$selection" fi [[ -z $useredit ]] && { msg -verm "$(fun_trans "Error, Usuario Invalido")" msg -bar return 1 } [[ ! $(echo ${usuarios_ativos[@]}|grep -w "$useredit") ]] && { msg -verm "$(fun_trans "Error, Usuario Invalido")" msg -bar return 1 } while true; do msg -ne "Nuevo Tiempo de Duracion de:\033[1;33m $useredit" read -p ": " diasuser if [[ -z "$diasuser" ]]; then echo -e '\n\n\n' err_fun 7 && continue elif [[ "$diasuser" != +([0-9]) ]]; then echo -e '\n\n\n' err_fun 8 && continue elif [[ "$diasuser" -gt "360" ]]; then echo -e '\n\n\n' err_fun 9 && continue fi break done msg -bar renew_user_fun "${useredit}" "${diasuser}" && msg -ama "$(fun_trans "Usuario Modificado Con Exito")" || msg -verm "$(fun_trans "Error, Usuario no Modificado")" msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } edit_user () { clear clear msg -bar usuarios_ativos=($(mostrar_usuarios)) if [[ -z ${usuarios_ativos[@]} ]]; then msg -tit msg -verm "$(fun_trans " EDITTAR USER | Ningun usuario registrado")" msg -bar return 1 else msg -tit msg -ama "$(fun_trans " EDITTAR USER | Usuarios Activos del Servidor")" msg -bar i=0 for us in $(echo ${usuarios_ativos[@]}); do msg -ne "[$i] ->" && echo -e "\033[1;33m ${us}" let i++ done msg -bar fi msg -ama "$(fun_trans "Escriba o seleccione un Usuario")" msg -bar unset selection while [[ -z ${selection} ]]; do echo -ne "\033[1;37m$(fun_trans "Seleccione una Opcion"): " && read selection tput cuu1; tput dl1 done if [[ ! $(echo "${selection}" | egrep '[^0-9]') ]]; then useredit="${usuarios_ativos[$selection]}" else useredit="$selection" fi [[ -z $useredit ]] && { msg -verm "$(fun_trans "Error, Usuario Invalido")" msg -bar return 1 } [[ ! $(echo ${usuarios_ativos[@]}|grep -w "$useredit") ]] && { msg -verm "$(fun_trans "Error, Usuario Invalido")" msg -bar return 1 } while true; do msg -ne "$(fun_trans "Usuario Seleccionado"): " && echo -e "$useredit" msg -ne "Nueva Contraseña de:\033[1;33m $useredit" read -p ": " senhauser if [[ -z "$senhauser" ]]; then err_fun 4 && continue elif [[ "${#senhauser}" -lt "6" ]]; then err_fun 5 && continue elif [[ "${#senhauser}" -gt "20" ]]; then err_fun 6 && continue fi break done while true; do msg -ne "Dias de Duracion de:\033[1;33m $useredit" read -p ": " diasuser if [[ -z "$diasuser" ]]; then err_fun 7 && continue elif [[ "$diasuser" != +([0-9]) ]]; then err_fun 8 && continue elif [[ "$diasuser" -gt "360" ]]; then err_fun 9 && continue fi break done while true; do msg -ne "Nuevo Limite de Conexion de:\033[1;33m $useredit" read -p ": " limiteuser if [[ -z "$limiteuser" ]]; then err_fun 11 && continue elif [[ "$limiteuser" != +([0-9]) ]]; then err_fun 12 && continue elif [[ "$limiteuser" -gt "999" ]]; then err_fun 13 && continue fi break done tput cuu1 && tput dl1 tput cuu1 && tput dl1 tput cuu1 && tput dl1 tput cuu1 && tput dl1 msg -ne "$(fun_trans " >> Usuario"): " && echo -e "$useredit" msg -ne "$(fun_trans " >> Contraseña"): " && echo -e "$senhauser" msg -ne "$(fun_trans " >> Dias de Duracion"): " && echo -e "$diasuser" msg -ne "$(fun_trans " >> Fecha de Expiracion"): " && echo -e "$(date "+%F" -d " + $diasuser days")" msg -ne "$(fun_trans " >> Limite de Conexion"): " && echo -e "$limiteuser" msg -bar edit_user_fun "${useredit}" "${senhauser}" "${diasuser}" "${limiteuser}" && msg -ama "$(fun_trans "Usuario Modificado Con Exito")" && rm -rf ${SCPusr}/Limiter.log || msg -verm "$(fun_trans "Error, Usuario nao Modificado")" msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } data_hwid(){ clear msg -bar msg -tit msg -ama "$(fun_trans " INFORMACION DE USUARIOS HWID REGISTRADOS ")" msg -bar cat_users=$(cat "/etc/passwd"|grep 'home'|grep 'hwid'|grep -v 'syslog') dat_us=$(printf '%-20s%-12s%-8s%s' 'Cliente' 'Fecha' 'Dias' 'Statu') msg -azu " N° $dat_us" msg -bar i=1 for u in `echo "${cat_users}"|awk -F ':' '{print $1}'`; do fix_hwid_token=$(echo "${cat_users}"|grep -w "$u"|awk -F ':' '{print $5}'|cut -d ',' -f1) && [[ "${fix_hwid_token}" != @(hwid) ]] && continue fecha=$(chage -l "$u"|sed -n '4p'|awk -F ': ' '{print $2}') mes_dia=$(echo $fecha|awk -F ',' '{print $1}'|sed 's/ //g') ano=$(echo $fecha|awk -F ', ' '{printf $2}'|cut -c 3-) us=$(printf '%-12s' "$u") pass=$(cat "/etc/passwd"|grep -w "$u"|awk -F ':' '{print $5}'|cut -d ',' -f2) [[ "${#pass}" -gt '12' ]] && pass="Desconocida" pass="$(printf '%-19s' "$pass")" unset stat if [[ $(passwd --status $u|cut -d ' ' -f2) = "P" ]]; then stat="$(msg -verd "◉ ")" else stat="$(msg -verm2 "📵 ")" fi echo -ne " $(msg -verd "$i)")$(msg -verm2 "-") $(msg -azu "${pass}")" if [[ $(echo $fecha|awk '{print $2}') = "" ]]; then exp="$(printf '%8s%-2s' '[X]')" exp+="$(printf '%-6s' '[X]')" echo " $(msg -verm2 "$fecha")$(msg -verd "$exp")$(echo -e "$stat")" else if [[ $(date +%s) -gt $(date '+%s' -d "${fecha}") ]]; then exp="$(printf '%-5s' "Exp")" echo " $(msg -verm2 "$mes_dia/$ano") $(msg -verm2 "$exp")$(echo -e "$stat")" else EXPTIME="$(($(($(date '+%s' -d "${fecha}") - $(date +%s))) / 86400))" if [[ "${#EXPTIME}" = "1" ]]; then exp="$(printf '%6s%-7s' "$EXPTIME")" elif [[ "${#EXPTIME}" = "2" ]]; then exp="$(printf '%7s%-6s' "$EXPTIME")" else exp="$(printf '%7s%-5s' "$EXPTIME")" fi echo " $(msg -verm2 "$mes_dia/$ano")$(msg -verd "$exp")$(echo -e "$stat")" fi fi echo -e " $(msg -ama "HWID:") $(msg -azu "${us}")" msg -bar3 let i++ done msg -bar } data_token(){ clear msg -bar msg -tit msg -ama "$(fun_trans " INFORMACION DE USUARIOS TOKEN REGISTRADOS ")" msg -bar cat_users=$(cat "/etc/passwd"|grep 'home'|grep 'token'|grep -v 'syslog') dat_us=$(printf '%-20s%-12s%-8s%s' 'Cliente' 'Fecha' 'Dias' 'Statu') msg -azu " N° $dat_us" msg -bar i=1 for u in `echo "${cat_users}"|awk -F ':' '{print $1}'`; do fix_hwid_token=$(echo "${cat_users}"|grep -w "$u"|awk -F ':' '{print $5}'|cut -d ',' -f1) && [[ "${fix_hwid_token}" != @(hwid) ]] && continue fecha=$(chage -l "$u"|sed -n '4p'|awk -F ': ' '{print $2}') mes_dia=$(echo $fecha|awk -F ',' '{print $1}'|sed 's/ //g') ano=$(echo $fecha|awk -F ', ' '{printf $2}'|cut -c 3-) us=$(printf '%-12s' "$u") pass=$(cat "/etc/passwd"|grep -w "$u"|awk -F ':' '{print $5}'|cut -d ',' -f2) [[ "${#pass}" -gt '12' ]] && pass="Desconocida" pass="$(printf '%-19s' "$pass")" unset stat if [[ $(passwd --status $u|cut -d ' ' -f2) = "P" ]]; then stat="$(msg -verd "◉ ")" else stat="$(msg -verm2 "📵 ")" fi echo -ne " $(msg -verd "$i)")$(msg -verm2 "-") $(msg -azu "${pass}")" if [[ $(echo $fecha|awk '{print $2}') = "" ]]; then exp="$(printf '%8s%-2s' '[X]')" exp+="$(printf '%-6s' '[X]')" echo " $(msg -verm2 "$fecha")$(msg -verd "$exp")$(echo -e "$stat")" else if [[ $(date +%s) -gt $(date '+%s' -d "${fecha}") ]]; then exp="$(printf '%-5s' "Exp")" echo " $(msg -verm2 "$mes_dia/$ano") $(msg -verm2 "$exp")$(echo -e "$stat")" else EXPTIME="$(($(($(date '+%s' -d "${fecha}") - $(date +%s))) / 86400))" if [[ "${#EXPTIME}" = "1" ]]; then exp="$(printf '%6s%-7s' "$EXPTIME")" elif [[ "${#EXPTIME}" = "2" ]]; then exp="$(printf '%7s%-6s' "$EXPTIME")" else exp="$(printf '%7s%-5s' "$EXPTIME")" fi echo " $(msg -verm2 "$mes_dia/$ano")$(msg -verd "$exp")$(echo -e "$stat")" fi fi echo -e " $(msg -ama "TOKEN:") $(msg -azu "${us}")" msg -bar3 let i++ done msg -bar } data_user(){ clear msg -bar msg -tit msg -ama "$(fun_trans " INFORMACION DE USUARIOS SSH REGISTRADOS ")" msg -bar2 cat_users=$(cat "/etc/passwd"|grep 'home'|grep 'false'|grep -v 'syslog') dat_us=$(printf '%-13s%-14s%-10s%-4s%-6s%s' 'Usuario' 'Contraseña' 'Fecha' 'Dia' 'Limit' 'Statu') msg -azu " $dat_us" msg -bar i=1 for u in `echo "${cat_users}"|awk -F ':' '{print $1}'`; do fix_hwid_token=$(echo "${cat_users}"|grep -w "$u"|awk -F ':' '{print $5}'|cut -d ',' -f1) && [[ "${fix_hwid_token}" = @(hwid|token) ]] && continue fecha=$(chage -l "$u"|sed -n '4p'|awk -F ': ' '{print $2}') mes_dia=$(echo $fecha|awk -F ',' '{print $1}'|sed 's/ //g') ano=$(echo $fecha|awk -F ', ' '{printf $2}'|cut -c 3-) us=$(printf '%-12s' "$u") pass=$(cat ${USRdatabase}|grep -w "$u"|cut -d'|' -f2) [[ "${#pass}" -gt '12' ]] && pass="duplicada" pass="$(printf '%-12s' "$pass")" unset stat if [[ $(passwd --status $u|cut -d ' ' -f2) = "P" ]]; then stat="$(msg -verd "◉ ")" else stat="$(msg -verm2 "📵 ")" fi Limit=$(cat ${USRdatabase}|grep -w "$u"|cut -d'|' -f4) [[ "${#Limit}" = "1" ]] && Limit=$(printf '%2s%-4s' "$Limit") || Limit=$(printf '%-6s' "$Limit") echo -ne "$(msg -verd "$i")$(msg -verm2 "-")$(msg -azu "${us}") $(msg -azu "${pass}")" if [[ $(echo $fecha|awk '{print $2}') = "" ]]; then exp="$(printf '%8s%-2s' '[X]')" exp+="$(printf '%-6s' '[X]')" echo " $(msg -verm2 "$fecha")$(msg -verd "$exp")$(echo -e "$stat")" else if [[ $(date +%s) -gt $(date '+%s' -d "${fecha}") ]]; then exp="$(printf '%-5s' "Exp")" echo " $(msg -verm2 "$mes_dia/$ano") $(msg -verm2 "$exp")$(msg -ama "$Limit")$(echo -e "$stat")" else EXPTIME="$(($(($(date '+%s' -d "${fecha}") - $(date +%s))) / 86400))" [[ "${#EXPTIME}" = "1" ]] && exp="$(printf '%2s%-3s' "$EXPTIME")" || exp="$(printf '%-5s' "$EXPTIME")" echo " $(msg -verm2 "$mes_dia/$ano") $(msg -verd "$exp")$(msg -ama "$Limit")$(echo -e "$stat")" fi fi let i++ done msg -bar } menudata(){ clear msg -bar msg -tit msg -ama " \e[1;33m[1] \e[37mDETALLES DE CUENTAS SSH \e[0m\n \e[1;33m[2] \e[37mDETALLES DE CUENTAS HWID \e[0m\n \e[1;33m[3] \e[37mDETALLES DE CUENTAS TOKEN \e[0m\n \e[1;31m[0] \e[1;37m<- VOLVER" msg -bar read -p " $(echo -e "\e[1;37mSeleccione Una Opcion [1/3]:\e[1;33m") " cuen case $cuen in 1)data_user;; 2)data_hwid;; 3)data_token;; 0) ;; esac } menumoni(){ clear msg -bar msg -tit msg -ama " \e[1;33m[1] \e[37mMONITOR DE CUENTAS SSH\e[0m\n \e[1;33m[2] \e[37mMONITOR DE CUENTAS HWID\e[0m\n \e[1;33m[3] \e[37mMONITOR DE CUENTAS TOKEN\e[0m\n \e[1;31m[0] \e[1;37m<- VOLVER" msg -bar read -p " $(echo -e "\e[1;37mSeleccione Una Opcion [1/3]:\e[1;33m") " cuen case $cuen in 1)monit_ssh;; 2)monit_hwid;; 3)monit_token;; 0) ;; esac } monit_hwid () { clear clear msg -bar msg -tit red=$(tput setaf 1) gren=$(tput setaf 2) yellow=$(tput setaf 3) echo -e "$(fun_trans "\e[93m MONITOR DE CONEXIONES SSH/DROPBEAR/SSL/OPENVPN")" msg -bar txtvar=$(printf '%-13s' " USUARIO") txtvar+=$(printf '%-20s' "CONEXIONES") txtvar+=$(printf '%-10s' "TIME/ON") echo -e " \e[1;33m${txtvar}\e[0m" msg -bar cat_users=$(cat "/etc/passwd"|grep 'home'|grep 'hwid'|grep -v 'syslog') for i in `echo "$cat_users"|awk -F ':' '{print $1}'`; do hwid="$i" nom="$(echo "$cat_users"|grep -w "$i"|awk -F ':' '{print $5}'|cut -d ',' -f2)" user=$(printf '%-10s' " ${nom}") sep=$(printf '%-5s') _=$( PID="0+" [[ $(dpkg --get-selections|grep -w "openssh"|head -1) ]] && PID+="$(ps aux|grep -v grep|grep sshd|grep -w "$hwid"|grep -v root|wc -l)+" [[ $(dpkg --get-selections|grep -w "dropbear"|head -1) ]] && PID+="$(dropbear_pids|grep -w "${hwid}"|wc -l)+" [[ $(dpkg --get-selections|grep -w "openvpn"|head -1) ]] && [[ -e /etc/openvpn/openvpn-status.log ]] && [[ $(openvpn_pids|grep -w "$hwid"|cut -d'|' -f2) ]] && PID+="$(openvpn_pids|grep -w "$hwid"|cut -d'|' -f2)+" PID+="0" TIMEON="${TIMEUS[$hwid]}" [[ -z $TIMEON ]] && TIMEON=0 MIN=$(($TIMEON/60)) SEC=$(($TIMEON-$MIN*60)) HOR=$(($MIN/60)) MIN=$(($MIN-$HOR*60)) HOUR="${HOR}h:${MIN}m:${SEC}s" [[ $(echo $PID|bc) -gt 0 ]] && hwid="$hwid [\033[1;32mON\033[0m${yellow}] " || hwid="$hwid [\033[1;31mOFF\033[0m${yellow}]" TOTALPID="$(echo $PID|bc)/hwid" #$MAXUSER" while [[ ${#hwid} -lt 45 ]]; do hwid=$hwid" " done while [[ ${#TOTALPID} -lt 13 ]]; do TOTALPID=$TOTALPID" " done while [[ ${#HOUR} -lt 8 ]]; do HOUR=$HOUR" " done echo -e "${yellow}USER:${gren}$user $sep $TOTALPID $HOUR\n ${red}HWID:${yellow} $hwid\n$(msg -bar)" >&2 ) & pid=$! sleep 0.2s done while [[ -d /proc/$pid ]]; do sleep 2s done msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } monit_token () { clear clear msg -bar msg -tit red=$(tput setaf 1) gren=$(tput setaf 2) yellow=$(tput setaf 3) echo -e "$(fun_trans "\e[93m MONITOR DE CONEXIONES SSH/DROPBEAR/SSL/OPENVPN")" msg -bar txtvar=$(printf '%-13s' " USUARIO") txtvar+=$(printf '%-20s' "CONEXIONES") txtvar+=$(printf '%-10s' "TIME/ON") echo -e " \e[1;33m${txtvar}\e[0m" msg -bar cat_users=$(cat "/etc/passwd"|grep 'home'|grep 'token'|grep -v 'syslog') for i in `echo "$cat_users"|awk -F ':' '{print $1}'`; do token="$i" nom="$(echo "$cat_users"|grep -w "$i"|awk -F ':' '{print $5}'|cut -d ',' -f2)" user=$(printf '%-10s' " ${nom}") sep=$(printf '%-5s') _=$( PID="0+" [[ $(dpkg --get-selections|grep -w "openssh"|head -1) ]] && PID+="$(ps aux|grep -v grep|grep sshd|grep -w "$token"|grep -v root|wc -l)+" [[ $(dpkg --get-selections|grep -w "dropbear"|head -1) ]] && PID+="$(dropbear_pids|grep -w "${token}"|wc -l)+" [[ $(dpkg --get-selections|grep -w "openvpn"|head -1) ]] && [[ -e /etc/openvpn/openvpn-status.log ]] && [[ $(openvpn_pids|grep -w "$token"|cut -d'|' -f2) ]] && PID+="$(openvpn_pids|grep -w "$token"|cut -d'|' -f2)+" PID+="0" TIMEON="${TIMEUS[$token]}" [[ -z $TIMEON ]] && TIMEON=0 MIN=$(($TIMEON/60)) SEC=$(($TIMEON-$MIN*60)) HOR=$(($MIN/60)) MIN=$(($MIN-$HOR*60)) HOUR="${HOR}h:${MIN}m:${SEC}s" [[ $(echo $PID|bc) -gt 0 ]] && token="$token [\033[1;32mON\033[0m${yellow}] " || token="$token [\033[1;31mOFF\033[0m${yellow}]" TOTALPID="$(echo $PID|bc)/token" #$MAXUSER" while [[ ${#token} -lt 45 ]]; do token=$token" " done while [[ ${#TOTALPID} -lt 13 ]]; do TOTALPID=$TOTALPID" " done while [[ ${#HOUR} -lt 8 ]]; do HOUR=$HOUR" " done echo -e "${yellow}USER:${gren}$user $sep $TOTALPID $HOUR\n ${red}TOKEN:${yellow} $token\n$(msg -bar)" >&2 ) & pid=$! sleep 0.2s done while [[ -d /proc/$pid ]]; do sleep 2s done msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } monit_ssh () { clear clear msg -bar msg -tit red=$(tput setaf 1) gren=$(tput setaf 2) yellow=$(tput setaf 3) echo -e "$(fun_trans "\e[93m MONITOR DE CONEXIONES SSH/DROPBEAR/SSL/OPENVPN")" msg -bar txtvar=$(printf '%-20s' " USUARIO") txtvar+=$(printf '%-14s' "CONEXIONES") txtvar+=$(printf '%-8s' "TIME/ON") echo -e " \e[1;33m${txtvar}\e[0m" msg -bar cat_users=$(cat "/etc/passwd"|grep 'home'|grep 'sshm'|grep -v 'syslog') for i in `echo "$cat_users"|awk -F ':' '{print $1}'`; do user="$i" _=$( PID="0+" [[ $(dpkg --get-selections|grep -w "openssh"|head -1) ]] && PID+="$(ps aux|grep -v grep|grep sshd|grep -w "$user"|grep -v root|wc -l)+" [[ $(dpkg --get-selections|grep -w "dropbear"|head -1) ]] && PID+="$(dropbear_pids|grep -w "$user"|wc -l)+" [[ $(dpkg --get-selections|grep -w "openvpn"|head -1) ]] && [[ -e /etc/openvpn/openvpn-status.log ]] && [[ $(openvpn_pids|grep -w "$user"|cut -d'|' -f2) ]] && PID+="$(openvpn_pids|grep -w "$user"|cut -d'|' -f2)+" PID+="0" TIMEON="${TIMEUS[$user]}" [[ -z $TIMEON ]] && TIMEON=0 MIN=$(($TIMEON/60)) SEC=$(($TIMEON-$MIN*60)) HOR=$(($MIN/60)) MIN=$(($MIN-$HOR*60)) HOUR="${HOR}h:${MIN}m:${SEC}s" [[ -z $(cat ${USRdatabase}|grep -w "${user}") ]] && MAXUSER="" || MAXUSER="$(cat ${USRdatabase}|grep -w "${user}"|cut -d'|' -f4)" [[ $(echo $PID|bc) -gt 0 ]] && user="$user [\033[1;32mON\033[0m${yellow}] " || user="$user [\033[1;31mOFF\033[0m${yellow}]" TOTALPID="$(echo $PID|bc)/$MAXUSER" while [[ ${#user} -lt 45 ]]; do user=$user" " done while [[ ${#TOTALPID} -lt 13 ]]; do TOTALPID=$TOTALPID" " done while [[ ${#HOUR} -lt 9 ]]; do HOUR=$HOUR" " done echo -e "${yellow}$user $TOTALPID $HOUR\n$(msg -bar)" >&2 ) & pid=$! sleep 0.2s done while [[ -d /proc/$pid ]]; do sleep 2s done msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } rm_vencidos () { clear clear msg -bar msg -tit echo -e "$(fun_trans "\e[93m BORRANDO USUARIOS VENCIDOS ")" msg -bar red=$(tput setaf 1) gren=$(tput setaf 2) yellow=$(tput setaf 3) txtvar=$(printf '%-25s' " USUARIO") txtvar+=$(printf '%-25s' " VALIDIDEZ") echo -e "\033[1;92m${txtvar}" msg -bar expired="${red}$(fun_trans "Usuario Expirado")" valid="${gren}$(fun_trans " Usuario Vigente")" never="${yellow}$(fun_trans "Usuario Ilimitado")" removido="${red}$(fun_trans "Eliminado")" DataVPS=$(date +%s) while read user; do DataUser=$(chage -l "${user}" |grep -i co|awk -F ":" '{print $2}') usr=$user while [[ ${#usr} -lt 20 ]]; do usr=$usr" " done [[ "$DataUser" = " never" ]] && { echo -e "${yellow}$usr $never" continue } DataSEC=$(date +%s --date="$DataUser") if [[ "$DataSEC" -lt "$DataVPS" ]]; then echo -ne "${yellow}$usr $expired" rm_user "$user" && echo -e "($removido)" else echo -e "${yellow}$usr $valid" fi done <<< "$(mostrar_usuarios)" rm -rf /etc/VPS-MX/VPS-MX-userlock rm -rf /etc/VPS-MX/controlador/Limiter.log unlockall2 msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } verif_fun () { local conexao local limite local TIMEUS declare -A conexao declare -A limite declare -A TIMEUS local LIMITERLOG="${SCPusr}/Limiter.log" local LIMITERLOG2="${SCPusr}/Limiter2.log" [[ $(dpkg --get-selections|grep -w "openssh"|head -1) ]] && local SSH=ON || local SSH=OFF [[ $(dpkg --get-selections|grep -w "dropbear"|head -1) ]] && local DROP=ON || local DROP=OFF [[ $(dpkg --get-selections|grep -w "openvpn"|head -1) ]] && [[ -e /etc/openvpn/openvpn-status.log ]] && local OPEN=ON || local OPEN=OFF while true; do unset EXPIRED unset ONLINES unset BLOQUEADO local TimeNOW=$(date +%s) while read user; do echo -ne "\033[1;33mUSUARIO: \033[1;32m$user " if [[ ! $(echo $(mostrar_usuarios)|grep -w "$user") ]]; then echo -e "\033[1;31mNO EXISTE" continue fi local DataUser=$(chage -l "${user}" |grep -i co|awk -F ":" '{print $2}') if [[ ! -z "$(echo $DataUser|grep never)" ]]; then echo -e "\033[1;31mILIMITADO" continue fi local DataSEC=$(date +%s --date="$DataUser") if [[ "$DataSEC" -lt "$TimeNOW" ]]; then EXPIRED="1+" block_userfun $user -loked && echo " $user (EXPIRADO) $(date +%r--%d/%m/%y)" >> $LIMITERLOG && echo " $user (EXPIRADO) $(date +%r--%d/%m/%y)" >> $LIMITERLOG2 && KEY="2012880601:AAEJ3Kk18PGDzW57LpTMnVMn_pQYQKW3V9w" URL="https://api.telegram.org/bot$KEY/sendMessage" MSG="⚠️ AVISO DE VPS: $NOM1 ⚠️ 🔹 CUENTA: $user ❗️ �� EXPIRADA �� ❗️" curl -s --max-time 10 -d "chat_id=$IDB1&disable_web_page_preview=1&text=$MSG" $URL && pkill -u $user echo -e "\033[1;31m EXPIRADO" continue fi local PID="0+" [[ $SSH = ON ]] && PID+="$(ps aux|grep -v grep|grep sshd|grep -w "$user"|grep -v root|wc -l 2>/dev/null)+" [[ $DROP = ON ]] && PID+="$(dropbear_pids|grep -w "$user"|wc -l 2>/dev/null)+" [[ $OPEN = ON ]] && [[ $(openvpn_pids|grep -w "$user"|cut -d'|' -f2) ]] && PID+="$(openvpn_pids|grep -w "$user"|cut -d'|' -f2)+" local ONLINES+="$(echo ${PID}0|bc)+" local conexao[$user]="$(echo ${PID}0|bc)" if [[ ${conexao[$user]} -gt '0' ]]; then #CONTADOR DE TEMPO ONLINE [[ -z "${TIMEUS[$user]}" ]] && local TIMEUS[$user]=0 [[ "${TIMEUS[$user]}" != +([0-9]) ]] && local TIMEUS[$user]=0 local TIMEUS[$user]="$((300+${TIMEUS[$user]}))" local VARS="$(cat ${MyTIME}|grep -w -v "$user")" echo "TIMEUS[$user]='${TIMEUS[$user]}'" > ${MyTIME} for variavel in $(echo ${VARS}); do echo "${variavel}" >> ${MyTIME}; done fi local limite[$user]="$(cat ${USRdatabase}|grep -w "${user}"|cut -d'|' -f4)" [[ -z "${limite[$user]}" ]] && continue [[ "${limite[$user]}" != +([0-9]) ]] && continue if [[ "${conexao[$user]}" -gt "${limite[$user]}" ]]; then local lock=$(block_userfun $user -loked) pkill -u $user droplim=`dropbear_pids|grep -w "$user"|cut -d'|' -f2` kill -9 $droplim &>/dev/null openlim=`openvpn_pids|grep -w "$user"|cut -d'|' -f2` kill -9 $openlim &>/dev/null echo "$lock" >> $LIMITERLOG && echo "$lock" >> $LIMITERLOG2 echo -e "\033[1;31m ULTRAPASO LIMITE" continue fi echo -e "\033[1;33m OK! \033[1;31m${conexao[$user]} CONEXIONESS" BLOQUEADO="$(wc -l /etc/VPS-MX/VPS-MX-userlock | awk '{print $1}')" BLOQUEADO2="$(echo ${BLOQUEADO}|bc)0" BLOQUEADO3="/10" EXPIRADO="$(grep -c EXPIRADO /etc/VPS-MX/controlador/Limiter.log)" EXPIRADO2="$(echo ${EXPIRADO}|bc)0" EXPIRADO3="/10" done <<< "$(mostrar_usuarios)" echo "${ONLINES}0"|bc > ${SCPdir}/USRonlines echo "${EXPIRADO2}${EXPIRADO3}"|bc > ${SCPdir}/USRexpired echo "${BLOQUEADO2}${BLOQUEADO3}"|bc > ${SCPdir}/USRbloqueados limseg="$(less /etc/VPS-MX/controlador/tiemlim.log)" sleep $limseg # TEMPO DE ESPERA DO LOOP clear done } SPR & backup_fun () { clear clear msg -bar msg -tit msg -ama "$(fun_trans " HERRAMIENTA DE BACKUP DE USUARIOS")" msg -bar menu_func "CREAR BACKUP" "RESTAURAR BACKUP" msg -bar unset selection while [[ ${selection} != @([1-2]) ]]; do echo -ne "\033[1;37m$(fun_trans "Seleccione una Opcion"): " && read selection tput cuu1 && tput dl1 done case ${selection} in 1) cp ${USRdatabase} $HOME/VPS-MX-Backup msg -azu "$(fun_trans "Procedimiento Hecho con Exito, Guardado en:")" echo "" echo -e "\033[1;31mBACKUP > [\033[1;32m$HOME/VPS-MX-Backup\033[1;31m]" echo "" ;; 2) while [[ ! -e ${dirbackup} ]]; do echo -ne "\033[1;37m ¡¡Recomiendo DESACTIVAR Limitador si es que lo tine ACTIVO!!\n" echo -ne "\033[1;37m Escriba la ubicacion de la copia de seguridad\n" msg -bar echo -ne "\033[1;37m ENTER: para ruta predeterminada /root/VPS-MX-Backup: " && read dirbackup echo "" echo "---------- RESTAURANDO CUENTAS ESPERE " echo "" msg -bar [[ -z "${dirbackup}" ]] && dirbackup="/root/VPS-MX-Backup" tput cuu1 && tput dl1 done VPSsec=$(date +%s) while read line; do nome=$(echo ${line}|cut -d'|' -f1) [[ $(echo $(mostrar_usuarios)|grep -w "$nome") ]] && { msg -verm "$nome [ERROR]" continue } senha=$(echo ${line}|cut -d'|' -f2) DateExp=$(echo ${line}|cut -d'|' -f3) DataSec=$(date +%s --date="$DateExp") [[ "$VPSsec" -lt "$DataSec" ]] && dias="$(($(($DataSec - $VPSsec)) / 86400))" || dias="NP" limite=$(echo ${line}|cut -d'|' -f4) add_user "$nome" "$senha" "$dias" "$limite" &>/dev/null && msg -verd "$nome [CUENTA VALIDA]" || msg -verm "$nome [CUENTA INVALIDA FECHA EXPIRADA]" done < ${dirbackup} ;; esac echo "" msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } verif_funx () { clear clear msg -bar msg -tit echo -e "\033[1;32m LIMITADOR DE CUENTAS" msg -bar echo -e "Esta Opcion Limita las Conexiones de SSH/SSL/DROPBEAR" PIDVRF="$(ps aux|grep "${SCPusr}/usercodes verificar"|grep -v grep|awk '{print $2}')" if [[ -z $PIDVRF ]]; then msg -bar echo -ne "\033[1;96m ¿Cada cuantos segundos ejecutar el limitador?\n\033[1;97m +Segundos = -Uso de CPU | -Segundos = +Uso de CPU\033[0;92m \n Predeterminado:\033[1;37m 120s\n Cuantos Segundos (Numeros Unicamente): " && read tiemlim [[ -z "$tiemlim" ]] && tiemlim="120" echo "${tiemlim}" > /etc/VPS-MX/controlador/tiemlim.log cd ${SCPusr} screen -dmS very ${SCPusr}/usercodes verificar else for pid in $(echo $PIDVRF); do kill -9 $pid &>/dev/null done [[ -e ${SCPdir}/USRonlines ]] && rm ${SCPdir}/USRonlines [[ -e ${SCPdir}/USRexpired ]] && rm ${SCPdir}/USRexpired [[ -e ${SCPdir}/USRbloqueados ]] && rm ${SCPdir}/USRbloqueados fi msg -bar [[ -z ${VERY} ]] && verificar="\033[1;32m ACTIVADO " || verificar="\033[1;31m DESACTIVADO " echo -e " $verificar -- CON EXITO" msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } verif2_funx () { clear clear msg -bar msg -tit echo -e "\033[1;32m DESBLOQUEO AUT. Y LIMPIADOR DE EXPIARDOS" msg -bar echo -e "Esta opcion desbloquea cada 60 segundos a usuarios\nbloqueados por el limitador y limpia los usuarios expirados" PIDVRF2="$(ps aux|grep "${SCPusr}/usercodes desbloqueo"|grep -v grep|awk '{print $2}')" if [[ -z $PIDVRF2 ]]; then msg -bar echo -ne "\033[1;96m ¿Cada cuantos segundos ejecutar el desbloqueador?\n\033[1;97m +Segundos = -Uso de CPU | -Segundos = +Uso de CPU\033[0;92m \n Predeterminado:\033[1;37m 300s\n Cuantos Segundos (Numeros Unicamente): " && read tiemdes [[ -z "$tiemdes" ]] && tiemdes="300" echo "${tiemdes}" > /etc/VPS-MX/controlador/tiemdes.log cd ${SCPusr} screen -dmS very2 ${SCPusr}/usercodes desbloqueo else for pid in $(echo $PIDVRF2); do kill -9 $pid &>/dev/null done fi msg -bar [[ -z ${VERY2} ]] && desbloqueo="\033[1;32m ACTIVADO " || desbloqueo="\033[1;31m DESACTIVADO " echo -e " $desbloqueo -- CON EXITO" msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } baner_fun () { banner_on () { clear clear local="/etc/VPS-MX/bannerssh" rm -rf $local > /dev/null 2>&1 local2="/etc/dropbear/banner" chk=$(cat /etc/ssh/sshd_config | grep Banner) if [ "$(echo "$chk" | grep -v "#Banner" | grep Banner)" != "" ]; then local=$(echo "$chk" |grep -v "#Banner" | grep Banner | awk '{print $2}') else echo "" >> /etc/ssh/sshd_config echo "Banner /etc/VPS-MX/bannerssh" >> /etc/ssh/sshd_config local="/etc/VPS-MX/bannerssh" fi msg -bar msg -tit msg -ama " AGREGAR BANNER SSH/SSL/DROPBEAR" msg -bar msg -ne "$(fun_trans "Inserte el BANNER de preferencia en HTML sin saltos"): \n\n" && read ban_ner echo "" msg -bar credi="$(less /etc/VPS-MX/message.txt)" echo "$ban_ner" >> $local echo '

'$credi'
SCRIPT - VPS•MX

' >> $local if [[ -e "$local2" ]]; then rm $local2 > /dev/null 2>&1 cp $local $local2 > /dev/null 2>&1 fi msg -verd "$(fun_trans " BANNER AGREGADO CON !! EXITO ¡¡" )" && msg -bar service dropbear stop 2>/dev/null service ssh restart 2>/dev/null service dropbear restart 2>/dev/null } banner_off () { clear clear msg -bar msg -tit msg -ama " ELIMINANDO BANNER SSH/SSL/DROPBEAR" msg -bar sed -i '/'Banner'/d' /etc/ssh/sshd_config sed -i -e 's/^[ \t]*//; s/[ \t]*$//; /^$/d' /etc/ssh/sshd_config echo "" >> /etc/ssh/sshd_config rm -rf /etc/dropbear/banner > /dev/null 2>&1 echo "" > /etc/dropbear/banner > /dev/null 2>&1 service dropbear stop 2>/dev/null service ssh restart 2>/dev/null service dropbear restart 2>/dev/null echo -e "\033[1;92m BANNER ELIMINADO !! EXITO ¡¡ " msg -bar } clear clear msg -bar msg -tit msg -ama " AGREGAR BANNER SSH/SSL/DROPBEAR" msg -bar echo -e "${cor[1]} Escoja la opcion deseada." msg -bar echo -e "\033[1;92m 1).- \033[1;37m AGREGAR BANNER SSH/SSL/DROPBEAR " echo -e "\033[1;92m 2).- \033[1;37m ELIMINAR Y DESACTIVAR BANNER " msg -bar echo -ne "\033[1;37mDigite solo el numero segun su respuesta: \033[1;32m" read opcao case $opcao in 1) msg -bar banner_on ;; 2) msg -bar banner_off ;; esac msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } desbloqueo_auto () { while true; do Desbloqueo.sh 2>/dev/null tiemdes="$(less /etc/VPS-MX/controlador/tiemdes.log)" sleep $tiemdes done } rec_total () { clear clear msg -bar msg -tit echo -e "\033[1;32m REGISTRO TOTAL DE CUENTAS VIEJAS Y NUEVAS" msg -bar msg -ama " CUENSTAS SSH" if [[ -e /etc/VPS-MX/VPS-MXuser ]]; then echo "$(cat /etc/VPS-MX/VPS-MXuser)" else msg -ama " NO HAY REGISTRO" fi msg -bar msg -ama " CUENTAS HWID" if [[ -e /etc/VPS-MX/User-HWID ]]; then echo "$(cat /etc/VPS-MX/User-HWID)" else msg -ama " NO HAY REGISTRO" fi msg -bar msg -ama " CUENTAS TOKEN" if [[ -e /etc/VPS-MX/User-TOKEN ]]; then echo "$(cat /etc/VPS-MX/User-TOKEN)" else msg -ama " NO HAY REGISTRO" fi msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes } if [[ "$1" = "verificar" ]]; then verif_fun exit fi [[ -z ${VERY} ]] && verificar="\033[1;31m[DESACTIVADO]" || verificar="\033[1;32m[ACTIVO]" if [[ "$1" = "desbloqueo" ]]; then desbloqueo_auto exit fi [[ -z ${VERY2} ]] && desbloqueo="\033[1;31m[DESACTIVADO]" || desbloqueo="\033[1;32m[ACTIVO]" msg -tit msg -ama " MENU ADMINISTRACION DE USUARIOS SSL/SSH/DROPBEAR" msg -bar msg -bar3 menu_func "CREAR NUEVO USUARIO [\e[31m\e[43mSSH/HWID/TOKEN \e[0m\e[37m]" "CREAR USUARIO TEMPORAL" "REMOVER USUARIO [\e[31m\e[43mSSH/HWID/TOKEN \e[0m\e[37m]" "BLOQUEAR |DESBLOQUEAR USUARIO" "REINICIAR CONTADOR DE BLOQUEADOS |EXPIRADOS" "EDITAR USUARIO" "RENOVAR USUARIO" "MOSTRAR CUENTAS [\e[31m\e[43mSSH/HWID/TOKEN \e[0m\e[37m]" "USUARIOS CONECTADOS [\e[31m\e[43mSSH/HWID/TOKEN \e[0m\e[37m] " "ELIMINAR USUARIOS VENCIDOS" "BACKUP USUARIOS" "AGREGAR/ELIMINAR BANNER " "\033[1;31m⚠️ELIMINAR TODOS LOS USUARIOS⚠️ \n" " -fi ${verificar} \033[1;97m🔒 LIMITADOR-DE-CUENTAS 🔒 \n" " -fi ${desbloqueo} \033[1;97m🔓 DESBLOQUEO-AUTOMATICO 🔓 \n" "\033[1;92mLOG DE CUENTAS REGISTRADAS" "LIMPIAR LOG DE LIMITADOR" [[ -e "${SCPusr}/Limiter2.log" ]] && echo -ne "$(msg -verd " [18]") $(msg -verm2 "➛ ") " && msg -azu "$(fun_trans "\033[1;93mVER LOG DE LIMITADOR")" echo -ne ""$(msg -bar)" \n$(msg -verd " [0]") $(msg -verm2 "➛ ")" && msg -bra " \e[97m\033[1;41m VOLVER \033[1;37m" msg -bar selection=$(selection_fun 19) case ${selection} in 1)menu_crearuser;; 2)${SCPdir2}/Crear-Demo.sh "${idioma}";; 3)menudel;; 4)block_user;; 5)reset_contador;; 6)edit_user;; 7)renew_user;; 8)menudata;; 9)menumoni;; 10)rm_vencidos;; 11)backup_fun;; 12)baner_fun;; 13)eliminar_all;; 14)verif_funx;; 15)verif2_funx;; 16)rec_total;; 17) rm -rf ${SCPusr}/Limiter2.log echo -e "\033[1;32m LOG ELIMINADO CON EXITO" msg -bar msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes ;; 18) clear clear msg -bar sed -i -e 's/^[ \t]*//; s/[ \t]*$//; /^$/d' /etc/VPS-MX/controlador/Limiter2.log [[ -e "${SCPusr}/Limiter2.log" ]] && { msg -tit msg -ama " REGISTRO DEL LIMITADOR " cat ${SCPusr}/Limiter2.log msg -bar } msg -ne " Enter Para Continuar" && read enter ${SCPusr}/usercodes ;; esac