mirror of
https://github.com/pivpn/pivpn.git
synced 2024-12-23 13:20:16 +00:00
d17d381049
DNS resolution even if the user does not route the local network through the tunnel. - Format listCONF in a similar way as listOVPN - Specifically look for a free octet in the last word of clients.txt and not just any word. Necessary otherwhise public keys starting with a number will match against an octet. Example: if line is 'name 5abcdefgh 4', then looking for ' 5' will match but '5$' will not (correctly). - 'pivpn -c' will show the Connected Clients List for WireGuard too
28 lines
No EOL
743 B
Bash
Executable file
28 lines
No EOL
743 B
Bash
Executable file
#!/bin/bash
|
|
|
|
cd /etc/wireguard/configs
|
|
if [ ! -s clients.txt ]; then
|
|
echo "::: There are no clients to list"
|
|
exit 1
|
|
fi
|
|
|
|
printf "\e[1m::: Clients Summary :::\e[0m\n"
|
|
|
|
# Present the user with a summary of the clients, fetching info from dates.
|
|
{
|
|
echo -e "\e[4mClient\e[0m \t \e[4mPublic key\e[0m \t \e[4mCreation date\e[0m"
|
|
|
|
while read -r LINE; do
|
|
CLIENT_NAME="$(awk '{print $1}' <<< "$LINE")"
|
|
|
|
PUBLIC_KEY="$(awk '{print $2}' <<< "$LINE")"
|
|
|
|
CREATION_DATE="$(awk '{print $3}' <<< "$LINE")"
|
|
|
|
# Dates are converted from UNIX time to human readable.
|
|
CD_FORMAT="$(date -d @"$CREATION_DATE" +'%d %b %Y, %H:%M, %Z')"
|
|
|
|
echo -e "$CLIENT_NAME \t $PUBLIC_KEY \t $CD_FORMAT"
|
|
done < clients.txt
|
|
|
|
} | column -t -s $'\t' |