]> git.sur5r.net Git - openldap/blob - servers/slapd/back-ldbm/referral.c
Clean up include 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 #ifdef NEW_LOGGING
51                         LDAP_LOG(( "backend", LDAP_LEVEL_DETAIL1,
52                                    "ldbm_back_referrals: op=%ld target=\"%s\" matched=\"%s\"\n",
53                                    op->o_tag, dn, matched_dn ));
54 #else
55                         Debug( LDAP_DEBUG_TRACE,
56                                 "ldbm_referrals: op=%ld target=\"%s\" matched=\"%s\"\n",
57                                 op->o_tag, dn, matched_dn );
58 #endif
59
60
61                         refs = is_entry_referral( matched )
62                                 ? get_entry_referrals( be, conn, op, matched )
63                                 : NULL;
64
65                         cache_return_entry_r( &li->li_cache, matched );
66                 }
67
68                 if( refs != NULL ) {
69                         /* send referrals */
70                         send_ldap_result( conn, op, rc = LDAP_REFERRAL,
71                                 matched_dn, NULL, refs, NULL );
72                 }
73
74                 if( matched != NULL ) {
75                         ber_bvecfree( refs );
76                         free( matched_dn );
77                 }
78
79                 return rc;
80         }
81
82         if ( is_entry_referral( e ) ) {
83                 /* entry is a referral */
84                 struct berval **refs = get_entry_referrals( be,
85                         conn, op, e );
86
87 #ifdef NEW_LOGGING
88                 LDAP_LOG(( "backend", LDAP_LEVEL_DETAIL1,
89                            "ldbm_referrals: op=%ld target=\"%s\" matched=\"%s\"\n",
90                            op->o_tag, dn, e->e_dn ));
91 #else
92                 Debug( LDAP_DEBUG_TRACE,
93                         "ldbm_referrals: op=%ld target=\"%s\" matched=\"%s\"\n",
94                         op->o_tag, dn, e->e_dn );
95 #endif
96
97
98                 if( refs != NULL ) {
99                         send_ldap_result( conn, op, rc = LDAP_REFERRAL,
100                         e->e_dn, NULL, refs, NULL );
101                 }
102
103                 ber_bvecfree( refs );
104         }
105
106         cache_return_entry_r( &li->li_cache, e );
107         return rc;
108 }