diff options
Diffstat (limited to 'net-proxy/privoxy/files')
-rw-r--r-- | net-proxy/privoxy/files/digest-privoxy-3.0.3-r3 | 3 | ||||
-rw-r--r-- | net-proxy/privoxy/files/digest-privoxy-3.0.3-r5 | 3 | ||||
-rw-r--r-- | net-proxy/privoxy/files/digest-privoxy-3.0.5_beta | 3 | ||||
-rw-r--r-- | net-proxy/privoxy/files/privoxy-3.0.3-zlib.patch | 517 | ||||
-rw-r--r-- | net-proxy/privoxy/files/privoxy-zlib.patch | 508 | ||||
-rw-r--r-- | net-proxy/privoxy/files/privoxy.initd (renamed from net-proxy/privoxy/files/privoxy.rc7) | 2 |
6 files changed, 1 insertions, 1035 deletions
diff --git a/net-proxy/privoxy/files/digest-privoxy-3.0.3-r3 b/net-proxy/privoxy/files/digest-privoxy-3.0.3-r3 deleted file mode 100644 index 59989685087a..000000000000 --- a/net-proxy/privoxy/files/digest-privoxy-3.0.3-r3 +++ /dev/null @@ -1,3 +0,0 @@ -MD5 b0710be8af09409bfb03f52523a17010 privoxy-3.0.3-stable-src.tar.gz 1561072 -RMD160 ae77a87c51ec8685f9352c99a8db820fc95b9202 privoxy-3.0.3-stable-src.tar.gz 1561072 -SHA256 4dab0049049c1ae6cfb00faea606d981535d0f0a65aab17e3179cc3d75de9f84 privoxy-3.0.3-stable-src.tar.gz 1561072 diff --git a/net-proxy/privoxy/files/digest-privoxy-3.0.3-r5 b/net-proxy/privoxy/files/digest-privoxy-3.0.3-r5 deleted file mode 100644 index 59989685087a..000000000000 --- a/net-proxy/privoxy/files/digest-privoxy-3.0.3-r5 +++ /dev/null @@ -1,3 +0,0 @@ -MD5 b0710be8af09409bfb03f52523a17010 privoxy-3.0.3-stable-src.tar.gz 1561072 -RMD160 ae77a87c51ec8685f9352c99a8db820fc95b9202 privoxy-3.0.3-stable-src.tar.gz 1561072 -SHA256 4dab0049049c1ae6cfb00faea606d981535d0f0a65aab17e3179cc3d75de9f84 privoxy-3.0.3-stable-src.tar.gz 1561072 diff --git a/net-proxy/privoxy/files/digest-privoxy-3.0.5_beta b/net-proxy/privoxy/files/digest-privoxy-3.0.5_beta deleted file mode 100644 index 71f14cf256f2..000000000000 --- a/net-proxy/privoxy/files/digest-privoxy-3.0.5_beta +++ /dev/null @@ -1,3 +0,0 @@ -MD5 61f16bde1f88090eae88bf8b7fdbb557 privoxy-3.0.5-beta-src.tar.gz 1727642 -RMD160 c446ca3646bf88357d3102b1cbc867a1daf77876 privoxy-3.0.5-beta-src.tar.gz 1727642 -SHA256 e7285b27311fe2093d742e4f8c553a04232946f66aa6ad6bc6141f76c1b0b489 privoxy-3.0.5-beta-src.tar.gz 1727642 diff --git a/net-proxy/privoxy/files/privoxy-3.0.3-zlib.patch b/net-proxy/privoxy/files/privoxy-3.0.3-zlib.patch deleted file mode 100644 index 00ba739ac127..000000000000 --- a/net-proxy/privoxy/files/privoxy-3.0.3-zlib.patch +++ /dev/null @@ -1,517 +0,0 @@ -diff -Nru privoxy-3.0.3-stable.orig/actionlist.h privoxy-3.0.3-stable/actionlist.h ---- privoxy-3.0.3-stable.orig/actionlist.h 2002-09-25 18:25:25.000000000 +0300 -+++ privoxy-3.0.3-stable/actionlist.h 2006-03-29 01:19:45.337430250 +0300 -@@ -116,6 +116,7 @@ - DEFINE_ACTION_STRING ("deanimate-gifs", ACTION_DEANIMATE, ACTION_STRING_DEANIMATE) - DEFINE_CGI_PARAM_RADIO ("deanimate-gifs", ACTION_DEANIMATE, ACTION_STRING_DEANIMATE, "first", 0) - DEFINE_CGI_PARAM_RADIO ("deanimate-gifs", ACTION_DEANIMATE, ACTION_STRING_DEANIMATE, "last", 1) -+DEFINE_ACTION_BOOL ("decompress-from-server", ACTION_DECOMPRESS_IN) - DEFINE_ACTION_BOOL ("downgrade-http-version", ACTION_DOWNGRADE) - DEFINE_ACTION_BOOL ("fast-redirects", ACTION_FAST_REDIRECTS) - DEFINE_ACTION_MULTI ("filter", ACTION_MULTI_FILTER) -diff -Nru privoxy-3.0.3-stable.orig/configure.in privoxy-3.0.3-stable/configure.in ---- privoxy-3.0.3-stable.orig/configure.in 2004-01-30 11:26:03.000000000 +0200 -+++ privoxy-3.0.3-stable/configure.in 2006-03-29 01:19:45.353431250 +0300 -@@ -1234,6 +1234,20 @@ - libpcrs is available], - [ if test $enableval = "no"; then have_pcrs=no; fi ]) - -+AC_ARG_ENABLE(zlib, -+[ --enable-zlib Use the zlib library to allow compressing or -+ decompressing data on the fly.], -+[enableval2=$enableval], -+[enableval2=no]) -+if test $enableval2 = yes; then -+ AC_CHECK_LIB(z, zlibVersion, , [ -+ AC_MSG_ERROR([Unable to find a copy of zlib. The zlib library -+is necessary to enable compresion support. ]) -+ ]) -+ AC_DEFINE(FEATURE_ZLIB,1, -+ [ Define to 1 to use compression through the zlib library. ]) -+fi -+ - - # If we have libpcre and either we also have pcreposix or - # we don't need pcreposix, then link pcre dynamically; else -diff -Nru privoxy-3.0.3-stable.orig/default.action.master privoxy-3.0.3-stable/default.action.master ---- privoxy-3.0.3-stable.orig/default.action.master 2006-03-29 01:19:03.000000000 +0300 -+++ privoxy-3.0.3-stable/default.action.master 2006-03-29 01:19:45.357431500 +0300 -@@ -452,7 +452,7 @@ - -hide-user-agent \ - -kill-popups \ - -limit-connect \ --+prevent-compression \ -+-prevent-compression \ - -send-vanilla-wafer \ - -send-wafer \ - +session-cookies-only \ -diff -Nru privoxy-3.0.3-stable.orig/filters.c privoxy-3.0.3-stable/filters.c ---- privoxy-3.0.3-stable.orig/filters.c 2003-11-11 15:10:31.000000000 +0200 -+++ privoxy-3.0.3-stable/filters.c 2006-03-29 01:23:20.022847250 +0300 -@@ -1320,6 +1320,38 @@ - csp->flags |= CSP_FLAG_MODIFIED; - } - -+#ifdef FEATURE_ZLIB -+ /* If the body has a compressed transfer-encoding, uncompress -+ * it first, adjusting size and iob->eod. Note that -+ * decompression occurs after de-chunking. -+ */ -+ if (csp->content_type & CT_GZIP || csp->content_type & CT_DEFLATE) -+ { -+ /* Notice that we at least tried to decompress. */ -+ if (JB_ERR_OK != decompress_iob(csp)) -+ { -+ /* We failed to decompress the data; there's no point -+ * in continuing since we can't filter. This is -+ * slightly tricky because we need to remember not to -+ * modify the Content-Encoding header later; using -+ * CT_TABOO flag is a kludge for this purpose. -+ */ -+ csp->content_type |= CT_TABOO; -+ return(NULL); -+ } -+ log_error(LOG_LEVEL_RE_FILTER, "Decompressing successful"); -+ -+ /* Decompression gives us a completely new iob, so we -+ * need to update. -+ */ -+ size = csp->iob->eod - csp->iob->cur; -+ old = csp->iob->cur; -+ -+ csp->flags |= CSP_FLAG_MODIFIED; -+ } -+#endif -+ -+ - /* - * For all applying +filter actions, look if a filter by that - * name exists and if yes, execute it's pcrs_joblist on the -diff -Nru privoxy-3.0.3-stable.orig/jcc.c privoxy-3.0.3-stable/jcc.c ---- privoxy-3.0.3-stable.orig/jcc.c 2003-12-12 14:52:53.000000000 +0200 -+++ privoxy-3.0.3-stable/jcc.c 2006-03-29 01:19:45.357431500 +0300 -@@ -659,6 +659,10 @@ - # include <select.h> - # endif - -+#ifdef FEATURE_ZLIB -+#include <zlib.h> -+#endif -+ - #endif - - #include "project.h" -@@ -1605,6 +1609,8 @@ - - if ((csp->content_type & CT_TEXT) && /* It's a text / * MIME-Type */ - !http->ssl && /* We talk plaintext */ -+ !(csp->content_type & CT_GZIP) && -+ !(csp->content_type & CT_DEFLATE) && - block_popups) /* Policy allows */ - { - block_popups_now = 1; -diff -Nru privoxy-3.0.3-stable.orig/parsers.c privoxy-3.0.3-stable/parsers.c ---- privoxy-3.0.3-stable.orig/parsers.c 2003-07-11 16:21:25.000000000 +0300 -+++ privoxy-3.0.3-stable/parsers.c 2006-03-29 01:19:45.361431750 +0300 -@@ -433,6 +433,10 @@ - #include <assert.h> - #include <string.h> - -+#ifdef FEATURE_ZLIB -+#include <zlib.h> -+#endif -+ - #if !defined(_WIN32) && !defined(__OS2__) - #include <unistd.h> - #endif -@@ -632,6 +636,281 @@ - } - - -+#ifdef FEATURE_ZLIB -+/********************************************************************* -+ * -+ * Function : decompress_iob -+ * -+ * Description : Decompress buffered page, expanding the -+ * buffer as necessary. csp->iob->cur -+ * should point to the the beginning of the -+ * compressed data block. -+ * -+ * Parameters : -+ * 1 : csp = Current client state (buffers, headers, etc...) -+ * -+ * Returns : JB_ERR_OK on success, JB_ERR_MEMORY if out-of-memory -+ * limit reached, JB_ERR_GENERIC if error decompressing -+ * buffer. -+ * -+ *********************************************************************/ -+jb_err decompress_iob(struct client_state *csp) -+{ -+ char *buf; /* new, uncompressed buffer */ -+ int bufsize = csp->iob->size; /* allocated size of the new buffer */ -+ /* Number of bytes at the beginning -+ * of the iob that we should NOT -+ * decompress. -+ */ -+ int skip_size = csp->iob->cur - csp->iob->buf; -+ int status; /* return status of the inflate() call */ -+ z_stream zstr; /* used by calls to zlib */ -+ -+ /* This is to protect the parsing of gzipped data, but it should(?) -+ * be valid for deflated data also. -+ */ -+ if (bufsize < 10) -+ { -+ log_error (LOG_LEVEL_ERROR, "Buffer too small decompressing iob"); -+ return JB_ERR_GENERIC; -+ } -+ -+ if (csp->content_type & CT_GZIP) -+ { -+ /* Our task is slightly complicated by the facts that data -+ * compressed by gzip does not include a zlib header, and -+ * that there is no easily accessible interface in zlib to -+ * handle a gzip header. We strip off the gzip header by -+ * hand, and later inform zlib not to expect a header. -+ */ -+ -+ /* Strip off the gzip header. Please see RFC 1952 for more -+ * explanation of the appropriate fields. -+ */ -+ if ((*csp->iob->cur++ != (char)0x1f) -+ || (*csp->iob->cur++ != (char)0x8b) -+ || (*csp->iob->cur++ != Z_DEFLATED)) -+ { -+ log_error (LOG_LEVEL_ERROR, -+ "Invalid gzip header when decompressing"); -+ return JB_ERR_GENERIC; -+ } -+ else { -+ int flags = *csp->iob->cur++; -+ if (flags & 0xe0) -+ { -+ /* The gzip header has reserved bits set; bail out. */ -+ log_error (LOG_LEVEL_ERROR, -+ "Invalid gzip header when decompressing"); -+ return JB_ERR_GENERIC; -+ } -+ csp->iob->cur += 6; -+ -+ /* Skip extra fields if necessary. */ -+ if (flags & 0x04) -+ { -+ /* Skip a given number of bytes, specified as a 16-bit -+ * little-endian value. -+ */ -+ csp->iob->cur += *csp->iob->cur++ + (*csp->iob->cur++ << 8); -+ } -+ -+ /* Skip the filename if necessary. */ -+ if (flags & 0x08) -+ { -+ /* A null-terminated string follows. */ -+ while (*csp->iob->cur++); -+ } -+ -+ /* Skip the comment if necessary. */ -+ if (flags & 0x10) -+ { -+ while (*csp->iob->cur++); -+ } -+ -+ /* Skip the CRC if necessary. */ -+ if (flags & 0x02) -+ { -+ csp->iob->cur += 2; -+ } -+ } -+ } -+ else if (csp->content_type & CT_DEFLATE) -+ { -+ log_error (LOG_LEVEL_INFO, "Decompressing deflated iob: %d", *csp->iob->cur); -+ /* In theory (that is, according to RFC 1950), deflate-compressed -+ * data should begin with a two-byte zlib header and have an -+ * adler32 checksum at the end. It seems that in practice the -+ * only the raw compressed data is sent. Note that this means that -+ * we are not RFC 1950-compliant here, but the advantage is that -+ * this actually works. :) -+ * -+ * We add a dummy null byte to tell zlib where the data ends, -+ * and later inform it not to expect a header. -+ * -+ * Fortunately, add_to_iob() has thoughtfully null-terminated -+ * the buffer; we can just increment the end pointer to include -+ * the dummy byte. -+ */ -+ csp->iob->eod++; -+ } -+ else -+ { -+ log_error (LOG_LEVEL_ERROR, -+ "Unable to determine compression format for decompression"); -+ return JB_ERR_GENERIC; -+ } -+ -+ /* Set up the fields required by zlib. */ -+ zstr.next_in = csp->iob->cur; -+ zstr.avail_in = csp->iob->eod - csp->iob->cur; -+ zstr.zalloc = Z_NULL; -+ zstr.zfree = Z_NULL; -+ zstr.opaque = Z_NULL; -+ -+ /* Passing -MAX_WBITS to inflateInit2 tells the library -+ * that there is no zlib header. -+ */ -+ if (inflateInit2 (&zstr, -MAX_WBITS) != Z_OK) -+ { -+ log_error (LOG_LEVEL_ERROR, -+ "Error initializing decompression"); -+ return JB_ERR_GENERIC; -+ } -+ -+ /* Next, we allocate new storage for the inflated data. -+ * We don't modify the existing iob yet, so in case there -+ * is error in decompression we can recover gracefully. -+ */ -+ buf = zalloc (bufsize); -+ if (NULL == buf) -+ { -+ log_error (LOG_LEVEL_ERROR, -+ "Out of memory decompressing iob"); -+ return JB_ERR_MEMORY; -+ } -+ -+ assert(bufsize >= skip_size); -+ memcpy(buf, csp->iob->buf, skip_size); -+ zstr.avail_out = bufsize - skip_size; -+ zstr.next_out = buf + skip_size; -+ -+ /* Try to decompress the whole stream in one shot. */ -+ while (Z_BUF_ERROR == (status = inflate(&zstr, Z_FINISH))) -+ { -+ /* We need to allocate more memory for the output buffer. */ -+ -+ char *tmpbuf; /* used for realloc'ing the buffer */ -+ int oldbufsize = bufsize; /* keep track of the old bufsize */ -+ -+ /* If zlib wants more data then there's a problem, because -+ * the complete compressed file should have been buffered. -+ */ -+ if (0 == zstr.avail_in) -+ { -+ log_error(LOG_LEVEL_ERROR, -+ "Unexpected end of compressed iob"); -+ return JB_ERR_GENERIC; -+ } -+ -+ /* If we tried the limit and still didn't have enough -+ * memory, just give up. -+ */ -+ if (bufsize == csp->config->buffer_limit) -+ { -+ log_error(LOG_LEVEL_ERROR, "Out of memory decompressing iob"); -+ return JB_ERR_MEMORY; -+ } -+ -+ /* Try doubling the buffer size each time. */ -+ bufsize *= 2; -+ -+ /* Don't exceed the buffer limit. */ -+ if (bufsize > csp->config->buffer_limit) -+ { -+ bufsize = csp->config->buffer_limit; -+ } -+ -+ /* Try to allocate the new buffer. */ -+ tmpbuf = realloc(buf, bufsize); -+ if (NULL == tmpbuf) -+ { -+ log_error(LOG_LEVEL_ERROR, "Out of memory decompressing iob"); -+ freez(buf); -+ return JB_ERR_MEMORY; -+ } -+ else -+ { -+ char *oldnext_out = zstr.next_out; -+ -+ /* Update the fields for inflate() to use the new -+ * buffer, which may be in a different location from -+ * the old one. -+ */ -+ zstr.avail_out += bufsize - oldbufsize; -+ zstr.next_out = tmpbuf + bufsize - zstr.avail_out; -+ -+ /* Compare with an uglier method of calculating these values -+ * that doesn't require the extra oldbufsize variable. -+ */ -+ assert(zstr.avail_out == -+ tmpbuf + bufsize - (char *)zstr.next_out); -+ assert((char *)zstr.next_out == -+ tmpbuf + ((char *)oldnext_out - buf)); -+ assert(zstr.avail_out > 0); -+ -+ buf = tmpbuf; -+ } -+ } -+ -+ inflateEnd(&zstr); -+ if (status != Z_STREAM_END) -+ { -+ /* We failed to decompress the stream. */ -+ log_error(LOG_LEVEL_ERROR, -+ "Error in decompressing to the buffer (iob): %s", -+ zstr.msg); -+ return JB_ERR_GENERIC; -+ } -+ -+ /* Finally, we can actually update the iob, since the -+ * decompression was successful. First, free the old -+ * buffer. -+ */ -+ freez(csp->iob->buf); -+ -+ /* Now, update the iob to use the new buffer. */ -+ csp->iob->buf = buf; -+ csp->iob->cur = csp->iob->buf + skip_size; -+ csp->iob->eod = zstr.next_out; -+ csp->iob->size = bufsize; -+ -+ /* Make sure the new uncompressed iob obeys some minimal -+ * consistency conditions. -+ */ -+ if ((csp->iob->buf < csp->iob->cur) -+ && (csp->iob->cur <= csp->iob->eod) -+ && (csp->iob->eod <= csp->iob->buf + csp->iob->size)) -+ { -+ char t = csp->iob->cur[100]; -+ csp->iob->cur[100] = 0; -+ log_error(LOG_LEVEL_INFO, -+ "Sucessfully decompressed: %s", csp->iob->cur); -+ csp->iob->cur[100] = t; -+ return JB_ERR_OK; -+ } -+ else -+ { -+ /* It seems that zlib did something weird. */ -+ log_error(LOG_LEVEL_ERROR, -+ "Unexpected error decompressing the buffer (iob): %d==%d, %d>%d, %d<%d", csp->iob->cur, csp->iob->buf + skip_size, csp->iob->eod, csp->iob->buf, csp->iob->eod, csp->iob->buf + csp->iob->size); -+ return JB_ERR_GENERIC; -+ } -+ -+} -+#endif /* defined(FEATURE_ZLIB) */ -+ -+ - /********************************************************************* - * - * Function : get_header -@@ -937,13 +1216,59 @@ - *********************************************************************/ - jb_err server_content_encoding(struct client_state *csp, char **header) - { -+#ifdef FEATURE_ZLIB -+ if (strstr(*header, "gzip")) -+ { -+ /* -+ * If the body was modified, we have tried to -+ * decompress it, so adjust the header if necessary. -+ */ -+ if ((csp->flags & CSP_FLAG_MODIFIED) /* we attempted to decompress */ -+ && !(csp->content_type & CT_TABOO)) /* decompression was successful */ -+ { -+ freez(*header); -+ *header = strdup("Content-Encoding: identity"); -+ return (header == NULL) ? JB_ERR_MEMORY : JB_ERR_OK; -+ } -+ else -+ { -+ csp->content_type |= CT_GZIP; -+ } -+ } -+ else if (strstr(*header, "deflate")) -+ { -+ /* -+ * If the body was modified, we have tried to -+ * decompress it, so adjust the header if necessary. -+ */ -+ if ((csp->flags & CSP_FLAG_MODIFIED) /* we attempted to decompress */ -+ && !(csp->content_type & CT_TABOO)) /* decompression was successful */ -+ { -+ freez(*header); -+ *header = strdup("Content-Encoding: identity"); -+ return (header == NULL) ? JB_ERR_MEMORY : JB_ERR_OK; -+ } -+ else -+ { -+ csp->content_type |= CT_DEFLATE; -+ } -+ } -+ else if (strstr(*header, "compress")) -+ { -+ /* We can't decompress this; therefore we can't filter -+ * it either. -+ */ -+ csp->content_type |= CT_TABOO; -+ } -+#else /* !defined(FEATURE_GZIP) */ - /* - * Turn off pcrs and gif filtering if body compressed - */ - if (strstr(*header, "gzip") || strstr(*header, "compress") || strstr(*header, "deflate")) - { -- csp->content_type = CT_TABOO; -+ csp->content_type |= CT_TABOO; - } -+#endif /* !defined(FEATURE_GZIP) */ - - return JB_ERR_OK; - -diff -Nru privoxy-3.0.3-stable.orig/parsers.h privoxy-3.0.3-stable/parsers.h ---- privoxy-3.0.3-stable.orig/parsers.h 2002-09-25 17:52:46.000000000 +0300 -+++ privoxy-3.0.3-stable/parsers.h 2006-03-29 01:19:45.361431750 +0300 -@@ -194,6 +194,7 @@ - - extern int flush_socket(jb_socket fd, struct client_state *csp); - extern jb_err add_to_iob(struct client_state *csp, char *buf, int n); -+extern jb_err decompress_iob(struct client_state *csp); - extern char *get_header(struct client_state *csp); - extern char *get_header_value(const struct list *header_list, const char *header_name); - extern char *sed(const struct parsers pats[], const add_header_func_ptr more_headers[], struct client_state *csp); -diff -Nru privoxy-3.0.3-stable.orig/project.h privoxy-3.0.3-stable/project.h ---- privoxy-3.0.3-stable.orig/project.h 2004-01-30 17:29:29.000000000 +0200 -+++ privoxy-3.0.3-stable/project.h 2006-03-29 01:28:21.741703500 +0300 -@@ -563,7 +563,7 @@ - #define JB_ERR_PARSE 4 /**< Error parsing file */ - #define JB_ERR_MODIFIED 5 /**< File has been modified outside of the - CGI actions editor. */ -- -+#define JB_ERR_GENERIC 6 - - /** - * This macro is used to free a pointer that may be NULL. -@@ -818,6 +818,15 @@ - #define CT_TABOO 4 /**< csp->content_type bitmask: - DO NOT filter, irrespective of other flags. */ - -+/* Although these are not, strictly speaking, content types -+ * (they are content encodings), it is simple to handle -+ * them as such. -+ */ -+#define CT_GZIP 8 /**< csp->content_type bitmask: -+ gzip-compressed data. */ -+#define CT_DEFLATE 16 /**< csp->content_type bitmask: -+ zlib-compressed data. */ -+ - /** - * The mask which includes all actions. - */ -@@ -862,6 +871,8 @@ - #define ACTION_VANILLA_WAFER 0x00008000UL - /** Action bitmap: Limit CONNECT requests to safe ports. */ - #define ACTION_LIMIT_CONNECT 0x00010000UL -+/** Action bitmap: Uncompress incoming text for filtering. */ -+#define ACTION_DECOMPRESS_IN 0x00020000UL - - /** Action string index: How to deanimate GIFs */ - #define ACTION_STRING_DEANIMATE 0 diff --git a/net-proxy/privoxy/files/privoxy-zlib.patch b/net-proxy/privoxy/files/privoxy-zlib.patch deleted file mode 100644 index 174ce9182b17..000000000000 --- a/net-proxy/privoxy/files/privoxy-zlib.patch +++ /dev/null @@ -1,508 +0,0 @@ -diff -Nru privoxy-3.0.3-stable.orig/actionlist.h privoxy-3.0.3-stable/actionlist.h ---- privoxy-3.0.3-stable.orig/actionlist.h 2002-09-25 18:25:25.000000000 +0300 -+++ privoxy-3.0.3-stable/actionlist.h 2005-02-27 01:01:23.072737744 +0200 -@@ -116,6 +116,7 @@ - DEFINE_ACTION_STRING ("deanimate-gifs", ACTION_DEANIMATE, ACTION_STRING_DEANIMATE) - DEFINE_CGI_PARAM_RADIO ("deanimate-gifs", ACTION_DEANIMATE, ACTION_STRING_DEANIMATE, "first", 0) - DEFINE_CGI_PARAM_RADIO ("deanimate-gifs", ACTION_DEANIMATE, ACTION_STRING_DEANIMATE, "last", 1) -+DEFINE_ACTION_BOOL ("decompress-from-server", ACTION_DECOMPRESS_IN) - DEFINE_ACTION_BOOL ("downgrade-http-version", ACTION_DOWNGRADE) - DEFINE_ACTION_BOOL ("fast-redirects", ACTION_FAST_REDIRECTS) - DEFINE_ACTION_MULTI ("filter", ACTION_MULTI_FILTER) -diff -Nru privoxy-3.0.3-stable.orig/configure.in privoxy-3.0.3-stable/configure.in ---- privoxy-3.0.3-stable.orig/configure.in 2004-01-30 11:26:03.000000000 +0200 -+++ privoxy-3.0.3-stable/configure.in 2005-02-27 00:59:01.813373408 +0200 -@@ -1234,6 +1234,20 @@ - libpcrs is available], - [ if test $enableval = "no"; then have_pcrs=no; fi ]) - -+AC_ARG_ENABLE(zlib, -+[ --enable-zlib Use the zlib library to allow compressing or -+ decompressing data on the fly.], -+[enableval2=$enableval], -+[enableval2=no]) -+if test $enableval2 = yes; then -+ AC_CHECK_LIB(z, zlibVersion, , [ -+ AC_MSG_ERROR([Unable to find a copy of zlib. The zlib library -+is necessary to enable compresion support. ]) -+ ]) -+ AC_DEFINE(FEATURE_ZLIB,1, -+ [ Define to 1 to use compression through the zlib library. ]) -+fi -+ - - # If we have libpcre and either we also have pcreposix or - # we don't need pcreposix, then link pcre dynamically; else -diff -Nru privoxy-3.0.3-stable.orig/default.action.master privoxy-3.0.3-stable/default.action.master ---- privoxy-3.0.3-stable.orig/default.action.master 2004-01-30 17:28:45.000000000 +0200 -+++ privoxy-3.0.3-stable/default.action.master 2005-02-27 00:59:01.815373104 +0200 -@@ -452,7 +452,7 @@ - -hide-user-agent \ - -kill-popups \ - -limit-connect \ --+prevent-compression \ -+-prevent-compression \ - -send-vanilla-wafer \ - -send-wafer \ - +session-cookies-only \ -diff -Nru privoxy-3.0.3-stable.orig/filters.c privoxy-3.0.3-stable/filters.c ---- privoxy-3.0.3-stable.orig/filters.c 2003-11-11 15:10:31.000000000 +0200 -+++ privoxy-3.0.3-stable/filters.c 2005-02-27 01:01:23.073737592 +0200 -@@ -1320,6 +1320,38 @@ - csp->flags |= CSP_FLAG_MODIFIED; - } - -+#ifdef FEATURE_ZLIB -+ /* If the body has a compressed transfer-encoding, uncompress -+ * it first, adjusting size and iob->eod. Note that -+ * decompression occurs after de-chunking. -+ */ -+ if (csp->content_type & CT_GZIP || csp->content_type & CT_DEFLATE) -+ { -+ /* Notice that we at least tried to decompress. */ -+ if (JB_ERR_OK != decompress_iob(csp)) -+ { -+ /* We failed to decompress the data; there's no point -+ * in continuing since we can't filter. This is -+ * slightly tricky because we need to remember not to -+ * modify the Content-Encoding header later; using -+ * CT_TABOO flag is a kludge for this purpose. -+ */ -+ csp->content_type |= CT_TABOO; -+ return(NULL); -+ } -+ log_error(LOG_LEVEL_RE_FILTER, "Decompressing successful"); -+ -+ /* Decompression gives us a completely new iob, so we -+ * need to update. -+ */ -+ size = csp->iob->eod - csp->iob->cur; -+ old_buf = csp->iob->cur; -+ -+ csp->flags |= CSP_FLAG_MODIFIED; -+ } -+#endif -+ -+ - /* - * For all applying +filter actions, look if a filter by that - * name exists and if yes, execute it's pcrs_joblist on the -diff -Nru privoxy-3.0.3-stable.orig/jcc.c privoxy-3.0.3-stable/jcc.c ---- privoxy-3.0.3-stable.orig/jcc.c 2003-12-12 14:52:53.000000000 +0200 -+++ privoxy-3.0.3-stable/jcc.c 2005-02-27 01:06:08.737310128 +0200 -@@ -659,6 +659,10 @@ - # include <select.h> - # endif - -+#ifdef FEATURE_ZLIB -+#include <zlib.h> -+#endif -+ - #endif - - #include "project.h" -@@ -1605,6 +1609,8 @@ - - if ((csp->content_type & CT_TEXT) && /* It's a text / * MIME-Type */ - !http->ssl && /* We talk plaintext */ -+ !(csp->content_type & CT_GZIP) && -+ !(csp->content_type & CT_DEFLATE) && - block_popups) /* Policy allows */ - { - block_popups_now = 1; -diff -Nru privoxy-3.0.3-stable.orig/parsers.c privoxy-3.0.3-stable/parsers.c ---- privoxy-3.0.3-stable.orig/parsers.c 2003-07-11 16:21:25.000000000 +0300 -+++ privoxy-3.0.3-stable/parsers.c 2005-02-27 01:01:23.078736832 +0200 -@@ -433,6 +433,10 @@ - #include <assert.h> - #include <string.h> - -+#ifdef FEATURE_ZLIB -+#include <zlib.h> -+#endif -+ - #if !defined(_WIN32) && !defined(__OS2__) - #include <unistd.h> - #endif -@@ -632,6 +636,281 @@ - } - - -+#ifdef FEATURE_ZLIB -+/********************************************************************* -+ * -+ * Function : decompress_iob -+ * -+ * Description : Decompress buffered page, expanding the -+ * buffer as necessary. csp->iob->cur -+ * should point to the the beginning of the -+ * compressed data block. -+ * -+ * Parameters : -+ * 1 : csp = Current client state (buffers, headers, etc...) -+ * -+ * Returns : JB_ERR_OK on success, JB_ERR_MEMORY if out-of-memory -+ * limit reached, JB_ERR_GENERIC if error decompressing -+ * buffer. -+ * -+ *********************************************************************/ -+jb_err decompress_iob(struct client_state *csp) -+{ -+ char *buf; /* new, uncompressed buffer */ -+ int bufsize = csp->iob->size; /* allocated size of the new buffer */ -+ /* Number of bytes at the beginning -+ * of the iob that we should NOT -+ * decompress. -+ */ -+ int skip_size = csp->iob->cur - csp->iob->buf; -+ int status; /* return status of the inflate() call */ -+ z_stream zstr; /* used by calls to zlib */ -+ -+ /* This is to protect the parsing of gzipped data, but it should(?) -+ * be valid for deflated data also. -+ */ -+ if (bufsize < 10) -+ { -+ log_error (LOG_LEVEL_ERROR, "Buffer too small decompressing iob"); -+ return JB_ERR_GENERIC; -+ } -+ -+ if (csp->content_type & CT_GZIP) -+ { -+ /* Our task is slightly complicated by the facts that data -+ * compressed by gzip does not include a zlib header, and -+ * that there is no easily accessible interface in zlib to -+ * handle a gzip header. We strip off the gzip header by -+ * hand, and later inform zlib not to expect a header. -+ */ -+ -+ /* Strip off the gzip header. Please see RFC 1952 for more -+ * explanation of the appropriate fields. -+ */ -+ if ((*csp->iob->cur++ != (char)0x1f) -+ || (*csp->iob->cur++ != (char)0x8b) -+ || (*csp->iob->cur++ != Z_DEFLATED)) -+ { -+ log_error (LOG_LEVEL_ERROR, -+ "Invalid gzip header when decompressing"); -+ return JB_ERR_GENERIC; -+ } -+ else { -+ int flags = *csp->iob->cur++; -+ if (flags & 0xe0) -+ { -+ /* The gzip header has reserved bits set; bail out. */ -+ log_error (LOG_LEVEL_ERROR, -+ "Invalid gzip header when decompressing"); -+ return JB_ERR_GENERIC; -+ } -+ csp->iob->cur += 6; -+ -+ /* Skip extra fields if necessary. */ -+ if (flags & 0x04) -+ { -+ /* Skip a given number of bytes, specified as a 16-bit -+ * little-endian value. -+ */ -+ csp->iob->cur += *csp->iob->cur++ + (*csp->iob->cur++ << 8); -+ } -+ -+ /* Skip the filename if necessary. */ -+ if (flags & 0x08) -+ { -+ /* A null-terminated string follows. */ -+ while (*csp->iob->cur++); -+ } -+ -+ /* Skip the comment if necessary. */ -+ if (flags & 0x10) -+ { -+ while (*csp->iob->cur++); -+ } -+ -+ /* Skip the CRC if necessary. */ -+ if (flags & 0x02) -+ { -+ csp->iob->cur += 2; -+ } -+ } -+ } -+ else if (csp->content_type & CT_DEFLATE) -+ { -+ log_error (LOG_LEVEL_INFO, "Decompressing deflated iob: %d", *csp->iob->cur); -+ /* In theory (that is, according to RFC 1950), deflate-compressed -+ * data should begin with a two-byte zlib header and have an -+ * adler32 checksum at the end. It seems that in practice the -+ * only the raw compressed data is sent. Note that this means that -+ * we are not RFC 1950-compliant here, but the advantage is that -+ * this actually works. :) -+ * -+ * We add a dummy null byte to tell zlib where the data ends, -+ * and later inform it not to expect a header. -+ * -+ * Fortunately, add_to_iob() has thoughtfully null-terminated -+ * the buffer; we can just increment the end pointer to include -+ * the dummy byte. -+ */ -+ csp->iob->eod++; -+ } -+ else -+ { -+ log_error (LOG_LEVEL_ERROR, -+ "Unable to determine compression format for decompression"); -+ return JB_ERR_GENERIC; -+ } -+ -+ /* Set up the fields required by zlib. */ -+ zstr.next_in = csp->iob->cur; -+ zstr.avail_in = csp->iob->eod - csp->iob->cur; -+ zstr.zalloc = Z_NULL; -+ zstr.zfree = Z_NULL; -+ zstr.opaque = Z_NULL; -+ -+ /* Passing -MAX_WBITS to inflateInit2 tells the library -+ * that there is no zlib header. -+ */ -+ if (inflateInit2 (&zstr, -MAX_WBITS) != Z_OK) -+ { -+ log_error (LOG_LEVEL_ERROR, -+ "Error initializing decompression"); -+ return JB_ERR_GENERIC; -+ } -+ -+ /* Next, we allocate new storage for the inflated data. -+ * We don't modify the existing iob yet, so in case there -+ * is error in decompression we can recover gracefully. -+ */ -+ buf = zalloc (bufsize); -+ if (NULL == buf) -+ { -+ log_error (LOG_LEVEL_ERROR, -+ "Out of memory decompressing iob"); -+ return JB_ERR_MEMORY; -+ } -+ -+ assert(bufsize >= skip_size); -+ memcpy(buf, csp->iob->buf, skip_size); -+ zstr.avail_out = bufsize - skip_size; -+ zstr.next_out = buf + skip_size; -+ -+ /* Try to decompress the whole stream in one shot. */ -+ while (Z_BUF_ERROR == (status = inflate(&zstr, Z_FINISH))) -+ { -+ /* We need to allocate more memory for the output buffer. */ -+ -+ char *tmpbuf; /* used for realloc'ing the buffer */ -+ int oldbufsize = bufsize; /* keep track of the old bufsize */ -+ -+ /* If zlib wants more data then there's a problem, because -+ * the complete compressed file should have been buffered. -+ */ -+ if (0 == zstr.avail_in) -+ { -+ log_error(LOG_LEVEL_ERROR, -+ "Unexpected end of compressed iob"); -+ return JB_ERR_GENERIC; -+ } -+ -+ /* If we tried the limit and still didn't have enough -+ * memory, just give up. -+ */ -+ if (bufsize == csp->config->buffer_limit) -+ { -+ log_error(LOG_LEVEL_ERROR, "Out of memory decompressing iob"); -+ return JB_ERR_MEMORY; -+ } -+ -+ /* Try doubling the buffer size each time. */ -+ bufsize *= 2; -+ -+ /* Don't exceed the buffer limit. */ -+ if (bufsize > csp->config->buffer_limit) -+ { -+ bufsize = csp->config->buffer_limit; -+ } -+ -+ /* Try to allocate the new buffer. */ -+ tmpbuf = realloc(buf, bufsize); -+ if (NULL == tmpbuf) -+ { -+ log_error(LOG_LEVEL_ERROR, "Out of memory decompressing iob"); -+ freez(buf); -+ return JB_ERR_MEMORY; -+ } -+ else -+ { -+ char *oldnext_out = zstr.next_out; -+ -+ /* Update the fields for inflate() to use the new -+ * buffer, which may be in a different location from -+ * the old one. -+ */ -+ zstr.avail_out += bufsize - oldbufsize; -+ zstr.next_out = tmpbuf + bufsize - zstr.avail_out; -+ -+ /* Compare with an uglier method of calculating these values -+ * that doesn't require the extra oldbufsize variable. -+ */ -+ assert(zstr.avail_out == -+ tmpbuf + bufsize - (char *)zstr.next_out); -+ assert((char *)zstr.next_out == -+ tmpbuf + ((char *)oldnext_out - buf)); -+ assert(zstr.avail_out > 0); -+ -+ buf = tmpbuf; -+ } -+ } -+ -+ inflateEnd(&zstr); -+ if (status != Z_STREAM_END) -+ { -+ /* We failed to decompress the stream. */ -+ log_error(LOG_LEVEL_ERROR, -+ "Error in decompressing to the buffer (iob): %s", -+ zstr.msg); -+ return JB_ERR_GENERIC; -+ } -+ -+ /* Finally, we can actually update the iob, since the -+ * decompression was successful. First, free the old -+ * buffer. -+ */ -+ freez(csp->iob->buf); -+ -+ /* Now, update the iob to use the new buffer. */ -+ csp->iob->buf = buf; -+ csp->iob->cur = csp->iob->buf + skip_size; -+ csp->iob->eod = zstr.next_out; -+ csp->iob->size = bufsize; -+ -+ /* Make sure the new uncompressed iob obeys some minimal -+ * consistency conditions. -+ */ -+ if ((csp->iob->buf < csp->iob->cur) -+ && (csp->iob->cur <= csp->iob->eod) -+ && (csp->iob->eod <= csp->iob->buf + csp->iob->size)) -+ { -+ char t = csp->iob->cur[100]; -+ csp->iob->cur[100] = 0; -+ log_error(LOG_LEVEL_INFO, -+ "Sucessfully decompressed: %s", csp->iob->cur); -+ csp->iob->cur[100] = t; -+ return JB_ERR_OK; -+ } -+ else -+ { -+ /* It seems that zlib did something weird. */ -+ log_error(LOG_LEVEL_ERROR, -+ "Unexpected error decompressing the buffer (iob): %d==%d, %d>%d, %d<%d", csp->iob->cur, csp->iob->buf + skip_size, csp->iob->eod, csp->iob->buf, csp->iob->eod, csp->iob->buf + csp->iob->size); -+ return JB_ERR_GENERIC; -+ } -+ -+} -+#endif /* defined(FEATURE_ZLIB) */ -+ -+ - /********************************************************************* - * - * Function : get_header -@@ -937,13 +1216,59 @@ - *********************************************************************/ - jb_err server_content_encoding(struct client_state *csp, char **header) - { -+#ifdef FEATURE_ZLIB -+ if (strstr(*header, "gzip")) -+ { -+ /* -+ * If the body was modified, we have tried to -+ * decompress it, so adjust the header if necessary. -+ */ -+ if ((csp->flags & CSP_FLAG_MODIFIED) /* we attempted to decompress */ -+ && !(csp->content_type & CT_TABOO)) /* decompression was successful */ -+ { -+ freez(*header); -+ *header = strdup("Content-Encoding: identity"); -+ return (header == NULL) ? JB_ERR_MEMORY : JB_ERR_OK; -+ } -+ else -+ { -+ csp->content_type |= CT_GZIP; -+ } -+ } -+ else if (strstr(*header, "deflate")) -+ { -+ /* -+ * If the body was modified, we have tried to -+ * decompress it, so adjust the header if necessary. -+ */ -+ if ((csp->flags & CSP_FLAG_MODIFIED) /* we attempted to decompress */ -+ && !(csp->content_type & CT_TABOO)) /* decompression was successful */ -+ { -+ freez(*header); -+ *header = strdup("Content-Encoding: identity"); -+ return (header == NULL) ? JB_ERR_MEMORY : JB_ERR_OK; -+ } -+ else -+ { -+ csp->content_type |= CT_DEFLATE; -+ } -+ } -+ else if (strstr(*header, "compress")) -+ { -+ /* We can't decompress this; therefore we can't filter -+ * it either. -+ */ -+ csp->content_type |= CT_TABOO; -+ } -+#else /* !defined(FEATURE_GZIP) */ - /* - * Turn off pcrs and gif filtering if body compressed - */ - if (strstr(*header, "gzip") || strstr(*header, "compress") || strstr(*header, "deflate")) - { -- csp->content_type = CT_TABOO; -+ csp->content_type |= CT_TABOO; - } -+#endif /* !defined(FEATURE_GZIP) */ - - return JB_ERR_OK; - -diff -Nru privoxy-3.0.3-stable.orig/parsers.h privoxy-3.0.3-stable/parsers.h ---- privoxy-3.0.3-stable.orig/parsers.h 2002-09-25 17:52:46.000000000 +0300 -+++ privoxy-3.0.3-stable/parsers.h 2005-02-27 01:01:23.079736680 +0200 -@@ -194,6 +194,7 @@ - - extern int flush_socket(jb_socket fd, struct client_state *csp); - extern jb_err add_to_iob(struct client_state *csp, char *buf, int n); -+extern jb_err decompress_iob(struct client_state *csp); - extern char *get_header(struct client_state *csp); - extern char *get_header_value(const struct list *header_list, const char *header_name); - extern char *sed(const struct parsers pats[], const add_header_func_ptr more_headers[], struct client_state *csp); -diff -Nru privoxy-3.0.3-stable.orig/project.h privoxy-3.0.3-stable/project.h ---- privoxy-3.0.3-stable.orig/project.h 2004-01-30 17:29:29.000000000 +0200 -+++ privoxy-3.0.3-stable/project.h 2005-02-27 01:01:23.081736376 +0200 -@@ -818,6 +818,15 @@ - #define CT_TABOO 4 /**< csp->content_type bitmask: - DO NOT filter, irrespective of other flags. */ - -+/* Although these are not, strictly speaking, content types -+ * (they are content encodings), it is simple to handle -+ * them as such. -+ */ -+#define CT_GZIP 8 /**< csp->content_type bitmask: -+ gzip-compressed data. */ -+#define CT_DEFLATE 16 /**< csp->content_type bitmask: -+ zlib-compressed data. */ -+ - /** - * The mask which includes all actions. - */ -@@ -862,6 +871,8 @@ - #define ACTION_VANILLA_WAFER 0x00008000UL - /** Action bitmap: Limit CONNECT requests to safe ports. */ - #define ACTION_LIMIT_CONNECT 0x00010000UL -+/** Action bitmap: Uncompress incoming text for filtering. */ -+#define ACTION_DECOMPRESS_IN 0x00020000UL - - /** Action string index: How to deanimate GIFs */ - #define ACTION_STRING_DEANIMATE 0 diff --git a/net-proxy/privoxy/files/privoxy.rc7 b/net-proxy/privoxy/files/privoxy.initd index b06d990b273d..279a1f1abbbb 100644 --- a/net-proxy/privoxy/files/privoxy.rc7 +++ b/net-proxy/privoxy/files/privoxy.initd @@ -1,7 +1,7 @@ #!/sbin/runscript # Copyright 1999-2004 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/net-proxy/privoxy/files/privoxy.rc7,v 1.1 2005/04/22 19:15:11 mrness Exp $ +# $Header: /var/cvsroot/gentoo-x86/net-proxy/privoxy/files/privoxy.initd,v 1.1 2007/06/17 07:06:38 mrness Exp $ depend() { need net |