diff options
author | Stig Venaas <venaas@php.net> | 2001-11-29 20:26:20 +0000 |
---|---|---|
committer | Stig Venaas <venaas@php.net> | 2001-11-29 20:26:20 +0000 |
commit | 088c7a6044703269f21edcbf1a329bc727a70d6c (patch) | |
tree | 1e4b331d9f24692b85c644acecbf55f0ec736cb3 | |
parent | ce4c65a60dfefe686b7a1db54bd80c38da395006 (diff) | |
download | php-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.m4 | 11 | ||||
-rw-r--r-- | ext/ldap/ldap.c | 96 | ||||
-rw-r--r-- | ext/ldap/php_ldap.h | 4 |
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); |