+/* $OpenLDAP$ */
/*
- * Copyright 1999 The OpenLDAP Foundation, All Rights Reserved.
+ * Copyright 1999-2000 The OpenLDAP Foundation, All Rights Reserved.
*
* COPYING RESTRICTIONS APPLY, see COPYRIGHT file in the top level
* directory of this package.
#include "portable.h"
#include <stdio.h>
-#include <string.h>
-#include <ac/socket.h> /* Get struct sockaddr for slap.h */
+#include <ac/string.h>
+#include <ac/socket.h>
#include "slap.h"
/*
- * given a normalized uppercased dn (or root part), return an aliased dn if any of the
- * alias suffixes match
+ * given a normalized uppercased dn (or root part),
+ * return an aliased dn if any of the alias suffixes match
*/
-char *suffixAlias (char *dn, Operation *op, Backend *be)
+char *suffix_alias(
+ Backend *be,
+ char *dn )
{
- int i, dnLength;
+ int i, dnLength;
if(dn == NULL) return NULL;
+ if(be == NULL) return dn;
dnLength = strlen ( dn );
- for ( i = 0;
- be->be_suffixAlias != NULL && be->be_suffixAlias[i] != NULL;
- i += 2) {
- int aliasLength = strlen (be->be_suffixAlias[i]);
+
+ for ( i = 0;
+ be->be_suffixAlias != NULL && be->be_suffixAlias[i] != NULL;
+ i += 2 )
+ {
+ int aliasLength = strlen (be->be_suffixAlias[i]);
int diff = dnLength - aliasLength;
if ( diff < 0 ) {
/* alias is longer than dn */
continue;
} else if ( diff > 0 ) {
- if ( ! DNSEPARATOR(dn[diff-1]) ) {
+ if ( ! DN_SEPARATOR(dn[diff-1]) ) {
/* boundary is not at a DN separator */
continue;
}
}
if (!strcmp(be->be_suffixAlias[i], &dn[diff])) {
- char *oldDN = dn;
+ char *oldDN = dn;
dn = ch_malloc( diff + strlen(be->be_suffixAlias[i+1]) + 1 );
strncpy( dn, oldDN, diff );
strcpy( &dn[diff], be->be_suffixAlias[i+1] );
- Debug( LDAP_DEBUG_ARGS, "SuffixAlias: converted \"%s\" to \"%s\"",
+#ifdef NEW_LOGGING
+ LDAP_LOG(( "operation", LDAP_LEVEL_INFO,
+ "suffix_alias: converted \"%s\" to \"%s\"\n",
+ oldDN, dn ));
+#else
+ Debug( LDAP_DEBUG_ARGS,
+ "suffix_alias: converted \"%s\" to \"%s\"\n",
oldDN, dn, 0);
- free (oldDN);
+#endif
+
+ free (oldDN);
break;
}
}
+
return dn;
}