openldap/servers/slapd/back-shell/init.c
Kurt Zeilenga 4e51bba217 Patch: Implement surrogate parent for back-shell (ITS#1815)
================
Written by Hallvard B. Furuseth and placed into the public domain.
This software is not subject to any license of the University of Oslo.
			================

A surrogate parent is supposed to keep back-shell children from
deadlocking due to resources locked by a threading parent.

Implementation note: The surrogate parent closes all unused file
descriptors, so it logs errors to stderr instead of via Debug() and
uses relloc() instead of ch_realloc().

Also close a file descriptor leak if fork() fails in fork.c.

Hallvard B. Furuseth <h.b.furuseth@usit.uio.no>, May 2002.
2002-05-15 06:18:14 +00:00

124 lines
2.4 KiB
C

/* init.c - initialize shell backend */
/* $OpenLDAP$ */
/*
* Copyright 1998-2002 The OpenLDAP Foundation, All Rights Reserved.
* COPYING RESTRICTIONS APPLY, see COPYRIGHT file
*/
#include "portable.h"
#include <stdio.h>
#include <ac/socket.h>
#include <ac/unistd.h>
#include "slap.h"
#include "shell.h"
#ifdef SLAPD_SHELL_DYNAMIC
int back_shell_LTX_init_module(int argc, char *argv[]) {
BackendInfo bi;
memset( &bi, '\0', sizeof(bi) );
bi.bi_type = "shell";
bi.bi_init = shell_back_initialize;
backend_add(&bi);
return 0;
}
#endif /* SLAPD_SHELL_DYNAMIC */
int
shell_back_initialize(
BackendInfo *bi
)
{
bi->bi_open = 0;
bi->bi_config = 0;
bi->bi_close = 0;
bi->bi_destroy = shell_back_destroy;
bi->bi_db_init = shell_back_db_init;
bi->bi_db_config = shell_back_db_config;
bi->bi_db_open = 0;
bi->bi_db_close = 0;
bi->bi_db_destroy = shell_back_db_destroy;
bi->bi_op_bind = shell_back_bind;
bi->bi_op_unbind = shell_back_unbind;
bi->bi_op_search = shell_back_search;
bi->bi_op_compare = shell_back_compare;
bi->bi_op_modify = shell_back_modify;
bi->bi_op_modrdn = shell_back_modrdn;
bi->bi_op_add = shell_back_add;
bi->bi_op_delete = shell_back_delete;
bi->bi_op_abandon = shell_back_abandon;
bi->bi_extended = 0;
bi->bi_acl_group = 0;
bi->bi_acl_attribute = 0;
bi->bi_chk_referrals = 0;
bi->bi_connection_init = 0;
bi->bi_connection_destroy = 0;
#ifdef SHELL_SURROGATE_PARENT
ldap_pvt_thread_mutex_init( &shell_surrogate_index_mutex );
ldap_pvt_thread_mutex_init( &shell_surrogate_fd_mutex[0] );
ldap_pvt_thread_mutex_init( &shell_surrogate_fd_mutex[1] );
#endif
return 0;
}
int
shell_back_destroy(
BackendInfo *bi
)
{
#ifdef SHELL_SURROGATE_PARENT
ldap_pvt_thread_mutex_destroy( &shell_surrogate_index_mutex );
ldap_pvt_thread_mutex_destroy( &shell_surrogate_fd_mutex[0] );
ldap_pvt_thread_mutex_destroy( &shell_surrogate_fd_mutex[1] );
if ( shell_surrogate_fd[0] >= 0 ) {
close( shell_surrogate_fd[0] );
close( shell_surrogate_fd[1] );
}
if ( shell_surrogate_pid >= 0 )
kill( shell_surrogate_pid, SIGTERM );
#endif
return 0;
}
int
shell_back_db_init(
Backend *be
)
{
struct shellinfo *si;
#ifdef SHELL_SURROGATE_PARENT
if ( shell_surrogate_fd[0] < 0 )
make_surrogate_parent();
#endif
si = (struct shellinfo *) ch_calloc( 1, sizeof(struct shellinfo) );
be->be_private = si;
return si == NULL;
}
int
shell_back_db_destroy(
Backend *be
)
{
free( be->be_private );
return 0;
}