Skip to content

Latest commit

 

History

History
77 lines (63 loc) · 3.12 KB

File metadata and controls

77 lines (63 loc) · 3.12 KB

PAM

Провижинг осуществляется по средством скрипта.

Добавляем пользователей и устанавливаем им пароли:

[root@pam]# useradd -m -s /bin/bash user1
[root@pam]# useradd -m -s /bin/bash user2
[root@pam]# echo "123"|sudo passwd --stdin user1 &&\
[root@pam]# echo "123" | sudo passwd --stdin user2

Создаем группу adm_group и добавляем в него пользователей, user1 сможет заходить в выходные

[root@pam]# groupadd adm_group
[root@pam]# usermod -a -G adm_group user1
[root@pam]# usermod -a -G adm_group root
[root@pam]# usermod -a -G adm_group vagrant

Подключаем PAM-модуль для sshd и настраиваем time.conf:

[root@pam]# sed -i '8i\account required pam_time.so' /etc/pam.d/sshd
[root@pam]# sed -i '62a\*;*;!adm_group;Wd' /etc/security/time.conf

Так же чтобы проверить что пользователь может рестартить сервис, нам потребуется установить сам Docker и дать такую возможность для user2

[root@pam]# usermod -a -G docker user2
[root@pam]# touch /etc/sudoers.d/user2
[root@pam]# cat >> /etc/sudoers.d/user2 << EOF
Cmnd_Alias DOCKER_U2 = /usr/bin/systemctl stop docker, /usr/bin/systemctl start docker, /usr/bin/systemctl restart docker

user2 ALL= NOPASSWD: DOCKER_U2
EOF

[root@pam]# touch /etc/polkit-1/rules.d/01-systemd.rules
[root@pam]# cat >> /etc/polkit-1/rules.d/01-systemd.rules << EOF
polkit.addRule(function(action, subject) {
if (action.id.match("org.freedesktop.systemd1.manage-units") &&
subject.user === "user2") {
return polkit.Result.YES;
}
});
EOF

Решение с pam_time.so действительно работает только с одельными пользователями, а не группами. Поэтому используем модуль pam_exec.so. Написан скрипт, который возвращает 0 если все удовлетворяет нашим условиям, и соответственно 1, если это пользователь не может логироваться в выходные.

#!/bin/bash
if getent group adm_group | grep &>/dev/null $PAM_USER; then

    exit 0;
fi

if [ $(date +%u) -gt 5 ];then

  exit 1;

else

   exit 0;

fi

Кстати, пришлось копировать уже написанный скрипт, потому как иначе Vagrant криво собирал, и терялась часть скрипта.

Что касается части со *

polkit.addRule(function(action, subject) {
if (action.id.match("org.freedesktop.systemd1.manage-units") &&
action.lookup("unit") == "docker.service")  &&
subject.user === "user2") {
return polkit.Result.YES;
}
});

но этот способ работает только с верии systend v226, тоесть только в Centos8, к сожалению, совсем нет времени искать решение для7