mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-06 10:46:21 +08:00
74fa239a20
- librewrite, for string rewriting; it may be used in back-ldap by configuring with '--enable-rewrite'. It must be used in back-meta. There's a text file, 'libraries/librewrite/RATIONALE', that explains the usage and the features. More comprehensive documentation will follow. - enhancements of back-ldap (ITS#989,ITS#998,ITS#1002,ITS#1054 and ITS#1137) including dn rewriting, a fix to group acl matching and so - back-meta: a new backend that proxies a set of remote servers by spawning queries. It uses portions of back-ldap and the rewrite capabilities of librewrite. It can be compiled by configuring with `--enable-ldap --enable-rewrite --enable-meta'. There's a text file, 'servers/slapd/back-meta/Documentation', that describes the main features and config statements. Note: someone (Kurt?) should run 'autoconf' and commit 'configure' as my autoconf version must be different: my configures contain a number of differences and I didn't feel comfortable in adding them :)
161 lines
4.9 KiB
C
161 lines
4.9 KiB
C
/* suffixmassage.c - massages ldap backend dns */
|
|
/* $OpenLDAP$ */
|
|
|
|
/*
|
|
* Copyright 1999, Howard Chu, All rights reserved. <hyc@highlandsun.com>
|
|
* Copyright 2000, Pierangelo Masarati, All rights reserved. <ando@sys-net.it>
|
|
*
|
|
* Module back-ldap, originally developed by Howard Chu
|
|
*
|
|
* has been modified by Pierangelo Masarati. The original copyright
|
|
* notice has been maintained.
|
|
*
|
|
* Permission is granted to anyone to use this software for any purpose
|
|
* on any computer system, and to alter it and redistribute it, subject
|
|
* to the following restrictions:
|
|
*
|
|
* 1. The author is not responsible for the consequences of use of this
|
|
* software, no matter how awful, even if they arise from flaws in it.
|
|
*
|
|
* 2. The origin of this software must not be misrepresented, either by
|
|
* explicit claim or by omission. Since few users ever read sources,
|
|
* credits should appear in the documentation.
|
|
*
|
|
* 3. Altered versions must be plainly marked as such, and must not be
|
|
* misrepresented as being the original software. Since few users
|
|
* ever read sources, credits should appear in the documentation.
|
|
*
|
|
* 4. This notice may not be removed or altered.
|
|
*/
|
|
|
|
#include "portable.h"
|
|
|
|
#ifndef ENABLE_REWRITE
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <ac/socket.h>
|
|
|
|
#include "slap.h"
|
|
#include "back-ldap.h"
|
|
|
|
/*
|
|
* ldap_back_dn_massage
|
|
*
|
|
* Aliases the suffix; based on suffix_alias (servers/slapd/suffixalias.c).
|
|
*/
|
|
char *
|
|
ldap_back_dn_massage(
|
|
struct ldapinfo *li,
|
|
char *dn,
|
|
int normalized
|
|
)
|
|
{
|
|
int i, dnLength;
|
|
|
|
if ( dn == NULL ) {
|
|
return NULL;
|
|
}
|
|
if ( li == NULL ) {
|
|
return dn;
|
|
}
|
|
|
|
dnLength = strlen ( dn );
|
|
|
|
for ( i = 0;
|
|
li->suffix_massage != NULL && li->suffix_massage[i] != NULL;
|
|
i += 4 ) {
|
|
int aliasLength = strlen( li->suffix_massage[i+normalized] );
|
|
int diff = dnLength - aliasLength;
|
|
|
|
if ( diff < 0 ) {
|
|
/* alias is longer than dn */
|
|
continue;
|
|
} else if ( diff > 0 ) {
|
|
if ( normalized && ( ! DN_SEPARATOR(dn[diff-1]) ) ) {
|
|
/* boundary is not at a DN separator */
|
|
continue;
|
|
}
|
|
/* At a DN Separator */
|
|
/* XXX or an escaped separator... oh well */
|
|
}
|
|
|
|
if ( !strcmp( li->suffix_massage[i+normalized], &dn[diff] ) ) {
|
|
char *oldDN = dn;
|
|
dn = ch_malloc( diff + strlen( li->suffix_massage[i+2+normalized] ) + 1 );
|
|
strncpy( dn, oldDN, diff );
|
|
strcpy( &dn[diff], li->suffix_massage[i+2+normalized] );
|
|
Debug( LDAP_DEBUG_ARGS,
|
|
"ldap_back_dn_massage:"
|
|
" converted \"%s\" to \"%s\"\n",
|
|
oldDN, dn, 0 );
|
|
free( oldDN );
|
|
break;
|
|
}
|
|
}
|
|
|
|
return dn;
|
|
}
|
|
|
|
/*
|
|
* ldap_back_dn_restore
|
|
*
|
|
* Restores the original suffix;
|
|
* based on suffix_alias (servers/slapd/suffixalias.c).
|
|
*/
|
|
char *
|
|
ldap_back_dn_restore(
|
|
struct ldapinfo *li,
|
|
char *dn,
|
|
int normalized
|
|
)
|
|
{
|
|
int i, dnLength;
|
|
|
|
if ( dn == NULL ) {
|
|
return NULL;
|
|
}
|
|
if ( li == NULL ) {
|
|
return dn;
|
|
}
|
|
|
|
dnLength = strlen ( dn );
|
|
|
|
for ( i = 0;
|
|
li->suffix_massage != NULL && li->suffix_massage[i] != NULL;
|
|
i += 4 ) {
|
|
int aliasLength = strlen( li->suffix_massage[i+2+normalized] );
|
|
int diff = dnLength - aliasLength;
|
|
|
|
if ( diff < 0 ) {
|
|
/* alias is longer than dn */
|
|
continue;
|
|
|
|
} else if ( diff > 0 ) {
|
|
if ( normalized && ( ! DN_SEPARATOR(dn[diff-1]) ) ) {
|
|
/* boundary is not at a DN separator */
|
|
continue;
|
|
}
|
|
/* At a DN Separator */
|
|
/* XXX or an escaped separator... oh well */
|
|
}
|
|
|
|
if ( !strcmp( li->suffix_massage[i+2+normalized], &dn[diff] ) ) {
|
|
char *oldDN = dn;
|
|
dn = ch_malloc( diff + strlen( li->suffix_massage[i+normalized] ) + 1 );
|
|
strncpy( dn, oldDN, diff );
|
|
strcpy( &dn[diff], li->suffix_massage[i+normalized] );
|
|
Debug( LDAP_DEBUG_ARGS,
|
|
"ldap_back_dn_restore:"
|
|
" converted \"%s\" to \"%s\"\n",
|
|
oldDN, dn, 0 );
|
|
free( oldDN );
|
|
break;
|
|
}
|
|
}
|
|
|
|
return dn;
|
|
}
|
|
#endif /* !ENABLE_REWRITE */
|
|
|