projects
/
yaz-moved-to-github.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
yaz_url_exec: mangle headers HOST/User-Agent
[yaz-moved-to-github.git]
/
src
/
comstack.c
diff --git
a/src/comstack.c
b/src/comstack.c
index
cec2fd3
..
eac17f7
100644
(file)
--- a/
src/comstack.c
+++ b/
src/comstack.c
@@
-1,5
+1,5
@@
/* This file is part of the YAZ toolkit.
/* This file is part of the YAZ toolkit.
- * Copyright (C) 1995-2012 Index Data
+ * Copyright (C) 1995-2013 Index Data
* See the file LICENSE for details.
*/
/**
* See the file LICENSE for details.
*/
/**
@@
-126,11
+126,6
@@
static int cs_parse_host(const char *uri, const char **host,
(*connect_host)[len] = '\0';
uri = cp + 1;
}
(*connect_host)[len] = '\0';
uri = cp + 1;
}
- else
- {
- *connect_host = xstrdup(uri);
- uri += strlen(uri); /* set to "" */
- }
#ifdef WIN32
return 0;
#else
#ifdef WIN32
return 0;
#else
@@
-195,7
+190,22
@@
COMSTACK cs_create_host_proxy(const char *vhost, int blocking, void **vp,
char *connect_host = 0;
if (!cs_parse_host(vhost, &host, &t, &proto, &connect_host))
char *connect_host = 0;
if (!cs_parse_host(vhost, &host, &t, &proto, &connect_host))
+ {
+ xfree(connect_host);
return 0;
return 0;
+ }
+
+ if (proxy_host)
+ {
+ enum oid_proto proto1;
+
+ xfree(connect_host);
+ if (!cs_parse_host(proxy_host, &host, &t, &proto1, &connect_host))
+ {
+ xfree(connect_host);
+ return 0;
+ }
+ }
if (t == tcpip_type)
{
if (t == tcpip_type)
{
@@
-207,8
+217,6
@@
COMSTACK cs_create_host_proxy(const char *vhost, int blocking, void **vp,
}
if (cs)
{
}
if (cs)
{
- if (proxy_host)
- host = proxy_host;
if (!(*vp = cs_straddr(cs, connect_host ? connect_host : host)))
{
cs_close (cs);
if (!(*vp = cs_straddr(cs, connect_host ? connect_host : host)))
{
cs_close (cs);
@@
-253,8
+261,8
@@
static int cs_read_chunk(const char *buf, int i, int len)
#if CHUNK_DEBUG
if (i < len-2)
{
#if CHUNK_DEBUG
if (i < len-2)
{
- printf ("\n<<<");
int j;
int j;
+ printf ("\n<<<");
for (j = i; j <= i+3; j++)
printf ("%c", buf[j]);
printf (">>>\n");
for (j = i; j <= i+3; j++)
printf ("%c", buf[j]);
printf (">>>\n");
@@
-323,22
+331,40
@@
static int cs_read_chunk(const char *buf, int i, int len)
static int cs_complete_http(const char *buf, int len, int head_only)
{
/* deal with HTTP request/response */
static int cs_complete_http(const char *buf, int len, int head_only)
{
/* deal with HTTP request/response */
- int i = 2, content_len = 0, chunked = 0;
+ int i, content_len = 0, chunked = 0;
- if (len < 6)
- return 0;
+ /* need at least one line followed by \n or \r .. */
+ for (i = 0; ; i++)
+ if (i == len)
+ return 0; /* incomplete */
+ else if (buf[i] == '\n' || buf[i] == '\r')
+ break;
- /* if dealing with HTTP responses - then default
- content length is unlimited (socket close) */
+ /* check to see if it's a response with content */
if (!head_only && !memcmp(buf, "HTTP/", 5))
if (!head_only && !memcmp(buf, "HTTP/", 5))
- content_len = -1;
-
+ {
+ int j;
+ for (j = 5; j < i; j++)
+ if (buf[j] == ' ')
+ {
+ ++j;
+ if (buf[j] == '1') /* 1XX */
+ ;
+ else if (!memcmp(buf + j, "204", 3))
+ ;
+ else if (!memcmp(buf + j, "304", 3))
+ ;
+ else
+ content_len = -1;
+ break;
+ }
+ }
#if 0
printf("len = %d\n", len);
fwrite (buf, 1, len, stdout);
printf("----------\n");
#endif
#if 0
printf("len = %d\n", len);
fwrite (buf, 1, len, stdout);
printf("----------\n");
#endif
- while (i <= len-2)
+ for (i = 2; i <= len-2; )
{
if (i > 8192)
{
{
if (i > 8192)
{