Blame SOURCES/0017-Add-parameter-logger-to-daemons.patch

9f2ebf
From de26ea6f603e87ef306f08fa1b458b8a180bdf2d Mon Sep 17 00:00:00 2001
9f2ebf
From: Lukas Slebodnik <lslebodn@redhat.com>
9f2ebf
Date: Mon, 23 Oct 2017 15:18:47 +0200
9f2ebf
Subject: [PATCH 17/21] Add parameter --logger to daemons
9f2ebf
MIME-Version: 1.0
9f2ebf
Content-Type: text/plain; charset=UTF-8
9f2ebf
Content-Transfer-Encoding: 8bit
9f2ebf
9f2ebf
Different binary handled information about logging differently
9f2ebf
 e,g, --debug-to-files --debug-to-stderr
9f2ebf
And logging to journald was a special case of previous options
9f2ebf
(!debug_file && !debug_to_stderr). It was also tied to the monitor option
9f2ebf
"--daemon" and therefore loggind to stderr was used in interactive mode
9f2ebf
+ systemd Type=notify.
9f2ebf
9f2ebf
Resolves:
9f2ebf
https://pagure.io/SSSD/sssd/issue/3433
9f2ebf
9f2ebf
Reviewed-by: Justin Stephenson <jstephen@redhat.com>
9f2ebf
Reviewed-by: Fabiano FidĂȘncio <fidencio@redhat.com>
9f2ebf
(cherry picked from commit cb75b275d15beedd1fdecc1f8ced657fba282218)
9f2ebf
---
9f2ebf
 src/man/sssd.8.xml                | 31 +++++++++++++++++++++++++
9f2ebf
 src/monitor/monitor.c             | 48 ++++++++++++---------------------------
9f2ebf
 src/p11_child/p11_child_nss.c     |  3 +++
9f2ebf
 src/providers/ad/ad_gpo_child.c   |  4 ++++
9f2ebf
 src/providers/data_provider_be.c  |  4 ++++
9f2ebf
 src/providers/ipa/selinux_child.c |  4 ++++
9f2ebf
 src/providers/krb5/krb5_child.c   |  4 ++++
9f2ebf
 src/providers/ldap/ldap_child.c   |  4 ++++
9f2ebf
 src/providers/proxy/proxy_auth.c  |  4 ++--
9f2ebf
 src/providers/proxy/proxy_child.c |  4 ++++
9f2ebf
 src/responder/autofs/autofssrv.c  |  4 ++++
9f2ebf
 src/responder/ifp/ifpsrv.c        |  4 ++++
9f2ebf
 src/responder/kcm/kcm.c           |  4 ++++
9f2ebf
 src/responder/nss/nsssrv.c        |  4 ++++
9f2ebf
 src/responder/pac/pacsrv.c        |  4 ++++
9f2ebf
 src/responder/pam/pamsrv.c        |  4 ++++
9f2ebf
 src/responder/secrets/secsrv.c    |  4 ++++
9f2ebf
 src/responder/ssh/sshsrv.c        |  4 ++++
9f2ebf
 src/responder/sudo/sudosrv.c      |  4 ++++
9f2ebf
 src/tests/cmocka/dummy_child.c    |  4 ++++
9f2ebf
 src/tests/debug-tests.c           | 10 ++++++++
9f2ebf
 src/util/child_common.c           |  2 +-
9f2ebf
 src/util/debug.c                  |  4 ++--
9f2ebf
 src/util/server.c                 | 12 ++++++----
9f2ebf
 24 files changed, 135 insertions(+), 43 deletions(-)
9f2ebf
9f2ebf
diff --git a/src/man/sssd.8.xml b/src/man/sssd.8.xml
9f2ebf
index 923da6824907f0d2d140d9ca83f87338e7664f83..0b725628ff93f48f832140dd5dc15b040a8b179f 100644
9f2ebf
--- a/src/man/sssd.8.xml
9f2ebf
+++ b/src/man/sssd.8.xml
9f2ebf
@@ -94,6 +94,37 @@
9f2ebf
             </varlistentry>
9f2ebf
             <varlistentry>
9f2ebf
                 <term>
9f2ebf
+                    <option>--logger=</option><replaceable>value</replaceable>
9f2ebf
+                </term>
9f2ebf
+                <listitem>
9f2ebf
+                    <para>
9f2ebf
+                        Location where SSSD will send log messages. This option
9f2ebf
+                        overrides the value of the deprecated option
9f2ebf
+                        <option>--debug-to-files</option>. The deprecated
9f2ebf
+                        option will still work if the <option>--logger</option>
9f2ebf
+                        is not used.
9f2ebf
+                    </para>
9f2ebf
+                    <para>
9f2ebf
+                        <emphasis>stderr</emphasis>: Redirect debug messages to
9f2ebf
+                        standard error output.
9f2ebf
+                    </para>
9f2ebf
+                    <para>
9f2ebf
+                        <emphasis>files</emphasis>: Redirect debug messages to
9f2ebf
+                        the log files. By default, the log files are stored in
9f2ebf
+                        <filename>/var/log/sssd</filename> and there are
9f2ebf
+                        separate log files for every SSSD service and domain.
9f2ebf
+                    </para>
9f2ebf
+                    <para>
9f2ebf
+                        <emphasis>journald</emphasis>: Redirect debug messages
9f2ebf
+                        to systemd-journald
9f2ebf
+                    </para>
9f2ebf
+                    <para>
9f2ebf
+                        Default: not set
9f2ebf
+                    </para>
9f2ebf
+                </listitem>
9f2ebf
+            </varlistentry>
9f2ebf
+            <varlistentry>
9f2ebf
+                <term>
9f2ebf
                     <option>-D</option>,<option>--daemon</option>
9f2ebf
                 </term>
9f2ebf
                 <listitem>
9f2ebf
diff --git a/src/monitor/monitor.c b/src/monitor/monitor.c
9f2ebf
index 7726548bbb666bb189667efc1de2295f8a001105..3c0b7ab2dac10fe15a8a5b807cb68ea4b7ab8461 100644
9f2ebf
--- a/src/monitor/monitor.c
9f2ebf
+++ b/src/monitor/monitor.c
9f2ebf
@@ -1211,22 +1211,11 @@ static int get_service_config(struct mt_ctx *ctx, const char *name,
9f2ebf
             }
9f2ebf
         }
9f2ebf
 
9f2ebf
-        if (debug_to_file) {
9f2ebf
-            svc->command = talloc_strdup_append(
9f2ebf
-                svc->command, " --debug-to-files"
9f2ebf
-            );
9f2ebf
-            if (!svc->command) {
9f2ebf
-                talloc_free(svc);
9f2ebf
-                return ENOMEM;
9f2ebf
-            }
9f2ebf
-        } else if (ctx->is_daemon == false) {
9f2ebf
-            svc->command = talloc_strdup_append(
9f2ebf
-                svc->command, " --debug-to-stderr"
9f2ebf
-            );
9f2ebf
-            if (!svc->command) {
9f2ebf
-                talloc_free(svc);
9f2ebf
-                return ENOMEM;
9f2ebf
-            }
9f2ebf
+        svc->command = talloc_asprintf_append(
9f2ebf
+            svc->command, " --logger=%s", sss_logger_str[sss_logger]);
9f2ebf
+        if (!svc->command) {
9f2ebf
+            talloc_free(svc);
9f2ebf
+            return ENOMEM;
9f2ebf
         }
9f2ebf
     }
9f2ebf
 
9f2ebf
@@ -1374,22 +1363,11 @@ static int get_provider_config(struct mt_ctx *ctx, const char *name,
9f2ebf
             }
9f2ebf
         }
9f2ebf
 
9f2ebf
-        if (debug_to_file) {
9f2ebf
-            svc->command = talloc_strdup_append(
9f2ebf
-                svc->command, " --debug-to-files"
9f2ebf
-            );
9f2ebf
-            if (!svc->command) {
9f2ebf
-                talloc_free(svc);
9f2ebf
-                return ENOMEM;
9f2ebf
-            }
9f2ebf
-        } else if (ctx->is_daemon == false) {
9f2ebf
-            svc->command = talloc_strdup_append(
9f2ebf
-                svc->command, " --debug-to-stderr"
9f2ebf
-            );
9f2ebf
-            if (!svc->command) {
9f2ebf
-                talloc_free(svc);
9f2ebf
-                return ENOMEM;
9f2ebf
-            }
9f2ebf
+        svc->command = talloc_asprintf_append(
9f2ebf
+            svc->command, " --logger=%s", sss_logger_str[sss_logger]);
9f2ebf
+        if (!svc->command) {
9f2ebf
+            talloc_free(svc);
9f2ebf
+            return ENOMEM;
9f2ebf
         }
9f2ebf
     }
9f2ebf
 
9f2ebf
@@ -2454,6 +2432,7 @@ int main(int argc, const char *argv[])
9f2ebf
     int opt_version = 0;
9f2ebf
     int opt_netlinkoff = 0;
9f2ebf
     char *opt_config_file = NULL;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
     char *config_file = NULL;
9f2ebf
     int flags = 0;
9f2ebf
     struct main_context *main_ctx;
9f2ebf
@@ -2465,6 +2444,7 @@ int main(int argc, const char *argv[])
9f2ebf
     struct poptOption long_options[] = {
9f2ebf
         POPT_AUTOHELP
9f2ebf
         SSSD_MAIN_OPTS
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         {"daemon", 'D', POPT_ARG_NONE, &opt_daemon, 0, \
9f2ebf
          _("Become a daemon (default)"), NULL }, \
9f2ebf
         {"interactive", 'i', POPT_ARG_NONE, &opt_interactive, 0, \
9f2ebf
@@ -2551,6 +2531,8 @@ int main(int argc, const char *argv[])
9f2ebf
         debug_to_stderr = 1;
9f2ebf
     }
9f2ebf
 
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
+
9f2ebf
     if (opt_config_file) {
9f2ebf
         config_file = talloc_strdup(tmp_ctx, opt_config_file);
9f2ebf
     } else {
9f2ebf
@@ -2575,7 +2557,7 @@ int main(int argc, const char *argv[])
9f2ebf
 
9f2ebf
     /* Open before server_setup() does to have logging
9f2ebf
      * during configuration checking */
9f2ebf
-    if (debug_to_file) {
9f2ebf
+    if (sss_logger == FILES_LOGGER) {
9f2ebf
         ret = open_debug_file();
9f2ebf
         if (ret) {
9f2ebf
             return 7;
9f2ebf
diff --git a/src/p11_child/p11_child_nss.c b/src/p11_child/p11_child_nss.c
9f2ebf
index f165b58e63d2b8a6f26acf8bd89e7b41713e7359..e7dbcb689220d1cd2585fbde5f26e84f8fa15cc2 100644
9f2ebf
--- a/src/p11_child/p11_child_nss.c
9f2ebf
+++ b/src/p11_child/p11_child_nss.c
9f2ebf
@@ -537,6 +537,7 @@ int main(int argc, const char *argv[])
9f2ebf
     int opt;
9f2ebf
     poptContext pc;
9f2ebf
     int debug_fd = -1;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
     errno_t ret;
9f2ebf
     TALLOC_CTX *main_ctx = NULL;
9f2ebf
     char *cert;
9f2ebf
@@ -564,6 +565,7 @@ int main(int argc, const char *argv[])
9f2ebf
         {"debug-to-stderr", 0, POPT_ARG_NONE | POPT_ARGFLAG_DOC_HIDDEN,
9f2ebf
          &debug_to_stderr, 0,
9f2ebf
          _("Send the debug output to stderr directly."), NULL },
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         {"auth", 0, POPT_ARG_NONE, NULL, 'a', _("Run in auth mode"), NULL},
9f2ebf
         {"pre", 0, POPT_ARG_NONE, NULL, 'p', _("Run in pre-auth mode"), NULL},
9f2ebf
         {"pin", 0, POPT_ARG_NONE, NULL, 'i', _("Expect PIN on stdin"), NULL},
9f2ebf
@@ -672,6 +674,7 @@ int main(int argc, const char *argv[])
9f2ebf
             DEBUG(SSSDBG_CRIT_FAILURE, "set_debug_file_from_fd failed.\n");
9f2ebf
         }
9f2ebf
     }
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
 
9f2ebf
     DEBUG(SSSDBG_TRACE_FUNC, "p11_child started.\n");
9f2ebf
 
9f2ebf
diff --git a/src/providers/ad/ad_gpo_child.c b/src/providers/ad/ad_gpo_child.c
9f2ebf
index 8e5e062547721567cb450f9d0f72f1ec8cb99f96..5375cc691e8649c289672b74c4bfe5266c8222c9 100644
9f2ebf
--- a/src/providers/ad/ad_gpo_child.c
9f2ebf
+++ b/src/providers/ad/ad_gpo_child.c
9f2ebf
@@ -687,6 +687,7 @@ main(int argc, const char *argv[])
9f2ebf
     int opt;
9f2ebf
     poptContext pc;
9f2ebf
     int debug_fd = -1;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
     errno_t ret;
9f2ebf
     int sysvol_gpt_version;
9f2ebf
     int result;
9f2ebf
@@ -710,6 +711,7 @@ main(int argc, const char *argv[])
9f2ebf
         {"debug-to-stderr", 0, POPT_ARG_NONE | POPT_ARGFLAG_DOC_HIDDEN,
9f2ebf
          &debug_to_stderr, 0,
9f2ebf
          _("Send the debug output to stderr directly."), NULL },
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         POPT_TABLEEND
9f2ebf
     };
9f2ebf
 
9f2ebf
@@ -744,6 +746,8 @@ main(int argc, const char *argv[])
9f2ebf
         }
9f2ebf
     }
9f2ebf
 
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
+
9f2ebf
     DEBUG(SSSDBG_TRACE_FUNC, "gpo_child started.\n");
9f2ebf
 
9f2ebf
     main_ctx = talloc_new(NULL);
9f2ebf
diff --git a/src/providers/data_provider_be.c b/src/providers/data_provider_be.c
9f2ebf
index 2e55dc4e3fe9ba1aa8c1c51c426efee00b9ae91d..56ddac112a209b6937313d3d3c94a73d2067331f 100644
9f2ebf
--- a/src/providers/data_provider_be.c
9f2ebf
+++ b/src/providers/data_provider_be.c
9f2ebf
@@ -537,6 +537,7 @@ int main(int argc, const char *argv[])
9f2ebf
 {
9f2ebf
     int opt;
9f2ebf
     poptContext pc;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
     char *be_domain = NULL;
9f2ebf
     char *srv_name = NULL;
9f2ebf
     struct main_context *main_ctx;
9f2ebf
@@ -548,6 +549,7 @@ int main(int argc, const char *argv[])
9f2ebf
     struct poptOption long_options[] = {
9f2ebf
         POPT_AUTOHELP
9f2ebf
         SSSD_MAIN_OPTS
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         SSSD_SERVER_OPTS(uid, gid)
9f2ebf
         {"domain", 0, POPT_ARG_STRING, &be_domain, 0,
9f2ebf
          _("Domain of the information provider (mandatory)"), NULL },
9f2ebf
@@ -582,6 +584,8 @@ int main(int argc, const char *argv[])
9f2ebf
     debug_log_file = talloc_asprintf(NULL, "sssd_%s", be_domain);
9f2ebf
     if (!debug_log_file) return 2;
9f2ebf
 
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
+
9f2ebf
     srv_name = talloc_asprintf(NULL, "sssd[be[%s]]", be_domain);
9f2ebf
     if (!srv_name) return 2;
9f2ebf
 
9f2ebf
diff --git a/src/providers/ipa/selinux_child.c b/src/providers/ipa/selinux_child.c
9f2ebf
index 073475094ee491bd5453898c6ba65214fa14fe59..120492686963241b7e419413f489cc38953e32f2 100644
9f2ebf
--- a/src/providers/ipa/selinux_child.c
9f2ebf
+++ b/src/providers/ipa/selinux_child.c
9f2ebf
@@ -206,6 +206,7 @@ int main(int argc, const char *argv[])
9f2ebf
     struct response *resp = NULL;
9f2ebf
     ssize_t written;
9f2ebf
     bool needs_update;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
 
9f2ebf
     struct poptOption long_options[] = {
9f2ebf
         POPT_AUTOHELP
9f2ebf
@@ -220,6 +221,7 @@ int main(int argc, const char *argv[])
9f2ebf
         {"debug-to-stderr", 0, POPT_ARG_NONE | POPT_ARGFLAG_DOC_HIDDEN,
9f2ebf
          &debug_to_stderr, 0,
9f2ebf
          _("Send the debug output to stderr directly."), NULL },
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         POPT_TABLEEND
9f2ebf
     };
9f2ebf
 
9f2ebf
@@ -254,6 +256,8 @@ int main(int argc, const char *argv[])
9f2ebf
         }
9f2ebf
     }
9f2ebf
 
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
+
9f2ebf
     DEBUG(SSSDBG_TRACE_FUNC, "selinux_child started.\n");
9f2ebf
     DEBUG(SSSDBG_TRACE_INTERNAL,
9f2ebf
           "Running with effective IDs: [%"SPRIuid"][%"SPRIgid"].\n",
9f2ebf
diff --git a/src/providers/krb5/krb5_child.c b/src/providers/krb5/krb5_child.c
9f2ebf
index 888cc5d6f5c554901cc46d4315844d7bbbe582b8..700338e47a3f9ac6fcf11b4c92364dbdb4f9bcf7 100644
9f2ebf
--- a/src/providers/krb5/krb5_child.c
9f2ebf
+++ b/src/providers/krb5/krb5_child.c
9f2ebf
@@ -3020,6 +3020,7 @@ int main(int argc, const char *argv[])
9f2ebf
     int opt;
9f2ebf
     poptContext pc;
9f2ebf
     int debug_fd = -1;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
     errno_t ret;
9f2ebf
     krb5_error_code kerr;
9f2ebf
     uid_t fast_uid;
9f2ebf
@@ -3039,6 +3040,7 @@ int main(int argc, const char *argv[])
9f2ebf
         {"debug-to-stderr", 0, POPT_ARG_NONE | POPT_ARGFLAG_DOC_HIDDEN,
9f2ebf
          &debug_to_stderr, 0,
9f2ebf
          _("Send the debug output to stderr directly."), NULL },
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         {CHILD_OPT_FAST_CCACHE_UID, 0, POPT_ARG_INT, &fast_uid, 0,
9f2ebf
           _("The user to create FAST ccache as"), NULL},
9f2ebf
         {CHILD_OPT_FAST_CCACHE_GID, 0, POPT_ARG_INT, &fast_gid, 0,
9f2ebf
@@ -3097,6 +3099,8 @@ int main(int argc, const char *argv[])
9f2ebf
         }
9f2ebf
     }
9f2ebf
 
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
+
9f2ebf
     DEBUG(SSSDBG_TRACE_FUNC, "krb5_child started.\n");
9f2ebf
 
9f2ebf
     kr = talloc_zero(NULL, struct krb5_req);
9f2ebf
diff --git a/src/providers/ldap/ldap_child.c b/src/providers/ldap/ldap_child.c
9f2ebf
index b796e5cae01517c85c2fc1605b1e5877454691dc..baeed239db5dc7ffa482edcbc155f25f718c8249 100644
9f2ebf
--- a/src/providers/ldap/ldap_child.c
9f2ebf
+++ b/src/providers/ldap/ldap_child.c
9f2ebf
@@ -599,6 +599,7 @@ int main(int argc, const char *argv[])
9f2ebf
     int kerr;
9f2ebf
     int opt;
9f2ebf
     int debug_fd = -1;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
     poptContext pc;
9f2ebf
     TALLOC_CTX *main_ctx = NULL;
9f2ebf
     uint8_t *buf = NULL;
9f2ebf
@@ -622,6 +623,7 @@ int main(int argc, const char *argv[])
9f2ebf
          _("An open file descriptor for the debug logs"), NULL},
9f2ebf
         {"debug-to-stderr", 0, POPT_ARG_NONE | POPT_ARGFLAG_DOC_HIDDEN, &debug_to_stderr, 0, \
9f2ebf
          _("Send the debug output to stderr directly."), NULL }, \
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         POPT_TABLEEND
9f2ebf
     };
9f2ebf
 
9f2ebf
@@ -657,6 +659,8 @@ int main(int argc, const char *argv[])
9f2ebf
         }
9f2ebf
     }
9f2ebf
 
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
+
9f2ebf
     BlockSignals(false, SIGTERM);
9f2ebf
     CatchSignal(SIGTERM, sig_term_handler);
9f2ebf
 
9f2ebf
diff --git a/src/providers/proxy/proxy_auth.c b/src/providers/proxy/proxy_auth.c
9f2ebf
index a05586e60b6ef894b0fcf1b8b3f30fdbf51a808d..665a29cf779290b8d35973245a36a1b5224bca78 100644
9f2ebf
--- a/src/providers/proxy/proxy_auth.c
9f2ebf
+++ b/src/providers/proxy/proxy_auth.c
9f2ebf
@@ -178,9 +178,9 @@ static struct tevent_req *proxy_child_init_send(TALLOC_CTX *mem_ctx,
9f2ebf
 
9f2ebf
     state->command = talloc_asprintf(req,
9f2ebf
             "%s/proxy_child -d %#.4x --debug-timestamps=%d "
9f2ebf
-            "--debug-microseconds=%d%s --domain %s --id %d",
9f2ebf
+            "--debug-microseconds=%d --logger=%s --domain %s --id %d",
9f2ebf
             SSSD_LIBEXEC_PATH, debug_level, debug_timestamps,
9f2ebf
-            debug_microseconds, (debug_to_file ? " --debug-to-files" : ""),
9f2ebf
+            debug_microseconds, sss_logger_str[sss_logger],
9f2ebf
             auth_ctx->be->domain->name,
9f2ebf
             child_ctx->id);
9f2ebf
     if (state->command == NULL) {
9f2ebf
diff --git a/src/providers/proxy/proxy_child.c b/src/providers/proxy/proxy_child.c
9f2ebf
index be58622eb8b26231eeb6699976d51f57dc44de98..ae4855adeb5cc68f1a19003355a5d94f5b1bb378 100644
9f2ebf
--- a/src/providers/proxy/proxy_child.c
9f2ebf
+++ b/src/providers/proxy/proxy_child.c
9f2ebf
@@ -504,6 +504,7 @@ int main(int argc, const char *argv[])
9f2ebf
 {
9f2ebf
     int opt;
9f2ebf
     poptContext pc;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
     char *domain = NULL;
9f2ebf
     char *srv_name = NULL;
9f2ebf
     char *conf_entry = NULL;
9f2ebf
@@ -517,6 +518,7 @@ int main(int argc, const char *argv[])
9f2ebf
     struct poptOption long_options[] = {
9f2ebf
         POPT_AUTOHELP
9f2ebf
         SSSD_MAIN_OPTS
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         SSSD_SERVER_OPTS(uid, gid)
9f2ebf
         {"domain", 0, POPT_ARG_STRING, &domain, 0,
9f2ebf
          _("Domain of the information provider (mandatory)"), NULL },
9f2ebf
@@ -561,6 +563,8 @@ int main(int argc, const char *argv[])
9f2ebf
     debug_log_file = talloc_asprintf(NULL, "proxy_child_%s", domain);
9f2ebf
     if (!debug_log_file) return 2;
9f2ebf
 
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
+
9f2ebf
     srv_name = talloc_asprintf(NULL, "sssd[proxy_child[%s]]", domain);
9f2ebf
     if (!srv_name) return 2;
9f2ebf
 
9f2ebf
diff --git a/src/responder/autofs/autofssrv.c b/src/responder/autofs/autofssrv.c
9f2ebf
index cfb2233fdfc346bf27b128ee8c4261f4c73e3470..b0762a2b685a7c5ab3abfa281f0906ad8bfe1c88 100644
9f2ebf
--- a/src/responder/autofs/autofssrv.c
9f2ebf
+++ b/src/responder/autofs/autofssrv.c
9f2ebf
@@ -185,6 +185,7 @@ int main(int argc, const char *argv[])
9f2ebf
 {
9f2ebf
     int opt;
9f2ebf
     poptContext pc;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
     struct main_context *main_ctx;
9f2ebf
     int ret;
9f2ebf
     uid_t uid;
9f2ebf
@@ -193,6 +194,7 @@ int main(int argc, const char *argv[])
9f2ebf
     struct poptOption long_options[] = {
9f2ebf
         POPT_AUTOHELP
9f2ebf
         SSSD_MAIN_OPTS
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         SSSD_SERVER_OPTS(uid, gid)
9f2ebf
         SSSD_RESPONDER_OPTS
9f2ebf
         POPT_TABLEEND
9f2ebf
@@ -221,6 +223,8 @@ int main(int argc, const char *argv[])
9f2ebf
     /* set up things like debug, signals, daemonization, etc... */
9f2ebf
     debug_log_file = "sssd_autofs";
9f2ebf
 
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
+
9f2ebf
     ret = server_setup("sssd[autofs]", 0, uid, gid,
9f2ebf
                        CONFDB_AUTOFS_CONF_ENTRY, &main_ctx);
9f2ebf
     if (ret != EOK) {
9f2ebf
diff --git a/src/responder/ifp/ifpsrv.c b/src/responder/ifp/ifpsrv.c
9f2ebf
index 0dc61a42200cc79fc6f12515a8f581ad0201a043..85dfbacc217e2870dd7517e36a1d39e7f2054a8b 100644
9f2ebf
--- a/src/responder/ifp/ifpsrv.c
9f2ebf
+++ b/src/responder/ifp/ifpsrv.c
9f2ebf
@@ -355,6 +355,7 @@ int main(int argc, const char *argv[])
9f2ebf
 {
9f2ebf
     int opt;
9f2ebf
     poptContext pc;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
     struct main_context *main_ctx;
9f2ebf
     int ret;
9f2ebf
     uid_t uid;
9f2ebf
@@ -363,6 +364,7 @@ int main(int argc, const char *argv[])
9f2ebf
     struct poptOption long_options[] = {
9f2ebf
         POPT_AUTOHELP
9f2ebf
         SSSD_MAIN_OPTS
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         SSSD_SERVER_OPTS(uid, gid)
9f2ebf
         SSSD_RESPONDER_OPTS
9f2ebf
         POPT_TABLEEND
9f2ebf
@@ -391,6 +393,8 @@ int main(int argc, const char *argv[])
9f2ebf
     /* set up things like debug, signals, daemonization, etc... */
9f2ebf
     debug_log_file = "sssd_ifp";
9f2ebf
 
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
+
9f2ebf
     ret = server_setup("sssd[ifp]", 0, 0, 0,
9f2ebf
                        CONFDB_IFP_CONF_ENTRY, &main_ctx);
9f2ebf
     if (ret != EOK) return 2;
9f2ebf
diff --git a/src/responder/kcm/kcm.c b/src/responder/kcm/kcm.c
9f2ebf
index 2202f96381a2622a2c5433e281172287b325f960..358fcc18165dec7b41a7389a3ef22660ac04b4a8 100644
9f2ebf
--- a/src/responder/kcm/kcm.c
9f2ebf
+++ b/src/responder/kcm/kcm.c
9f2ebf
@@ -258,6 +258,7 @@ int main(int argc, const char *argv[])
9f2ebf
 {
9f2ebf
     int opt;
9f2ebf
     poptContext pc;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
     struct main_context *main_ctx;
9f2ebf
     int ret;
9f2ebf
     uid_t uid;
9f2ebf
@@ -266,6 +267,7 @@ int main(int argc, const char *argv[])
9f2ebf
     struct poptOption long_options[] = {
9f2ebf
         POPT_AUTOHELP
9f2ebf
         SSSD_MAIN_OPTS
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         SSSD_SERVER_OPTS(uid, gid)
9f2ebf
         POPT_TABLEEND
9f2ebf
     };
9f2ebf
@@ -293,6 +295,8 @@ int main(int argc, const char *argv[])
9f2ebf
     /* set up things like debug, signals, daemonization, etc... */
9f2ebf
     debug_log_file = "sssd_kcm";
9f2ebf
 
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
+
9f2ebf
     ret = server_setup("sssd[kcm]", 0, uid, gid, CONFDB_KCM_CONF_ENTRY,
9f2ebf
                        &main_ctx);
9f2ebf
     if (ret != EOK) return 2;
9f2ebf
diff --git a/src/responder/nss/nsssrv.c b/src/responder/nss/nsssrv.c
9f2ebf
index 32bfcd69bbb9b35e9932b70a826c4f99ab6a07f3..11d19fd30c86283d537623db12e52caa6cc4dcd3 100644
9f2ebf
--- a/src/responder/nss/nsssrv.c
9f2ebf
+++ b/src/responder/nss/nsssrv.c
9f2ebf
@@ -422,6 +422,7 @@ int main(int argc, const char *argv[])
9f2ebf
 {
9f2ebf
     int opt;
9f2ebf
     poptContext pc;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
     struct main_context *main_ctx;
9f2ebf
     int ret;
9f2ebf
     uid_t uid;
9f2ebf
@@ -430,6 +431,7 @@ int main(int argc, const char *argv[])
9f2ebf
     struct poptOption long_options[] = {
9f2ebf
         POPT_AUTOHELP
9f2ebf
         SSSD_MAIN_OPTS
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         SSSD_SERVER_OPTS(uid, gid)
9f2ebf
         SSSD_RESPONDER_OPTS
9f2ebf
         POPT_TABLEEND
9f2ebf
@@ -458,6 +460,8 @@ int main(int argc, const char *argv[])
9f2ebf
     /* set up things like debug, signals, daemonization, etc... */
9f2ebf
     debug_log_file = "sssd_nss";
9f2ebf
 
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
+
9f2ebf
     ret = server_setup("sssd[nss]", 0, uid, gid, CONFDB_NSS_CONF_ENTRY,
9f2ebf
                        &main_ctx);
9f2ebf
     if (ret != EOK) return 2;
9f2ebf
diff --git a/src/responder/pac/pacsrv.c b/src/responder/pac/pacsrv.c
9f2ebf
index 1f820c07f5c55fe8df75cce05b403c41075d9f94..b72e5c8d2a42bc85f0974dcb81a1290d3f740986 100644
9f2ebf
--- a/src/responder/pac/pacsrv.c
9f2ebf
+++ b/src/responder/pac/pacsrv.c
9f2ebf
@@ -209,6 +209,7 @@ int main(int argc, const char *argv[])
9f2ebf
 {
9f2ebf
     int opt;
9f2ebf
     poptContext pc;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
     struct main_context *main_ctx;
9f2ebf
     int ret;
9f2ebf
     uid_t uid;
9f2ebf
@@ -217,6 +218,7 @@ int main(int argc, const char *argv[])
9f2ebf
     struct poptOption long_options[] = {
9f2ebf
         POPT_AUTOHELP
9f2ebf
         SSSD_MAIN_OPTS
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         SSSD_SERVER_OPTS(uid, gid)
9f2ebf
         SSSD_RESPONDER_OPTS
9f2ebf
         POPT_TABLEEND
9f2ebf
@@ -245,6 +247,8 @@ int main(int argc, const char *argv[])
9f2ebf
     /* set up things like debug, signals, daemonization, etc... */
9f2ebf
     debug_log_file = "sssd_pac";
9f2ebf
 
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
+
9f2ebf
     ret = server_setup("sssd[pac]", 0, uid, gid,
9f2ebf
                        CONFDB_PAC_CONF_ENTRY, &main_ctx);
9f2ebf
     if (ret != EOK) return 2;
9f2ebf
diff --git a/src/responder/pam/pamsrv.c b/src/responder/pam/pamsrv.c
9f2ebf
index 79470823d18138da6ef9235e6336a3220ead1797..cc0e4bddcdbecfadabea78a6d2815d0ac6d651b6 100644
9f2ebf
--- a/src/responder/pam/pamsrv.c
9f2ebf
+++ b/src/responder/pam/pamsrv.c
9f2ebf
@@ -355,6 +355,7 @@ int main(int argc, const char *argv[])
9f2ebf
 {
9f2ebf
     int opt;
9f2ebf
     poptContext pc;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
     struct main_context *main_ctx;
9f2ebf
     int ret;
9f2ebf
     uid_t uid;
9f2ebf
@@ -365,6 +366,7 @@ int main(int argc, const char *argv[])
9f2ebf
     struct poptOption long_options[] = {
9f2ebf
         POPT_AUTOHELP
9f2ebf
         SSSD_MAIN_OPTS
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         SSSD_SERVER_OPTS(uid, gid)
9f2ebf
         SSSD_RESPONDER_OPTS
9f2ebf
         POPT_TABLEEND
9f2ebf
@@ -393,6 +395,8 @@ int main(int argc, const char *argv[])
9f2ebf
     /* set up things like debug, signals, daemonization, etc... */
9f2ebf
     debug_log_file = "sssd_pam";
9f2ebf
 
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
+
9f2ebf
     if (!is_socket_activated()) {
9f2ebf
         /* Crate pipe file descriptors here before privileges are dropped
9f2ebf
          * in server_setup() */
9f2ebf
diff --git a/src/responder/secrets/secsrv.c b/src/responder/secrets/secsrv.c
9f2ebf
index 2b661b165ef0c174557f53012b2dbaa236a6e359..59c0f3a56040a6fc0c092247fbd124a069f97153 100644
9f2ebf
--- a/src/responder/secrets/secsrv.c
9f2ebf
+++ b/src/responder/secrets/secsrv.c
9f2ebf
@@ -324,6 +324,7 @@ int main(int argc, const char *argv[])
9f2ebf
 {
9f2ebf
     int opt;
9f2ebf
     poptContext pc;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
     struct main_context *main_ctx;
9f2ebf
     int ret;
9f2ebf
     uid_t uid;
9f2ebf
@@ -332,6 +333,7 @@ int main(int argc, const char *argv[])
9f2ebf
     struct poptOption long_options[] = {
9f2ebf
         POPT_AUTOHELP
9f2ebf
         SSSD_MAIN_OPTS
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         SSSD_SERVER_OPTS(uid, gid)
9f2ebf
         POPT_TABLEEND
9f2ebf
     };
9f2ebf
@@ -359,6 +361,8 @@ int main(int argc, const char *argv[])
9f2ebf
     /* set up things like debug, signals, daemonization, etc... */
9f2ebf
     debug_log_file = "sssd_secrets";
9f2ebf
 
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
+
9f2ebf
     ret = server_setup("sssd[secrets]", 0, uid, gid, CONFDB_SEC_CONF_ENTRY,
9f2ebf
                        &main_ctx);
9f2ebf
     if (ret != EOK) return 2;
9f2ebf
diff --git a/src/responder/ssh/sshsrv.c b/src/responder/ssh/sshsrv.c
9f2ebf
index 440f0e2b9dc06e3dc52ff96d7207b8a3727865c0..8b0e7cc2d71044d7ab3bd2439041f678ddedb4cd 100644
9f2ebf
--- a/src/responder/ssh/sshsrv.c
9f2ebf
+++ b/src/responder/ssh/sshsrv.c
9f2ebf
@@ -177,6 +177,7 @@ int main(int argc, const char *argv[])
9f2ebf
 {
9f2ebf
     int opt;
9f2ebf
     poptContext pc;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
     struct main_context *main_ctx;
9f2ebf
     int ret;
9f2ebf
     uid_t uid;
9f2ebf
@@ -185,6 +186,7 @@ int main(int argc, const char *argv[])
9f2ebf
     struct poptOption long_options[] = {
9f2ebf
         POPT_AUTOHELP
9f2ebf
         SSSD_MAIN_OPTS
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         SSSD_SERVER_OPTS(uid, gid)
9f2ebf
         SSSD_RESPONDER_OPTS
9f2ebf
         POPT_TABLEEND
9f2ebf
@@ -213,6 +215,8 @@ int main(int argc, const char *argv[])
9f2ebf
     /* set up things like debug, signals, daemonization, etc... */
9f2ebf
     debug_log_file = "sssd_ssh";
9f2ebf
 
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
+
9f2ebf
     ret = server_setup("sssd[ssh]", 0, uid, gid,
9f2ebf
                        CONFDB_SSH_CONF_ENTRY, &main_ctx);
9f2ebf
     if (ret != EOK) {
9f2ebf
diff --git a/src/responder/sudo/sudosrv.c b/src/responder/sudo/sudosrv.c
9f2ebf
index dca70ea4afc0e6df6d1b1864338c7b1091a98fee..19058321a25022d7704556ec0ef79729db3ac1f2 100644
9f2ebf
--- a/src/responder/sudo/sudosrv.c
9f2ebf
+++ b/src/responder/sudo/sudosrv.c
9f2ebf
@@ -178,6 +178,7 @@ int main(int argc, const char *argv[])
9f2ebf
 {
9f2ebf
     int opt;
9f2ebf
     poptContext pc;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
     struct main_context *main_ctx;
9f2ebf
     int ret;
9f2ebf
     uid_t uid;
9f2ebf
@@ -186,6 +187,7 @@ int main(int argc, const char *argv[])
9f2ebf
     struct poptOption long_options[] = {
9f2ebf
         POPT_AUTOHELP
9f2ebf
         SSSD_MAIN_OPTS
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         SSSD_SERVER_OPTS(uid, gid)
9f2ebf
         SSSD_RESPONDER_OPTS
9f2ebf
         POPT_TABLEEND
9f2ebf
@@ -214,6 +216,8 @@ int main(int argc, const char *argv[])
9f2ebf
     /* set up things like debug, signals, daemonization, etc... */
9f2ebf
     debug_log_file = "sssd_sudo";
9f2ebf
 
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
+
9f2ebf
     ret = server_setup("sssd[sudo]", 0, uid, gid, CONFDB_SUDO_CONF_ENTRY,
9f2ebf
                        &main_ctx);
9f2ebf
     if (ret != EOK) {
9f2ebf
diff --git a/src/tests/cmocka/dummy_child.c b/src/tests/cmocka/dummy_child.c
9f2ebf
index bcaa9455037a0604422750bf7cc719a25cef4a99..811cb40490c89c4250401e0d8d3e9d1c277f57af 100644
9f2ebf
--- a/src/tests/cmocka/dummy_child.c
9f2ebf
+++ b/src/tests/cmocka/dummy_child.c
9f2ebf
@@ -34,6 +34,7 @@ int main(int argc, const char *argv[])
9f2ebf
 {
9f2ebf
     int opt;
9f2ebf
     int debug_fd = -1;
9f2ebf
+    char *opt_logger = NULL;
9f2ebf
     poptContext pc;
9f2ebf
     ssize_t len;
9f2ebf
     ssize_t written;
9f2ebf
@@ -55,6 +56,7 @@ int main(int argc, const char *argv[])
9f2ebf
          _("An open file descriptor for the debug logs"), NULL},
9f2ebf
         {"debug-to-stderr", 0, POPT_ARG_NONE | POPT_ARGFLAG_DOC_HIDDEN, &debug_to_stderr, 0, \
9f2ebf
          _("Send the debug output to stderr directly."), NULL },
9f2ebf
+        SSSD_LOGGER_OPTS
9f2ebf
         {"guitar", 0, POPT_ARG_STRING, &guitar, 0, _("Who plays guitar"), NULL },
9f2ebf
         {"drums", 0, POPT_ARG_STRING, &drums, 0, _("Who plays drums"), NULL },
9f2ebf
         POPT_TABLEEND
9f2ebf
@@ -76,6 +78,8 @@ int main(int argc, const char *argv[])
9f2ebf
     }
9f2ebf
     poptFreeContext(pc);
9f2ebf
 
9f2ebf
+    sss_set_logger(opt_logger);
9f2ebf
+
9f2ebf
     action = getenv("TEST_CHILD_ACTION");
9f2ebf
     if (action) {
9f2ebf
         if (strcasecmp(action, "check_extra_args") == 0) {
9f2ebf
diff --git a/src/tests/debug-tests.c b/src/tests/debug-tests.c
9f2ebf
index d904d7eb8b5418608023faca0d62067f3106d23b..1446ec0474ab4bf72e66b58831fef59defd7be76 100644
9f2ebf
--- a/src/tests/debug-tests.c
9f2ebf
+++ b/src/tests/debug-tests.c
9f2ebf
@@ -343,6 +343,7 @@ START_TEST(test_debug_is_set_single_no_timestamp)
9f2ebf
     debug_microseconds = 0;
9f2ebf
     debug_to_file = 1;
9f2ebf
     debug_prg_name = "sssd";
9f2ebf
+    sss_set_logger(sss_logger_str[FILES_LOGGER]);
9f2ebf
 
9f2ebf
     for (i = 0; i <= 9; i++) {
9f2ebf
         debug_level = levels[i];
9f2ebf
@@ -385,6 +386,8 @@ START_TEST(test_debug_is_set_single_timestamp)
9f2ebf
     debug_microseconds = 0;
9f2ebf
     debug_to_file = 1;
9f2ebf
     debug_prg_name = "sssd";
9f2ebf
+    sss_set_logger(sss_logger_str[FILES_LOGGER]);
9f2ebf
+
9f2ebf
 
9f2ebf
     for (i = 0; i <= 9; i++) {
9f2ebf
         debug_level = levels[i];
9f2ebf
@@ -432,6 +435,8 @@ START_TEST(test_debug_is_set_single_timestamp_microseconds)
9f2ebf
     debug_microseconds = 1;
9f2ebf
     debug_to_file = 1;
9f2ebf
     debug_prg_name = "sssd";
9f2ebf
+    sss_set_logger(sss_logger_str[FILES_LOGGER]);
9f2ebf
+
9f2ebf
 
9f2ebf
     for (i = 0; i <= 9; i++) {
9f2ebf
         debug_level = levels[i];
9f2ebf
@@ -480,6 +485,8 @@ START_TEST(test_debug_is_notset_no_timestamp)
9f2ebf
     debug_microseconds = 0;
9f2ebf
     debug_to_file = 1;
9f2ebf
     debug_prg_name = "sssd";
9f2ebf
+    sss_set_logger(sss_logger_str[FILES_LOGGER]);
9f2ebf
+
9f2ebf
 
9f2ebf
     for (i = 0; i <= 9; i++) {
9f2ebf
         debug_level = all_set & ~levels[i];
9f2ebf
@@ -525,6 +532,8 @@ START_TEST(test_debug_is_notset_timestamp)
9f2ebf
     debug_microseconds = 0;
9f2ebf
     debug_to_file = 1;
9f2ebf
     debug_prg_name = "sssd";
9f2ebf
+    sss_set_logger(sss_logger_str[FILES_LOGGER]);
9f2ebf
+
9f2ebf
 
9f2ebf
     for (i = 0; i <= 9; i++) {
9f2ebf
         debug_level = all_set & ~levels[i];
9f2ebf
@@ -570,6 +579,7 @@ START_TEST(test_debug_is_notset_timestamp_microseconds)
9f2ebf
     debug_microseconds = 1;
9f2ebf
     debug_to_file = 1;
9f2ebf
     debug_prg_name = "sssd";
9f2ebf
+    sss_set_logger(sss_logger_str[FILES_LOGGER]);
9f2ebf
 
9f2ebf
     for (i = 0; i <= 9; i++) {
9f2ebf
         debug_level = all_set & ~levels[i];
9f2ebf
diff --git a/src/util/child_common.c b/src/util/child_common.c
9f2ebf
index b300d84bf432608db96de36e04637b5fb115212e..dc070f26446305e07cbb34edd1e4d72db72aedc5 100644
9f2ebf
--- a/src/util/child_common.c
9f2ebf
+++ b/src/util/child_common.c
9f2ebf
@@ -676,7 +676,7 @@ static errno_t prepare_child_argv(TALLOC_CTX *mem_ctx,
9f2ebf
         }
9f2ebf
 
9f2ebf
         if (child_debug_stderr) {
9f2ebf
-            argv[--argc] = talloc_strdup(argv, "--debug-to-stderr");
9f2ebf
+            argv[--argc] = talloc_strdup(argv, "--logger=stderr");
9f2ebf
             if (argv[argc] == NULL) {
9f2ebf
                 ret = ENOMEM;
9f2ebf
                 goto fail;
9f2ebf
diff --git a/src/util/debug.c b/src/util/debug.c
9f2ebf
index 4e469447e5ab8aa89cd57bcd6d00269875a12bc6..30801fce7c27b115d1cafd4ed826a57c7d444a72 100644
9f2ebf
--- a/src/util/debug.c
9f2ebf
+++ b/src/util/debug.c
9f2ebf
@@ -277,7 +277,7 @@ void sss_vdebug_fn(const char *file,
9f2ebf
     errno_t ret;
9f2ebf
     va_list ap_fallback;
9f2ebf
 
9f2ebf
-    if (!debug_file && !debug_to_stderr) {
9f2ebf
+    if (sss_logger == JOURNALD_LOGGER) {
9f2ebf
         /* If we are not outputting logs to files, we should be sending them
9f2ebf
          * to journald.
9f2ebf
          * NOTE: on modern systems, this is where stdout/stderr will end up
9f2ebf
@@ -470,7 +470,7 @@ int rotate_debug_files(void)
9f2ebf
     int ret;
9f2ebf
     errno_t error;
9f2ebf
 
9f2ebf
-    if (!debug_to_file) return EOK;
9f2ebf
+    if (sss_logger != FILES_LOGGER) return EOK;
9f2ebf
 
9f2ebf
     do {
9f2ebf
         error = 0;
9f2ebf
diff --git a/src/util/server.c b/src/util/server.c
9f2ebf
index 0046c9737bc0d9aea7be59b4fed5e0f8930ff66e..26b8b27f0e5c8524520a2d4774e90fd6cb32bf7a 100644
9f2ebf
--- a/src/util/server.c
9f2ebf
+++ b/src/util/server.c
9f2ebf
@@ -455,7 +455,7 @@ int server_setup(const char *name, int flags,
9f2ebf
     char *conf_db;
9f2ebf
     int ret = EOK;
9f2ebf
     bool dt;
9f2ebf
-    bool dl;
9f2ebf
+    bool dl = false;
9f2ebf
     bool dm;
9f2ebf
     struct tevent_signal *tes;
9f2ebf
     struct logrotate_ctx *lctx;
9f2ebf
@@ -637,16 +637,18 @@ int server_setup(const char *name, int flags,
9f2ebf
     }
9f2ebf
 
9f2ebf
     /* same for debug to file */
9f2ebf
-    dl = (debug_to_file != 0);
9f2ebf
     ret = confdb_get_bool(ctx->confdb_ctx, conf_entry,
9f2ebf
                           CONFDB_SERVICE_DEBUG_TO_FILES,
9f2ebf
-                          dl, &dl);
9f2ebf
+                          false, &dl);
9f2ebf
     if (ret != EOK) {
9f2ebf
         DEBUG(SSSDBG_FATAL_FAILURE, "Error reading from confdb (%d) [%s]\n",
9f2ebf
                                      ret, strerror(ret));
9f2ebf
         return ret;
9f2ebf
     }
9f2ebf
-    if (dl) debug_to_file = 1;
9f2ebf
+    if (dl) {
9f2ebf
+        debug_to_file = 1;
9f2ebf
+        sss_set_logger(sss_logger_str[FILES_LOGGER]);
9f2ebf
+    }
9f2ebf
 
9f2ebf
     /* before opening the log file set up log rotation */
9f2ebf
     lctx = talloc_zero(ctx, struct logrotate_ctx);
9f2ebf
@@ -662,7 +664,7 @@ int server_setup(const char *name, int flags,
9f2ebf
     }
9f2ebf
 
9f2ebf
     /* open log file if told so */
9f2ebf
-    if (debug_to_file) {
9f2ebf
+    if (sss_logger == FILES_LOGGER) {
9f2ebf
         ret = open_debug_file();
9f2ebf
         if (ret != EOK) {
9f2ebf
             DEBUG(SSSDBG_FATAL_FAILURE, "Error setting up logging (%d) "
9f2ebf
-- 
9f2ebf
2.13.5
9f2ebf