#ifndef MASTER_SERVICE_SETTINGS_H
#define MASTER_SERVICE_SETTINGS_H
#include "net.h"
struct setting_parser_info;
struct setting_parser_context;
struct master_service;
struct master_service_settings {
const char *base_dir;
const char *state_dir;
const char *log_path;
const char *info_log_path;
const char *debug_log_path;
const char *log_timestamp;
const char *log_debug;
const char *syslog_facility;
const char *import_environment;
const char *stats_writer_socket_path;
bool version_ignore;
bool shutdown_clients;
bool verbose_proctitle;
const char *haproxy_trusted_networks;
unsigned int haproxy_timeout;
};
struct master_service_settings_input {
const char *config_path;
bool preserve_environment;
bool preserve_user;
bool preserve_home;
bool never_exec;
bool use_sysexits;
bool parse_full_config;
const char *module;
const char *service;
const char *username;
const char *local_name;
};
struct master_service_settings_output {
/* if service was not given for lookup, this contains names of services
that have more specific settings */
const char *const *specific_services;
/* some settings for this service (or if service was not given,
(but this lookup didn't necessarily return any of them). */
/* returned settings contain settings specific to given
/* Config couldn't be read because we don't have enough permissions.
The process probably should be restarted and the settings read
before dropping privileges. */
};
extern const struct setting_parser_info master_service_setting_parser_info;
/* Try to open the config socket if it's going to be needed later by
master_service_settings_read*() */
const struct master_service_settings_input *input,
struct master_service_settings_output *output_r,
const char **error_r);
const struct setting_parser_info **roots,
/* destroy settings parser and clear service's set_pool, so that
master_service_settings_read*() can be called without freeing memory used
by existing settings structures. */
const struct master_service_settings *
const struct setting_parser_context *set_parser);
struct setting_parser_context *
/* Returns TRUE if -o key=value parameter was used. Setting keys in overrides
and parameter are unaliased before comparing. */
const char *key);
/* Parse log_debug setting into an event filter. */
const char **error_r);
#endif