]> git.sur5r.net Git - openldap/blobdiff - servers/slapd/back-shell/init.c
Merge remote-tracking branch 'origin/mdb.master' into OPENLDAP_REL_ENG_2_4
[openldap] / servers / slapd / back-shell / init.c
index 6a841c154ba5903cc0123182fed21ac79995829f..8fca9b5f932d83391d8df47771443bf7d1175e27 100644 (file)
@@ -1,4 +1,32 @@
 /* init.c - initialize shell backend */
+/* $OpenLDAP$ */
+/* This work is part of OpenLDAP Software <http://www.openldap.org/>.
+ *
+ * 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
+ * <http://www.OpenLDAP.org/license.html>.
+ */
+/* 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"
 
 #include <ac/socket.h>
 
 #include "slap.h"
+
+#include "config.h"
+
 #include "shell.h"
 
-void
-shell_back_init(
-    Backend    *be
+int
+shell_back_initialize(
+    BackendInfo        *bi
+)
+{
+       bi->bi_open = 0;
+       bi->bi_config = 0;
+       bi->bi_close = 0;
+       bi->bi_destroy = 0;
+
+       bi->bi_db_init = shell_back_db_init;
+       bi->bi_db_config = 0;
+       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 = 0;
+
+       bi->bi_extended = 0;
+
+       bi->bi_chk_referrals = 0;
+
+       bi->bi_connection_init = 0;
+       bi->bi_connection_destroy = 0;
+
+       return shell_back_init_cf( bi );
+}
+
+int
+shell_back_db_init(
+       Backend *be,
+       ConfigReply *cr
 )
 {
        struct shellinfo        *si;
@@ -19,4 +87,25 @@ shell_back_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,
+       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 */
+