X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Fmain.c;h=8922d0fbab1f10c56fda97bac5b17978d048289f;hb=9c550e7235830af9d031d8d7ba86b87f36dcc99f;hp=56267449fd3fd3e148e1e7086e24e82e65438647;hpb=71921f219ce184a9952760e4df09a06256423040;p=openldap diff --git a/servers/slapd/main.c b/servers/slapd/main.c index 56267449fd..8922d0fbab 100644 --- a/servers/slapd/main.c +++ b/servers/slapd/main.c @@ -34,8 +34,6 @@ #include #include -#include "ldap_pvt.h" - #include "slap.h" #include "lutil.h" #include "ldif.h" @@ -66,7 +64,7 @@ static struct sockaddr_in bind_addr; typedef int (MainFunc) LDAP_P(( int argc, char *argv[] )); extern MainFunc slapadd, slapcat, slapdn, slapindex, slappasswd, - slaptest, slapauth; + slaptest, slapauth, slapacl; static struct { char *name; @@ -79,6 +77,13 @@ static struct { {"slappasswd", slappasswd}, {"slaptest", slaptest}, {"slapauth", slapauth}, + {"slapacl", slapacl}, + /* NOTE: new tools must be added in chronological order, + * not in alphabetical order, because for backwards + * compatibility name[4] is used to identify the + * tools; so name[4]=='a' must refer to "slapadd" and + * not to "slapauth". Alphabetical order can be used + * for tools whose name[4] is not used yet */ {NULL, NULL} }; @@ -93,7 +98,6 @@ const char Versionstr[] = #endif #ifdef LOG_LOCAL4 - #define DEFAULT_SYSLOG_USER LOG_LOCAL4 typedef struct _str2intDispatch { @@ -102,7 +106,6 @@ typedef struct _str2intDispatch { int intVal; } STRDISP, *STRDISP_P; - /* table to compute syslog-options to integer */ static STRDISP syslog_types[] = { { "LOCAL0", sizeof("LOCAL0"), LOG_LOCAL0 }, @@ -113,11 +116,16 @@ static STRDISP syslog_types[] = { { "LOCAL5", sizeof("LOCAL5"), LOG_LOCAL5 }, { "LOCAL6", sizeof("LOCAL6"), LOG_LOCAL6 }, { "LOCAL7", sizeof("LOCAL7"), LOG_LOCAL7 }, +#ifdef LOG_USER + { "USER", sizeof("USER"), LOG_USER }, +#endif +#ifdef LOG_DAEMON + { "DAEMON", sizeof("DAEMON"), LOG_DAEMON }, +#endif { NULL, 0, 0 } }; -static int cnvt_str2int( char *, STRDISP_P, int ); - +static int cnvt_str2int( char *, STRDISP_P, int ); #endif /* LOG_LOCAL4 */ #define CHECK_NONE 0x00 @@ -125,6 +133,57 @@ static int cnvt_str2int( char *, STRDISP_P, int ); static int check = CHECK_NONE; static int version = 0; +void *slap_tls_ctx; + +static int +slapd_opt_slp( const char *val, void *arg ) +{ +#ifdef HAVE_SLP + /* NULL is default */ + if ( val == NULL || strcasecmp( val, "on" ) == 0 ) { + slapd_register_slp = 1; + + } else if ( strcasecmp( val, "off" ) == 0 ) { + slapd_register_slp = 0; + + /* NOTE: add support for URL specification? */ + + } else { + fprintf(stderr, "unrecognized value \"%s\" for SLP option\n", val ); + return -1; + } + + return 0; + +#else + fputs( "slapd: SLP support is not available\n", stderr ); + return 0; +#endif +} + +/* + * Option helper structure: + * + * oh_nam is left-hand part of