X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Fback-shell%2Finit.c;h=8fca9b5f932d83391d8df47771443bf7d1175e27;hb=c216e1809971ac6c5b2b973501e0e8a766b77287;hp=c539de9a1a9dd91c556518e5ea440cb32af91887;hpb=e0eba072443fc49e2c83f3f74d09b7e0ee4f45bb;p=openldap diff --git a/servers/slapd/back-shell/init.c b/servers/slapd/back-shell/init.c index c539de9a1a..8fca9b5f93 100644 --- a/servers/slapd/back-shell/init.c +++ b/servers/slapd/back-shell/init.c @@ -1,8 +1,31 @@ /* init.c - initialize shell backend */ /* $OpenLDAP$ */ -/* - * Copyright 1998-2000 The OpenLDAP Foundation, All Rights Reserved. - * COPYING RESTRICTIONS APPLY, see COPYRIGHT file +/* This work is part of OpenLDAP Software . + * + * Copyright 1998-2013 The OpenLDAP Foundation. + * 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 the file LICENSE in the + * top-level directory of the distribution or, alternatively, at + * . + */ +/* Portions Copyright (c) 1995 Regents of the University of Michigan. + * All rights reserved. + * + * Redistribution and use in source and binary forms are permitted + * provided that this notice is preserved and that due credit is given + * to the University of Michigan at Ann Arbor. The name of the University + * may not be used to endorse or promote products derived from this + * software without specific prior written permission. This software + * is provided ``as is'' without express or implied warranty. + */ +/* ACKNOWLEDGEMENTS: + * This work was originally developed by the University of Michigan + * (as part of U-MICH LDAP). */ #include "portable.h" @@ -12,22 +35,10 @@ #include #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; -} +#include "config.h" -#endif /* SLAPD_SHELL_DYNAMIC */ +#include "shell.h" int shell_back_initialize( @@ -40,7 +51,7 @@ shell_back_initialize( bi->bi_destroy = 0; bi->bi_db_init = shell_back_db_init; - bi->bi_db_config = shell_back_db_config; + bi->bi_db_config = 0; bi->bi_db_open = 0; bi->bi_db_close = 0; bi->bi_db_destroy = shell_back_db_destroy; @@ -53,27 +64,22 @@ shell_back_initialize( 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_op_abandon = 0; bi->bi_extended = 0; - bi->bi_acl_group = 0; - -#ifdef HAVE_CYRUS_SASL - bi->bi_sasl_authorize = 0; - bi->bi_sasl_getsecret = 0; - bi->bi_sasl_putsecret = 0; -#endif /* HAVE_CYRUS_SASL */ + bi->bi_chk_referrals = 0; bi->bi_connection_init = 0; bi->bi_connection_destroy = 0; - return 0; + return shell_back_init_cf( bi ); } int shell_back_db_init( - Backend *be + Backend *be, + ConfigReply *cr ) { struct shellinfo *si; @@ -81,15 +87,25 @@ shell_back_db_init( si = (struct shellinfo *) ch_calloc( 1, sizeof(struct shellinfo) ); be->be_private = si; + be->be_cf_ocs = be->bd_info->bi_cf_ocs; return si == NULL; } int shell_back_db_destroy( - Backend *be + Backend *be, + ConfigReply *cr ) { free( be->be_private ); return 0; } + +#if SLAPD_SHELL == SLAPD_MOD_DYNAMIC + +/* conditionally define the init_module() function */ +SLAP_BACKEND_INIT_MODULE( shell ) + +#endif /* SLAPD_SHELL == SLAPD_MOD_DYNAMIC */ +