1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117
|
/* Copyright (C) 1997 Luke Howard.
This file is part of the nss_ldap library.
Contributed by Luke Howard, <lukeh@padl.com>, 1997.
(The author maintains a non-exclusive licence to distribute this file
under their own conditions.)
The nss_ldap library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The nss_ldap library 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
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with the nss_ldap library; see the file COPYING.LIB. If not,
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA.
*/
#ifndef _LDAP_NSS_LDAP_UTIL_H
#define _LDAP_NSS_LDAP_UTIL_H
/* utility routines. */
#define CN_ATTR "CN"
#define DC_ATTR "DC"
#define DC_ATTR_AVA DC_ATTR"="
#define DC_ATTR_AVA_LEN (sizeof(DC_ATTR_AVA) - 1)
/*
* get the RDN's value: eg. if the RDN was cn=lukeh, getrdnvalue(entry)
* would return lukeh.
*/
NSS_STATUS _nss_ldap_getrdnvalue (
LDAP * ld,
LDAPMessage * entry,
const char *rdntype,
char **rval,
char **buf,
size_t * len);
#ifdef RFC2307BIS
/*
* map a distinguished name to a login naem.
*/
NSS_STATUS _nss_ldap_dn2uid (
LDAP * ld,
const char *dn,
char **uid,
char **buf,
size_t * len);
#endif /* RFC2307BIS */
#define NSS_LDAP_CONFIG_BUFSIZ 1024
#define NSS_LDAP_KEY_HOST "host"
#define NSS_LDAP_KEY_SCOPE "scope"
#define NSS_LDAP_KEY_BASE "base"
#define NSS_LDAP_KEY_PORT "port"
#define NSS_LDAP_KEY_BINDDN "binddn"
#define NSS_LDAP_KEY_BINDPW "bindpw"
#define NSS_LDAP_KEY_DEREF "deref"
#define NSS_LDAP_KEY_ROOTBINDDN "rootbinddn"
#define NSS_LDAP_KEY_LDAP_VERSION "ldap_version"
#define NSS_LDAP_KEY_SSL "ssl"
#define NSS_LDAP_KEY_SSLPATH "sslpath"
#define NSS_LDAP_PATH_CONF "/etc/libnss-ldap.conf"
#define NSS_LDAP_PATH_ROOTPASSWD "/etc/ldap.secret"
/*
* There are a number of means of obtaining configuration information.
*
* (a) DHCP (Cf draft-hedstrom-dhc-ldap-00.txt)
* (b) a configuration file (/etc/libnss-ldap.conf) **
* (c) a coldstart file & subsequent referrals from the LDAP server
* (d) a custom LDAP bind protocol
* (e) DNS **
*
* This should be opaque to the rest of the library.
* ** implemented
*/
NSS_STATUS _nss_ldap_readconfig (
ldap_config_t ** result,
char *buf,
size_t buflen
);
/*
* Escape '*' in a string for use as a filter
*/
NSS_STATUS _nss_ldap_escape_string (
const char *str,
char *buf,
size_t buflen
);
#define MAP_H_ERRNO(nss_status, herr) do { \
if ((unsigned int) (nss_status - _NSS_LOOKUP_OFFSET) > _nss_ldap_herrno2nssstat_tab_count) \
herr = NO_RECOVERY; \
herr = _nss_ldap_herrno2nssstat_tab[nss_status - _NSS_LOOKUP_OFFSET]; \
} while (0)
#ifdef IRS_NSS
#define MAP_ERRNO(nss_status, herr) do { \
if ((unsigned int) nss_status > _nss_ldap_errno2nssstat_tab_count) \
errno = EPERM; \
errno = _nss_ldap_errno2nssstat_tab[nss_status]; \
} while (0)
#endif /* IRS_NSS */
#endif /* _LDAP_NSS_LDAP_UTIL_H */
|