+/*
+ * Copyright 1998-1999 The OpenLDAP Foundation, All Rights Reserved.
+ * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
+ */
#include "portable.h"
#include <stdio.h>
#include <ac/string.h>
#include <ac/ctype.h>
#include <ac/time.h>
-extern char *strdup (const char *);
#include "ldap-int.h"
#include "ldapconfig.h"
-struct ldapoptions openldap_ldap_global_options;
+struct ldapoptions openldap_ldap_global_options = { LDAP_DEBUG_NONE };
#undef gopts
#define gopts openldap_ldap_global_options
char *cmd, *opt;
char *start, *end;
+ if (file == NULL) {
+ /* no file name */
+ return;
+ }
+
fp = fopen(file, "r");
if(fp == NULL) {
/* could not open file */
static void openldap_ldap_init_w_userconf(const char *file)
{
- char *home = getenv("HOME");
+ char *home;
char *path;
-
+
+ if (file == NULL) {
+ /* no file name */
+ return;
+ }
+
+ home = getenv("HOME");
+
if (home != NULL) {
path = malloc(strlen(home) + strlen(file) + 3);
} else {
path = malloc(strlen(file) + 3);
}
-
if(home != NULL && path != NULL) {
+ /* we assume UNIX path syntax is used... */
+
/* try ~/file */
sprintf(path, "%s/%s", home, file);
openldap_ldap_init_w_conf(path);
openldap_ldap_init_w_conf(path);
}
+ if(path != NULL) {
+ free(path);
+ }
+
/* try file */
openldap_ldap_init_w_conf(file);
-
- if(path == NULL) {
- /* try .file */
- sprintf(path, ".%s", file);
- openldap_ldap_init_w_conf(path);
- }
}
static void openldap_ldap_init_w_env(const char *prefix)
return;
}
+ ldap_pvt_init_utils();
+
gopts.ldo_version = LDAP_VERSION2;
gopts.ldo_deref = LDAP_DEREF_NEVER;
gopts.ldo_timelimit = LDAP_NO_LIMIT;
gopts.ldo_sizelimit = LDAP_NO_LIMIT;
+ gopts.ldo_debug = 0;
+
gopts.ldo_defhost = strdup("localhost");
gopts.ldo_defport = LDAP_PORT;
LDAP_BOOL_SET(&gopts, LDAP_BOOL_REFERRALS);
#endif
+ openldap_ldap_initialized = 1;
+
+ if( getenv("LDAPNOINIT") != NULL ) {
+ return;
+ }
+
openldap_ldap_init_w_conf(DEFAULT_LDAP_CONF_FILE);
openldap_ldap_init_w_userconf(DEFAULT_LDAP_USERRC_FILE);
- openldap_ldap_init_w_env(NULL);
- openldap_ldap_initialized = 1;
+ {
+ char *altfile = getenv("LDAPCONF");
+
+ if( altfile != NULL ) {
+ openldap_ldap_init_w_conf( altfile );
+ }
+ }
+
+ {
+ char *altfile = getenv("LDAPRC");
+
+ if( altfile != NULL ) {
+ openldap_ldap_init_w_userconf( altfile );
+ }
+ }
+
+ openldap_ldap_init_w_env(NULL);
}