| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223 |
- #!/bin/bash
- #Modificado el 14/06
- dir_user="/userDIR"
- dir="/etc/adm-lite"
- fun_ip () {
- MEU_IP=$(ip addr | grep 'inet' | grep -v inet6 | grep -vE '127\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}' | grep -o -E '[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}' | head -1)
- MEU_IP2=$(wget -qO- ipv4.icanhazip.com)
- [[ "$MEU_IP" != "$MEU_IP2" ]] && echo "$MEU_IP2" || echo "$MEU_IP"
- }
- removeonline(){
- i=1
- [[ -d /var/www/html ]] && [[ -e /var/www/html/$arquivo_move ]] && rm -rf /var/www/html/$arquivo_move > /dev/null 2>&1
- [[ -e /var/www/$arquivo_move ]] && rm -rf /var/www/$arquivo_move > /dev/null 2>&1
- echo -e "${cor[5]}Extraxion Exitosa Exitosa"
- echo -e "$barra"
- echo "SUBIENDO"
- subironline
- }
- subironline(){
- [ ! -d /var ] && mkdir /var
- [ ! -d /var/www ] && mkdir /var/www
- [ ! -d /var/www/html ] && mkdir /var/www/html
- [ ! -e /var/www/html/index.html ] && touch /var/www/html/index.html
- [ ! -e /var/www/index.html ] && touch /var/www/index.html
- chmod -R 755 /var/www
- cp $HOME/$arquivo_move /var/www/$arquivo_move
- cp $HOME/$arquivo_move /var/www/html/$arquivo_move
- service apache2 restart
- IP="$(fun_ip)"
- echo -e "\033[1;36m http://$IP:81/$arquivo_move\033[0m"
- echo -e "$barra"
- echo -e "${cor[5]}Carga Exitosa!"
- echo -e "$barra"
- read -p "PRESIONE ENTER"
- }
- echo -e "\033[1;33mMenu de Respaldos de Usuarios\033[1;30m
- ----------------------------------
- \033[1;32m1) \033[1;37mCrear respaldo de Usuarios Online
- ----------------------------------
- \033[1;32m2) \033[1;37mRestaurar Usuarios de un backup Online
- ----------------------------------
- \033[1;32m3) \033[1;37m RESTAURAR FILE LOCAL
- ----------------------------------"
- read -p "ECOJE: " option
- function backup_de_usuarios(){
- echo -e "--------------------------------------------------------"
- read -p "Ingrese Nombre de su Fichero o pulse ENTER: " name
- bc="$HOME/$name"
- arquivo_move="$name"
- clear
- i=1
- [[ -e $bc ]] && rm $bc
- echo -e "\033[1;37mHaciendo Backup de Usuarios...\033[0m"
- [[ -e /bin/ejecutar/token ]] && passTK=$(cat < /bin/ejecutar/token)
- #for user in `awk -F : '$3 > 900 { print $1 }' /etc/passwd |grep -v "nobody" |grep -vi polkitd |grep -vi systemd-[a-z] |grep -vi systemd-[0-9] |sort`
- for user in `cat "/etc/passwd"|grep 'home'|grep 'false'|grep -v 'syslog' | cut -d: -f1 |sort`
- do
- if [ -e $dir$dir_user/$user ]
- then
- pass=$(cat $dir$dir_user/$user | grep "senha" | awk '{print $2}')
- limite=$(cat $dir$dir_user/$user | grep "limite" | awk '{print $2}')
- data=$(cat $dir$dir_user/$user | grep "data" | awk '{print $2}')
- data_sec=$(date +%s)
- data_user=$(chage -l "$user" |grep -i co |awk -F ":" '{print $2}')
- data_user_sec=$(date +%s --date="$data_user")
- variavel_soma=$(($data_user_sec - $data_sec))
- dias_use=$(($variavel_soma / 86400))
- if [[ "$dias_use" -le 0 ]];
- then
- dias_use=0
- fi
- sl=$((dias_use + 1))
- i=$((i + 1))
- [[ -z "$limite" ]] && limite="5"
- else
- echo -e "\033[1;31mNo fue posible obtener la contraseña del usuario\033[1;37m ($user)"
- read -p "Introduzca la contraseña manualmente o pulse ENTER: " pass
- if [ -z "$pass" ]; then
- pass="$user"
- fi
- fi
- [[ $(echo $limite) = "HWID" ]] && echo "$user:$user:HWID:$sl:$pass" >> $bc && echo -e "\033[1;37mUser $pass \033[0;35m [\033[0;36m$limite\033[0;35m]\033[0;31m Backup [\033[1;31mOK\033[1;37m] con $sl DIAS\033[0m"
- [[ $(echo $limite) = "TOKEN" ]] && echo "$user:$passTK:TOKEN:$sl:$pass" >> $bc && echo -e "\033[1;37mUser $pass \033[0;35m [\033[0;36m$limite\033[0;35m]\033[0;31m Backup [\033[1;31mOK\033[1;37m] con $sl DIAS\033[0m"
- [[ "$limite" =~ ^[0-9]+$ ]] && echo "$user:$pass:$limite:$sl" >> $bc && echo -e "\033[1;37mUser $user \033[0;35m [\033[0;36mSSH\033[0;35m]\033[0;31m Backup [\033[1;31mOK\033[1;37m] con $sl DIAS\033[0m"
- done
- echo " "
- echo -e "\033[1;31mBackup Completado !!!\033[0m"
- echo " "
- echo -e "\033[1;37mLos usuarios $i se encuentra en el archivo \033[1;31m $bc \033[1;37m"
- }
- function restaurar_usuarios(){
- cd $HOME
- echo "INGRESE LINK Que Mantienes Online en GitHub, o VPS "
- read -p "Pega tu Link : " url1
- wget -q -O recovery $url1 && echo -e "\033[1;31m- \033[1;32mFile Exito!" || echo -e "\033[1;31m- \033[1;31mFile Fallo"
- #echo -n "Escriba el directorio del archivo Backup: "
- echo -e "\033[1;37mRestaurando Usuarios...\033[0m"
- [[ -e $HOME/recovery ]] && arq="$HOME/recovery" || return
- for user in `cat $arq`
- do
- usuario=$(echo "$user" |awk -F : '{print $1}')
- senha=$(echo "$user" |awk -F : '{print $2}')
- limite=$(echo "$user" |awk -F : '{print $3}')
- data=$(echo "$user" |awk -F : '{print $4}')
- usrHT=$(echo "$user" |awk -F : '{print $5}')
- valid=$(date '+%C%y-%m-%d' -d " +$data days")
- datexp=$(date "+%d/%m/%Y" -d " +$data days")
- if cat /etc/passwd |grep $usuario: 1> /dev/null 2>/dev/null
- then
- echo -e "\033[1;37m\033[1;31m$usuario \033[1;37mEXISTE: \033[1;31m$senha [\033[1;31mFAILED\033[1;37m]\033[0m" > /dev/null
- else
- echo "$user" |cut -d: -f3 1> /dev/null 2>/dev/null
- if [ $? = 0 ]
- then
- useradd -M -s /bin/false $usuario
- (echo $senha ; echo $senha) | passwd $usuario > /dev/null 2> /dev/null
- limit $usuario $limite 1> /dev/null 2> /dev/null
- [[ $(echo $limite) = "HWID" ]] && echo "senha: $usrHT" > /etc/adm-lite/userDIR/$usuario
- [[ $(echo $limite) = "TOKEN" ]] && echo "senha: $usrHT" > /etc/adm-lite/userDIR/$usuario
- [[ "$limite" =~ ^[0-9]+$ ]] && echo "senha: $senha" > /etc/adm-lite/userDIR/$usuario
- echo "limite: $limite" >> /etc/adm-lite/userDIR/$usuario
- echo "data: $valid" >> /etc/adm-lite/userDIR/$usuario
- chage -E $valid $usuario 2> /dev/null
- [[ $(echo $limite) = "HWID" ]] && echo -e "\033[1;31m$usrHT \033[1;37mRESTORE: \033[1;31m$limite - \033[1;37m[\033[1;31mOk\033[1;37m] \033[1;37mcon\033[1;31m $data \033[1;37m Dias\033[0m"
- [[ $(echo $limite) = "TOKEN" ]] && echo -e "\033[1;31m$usrHT \033[1;37mRESTORE: \033[1;31m$limite - \033[1;37m[\033[1;31mOk\033[1;37m] \033[1;37mcon\033[1;31m $data \033[1;37m Dias\033[0m"
- [[ "$limite" =~ ^[0-9]+$ ]] && echo -e "\033[1;31m$usuario \033[1;37mRESTORE: \033[1;31m$senha - \033[1;37m[\033[1;31mOk\033[1;37m] \033[1;37mcon\033[1;31m $data \033[1;37m Dias\033[0m"
- else
- useradd -M -s /bin/false $usuario
- (echo $senha ; echo $senha) | passwd $usuario > /dev/null 2> /dev/null
- [[ $(echo $limite) = "HWID" ]] && echo -e "\033[1;31m$usrHT \033[1;37mRESTORE: \033[1;31m$limite - \033[1;37m[\033[1;31mOk\033[1;37m] \033[1;37mcon\033[1;31m $data \033[1;37m Dias\033[0m"
- [[ $(echo $limite) = "TOKEN" ]] && echo -e "\033[1;31m$usrHT \033[1;37mRESTORE: \033[1;31m$limite - \033[1;37m[\033[1;31mOk\033[1;37m] \033[1;37mcon\033[1;31m $data \033[1;37m Dias\033[0m"
- [[ "$limite" =~ ^[0-9]+$ ]] && echo -e "\033[1;31m$usuario \033[1;37mRESTORE: \033[1;31m$senha - \033[1;37m[\033[1;31mOk\033[1;37m] \033[1;37mcon\033[1;31m $data \033[1;37m Dias\033[0m"
- echo "limite: $limite" >> /etc/adm-lite/userDIR/$usuario
- chage -E $valid $usuario 2> /dev/null
- fi
- fi
- done
- }
- _resLOC () {
- cd $HOME
- echo "INGRESE LA RUTA LOCAL DONDE TIENES ALOJADO EL FICHERO "
- echo -e " EJEMPLO : /root/file.txt "
- read -p "Pega TU RUTA : " url1
- [[ -e $url1 ]] && {
- echo -e " FILE ENCONTRADO \n"
- arq="$url1"
- } || {
- echo -e " FILE NO FOUND \n"
- return
- }
- #echo -n "Escriba el directorio del archivo Backup: "
- echo -e "\033[1;37mRestaurando Usuarios de ... $arq\033[0m \n"
- for user in `cat $arq`
- do
- usuario=$(echo "$user" |awk -F : '{print $1}')
- senha=$(echo "$user" |awk -F : '{print $2}')
- limite=$(echo "$user" |awk -F : '{print $3}')
- data=$(echo "$user" |awk -F : '{print $4}')
- usrHT=$(echo "$user" |awk -F : '{print $5}')
- valid=$(date '+%C%y-%m-%d' -d " +$data days")
- datexp=$(date "+%d/%m/%Y" -d " +$data days")
- if cat /etc/passwd |grep $usuario: 1> /dev/null 2>/dev/null
- then
- echo -e "\033[1;37m\033[1;31m$usuario \033[1;37mEXISTE: \033[1;31m$senha [\033[1;31mFAILED\033[1;37m]\033[0m" > /dev/null
- else
- echo "$user" |cut -d: -f3 1> /dev/null 2>/dev/null
- if [ $? = 0 ]
- then
- useradd -M -s /bin/false $usuario
- (echo $senha ; echo $senha) | passwd $usuario > /dev/null 2> /dev/null
- limit $usuario $limite 1> /dev/null 2> /dev/null
- [[ $(echo $limite) = "HWID" ]] && echo "senha: $usrHT" > /etc/adm-lite/userDIR/$usuario
- [[ $(echo $limite) = "TOKEN" ]] && echo "senha: $usrHT" > /etc/adm-lite/userDIR/$usuario
- [[ "$limite" =~ ^[0-9]+$ ]] && echo "senha: $senha" > /etc/adm-lite/userDIR/$usuario
- echo "limite: $limite" >> /etc/adm-lite/userDIR/$usuario
- echo "data: $valid" >> /etc/adm-lite/userDIR/$usuario
- chage -E $valid $usuario 2> /dev/null
- [[ $(echo $limite) = "HWID" ]] && echo -e "\033[1;31m$usrHT \033[1;37mRESTORE: \033[1;31m$limite - \033[1;37m[\033[1;31mOk\033[1;37m] \033[1;37mcon\033[1;31m $data \033[1;37m Dias\033[0m"
- [[ $(echo $limite) = "TOKEN" ]] && echo -e "\033[1;31m$usrHT \033[1;37mRESTORE: \033[1;31m$limite - \033[1;37m[\033[1;31mOk\033[1;37m] \033[1;37mcon\033[1;31m $data \033[1;37m Dias\033[0m"
- [[ "$limite" =~ ^[0-9]+$ ]] && echo -e "\033[1;31m$usuario \033[1;37mRESTORE: \033[1;31m$senha - \033[1;37m[\033[1;31mOk\033[1;37m] \033[1;37mcon\033[1;31m $data \033[1;37m Dias\033[0m"
- else
- useradd -M -s /bin/false $usuario
- (echo $senha ; echo $senha) | passwd $usuario > /dev/null 2> /dev/null
- [[ $(echo $limite) = "HWID" ]] && echo -e "\033[1;31m$usrHT \033[1;37mRESTORE: \033[1;31m$limite - \033[1;37m[\033[1;31mOk\033[1;37m] \033[1;37mcon\033[1;31m $data \033[1;37m Dias\033[0m"
- [[ $(echo $limite) = "TOKEN" ]] && echo -e "\033[1;31m$usrHT \033[1;37mRESTORE: \033[1;31m$limite - \033[1;37m[\033[1;31mOk\033[1;37m] \033[1;37mcon\033[1;31m $data \033[1;37m Dias\033[0m"
- [[ "$limite" =~ ^[0-9]+$ ]] && echo -e "\033[1;31m$usuario \033[1;37mRESTORE: \033[1;31m$senha - \033[1;37m[\033[1;31mOk\033[1;37m] \033[1;37mcon\033[1;31m $data \033[1;37m Dias\033[0m"
- echo "limite: $limite" >> /etc/adm-lite/userDIR/$usuario
- chage -E $valid $usuario 2> /dev/null
- fi
- fi
- done
- }
- if [ $option -eq 1 ]; then
- backup_de_usuarios
- echo -e "-------------------------------------------------------"
- echo -e " \033[4;31mNOTA importante\033[0m"
- echo -e "Recuerda Ir a GitHub y cargarlo Online, para luego poder Restaurarlo!!"
- echo -e "-------------------------------------------------------"
- echo -e " \033[0;31mSi esta usando maquina, Montalo Online"
- echo -e " Para luego usar el Link del Fichero, y puedas ."
- echo -e " Descargarlo desde cualquier sitio con acceso WEB"
- echo -e " Ejemplo : http://ip-del-vps:81/tu-fichero.\033[0m"
- echo -e "-------------------------------------------------------"
- read -p "PRESIONA ENTER PARA CARGAR ONLINE"
- removeonline
- fi
- if [ $option -eq 2 ]; then
- restaurar_usuarios
- fi
- if [ $option -eq 3 ]; then
- _resLOC
- fi
|