X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Fback-perl%2Fconfig.c;h=c63135110da4b7cae093664dae3f2ba4e5c0406e;hb=e0952945d0b6da70703a711c91306be07d31ea1a;hp=fd3105aa7e7837c8c07c32a154d9599111a87e24;hpb=73c87065fb84af6536b06d62bc322070fc53a1cd;p=openldap diff --git a/servers/slapd/back-perl/config.c b/servers/slapd/back-perl/config.c index fd3105aa7e..c63135110d 100644 --- a/servers/slapd/back-perl/config.c +++ b/servers/slapd/back-perl/config.c @@ -1,25 +1,20 @@ /* $OpenLDAP$ */ -/* - * Copyright 1999, John C. Quillan, All rights reserved. +/* This work is part of OpenLDAP Software . * - * 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. + * Copyright 1999-2008 The OpenLDAP Foundation. + * Portions Copyright 1999 John C. Quillan. + * Portions Copyright 2002 myinternet Limited. + * 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 file LICENSE in the + * top-level directory of the distribution or, alternatively, at + * . */ -#include "portable.h" -/* init.c - initialize shell backend */ - -#include -/* #include - #include -*/ - -#include -#include - -#include "slap.h" #include "perl_back.h" @@ -53,21 +48,35 @@ perl_back_db_config( return( 1 ); } - strncpy(eval_str, argv[1], EVAL_BUF_SIZE ); +#ifdef PERL_IS_5_6 + snprintf( eval_str, EVAL_BUF_SIZE, "use %s;", argv[1] ); + eval_pv( eval_str, 0 ); + + if (SvTRUE(ERRSV)) { + STRLEN n_a; - perl_require_pv( strcat( eval_str, ".pm" )); + fprintf(stderr , "Error %s\n", SvPV(ERRSV, n_a)) ; + } +#else + snprintf( eval_str, EVAL_BUF_SIZE, "%s.pm", argv[1] ); + perl_require_pv( eval_str ); if (SvTRUE(GvSV(errgv))) { fprintf(stderr , "Error %s\n", SvPV(GvSV(errgv), na)) ; - - } else { + } +#endif /* PERL_IS_5_6 */ + else { dSP; ENTER; SAVETMPS; PUSHMARK(sp); XPUSHs(sv_2mortal(newSVpv(argv[1], 0))); PUTBACK; +#ifdef PERL_IS_5_6 + count = call_method("new", G_SCALAR); +#else count = perl_call_method("new", G_SCALAR); - +#endif + SPAGAIN; if (count != 1) { @@ -87,10 +96,19 @@ perl_back_db_config( return( 1 ); } - sprintf( eval_str, "push @INC, '%s';", argv[1] ); + snprintf( eval_str, EVAL_BUF_SIZE, "push @INC, '%s';", argv[1] ); +#ifdef PERL_IS_5_6 + loc_sv = eval_pv( eval_str, 0 ); +#else loc_sv = perl_eval_pv( eval_str, 0 ); +#endif + /* XXX loc_sv return value is ignored. */ + + } else if ( strcasecmp( argv[0], "filterSearchResults" ) == 0 ) { + perl_back->pb_filter_search_results = 1; } else { + return_code = SLAP_CONF_UNKNOWN; /* * Pass it to Perl module if defined */ @@ -108,7 +126,11 @@ perl_back_db_config( PUTBACK ; +#ifdef PERL_IS_5_6 + count = call_method("config", G_SCALAR); +#else count = perl_call_method("config", G_SCALAR); +#endif SPAGAIN ; @@ -122,12 +144,7 @@ perl_back_db_config( } - /* if the module rejected it then we should reject it */ - if ( return_code != 0 ) { - fprintf( stderr, - "Unknown perl backend config: %s\n", argv[0]); - exit( EXIT_FAILURE ); - } + return return_code; } return 0;