/** BEGIN COPYRIGHT BLOCK * This Program is free software; you can redistribute it and/or modify it under * the terms of the GNU General Public License as published by the Free Software * Foundation; version 2 of the License. * * This Program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along with * this Program; if not, write to the Free Software Foundation, Inc., 59 Temple * Place, Suite 330, Boston, MA 02111-1307 USA. * * In addition, as a special exception, Red Hat, Inc. gives You the additional * right to link the code of this Program with code not covered under the GNU * General Public License ("Non-GPL Code") and to distribute linked combinations * including the two, subject to the limitations in this paragraph. Non-GPL Code * permitted under this exception must only link to the code of this Program * through those well defined interfaces identified in the file named EXCEPTION * found in the source code files (the "Approved Interfaces"). The files of * Non-GPL Code may instantiate templates or use macros or inline functions from * the Approved Interfaces without causing the resulting work to be covered by * the GNU General Public License. Only Red Hat, Inc. may make changes or * additions to the list of Approved Interfaces. You must obey the GNU General * Public License in all respects for all of the Program code and other code used * in conjunction with the Program except the Non-GPL Code covered by this * exception. If you modify this file, you may extend this exception to your * version of the file, but you are not obligated to do so. If you do not wish to * provide this exception without modification, you must delete this exception * statement from your version and license this file solely under the GPL without * exception. * * * Copyright (C) 2001 Sun Microsystems, Inc. Used by permission. * Copyright (C) 2005 Red Hat, Inc. * All rights reserved. * END COPYRIGHT BLOCK **/ #ifdef HAVE_CONFIG_H # include #endif #ifndef ACL_USER_CACHE_H #define ACL_USER_CACHE_H #include #include #include /* Removed for new ns security integration #include */ #include #include #include typedef struct { PRCList list; /* pointer to next & prev obj */ char *uid; /* unique within a database */ char *userdn; /* LDAP DN if using LDAP db */ char *passwd; /* password */ SECItem *derCert; /* raw certificate data */ char *group; /* group recently checked for membership */ time_t time; /* last time when the cache was validated */ PRHashTable *hashtable; /* hash table where this obj is being used */ } UserCacheObj; NSPR_BEGIN_EXTERN_C /* Set the number of seconds the cache is valid */ extern int acl_usr_cache_set_timeout (const int nsec); /* Is the cache enabled? */ extern int acl_usr_cache_enabled(); /* initialize user cache */ extern int acl_usr_cache_init (); /* Creates a new user obj entry */ extern int acl_usr_cache_insert (const char *uid, const char *dbname, const char *dn, const char *passwd, const char *group, const SECItem *derCert, const time_t time); /* Add group to the user's cache obj. */ extern int acl_usr_cache_set_group (const char *uid, const char *dbname, const char *group, const time_t time); /* Add userdn to the user's cache obj. */ extern int acl_usr_cache_set_userdn (const char *uid, const char *dbname, const char *userdn, const time_t time); /* Returns LAS_EVAL_TRUE if the user's password matches -- also returns the dn */ extern int acl_usr_cache_passwd_check (const char *uid, const char *dbname, const char *passwd, const time_t time, char **dn, pool_handle_t *pool); /* Returns LAS_EVAL_TRUE if the user is a member of the group */ extern int acl_usr_cache_group_check (const char *uid, const char *dbname, const char *group, const time_t time); /* Returns LAS_EVAL_TRUE if the user is a member of the group */ extern int acl_usr_cache_group_len_check (const char *uid, const char *dbname, const char *group, const int len, const time_t time); /* Returns LAS_EVAL_TRUE if the user's cache is valid and has a group */ extern int acl_usr_cache_get_group (const char *uid, const char *dbname, const time_t time, char **group, pool_handle_t *pool); /* Returns LAS_EVAL_TRUE if the user is a member of the group */ extern int acl_usr_cache_userdn_check (const char *uid, const char *dbname, const char *userdn, const time_t time); /* Returns LAS_EVAL_TRUE if the user's cache is valid and has userdn */ extern int acl_usr_cache_get_userdn (const char *uid, const char *dbname, const time_t time, char **userdn, pool_handle_t *pool); /* Creates a new user obj entry for cert to user mapping */ extern int acl_cert_cache_insert (void *cert, const char *dbname, const char *uid, const char *dn, const time_t time); /* Returns LAS_EVAL_TRUE if the user's cache is valid and returns uid */ extern int acl_cert_cache_get_uid (void *cert, const char *dbname, const time_t time, char **uid, char **dn, pool_handle_t *pool); NSPR_END_EXTERN_C #endif /* ACL_USER_CACHE_H */