summaryrefslogtreecommitdiffstats
path: root/include/ap_ldap_url.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/ap_ldap_url.h')
-rw-r--r--include/ap_ldap_url.h120
1 files changed, 120 insertions, 0 deletions
diff --git a/include/ap_ldap_url.h b/include/ap_ldap_url.h
new file mode 100644
index 0000000000..9f2bca1d08
--- /dev/null
+++ b/include/ap_ldap_url.h
@@ -0,0 +1,120 @@
+/* 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 ap_ldap_url.h
+ * @brief MODLDAP ldap_init() functions
+ */
+#ifndef AP_LDAP_URL_H
+#define AP_LDAP_URL_H
+
+/**
+ * @addtogroup AP_Util_LDAP
+ * @{
+ */
+
+#if defined(DOXYGEN)
+#include "ap_ldap.h"
+#endif
+
+#if AP_HAS_LDAP
+
+#include "apu.h"
+#include "apr_pools.h"
+
+#ifdef __cplusplus
+extern "C" {
+#endif /* __cplusplus */
+
+/** Structure to access an exploded LDAP URL */
+typedef struct ap_ldap_url_desc_t {
+ struct ap_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;
+} ap_ldap_url_desc_t;
+
+#ifndef AP_LDAP_URL_SUCCESS
+#define AP_LDAP_URL_SUCCESS 0x00 /* Success */
+#define AP_LDAP_URL_ERR_MEM 0x01 /* can't allocate memory space */
+#define AP_LDAP_URL_ERR_PARAM 0x02 /* parameter is bad */
+#define AP_LDAP_URL_ERR_BADSCHEME 0x03 /* URL doesn't begin with "ldap[si]://" */
+#define AP_LDAP_URL_ERR_BADENCLOSURE 0x04 /* URL is missing trailing ">" */
+#define AP_LDAP_URL_ERR_BADURL 0x05 /* URL is bad */
+#define AP_LDAP_URL_ERR_BADHOST 0x06 /* host port is bad */
+#define AP_LDAP_URL_ERR_BADATTRS 0x07 /* bad (or missing) attributes */
+#define AP_LDAP_URL_ERR_BADSCOPE 0x08 /* scope string is invalid (or missing) */
+#define AP_LDAP_URL_ERR_BADFILTER 0x09 /* bad or missing filter */
+#define AP_LDAP_URL_ERR_BADEXTS 0x0a /* bad or missing extensions */
+#endif
+
+/**
+ * Is this URL an ldap url? ldap://
+ * @param url The url to test
+ */
+MODLDAP_DECLARE(int) ap_ldap_is_ldap_url(const char *url);
+
+/**
+ * Is this URL an SSL ldap url? ldaps://
+ * @param url The url to test
+ */
+MODLDAP_DECLARE(int) ap_ldap_is_ldaps_url(const char *url);
+
+/**
+ * Is this URL an ldap socket url? ldapi://
+ * @param url The url to test
+ */
+MODLDAP_DECLARE(int) ap_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
+ */
+MODLDAP_DECLARE(int) ap_ldap_url_parse_ext(apr_pool_t *pool,
+ const char *url_in,
+ ap_ldap_url_desc_t **ludpp,
+ ap_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
+ */
+MODLDAP_DECLARE(int) ap_ldap_url_parse(apr_pool_t *pool,
+ const char *url_in,
+ ap_ldap_url_desc_t **ludpp,
+ ap_ldap_err_t **result_err);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* AP_HAS_LDAP */
+
+/** @} */
+
+#endif /* AP_LDAP_URL_H */