openldap/servers/slapd/back-perl/config.c
John Quillan 3f1fd3bcee Fix bug in compare.c where obj_ref to pb_obj_ref
Added call to perl "config" method so the the
perl module can have its own configuration
options.

Fix bug in init.c where the address of the be_private
object was being retrieved when it was already
a pointer.

Added the dn parameter to the modify.c call to the
modify method.  Not sure why this wasn't there
in the beginning.

Expects and array from the search method instead of
a scalar in search.c so that it can return search
results and a return code.

Added the demo file SampleLDAP.pm
1999-04-04 04:16:14 +00:00

134 lines
2.6 KiB
C

/*
* Copyright 1999, John C. Quillan, All rights reserved.
*
* Redistribution and use in source and binary forms are permitted only
* as authorized by the OpenLDAP Public License. A copy of this
* license is available at http://www.OpenLDAP.org/license.html or
* in file LICENSE in the top-level directory of the distribution.
*/
#include "portable.h"
/* init.c - initialize shell backend */
#include <stdio.h>
/* #include <ac/types.h>
#include <ac/socket.h>
*/
#include <EXTERN.h>
#include <perl.h>
#include "slap.h"
#include "perl_back.h"
/**********************************************************
*
* Config
*
**********************************************************/
int
perl_back_db_config(
BackendDB *be,
char *fname,
int lineno,
int argc,
char **argv
)
{
SV* loc_sv;
PerlBackend *perl_back = (PerlBackend *) be->be_private;
char eval_str[EVAL_BUF_SIZE];
int count ;
int args;
int return_code;
if ( strcasecmp( argv[0], "perlModule" ) == 0 ) {
if ( argc < 2 ) {
Debug( LDAP_DEBUG_ANY,
"%s.pm: line %d: missing module in \"perlModule <module>\" line\n",
fname, lineno, 0 );
return( 1 );
}
strncpy(eval_str, argv[1], EVAL_BUF_SIZE );
perl_require_pv( strcat( eval_str, ".pm" ));
if (SvTRUE(GvSV(errgv))) {
fprintf(stderr , "Error %s\n", SvPV(GvSV(errgv), na)) ;
} else {
dSP; ENTER; SAVETMPS;
PUSHMARK(sp);
XPUSHs(sv_2mortal(newSVpv(argv[1], 0)));
PUTBACK;
count = perl_call_method("new", G_SCALAR);
SPAGAIN;
if (count != 1) {
croak("Big trouble in config\n") ;
}
perl_back->pb_obj_ref = newSVsv(POPs);
PUTBACK; FREETMPS; LEAVE ;
}
} else if ( strcasecmp( argv[0], "perlModulePath" ) == 0 ) {
if ( argc < 2 ) {
fprintf( stderr,
"%s: line %d: missing module in \"PerlModulePath <module>\" line\n",
fname, lineno );
return( 1 );
}
sprintf( eval_str, "push @INC, '%s';", argv[1] );
loc_sv = perl_eval_pv( eval_str, 0 );
} else {
/*
* Pass it to Perl module if defined
*/
{
dSP ; ENTER ; SAVETMPS;
PUSHMARK(sp) ;
XPUSHs( perl_back->pb_obj_ref );
/* Put all arguments on the perl stack */
for( args = 0; args < argc; args++ ) {
XPUSHs(sv_2mortal(newSVpv(argv[args], 0)));
}
PUTBACK ;
count = perl_call_method("config", G_SCALAR);
SPAGAIN ;
if (count != 1) {
croak("Big trouble in config\n") ;
}
return_code = POPi;
PUTBACK ; FREETMPS ; LEAVE ;
}
/* if the module rejected it then we should reject it */
if ( return_code != 0 ) {
fprintf( stderr,
"Unknown perl backeng config: %s\n", argv[0]);
exit( 1 );
}
}
return 0;
}