PR: bin/8250

protect against buffer overruns in mail temporary files.
This commit is contained in:
thepish 1998-10-10 09:58:20 +00:00
parent bcaad08a69
commit baece423c7
7 changed files with 24 additions and 14 deletions

View File

@ -77,7 +77,7 @@ collect(hp, printheaders)
int lc, cc, escape, eofcount;
register int c, t;
char linebuf[LINESIZE], *cp;
extern char tempMail[];
extern char *tempMail;
char getsub;
int omask;
void collint(), collhup(), collstop();
@ -472,7 +472,7 @@ mespipe(fp, cmd)
{
FILE *nf;
sig_t sigint = signal(SIGINT, SIG_IGN);
extern char tempEdit[];
extern char *tempEdit;
char *shell;
if ((nf = Fopen(tempEdit, "w+")) == NULL) {
@ -521,7 +521,7 @@ forward(ms, fp, f)
int f;
{
register int *msgvec;
extern char tempMail[];
extern char *tempMail;
struct ignoretab *ig;
char *tabst;

View File

@ -148,7 +148,7 @@ run_editor(fp, size, type, readonly)
time_t modtime;
char *edit;
struct stat statb;
extern char tempEdit[];
extern char *tempEdit;
if ((t = creat(tempEdit, readonly ? 0400 : 0600)) < 0) {
perror(tempEdit);

View File

@ -64,12 +64,13 @@ setfile(name)
char isedit = *name != '%';
char *who = name[1] ? name + 1 : myname;
static int shudclob;
extern char tempMesg[];
extern char *tempMesg;
extern int errno;
if ((name = expand(name)) == NOSTR)
return -1;
fprintf(stderr,">%s\n",name);
if ((ibuf = Fopen(name, "r")) == NULL) {
if (!isedit && errno == ENOENT)
goto nomail;

View File

@ -223,7 +223,7 @@ outof(names, fo, hp)
char *date, *fname, *ctime();
FILE *fout, *fin;
int ispipe;
extern char tempEdit[];
extern char *tempEdit;
top = names;
np = names;

View File

@ -72,7 +72,7 @@ quit()
FILE *ibuf, *obuf, *fbuf, *rbuf, *readstat, *abuf;
register struct message *mp;
register int c;
extern char tempQuit[], tempResid[];
extern char *tempQuit, *tempResid;
struct stat minfo;
char *mbox;

View File

@ -428,7 +428,7 @@ infix(hp, fi)
struct header *hp;
FILE *fi;
{
extern char tempMail[];
extern char *tempMail;
register FILE *nfo, *nfi;
register int c;

View File

@ -36,7 +36,7 @@
static char sccsid[] = "@(#)temp.c 8.1 (Berkeley) 6/6/93";
#endif
static const char rcsid[] =
"$Id$";
"$Id: temp.c,v 1.3 1997/07/24 06:56:33 charnier Exp $";
#endif /* not lint */
#include "rcv.h"
@ -49,11 +49,11 @@ static const char rcsid[] =
* Give names to all the temporary files that we will need.
*/
char tempMail[24];
char tempQuit[24];
char tempEdit[24];
char tempResid[24];
char tempMesg[24];
char *tempMail;
char *tempQuit;
char *tempEdit;
char *tempResid;
char *tempMesg;
char *tmpdir;
void
@ -74,14 +74,23 @@ tinit()
tmpdir = cp;
}
tempMail=(char *)malloc(len+sizeof("RsXXXXXX"));
strcpy(tempMail, tmpdir);
mktemp(strcat(tempMail, "RsXXXXXX"));
tempResid=(char *)malloc(len+sizeof("RqXXXXXX"));
strcpy(tempResid, tmpdir);
mktemp(strcat(tempResid, "RqXXXXXX"));
tempQuit=(char *)malloc(len+sizeof("RmXXXXXX"));
strcpy(tempQuit, tmpdir);
mktemp(strcat(tempQuit, "RmXXXXXX"));
tempEdit=(char *)malloc(len+sizeof("ReXXXXXX"));
strcpy(tempEdit, tmpdir);
mktemp(strcat(tempEdit, "ReXXXXXX"));
tempMesg=(char *)malloc(len+sizeof("RxXXXXXX"));
strcpy(tempMesg, tmpdir);
mktemp(strcat(tempMesg, "RxXXXXXX"));