X-Git-Url: http://www.privoxy.org/gitweb/?p=privoxy.git;a=blobdiff_plain;f=loadcfg.c;h=55874d57fe151e288d20fcb1ababac3a3ebb8c46;hp=31463db17ff1d696945a2405b537032ccb4dc373;hb=c5b8825873c2e08323d2521afab84a959bfa7248;hpb=767afb7f5d7062d75385b9ab3afdad47d0249a39 diff --git a/loadcfg.c b/loadcfg.c index 31463db1..55874d57 100644 --- a/loadcfg.c +++ b/loadcfg.c @@ -121,7 +121,7 @@ static struct file_list *current_configfile = NULL; /* * This takes the "cryptic" hash of each keyword and aliases them to * something a little more readable. This also makes changing the - * hash values easier if they should change or the hash algorthm changes. + * hash values easier if they should change or the hash algorithm changes. * Use the included "hash" program to find out what the hash will be * for any string supplied on the command line. (Or just put it in the * config file and read the number from the error message in the log). @@ -239,11 +239,9 @@ static void unload_configfile (void * data) while (cur_fwd != NULL) { struct forward_spec * next_fwd = cur_fwd->next; - free_pattern_spec(cur_fwd->url); - freez(cur_fwd->gateway_host); - freez(cur_fwd->forward_host); - free(cur_fwd); + unload_forward_spec(cur_fwd); + cur_fwd = next_fwd; } config->forward = NULL; @@ -273,12 +271,13 @@ static void unload_configfile (void * data) list_remove_all(config->ordered_client_headers); freez(config->admin_address); + freez(config->cors_allowed_origin); freez(config->proxy_info_url); freez(config->proxy_args); freez(config->usermanual); freez(config->trusted_cgi_referrer); -#ifdef FEATURE_HTTPS_FILTERING +#ifdef FEATURE_HTTPS_INSPECTION freez(config->ca_password); freez(config->ca_directory); freez(config->ca_cert_file); @@ -584,7 +583,7 @@ struct configuration_spec * load_config(void) unsigned long linenum = 0; int i; char *logfile = NULL; -#ifdef FEATURE_HTTPS_FILTERING +#ifdef FEATURE_HTTPS_INSPECTION char *ca_cert_file = NULL; char *ca_key_file = NULL; char *ca_directory = NULL; @@ -635,7 +634,7 @@ struct configuration_spec * load_config(void) config->usermanual = strdup_or_die(USER_MANUAL_URL); config->proxy_args = strdup_or_die(""); config->forwarded_connect_retries = 0; -#ifdef FEATURE_HTTPS_FILTERING +#ifdef FEATURE_HTTPS_INSPECTION config->ca_password = strdup(""); ca_cert_file = strdup("cacert.crt"); ca_key_file = strdup("cakey.pem"); @@ -1733,7 +1732,7 @@ struct configuration_spec * load_config(void) config->usermanual = strdup_or_die(arg); break; -#ifdef FEATURE_HTTPS_FILTERING +#ifdef FEATURE_HTTPS_INSPECTION /* ************************************************************************* * ca private key file password * *************************************************************************/ @@ -1746,6 +1745,7 @@ struct configuration_spec * load_config(void) * ca-directory directory * *************************************************************************/ case hash_ca_directory: + freez(ca_directory); ca_directory = make_path(NULL, arg); if (NULL == ca_directory) @@ -1760,6 +1760,7 @@ struct configuration_spec * load_config(void) * In ca dir by default * *************************************************************************/ case hash_ca_cert_file: + freez(ca_cert_file); ca_cert_file = make_path(config->ca_directory, arg); if (NULL == ca_cert_file) @@ -1774,6 +1775,7 @@ struct configuration_spec * load_config(void) * In ca dir by default * *************************************************************************/ case hash_ca_key_file: + freez(ca_key_file); ca_key_file = make_path(config->ca_directory, arg); if (NULL == ca_key_file) @@ -1787,6 +1789,7 @@ struct configuration_spec * load_config(void) * certificate-directory directory * *************************************************************************/ case hash_certificate_directory: + freez(certificate_directory); certificate_directory = make_path(NULL, arg); if (NULL == certificate_directory) @@ -1801,6 +1804,7 @@ struct configuration_spec * load_config(void) * trusted CAs file name trusted-cas-file * *************************************************************************/ case hash_trusted_cas_file: + freez(trusted_cas_file); trusted_cas_file = make_path(config->ca_directory, arg); if (NULL == trusted_cas_file) @@ -1986,7 +1990,7 @@ struct configuration_spec * load_config(void) } } -#ifdef FEATURE_HTTPS_FILTERING +#ifdef FEATURE_HTTPS_INSPECTION /* * Setting SSL parameters from loaded values into structures */