2 /* This work is part of OpenLDAP Software <http://www.openldap.org/>.
4 * Copyright 1999-2011 The OpenLDAP Foundation.
5 * Portions Copyright 1999 John C. Quillan.
6 * Portions Copyright 2002 myinternet Limited.
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted only as authorized by the OpenLDAP
13 * A copy of this license is available in file LICENSE in the
14 * top-level directory of the distribution or, alternatively, at
15 * <http://www.OpenLDAP.org/license.html>.
18 #include "perl_back.h"
21 /**********************************************************
25 **********************************************************/
33 PerlBackend *perl_back = (PerlBackend *) op->o_bd->be_private;
35 /* allow rootdn as a means to auth without the need to actually
36 * contact the proxied DSA */
37 switch ( be_rootdn_bind( op, rs ) ) {
38 case SLAP_CB_CONTINUE:
45 #if defined(HAVE_WIN32_ASPERL) || defined(USE_ITHREADS)
46 PERL_SET_CONTEXT( PERL_INTERPRETER );
49 ldap_pvt_thread_mutex_lock( &perl_interpreter_mutex );
55 XPUSHs( perl_back->pb_obj_ref );
56 XPUSHs(sv_2mortal(newSVpv( op->o_req_dn.bv_val , 0)));
57 XPUSHs(sv_2mortal(newSVpv( op->orb_cred.bv_val , op->orb_cred.bv_len)));
60 count = call_method("bind", G_SCALAR);
65 croak("Big trouble in back_bind\n");
71 PUTBACK; FREETMPS; LEAVE;
74 ldap_pvt_thread_mutex_unlock( &perl_interpreter_mutex );
76 Debug( LDAP_DEBUG_ANY, "Perl BIND returned 0x%04x\n", rs->sr_err, 0, 0 );
78 /* frontend will send result on success (0) */
79 if( rs->sr_err != LDAP_SUCCESS )
80 send_ldap_result( op, rs );
82 return ( rs->sr_err );