Unix & Linux Asked by nitins on January 24, 2021
Is it possible to change password database file(/etc/passwd
) to some other file. How does this authentication mechanism work internally ?
Does it depend on pam ?
You're right: /etc/passwd
and /etc/shadow
are consulted by pam_unix.so
, which are part of PAM. At least on modern Linuxes. You could change this by patching pam_unix.so
. If the manpage is to be believed, you can't change the location of the system databases.
And you really don't want to. /etc/passwd
isn't just used for authentication, it's also used for (reverse) name resolution and to look up things like the user's full name, shell, et cetera. The name and location are so standardised that moving them would almost definitely break things outside of just PAM. You'd have to patch a lot more than you bargained for.
Update: If you're trying to hide the /etc/{passwd,shadow,group}
files for security, don't worry about it. Security by obscurity rarely helps as a policy. Leave them where they are and tighten the rest of your policies.
If you have some custom software you need to access a different set of user/group databases, you could make a copy of the relevant PAM and NSS modules and patch them to use your custom databases. The original unix databases stay where they are so software isn't confused, but you can set PAM and NSS to use your custom modules wherever you need to and using whatever policy makes sense to you.
Keep the unix databases essentially pristine and you have what you asked for. This is pretty much what the radius
and ldap
PAM/NSS modules do: they provide an additional (not replacement) source of credentials and user/group information.
Going one step further: you can go back to PAM and NSS and disable the unix database lookups altogether. Leave the files there for old software (naturally, their views of the user/group databases will be inaccurate, but at least they won't break).
Correct answer by Alexios on January 24, 2021
Use NIS or LDAP to authenticate your users. Their passwords won't be stored in the /etc/{password/shadow} file(s).
Answered by jlliagre on January 24, 2021
What you're looking for is the pam_pwdfile
module. On Debian/Ubuntu the package is libpam-pwdfile
(not sure about RedHat derived distros).
The README
included with the package explains how to use it.
Answered by bahamat on January 24, 2021
I'm not sure if it's possible out of the box, but It's definitely possible with some hacking. In order to do this you'll need to:
Answered by rvs on January 24, 2021
Get help from others!
Recent Questions
Recent Answers
© 2024 TransWikia.com. All rights reserved. Sites we Love: PCI Database, UKBizDB, Menu Kuliner, Sharing RPP