Я использовал этот pam-auth-update
инструмент для включения некоторых профилей конфигурации pam:
PAM configuration
PAM profiles to enable:
[*] encfs encrypted home directories
[*] Unix authentication
[*] Mount volumes for user
[*] GNOME Keyring Daemon - Login keyring management
[*] ConsoleKit Session Management
Все функции работают, как и ожидалось, но есть одна вещь - Mount volumes for user
опция влияет на su
команду.
Я добавил следующую строку в /etc/security/pam_mount.conf.xml
файл:
<volume user="morfik" fstype="fuse" path="encfs#/media/Server/Dropbox.encfs/Dropbox/encrypted" mountpoint="/media/Server/Dropbox" />
и когда я набираю в терминале su morfik
(как root), не должно быть никакого запроса пароля, но вместо этого я вижу это:
# su morfik
reenter password for pam_mount:
Если я снял Mount volumes for user
флажок с опции в меню выше, все, кажется, файл и reenter password
исчезает. Я пытался играть с /etc/pam.d/
файлами, но у меня нет опыта работы с PAM, и я не смог заставить его работать.
Кто-нибудь знает, что нужно изменить в этих файлах?
UPDATE # 1
Это содержимое /etc/pam.d
каталога:
# ls -al /etc/pam.d/
total 104K
drwxr-xr-x 2 root root 4.0K Mar 21 16:21 ./
drwxr-xr-x 153 root root 12K Mar 21 16:11 ../
-rw-r--r-- 1 root root 197 Sep 8 2013 atd
-rw-r--r-- 1 root root 384 May 25 2012 chfn
-rw-r--r-- 1 root root 92 May 25 2012 chpasswd
-rw-r--r-- 1 root root 581 May 25 2012 chsh
-rw-r--r-- 1 root root 1.2K Mar 20 17:35 common-account
-rw-r--r-- 1 root root 1.3K Mar 20 17:35 common-auth
-rw-r--r-- 1 root root 1.5K Mar 20 17:35 common-password
-rw-r--r-- 1 root root 1.3K Mar 20 17:35 common-session
-rw-r--r-- 1 root root 1.2K Mar 20 17:35 common-session-noninteractive
-rw-r--r-- 1 root root 527 Jul 3 2012 cron
-rw-r--r-- 1 root root 69 Jul 16 2013 cups-daemon
-rw-r--r-- 1 root root 4.8K Mar 5 10:18 login
-rw-r--r-- 1 root root 92 May 25 2012 newusers
-rw-r--r-- 1 root root 520 Jul 22 2008 other
-rw-r--r-- 1 root root 147 Feb 13 07:15 passwd
-rw-r--r-- 1 root root 255 Oct 15 18:40 polkit-1
-rw-r--r-- 1 root root 84 Dec 27 12:40 samba
-rw-r--r-- 1 root root 2.1K Feb 15 03:11 sshd
-rw-r--r-- 1 root root 2.3K May 25 2012 su
-rw-r--r-- 1 root root 95 Jan 15 22:58 sudo
-rw-r--r-- 1 root root 108 Oct 19 23:42 xscreensaver
Там нет файла /etc/pam.d/system-auth
.
Я проверил, какие файлы есть pam_mount
в их содержимом, и я получил это:
# egrep -i pam_mount *
common-auth:auth optional pam_mount.so
common-session:session optional pam_mount.so
Содержание файлов:
#
# /etc/pam.d/common-auth - authentication settings common to all services
#
# This file is included from other service-specific PAM config files,
# and should contain a list of the authentication modules that define
# the central authentication scheme for use on the system
# (e.g., /etc/shadow, LDAP, Kerberos, etc.). The default is to use the
# traditional Unix authentication mechanisms.
#
# As of pam 1.0.1-6, this file is managed by pam-auth-update by default.
# To take advantage of this, it is recommended that you configure any
# local modules either before or after the default block, and use
# pam-auth-update to manage selection of other modules. See
# pam-auth-update(8) for details.
# here are the per-package modules (the "Primary" block)
auth sufficient pam_encfs.so
auth [success=1 default=ignore] pam_unix.so nullok_secure try_first_pass
# here's the fallback if no module succeeds
auth requisite pam_deny.so
# prime the stack with a positive return value if there isn't one already;
# this avoids us returning an error just because nothing sets a success code
# since the modules above will each just jump around
auth required pam_permit.so
# and here are more per-package modules (the "Additional" block)
auth optional pam_mount.so
# end of pam-auth-update config
а также:
#
# /etc/pam.d/common-session - session-related modules common to all services
#
# This file is included from other service-specific PAM config files,
# and should contain a list of modules that define tasks to be performed
# at the start and end of sessions of *any* kind (both interactive and
# non-interactive).
#
# As of pam 1.0.1-6, this file is managed by pam-auth-update by default.
# To take advantage of this, it is recommended that you configure any
# local modules either before or after the default block, and use
# pam-auth-update to manage selection of other modules. See
# pam-auth-update(8) for details.
# here are the per-package modules (the "Primary" block)
session [default=1] pam_permit.so
# here's the fallback if no module succeeds
session requisite pam_deny.so
# prime the stack with a positive return value if there isn't one already;
# this avoids us returning an error just because nothing sets a success code
# since the modules above will each just jump around
session required pam_permit.so
# and here are more per-package modules (the "Additional" block)
session required pam_unix.so
session optional pam_mount.so
session optional pam_ck_connector.so nox11
# end of pam-auth-update config
UPDATE # 2
Я использую тестирование Debian. Я пытался изменить положение pam_mount
, но это всегда то же самое. Я прочитал некоторые разделы руководства, и там было что-то вроде:
When "sufficient" is used in the second column, you must make sure that pam_mount is added before this entry. Otherwise pam_mount will not get executed should a previous PAM module succeed. Also be aware of the "include" statements. These make PAM look into the specified file. If there is a "sufficient" statement, then the pam_mount entry must either be in the included file before the "sufficient" statement or before the "include" statement.
Я даже добавил pam_mount
в /etc/pam.d/su
файл, чтобы проверить, имеет ли это какое-то значение, но это не имеет значения. Если pam_mount
если сначала, как они говорят, вместо запроса пароля, я получаю pam_mount password
запрос при входе в свою систему, и он по-прежнему запрашивает пароль при попыткеsu morfik
/etc/security/pam_mount.conf.xml
файл, появляется подсказка.Ответы:
Столкнулся с той же проблемой.
Оказывается, проблема решена путем добавления
disable_interactive
опции рядом сpam_mount.so
в файлах конфигурации (/etc/pam.d/common-{auth,session}
).Это происходит сразу после того,
pam_mount.so
как параметры разделяются пробелами (от имениso
файла и между каждыми двумя параметрами).Когда
pam_mount.so
код будет выполнен после входа в систему, он получит пароль из верхней части стека и использует этот пароль для расшифровки вашего тома.Когда вы делаете
su
из корневого сеанса, пароль не требуется и, следовательноpam_mount.so
, не получит пароль. Таким образом, безdisable_interactive
опции он попытается получить пароль.К счастью, как вы можете видеть из https://sourceforge.net/p/pam-mount/pam-mount/ci/master/tree/src/pam_mount.c , строка 493,
pam_mount
попытаться выполнить даже без пароля, который это хорошо, потому что пароль не нужен, если том уже разблокирован и смонтирован.источник
encfs
. Я просто создал каталоги и установил соответствующие модули PAM. После добавления «disable_interactive» к двум файлам он фактически перестал показывать запрос пароля. Я не уверен, что сообщение «mount fail» связано с паролем или потому, что нет «каталога encfs». В любом случае мне удалось сменить пользователя без пароля. Поэтому я принимаю этот ответ.Полное предположение, но посмотрите на ваши
/etc/pam.d/*
файлы и убедитесь, что все конфигурации PAM, связанные сpam_mount
, настроены следующим образом:Кажется, это подтверждается
pam_mount.conf
справочной страницей:выдержка
ПРИМЕЧАНИЕ . Порядок
/etc/pam.d/*
файлов конфигурации также указан здесь в этой теме ArchLinux Wiki под названием: Pam mount .Ссылки
источник
pam_mount
есть несколько примеров того, как структурировать ваш заказ PAM с помощью этого модуля. Можете ли вы взглянуть на это и сравнить с вашими/etc/pam.d/*
файлами? Я ожидаю, что вам нужно переодеться вокруг стека PAM. Можете ли вы запустить это:strace -s 2000 -o su.log su morfik
чтобы мы могли видеть, какие правила вызывают это?