Одним из значительных преимуществ использования собственного сценария adduser является возможность расширять его и изменять логику отдельных операций, не заботясь об обновлении системы под эти изменения. В числе вероятных расширений автоматическая отправка приветственного электронного письма, в общих чертах обрисовывающего порядок работы и способы получения справочной информации, автоматическая печать на бумаге сводной информации об учетной записи для передачи пользователю, добавление псевдонима firstname_lastname или firstname.lastname в файл
№ 41. Приостановка действия учетной записи
Есть много случаев, когда желательно заблокировать учетную запись, не удаляя ее из системы, например, когда пользователь уличен в краже промышленных секретов и идет разбирательство, студент отправился отдыхать на летние каникулы или подрядчик ушел в отпуск.
Можно просто изменить пароль пользователя и не сообщить ему, но, если пользователь в это время находится в системе, также важно было бы принудительно вывести его из системы и закрыть доступ к его домашнему каталогу из других учетных записей в системе. Когда действие учетной записи приостанавливается, почти всегда требуется вывести пользователя из системы
Бо́льшая часть сценария в листинге 5.16 связана с определением присутствия пользователя в системе, его уведомлением о завершении сеанса и принудительным выводом из системы.
Код
Листинг 5.16. Сценарий suspenduser
#!/bin/bash
# suspenduser — приостанавливает действие учетной записи до неопределенного
#·· момента в будущем
homedir="/home" # Местонахождение домашних каталогов пользователей
secs=10········ # Пауза в секундах перед выводом пользователя из системы
if [-z $1]; then
··echo "Usage: $0 account" >&2
··exit 1
elif ["$(id −un)"!= "root"]; then
··echo "Error. You must be 'root' to run this command." >&2
··exit 1
fi
echo "Please change the password for account $1 to something new."
passwd $1
# Теперь посмотрим, если пользователь зарегистрирован в системе.
#·· выведем его принудительно.
if who|grep "$1" > /dev/null; then
··for tty in $(who | grep $1 | awk '{print $2}'); do
····cat << "EOF" > /dev/$tty
******************************************************************************
URGENT NOTICE FROM THE ADMINISTRATOR:
This account is being suspended, and you are going to be logged out
in $secs seconds. Please immediately shut down any processes you
have running and log out.
If you have any questions, please contact your supervisor or
John Doe, Director of Information Technology.
******************************************************************************
EOF
··done
··echo "(Warned $1, now sleeping $secs seconds)"
··sleep $secs
··jobs=$(ps −u $1 | cut −d\ −f1)
·· sleep 1·········· # Дать одну секунду…
·· echo "$1 was logged in. Just logged them out."
fi
# В заключение закрыть домашний каталог от любопытных глаз.
chmod 000 $homedir/$1
echo "Account $1 has been suspended."
exit 0
Как это работает