2020-10-16 00:32:37 +08:00
|
|
|
#! /usr/bin/env bash
|
|
|
|
# vim: set filetype=sh ts=4 sw=4 sts=4 et:
|
|
|
|
set -e
|
|
|
|
|
|
|
|
basedir=$(readlink -f "$(dirname "$0")"/../..)
|
|
|
|
# shellcheck source=lib/shell/functions.inc
|
|
|
|
. "$basedir"/lib/shell/functions.inc
|
|
|
|
|
2022-01-20 23:51:45 +08:00
|
|
|
# default config values for this script
|
2022-01-21 23:58:14 +08:00
|
|
|
MAX_AGE=86400
|
2020-10-16 00:32:37 +08:00
|
|
|
|
2022-01-20 23:51:45 +08:00
|
|
|
# set error trap, read config, setup logging, exit early if script is disabled, etc.
|
|
|
|
script_init osh-lingering-sessions-reaper config_optional check_secure_lax
|
2020-12-31 20:13:20 +08:00
|
|
|
|
2020-10-16 00:32:37 +08:00
|
|
|
_log "Terminating lingering sessions..."
|
|
|
|
|
|
|
|
tokill=''
|
|
|
|
nb=0
|
|
|
|
# shellcheck disable=SC2162
|
|
|
|
while read etimes pid tty
|
|
|
|
do
|
2022-01-21 23:58:14 +08:00
|
|
|
if [ "$tty" = "?" ] && [ "$etimes" -gt "$MAX_AGE" ]; then
|
2020-10-16 00:32:37 +08:00
|
|
|
tokill="$tokill $pid"
|
2021-01-15 23:06:46 +08:00
|
|
|
(( ++nb ))
|
2020-10-16 00:32:37 +08:00
|
|
|
fi
|
|
|
|
done < <(ps -C ttyrec -o etimes,pid,tty --no-header)
|
|
|
|
if [ -n "$tokill" ]; then
|
2021-01-14 17:35:48 +08:00
|
|
|
# add || true to avoid script termination due to TOCTTOU and set -e
|
2020-10-16 00:32:37 +08:00
|
|
|
# shellcheck disable=SC2086
|
2021-01-14 17:35:48 +08:00
|
|
|
kill $tokill || true
|
2020-10-16 00:32:37 +08:00
|
|
|
_log "Terminated $nb orphan ttyrec sessions (pids$tokill)"
|
|
|
|
fi
|
|
|
|
|
|
|
|
tokill=''
|
|
|
|
nb=0
|
|
|
|
# shellcheck disable=SC2162
|
|
|
|
while read etimes pid tty user
|
|
|
|
do
|
2022-01-21 23:58:14 +08:00
|
|
|
if [ "$tty" = "?" ] && [ "$user" != "root" ] && [ "$etimes" -gt "$MAX_AGE" ]; then
|
2020-10-16 00:32:37 +08:00
|
|
|
if [ "$(ps --no-header --ppid "$pid" | wc -l)" = 0 ]; then
|
|
|
|
tokill="$tokill $pid"
|
2021-01-15 23:06:46 +08:00
|
|
|
(( ++nb ))
|
2020-10-16 00:32:37 +08:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
done < <(ps -C sshd --no-header -o etimes,pid,tty,user)
|
|
|
|
if [ -n "$tokill" ]; then
|
2021-01-14 17:35:48 +08:00
|
|
|
# add || true to avoid script termination due to TOCTTOU and set -e
|
2020-10-16 00:32:37 +08:00
|
|
|
# shellcheck disable=SC2086
|
2021-01-14 17:35:48 +08:00
|
|
|
kill $tokill || true
|
2020-10-16 00:32:37 +08:00
|
|
|
_log "Terminated $nb orphan sshd sessions (pids$tokill)"
|
|
|
|
fi
|
|
|
|
|
2022-01-20 23:51:45 +08:00
|
|
|
exit_success
|