121 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			121 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* Licensed to the Apache Software Foundation (ASF) under one or more
 | |
|  * contributor license agreements.  See the NOTICE file distributed with
 | |
|  * this work for additional information regarding copyright ownership.
 | |
|  * The ASF licenses this file to You under the Apache License, Version 2.0
 | |
|  * (the "License"); you may not use this file except in compliance with
 | |
|  * the License.  You may obtain a copy of the License at
 | |
|  *
 | |
|  *     http://www.apache.org/licenses/LICENSE-2.0
 | |
|  *
 | |
|  * Unless required by applicable law or agreed to in writing, software
 | |
|  * distributed under the License is distributed on an "AS IS" BASIS,
 | |
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
|  * See the License for the specific language governing permissions and
 | |
|  * limitations under the License.
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * @file apr_ldap_url.h
 | |
|  * @brief  APR-UTIL LDAP ldap_init() functions
 | |
|  */
 | |
| #ifndef APR_LDAP_URL_H
 | |
| #define APR_LDAP_URL_H
 | |
| 
 | |
| /**
 | |
|  * @addtogroup APR_Util_LDAP
 | |
|  * @{
 | |
|  */
 | |
| 
 | |
| #if defined(DOXYGEN)
 | |
| #include "apr_ldap.h"
 | |
| #endif
 | |
| 
 | |
| #if APR_HAS_LDAP
 | |
| 
 | |
| #include "apu.h"
 | |
| #include "apr_pools.h"
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| /** Structure to access an exploded LDAP URL */
 | |
| typedef struct apr_ldap_url_desc_t {
 | |
|     struct  apr_ldap_url_desc_t  *lud_next;
 | |
|     char    *lud_scheme;
 | |
|     char    *lud_host;
 | |
|     int     lud_port;
 | |
|     char    *lud_dn;
 | |
|     char    **lud_attrs;
 | |
|     int     lud_scope;
 | |
|     char    *lud_filter;
 | |
|     char    **lud_exts;
 | |
|     int     lud_crit_exts;
 | |
| } apr_ldap_url_desc_t;
 | |
| 
 | |
| #ifndef APR_LDAP_URL_SUCCESS
 | |
| #define APR_LDAP_URL_SUCCESS          0x00    /* Success */
 | |
| #define APR_LDAP_URL_ERR_MEM          0x01    /* can't allocate memory space */
 | |
| #define APR_LDAP_URL_ERR_PARAM        0x02    /* parameter is bad */
 | |
| #define APR_LDAP_URL_ERR_BADSCHEME    0x03    /* URL doesn't begin with "ldap[si]://" */
 | |
| #define APR_LDAP_URL_ERR_BADENCLOSURE 0x04    /* URL is missing trailing ">" */
 | |
| #define APR_LDAP_URL_ERR_BADURL       0x05    /* URL is bad */
 | |
| #define APR_LDAP_URL_ERR_BADHOST      0x06    /* host port is bad */
 | |
| #define APR_LDAP_URL_ERR_BADATTRS     0x07    /* bad (or missing) attributes */
 | |
| #define APR_LDAP_URL_ERR_BADSCOPE     0x08    /* scope string is invalid (or missing) */
 | |
| #define APR_LDAP_URL_ERR_BADFILTER    0x09    /* bad or missing filter */
 | |
| #define APR_LDAP_URL_ERR_BADEXTS      0x0a    /* bad or missing extensions */
 | |
| #endif
 | |
| 
 | |
| /**
 | |
|  * Is this URL an ldap url? ldap://
 | |
|  * @param url The url to test
 | |
|  */
 | |
| APU_DECLARE(int) apr_ldap_is_ldap_url(const char *url);
 | |
| 
 | |
| /**
 | |
|  * Is this URL an SSL ldap url? ldaps://
 | |
|  * @param url The url to test
 | |
|  */
 | |
| APU_DECLARE(int) apr_ldap_is_ldaps_url(const char *url);
 | |
| 
 | |
| /**
 | |
|  * Is this URL an ldap socket url? ldapi://
 | |
|  * @param url The url to test
 | |
|  */
 | |
| APU_DECLARE(int) apr_ldap_is_ldapi_url(const char *url);
 | |
| 
 | |
| /**
 | |
|  * Parse an LDAP URL.
 | |
|  * @param pool The pool to use
 | |
|  * @param url_in The URL to parse
 | |
|  * @param ludpp The structure to return the exploded URL
 | |
|  * @param result_err The result structure of the operation
 | |
|  */
 | |
| APU_DECLARE(int) apr_ldap_url_parse_ext(apr_pool_t *pool,
 | |
|                                         const char *url_in,
 | |
|                                         apr_ldap_url_desc_t **ludpp,
 | |
|                                         apr_ldap_err_t **result_err);
 | |
| 
 | |
| /**
 | |
|  * Parse an LDAP URL.
 | |
|  * @param pool The pool to use
 | |
|  * @param url_in The URL to parse
 | |
|  * @param ludpp The structure to return the exploded URL
 | |
|  * @param result_err The result structure of the operation
 | |
|  */
 | |
| APU_DECLARE(int) apr_ldap_url_parse(apr_pool_t *pool,
 | |
|                                     const char *url_in,
 | |
|                                     apr_ldap_url_desc_t **ludpp,
 | |
|                                     apr_ldap_err_t **result_err);
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif /* APR_HAS_LDAP */
 | |
| 
 | |
| /** @} */
 | |
| 
 | |
| #endif /* APR_LDAP_URL_H */
 | 
