| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836 |
- #!/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 "<ca>" >> ~/$1.ovpn
- cat /etc/openvpn/easy-rsa/pki/ca.crt >> ~/$1.ovpn
- echo "</ca>" >> ~/$1.ovpn
- echo "<cert>" >> ~/$1.ovpn
- cat /etc/openvpn/easy-rsa/pki/issued/$1.crt >> ~/$1.ovpn
- echo "</cert>" >> ~/$1.ovpn
- echo "<key>" >> ~/$1.ovpn
- cat /etc/openvpn/easy-rsa/pki/private/$1.key >> ~/$1.ovpn
- echo "</key>" >> ~/$1.ovpn
- echo "<tls-auth>" >> ~/$1.ovpn
- cat /etc/openvpn/ta.key >> ~/$1.ovpn
- echo "</tls-auth>" >> ~/$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;<auth-user-pass>\n$1\n$2\n</auth-user-pass>;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 '<p style="text-align: center;"><span style="color: #0000ff;"><strong>'$credi'</strong></span><br /><em><span style="color: #ff0000;"><strong>SCRIPT - VPS•MX</strong></span></em></p>' >> $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
-
|