[w3m-dev 03644] Re: Other user can see local cookie.
* cookie.c (save_cookies): return if no_rc_dir * etc.c (tmpf_base): add cookie (tmpfname): use tmp_dir instead of rc_dir * file.c (loadGeneralFile): cookie is not passed via URL * fm.h (TMPF_COOKIE): incl (MAX_TMPF_TYPE): incl (no_rc_dir): added (tmp_dir): added (config_file): added * local.c (Local_cookie_file): added (writeLocalCookie): added (setLocalCookie): dont set environment LOCAL_COOKIE (localcgi_post): writeLocalCookie (localcgi_get): writeLocalCookie * main.c (config_filename): deleted (cmd_loadURL): arg FormList (main): rewrite config_file, rc (ldhelp): no cookie in URL (cmd_loadURL): arg FormList (goURL0): cmd_loadURL change (cmd_loadBuffer): cmd_loadURL change (adBmark): cookie is posted (follow_map): cmd_loadURL change (linkMn): cmd_loadURL change (reinit): init_rc change * proto.h (create_option_search_table): deleted (init_rc): no args * rc.c (create_option_search_table): static (init_rc): no args rewrite (optionpanel_src1): rewrite (load_option_panel): html_quote (panel_set_option): no_rc_dir * w3mbookmark.c: rewrite * w3mhelperpanel.c: rewrite * scripts/dirlist.cgi.in: rewrite * scripts/w3mhelp.cgi.in: rewrite * scripts/w3mmail.cgi.in: rewrite * scripts/multipart/multipart.cgi.in: rewrite From: Hironori SAKAMOTO <hsaka@mth.biglobe.ne.jp>
This commit is contained in:
@@ -1,7 +1,8 @@
|
||||
/* $Id: w3mhelperpanel.c,v 1.10 2002/11/26 18:03:29 ukai Exp $ */
|
||||
/* $Id: w3mhelperpanel.c,v 1.11 2003/01/15 17:13:22 ukai Exp $ */
|
||||
#include <errno.h>
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include "config.h"
|
||||
#include "Str.h"
|
||||
#include "indep.h"
|
||||
@@ -18,7 +19,7 @@
|
||||
#define MSG_DELETE "<22><><EFBFBD><EFBFBD>"
|
||||
#define MSG_DOIT "<22>¹<EFBFBD>"
|
||||
#else /* LANG != JA */
|
||||
#define MSG_TITLE "External Viewers"
|
||||
#define MSG_TITLE "External Viewers Setup"
|
||||
#define MSG_NEW_ENTRY "New Entry"
|
||||
#define MSG_TYPE "Type"
|
||||
#define MSG_COMMAND "Command"
|
||||
@@ -81,32 +82,33 @@ printMailcapPanel(char *mailcap)
|
||||
}
|
||||
}
|
||||
printf("Content-Type: text/html\n\n");
|
||||
printf
|
||||
("<html><head><title>External Viewer Setup</title></head><body><h1>%s</h1>\n",
|
||||
MSG_TITLE);
|
||||
printf("<form method=get action=\"file:///$LIB/" W3MHELPERPANEL_CMDNAME
|
||||
printf("<html>\n<head>\n<title>%s</title>\n</head>\n<body>\n<h1>%s</h1>\n",
|
||||
MSG_TITLE, MSG_TITLE);
|
||||
printf("<form method=post action=\"file:///$LIB/" W3MHELPERPANEL_CMDNAME
|
||||
"\">\n");
|
||||
printf("<input type=hidden name=mode value=edit>\n");
|
||||
printf("<input type=hidden name=cookie value=\"%s\">\n", local_cookie);
|
||||
printf
|
||||
("%s: %s=<input type=text name=newtype><br>%s=<input type=text name=newcmd><br><input type=submit name=submit value=\"%s\">\n",
|
||||
MSG_NEW_ENTRY, MSG_TYPE, MSG_COMMAND, MSG_REGISTER);
|
||||
printf
|
||||
("<p><hr width=50%%><p><table border='0' cellpadding='0'><tr><th> <th><b>%s</b><th><b>%s</b>\n",
|
||||
MSG_TYPE, MSG_COMMAND);
|
||||
printf("<input type=hidden name=cookie value=\"%s\">\n",
|
||||
html_quote(local_cookie));
|
||||
printf("<table>\n<tr><td>%s:<td>%s=<input type=text name=newtype size=40>\n\
|
||||
<tr><td><td>%s=<input type=text name=newcmd size=40>\n\
|
||||
<tr><td><input type=submit name=submit value=\"%s\">\n</table>\n",
|
||||
MSG_NEW_ENTRY, MSG_TYPE, MSG_COMMAND, MSG_REGISTER);
|
||||
printf("<p><hr width=50%%><p>\n<table border='0' cellpadding='0'>\n\
|
||||
<tr><th align=left><b>%s</b><th><b>%s</b>\n",
|
||||
MSG_TYPE, MSG_COMMAND);
|
||||
while (tmp = Strfgets(f), tmp->length > 0) {
|
||||
if (tmp->ptr[0] == '#')
|
||||
continue;
|
||||
Strchop(tmp);
|
||||
extractMailcapEntry(tmp->ptr, &type, &viewer);
|
||||
printf("<tr valign=top><td><td>%s<td>%s<td>", html_quote(type),
|
||||
printf("<tr valign=top><td>%s<td>%s<td nowrap>", html_quote(type),
|
||||
html_quote(viewer));
|
||||
printf("<input type=checkbox name=delete value=\"%s\">%s\n",
|
||||
html_quote(type), MSG_DELETE);
|
||||
}
|
||||
printf
|
||||
("</table><input type=submit name=submit value=\"%s\"></form></body></html>\n",
|
||||
MSG_DOIT);
|
||||
printf("</table>\n<input type=submit name=submit value=\"%s\">\n</form>\n\
|
||||
</body>\n</html>\n",
|
||||
MSG_DOIT);
|
||||
}
|
||||
|
||||
void
|
||||
@@ -159,17 +161,34 @@ main(int argc, char *argv[], char **envp)
|
||||
{
|
||||
Str mailcapfile;
|
||||
extern char *getenv();
|
||||
char *qs;
|
||||
char *p;
|
||||
int length;
|
||||
Str qs = NULL;
|
||||
struct parsed_tagarg *cgiarg;
|
||||
char *mode;
|
||||
char *sent_cookie;
|
||||
|
||||
if ((qs = getenv("QUERY_STRING")) == NULL)
|
||||
exit(1);
|
||||
p = getenv("REQUEST_METHOD");
|
||||
if (p == NULL || strcasecmp(p, "post"))
|
||||
goto request_err;
|
||||
p = getenv("CONTENT_LENGTH");
|
||||
if (p == NULL || (length = atoi(p)) <= 0)
|
||||
goto request_err;
|
||||
|
||||
cgiarg = cgistr2tagarg(qs);
|
||||
qs = Strfgets(stdin);
|
||||
Strchop(qs);
|
||||
if (qs->length != length)
|
||||
goto request_err;
|
||||
cgiarg = cgistr2tagarg(qs->ptr);
|
||||
|
||||
local_cookie = getenv("LOCAL_COOKIE");
|
||||
p = getenv("LOCAL_COOKIE_FILE");
|
||||
if (p) {
|
||||
FILE *f = fopen(p, "r");
|
||||
if (f) {
|
||||
local_cookie = Strfgets(f)->ptr;
|
||||
fclose(f);
|
||||
}
|
||||
}
|
||||
sent_cookie = tag_get_value(cgiarg, "cookie");
|
||||
if (local_cookie == NULL || sent_cookie == NULL ||
|
||||
strcmp(local_cookie, sent_cookie) != 0) {
|
||||
@@ -178,8 +197,7 @@ main(int argc, char *argv[], char **envp)
|
||||
}
|
||||
|
||||
mode = tag_get_value(cgiarg, "mode");
|
||||
mailcapfile = Strnew_charp(expandPath(RC_DIR));
|
||||
Strcat_charp(mailcapfile, "/mailcap");
|
||||
mailcapfile = Strnew_charp(expandPath(USER_MAILCAP));
|
||||
if (mode && !strcmp(mode, "edit")) {
|
||||
char *referer;
|
||||
/* check if I can edit my mailcap */
|
||||
@@ -198,4 +216,8 @@ main(int argc, char *argv[], char **envp)
|
||||
printMailcapPanel(mailcapfile->ptr);
|
||||
}
|
||||
return 0;
|
||||
|
||||
request_err:
|
||||
bye("Incomplete Request:", qs ? qs->ptr : "(null)");
|
||||
exit(1);
|
||||
}
|
||||
|
Reference in New Issue
Block a user