pivpn/scripts/openvpn/listOVPN.sh

43 lines
1.3 KiB
Bash
Raw Normal View History

2019-10-14 10:27:28 +00:00
#!/usr/bin/env bash
# PiVPN: list clients script
# Updated Script to include Expiration Dates and Clean up Escape Seq -- psgoundar
2019-10-14 10:27:28 +00:00
INDEX="/etc/openvpn/easy-rsa/pki/index.txt"
if [ ! -f "${INDEX}" ]; then
echo "The file: $INDEX was not found!"
exit 1
fi
2020-10-01 11:23:31 +00:00
EASYRSA="/etc/openvpn/easy-rsa/easyrsa"
if [ ! -f "${EASYRSA}" ]; then
echo "The file: $EASYRSA was not found!"
exit 1
fi
$EASYRSA update-db >> /dev/null 2>1
2020-09-10 12:55:35 +00:00
2019-10-14 10:27:28 +00:00
printf ": NOTE : The first entry should always be your valid server!\n"
printf "\\n"
printf "\\e[1m::: Certificate Status List :::\\e[0m\\n"
{
printf "\\e[4mStatus\\e[0m \t \\e[4mName\\e[0m\\e[0m \t \\e[4mExpiration\\e[0m\\n"
2019-10-14 10:27:28 +00:00
while read -r line || [ -n "$line" ]; do
STATUS=$(echo "$line" | awk '{print $1}')
NAME=$(echo "$line" | awk -FCN= '{print $2}')
EXPD=$(echo "$line" | awk '{if (length($2) == 15) print $2; else print "20"$2}' | cut -b 1-8 | date +"%b %d %Y" -f -)
2019-10-14 10:27:28 +00:00
if [ "${STATUS}" == "V" ]; then
printf "Valid \t %s \t %s\\n" "$NAME" "$EXPD"
2019-10-14 10:27:28 +00:00
elif [ "${STATUS}" == "R" ]; then
printf "Revoked \t %s \t %s\\n" "$NAME" "$EXPD"
2020-09-10 12:55:35 +00:00
elif [ "${STATUS}" == "E" ]; then
printf " Expired :: %s\n" "$NAME"
2019-10-14 10:27:28 +00:00
else
printf "Unknown \t %s \t %s\\n" "$NAME" "$EXPD"
2019-10-14 10:27:28 +00:00
fi
done <${INDEX}
printf "\\n"
} | column -t -s $'\t'