mirror of
https://github.com/rkd77/elinks.git
synced 2025-01-03 14:57:44 -05:00
Content-Encoding: deflate means neither zlib nor gzip header.
deflate.c used to call inflateInit2(stream, MAX_WBITS + 32). This makes zlib first check for a gzip header, and if it doesn't find one, assume a zlib header. However, if the server said "Content-Encoding: deflate", then neither header is there, and zlib does not detect this automatically. So ELinks has to distinguish between the gzip and deflate encodings, and tell zlib which one was meant. This bug resulted in blank pages at blogs.msdn.com accessed through proxy.suomi.net.
This commit is contained in:
parent
6139c2ffb5
commit
3aecdfc095
@ -38,7 +38,7 @@ struct deflate_enc_data {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static int
|
static int
|
||||||
deflate_open(struct stream_encoded *stream, int fd)
|
deflate_open(int window_size, struct stream_encoded *stream, int fd)
|
||||||
{
|
{
|
||||||
/* A zero-initialized z_stream. The compiler ensures that all
|
/* A zero-initialized z_stream. The compiler ensures that all
|
||||||
* pointer members in it are null. (Can't do this with memset
|
* pointer members in it are null. (Can't do this with memset
|
||||||
@ -60,7 +60,7 @@ deflate_open(struct stream_encoded *stream, int fd)
|
|||||||
data->fdread = fd;
|
data->fdread = fd;
|
||||||
data->last_read = 0;
|
data->last_read = 0;
|
||||||
|
|
||||||
err = inflateInit2(&data->deflate_stream, MAX_WBITS | 32);
|
err = inflateInit2(&data->deflate_stream, window_size);
|
||||||
if (err != Z_OK) {
|
if (err != Z_OK) {
|
||||||
mem_free(data);
|
mem_free(data);
|
||||||
return -1;
|
return -1;
|
||||||
@ -70,6 +70,20 @@ deflate_open(struct stream_encoded *stream, int fd)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
deflate_raw_open(struct stream_encoded *stream, int fd)
|
||||||
|
{
|
||||||
|
/* raw DEFLATE with neither zlib nor gzip header */
|
||||||
|
return deflate_open(-MAX_WBITS, stream, fd);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
deflate_gzip_open(struct stream_encoded *stream, int fd)
|
||||||
|
{
|
||||||
|
/* detect gzip header, else assume zlib header */
|
||||||
|
return deflate_open(MAX_WBITS + 32, stream, fd);
|
||||||
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
deflate_read(struct stream_encoded *stream, unsigned char *buf, int len)
|
deflate_read(struct stream_encoded *stream, unsigned char *buf, int len)
|
||||||
{
|
{
|
||||||
@ -117,7 +131,7 @@ deflate_read(struct stream_encoded *stream, unsigned char *buf, int len)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static unsigned char *
|
static unsigned char *
|
||||||
deflate_decode_buffer(unsigned char *data, int len, int *new_len)
|
deflate_decode_buffer(int window_size, unsigned char *data, int len, int *new_len)
|
||||||
{
|
{
|
||||||
z_stream stream;
|
z_stream stream;
|
||||||
unsigned char *buffer = NULL;
|
unsigned char *buffer = NULL;
|
||||||
@ -130,7 +144,7 @@ deflate_decode_buffer(unsigned char *data, int len, int *new_len)
|
|||||||
stream.next_in = data;
|
stream.next_in = data;
|
||||||
stream.avail_in = len;
|
stream.avail_in = len;
|
||||||
|
|
||||||
if (inflateInit2(&stream, MAX_WBITS | 32) != Z_OK)
|
if (inflateInit2(&stream, window_size) != Z_OK)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
@ -165,6 +179,20 @@ deflate_decode_buffer(unsigned char *data, int len, int *new_len)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static unsigned char *
|
||||||
|
deflate_raw_decode_buffer(unsigned char *data, int len, int *new_len)
|
||||||
|
{
|
||||||
|
/* raw DEFLATE with neither zlib nor gzip header */
|
||||||
|
return deflate_decode_buffer(-MAX_WBITS, data, len, new_len);
|
||||||
|
}
|
||||||
|
|
||||||
|
static unsigned char *
|
||||||
|
deflate_gzip_decode_buffer(unsigned char *data, int len, int *new_len)
|
||||||
|
{
|
||||||
|
/* detect gzip header, else assume zlib header */
|
||||||
|
return deflate_decode_buffer(MAX_WBITS + 32, data, len, new_len);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
deflate_close(struct stream_encoded *stream)
|
deflate_close(struct stream_encoded *stream)
|
||||||
{
|
{
|
||||||
@ -183,9 +211,9 @@ static const unsigned char *const deflate_extensions[] = { NULL };
|
|||||||
const struct decoding_backend deflate_decoding_backend = {
|
const struct decoding_backend deflate_decoding_backend = {
|
||||||
"deflate",
|
"deflate",
|
||||||
deflate_extensions,
|
deflate_extensions,
|
||||||
deflate_open,
|
deflate_raw_open,
|
||||||
deflate_read,
|
deflate_read,
|
||||||
deflate_decode_buffer,
|
deflate_raw_decode_buffer,
|
||||||
deflate_close,
|
deflate_close,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -194,8 +222,8 @@ static const unsigned char *const gzip_extensions[] = { ".gz", ".tgz", NULL };
|
|||||||
const struct decoding_backend gzip_decoding_backend = {
|
const struct decoding_backend gzip_decoding_backend = {
|
||||||
"gzip",
|
"gzip",
|
||||||
gzip_extensions,
|
gzip_extensions,
|
||||||
deflate_open,
|
deflate_gzip_open,
|
||||||
deflate_read,
|
deflate_read,
|
||||||
deflate_decode_buffer,
|
deflate_gzip_decode_buffer,
|
||||||
deflate_close,
|
deflate_close,
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user