1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-25 06:04:04 +03:00
samba-mirror/lib/cmdline/cmdline_s4.c
Douglas Bagnall 9537ac723c cmdline_s4: re-initialise logging once loadparm is ready
The first time round we maybe didn't know which files we wanted to log to.
Suppose, for example, we had an smb.conf with

 log level = 1 dsdb_group_json_audit:5@/var/log/group_json.log

we wouldn't see anything in "/var/log/group_json.log", while the level
5 dsdb_group_json_audit messages would go into the main log.

Note that the named file would still be opened by winbindd and others
that use the s3 code, but would remain empty as they don't have anything
to say about dsdb_group_json_audit.

BUG: https://bugzilla.samba.org/show_bug.cgi?id=15076

Signed-off-by: Douglas Bagnall <douglas.bagnall@catalyst.net.nz>
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
Reviewed-by: Andreas Schneider <asn@samba.org>
2022-05-30 10:11:28 +00:00

126 lines
2.9 KiB
C

/*
* Copyright (c) 2020 Andreas Schneider <asn@samba.org>
*
* 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 <http://www.gnu.org/licenses/>.
*/
#include "lib/replace/replace.h"
#include <talloc.h>
#include "lib/param/param.h"
#include "lib/util/debug.h"
#include "lib/util/fault.h"
#include "auth/credentials/credentials.h"
#include "dynconfig/dynconfig.h"
#include "cmdline_private.h"
static bool _require_smbconf;
static enum samba_cmdline_config_type _config_type;
static bool _samba_cmdline_load_config_s4(void)
{
struct loadparm_context *lp_ctx = samba_cmdline_get_lp_ctx();
const char *config_file = NULL;
const struct samba_cmdline_daemon_cfg *cmdline_daemon_cfg = \
samba_cmdline_get_daemon_cfg();
bool ok;
/* Load smb conf */
config_file = lpcfg_configfile(lp_ctx);
if (config_file == NULL) {
if (is_default_dyn_CONFIGFILE()) {
const char *env = getenv("SMB_CONF_PATH");
if (env != NULL && strlen(env) > 0) {
set_dyn_CONFIGFILE(env);
}
}
}
switch (_config_type) {
case SAMBA_CMDLINE_CONFIG_SERVER:
if (!cmdline_daemon_cfg->interactive) {
setup_logging(getprogname(), DEBUG_FILE);
}
break;
default:
break;
}
config_file = get_dyn_CONFIGFILE();
ok = lpcfg_load(lp_ctx, config_file);
if (!ok) {
fprintf(stderr,
"Can't load %s - run testparm to debug it\n",
config_file);
if (_require_smbconf) {
return false;
}
}
switch (_config_type) {
case SAMBA_CMDLINE_CONFIG_SERVER:
/*
* We need to setup_logging *again* to ensure multi-file
* logging is set up as specified in smb.conf.
*/
if (!cmdline_daemon_cfg->interactive) {
setup_logging(getprogname(), DEBUG_FILE);
}
break;
default:
break;
}
return true;
}
bool samba_cmdline_init(TALLOC_CTX *mem_ctx,
enum samba_cmdline_config_type config_type,
bool require_smbconf)
{
struct loadparm_context *lp_ctx = NULL;
struct cli_credentials *creds = NULL;
bool ok;
ok = samba_cmdline_init_common(mem_ctx);
if (!ok) {
return false;
}
lp_ctx = loadparm_init_global(false);
if (lp_ctx == NULL) {
return false;
}
ok = samba_cmdline_set_lp_ctx(lp_ctx);
if (!ok) {
return false;
}
_require_smbconf = require_smbconf;
_config_type = config_type;
creds = cli_credentials_init(mem_ctx);
if (creds == NULL) {
return false;
}
ok = samba_cmdline_set_creds(creds);
if (!ok) {
return false;
}
samba_cmdline_set_load_config_fn(_samba_cmdline_load_config_s4);
return true;
}