| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- /** BEGIN COPYRIGHT BLOCK
- * Copyright (C) 2001 Sun Microsystems, Inc. Used by permission.
- * Copyright (C) 2005 Red Hat, Inc.
- * All rights reserved.
- *
- * License: GPL (version 3 or any later version).
- * See LICENSE for details.
- * END COPYRIGHT BLOCK **/
- #ifdef HAVE_CONFIG_H
- #include <config.h>
- #endif
- #ifndef _LDAPU_LDAPUTIL_H
- #define _LDAPU_LDAPUTIL_H
- #include <ldaputil/dbconf.h>
- #include <ldaputil/certmap.h>
- typedef struct ldapu_list_node
- {
- void *info; /* pointer to the corresponding info */
- struct ldapu_list_node *next; /* pointer to the next node */
- struct ldapu_list_node *prev; /* pointer to the prev node */
- } LDAPUListNode_t;
- typedef struct ldapu_list
- {
- LDAPUListNode_t *head;
- LDAPUListNode_t *tail;
- } LDAPUList_t;
- typedef struct
- {
- char *prop; /* property name */
- char *val; /* value -- only char* supported for now */
- } LDAPUPropVal_t;
- typedef LDAPUList_t LDAPUPropValList_t;
- enum
- {
- COMPS_COMMENTED_OUT,
- COMPS_EMPTY,
- COMPS_HAS_ATTRS
- };
- typedef struct
- {
- char *issuerName; /* issuer (symbolic/short) name */
- CERTName *issuerDN; /* cert issuer's DN */
- LDAPUPropValList_t *propval; /* pointer to the prop-val pairs list */
- CertMapFn_t mapfn; /* cert to ldapdn & filter mapping func */
- CertVerifyFn_t verifyfn; /* verify cert function */
- CertSearchFn_t searchfn; /* search ldap entry function */
- long dncomps; /* bitmask: components to form ldap dn */
- long filtercomps; /* components used to form ldap filter */
- int verifyCert; /* Verify the cert? */
- char *searchAttr; /* LDAP attr used by the search fn */
- int dncompsState; /* Empty, commented out, or attr names */
- int filtercompsState; /* Empty, commented out, or attr names */
- } LDAPUCertMapInfo_t;
- typedef LDAPUList_t LDAPUCertMapListInfo_t;
- typedef void *(*LDAPUListNodeFn_t)(void *info, void *arg);
- #ifdef __cplusplus
- extern "C" {
- #endif
- extern int certmap_read_default_certinfo(const char *file);
- extern int certmap_read_certconfig_file(const char *file);
- extern void ldapu_certinfo_free(void *certmap_info);
- extern void ldapu_certmap_listinfo_free(void *certmap_listinfo);
- extern void ldapu_propval_list_free(void *propval_list);
- NSAPI_PUBLIC extern int ldaputil_exit(void);
- NSAPI_PUBLIC extern int ldapu_cert_to_user(void *cert, LDAP *ld, const char *basedn, LDAPMessage **res, char **user);
- NSAPI_PUBLIC extern int ldapu_certmap_init(const char *config_file,
- const char *libname,
- LDAPUCertMapListInfo_t **certmap_list,
- LDAPUCertMapInfo_t
- **certmap_default);
- NSAPI_PUBLIC extern int ldapu_list_alloc(LDAPUList_t **list);
- NSAPI_PUBLIC extern int ldapu_propval_alloc(const char *prop, const char *val, LDAPUPropVal_t **propval);
- NSAPI_PUBLIC extern int ldapu_list_add_info(LDAPUList_t *list, void *info);
- #ifndef DONT_USE_LDAP_SSL
- #define USE_LDAP_SSL
- #endif
- #ifndef LDAP_CALL
- #define LDAP_CALL
- #endif
- #ifndef LDAP_CALLBACK
- #define LDAP_CALLBACK
- #endif
- typedef struct
- {
- #ifdef USE_LDAP_SSL
- LDAP *(LDAP_CALL LDAP_CALLBACK *ldapuV_ssl_init)(const char *, int, int);
- #else
- LDAP *(LDAP_CALL LDAP_CALLBACK *ldapuV_init)(const char *, int);
- #endif
- int(LDAP_CALL LDAP_CALLBACK *ldapuV_set_option)(LDAP *, int, const void *);
- int(LDAP_CALL LDAP_CALLBACK *ldapuV_simple_bind_s)(LDAP *, const char *, const char *);
- int(LDAP_CALL LDAP_CALLBACK *ldapuV_unbind)(LDAP *);
- int(LDAP_CALL LDAP_CALLBACK *ldapuV_search_s)(LDAP *, const char *, int, const char *, char **, int, LDAPMessage **);
- int(LDAP_CALL LDAP_CALLBACK *ldapuV_count_entries)(LDAP *, LDAPMessage *);
- LDAPMessage *(LDAP_CALL LDAP_CALLBACK *ldapuV_first_entry)(LDAP *, LDAPMessage *);
- LDAPMessage *(LDAP_CALL LDAP_CALLBACK *ldapuV_next_entry)(LDAP *, LDAPMessage *);
- int(LDAP_CALL LDAP_CALLBACK *ldapuV_msgfree)(LDAP *, LDAPMessage *);
- char *(LDAP_CALL LDAP_CALLBACK *ldapuV_get_dn)(LDAP *, LDAPMessage *);
- void(LDAP_CALL LDAP_CALLBACK *ldapuV_memfree)(LDAP *, void *);
- char *(LDAP_CALL LDAP_CALLBACK *ldapuV_first_attribute)(LDAP *, LDAPMessage *, BerElement **);
- char *(LDAP_CALL LDAP_CALLBACK *ldapuV_next_attribute)(LDAP *, LDAPMessage *, BerElement *);
- void(LDAP_CALL LDAP_CALLBACK *ldapuV_ber_free)(LDAP *, BerElement *, int);
- char **(LDAP_CALL LDAP_CALLBACK *ldapuV_get_values)(LDAP *, LDAPMessage *, const char *);
- void(LDAP_CALL LDAP_CALLBACK *ldapuV_value_free)(LDAP *, char **);
- struct berval **(LDAP_CALL LDAP_CALLBACK *ldapuV_get_values_len)(LDAP *, LDAPMessage *, const char *);
- void(LDAP_CALL LDAP_CALLBACK *ldapuV_value_free_len)(LDAP *, struct berval **);
- } LDAPUVTable_t;
- NSAPI_PUBLIC extern void ldapu_VTable_set(LDAPUVTable_t *);
- #ifdef __cplusplus
- }
- #endif
- #endif /* _LDAPU_LDAPUTIL_H */
|