X-Git-Url: http://www.privoxy.org/gitweb/?a=blobdiff_plain;f=killpopup.c;h=f191b08e71a60843432cb3e2600fc1044f2cc2d2;hb=0a53b85370a14b77571db427fe22385f58f02ebe;hp=67f5de9ba8e97687466dd91bed5e6586e7cd6ea9;hpb=6d1554928803b8cceb91a8e82de8ae3418c896f4;p=privoxy.git diff --git a/killpopup.c b/killpopup.c index 67f5de9b..f191b08e 100644 --- a/killpopup.c +++ b/killpopup.c @@ -1,4 +1,4 @@ -const char killpopup_rcs[] = "$Id: killpopup.c,v 1.2 2001/05/20 01:21:20 jongfoster Exp $"; +const char killpopup_rcs[] = "$Id: killpopup.c,v 1.6 2001/07/19 19:11:35 haroon Exp $"; /********************************************************************* * * File : $Source: /cvsroot/ijbswa/current/killpopup.c,v $ @@ -32,6 +32,19 @@ const char killpopup_rcs[] = "$Id: killpopup.c,v 1.2 2001/05/20 01:21:20 jongfos * * Revisions : * $Log: killpopup.c,v $ + * Revision 1.6 2001/07/19 19:11:35 haroon + * - Implemented Guy's idea of replacing window.open( with 1;''.concat( + * - Implemented Guy's idea of replacing .resizeTo( with .scrollTo( + * + * Revision 1.5 2001/07/18 15:02:52 haroon + * improved nuking of window.open + * + * Revision 1.4 2001/06/29 13:29:55 oes + * Added FIXMEs (and didn't repair, hehe) + * + * Revision 1.3 2001/05/22 18:56:28 oes + * CRLF -> LF + * * Revision 1.2 2001/05/20 01:21:20 jongfoster * Version 2.9.4 checkin. * - Merged popupfile and cookiefile, and added control over PCRS @@ -70,16 +83,12 @@ const char killpopup_rcs[] = "$Id: killpopup.c,v 1.2 2001/05/20 01:21:20 jongfos #include "project.h" #include "killpopup.h" #include "jcc.h" +#include "errlog.h" const char killpopup_h_rcs[] = KILLPOPUP_H_VERSION; #ifdef KILLPOPUPS -/* Change these for debug output. *lots*. */ -/*#define POPUP_VERBOSE 1*/ -#undef POPUP_VERBOSE - - /********************************************************************* * * Function : filter_popups @@ -87,6 +96,7 @@ const char killpopup_h_rcs[] = KILLPOPUP_H_VERSION; * Description : Filter the block of data that's been read from the server. * Caller is responsible for checking permissons list * to determine if this function should be called. + * Remember not to change the content length (substitute char by char) * * Parameters : * 1 : buff = Buffer to scan and modify. Null terminated. @@ -100,49 +110,30 @@ void filter_popups(char *buff, int size) char *popup = NULL; char *close = NULL; char *p = NULL; - char *q = NULL; /* by BREITENB NEW! */ while ((popup = strstr( buff, "window.open(" )) != NULL) { -#ifdef POPUP_VERBOSE - fprintf(logfp, "Found start of window open" ); -#endif - close = strstr( popup+1, ");" ); - if ( close ) - { -#ifdef POPUP_VERBOSE - fprintf(logfp, "Found end of window open" ); -#endif - for ( p = popup; p != (close+1); p++ ) - { - *p = ' '; - } -#ifdef POPUP_VERBOSE - fprintf(logfp, "Blocked %s\n", host_name ); -#endif - } - else - { -#ifdef POPUP_VERBOSE - fprintf(logfp, "Couldn't find end, turned into comment. Read boundary?\n" ); -#endif - *popup = '/'; - popup++; - *popup = '/'; - } - - - q=popup; /* by BREITENB NEW! */ - while (q>=buff) + if ( popup ) { - if (*q==' ' || *q=='\t') - q--; - else break; + /* + * replace the window.open( with a harmless JavaScript replacement (notice the two single quotes) + * Guy's idea (thanks) + */ + strncpy(popup, "1;''.concat(", 12); + log_error(LOG_LEVEL_POPUPS, "Blocked popup window open"); } - if (q>=buff) + } + + while ((popup = strstr( buff, ".resizeTo(" )) != NULL) + { + if ( popup ) { - if (*q=='=') *++q='1'; - /* result of popup is assigned to a variable! ensure success. hehehe. */ + /* + * replace the .resizeTo( with a harmless JavaScript replacement + * Guy's idea (thanks) + */ + strncpy(popup, ".scrollTo(", 10); + log_error(LOG_LEVEL_POPUPS, "Blocked popup window resize"); } } @@ -156,7 +147,7 @@ void filter_popups(char *buff, int size) close=strchr(popup,'>'); if (close) { - /* we are now between */ + /* we are now between FIXME: No, we're anywhere! --oes*/ p=strstr(popup, "onUnload"); if (p) {