Remove output on stdout by default on daemon startuip
This commit is contained in:
parent
cca057908c
commit
1e13533048
@ -304,7 +304,7 @@ internal_config_read_logging(int file,
|
|||||||
lc->console_level = LOG_LEVEL_INFO;
|
lc->console_level = LOG_LEVEL_INFO;
|
||||||
lc->enable_syslog = 0;
|
lc->enable_syslog = 0;
|
||||||
lc->syslog_level = LOG_LEVEL_INFO;
|
lc->syslog_level = LOG_LEVEL_INFO;
|
||||||
lc->dump_on_start = 1;
|
lc->dump_on_start = 0;
|
||||||
lc->enable_pid = 0;
|
lc->enable_pid = 0;
|
||||||
|
|
||||||
g_snprintf(section_name, 511, "%s%s", section_prefix, SESMAN_CFG_LOGGING);
|
g_snprintf(section_name, 511, "%s%s", section_prefix, SESMAN_CFG_LOGGING);
|
||||||
@ -616,7 +616,6 @@ log_config_init_for_console(enum logLevels lvl, const char *override_name)
|
|||||||
{
|
{
|
||||||
config->console_level = lvl;
|
config->console_level = lvl;
|
||||||
}
|
}
|
||||||
config->dump_on_start = 0; /* Don't need dump for console only */
|
|
||||||
}
|
}
|
||||||
return config;
|
return config;
|
||||||
}
|
}
|
||||||
@ -721,7 +720,8 @@ log_start_from_param(const struct log_config *src_log_config)
|
|||||||
* @return 0 on success
|
* @return 0 on success
|
||||||
*/
|
*/
|
||||||
enum logReturns
|
enum logReturns
|
||||||
log_start(const char *iniFile, const char *applicationName)
|
log_start(const char *iniFile, const char *applicationName,
|
||||||
|
bool_t dump_on_start)
|
||||||
{
|
{
|
||||||
enum logReturns ret = LOG_GENERAL_ERROR;
|
enum logReturns ret = LOG_GENERAL_ERROR;
|
||||||
struct log_config *config;
|
struct log_config *config;
|
||||||
@ -730,6 +730,7 @@ log_start(const char *iniFile, const char *applicationName)
|
|||||||
|
|
||||||
if (config != NULL)
|
if (config != NULL)
|
||||||
{
|
{
|
||||||
|
config->dump_on_start = dump_on_start;
|
||||||
ret = log_start_from_param(config);
|
ret = log_start_from_param(config);
|
||||||
log_config_free(config);
|
log_config_free(config);
|
||||||
|
|
||||||
|
@ -263,11 +263,15 @@ internal_log_location_overrides_level(const char *function_name,
|
|||||||
* This function initialize the log facilities according to the configuration
|
* This function initialize the log facilities according to the configuration
|
||||||
* file, that is described by the in parameter.
|
* file, that is described by the in parameter.
|
||||||
* @param iniFile
|
* @param iniFile
|
||||||
* @param applicationName, the name that is used in the log for the running application
|
* @param applicationName the name that is used in the log for the running
|
||||||
|
* application
|
||||||
|
* @param dump_on_start Whether to dump the config on stdout before
|
||||||
|
* logging is started
|
||||||
* @return LOG_STARTUP_OK on success
|
* @return LOG_STARTUP_OK on success
|
||||||
*/
|
*/
|
||||||
enum logReturns
|
enum logReturns
|
||||||
log_start(const char *iniFile, const char *applicationName);
|
log_start(const char *iniFile, const char *applicationName,
|
||||||
|
bool_t dump_on_start);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An alternative log_start where the caller gives the params directly.
|
* An alternative log_start where the caller gives the params directly.
|
||||||
|
@ -13,7 +13,7 @@ xrdp\-sesman \- \fBxrdp\fR(8) session manager
|
|||||||
\-\-version
|
\-\-version
|
||||||
.br
|
.br
|
||||||
.B xrdp\-sesman
|
.B xrdp\-sesman
|
||||||
[ \-\-nodaemon ] [ --config /path/to/sesman.ini ]
|
[\-\-nodaemon] [\-\-dump\-config] [\-\-config /path/to/sesman.ini]
|
||||||
|
|
||||||
.SH "DESCRIPTION"
|
.SH "DESCRIPTION"
|
||||||
\fBxrdp\-sesman\fR is \fBxrdp\fR(8) session manager.
|
\fBxrdp\-sesman\fR is \fBxrdp\fR(8) session manager.
|
||||||
@ -34,6 +34,10 @@ Output version information and exit.
|
|||||||
\fB\-n\fR, \fB\-\-nodaemon\fR
|
\fB\-n\fR, \fB\-\-nodaemon\fR
|
||||||
Starts \fBxrdp\-sesman\fR in foreground instead of starting it as a daemon.
|
Starts \fBxrdp\-sesman\fR in foreground instead of starting it as a daemon.
|
||||||
.TP
|
.TP
|
||||||
|
\fB\-\-dump\-config\fR
|
||||||
|
Print the configuration on stdout before starting the daemon.
|
||||||
|
The default is not to do this.
|
||||||
|
.TP
|
||||||
\fB\-c\fR, \fB\-\-config\fR
|
\fB\-c\fR, \fB\-\-config\fR
|
||||||
Specify a path to a different \fIsesman.ini\fR file. This option is intended
|
Specify a path to a different \fIsesman.ini\fR file. This option is intended
|
||||||
to be used primarily for testing or for unusual configurations.
|
to be used primarily for testing or for unusual configurations.
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
\-\-version
|
\-\-version
|
||||||
.br
|
.br
|
||||||
.B xrdp
|
.B xrdp
|
||||||
[ \-\-nodaemon ] [ --port port ] [ --fork ] [ --config /path/to/xrdp.ini ]
|
[\-\-nodaemon] [\-\-port port] [\-\-fork] [\-\-dump\-config] [\-\-config /path/to/xrdp.ini]
|
||||||
|
|
||||||
.SH "DESCRIPTION"
|
.SH "DESCRIPTION"
|
||||||
\fBxrdp\fR is a Remote Desktop Protocol (RDP) Server.
|
\fBxrdp\fR is a Remote Desktop Protocol (RDP) Server.
|
||||||
@ -45,6 +45,10 @@ Fork a new process on a new connection. If not enabled, use a new thread
|
|||||||
for every connection. This overrides \fIfork\fR setting in
|
for every connection. This overrides \fIfork\fR setting in
|
||||||
\fIxrdp.ini\fR file.
|
\fIxrdp.ini\fR file.
|
||||||
.TP
|
.TP
|
||||||
|
\fB\-\-dump\-config\fR
|
||||||
|
Print the configuration on stdout before starting the daemon.
|
||||||
|
The default is not to do this.
|
||||||
|
.TP
|
||||||
\fB\-c\fR, \fB\-\-config\fR
|
\fB\-c\fR, \fB\-\-config\fR
|
||||||
Specify a path to a different \fIxrdp.ini\fR file. This option is intended
|
Specify a path to a different \fIxrdp.ini\fR file. This option is intended
|
||||||
to be used primarily for testing or for unusual configurations.
|
to be used primarily for testing or for unusual configurations.
|
||||||
|
@ -41,6 +41,7 @@ struct sesman_startup_params
|
|||||||
int no_daemon;
|
int no_daemon;
|
||||||
int help;
|
int help;
|
||||||
int version;
|
int version;
|
||||||
|
int dump_config;
|
||||||
};
|
};
|
||||||
|
|
||||||
int g_sck;
|
int g_sck;
|
||||||
@ -127,6 +128,10 @@ sesman_process_params(int argc, char **argv,
|
|||||||
{
|
{
|
||||||
startup_params->version = 1;
|
startup_params->version = 1;
|
||||||
}
|
}
|
||||||
|
else if (nocase_matches(option, "--dump-config", NULL))
|
||||||
|
{
|
||||||
|
startup_params->dump_config = 1;
|
||||||
|
}
|
||||||
else if (nocase_matches(option, "-c", "--config", NULL))
|
else if (nocase_matches(option, "-c", "--config", NULL))
|
||||||
{
|
{
|
||||||
index++;
|
index++;
|
||||||
@ -310,6 +315,7 @@ print_help(void)
|
|||||||
g_printf(" -v, --version show version\n");
|
g_printf(" -v, --version show version\n");
|
||||||
g_printf(" -n, --nodaemon don't fork into background\n");
|
g_printf(" -n, --nodaemon don't fork into background\n");
|
||||||
g_printf(" -c, --config specify new path to sesman.ini\n");
|
g_printf(" -c, --config specify new path to sesman.ini\n");
|
||||||
|
g_writeln(" --dump-config display config on stdout on startup");
|
||||||
g_deinit();
|
g_deinit();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -415,12 +421,6 @@ main(int argc, char **argv)
|
|||||||
g_exit(kill_running_sesman(pid_file));
|
g_exit(kill_running_sesman(pid_file));
|
||||||
}
|
}
|
||||||
|
|
||||||
daemon = !startup_params.no_daemon;
|
|
||||||
if (!daemon)
|
|
||||||
{
|
|
||||||
g_printf("starting sesman in foreground...\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (g_file_exist(pid_file))
|
if (g_file_exist(pid_file))
|
||||||
{
|
{
|
||||||
g_printf("xrdp-sesman is already running.\n");
|
g_printf("xrdp-sesman is already running.\n");
|
||||||
@ -440,15 +440,14 @@ main(int argc, char **argv)
|
|||||||
g_exit(1);
|
g_exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* not to spit on the console, show config summary only when running
|
if (startup_params.dump_config)
|
||||||
* in foreground */
|
|
||||||
if (!daemon)
|
|
||||||
{
|
{
|
||||||
config_dump(g_cfg);
|
config_dump(g_cfg);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* starting logging subsystem */
|
/* starting logging subsystem */
|
||||||
log_error = log_start(startup_params.sesman_ini, "xrdp-sesman");
|
log_error = log_start(startup_params.sesman_ini, "xrdp-sesman",
|
||||||
|
startup_params.dump_config);
|
||||||
|
|
||||||
if (log_error != LOG_STARTUP_OK)
|
if (log_error != LOG_STARTUP_OK)
|
||||||
{
|
{
|
||||||
@ -481,6 +480,7 @@ main(int argc, char **argv)
|
|||||||
LOG(LOG_LEVEL_TRACE, " reconnect_sh = %s", g_cfg->reconnect_sh);
|
LOG(LOG_LEVEL_TRACE, " reconnect_sh = %s", g_cfg->reconnect_sh);
|
||||||
LOG(LOG_LEVEL_TRACE, " auth_file_path = %s", g_cfg->auth_file_path);
|
LOG(LOG_LEVEL_TRACE, " auth_file_path = %s", g_cfg->auth_file_path);
|
||||||
|
|
||||||
|
daemon = !startup_params.no_daemon;
|
||||||
if (daemon)
|
if (daemon)
|
||||||
{
|
{
|
||||||
/* not to spit on the console, shut up stdout/stderr before anything's logged */
|
/* not to spit on the console, shut up stdout/stderr before anything's logged */
|
||||||
|
@ -92,7 +92,7 @@ sig_sesman_reload_cfg(int sig)
|
|||||||
g_cfg = cfg;
|
g_cfg = cfg;
|
||||||
|
|
||||||
/* start again logging subsystem */
|
/* start again logging subsystem */
|
||||||
error = log_start(g_cfg->sesman_ini, "xrdp-sesman");
|
error = log_start(g_cfg->sesman_ini, "xrdp-sesman", 0);
|
||||||
|
|
||||||
if (error != LOG_STARTUP_OK)
|
if (error != LOG_STARTUP_OK)
|
||||||
{
|
{
|
||||||
|
10
xrdp/xrdp.c
10
xrdp/xrdp.c
@ -80,7 +80,8 @@ print_help(void)
|
|||||||
g_writeln(" -n, --nodaemon don't fork into background");
|
g_writeln(" -n, --nodaemon don't fork into background");
|
||||||
g_writeln(" -p, --port tcp listen port");
|
g_writeln(" -p, --port tcp listen port");
|
||||||
g_writeln(" -f, --fork fork on new connection");
|
g_writeln(" -f, --fork fork on new connection");
|
||||||
g_writeln(" -c, --config Specify new path to xrdp.ini");
|
g_writeln(" -c, --config specify new path to xrdp.ini");
|
||||||
|
g_writeln(" --dump-config display config on stdout on startup");
|
||||||
}
|
}
|
||||||
|
|
||||||
/*****************************************************************************/
|
/*****************************************************************************/
|
||||||
@ -361,6 +362,10 @@ xrdp_process_params(int argc, char **argv,
|
|||||||
startup_params->fork = 1;
|
startup_params->fork = 1;
|
||||||
g_writeln("--fork parameter found, ini override");
|
g_writeln("--fork parameter found, ini override");
|
||||||
}
|
}
|
||||||
|
else if (nocase_matches(option, "--dump-config", NULL))
|
||||||
|
{
|
||||||
|
startup_params->dump_config = 1;
|
||||||
|
}
|
||||||
else if (nocase_matches(option, "-c", "--config", NULL))
|
else if (nocase_matches(option, "-c", "--config", NULL))
|
||||||
{
|
{
|
||||||
index++;
|
index++;
|
||||||
@ -536,7 +541,8 @@ main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* starting logging subsystem */
|
/* starting logging subsystem */
|
||||||
error = log_start(startup_params.xrdp_ini, "xrdp");
|
error = log_start(startup_params.xrdp_ini, "xrdp",
|
||||||
|
startup_params.dump_config);
|
||||||
|
|
||||||
if (error != LOG_STARTUP_OK)
|
if (error != LOG_STARTUP_OK)
|
||||||
{
|
{
|
||||||
|
@ -539,6 +539,7 @@ struct xrdp_startup_params
|
|||||||
int help;
|
int help;
|
||||||
int version;
|
int version;
|
||||||
int fork;
|
int fork;
|
||||||
|
int dump_config;
|
||||||
int tcp_send_buffer_bytes;
|
int tcp_send_buffer_bytes;
|
||||||
int tcp_recv_buffer_bytes;
|
int tcp_recv_buffer_bytes;
|
||||||
int tcp_nodelay;
|
int tcp_nodelay;
|
||||||
|
Loading…
Reference in New Issue
Block a user