1 /* This work is part of OpenLDAP Software <http://www.openldap.org/>.
3 * Copyright 2004 The OpenLDAP Foundation.
4 * Portions Copyright 2004 Pierangelo Masarati.
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted only as authorized by the OpenLDAP
11 * A copy of this license is available in file LICENSE in the
12 * top-level directory of the distribution or, alternatively, at
13 * <http://www.OpenLDAP.org/license.html>.
16 * This work was initially developed by Pierangelo Masarati for inclusion
17 * in OpenLDAP Software.
24 #include <ac/stdlib.h>
27 #include <ac/string.h>
28 #include <ac/socket.h>
29 #include <ac/unistd.h>
35 #include "slapcommon.h"
38 do_check( Connection *c, Operation *op, struct berval *id )
40 struct berval authcdn;
43 rc = slap_sasl_getdn( c, op, id, NULL, &authcdn, SLAP_GETDN_AUTHCID );
44 if ( rc != LDAP_SUCCESS ) {
45 fprintf( stderr, "ID: <%s> check failed %d (%s)\n",
47 ldap_err2string( rc ) );
51 if ( !BER_BVISNULL( &authzID ) ) {
52 rc = slap_sasl_authorized( op, &authcdn, &authzID );
62 rc == LDAP_SUCCESS ? "OK" : "failed" );
65 fprintf( stderr, "ID: <%s> check succeeded\n"
69 op->o_tmpfree( authcdn.bv_val, op->o_tmpmemctx );
78 slapauth( int argc, char **argv )
80 int rc = EXIT_SUCCESS;
81 const char *progname = "slapauth";
86 lutil_log_initialize( argc, argv );
88 slap_tool_init( progname, SLAPAUTH, argc, argv );
90 argv = &argv[ optind ];
93 memset( &conn, 0, sizeof( Connection ) );
94 memset( &op, 0, sizeof( Operation ) );
96 connection_fake_init( &conn, &op, &conn );
98 if ( !BER_BVISNULL( &authzID ) ) {
99 struct berval authzdn;
101 rc = slap_sasl_getdn( &conn, &op, &authzID, NULL, &authzdn,
102 SLAP_GETDN_AUTHZID );
103 if ( rc != LDAP_SUCCESS ) {
104 fprintf( stderr, "authzID: <%s> check failed %d (%s)\n",
106 ldap_err2string( rc ) );
108 BER_BVZERO( &authzID );
116 if ( !BER_BVISNULL( &authcID ) ) {
117 if ( !BER_BVISNULL( &authzID ) || argc == 0 ) {
118 rc = do_check( &conn, &op, &authcID );
122 for ( ; argc--; argv++ ) {
123 struct berval authzdn;
125 ber_str2bv( argv[ 0 ], 0, 0, &authzID );
127 rc = slap_sasl_getdn( &conn, &op, &authzID, NULL, &authzdn,
128 SLAP_GETDN_AUTHZID );
129 if ( rc != LDAP_SUCCESS ) {
130 fprintf( stderr, "authzID: <%s> check failed %d (%s)\n",
132 ldap_err2string( rc ) );
134 BER_BVZERO( &authzID );
135 if ( !continuemode ) {
142 rc = do_check( &conn, &op, &authcID );
144 op.o_tmpfree( authzID.bv_val, op.o_tmpmemctx );
145 BER_BVZERO( &authzID );
147 if ( rc && !continuemode ) {
155 for ( ; argc--; argv++ ) {
158 ber_str2bv( argv[ 0 ], 0, 0, &id );
160 rc = do_check( &conn, &op, &id );
162 if ( rc && !continuemode ) {
168 if ( !BER_BVISNULL( &authzID ) ) {
169 op.o_tmpfree( authzID.bv_val, op.o_tmpmemctx );