diff options
author | Thorsten Kukuk <kukuk@thkukuk.de> | 2006-01-24 23:28:31 +0000 |
---|---|---|
committer | Thorsten Kukuk <kukuk@thkukuk.de> | 2006-01-24 23:28:31 +0000 |
commit | 8d5b793b25a66e6657f5fdbeab96e1feac0d56af (patch) | |
tree | bbf4487e537da00949fb92a413137425e80c6187 /libpam | |
parent | c14d282c2a5fefbf7060d05b9d1910b359a1566f (diff) | |
download | pam-8d5b793b25a66e6657f5fdbeab96e1feac0d56af.tar.gz pam-8d5b793b25a66e6657f5fdbeab96e1feac0d56af.tar.bz2 pam-8d5b793b25a66e6657f5fdbeab96e1feac0d56af.zip |
Relevant BUGIDs:
Purpose of commit: new feature
Commit summary:
---------------
Add framework for manpages in xml source
Fix --enable-static-modules
2006-01-24 Thorsten Kukuk <kukuk@thkukuk.de>
* libpam/pam_static_modules.h: New.
* Makefile.am: Reorder subdirectories for static modules.
* configure.in: Add --enable-static-modules option.
* libpam/Makefile.am: Define WITH_SELINUX and WITH_PWDB if
necessary, add pam_static_modules.h, link against all PAM
module object files if STATIC_MODULES is defined.
* libpam/pam_static.c: Remove old _static_module* includes,
include pam_static_modules.h.
* configure.in: Add checks for xsltproc, xmllint and docbook
xsl stylesheet.
* m4/jh_path_xml_catalog.m4: New.
Diffstat (limited to 'libpam')
-rw-r--r-- | libpam/Makefile.am | 13 | ||||
-rw-r--r-- | libpam/pam_static.c | 19 | ||||
-rw-r--r-- | libpam/pam_static_modules.h | 128 | ||||
-rw-r--r-- | libpam/pam_tokens.h | 8 |
4 files changed, 148 insertions, 20 deletions
diff --git a/libpam/Makefile.am b/libpam/Makefile.am index 4f60ad47..628ba5c5 100644 --- a/libpam/Makefile.am +++ b/libpam/Makefile.am @@ -4,6 +4,13 @@ AM_CFLAGS = -DDEFAULT_MODULE_PATH=\"$(SECUREDIR)/\" -DLIBPAM_COMPILE \ -I$(srcdir)/include $(LIBPRELUDE_CFLAGS) -DPAM_VERSION=\"$(VERSION)\" +if HAVE_LIBSELINUX + AM_CFLAGS += -D"WITH_SELINUX" +endif +if HAVE_LIBPWDB + AM_CFLAGS += -D"WITH_PWDB" +endif + AM_LDFLAGS = $(LIBPRELUDE_LIBS) @LIBDL@ CLEANFILES = *~ @@ -14,9 +21,13 @@ include_HEADERS = $(addprefix include/security/, _pam_compat.h _pam_macros.h _pa pam_appl.h pam_malloc.h pam_modules.h pam_ext.h pam_modutil.h) noinst_HEADERS = pam_prelude.h pam_private.h pam_tokens.h \ - pam_modutil_private.h + pam_modutil_private.h pam_static_modules.h libpam_la_LDFLAGS = -no-undefined -version-info 81:3:81 @LIBAUDIT@ +if STATIC_MODULES + libpam_la_LDFLAGS += `ls ../modules/pam_*/*.lo` \ + @LIBDB@ @LIBCRYPT@ @LIBNSL@ @LIBCRACK@ -lutil +endif if HAVE_VERSIONING libpam_la_LDFLAGS += -Wl,--version-script=$(srcdir)/libpam.map endif diff --git a/libpam/pam_static.c b/libpam/pam_static.c index 7ea4c81b..75f13414 100644 --- a/libpam/pam_static.c +++ b/libpam/pam_static.c @@ -14,24 +14,7 @@ #include "pam_private.h" -/* - * Need to include pointers to static modules; this was built by each - * of the modules that register... - */ - -#include "../modules/_static_module_list" - -/* - * and here is a structure that connects libpam to the above static - * modules - */ - -static struct pam_module *static_modules[] = { - -#include "../modules/_static_module_entry" - - NULL -}; +#include "pam_static_modules.h" /* * and now for the functions diff --git a/libpam/pam_static_modules.h b/libpam/pam_static_modules.h new file mode 100644 index 00000000..59d7407f --- /dev/null +++ b/libpam/pam_static_modules.h @@ -0,0 +1,128 @@ +/* + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, and the entire permission notice in its entirety, + * including the disclaimer of warranties. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. The name of the author may not be used to endorse or promote + * products derived from this software without specific prior + * written permission. + * + * ALTERNATIVELY, this product may be distributed under the terms of + * the GNU Public License, in which case the provisions of the GPL are + * required INSTEAD OF the above restrictions. (This clause is + * necessary due to a potential bad interaction between the GPL and + * the restrictions contained in a BSD-style copyright.) + * + * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED + * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, + * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, + * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED + * OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +/* Pointers to static module data. */ + +extern struct pam_module _pam_access_modstruct; +extern struct pam_module _pam_cracklib_modstruct; +extern struct pam_module _pam_debug_modstruct; +extern struct pam_module _pam_deny_modstruct; +extern struct pam_module _pam_echo_modstruct; +extern struct pam_module _pam_env_modstruct; +extern struct pam_module _pam_exec_modstruct; +extern struct pam_module _pam_filter_modstruct; +extern struct pam_module _pam_ftp_modstruct; +extern struct pam_module _pam_group_modstruct; +extern struct pam_module _pam_issue_modstruct; +extern struct pam_module _pam_lastlog_modstruct; +extern struct pam_module _pam_limits_modstruct; +extern struct pam_module _pam_listfile_modstruct; +extern struct pam_module _pam_localuser_modstruct; +extern struct pam_module _pam_mail_modstruct; +extern struct pam_module _pam_mkhomedir_modstruct; +extern struct pam_module _pam_motd_modstruct; +extern struct pam_module _pam_nologin_modstruct; +extern struct pam_module _pam_permit_modstruct; +#ifdef WITH_PWDB +extern struct pam_module _pam_pwdb_modstruct; +#endif +extern struct pam_module _pam_rhosts_auth_modstruct; +extern struct pam_module _pam_rootok_modstruct; +extern struct pam_module _pam_securetty_modstruct; +#ifdef WITH_SELINUX +extern struct pam_module _pam_selinux_modstruct; +#endif +extern struct pam_module _pam_shells_modstruct; +extern struct pam_module _pam_stress_modstruct; +extern struct pam_module _pam_succeed_if_modstruct; +extern struct pam_module _pam_tally_modstruct; +extern struct pam_module _pam_time_modstruct; +extern struct pam_module _pam_umask_modstruct; +extern struct pam_module _pam_unix_acct_modstruct; +extern struct pam_module _pam_unix_auth_modstruct; +extern struct pam_module _pam_unix_passwd_modstruct; +extern struct pam_module _pam_unix_session_modstruct; +extern struct pam_module _pam_userdb_modstruct; +extern struct pam_module _pam_warn_modstruct; +extern struct pam_module _pam_wheel_modstruct; +extern struct pam_module _pam_xauth_modstruct; + +/* and here is a structure that connects libpam to the above static + modules. */ + +static struct pam_module *static_modules[] = { + &_pam_access_modstruct, + &_pam_cracklib_modstruct, + &_pam_debug_modstruct, + &_pam_deny_modstruct, + &_pam_echo_modstruct, + &_pam_env_modstruct, + &_pam_exec_modstruct, + &_pam_filter_modstruct, + &_pam_ftp_modstruct, + &_pam_group_modstruct, + &_pam_issue_modstruct, + &_pam_lastlog_modstruct, + &_pam_limits_modstruct, + &_pam_listfile_modstruct, + &_pam_localuser_modstruct, + &_pam_mail_modstruct, + &_pam_mkhomedir_modstruct, + &_pam_motd_modstruct, + &_pam_nologin_modstruct, + &_pam_permit_modstruct, +#ifdef WITH_PWDB + &_pam_pwdb_modstruct, +#endif + &_pam_rhosts_auth_modstruct, + &_pam_rootok_modstruct, + &_pam_securetty_modstruct, +#ifdef WITH_SELINUX + &_pam_selinux_modstruct, +#endif + &_pam_shells_modstruct, + &_pam_stress_modstruct, + &_pam_succeed_if_modstruct, + &_pam_tally_modstruct, + &_pam_time_modstruct, + &_pam_umask_modstruct, + &_pam_unix_acct_modstruct, + &_pam_unix_auth_modstruct, + &_pam_unix_passwd_modstruct, + &_pam_unix_session_modstruct, + &_pam_userdb_modstruct, + &_pam_warn_modstruct, + &_pam_wheel_modstruct, + &_pam_xauth_modstruct, + NULL +}; diff --git a/libpam/pam_tokens.h b/libpam/pam_tokens.h index fad30759..fcda7ec2 100644 --- a/libpam/pam_tokens.h +++ b/libpam/pam_tokens.h @@ -17,6 +17,9 @@ /* an array of actions */ +#ifndef LIBPAM_COMPILE +static +#endif const char * const _pam_token_actions[-_PAM_ACTION_UNDEF] = { "ignore", /* 0 */ "ok", /* -1 */ @@ -28,6 +31,9 @@ const char * const _pam_token_actions[-_PAM_ACTION_UNDEF] = { /* an array of possible return values */ +#ifndef LIBPAM_COMPILE +static +#endif const char * const _pam_token_returns[_PAM_RETURN_VALUES+1] = { "success", /* 0 */ "open_err", /* 1 */ @@ -41,7 +47,7 @@ const char * const _pam_token_returns[_PAM_RETURN_VALUES+1] = { "authinfo_unavail", /* 9 */ "user_unknown", /* 10 */ "maxtries", /* 11 */ - "new_authtok_reqd", /* 12 */ + "new_authtok_reqd", /* 12 */ "acct_expired", /* 13 */ "session_err", /* 14 */ "cred_unavail", /* 15 */ |