summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStig Venaas <venaas@php.net>2001-11-29 20:26:20 +0000
committerStig Venaas <venaas@php.net>2001-11-29 20:26:20 +0000
commit088c7a6044703269f21edcbf1a329bc727a70d6c (patch)
tree1e4b331d9f24692b85c644acecbf55f0ec736cb3
parentce4c65a60dfefe686b7a1db54bd80c38da395006 (diff)
downloadphp-git-088c7a6044703269f21edcbf1a329bc727a70d6c.tar.gz
Adding ldap_set_rebind_proc() for APIs with V3 3 arg variant, need more
testing.
-rw-r--r--ext/ldap/config.m411
-rw-r--r--ext/ldap/ldap.c96
-rw-r--r--ext/ldap/php_ldap.h4
3 files changed, 111 insertions, 0 deletions
diff --git a/ext/ldap/config.m4 b/ext/ldap/config.m4
index 42fbda1e96..5274551399 100644
--- a/ext/ldap/config.m4
+++ b/ext/ldap/config.m4
@@ -90,4 +90,15 @@ if test "$PHP_LDAP" != "no"; then
PHP_ADD_INCLUDE($LDAP_INCDIR)
PHP_SUBST(LDAP_SHARED_LIBADD)
AC_DEFINE(HAVE_LDAP,1,[ ])
+
+ dnl Check for 3 arg ldap_set_rebind_proc
+ _SAVE_CPPFLAGS=$CPPFLAGS
+ CPPFLAGS="$CPPFLAGS -I$LDAP_INCDIR"
+ AC_CACHE_CHECK([for 3 arg ldap_set_rebind_proc], ac_cv_3arg_setrebindproc,
+ [AC_TRY_COMPILE([#include <ldap.h>], [ldap_set_rebind_proc(0,0,0)],
+ ac_cv_3arg_setrebindproc=yes, ac_cv_3arg_setrebindproc=no)])
+ if test "$ac_cv_3arg_setrebindproc" = yes; then
+ AC_DEFINE(HAVE_3ARG_SETREBINDPROC,1,[Whether 3 arg set_rebind_proc()])
+ fi
+ CPPFLAGS=$_SAVE_CPPFLAGS
fi
diff --git a/ext/ldap/ldap.c b/ext/ldap/ldap.c
index 1909105507..c76a930fdf 100644
--- a/ext/ldap/ldap.c
+++ b/ext/ldap/ldap.c
@@ -53,6 +53,9 @@
typedef struct {
LDAP *link;
+#ifdef HAVE_3ARG_SETREBINDPROC
+ zval *rebindproc;
+#endif
} ldap_linkdata;
ZEND_DECLARE_MODULE_GLOBALS(ldap)
@@ -119,6 +122,10 @@ function_entry ldap_functions[] = {
PHP_FE(ldap_start_tls, NULL)
#endif
+#ifdef HAVE_3ARG_SETREBINDPROC
+ PHP_FE(ldap_set_rebind_proc, NULL)
+#endif
+
#ifdef STR_TRANSLATION
PHP_FE(ldap_t61_to_8859, NULL)
PHP_FE(ldap_8859_to_t61, NULL)
@@ -152,6 +159,12 @@ static void _close_ldap_link(zend_rsrc_list_entry *rsrc TSRMLS_DC)
ldap_linkdata *ld = (ldap_linkdata *)rsrc->ptr;
ldap_unbind_s(ld->link);
+#ifdef HAVE_3ARG_SETREBINDPROC
+ if (ld->rebindproc != NULL) {
+ zval_dtor(ld->rebindproc);
+ FREE_ZVAL(ld->rebindproc);
+ }
+#endif
efree(ld);
LDAPG(num_links)--;
}
@@ -1992,6 +2005,89 @@ PHP_FUNCTION(ldap_start_tls)
#endif
+#ifdef HAVE_3ARG_SETREBINDPROC
+int _ldap_rebind_proc(LDAP *ldap, LDAP_CONST char *url, ber_tag_t req, ber_int_t msgid, void *params) {
+ ldap_linkdata *ld;
+ int retval;
+ zval *cb_url;
+ zval **cb_args[2];
+ zval *cb_retval;
+ zval *cb_link = (zval *) params;
+
+ ld = (ldap_linkdata *) zend_fetch_resource(&cb_link TSRMLS_CC, -1, "ldap link", NULL, 1, le_link);
+
+ /* link exists and callback set? */
+ if (ld == NULL || ld->rebindproc == NULL) {
+ php_error(E_WARNING, "%s(): Link not found or no callback set", get_active_function_name(TSRMLS_C));
+ return LDAP_OTHER;
+ }
+
+ /* callback */
+ MAKE_STD_ZVAL(cb_url);
+ ZVAL_STRING(cb_url, estrdup(url), 0);
+ cb_args[0] = &cb_link;
+ cb_args[1] = &cb_url;
+ if (call_user_function_ex(EG(function_table), NULL, ld->rebindproc, &cb_retval, 2, cb_args, 0, NULL) == SUCCESS && cb_retval) {
+ convert_to_long_ex(&cb_retval);
+ retval = Z_LVAL_P(cb_retval);
+ zval_ptr_dtor(&cb_retval);
+ } else {
+ php_error(E_WARNING, "LDAP: rebind_proc php callback failed");
+ retval = LDAP_OTHER;
+ }
+ zval_dtor(cb_url);
+ FREE_ZVAL(cb_url);
+ return retval;
+}
+
+
+/* {{{ proto int ldap_set_rebind_proc(int link, string callback)
+ Set a callback function to do re-binds on referral chasing. */
+PHP_FUNCTION(ldap_set_rebind_proc)
+{
+ zval *link, *callback;
+ ldap_linkdata *ld;
+ char *callback_name;
+
+ if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "rz", &link, &callback) == FAILURE) {
+ RETURN_FALSE;
+ }
+
+ ZEND_FETCH_RESOURCE(ld, ldap_linkdata *, &link, -1, "ldap link", le_link);
+
+ if (Z_TYPE_P(callback) == IS_STRING && Z_STRLEN_P(callback) == 0) {
+ /* unregister rebind procedure */
+ if (ld->rebindproc != NULL) {
+ zval_dtor(ld->rebindproc);
+ ld->rebindproc = NULL;
+ ldap_set_rebind_proc(ld->link, NULL, NULL);
+ }
+ RETURN_TRUE;
+ }
+
+ /* callable? */
+ if (!zend_is_callable(callback, 0, &callback_name)) {
+ php_error(E_WARNING, "%s() expects argument 2, '%s', to be a valid callback", get_active_function_name(TSRMLS_C), callback_name);
+ efree(callback_name);
+ RETURN_FALSE;
+ }
+ efree(callback_name);
+
+ /* register rebind procedure */
+ if (ld->rebindproc == NULL) {
+ ldap_set_rebind_proc(ld->link, _ldap_rebind_proc, (void *) link);
+ } else {
+ zval_dtor(ld->rebindproc);
+ }
+
+ ALLOC_ZVAL(ld->rebindproc);
+ *ld->rebindproc = *callback;
+ zval_copy_ctor(ld->rebindproc);
+ RETURN_TRUE;
+}
+#endif
+
+
#ifdef STR_TRANSLATION
/* {{{ php_ldap_do_translate
*/
diff --git a/ext/ldap/php_ldap.h b/ext/ldap/php_ldap.h
index 1f3d5191c2..703ccf8ce4 100644
--- a/ext/ldap/php_ldap.h
+++ b/ext/ldap/php_ldap.h
@@ -94,6 +94,10 @@ PHP_FUNCTION(ldap_rename);
PHP_FUNCTION(ldap_start_tls);
#endif
+#ifdef HAVE_3ARG_SETREBINDPROC
+PHP_FUNCTION(ldap_set_rebind_proc);
+#endif
+
#ifdef STR_TRANSLATION
PHP_FUNCTION(ldap_t61_to_8859);
PHP_FUNCTION(ldap_8859_to_t61);