mirror of
https://github.com/Zeckmathederg/glfs.git
synced 2025-01-23 14:32:13 +08:00
554 lines
18 KiB
XML
554 lines
18 KiB
XML
<?xml version="1.0" encoding="UTF-8"?>
|
|
<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
|
|
"http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
|
|
<!ENTITY % general-entities SYSTEM "../../general.ent">
|
|
%general-entities;
|
|
|
|
<!ENTITY linux-pam-download-http "https://github.com/linux-pam/linux-pam/releases/download/v&linux-pam-version;/Linux-PAM-&linux-pam-version;.tar.xz">
|
|
<!ENTITY linux-pam-download-ftp " ">
|
|
|
|
<!ENTITY linux-pam-docs-download "https://github.com/linux-pam/linux-pam/releases/download/v&linux-pam-version;/Linux-PAM-&linux-pam-docs-version;-docs.tar.xz">
|
|
<!--
|
|
<!ENTITY debian-pam-docs "http://debian.securedservers.com/kernel/pub/linux/libs/pam">
|
|
-->
|
|
]>
|
|
|
|
<sect1 id="linux-pam" xreflabel="Linux-PAM-&linux-pam-version;">
|
|
<?dbhtml filename="linux-pam.html"?>
|
|
|
|
|
|
<title>Linux-PAM-&linux-pam-version;</title>
|
|
|
|
<indexterm zone="linux-pam">
|
|
<primary sortas="a-Linux-PAM">Linux-PAM</primary>
|
|
</indexterm>
|
|
|
|
<sect2 role="package">
|
|
<title>Introduction to Linux PAM</title>
|
|
|
|
<para>
|
|
The <application>Linux PAM</application> package contains
|
|
Pluggable Authentication Modules used by the local
|
|
system administrator to control how application programs authenticate
|
|
users.
|
|
</para>
|
|
|
|
<bridgehead renderas="sect3">Package Information</bridgehead>
|
|
<itemizedlist spacing="compact">
|
|
<listitem>
|
|
<para>
|
|
Download (HTTP): <ulink url="&linux-pam-download-http;"/>
|
|
</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>
|
|
Download (FTP): <ulink url="&linux-pam-download-ftp;"/>
|
|
</para>
|
|
</listitem>
|
|
</itemizedlist>
|
|
|
|
<bridgehead renderas="sect3">Additional Downloads</bridgehead>
|
|
<itemizedlist spacing="compact">
|
|
<title>Optional Documentation</title>
|
|
<listitem>
|
|
<para>
|
|
Download (HTTP): <ulink url="&linux-pam-docs-download;"/>
|
|
</para>
|
|
</listitem>
|
|
</itemizedlist>
|
|
|
|
</sect2>
|
|
|
|
<sect2 role="kernel" id="linux-pam-kernel">
|
|
<title>Kernel Configuration</title>
|
|
|
|
<para>
|
|
For the PAM module <filename
|
|
class='libraryfile'>pam_loginuid.so</filename> (referred by
|
|
the PAM configuration file <filename>system-session</filename> if
|
|
<xref linkend='elogind'/> is built) to work,
|
|
a kernel configuration parameter need to be set or the module will
|
|
just do nothing:
|
|
</para>
|
|
|
|
<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
|
|
href="linux-pam-kernel.xml"/>
|
|
|
|
<indexterm zone="linux-pam linux-pam-kernel">
|
|
<primary sortas="d-linux-pam">Linux-PAM</primary>
|
|
</indexterm>
|
|
|
|
</sect2>
|
|
|
|
<sect2 role="installation">
|
|
<title>Installation of Linux PAM</title>
|
|
|
|
<para>
|
|
First, prevent the installation of an unneeded systemd file:
|
|
</para>
|
|
|
|
<screen><userinput>sed -e /service_DATA/d \
|
|
-i modules/pam_namespace/Makefile.am</userinput></screen>
|
|
|
|
<!-- https://github.com/linux-pam/linux-pam/issues/809 -->
|
|
<para>
|
|
The shipped <filename>libtool.m4</filename> file has a configuration
|
|
inconsistent with LFS <filename class='directory'>/usr</filename>
|
|
hierarchy. This issue would cause
|
|
<filename class='libraryfile'>libpam_misc.so</filename> linked with
|
|
an rpath flag which may sometimes cause troubles or even security
|
|
issues. Regenerate the building system to fix the inconsistency:
|
|
</para>
|
|
|
|
<screen><userinput>autoreconf -fi</userinput></screen>
|
|
|
|
<para>
|
|
If you downloaded the documentation, unpack the tarball by issuing
|
|
the following command.
|
|
</para>
|
|
|
|
<screen><userinput>tar -xf ../Linux-PAM-&linux-pam-docs-version;-docs.tar.xz --strip-components=1</userinput></screen>
|
|
<!--
|
|
<para>
|
|
If you want to regenerate the documentation yourself, fix the
|
|
<command>configure</command> script so it will detect lynx:
|
|
</para>
|
|
|
|
<screen><userinput>sed -e 's/dummy elinks/dummy lynx/' \
|
|
-e 's/-no-numbering -no-references/-force-html -nonumbers -stdin/' \
|
|
-i configure</userinput></screen>
|
|
-->
|
|
<para>
|
|
Compile and link <application>Linux PAM</application> by
|
|
running the following commands:
|
|
</para>
|
|
|
|
<screen><userinput>./configure --prefix=/usr \
|
|
--sbindir=/usr/sbin \
|
|
--sysconfdir=/etc \
|
|
--libdir=/usr/lib \
|
|
--enable-securedir=/usr/lib/security \
|
|
--docdir=/usr/share/doc/Linux-PAM-&linux-pam-version; &&
|
|
make</userinput></screen>
|
|
|
|
<para>
|
|
To test the results, a suitable <filename>/etc/pam.d/other</filename>
|
|
configuration file must exist.
|
|
</para>
|
|
|
|
<caution>
|
|
<title>Reinstallation or Upgrade of Linux PAM</title>
|
|
<para>
|
|
If you have a system with Linux PAM installed and working, be careful
|
|
when modifying the files in
|
|
<filename class="directory">/etc/pam.d</filename>, since your system
|
|
may become totally unusable. If you want to run the tests, you do not
|
|
need to create another <filename>/etc/pam.d/other</filename> file. The
|
|
existing file can be used for the tests.
|
|
</para>
|
|
|
|
<para>
|
|
You should also be aware that <command>make install</command>
|
|
overwrites the configuration files in
|
|
<filename class="directory">/etc/security</filename> as well as
|
|
<filename>/etc/environment</filename>. If you
|
|
have modified those files, be sure to back them up.
|
|
</para>
|
|
</caution>
|
|
|
|
<para>
|
|
For a first-time installation, create a configuration file by issuing the
|
|
following commands as the <systemitem class="username">root</systemitem>
|
|
user:
|
|
</para>
|
|
|
|
<screen role="root"><userinput>install -v -m755 -d /etc/pam.d &&
|
|
|
|
cat > /etc/pam.d/other << "EOF"
|
|
<literal>auth required pam_deny.so
|
|
account required pam_deny.so
|
|
password required pam_deny.so
|
|
session required pam_deny.so</literal>
|
|
EOF</userinput></screen>
|
|
|
|
<para>
|
|
Now run the tests by issuing <command>make check</command>.
|
|
Be sure the tests produced no errors before continuing the
|
|
installation. Note that the tests are very long.
|
|
Redirect the output to a log file, so you can inspect it thoroughly.
|
|
</para>
|
|
|
|
<para>
|
|
For a first-time installation, remove the configuration file
|
|
created earlier by issuing the following command as the
|
|
<systemitem class="username">root</systemitem> user:
|
|
</para>
|
|
|
|
<screen role="root"><userinput>rm -fv /etc/pam.d/other</userinput></screen>
|
|
|
|
<para>
|
|
Now, as the <systemitem class="username">root</systemitem>
|
|
user:
|
|
</para>
|
|
|
|
<screen role="root"><userinput>make install &&
|
|
chmod -v 4755 /usr/sbin/unix_chkpwd</userinput></screen>
|
|
|
|
</sect2>
|
|
|
|
<sect2 role="installation">
|
|
<title>32-bit Installation of Linux PAM</title>
|
|
|
|
<para>
|
|
First clean the directory:
|
|
</para>
|
|
|
|
<screen><userinput>make distclean</userinput></screen>
|
|
|
|
<para>
|
|
Now install lib32-<application>Linux-PAM</application> by
|
|
running the following commands:
|
|
</para>
|
|
|
|
<screen><userinput>CC="gcc -m32" CXX="g++ -m32" \
|
|
PKG_CONFIG_PATH="/usr/lib32/pkgconfig" \
|
|
./configure --prefix=/usr \
|
|
--libdir=/usr/lib32 \
|
|
--sbindir=/usr/sbin \
|
|
--sysconfdir=/etc \
|
|
--host=i686-pc-linux-gnu \
|
|
--enable-securedir=/usr/lib/security &&
|
|
|
|
make</userinput></screen>
|
|
|
|
<para>
|
|
Now, as the <systemitem class="username">root</systemitem>
|
|
user:
|
|
</para>
|
|
|
|
<screen role="root"><userinput>make DESTDIR=$PWD/DESTDIR install &&
|
|
cp -vR DESTDIR/usr/lib32/* /usr/lib32 &&
|
|
cp -vR DESTDIR/usr/lib/* /usr/lib32 &&
|
|
rm -rf DESTDIR &&
|
|
ldconfig</userinput></screen>
|
|
|
|
</sect2>
|
|
|
|
<sect2 role="commands">
|
|
<title>Command Explanations</title>
|
|
|
|
<para>
|
|
<parameter>--enable-securedir=/usr/lib/security</parameter>:
|
|
This switch sets the installation location for the
|
|
<application>PAM</application> modules.
|
|
</para>
|
|
<!--
|
|
<para>
|
|
<option>- -disable-regenerate-docu</option> : If the needed dependencies
|
|
(<xref linkend="DocBook"/>, <xref linkend="docbook-xsl"/>, <xref
|
|
linkend="libxslt"/>, and <xref linkend="lynx"/> or <ulink
|
|
url="&w3m-url;">W3m</ulink>) are installed, the manual pages, and the
|
|
html and text documentation files, are generated and installed.
|
|
Furthermore, if <xref linkend="fop"/> is installed, the PDF
|
|
documentation is generated and installed. Use this switch if you do not
|
|
want to rebuild the documentation.
|
|
</para>
|
|
-->
|
|
<para>
|
|
<command>chmod -v 4755 /usr/sbin/unix_chkpwd</command>:
|
|
The setuid bit for the <command>unix_chkpwd</command> helper program must be
|
|
turned on, so that non-<systemitem class="username">root</systemitem>
|
|
processes can access the shadow file.
|
|
</para>
|
|
|
|
</sect2>
|
|
|
|
<sect2 role="configuration">
|
|
<title>Configuring Linux-PAM</title>
|
|
|
|
<sect3 id="pam-config">
|
|
<title>Configuration Files</title>
|
|
|
|
<para>
|
|
<filename>/etc/security/*</filename> and
|
|
<filename>/etc/pam.d/*</filename>
|
|
</para>
|
|
|
|
<indexterm zone="linux-pam pam-config">
|
|
<primary sortas="e-etc-security">/etc/security/*</primary>
|
|
</indexterm>
|
|
|
|
<indexterm zone="linux-pam pam-config">
|
|
<primary sortas="e-etc-pam.d">/etc/pam.d/*</primary>
|
|
</indexterm>
|
|
|
|
</sect3>
|
|
|
|
<sect3>
|
|
<title>Configuration Information</title>
|
|
|
|
<para>
|
|
Configuration information is placed in
|
|
<filename class="directory">/etc/pam.d/</filename>.
|
|
Here is a sample file:
|
|
</para>
|
|
|
|
<screen><literal># Begin /etc/pam.d/other
|
|
|
|
auth required pam_unix.so nullok
|
|
account required pam_unix.so
|
|
session required pam_unix.so
|
|
password required pam_unix.so nullok
|
|
|
|
# End /etc/pam.d/other</literal></screen>
|
|
|
|
<para>
|
|
Now create some generic configuration files. As the
|
|
<systemitem class="username">root</systemitem> user:
|
|
</para>
|
|
|
|
<screen role="root"><userinput>install -vdm755 /etc/pam.d &&
|
|
cat > /etc/pam.d/system-account << "EOF" &&
|
|
<literal># Begin /etc/pam.d/system-account
|
|
|
|
account required pam_unix.so
|
|
|
|
# End /etc/pam.d/system-account</literal>
|
|
EOF
|
|
|
|
cat > /etc/pam.d/system-auth << "EOF" &&
|
|
<literal># Begin /etc/pam.d/system-auth
|
|
|
|
auth required pam_unix.so
|
|
|
|
# End /etc/pam.d/system-auth</literal>
|
|
EOF
|
|
|
|
cat > /etc/pam.d/system-session << "EOF" &&
|
|
<literal># Begin /etc/pam.d/system-session
|
|
|
|
session required pam_unix.so
|
|
|
|
# End /etc/pam.d/system-session</literal>
|
|
EOF
|
|
|
|
cat > /etc/pam.d/system-password << "EOF"
|
|
<literal># Begin /etc/pam.d/system-password
|
|
|
|
# use yescrypt hash for encryption, use shadow, and try to use any
|
|
# previously defined authentication token (chosen password) set by any
|
|
# prior module.
|
|
password required pam_unix.so yescrypt shadow try_first_pass
|
|
|
|
# End /etc/pam.d/system-password</literal>
|
|
EOF
|
|
</userinput></screen>
|
|
|
|
<para>
|
|
Next, add a restrictive <filename>/etc/pam.d/other</filename>
|
|
configuration file. With this file, programs that are PAM aware will
|
|
not run unless a configuration file specifically for that application
|
|
exists.
|
|
</para>
|
|
|
|
<screen role="root"><userinput>cat > /etc/pam.d/other << "EOF"
|
|
<literal># Begin /etc/pam.d/other
|
|
|
|
auth required pam_warn.so
|
|
auth required pam_deny.so
|
|
account required pam_warn.so
|
|
account required pam_deny.so
|
|
password required pam_warn.so
|
|
password required pam_deny.so
|
|
session required pam_warn.so
|
|
session required pam_deny.so
|
|
|
|
# End /etc/pam.d/other</literal>
|
|
EOF</userinput></screen>
|
|
|
|
<para>
|
|
The <application>PAM</application> man page (<command>man
|
|
pam</command>) provides a good starting point to learn
|
|
about the several fields, and allowable entries.
|
|
<!-- not accessible 2022-09-08 -->
|
|
<!-- it's available at a different address 2022-10-23-->
|
|
The
|
|
<ulink url="https://www.docs4dev.com/docs/en/linux-pam/1.1.2/reference/Linux-PAM_SAG.html">
|
|
Linux-PAM System Administrators' Guide
|
|
</ulink> is recommended for additional information.
|
|
</para>
|
|
|
|
<important>
|
|
<para>
|
|
You should now reinstall the <xref linkend="shadow"/>
|
|
package.
|
|
</para>
|
|
</important>
|
|
|
|
</sect3>
|
|
|
|
</sect2>
|
|
|
|
<sect2 role="content">
|
|
<title>Contents</title>
|
|
|
|
<segmentedlist>
|
|
<segtitle>Installed Program</segtitle>
|
|
<segtitle>Installed Libraries</segtitle>
|
|
<segtitle>Installed Directories</segtitle>
|
|
|
|
<seglistitem>
|
|
<seg>
|
|
faillock, mkhomedir_helper, pam_namespace_helper,
|
|
pam_timestamp_check, pwhistory_helper, unix_chkpwd and
|
|
unix_update
|
|
</seg>
|
|
<seg>
|
|
libpam.so, libpamc.so and libpam_misc.so
|
|
</seg>
|
|
<seg>
|
|
/etc/security,
|
|
/usr/lib/security,
|
|
/usr/include/security and
|
|
/usr/share/doc/Linux-PAM-&linux-pam-version;
|
|
</seg>
|
|
</seglistitem>
|
|
</segmentedlist>
|
|
|
|
<variablelist>
|
|
<bridgehead renderas="sect3">Short Descriptions</bridgehead>
|
|
<?dbfo list-presentation="list"?>
|
|
<?dbhtml list-presentation="table"?>
|
|
|
|
<varlistentry id="faillock">
|
|
<term><command>faillock</command></term>
|
|
<listitem>
|
|
<para>
|
|
displays and modifies the authentication failure record files
|
|
</para>
|
|
<indexterm zone="linux-pam faillock">
|
|
<primary sortas="b-faillock">faillock</primary>
|
|
</indexterm>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry id="mkhomedir_helper">
|
|
<term><command>mkhomedir_helper</command></term>
|
|
<listitem>
|
|
<para>
|
|
is a helper binary that creates home directories
|
|
</para>
|
|
<indexterm zone="linux-pam mkhomedir_helper">
|
|
<primary sortas="b-mkhomedir_helper">mkhomedir_helper</primary>
|
|
</indexterm>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry id="pam_namespace_helper">
|
|
<term><command>pam_namespace_helper</command></term>
|
|
<listitem>
|
|
<para>
|
|
is a helper program used to configure a private namespace for a
|
|
user session
|
|
</para>
|
|
<indexterm zone="linux-pam pam_namespace_helper">
|
|
<primary sortas="b-pam_namespace_helper">pam_namespace_helper</primary>
|
|
</indexterm>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry id="pwhistory_helper">
|
|
<term><command>pwhistory_helper</command></term>
|
|
<listitem>
|
|
<para>
|
|
is a helper program that transfers password hashes from passwd or
|
|
shadow to opasswd
|
|
</para>
|
|
<indexterm zone="linux-pam pwhistory_helper">
|
|
<primary sortas="b-pwhistory_helper">pwhistory_helper</primary>
|
|
</indexterm>
|
|
</listitem>
|
|
</varlistentry>
|
|
<!-- Removed with the removal of the pam_tally{,2} module
|
|
<varlistentry id="pam_tally">
|
|
<term><command>pam_tally</command></term>
|
|
<listitem>
|
|
<para>
|
|
is used to interrogate and manipulate the login counter file.
|
|
</para>
|
|
<indexterm zone="linux-pam pam_tally">
|
|
<primary sortas="b-pam_tally">pam_tally</primary>
|
|
</indexterm>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry id="pam_tally2">
|
|
<term><command>pam_tally2</command></term>
|
|
<listitem>
|
|
<para>
|
|
is used to interrogate and manipulate the login counter file, but
|
|
does not have some limitations that <command>pam_tally</command>
|
|
does.
|
|
</para>
|
|
<indexterm zone="linux-pam pam_tally2">
|
|
<primary sortas="b-pam_tally2">pam_tally2</primary>
|
|
</indexterm>
|
|
</listitem>
|
|
</varlistentry>
|
|
-->
|
|
|
|
<varlistentry id="pam_timestamp_check">
|
|
<term><command>pam_timestamp_check</command></term>
|
|
<listitem>
|
|
<para>
|
|
is used to check if the default timestamp is valid
|
|
</para>
|
|
<indexterm zone="linux-pam pam_timestamp_check">
|
|
<primary sortas="b-pam_timestamp_check">pam_timestamp_check</primary>
|
|
</indexterm>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry id="unix_chkpwd">
|
|
<term><command>unix_chkpwd</command></term>
|
|
<listitem>
|
|
<para>
|
|
is a helper binary that verifies the password of the current user
|
|
</para>
|
|
<indexterm zone="linux-pam unix_chkpwd">
|
|
<primary sortas="b-unix_chkpwd">unix_chkpwd</primary>
|
|
</indexterm>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry id="unix_update">
|
|
<term><command>unix_update</command></term>
|
|
<listitem>
|
|
<para>
|
|
is a helper binary that updates the password of a given user
|
|
</para>
|
|
<indexterm zone="linux-pam unix_update">
|
|
<primary sortas="b-unix_update">unix_update</primary>
|
|
</indexterm>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry id="libpam">
|
|
<term><filename class="libraryfile">libpam.so</filename></term>
|
|
<listitem>
|
|
<para>
|
|
provides the interfaces between applications and the
|
|
PAM modules
|
|
</para>
|
|
<indexterm zone="linux-pam libpam">
|
|
<primary sortas="c-libpam">libpam.so</primary>
|
|
</indexterm>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
</variablelist>
|
|
|
|
</sect2>
|
|
|
|
</sect1>
|