2023-05-01 11:56:22 +03:00
|
|
|
#! /bin/bash
|
|
|
|
|
|
|
|
# DESCRIPTION:
|
2023-05-01 16:55:45 +03:00
|
|
|
# checking openvpn server certificates expiration
|
|
|
|
# and
|
|
|
|
# preparing stats for monitoring
|
2023-05-01 11:56:22 +03:00
|
|
|
#
|
|
|
|
# DEPENDENCIES:
|
2023-05-01 16:55:45 +03:00
|
|
|
# - privileged rights
|
|
|
|
# - openssl
|
2023-05-01 11:56:22 +03:00
|
|
|
#
|
|
|
|
# PARAMETERS:
|
|
|
|
# 1: "qn" - execution without pauses
|
2023-05-01 16:55:45 +03:00
|
|
|
# 2: openvpn server config file path
|
2023-05-01 11:56:22 +03:00
|
|
|
#
|
|
|
|
# FUNCTIONS:
|
|
|
|
#
|
|
|
|
|
|
|
|
#######################################
|
|
|
|
# Print message and add to log.
|
|
|
|
# Globals:
|
|
|
|
# logs
|
|
|
|
# Arguments:
|
|
|
|
# 1: message to print and logging
|
|
|
|
#######################################
|
|
|
|
addtologs() {
|
|
|
|
echo "$(date +'%Y.%m.%d-%H:%M:%S') $1" | tee -a "${logs}"
|
|
|
|
}
|
|
|
|
|
|
|
|
#######################################
|
|
|
|
# Waiting for press [ENTER].
|
|
|
|
# Globals:
|
|
|
|
# None
|
|
|
|
# Arguments:
|
|
|
|
# None
|
|
|
|
#######################################
|
|
|
|
execpause() {
|
|
|
|
read -r -p "Press [ENTER] to continue... "
|
|
|
|
}
|
|
|
|
|
|
|
|
#######################################
|
|
|
|
# Exit procedure.
|
|
|
|
# Globals:
|
|
|
|
# show
|
|
|
|
# Arguments:
|
|
|
|
# None
|
|
|
|
#######################################
|
|
|
|
execquite() {
|
|
|
|
addtologs "execution time is $(($(date +%s)-time)) seconds, exit"
|
|
|
|
if [ "${show}" != "qn" ]; then
|
|
|
|
execpause
|
|
|
|
fi
|
|
|
|
exit
|
|
|
|
}
|
|
|
|
|
|
|
|
#######################################
|
|
|
|
# Error exit procedure
|
|
|
|
# Globals:
|
|
|
|
# None
|
|
|
|
# Arguments:
|
|
|
|
# 1: message to print and logging
|
|
|
|
#######################################
|
|
|
|
execerror() {
|
|
|
|
addtologs "error: $1"
|
|
|
|
execquite
|
|
|
|
}
|
|
|
|
|
|
|
|
#######################################
|
|
|
|
# Parsing config file and creating global vars.
|
|
|
|
# Globals:
|
|
|
|
# None
|
|
|
|
# Arguments:
|
|
|
|
# None
|
|
|
|
#######################################
|
|
|
|
getconfig() {
|
2023-05-01 16:55:45 +03:00
|
|
|
cacrpath=$(grep ^ca "${conf}" | cut -d' ' -f2)
|
|
|
|
certpath=$(grep ^cert "${conf}" | cut -d' ' -f2)
|
|
|
|
statfile="$(dirname "$(grep ^log /etc/openvpn/server/server.conf | cut -d' ' -f2)")/$(basename -s .sh "$0").log"
|
2023-05-01 11:56:22 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
#######################################
|
|
|
|
# Checking user rights.
|
|
|
|
# Globals:
|
|
|
|
# None
|
|
|
|
# Arguments:
|
|
|
|
# None
|
|
|
|
# return:
|
|
|
|
# 0 - if privileged rights, 1 - if not privileged rights
|
|
|
|
#######################################
|
|
|
|
checkroot() {
|
|
|
|
if [ "${EUID}" -ne 0 ]; then
|
|
|
|
return 1 # false
|
|
|
|
else
|
|
|
|
return 0 # true
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2023-05-01 16:55:45 +03:00
|
|
|
#######################################
|
|
|
|
# Print certificate expiration date in epoch
|
|
|
|
# Globals:
|
|
|
|
# None
|
|
|
|
# Arguments:
|
|
|
|
# 1: certificate path
|
|
|
|
#######################################
|
|
|
|
checkcert() {
|
|
|
|
printf '%s\n' "$(date -d "$(openssl x509 -text -noout -in "${1}" | grep 'Not After' | cut -d':' -f2-)" +%s)"
|
|
|
|
}
|
|
|
|
|
2023-05-01 11:56:22 +03:00
|
|
|
#
|
|
|
|
# VARIABLES:
|
|
|
|
#
|
|
|
|
|
|
|
|
show=$1
|
|
|
|
conf=$2
|
2023-05-01 16:55:45 +03:00
|
|
|
logs=/dev/null
|
2023-05-01 11:56:22 +03:00
|
|
|
if [ -z "${conf}" ] || [ "${conf}" == "-" ]; then
|
2023-05-01 16:55:45 +03:00
|
|
|
conf=/etc/openvpn/server/server.conf
|
2023-05-01 11:56:22 +03:00
|
|
|
fi
|
|
|
|
|
|
|
|
time=$(date +%s)
|
|
|
|
cd "$(dirname "$(realpath "$0")")" || execerror
|
|
|
|
if [ ! -e "${conf}" ]; then
|
2023-05-01 16:55:45 +03:00
|
|
|
execerror "${conf} not found"
|
2023-05-01 11:56:22 +03:00
|
|
|
else
|
|
|
|
getconfig
|
|
|
|
fi
|
2023-05-01 16:55:45 +03:00
|
|
|
|
|
|
|
if ! command -v openssl &> /dev/null; then
|
|
|
|
execerror "Not found dependencies"
|
2023-05-01 11:56:22 +03:00
|
|
|
fi
|
|
|
|
|
|
|
|
#
|
|
|
|
# MAIN:
|
|
|
|
#
|
|
|
|
|
2023-05-01 16:55:45 +03:00
|
|
|
if checkroot; then
|
|
|
|
cacrtime=$(checkcert "${cacrpath}")
|
|
|
|
certtime=$(checkcert "${certpath}")
|
|
|
|
cacrremain=$(( cacrtime - time ))
|
|
|
|
certremain=$(( certtime - time))
|
|
|
|
addtologs "${cacrpath} remains only ${cacrremain} seconds"
|
|
|
|
addtologs "${certpath} remains only ${certremain} seconds"
|
|
|
|
printf '%s\n' "ca=${cacrremain}" > "${statfile}"
|
|
|
|
printf '%s\n' "cert=${certremain}" >> "${statfile}"
|
|
|
|
addtologs "stats wrote to ${statfile}"
|
|
|
|
execquite
|
|
|
|
else
|
|
|
|
execerror "Restart this as root!"
|
|
|
|
fi
|