vpn-stack/sbin/wg-client-enable.sh

55 lines
1.5 KiB
Bash
Raw Normal View History

2021-01-25 15:37:53 -08:00
#!/bin/bash
#
# vpn-stack
2021-01-25 15:37:53 -08:00
# A set of bash scripts for installing and managing a WireGuard VPN server.
# https://git.stack-source.com/msb/vpn-stack
2022-07-14 12:32:41 -07:00
# Copyright (c) 2022 Matthew Saunders Brown <matthewsaundersbrown@gmail.com>
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
2021-01-25 15:37:53 -08:00
# load include file
source $(dirname $0)/wg.sh
2021-01-25 15:37:53 -08:00
help()
{
thisfilename=$(basename -- "$0")
echo "Enable existing VPN client config."
echo ""
echo "usage: $thisfilename -c <client> [-h]"
echo ""
echo " -h Print this help."
echo " -c <client> Name of the client configuration."
}
2021-01-25 15:37:53 -08:00
wg::getoptions "$@"
# check for client config name
if [[ -z $client ]]; then
echo "client name is required"
exit
2021-01-25 15:37:53 -08:00
fi
# set config file name
config=$client.conf
2021-01-25 15:37:53 -08:00
# check for server config
if [ -f /etc/wireguard/peers/$config ]; then
peer=$(grep PublicKey /etc/wireguard/peers/$config|cut -d ' ' -f 3)
status=$(wg |grep -c $peer)
if [ $status = 0 ]; then
wg addconf wg0 /etc/wireguard/peers/$config
wg-quick save wg0
echo "peer for $client enabled"
2021-01-25 15:37:53 -08:00
elif [ $status = 1 ]; then
echo "peer for $client already enabled"
2021-01-25 15:37:53 -08:00
else
echo "unexpected status for peer $client ($status)"
2021-01-25 15:37:53 -08:00
fi
elif [ -f /etc/wireguard/clients/$config ]; then
# create server config
# enable server config
echo "server config for $client not found, but client config exists."
2021-01-25 15:37:53 -08:00
echo "add programming here to create server config and enable"
else
echo "no configs for $client found"
2021-01-25 15:37:53 -08:00
fi