X-Git-Url: http://www.privoxy.org/gitweb/%40user-manual%40%40actions-help-prefix%40HIDE-CONTENT-DISPOSITION?a=blobdiff_plain;f=urlmatch.c;h=98cecf2cb155370240e18d1c0725aed5f06643cf;hb=ab4ae55aa26d51c2820e3e588937df2aeeba2e91;hp=2f7ee451bc44b4161777efc3a8246c69afbbf895;hpb=b0829aefd612a2211ac727294f36efa256a1beb3;p=privoxy.git diff --git a/urlmatch.c b/urlmatch.c index 2f7ee451..98cecf2c 100644 --- a/urlmatch.c +++ b/urlmatch.c @@ -1,4 +1,4 @@ -const char urlmatch_rcs[] = "$Id: urlmatch.c,v 1.40 2008/04/23 16:12:28 fabiankeil Exp $"; +const char urlmatch_rcs[] = "$Id: urlmatch.c,v 1.43 2008/05/04 13:30:55 fabiankeil Exp $"; /********************************************************************* * * File : $Source: /cvsroot/ijbswa/current/urlmatch.c,v $ @@ -33,6 +33,17 @@ const char urlmatch_rcs[] = "$Id: urlmatch.c,v 1.40 2008/04/23 16:12:28 fabianke * * Revisions : * $Log: urlmatch.c,v $ + * Revision 1.43 2008/05/04 13:30:55 fabiankeil + * Streamline parse_http_url()'s prototype. + * + * Revision 1.42 2008/05/04 13:24:16 fabiankeil + * If the method isn't CONNECT, reject URLs without protocol. + * + * Revision 1.41 2008/05/02 09:51:34 fabiankeil + * In parse_http_url(), don't muck around with values + * that are none of its business: require an initialized + * http structure and never unset http->ssl. + * * Revision 1.40 2008/04/23 16:12:28 fabiankeil * Free with freez(). * @@ -363,7 +374,8 @@ jb_err init_domain_components(struct http_request *http) * 1 : url = URL (or is it URI?) to break down * 2 : http = pointer to the http structure to hold elements. * Must be initialized with valid values (like NULLs). - * 3 : csp = Current client state (buffers, headers, etc...) + * 3 : require_protocol = Whether or not URLs without + * protocol are acceptable. * * Returns : JB_ERR_OK on success * JB_ERR_MEMORY on out of memory @@ -371,9 +383,7 @@ jb_err init_domain_components(struct http_request *http) * or >100 domains deep. * *********************************************************************/ -jb_err parse_http_url(const char * url, - struct http_request *http, - const struct client_state *csp) +jb_err parse_http_url(const char *url, struct http_request *http, int require_protocol) { int host_available = 1; /* A proxy can dream. */ @@ -443,6 +453,11 @@ jb_err parse_http_url(const char * url, http->host = NULL; host_available = 0; } + else if (require_protocol) + { + freez(buf); + return JB_ERR_PARSE; + } url_path = strchr(url_noproto, '/'); if (url_path != NULL) @@ -656,7 +671,9 @@ jb_err parse_http_request(const char *req, return JB_ERR_PARSE; } - err = parse_http_url(v[1], http, csp); + http->ssl = !strcmpic(v[0], "CONNECT"); + + err = parse_http_url(v[1], http, !http->ssl); if (err) { freez(buf); @@ -666,7 +683,6 @@ jb_err parse_http_request(const char *req, /* * Copy the details into the structure */ - http->ssl = !strcmpic(v[0], "CONNECT"); http->cmd = strdup(req); http->gpc = strdup(v[0]); http->ver = strdup(v[2]);