aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorDaniel Stenberg <daniel@haxx.se>2003-05-15 22:28:19 +0000
committerDaniel Stenberg <daniel@haxx.se>2003-05-15 22:28:19 +0000
commit465de793e8a6c7a6f546f1de84aaf5476c5e89e6 (patch)
treec14e4b5d1da59df6314c6989995b25dd7d3cfc16 /lib
parentde9b76cef0c74ab4191ed54fa0c8811afd23c867 (diff)
Skip any preceeding dots from the domain name of cookies when we keep them
in memory, only add it when we save the cookie. This makes all tailmatching and domain string matching internally a lot easier. This was also the reason for a remaining bug I introduced in my overhaul.
Diffstat (limited to 'lib')
-rw-r--r--lib/cookie.c24
1 files changed, 12 insertions, 12 deletions
diff --git a/lib/cookie.c b/lib/cookie.c
index 2bd41bc3b..b0206f623 100644
--- a/lib/cookie.c
+++ b/lib/cookie.c
@@ -234,24 +234,29 @@ Curl_cookie_add(struct CookieInfo *c,
break;
}
}
- if(dotcount < 3)
+ if(dotcount < 3) {
/* Received and skipped a cookie with a domain using too few
dots. */
badcookie=TRUE; /* mark this as a bad cookie */
+ }
else {
/* Now, we make sure that our host is within the given domain,
or the given domain is not valid and thus cannot be set. */
if(!domain || tailmatch(whatptr, domain)) {
- co->domain=strdup(whatptr);
+ char *ptr=whatptr;
+ if(ptr[0] == '.')
+ ptr++;
+ co->domain=strdup(ptr); /* dont prefix with dots internally */
co->tailmatch=TRUE; /* we always do that if the domain name was
given */
}
- else
+ else {
/* we did not get a tailmatch and then the attempted set domain
is not a domain to which the current host belongs. Mark as
bad. */
badcookie=TRUE;
+ }
}
}
else if(strequal("version", name)) {
@@ -381,6 +386,8 @@ Curl_cookie_add(struct CookieInfo *c,
ptr=strtok_r(NULL, "\t", &tok_buf), fields++) {
switch(fields) {
case 0:
+ if(ptr[0]=='.') /* skip preceeding dots */
+ ptr++;
co->domain = strdup(ptr);
break;
case 1:
@@ -453,14 +460,8 @@ Curl_cookie_add(struct CookieInfo *c,
/* the names are identical */
if(clist->domain && co->domain) {
- if(strequal(clist->domain, co->domain) ||
- (co->tailmatch && /* only do the dot magic if tailmatching is OK */
- ((clist->domain[0]=='.' &&
- strequal(&(clist->domain[1]), co->domain)) ||
- (co->domain[0]=='.' &&
- strequal(clist->domain, &(co->domain[1]))))) )
- /* The domains are identical, or at least identical if you skip the
- preceeding dot */
+ if(strequal(clist->domain, co->domain))
+ /* The domains are identical */
replace_old=TRUE;
}
else if(!clist->domain && !co->domain)
@@ -550,7 +551,6 @@ Curl_cookie_add(struct CookieInfo *c,
}
c->numcookies++; /* one more cookie in the jar */
-
return co;
}