]> git.sur5r.net Git - openldap/blobdiff - servers/slapd/back-perl/init.c
Removed unnecessary definition that is already in core.schema.
[openldap] / servers / slapd / back-perl / init.c
index a8026909a7decf94aef3d3b49b29064ba88b4974..59fecd7d6ded0563f2677186f0153cd076fcf83c 100644 (file)
        #include <ac/socket.h>
 */
 
+
+
 #include <EXTERN.h>
 #include <perl.h>
 
-
 #include "slap.h"
 #include "perl_back.h"
 
 
+
 PerlInterpreter *perl_interpreter = NULL;
 ldap_pvt_thread_mutex_t        perl_interpreter_mutex;
 
@@ -33,26 +35,73 @@ ldap_pvt_thread_mutex_t     perl_interpreter_mutex;
  *
  **********************************************************/
 
-void
-perl_back_init(
-       Backend *be
+int
+perl_back_initialize(
+       BackendInfo     *bi
 )
 {
        char *embedding[] = { "", "-e", "0" };
 
-       if( perl_interpreter == NULL ) {
-               perl_interpreter = perl_alloc();
-               perl_construct(perl_interpreter);
-               perl_parse(perl_interpreter, NULL, 3, embedding, (char **)NULL);
-               perl_run(perl_interpreter);
-               
-               ldap_pvt_thread_mutex_init( &perl_interpreter_mutex,
-                       ldap_pvt_thread_mutexattr_default );
+       Debug( LDAP_DEBUG_TRACE, "perl backend open\n", 0, 0, 0 );
+
+       if( perl_interpreter != NULL ) {
+               Debug( LDAP_DEBUG_ANY, "perl backend open: already opened\n",
+                       0, 0, 0 );
+               return 1;
        }
+       
+       perl_interpreter = perl_alloc();
+       perl_construct(perl_interpreter);
+       perl_parse(perl_interpreter, NULL, 3, embedding, (char **)NULL);
+       perl_run(perl_interpreter);
+
+       bi->bi_open = perl_back_open;
+       bi->bi_config = 0;
+       bi->bi_close = perl_back_close;
+       bi->bi_destroy = perl_back_destroy;
+
+       bi->bi_db_init = perl_back_db_init;
+       bi->bi_db_config = perl_back_db_config;
+       bi->bi_db_open = 0;
+       bi->bi_db_close = 0;
+       bi->bi_db_destroy = perl_back_db_destroy;
+
+       bi->bi_op_bind = perl_back_bind;
+       bi->bi_op_unbind = perl_back_unbind;
+       bi->bi_op_search = perl_back_search;
+       bi->bi_op_compare = perl_back_compare;
+       bi->bi_op_modify = perl_back_modify;
+       bi->bi_op_modrdn = perl_back_modrdn;
+       bi->bi_op_add = perl_back_add;
+       bi->bi_op_delete = perl_back_delete;
+       bi->bi_op_abandon = 0;
 
+#ifdef SLAPD_ACLGROUPS
+       bi->bi_acl_group = 0;
+#endif
+
+       return 0;
+}
+               
+int
+perl_back_open(
+       BackendInfo     *bi
+)
+{
+       ldap_pvt_thread_mutex_init( &perl_interpreter_mutex );
+       return 0;
+}
+
+int
+perl_back_db_init(
+       Backend *be
+)
+{
        be->be_private = (PerlBackend *) ch_malloc( sizeof(PerlBackend) );
-       memset(&be->be_private, 0, sizeof(PerlBackend));
+       memset( be->be_private, 0, sizeof(PerlBackend));
+
+       Debug( LDAP_DEBUG_TRACE, "perl backend db init\n", 0, 0, 0 );
 
-       Debug( LDAP_DEBUG_ANY, "Here in perl backend\n", 0, 0, 0 );
+       return 0;
 }