X-Git-Url: http://www.privoxy.org/gitweb/?p=privoxy.git;a=blobdiff_plain;f=jcc.c;h=cd0f26dcc6e06e74b73a7da3b149a207d07d314b;hp=05c30fabc3428ba974d258233ab005a14d521cd3;hb=bb57ac607f4d412207e73e0d08a0e75e29f2413b;hpb=a31cb2266750220828a56a307c0b492c12c24d2a diff --git a/jcc.c b/jcc.c index 05c30fab..cd0f26dc 100644 --- a/jcc.c +++ b/jcc.c @@ -1,4 +1,4 @@ -const char jcc_rcs[] = "$Id: jcc.c,v 1.14 2001/05/29 20:14:01 joergs Exp $"; +const char jcc_rcs[] = "$Id: jcc.c,v 1.18 2001/06/03 11:03:48 oes Exp $"; /********************************************************************* * * File : $Source: /cvsroot/ijbswa/current/jcc.c,v $ @@ -33,6 +33,73 @@ const char jcc_rcs[] = "$Id: jcc.c,v 1.14 2001/05/29 20:14:01 joergs Exp $"; * * Revisions : * $Log: jcc.c,v $ + * Revision 1.18 2001/06/03 11:03:48 oes + * Makefile/in + * + * introduced cgi.c + * + * actions.c: + * + * adapted to new enlist_unique arg format + * + * conf loadcfg.c + * + * introduced confdir option + * + * filters.c filtrers.h + * + * extracted-CGI relevant stuff + * + * jbsockets.c + * + * filled comment + * + * jcc.c + * + * support for new cgi mechansim + * + * list.c list.h + * + * functions for new list type: "map" + * extended enlist_unique + * + * miscutil.c .h + * introduced bindup() + * + * parsers.c parsers.h + * + * deleted const struct interceptors + * + * pcrs.c + * added FIXME + * + * project.h + * + * added struct map + * added struct http_response + * changes struct interceptors to struct cgi_dispatcher + * moved HTML stuff to cgi.h + * + * re_filterfile: + * + * changed + * + * showargs.c + * NO TIME LEFT + * + * Revision 1.17 2001/06/01 20:07:23 jongfoster + * Now uses action +image-blocker{} rather than config->tinygif + * + * Revision 1.16 2001/06/01 18:49:17 jongfoster + * Replaced "list_share" with "list" - the tiny memory gain was not + * worth the extra complexity. + * + * Revision 1.15 2001/05/31 21:24:47 jongfoster + * Changed "permission" to "action" throughout. + * Removed DEFAULT_USER_AGENT - it must now be specified manually. + * Moved vanilla wafer check into chat(), since we must now + * decide whether or not to add it based on the URL. + * * Revision 1.14 2001/05/29 20:14:01 joergs * AmigaOS bugfix: PCRS needs a lot of stack, stacksize for child threads * increased. @@ -226,6 +293,7 @@ const char jcc_rcs[] = "$Id: jcc.c,v 1.14 2001/05/29 20:14:01 joergs Exp $"; #include "jbsockets.h" #include "gateway.h" #include "actions.h" +#include "cgi.h" const char jcc_h_rcs[] = JCC_H_VERSION; const char project_h_rcs[] = PROJECT_H_VERSION; @@ -325,6 +393,7 @@ static void chat(struct client_state *csp) int pcrs_filter; /* bool, 1==will filter through pcrs */ int filtering = 0; /* bool, 1==currently filtering through pcrs */ #endif /* def PCRS */ + struct http_response *rsp; http = csp->http; @@ -463,7 +532,7 @@ static void chat(struct client_state *csp) && (csp->action->multi[ACTION_MULTI_WAFER]->next == NULL) && ((csp->action->flags & ACTION_VANILLA_WAFER) != 0)) { - enlist_share(csp->action->multi[ACTION_MULTI_WAFER], VANILLA_WAFER); + enlist(csp->action->multi[ACTION_MULTI_WAFER], VANILLA_WAFER); } #endif /* def JAR_FILES */ @@ -508,17 +577,23 @@ static void chat(struct client_state *csp) * we're toggled off or in force mode. */ - if (intercept_url(http, csp)) + if (NULL != (rsp = cgi_dispatch(csp))) { - /* - * The interceptor will write out the data. - * We don't need to do anything else - */ + if(0 != (n = make_http_response(rsp))) + { + if ((write_socket(csp->cfd, rsp->head, n) != n) + || (write_socket(csp->cfd, rsp->body, rsp->content_length) != rsp->content_length)) + { + log_error(LOG_LEVEL_ERROR, "write to: %s failed: %E", http->host); + } + } + #ifdef STATISTICS csp->rejected = 1; #endif /* def STATISTICS */ + free_http_response(rsp); freez(hdr); return; } @@ -565,39 +640,36 @@ static void chat(struct client_state *csp) #ifdef IMAGE_BLOCKING /* Block as image? */ - if ( (csp->config->tinygif > 0) && block_imageurl(http, csp) ) + if ( ((csp->action->flags & ACTION_IMAGE_BLOCKER) != 0) + && block_imageurl(http, csp) ) { /* Send "blocked" image */ - log_error(LOG_LEVEL_GPC, "%s%s image crunch!", - http->hostport, http->path); + const char * blocker = csp->action->string[ACTION_STRING_IMAGE_BLOCKER]; - if (csp->config->tinygif == 1) - { - write_socket(csp->cfd, BLANKGIF, sizeof(BLANKGIF)-1); - } - else if (csp->config->tinygif == 2) + log_error(LOG_LEVEL_GPC, "%s%s image crunch! --> %s", + http->hostport, http->path, (blocker ? blocker : "logo")); + + if ((blocker == NULL) || (0 == strcmpic(blocker, "logo"))) { write_socket(csp->cfd, JBGIF, sizeof(JBGIF)-1); } - else if ((csp->config->tinygif == 3) && (csp->config->tinygifurl)) + else if (0 == strcmpic(blocker, "blank")) { - freez(p); - p = (char *)malloc(sizeof(HTTP_REDIRECT_TEMPLATE) - + strlen(csp->config->tinygifurl)); - sprintf(p, HTTP_REDIRECT_TEMPLATE, csp->config->tinygifurl); - write_socket(csp->cfd, p, strlen(p)); + write_socket(csp->cfd, BLANKGIF, sizeof(BLANKGIF)-1); } else { - /* Should never happen */ - write_socket(csp->cfd, JBGIF, sizeof(JBGIF)-1); + freez(p); + p = (char *)malloc(sizeof(HTTP_REDIRECT_TEMPLATE) + strlen(blocker)); + sprintf(p, HTTP_REDIRECT_TEMPLATE, blocker); + write_socket(csp->cfd, p, strlen(p)); } } else #endif /* def IMAGE_BLOCKING */ /* Block as HTML */ { - /* Send HTML "blocked" message, interception, or redirection result */ + /* Send HTML "blocked" message */ write_socket(csp->cfd, p, strlen(p)); }