aboutsummaryrefslogtreecommitdiff
path: root/lib/cookie.c
diff options
context:
space:
mode:
authorDaniel Stenberg <daniel@haxx.se>2001-08-29 09:32:18 +0000
committerDaniel Stenberg <daniel@haxx.se>2001-08-29 09:32:18 +0000
commita2b6ef3478e2c37982521a326ea7b90d856adc8c (patch)
treedf983e69378b723011fcfdc6c130f2964278e149 /lib/cookie.c
parentb6526af442e547cd6e234efef5121d481b1eb103 (diff)
cookie jar adjustments
Diffstat (limited to 'lib/cookie.c')
-rw-r--r--lib/cookie.c99
1 files changed, 60 insertions, 39 deletions
diff --git a/lib/cookie.c b/lib/cookie.c
index b9acb944b..f303363d8 100644
--- a/lib/cookie.c
+++ b/lib/cookie.c
@@ -384,6 +384,8 @@ Curl_cookie_add(struct CookieInfo *c,
c->cookies = co;
}
+ c->numcookies++; /* one more cookie in the jar */
+
return co;
}
@@ -584,67 +586,86 @@ void Curl_cookie_cleanup(struct CookieInfo *c)
}
}
-#ifdef COOKIE /* experiemental functions for the upcoming cookie jar stuff */
-
/*
- * On my Solaris box, this command line builds this test program:
+ * Curl_cookie_output()
*
- * gcc -g -o cooktest -DCOOKIE=1 -DHAVE_CONFIG_H -I.. -I../include cookie.c strequal.o getdate.o memdebug.o mprintf.o strtok.o -lnsl -lsocket
+ * Writes all internally known cookies to the specified file. Specify
+ * "-" as file name to write to stdout.
*
+ * The function returns non-zero on write failure.
*/
-
-void Curl_cookie_output(struct CookieInfo *c)
+int Curl_cookie_output(struct CookieInfo *c, char *dumphere)
{
struct Cookie *co;
- struct Cookie *next;
+ FILE *out;
+ bool use_stdout=FALSE;
+
+ if(0 == c->numcookies)
+ /* If there are no known cookies, we don't write or even create any
+ destination file */
+ return 0;
+
+ if(strequal("-", dumphere)) {
+ /* use stdout */
+ out = stdout;
+ use_stdout=TRUE;
+ }
+ else {
+ out = fopen(dumphere, "w");
+ if(!out)
+ return 1; /* failure */
+ }
+
if(c) {
-#if COOKIE > 1
- if(c->filename)
- printf("Got these cookies from: \"%s\"\n", c->filename);
-#else
- puts("# Netscape HTTP Cookie File\n"
- "# http://www.netscape.com/newsref/std/cookie_spec.html\n"
- "# This is generated by libcurl! Do not edit.\n");
-#endif
-
+ fputs("# Netscape HTTP Cookie File\n"
+ "# http://www.netscape.com/newsref/std/cookie_spec.html\n"
+ "# This is generated by libcurl! Edit on your own risk.\n\n",
+ out);
co = c->cookies;
while(co) {
-#if COOKIE > 1
- printf("Name: %s\n", co->name?co->name:"");
- printf(" Value: %s\n", co->value?co->value:"");
- printf(" Domain: %s\n", co->domain?co->domain:"");
- printf(" Path: %s\n", co->path?co->path:"");
- printf(" Expire: %s\n", co->expirestr?co->expirestr:"");
- printf(" Version: %s\n", co->version?co->version:"");
- printf(" Max-Age: %s\n\n", co->maxage?co->maxage:"");
-#endif
- printf("%s\t" /* domain */
- "%s\t" /* field1 */
- "%s\t" /* path */
- "%s\t" /* secure */
- "%d\t" /* expires */
- "%s\t" /* name */
- "%s\n", /* value */
- co->domain,
- co->field1==2?"TRUE":"FALSE",
- co->path,
- co->secure?"TRUE":"FALSE",
- co->expires,
- co->name,
- co->value);
+ fprintf(out,
+ "%s\t" /* domain */
+ "%s\t" /* field1 */
+ "%s\t" /* path */
+ "%s\t" /* secure */
+ "%u\t" /* expires */
+ "%s\t" /* name */
+ "%s\n", /* value */
+ co->domain,
+ co->field1==2?"TRUE":"FALSE",
+ co->path,
+ co->secure?"TRUE":"FALSE",
+ (unsigned int)co->expires,
+ co->name,
+ co->value);
co=co->next;
}
}
+
+ if(!use_stdout)
+ fclose(out);
+
+ return 0;
}
+#ifdef CURL_COOKIE_DEBUG
+
+/*
+ * On my Solaris box, this command line builds this test program:
+ *
+ * gcc -g -o cooktest -DCURL_COOKIE_DEBUG -DHAVE_CONFIG_H -I.. -I../include cookie.c strequal.o getdate.o memdebug.o mprintf.o strtok.o -lnsl -lsocket
+ *
+ */
+
int main(int argc, char **argv)
{
struct CookieInfo *c=NULL;
if(argc>1) {
c = Curl_cookie_init(argv[1], c);
Curl_cookie_add(c, TRUE, "PERSONALIZE=none;expires=Monday, 13-Jun-1988 03:04:55 GMT; domain=.fidelity.com; path=/ftgw; secure");
+ Curl_cookie_add(c, TRUE, "foobar=yes; domain=.haxx.se; path=/looser;");
c = Curl_cookie_init(argv[1], c);
Curl_cookie_output(c);