/* Unix SMB/CIFS implementation. Copyright (C) 2001 by Martin Pool Copyright (C) 2003 by Jim McDonough Copyright (C) 2007 by Jeremy Allison This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #include "includes.h" /** * @file dynconfig.c * * @brief Global configurations, initialized to configured defaults. * * This file should be the only file that depends on path * configuration (--prefix, etc), so that if ./configure is re-run, * all programs will be appropriately updated. Everything else in * Samba should import extern variables from here, rather than relying * on preprocessor macros. * * Eventually some of these may become even more variable, so that * they can for example consistently be set across the whole of Samba * by command-line parameters, config file entries, or environment * variables. * * @todo Perhaps eventually these should be merged into the parameter * table? There's kind of a chicken-and-egg situation there... **/ #define DEFINE_DYN_CONFIG_PARAM(name) \ static char *dyn_##name; \ \ const char *get_dyn_##name(void) \ {\ if (dyn_##name == NULL) {\ return name;\ }\ return dyn_##name;\ }\ \ const char *set_dyn_##name(const char *newpath) \ {\ if (dyn_##name) {\ SAFE_FREE(dyn_##name);\ }\ dyn_##name = SMB_STRDUP(newpath);\ return dyn_##name;\ }\ \ bool is_default_dyn_##name(void) \ {\ return (dyn_##name == NULL);\ } DEFINE_DYN_CONFIG_PARAM(SBINDIR) DEFINE_DYN_CONFIG_PARAM(BINDIR) DEFINE_DYN_CONFIG_PARAM(SWATDIR) #ifndef __OS2__ DEFINE_DYN_CONFIG_PARAM(CONFIGFILE) /**< Location of smb.conf file. **/ DEFINE_DYN_CONFIG_PARAM(LOGFILEBASE) /** Log file directory. **/ DEFINE_DYN_CONFIG_PARAM(LMHOSTSFILE) /** Statically configured LanMan hosts. **/ #endif DEFINE_DYN_CONFIG_PARAM(CODEPAGEDIR) DEFINE_DYN_CONFIG_PARAM(LIBDIR) DEFINE_DYN_CONFIG_PARAM(MODULESDIR) DEFINE_DYN_CONFIG_PARAM(SHLIBEXT) #ifndef __OS2__ DEFINE_DYN_CONFIG_PARAM(LOCKDIR) DEFINE_DYN_CONFIG_PARAM(PIDDIR) DEFINE_DYN_CONFIG_PARAM(SMB_PASSWD_FILE) DEFINE_DYN_CONFIG_PARAM(PRIVATE_DIR) #endif #ifdef __OS2__ static char *dyn_CONFIGFILE; /**< Location of smb.conf file. **/ const char *get_dyn_CONFIGFILE(void) { static char buffer[1024] = ""; if (!*buffer) { snprintf(buffer, 260, "%s/samba/smb.conf", getenv("ETC")); } if (dyn_CONFIGFILE == NULL) { return buffer; } return dyn_CONFIGFILE; } const char *set_dyn_CONFIGFILE(const char *newpath) { if (dyn_CONFIGFILE) { SAFE_FREE(dyn_CONFIGFILE); } dyn_CONFIGFILE = SMB_STRDUP(newpath); return dyn_CONFIGFILE; } bool is_default_dyn_CONFIGFILE(void) \ {\ return (dyn_CONFIGFILE == NULL);\ } /** Log file directory. **/ static char *dyn_LOGFILEBASE; const char *get_dyn_LOGFILEBASE(void) { static char buffer[1024] = ""; if (!*buffer) { snprintf(buffer, 260, "%s/samba/log", getenv("ETC")); } if (dyn_LOGFILEBASE == NULL) { return buffer; } return dyn_LOGFILEBASE; } const char *set_dyn_LOGFILEBASE(const char *newpath) { if (dyn_LOGFILEBASE) { SAFE_FREE(dyn_LOGFILEBASE); } dyn_LOGFILEBASE = SMB_STRDUP(newpath); return dyn_LOGFILEBASE; } /** Statically configured LanMan hosts. **/ static char *dyn_LMHOSTSFILE; const char *get_dyn_LMHOSTSFILE(void) { static char buffer[1024] = ""; if (!*buffer) { snprintf(buffer, 260, "%s/samba/lmhosts", getenv("ETC")); } if (dyn_LMHOSTSFILE == NULL) { return buffer; } return dyn_LMHOSTSFILE; } const char *set_dyn_LMHOSTSFILE(const char *newpath) { if (dyn_LMHOSTSFILE) { SAFE_FREE(dyn_LMHOSTSFILE); } dyn_LMHOSTSFILE = SMB_STRDUP(newpath); return dyn_LMHOSTSFILE; } /** * @brief Directory holding lock files. * * Not writable, but used to set a default in the parameter table. **/ static char *dyn_LOCKDIR; const char *get_dyn_LOCKDIR(void) { static char buffer[1024] = ""; if (!*buffer) { snprintf(buffer, 260, "%s/samba/lock", getenv("ETC")); } if (dyn_LOCKDIR == NULL) { return buffer; } return dyn_LOCKDIR; } const char *set_dyn_LOCKDIR(const char *newpath) { if (dyn_LOCKDIR) { SAFE_FREE(dyn_LOCKDIR); } dyn_LOCKDIR = SMB_STRDUP(newpath); return dyn_LOCKDIR; } static char *dyn_PIDDIR; const char *get_dyn_PIDDIR(void) { static char buffer[1024] = ""; if (!*buffer) { snprintf(buffer, 260, "%s/samba/pid", getenv("ETC")); } if (dyn_PIDDIR == NULL) { return buffer; } return dyn_PIDDIR; } const char *set_dyn_PIDDIR(const char *newpath) { if (dyn_PIDDIR) { SAFE_FREE(dyn_PIDDIR); } dyn_PIDDIR = SMB_STRDUP(newpath); return dyn_PIDDIR; } static char *dyn_SMB_PASSWD_FILE; const char *get_dyn_SMB_PASSWD_FILE(void) { static char buffer[1024] = ""; if (!*buffer) { snprintf(buffer, 260, "%s/samba/private/smbpasswd", getenv("ETC")); } if (dyn_SMB_PASSWD_FILE == NULL) { return buffer; } return dyn_SMB_PASSWD_FILE; } const char *set_dyn_SMB_PASSWD_FILE(const char *newpath) { if (dyn_SMB_PASSWD_FILE) { SAFE_FREE(dyn_SMB_PASSWD_FILE); } dyn_SMB_PASSWD_FILE = SMB_STRDUP(newpath); return dyn_SMB_PASSWD_FILE; } static char *dyn_PRIVATE_DIR; const char *get_dyn_PRIVATE_DIR(void) { static char buffer[1024] = ""; if (!*buffer) { snprintf(buffer, 260, "%s/samba/private", getenv("ETC")); } if (dyn_PRIVATE_DIR == NULL) { return buffer; } return dyn_PRIVATE_DIR; } const char *set_dyn_PRIVATE_DIR(const char *newpath) { if (dyn_PRIVATE_DIR) { SAFE_FREE(dyn_PRIVATE_DIR); } dyn_PRIVATE_DIR = SMB_STRDUP(newpath); return dyn_PRIVATE_DIR; } #endif /* __OS2__ */ /* In non-FHS mode, these should be configurable using 'lock dir ='; but in FHS mode, they are their own directory. Implement as wrapper functions so that everything can still be kept in dynconfig.c. */ const char *get_dyn_STATEDIR(void) { #ifdef FHS_COMPATIBLE return STATEDIR; #else return lp_lockdir(); #endif } const char *get_dyn_CACHEDIR(void) { #ifdef FHS_COMPATIBLE return CACHEDIR; #else return lp_lockdir(); #endif }