| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274 |
- #!/bin/bash
- u_dir="/etc/adm-lite/userDIR"
- tmp_verifica="/etc/adm-lite/tmp_tmp"
- _arquivo1="/etc/adm-lite/tmp_arq1"
- _arquivo2="/etc/adm-lite/tmp_arq2"
- _arquivo3="/etc/adm-lite/tmp_arq3"
- _arquivo4="/etc/adm-lite/tmp_arq4"
- [[ ! -d "$u_dir" ]] && mkdir $u_dir
- [[ -e "$_arquivo1" ]] && rm $_arquivo1
- [[ -e "$_arquivo2" ]] && rm $_arquivo2
- [[ -e "$_arquivo3" ]] && rm $_arquivo3
- [[ -e "$_arquivo4" ]] && rm $_arquivo4
- function_dropb () {
- port_dropbear=`ps aux | grep dropbear | awk NR==1 | awk '{print $17;}'`
- [[ $port_dropbear = "" ]] && return
- log=/var/log/auth.log
- loginsukses='Password auth succeeded'
- echo ' '
- pids=`ps ax |grep dropbear |grep " $port_dropbear" |awk -F" " '{print $1}'`
- for pid in $pids
- do
- pidlogs=`grep $pid $log |grep "$loginsukses" |awk -F" " '{print $3}'`
- i=0
- for pidend in $pidlogs
- do
- let i=i+1
- 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}'`
- while [ ${#waktu} -lt 13 ]; do
- waktu=$waktu" "
- done
- while [ ${#user} -lt 16 ]; do
- user=$user" "
- done
- while [ ${#PID} -lt 8 ]; do
- PID=$PID" "
- done
- echo "$user $PID $waktu"
- fi
- done
- echo ""
- return
- }
- dropbear_pids () {
- unset pids
- port_dropbear=`ps aux | grep dropbear | awk NR==1 | awk '{print $17;}'`
- log=/var/log/auth.log
- 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 () {
- #nome|#loguin|#rcv|#snd|#time
- 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
- [[ ! $(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
- }
- 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
- }
- function_onlines () {
- (
- unset _on ssh
- #_ons=$(ps -x | grep sshd | grep -v root | grep priv | wc -l)
- #[[ "$(cat /etc/SSHPlus/Exp)" != "" ]] && _expuser=$(cat /etc/SSHPlus/Exp) || _expuser="0"
- #[[ -e /etc/openvpn/openvpn-status.log ]] && _onop=$(grep -c "10.8.0" /etc/openvpn/openvpn-status.log) || _onop="0"
- #[[ -e /etc/default/dropbear ]] && _drp=$(ps aux | grep dropbear | grep -v grep | wc -l) _ondrp=$(($_drp - 1)) || _ondrp="0"
- for user in $(mostrar_usuarios); do
- ssh+="$(ps -u $user | grep sshd |wc -l)+"
- ssh+="$(dropbear_pids|grep "$user"|wc -l)+"
- [[ -e /etc/openvpn/openvpn-status.log ]] && ssh+="$(fun_ovpn_onl|grep "$user"|wc -l)+"
- ssh+="0"
- _on=$(echo $ssh|bc)
- done
- #Usuarios Vencidos
- datenow=$(date +%s)
- for user in $(awk -F: '{print $1}' /etc/passwd); do
- expdate=$(chage -l $user|awk -F: '/Account expires/{print $2}')
- echo $expdate|grep -q never && continue
- datanormal=$(date -d"$expdate" '+%d/%m/%Y')
- expsec=$(date +%s --date="$expdate")
- diff=$(echo $datenow - $expsec|bc -l)
- echo $diff|grep -q ^\- && continue
- vencidos[1]+="1+"
- done
- #Fazendo A Soma#
- vencidos[1]+="0"
- vencidos[1]=$(echo ${vencidos[1]}|bc)
- echo "$_on" > ./onlines
- echo "${vencidos[1]}" > ./vencidos
- ) &
- }
- fun_ovpn_onl () {
- for userovpn in `cat /etc/passwd | grep ovpn | awk -F: '{print $1}'`; do
- us=$(cat /etc/openvpn/openvpn-status.log | grep $userovpn | wc -l)
- [[ "$us" != "0" ]] && echo "$userovpn"
- done
- }
- function_usertime () {
- (
- declare -A data
- declare -A time
- declare -A time2
- declare -A timefinal
- tempousers="./tempo_conexao"
- usr_pids_var="./userDIR"
- [[ ! -e $tempousers ]] && touch $tempousers
- _data_now=$(date +%s)
- 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]`; do
- unset ssh
- [[ -e $usr_pids_var/$user.pid ]] && source $usr_pids_var/$user.pid
- ssh+="$(ps -u $user | grep sshd |wc -l)+"
- ssh+="$(function_dropb | grep "$user" | wc -l)+"
- [[ -e /etc/openvpn/server.conf ]] && ssh+="$(fun_ovpn_onl | grep "$user" | wc -l)+"
- ssh+="0"
- user_pid=$(echo $ssh|bc)
- if [ "$user_pid" -gt "0" ]; then
- [[ "${data[$user]}" = "" ]] && data[$user]="$_data_now"
- if [ ! -e $usr_pids_var/$user.pid2 ]; then
- [[ -e $usr_pids_var/$user.pid ]] && cp $usr_pids_var/$user.pid $usr_pids_var/$user.pid2
- fi
- fi
- if [ "$user_pid" = "0" ]; then
- unset data[$user]
- [[ -e "$usr_pids_var/$user.pid" ]] && rm $usr_pids_var/$user.pid
- [[ -e $usr_pids_var/$user.pid2 ]] && rm $usr_pids_var/$user.pid2
- fi
- if [ "${data[$user]}" != "" ]; then
- time[$user]=$(($_data_now - ${data[$user]}))
- time2[$user]=$(cat $tempousers | grep "$user" | awk '{print $2}')
- [[ "${time2[$user]}" = "" ]] && time2[$user]="0"
- timefinal[$user]=$((${time2[$user]} + ${time[$user]}))
- _arquivo=$(cat $tempousers |grep -v "$user")
- echo "$_arquivo" > $tempousers
- echo "$user ${timefinal[$user]}" >> $tempousers
- echo "data[$user]=$_data_now" > $usr_pids_var/$user.pid
- fi
- done
- ) &
- }
- fun_net () {
- (
- log_0="/tmp/tcpdum"
- log_1="/tmp/tcpdump"
- log_2="/tmp/tcpdumpLOG"
- usr_dir="/etc/adm-lite/userDIR/usr_cnx"
- [[ -e "$log_1" ]] && mv -f $log_1 $log_2
- [[ ! -e $usr_dir ]] && touch $usr_dir
- #ENCERRA TCP
- for pd in `ps x | grep tcpdump | grep -v grep | awk '{print $1}'`; do
- kill -9 $pd > /dev/null 2>&1
- done
- #INICIA TCP
- tcpdump -s 50 -n 1> /tmp/tcpdump 2> /dev/null &
- [[ ! -e /tmp/tcpdump ]] && touch /tmp/tcpdump
- #ANALIZA USER
- for user in `awk -F : '$3 > 900 { print $1 }' /etc/passwd | grep -v "nobody" |grep -vi polkitd |grep -vi system-`; do
- touch /tmp/$user
- ip_openssh $user > /dev/null 2>&1
- ip_drop $user > /dev/null 2>&1
- sed -i '/^$/d' /tmp/$user
- pacotes=$(paste -sd+ /tmp/$user | bc)
- rm /tmp/$user
- if [ "$pacotes" != "" ]; then
- if [ "$(cat $usr_dir | grep "$user")" != "" ]; then
- pacotesuser=$(cat $usr_dir | grep "$user" | awk '{print $2}')
- [[ $pacotesuser = "" ]] && pacotesuser=0
- [[ $pacotesuser != +([0-9]) ]] && pacotesuser=0
- ussrvar=$(cat $usr_dir | grep -v "$user")
- echo "$ussrvar" > $usr_dir
- pacotes=$(($pacotes+$pacotesuser))
- echo -e "$user $pacotes" >> $usr_dir
- else
- echo -e "$user $pacotes" >> $usr_dir
- fi
- fi
- unset pacotes
- done
- ) &
- }
- ip_openssh () {
- user="$1"
- for ip in `lsof -u $user -P -n | grep "ESTABLISHED" | awk -F "->" '{print $2}' |awk -F ":" '{print $1}' | grep -v "127.0.0.1"`; do
- packet=$(cat $log_2 | grep "$ip" | wc -l)
- echo "$packet" >> /tmp/$user
- unset packet
- done
- }
- ip_drop () {
- user="$1"
- loguser='Password auth succeeded'
- touch /tmp/drop
- for ip in `cat /var/log/auth.log | tail -100 | grep "$user" | grep "$loguser" | awk -F "from" '{print $2}' | awk -F ":" '{print $1}'`; do
- if [ "$(cat /tmp/drop | grep "$ip")" = "" ]; then
- packet=$(cat $log_2 | grep "$ip" | wc -l)
- echo "$packet" >> /tmp/$user
- echo "$ip" >> /tmp/drop
- fi
- done
- rm /tmp/drop
- }
- #killall menu > /dev/null 2>&1
- #kill -9 $(ps x|grep -v grep|grep limiter.sh|awk '{print $1}')
- function_usertime > /dev/null 2>&1
- #function_killmultiloguin > /dev/null 2>&1
- function_onlines > /dev/null 2>&1
- #fun_net > /dev/null 2>&1
|