154925bf6Swillf /*
254925bf6Swillf  * lib/kdb/kdb_ldap/ldap_misc.h
354925bf6Swillf  *
454925bf6Swillf  * Copyright (c) 2004-2005, Novell, Inc.
554925bf6Swillf  * All rights reserved.
654925bf6Swillf  *
754925bf6Swillf  * Redistribution and use in source and binary forms, with or without
854925bf6Swillf  * modification, are permitted provided that the following conditions are met:
954925bf6Swillf  *
1054925bf6Swillf  *   * Redistributions of source code must retain the above copyright notice,
1154925bf6Swillf  *       this list of conditions and the following disclaimer.
1254925bf6Swillf  *   * Redistributions in binary form must reproduce the above copyright
1354925bf6Swillf  *       notice, this list of conditions and the following disclaimer in the
1454925bf6Swillf  *       documentation and/or other materials provided with the distribution.
1554925bf6Swillf  *   * The copyright holder's name is not used to endorse or promote products
1654925bf6Swillf  *       derived from this software without specific prior written permission.
1754925bf6Swillf  *
1854925bf6Swillf  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
1954925bf6Swillf  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
2054925bf6Swillf  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
2154925bf6Swillf  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
2254925bf6Swillf  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
2354925bf6Swillf  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
2454925bf6Swillf  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
2554925bf6Swillf  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
2654925bf6Swillf  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
2754925bf6Swillf  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
2854925bf6Swillf  * POSSIBILITY OF SUCH DAMAGE.
2954925bf6Swillf  */
3054925bf6Swillf 
3154925bf6Swillf /*
3254925bf6Swillf  * Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
3354925bf6Swillf  * Use is subject to license terms.
3454925bf6Swillf  */
3554925bf6Swillf 
3654925bf6Swillf #ifndef _HAVE_LDAP_MISC_H
3754925bf6Swillf #define _HAVE_LDAP_MISC_H 1
3854925bf6Swillf 
3954925bf6Swillf #include "ldap_services.h"
4054925bf6Swillf 
4154925bf6Swillf /* misc functions */
4254925bf6Swillf 
4354925bf6Swillf krb5_error_code
4454925bf6Swillf updateAttribute (LDAP *, char *, char *, char  *);
4554925bf6Swillf 
4654925bf6Swillf krb5_error_code
4754925bf6Swillf deleteAttribute (LDAP *, char *, char *, char *);
4854925bf6Swillf 
4954925bf6Swillf krb5_error_code
5054925bf6Swillf populateServers(LDAP *, char **, char ***, char *, char **);
5154925bf6Swillf 
5254925bf6Swillf krb5_error_code
5354925bf6Swillf disjoint_members(char **, char **);
5454925bf6Swillf 
5554925bf6Swillf krb5_error_code
5654925bf6Swillf is_principal_in_realm(krb5_ldap_context *, krb5_const_principal);
5754925bf6Swillf 
5854925bf6Swillf krb5_error_code
5954925bf6Swillf checkattributevalue(LDAP *, char *, char *, char **, int *);
6054925bf6Swillf 
6154925bf6Swillf krb5_error_code
6254925bf6Swillf krb5_get_attributes_mask(krb5_context, krb5_db_entry *, unsigned int *);
6354925bf6Swillf 
6454925bf6Swillf krb5_error_code
6554925bf6Swillf krb5_get_princ_type(krb5_context, krb5_db_entry *, int *);
6654925bf6Swillf 
6754925bf6Swillf krb5_error_code
6854925bf6Swillf krb5_get_princ_count(krb5_context, krb5_db_entry *, int *);
6954925bf6Swillf 
7054925bf6Swillf krb5_error_code
7154925bf6Swillf krb5_get_linkdn(krb5_context, krb5_db_entry *, char ***);
7254925bf6Swillf 
7354925bf6Swillf krb5_error_code
7454925bf6Swillf krb5_get_userdn(krb5_context, krb5_db_entry *, char **);
7554925bf6Swillf 
7654925bf6Swillf krb5_error_code
7754925bf6Swillf krb5_get_containerdn(krb5_context, krb5_db_entry *, char **);
7854925bf6Swillf 
7954925bf6Swillf krb5_error_code
8054925bf6Swillf store_tl_data(krb5_tl_data *, int, void *);
8154925bf6Swillf 
8254925bf6Swillf krb5_error_code
8354925bf6Swillf decode_tl_data(krb5_tl_data *, int, void **);
8454925bf6Swillf 
8554925bf6Swillf krb5_error_code
8654925bf6Swillf is_principal_in_realm(krb5_ldap_context *, krb5_const_principal);
8754925bf6Swillf 
8854925bf6Swillf krb5_error_code
89*1da57d55SToomas Soome krb5_get_subtree_info(krb5_ldap_context *, char ***, unsigned int *);
9054925bf6Swillf 
9154925bf6Swillf krb5_error_code
9254925bf6Swillf krb5_ldap_read_server_params(krb5_context , char *, int);
9354925bf6Swillf 
9454925bf6Swillf krb5_error_code
9554925bf6Swillf krb5_ldap_free_server_params(krb5_ldap_context *);
9654925bf6Swillf 
9754925bf6Swillf krb5_error_code
9854925bf6Swillf copy_arrays(char **, char ***, int);
9954925bf6Swillf 
10054925bf6Swillf krb5_error_code
10154925bf6Swillf krb5_ldap_list(krb5_context, char ***, char *, char *);
10254925bf6Swillf 
103*1da57d55SToomas Soome krb5_error_code
10454925bf6Swillf krb5_ldap_get_value(LDAP *, LDAPMessage *, char *, int *);
10554925bf6Swillf 
106*1da57d55SToomas Soome krb5_error_code
10754925bf6Swillf krb5_ldap_get_string(LDAP *, LDAPMessage *, char *, char **, krb5_boolean *);
10854925bf6Swillf 
109*1da57d55SToomas Soome krb5_error_code
11054925bf6Swillf krb5_ldap_get_strings(LDAP *, LDAPMessage *, char *, char ***, krb5_boolean *);
11154925bf6Swillf 
112*1da57d55SToomas Soome krb5_error_code
11354925bf6Swillf krb5_ldap_get_time(LDAP *, LDAPMessage *, char *, krb5_timestamp *, krb5_boolean *);
11454925bf6Swillf 
11554925bf6Swillf krb5_error_code
11654925bf6Swillf krb5_add_member(LDAPMod ***, int *);
11754925bf6Swillf 
11854925bf6Swillf krb5_error_code
11954925bf6Swillf krb5_add_str_mem_ldap_mod(LDAPMod  ***, char *, int, char **);
12054925bf6Swillf 
12154925bf6Swillf krb5_error_code
12254925bf6Swillf krb5_add_ber_mem_ldap_mod(LDAPMod  ***, char *, int, struct berval **);
12354925bf6Swillf 
12454925bf6Swillf krb5_error_code
12554925bf6Swillf krb5_add_int_arr_mem_ldap_mod(LDAPMod  ***, char *, int, int *);
12654925bf6Swillf 
12754925bf6Swillf krb5_error_code
12854925bf6Swillf krb5_add_int_mem_ldap_mod(LDAPMod  ***, char *, int , int);
12954925bf6Swillf 
13054925bf6Swillf krb5_error_code
13154925bf6Swillf krb5_ldap_free_mod_array(LDAPMod **);
13254925bf6Swillf 
13354925bf6Swillf krb5_error_code
13454925bf6Swillf krb5_ldap_get_reference_count (krb5_context, char *, char *, int *, LDAP *);
13554925bf6Swillf 
13654925bf6Swillf krb5_error_code
13754925bf6Swillf krb5_ldap_policydn_to_name (krb5_context, char *, char **);
13854925bf6Swillf 
13954925bf6Swillf krb5_error_code
14054925bf6Swillf krb5_ldap_name_to_policydn (krb5_context, char *, char **);
14154925bf6Swillf 
14254925bf6Swillf krb5_error_code
14354925bf6Swillf krb5_ldap_get_db_opt(char *, char **, char **);
14454925bf6Swillf 
14554925bf6Swillf krb5_error_code
14654925bf6Swillf populate_krb5_db_entry(krb5_context context,
14754925bf6Swillf     krb5_ldap_context *ldap_context,
14854925bf6Swillf     LDAP *ld,
14954925bf6Swillf     LDAPMessage *ent,
15054925bf6Swillf     krb5_const_principal princ,
15154925bf6Swillf     krb5_db_entry *entry);
15254925bf6Swillf 
15354925bf6Swillf #endif
154