/* pam_static.c -- static module loading helper functions */ /* created by Michael K. Johnson, johnsonm@redhat.com * * * $Log: pam_static.c,v $ * Revision 1.4 1996/12/01 03:14:13 morgan * use _pam_macros.h * * Revision 1.3 1996/11/10 20:09:16 morgan * name convention change _pam_ * * Revision 1.2 1996/06/02 08:02:56 morgan * Michael's minor alterations * * Revision 1.1 1996/05/26 04:34:04 morgan * Initial revision * */ /* This whole file is only used for PAM_STATIC */ #ifdef PAM_STATIC #include #include #include #include #include #include #include #include "pam_private.h" /* * Here is the structure that connects libpam to the registered static * modules. */ struct pam_module_list *_pam_static_modules = NULL; /* * and now for the functions */ /* Return pointer to data structure used to define a static module */ struct pam_module * _pam_open_static_handler(const char *path) { const char *clpath = path; char *lpath, *end; struct pam_module_list *lp; if (strchr(clpath, '/')) { /* ignore path and leading "/" */ clpath = strrchr(clpath, '/') + 1; } /* create copy to muck with (must free before return) */ lpath = _pam_strdup(clpath); /* chop .so off copy if it exists (or other extension on other platform...) */ end = strstr(lpath, ".so"); if (end) { *end = '\0'; } /* now go find the module */ for (lp = _pam_static_modules; lp != NULL; lp = lp->next) { D(("%s=?%s\n", lpath, lp->modp->name)); if (lp->modp->name && ! strcmp(lp->modp->name, lpath)) { break; } } if (lp == NULL) { pam_system_log(NULL, NULL, LOG_ERR, "no static module named %s", lpath); free(lpath); return (NULL); } free(lpath); return (lp->modp); } /* Return pointer to function requested from static module * Can't just return void *, because ANSI C disallows casting a * pointer to a function to a void *... * This definition means: * _pam_get_static_sym is a function taking two arguments and * returning a pointer to a function which takes no arguments * and returns void... */ voidfunc *_pam_get_static_sym(struct pam_module *mod, const char *symname) { if (! strcmp(symname, "pam_sm_authenticate")) { return ((voidfunc *)mod->pam_sm_authenticate); } else if (! strcmp(symname, "pam_sm_setcred")) { return ((voidfunc *)mod->pam_sm_setcred); } else if (! strcmp(symname, "pam_sm_acct_mgmt")) { return ((voidfunc *)mod->pam_sm_acct_mgmt); } else if (! strcmp(symname, "pam_sm_open_session")) { return ((voidfunc *)mod->pam_sm_open_session); } else if (! strcmp(symname, "pam_sm_close_session")) { return ((voidfunc *)mod->pam_sm_close_session); } else if (! strcmp(symname, "pam_sm_chauthtok")) { return ((voidfunc *)mod->pam_sm_chauthtok); } /* getting to this point is an error */ return ((voidfunc *)NULL); } #endif /* PAM_STATIC */ /* * Copyright (C) 1995 by Red Hat Software, Michael K. Johnson * All rights reserved * * 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. */