Как я могу получить изменения, используя файл inotifywait?
Я хочу получать имя пользователя каждый раз, когда его пароль изменяется в /etc/shadow. Вот мой сценарий:
while inotifywait -e attrib /etc/shadow; do
#edit user
while IFS=: read -r f1 f2
#get username for changed password
done < $file
#end edit user
done
Как я могу легко это сделать?
1 ответ
Решение
Для показа вашего последнего изменения пароля используйте passwd
passwd -S | awk '{print $3}'
или для другого имени пользователя
sudo passwd -S user_name | awk '{print $3}'
Поэтому вы можете перебирать имена пользователей в /etc/passwd
в вашем скрипте и покажите метки времени для каждого пользователя, может быть, для пользователей с ID >= 1000.
while inotifywait -e attrib /etc/shadow; do
awk -F: '($3 >= 1000) {print $1}' /etc/passwd | xargs -I{} passwd -S {} | awk '{print $1,$3}'
done
Чтобы определить, какие именно элементы изменились, вы должны сохранить выходные данные awk …
и сравни со следующим стартом.
пример
% passwd -S | awk '{print $3}'
07/14/2015
% passwd
Changing password for aboettger.
(current) UNIX password:
Enter new UNIX password:
Retype new UNIX password:
passwd: password updated successfully
% passwd -S | awk '{print $3}'
10/01/2015
или для конкретной учетной записи пользователя
% sudo passwd -S root | awk '{print $3}'
05/29/2015
или для всех пользователей
% awk -F: '($3 >= 1000) {print $1}' /etc/passwd | xargs -I{} passwd -S {} | awk '{print $1,$3}'
passwd: You may not view or modify password information for nobody.
aboettger 10/01/2015