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 */
|