login-settings.c revision ec892704d6a9625195fbb4087edeb04bc463d4ff
2e37d45867d081db150ab78dad303b9077aea24fTimo Sirainen/* Copyright (c) 2005-2011 Dovecot authors, see the included COPYING file */
d63b4241643b6014d49ff356f14e0f3ee43068a8Timo Sirainenstatic bool login_settings_check(void *_set, pool_t pool, const char **error_r);
a64adf62fa33f2463a86f990217b0c9078531a40Timo Sirainen { type, #name, offsetof(struct login_settings, name), NULL }
7744586e3e0fd60158abfbb03a233d3bd8d6c48bTimo Sirainenstatic const struct setting_define login_setting_defines[] = {
7744586e3e0fd60158abfbb03a233d3bd8d6c48bTimo Sirainenstatic const struct login_settings login_default_settings = {
71834d0736d031ccba629fcae62ba71c56e6b4edTimo Sirainen .login_log_format_elements = "user=<%u> method=%m rip=%r lip=%l mpid=%e %c",
7bafda1813454621e03615e83d55bccfa7cc56bdTimo Sirainen .ssl_cipher_list = "ALL:!LOW:!SSLv2:!EXP:!aNULL",
7744586e3e0fd60158abfbb03a233d3bd8d6c48bTimo Sirainenconst struct setting_parser_info login_setting_parser_info = {
f059a046515f4b2b15a6c2a10a6f12f6166e39a5Timo Sirainenstatic const struct setting_parser_info *default_login_set_roots[] = {
f059a046515f4b2b15a6c2a10a6f12f6166e39a5Timo Sirainenconst struct setting_parser_info **login_set_roots = default_login_set_roots;
5d03d9f439e41c90215a3c938ffebe4c2a8ae257Timo Sirainenstatic struct master_service_settings_cache *set_cache;
b215a8a123623782554a83f3025ef4e771bd8f01Timo Sirainen/* <settings checks> */
b215a8a123623782554a83f3025ef4e771bd8f01Timo Sirainenstatic int ssl_settings_check(void *_set ATTR_UNUSED, const char **error_r)
ce8a6f53ea3ce91b759a54b771e1779564de19a1Timo Sirainen *error_r = t_strdup_printf("SSL support not compiled in but ssl=%s",
02a0492affdff138f43903c19ca366363923044dTimo Sirainen *error_r = "ssl enabled, but ssl_cert not set";
02a0492affdff138f43903c19ca366363923044dTimo Sirainen *error_r = "ssl enabled, but ssl_key not set";
277c0eea825eec176cddc029af68f5a4d942e16eTimo Sirainen if (set->ssl_verify_client_cert && *set->ssl_ca == '\0') {
277c0eea825eec176cddc029af68f5a4d942e16eTimo Sirainen *error_r = "ssl_verify_client_cert set, but ssl_ca not";
97db4761382024093f441e4bc78ba8b6a056504dTimo Sirainenstatic bool login_settings_check(void *_set, pool_t pool, const char **error_r)
97db4761382024093f441e4bc78ba8b6a056504dTimo Sirainen p_strsplit(pool, set->login_log_format_elements, " ");
a64adf62fa33f2463a86f990217b0c9078531a40Timo Sirainen /* if we require valid cert, make sure we also ask for it */
b215a8a123623782554a83f3025ef4e771bd8f01Timo Sirainen /* disabled */
b215a8a123623782554a83f3025ef4e771bd8f01Timo Sirainen } else if (strcmp(set->ssl, "required") == 0) {
b215a8a123623782554a83f3025ef4e771bd8f01Timo Sirainen *error_r = t_strdup_printf("Unknown ssl setting value: %s",
b215a8a123623782554a83f3025ef4e771bd8f01Timo Sirainen/* </settings checks> */
ed4cdfe5847a6063d5a4684a6a47b17e943922b5Timo Sirainenstatic const struct var_expand_table *
ed4cdfe5847a6063d5a4684a6a47b17e943922b5Timo Sirainenlogin_set_var_expand_table(const struct master_service_settings_input *input)
ed4cdfe5847a6063d5a4684a6a47b17e943922b5Timo Sirainen static struct var_expand_table static_tab[] = {
ed4cdfe5847a6063d5a4684a6a47b17e943922b5Timo Sirainen tab[1].value = net_ip2addr(&input->remote_ip);
5d03d9f439e41c90215a3c938ffebe4c2a8ae257Timo Sirainen unsigned int i, count;
5d03d9f439e41c90215a3c938ffebe4c2a8ae257Timo Sirainen set_cache = master_service_settings_cache_init(master_service,
9b78c0d5e13141f4df6c6e483f854e5acb861288Timo Sirainen if (master_service_settings_cache_read(set_cache, &input, NULL,
d176f84ce5ca2073f4dfbafb457b9c74f6bf0d76Timo Sirainen i_fatal("Error reading configuration: %s", error);
5d03d9f439e41c90215a3c938ffebe4c2a8ae257Timo Sirainen cache_sets = settings_parser_get_list(parser) + 1;
9d6307357b77c1006fff39f324d4f536d456b170Timo Sirainen for (count = 0; input.roots[count] != NULL; count++) ;
5d03d9f439e41c90215a3c938ffebe4c2a8ae257Timo Sirainen for (i = 0; i < count; i++) {
5d03d9f439e41c90215a3c938ffebe4c2a8ae257Timo Sirainen sets[i] = settings_dup(input.roots[i], cache_sets[i], pool);
f059a046515f4b2b15a6c2a10a6f12f6166e39a5Timo Sirainen if (!settings_check(input.roots[i], pool, sets[i], &error)) {
f059a046515f4b2b15a6c2a10a6f12f6166e39a5Timo Sirainen const char *name = input.roots[i]->module_name;
ed4cdfe5847a6063d5a4684a6a47b17e943922b5Timo Sirainen settings_var_expand(&login_setting_parser_info, sets[0], pool,