]> git.sur5r.net Git - openldap/blob - servers/slapd/back-ldbm/referral.c
add new ber dump routine (behind NEW_LOGGING)
[openldap] / servers / slapd / back-ldbm / referral.c
1 /* referral.c - LDBM backend referral handler */
2 /* $OpenLDAP$ */
3 /*
4  * Copyright 2000 The OpenLDAP Foundation, All Rights Reserved.
5  * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
6  */
7
8 #include "portable.h"
9
10 #include <stdio.h>
11
12 #include <ac/string.h>
13 #include <ac/socket.h>
14
15 #include "slap.h"
16 #include "back-ldbm.h"
17
18 int
19 ldbm_back_referrals(
20     Backend     *be,
21     Connection  *conn,
22     Operation   *op,
23     const char *dn,
24     const char *ndn,
25         const char **text )
26 {
27         struct ldbminfo *li = (struct ldbminfo *) be->be_private;
28         int rc = LDAP_SUCCESS;
29         Entry *e, *matched;
30
31         if( op->o_tag == LDAP_REQ_SEARCH ) {
32                 /* let search take care of itself */
33                 return rc;
34         }
35
36         if( get_manageDSAit( op ) ) {
37                 /* let op take care of DSA management */
38                 return rc;
39         } 
40
41         /* get entry with reader lock */
42         e = dn2entry_r( be, ndn, &matched );
43         if ( e == NULL ) {
44                 char *matched_dn = NULL;
45                 struct berval **refs = default_referral;
46
47                 if ( matched != NULL ) {
48                         matched_dn = ch_strdup( matched->e_dn );
49
50                         Debug( LDAP_DEBUG_TRACE,
51                                 "ldbm_referrals: op=%ld target=\"%s\" matched=\"%s\"\n",
52                                 op->o_tag, dn, matched_dn );
53
54                         refs = is_entry_referral( matched )
55                                 ? get_entry_referrals( be, conn, op, matched )
56                                 : NULL;
57
58                         cache_return_entry_r( &li->li_cache, matched );
59                 }
60
61                 if( refs != NULL ) {
62                         /* send referrals */
63                         send_ldap_result( conn, op, rc = LDAP_REFERRAL,
64                                 matched_dn, NULL, refs, NULL );
65                 }
66
67                 if( matched != NULL ) {
68                         ber_bvecfree( refs );
69                         free( matched_dn );
70                 }
71
72                 return rc;
73         }
74
75         if ( is_entry_referral( e ) ) {
76                 /* entry is a referral */
77                 struct berval **refs = get_entry_referrals( be,
78                         conn, op, e );
79
80                 Debug( LDAP_DEBUG_TRACE,
81                         "ldbm_referrals: op=%ld target=\"%s\" matched=\"%s\"\n",
82                         op->o_tag, dn, e->e_dn );
83
84                 if( refs != NULL ) {
85                         send_ldap_result( conn, op, rc = LDAP_REFERRAL,
86                         e->e_dn, NULL, refs, NULL );
87                 }
88
89                 ber_bvecfree( refs );
90         }
91
92         cache_return_entry_r( &li->li_cache, e );
93         return rc;
94 }