2001-07-15 01:34:24 +08:00
|
|
|
/* backend.c - deals with backend subsystem */
|
2003-11-27 10:35:20 +08:00
|
|
|
/* $OpenLDAP$ */
|
|
|
|
/* This work is part of OpenLDAP Software <http://www.openldap.org/>.
|
|
|
|
*
|
2018-03-22 23:35:24 +08:00
|
|
|
* Copyright 2001-2018 The OpenLDAP Foundation.
|
2003-12-09 01:41:40 +08:00
|
|
|
* Portions Copyright 2001-2003 Pierangelo Masarati.
|
2003-11-27 10:35:20 +08:00
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted only as authorized by the OpenLDAP
|
|
|
|
* Public License.
|
|
|
|
*
|
|
|
|
* A copy of this license is available in file LICENSE in the
|
|
|
|
* top-level directory of the distribution or, alternatively, at
|
|
|
|
* <http://www.OpenLDAP.org/license.html>.
|
|
|
|
*/
|
|
|
|
/* ACKNOWLEDGEMENTS:
|
|
|
|
* This work was initially developed by Pierangelo Masarati for inclusion
|
|
|
|
* in OpenLDAP Software.
|
|
|
|
*/
|
2001-07-15 01:34:24 +08:00
|
|
|
|
|
|
|
|
|
|
|
#include "portable.h"
|
|
|
|
|
|
|
|
#include <stdio.h>
|
2003-05-15 05:36:34 +08:00
|
|
|
#include <ac/string.h>
|
2001-07-15 01:34:24 +08:00
|
|
|
|
|
|
|
#include "slap.h"
|
|
|
|
#include "back-monitor.h"
|
|
|
|
|
|
|
|
/*
|
|
|
|
* initializes backend subentries
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
monitor_subsys_backend_init(
|
2004-11-09 02:52:27 +08:00
|
|
|
BackendDB *be,
|
|
|
|
monitor_subsys_t *ms
|
2001-07-15 01:34:24 +08:00
|
|
|
)
|
|
|
|
{
|
2004-11-09 02:52:27 +08:00
|
|
|
monitor_info_t *mi;
|
2004-09-13 06:12:58 +08:00
|
|
|
Entry *e_backend, **ep;
|
2001-07-15 01:34:24 +08:00
|
|
|
int i;
|
2004-11-09 02:52:27 +08:00
|
|
|
monitor_entry_t *mp;
|
|
|
|
monitor_subsys_t *ms_database;
|
2005-03-24 13:13:31 +08:00
|
|
|
BackendInfo *bi;
|
2001-07-15 01:34:24 +08:00
|
|
|
|
2004-11-09 02:52:27 +08:00
|
|
|
mi = ( monitor_info_t * )be->be_private;
|
2001-07-15 01:34:24 +08:00
|
|
|
|
2004-11-08 18:10:15 +08:00
|
|
|
ms_database = monitor_back_get_subsys( SLAPD_MONITOR_DATABASE_NAME );
|
|
|
|
if ( ms_database == NULL ) {
|
|
|
|
Debug( LDAP_DEBUG_ANY,
|
|
|
|
"monitor_subsys_backend_init: "
|
|
|
|
"unable to get "
|
|
|
|
"\"" SLAPD_MONITOR_DATABASE_NAME "\" "
|
|
|
|
"subsystem\n",
|
|
|
|
0, 0, 0 );
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2005-08-07 05:03:26 +08:00
|
|
|
if ( monitor_cache_get( mi, &ms->mss_ndn, &e_backend ) ) {
|
2001-07-15 01:34:24 +08:00
|
|
|
Debug( LDAP_DEBUG_ANY,
|
|
|
|
"monitor_subsys_backend_init: "
|
2004-09-13 06:12:58 +08:00
|
|
|
"unable to get entry \"%s\"\n",
|
2004-11-08 18:10:15 +08:00
|
|
|
ms->mss_ndn.bv_val, 0, 0 );
|
2001-07-15 01:34:24 +08:00
|
|
|
return( -1 );
|
|
|
|
}
|
|
|
|
|
2004-11-09 02:52:27 +08:00
|
|
|
mp = ( monitor_entry_t * )e_backend->e_private;
|
2004-09-13 06:12:58 +08:00
|
|
|
mp->mp_children = NULL;
|
|
|
|
ep = &mp->mp_children;
|
|
|
|
|
2005-03-24 13:13:31 +08:00
|
|
|
i = -1;
|
|
|
|
LDAP_STAILQ_FOREACH( bi, &backendInfo, bi_next ) {
|
2003-04-19 01:17:18 +08:00
|
|
|
char buf[ BACKMONITOR_BUFSIZE ];
|
2005-08-07 05:03:26 +08:00
|
|
|
BackendDB *be;
|
2003-04-09 07:30:58 +08:00
|
|
|
struct berval bv;
|
2003-04-13 01:41:49 +08:00
|
|
|
int j;
|
2004-09-13 06:12:58 +08:00
|
|
|
Entry *e;
|
2001-07-15 01:34:24 +08:00
|
|
|
|
2005-03-24 13:13:31 +08:00
|
|
|
i++;
|
2001-07-15 01:34:24 +08:00
|
|
|
|
2006-01-12 16:40:09 +08:00
|
|
|
bv.bv_len = snprintf( buf, sizeof( buf ), "cn=Backend %d", i );
|
|
|
|
bv.bv_val = buf;
|
|
|
|
|
|
|
|
e = monitor_entry_stub( &ms->mss_dn, &ms->mss_ndn, &bv,
|
2012-04-12 15:44:21 +08:00
|
|
|
mi->mi_oc_monitoredObject, NULL, NULL );
|
2006-01-12 16:40:09 +08:00
|
|
|
|
2001-07-15 01:34:24 +08:00
|
|
|
if ( e == NULL ) {
|
|
|
|
Debug( LDAP_DEBUG_ANY,
|
|
|
|
"monitor_subsys_backend_init: "
|
2004-09-13 06:12:58 +08:00
|
|
|
"unable to create entry \"cn=Backend %d,%s\"\n",
|
2004-11-08 18:10:15 +08:00
|
|
|
i, ms->mss_ndn.bv_val, 0 );
|
2001-07-15 01:34:24 +08:00
|
|
|
return( -1 );
|
|
|
|
}
|
|
|
|
|
2005-04-22 05:05:38 +08:00
|
|
|
ber_str2bv( bi->bi_type, 0, 0, &bv );
|
2006-01-12 16:40:09 +08:00
|
|
|
attr_merge_normalize_one( e, mi->mi_ad_monitoredInfo,
|
|
|
|
&bv, NULL );
|
2003-05-18 01:19:16 +08:00
|
|
|
attr_merge_normalize_one( e_backend, mi->mi_ad_monitoredInfo,
|
2003-04-12 08:30:47 +08:00
|
|
|
&bv, NULL );
|
2002-11-21 10:17:24 +08:00
|
|
|
|
2006-01-12 16:40:09 +08:00
|
|
|
attr_merge_normalize_one( e, mi->mi_ad_monitorRuntimeConfig,
|
|
|
|
bi->bi_cf_ocs == NULL ? (struct berval *)&slap_false_bv :
|
|
|
|
(struct berval *)&slap_true_bv, NULL );
|
|
|
|
|
2002-11-21 10:17:24 +08:00
|
|
|
if ( bi->bi_controls ) {
|
|
|
|
int j;
|
|
|
|
|
|
|
|
for ( j = 0; bi->bi_controls[ j ]; j++ ) {
|
2005-04-22 05:05:38 +08:00
|
|
|
ber_str2bv( bi->bi_controls[ j ], 0, 0, &bv );
|
|
|
|
attr_merge_one( e, slap_schema.si_ad_supportedControl,
|
|
|
|
&bv, &bv );
|
2002-11-21 10:17:24 +08:00
|
|
|
}
|
|
|
|
}
|
2003-04-13 01:41:49 +08:00
|
|
|
|
2005-03-24 13:13:31 +08:00
|
|
|
j = -1;
|
|
|
|
LDAP_STAILQ_FOREACH( be, &backendDB, be_next ) {
|
2003-04-13 01:41:49 +08:00
|
|
|
char buf[ SLAP_LDAPDN_MAXLEN ];
|
|
|
|
struct berval dn;
|
|
|
|
|
2005-03-24 13:13:31 +08:00
|
|
|
j++;
|
|
|
|
|
2003-04-13 01:41:49 +08:00
|
|
|
if ( be->bd_info != bi ) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
snprintf( buf, sizeof( buf ), "cn=Database %d,%s",
|
2004-11-08 18:10:15 +08:00
|
|
|
j, ms_database->mss_dn.bv_val );
|
2003-04-13 01:41:49 +08:00
|
|
|
|
2005-04-22 05:05:38 +08:00
|
|
|
ber_str2bv( buf, 0, 0, &dn );
|
2005-04-30 04:29:59 +08:00
|
|
|
attr_merge_normalize_one( e, slap_schema.si_ad_seeAlso,
|
2003-04-13 01:41:49 +08:00
|
|
|
&dn, NULL );
|
|
|
|
}
|
2001-07-15 01:34:24 +08:00
|
|
|
|
2004-11-08 18:55:33 +08:00
|
|
|
mp = monitor_entrypriv_create();
|
|
|
|
if ( mp == NULL ) {
|
|
|
|
return -1;
|
|
|
|
}
|
2001-07-15 01:34:24 +08:00
|
|
|
e->e_private = ( void * )mp;
|
2004-11-08 18:10:15 +08:00
|
|
|
mp->mp_info = ms;
|
2004-11-08 18:55:33 +08:00
|
|
|
mp->mp_flags = ms->mss_flags | MONITOR_F_SUB;
|
2001-07-15 01:34:24 +08:00
|
|
|
|
|
|
|
if ( monitor_cache_add( mi, e ) ) {
|
|
|
|
Debug( LDAP_DEBUG_ANY,
|
|
|
|
"monitor_subsys_backend_init: "
|
2004-09-13 06:12:58 +08:00
|
|
|
"unable to add entry \"cn=Backend %d,%s\"\n",
|
2001-07-15 01:34:24 +08:00
|
|
|
i,
|
2004-11-08 18:10:15 +08:00
|
|
|
ms->mss_ndn.bv_val, 0 );
|
2001-07-15 01:34:24 +08:00
|
|
|
return( -1 );
|
|
|
|
}
|
|
|
|
|
2004-09-13 06:12:58 +08:00
|
|
|
*ep = e;
|
|
|
|
ep = &mp->mp_next;
|
2001-07-15 01:34:24 +08:00
|
|
|
}
|
|
|
|
|
2001-12-23 03:14:10 +08:00
|
|
|
monitor_cache_release( mi, e_backend );
|
2001-07-15 01:34:24 +08:00
|
|
|
|
|
|
|
return( 0 );
|
|
|
|
}
|
|
|
|
|