X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=src%2Fconf.c;h=adc0e1ba335d3859ef18b6cad8dc576a66218775;hb=04e1b924dfa4950e852ead79b2a51a5687bf8b41;hp=38b32852775c1727ffbd4c045515294a42c4f611;hpb=b3dfe6cb6fe0c5311f2d453a5a736ae443bbd5cd;p=umurmur.git diff --git a/src/conf.c b/src/conf.c index 38b3285..adc0e1b 100644 --- a/src/conf.c +++ b/src/conf.c @@ -44,6 +44,7 @@ static config_t configuration; #define DEFAULT_MAX_CLIENTS 10 #define DEFAULT_MAX_BANDWIDTH 48000 #define DEFAULT_BINDPORT 64738 +#define DEFAULT_BAN_LENGTH (60*60) const char defaultconfig[] = DEFAULT_CONFIG; @@ -58,6 +59,21 @@ void Conf_init(const char *conffile) } } +bool_t Conf_ok(const char *conffile) +{ + bool_t rc = true; + config_init(&configuration); + if (conffile == NULL) + conffile = defaultconfig; + if (config_read_file(&configuration, conffile) != CONFIG_TRUE) { + fprintf(stderr, "Error in config file %s line %d: %s\n", conffile, + config_error_line(&configuration), config_error_text(&configuration)); + rc = false; + } + config_destroy(&configuration); + return rc; +} + void Conf_deinit() { config_destroy(&configuration); @@ -102,6 +118,17 @@ const char *getStrConf(param_t param) return ""; } break; + case ADMIN_PASSPHRASE: + setting = config_lookup(&configuration, "admin_password"); + if (!setting) + return ""; + else { + if ((strsetting = config_setting_get_string(setting)) != NULL) + return strsetting; + else + return ""; + } + break; case BINDADDR: setting = config_lookup(&configuration, "bindaddr"); if (!setting) @@ -188,6 +215,14 @@ int getIntConf(param_t param) return config_setting_get_int(setting); } break; + case BAN_LENGTH: + setting = config_lookup(&configuration, "ban_length"); + if (!setting) + return DEFAULT_BAN_LENGTH; + else { + return config_setting_get_int(setting); + } + break; case MAX_BANDWIDTH: setting = config_lookup(&configuration, "max_bandwidth"); if (!setting) @@ -234,6 +269,13 @@ int Conf_getNextChannel(conf_channel_t *chdesc, int index) else chdesc->description = config_setting_get_string(setting); + ret = snprintf(configstr, maxconfig, "channels.[%d].password", index); + setting = config_lookup(&configuration, configstr); + if (ret >= maxconfig || ret < 0 || setting == NULL) /* Optional */ + chdesc->password = NULL; + else + chdesc->password = config_setting_get_string(setting); + ret = snprintf(configstr, maxconfig, "channels.[%d].noenter", index); setting = config_lookup(&configuration, configstr); if (ret >= maxconfig || ret < 0 || setting == NULL) /* Optional */