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 PERL_SET_CONTEXT( PERL_INTERPRETER );
46 ldap_pvt_thread_mutex_lock( &perl_interpreter_mutex );
52 XPUSHs( perl_back->pb_obj_ref );
53 XPUSHs(sv_2mortal(newSVpv( op->o_req_dn.bv_val , 0)));
54 XPUSHs(sv_2mortal(newSVpv( op->orb_cred.bv_val , op->orb_cred.bv_len)));
57 count = call_method("bind", G_SCALAR);
62 croak("Big trouble in back_bind\n");
68 PUTBACK; FREETMPS; LEAVE;
71 ldap_pvt_thread_mutex_unlock( &perl_interpreter_mutex );
73 Debug( LDAP_DEBUG_ANY, "Perl BIND returned 0x%04x\n", rs->sr_err, 0, 0 );
75 /* frontend will send result on success (0) */
76 if( rs->sr_err != LDAP_SUCCESS )
77 send_ldap_result( op, rs );
79 return ( rs->sr_err );