1 /* bind.c - shell backend bind function */
4 * Copyright 1998-2002 The OpenLDAP Foundation, All Rights Reserved.
5 * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
12 #include <ac/socket.h>
13 #include <ac/string.h>
30 struct shellinfo *si = (struct shellinfo *) be->be_private;
31 AttributeDescription *entry = slap_schema.si_ad_entry;
36 if ( si->si_bind == NULL ) {
37 send_ldap_result( conn, op, LDAP_UNWILLING_TO_PERFORM, NULL,
38 "bind not implemented", NULL, NULL );
51 if ( ! access_allowed( be, conn, op, &e,
52 entry, NULL, ACL_AUTH, NULL ) )
54 send_ldap_result( conn, op, LDAP_INSUFFICIENT_ACCESS,
55 NULL, NULL, NULL, NULL );
59 if ( (op->o_private = (void *) forkandexec( si->si_bind, &rfp, &wfp ))
61 send_ldap_result( conn, op, LDAP_OTHER, NULL,
62 "could not fork/exec", NULL, NULL );
66 /* write out the request to the bind process */
67 fprintf( wfp, "BIND\n" );
68 fprintf( wfp, "msgid: %ld\n", (long) op->o_msgid );
69 print_suffixes( wfp, be );
70 fprintf( wfp, "dn: %s\n", dn->bv_val );
71 fprintf( wfp, "method: %d\n", method );
72 fprintf( wfp, "credlen: %lu\n", cred->bv_len );
73 fprintf( wfp, "cred: %s\n", cred->bv_val ); /* XXX */
76 /* read in the results and send them along */
77 rc = read_and_send_results( be, conn, op, rfp, NULL, 0 );