2006-12-19 00:17:04 +01:00
|
|
|
--- collect.c
|
2011-05-13 13:37:37 +02:00
|
|
|
+++ collect.c 2006-07-20 11:21:32.000000000 +0000
|
|
|
|
@@ -720,7 +720,7 @@ cont:
|
2006-12-19 00:17:04 +01:00
|
|
|
* Grab a bunch of headers.
|
|
|
|
*/
|
|
|
|
do
|
|
|
|
- grabh(hp, GTO|GSUBJECT|GCC|GBCC,
|
|
|
|
+ grabh(hp, GTO|GSUBJECT|GCC|GBCC|GREPLYTO,
|
|
|
|
value("bsdcompat") != NULL &&
|
|
|
|
value("bsdorder") != NULL);
|
|
|
|
while (hp->h_to == NULL);
|
2011-05-13 13:37:37 +02:00
|
|
|
@@ -743,13 +743,21 @@ cont:
|
2006-12-19 00:17:04 +01:00
|
|
|
break;
|
|
|
|
case 's':
|
|
|
|
/*
|
|
|
|
- * Set the Subject list.
|
|
|
|
+ * Set the Subject line.
|
|
|
|
*/
|
|
|
|
cp = &linebuf[2];
|
|
|
|
while (whitechar(*cp & 0377))
|
|
|
|
cp++;
|
|
|
|
hp->h_subject = savestr(cp);
|
|
|
|
break;
|
|
|
|
+ case 'R':
|
|
|
|
+ /*
|
|
|
|
+ * Add to the Reply-To list.
|
|
|
|
+ */
|
|
|
|
+ cp = &linebuf[2];
|
|
|
|
+ while ((hp->h_replyto = checkaddrs(cat(hp->h_replyto,
|
|
|
|
+ sextract(&linebuf[2], GREPLYTO|GFULL))))
|
|
|
|
+ == NULL);
|
|
|
|
case '@':
|
|
|
|
/*
|
|
|
|
* Edit the attachment list.
|
|
|
|
--- def.h
|
2011-05-13 13:37:37 +02:00
|
|
|
+++ def.h 2006-07-20 11:21:32.000000000 +0000
|
2006-12-19 00:17:04 +01:00
|
|
|
@@ -393,7 +393,7 @@ enum gfield {
|
|
|
|
GUA = 128, /* User-Agent field */
|
|
|
|
GMIME = 256, /* MIME 1.0 fields */
|
|
|
|
GMSGID = 512, /* a Message-ID */
|
|
|
|
- /* 1024 */ /* unused */
|
|
|
|
+ GREPLYTO= 1024, /* a Reply-To field */
|
|
|
|
GIDENT = 2048, /* From:, Reply-To: and Organization: field */
|
|
|
|
GREF = 4096, /* References: field */
|
|
|
|
GDATE = 8192, /* Date: field */
|
|
|
|
@@ -403,7 +403,7 @@ enum gfield {
|
|
|
|
GFILES = 131072 /* include filename addresses */
|
|
|
|
};
|
|
|
|
|
|
|
|
-#define GMASK (GTO|GSUBJECT|GCC|GBCC) /* Mask of places from whence */
|
|
|
|
+#define GMASK (GTO|GSUBJECT|GCC|GBCC|GREPLYTO) /* Mask of places from whence */
|
|
|
|
|
|
|
|
#define visible(mp) (((mp)->m_flag&(MDELETED|MHIDDEN|MKILL))==0|| \
|
|
|
|
dot==(mp) && (mp)->m_flag&MKILL)
|
|
|
|
--- extern.h
|
2011-05-13 13:37:37 +02:00
|
|
|
+++ extern.h 2011-05-13 09:07:33.891926124 +0000
|
|
|
|
@@ -457,7 +457,7 @@ int send(struct message *mp, FILE *obuf,
|
|
|
|
char *prefix, enum sendaction action, off_t *stats);
|
|
|
|
/* sendout.c */
|
2006-12-19 00:17:04 +01:00
|
|
|
char *makeboundary(void);
|
2011-05-13 13:37:37 +02:00
|
|
|
-int mail(struct name *to, struct name *cc, struct name *bcc,
|
|
|
|
+int mail(struct name *to, struct name *cc, struct name *bcc, struct name *replyto,
|
2006-12-19 00:17:04 +01:00
|
|
|
struct name *smopts, char *subject, struct attachment *attach,
|
2011-05-13 13:37:37 +02:00
|
|
|
char *quotefile, int recipient_record, int tflag, int Eflag);
|
2006-12-19 00:17:04 +01:00
|
|
|
int sendmail(void *v);
|
|
|
|
--- mailx.1
|
2011-05-13 13:37:37 +02:00
|
|
|
+++ mailx.1 2011-05-13 09:11:27.640426515 +0000
|
2006-12-19 00:17:04 +01:00
|
|
|
@@ -43,7 +43,7 @@ mailx \- send and receive Internet mail
|
|
|
|
.PD 0
|
|
|
|
.HP
|
|
|
|
.ad l
|
2011-05-13 13:37:37 +02:00
|
|
|
-\fBmailx\fR [\fB\-BDdEFintv~\fR]
|
|
|
|
+\fBmailx\fR [\fB\-BDdEFintv~\fR] [\fB\-R\fR [\fIaddress\fR]]
|
2006-12-19 00:17:04 +01:00
|
|
|
[\fB\-s\fI\ subject\fR] [\fB\-a\fI\ attachment\fR ]
|
|
|
|
[\fB\-c\fI\ cc-addr\fR] [\fB\-b\fI\ bcc-addr\fR] [\fB\-r\fI\ from-addr\fR]
|
|
|
|
[\fB\-h\fI\ hops\fR]
|
2011-05-13 13:37:37 +02:00
|
|
|
@@ -203,8 +203,12 @@ it is recommended to set the
|
2006-12-19 00:17:04 +01:00
|
|
|
.I from
|
|
|
|
variable directly instead.
|
|
|
|
.TP
|
|
|
|
+.BI \-R\ \fR|\fB\ \-R \ address
|
|
|
|
+Without any argument any folders will be opened read-only.
|
|
|
|
+With argument an reply-to adress is specifed on command line.
|
|
|
|
+Only the first argument after the
|
|
|
|
.B \-R
|
|
|
|
-Opens any folders read-only.
|
|
|
|
+flag is used as the address.
|
|
|
|
.TP
|
|
|
|
.BI \-s \ subject
|
|
|
|
Specify subject on command line (only the first argument after the
|
2011-05-13 13:37:37 +02:00
|
|
|
@@ -2131,6 +2135,9 @@ copying the message to
|
2006-12-19 00:17:04 +01:00
|
|
|
`dead.letter' in the user's home directory
|
|
|
|
if save is set.
|
|
|
|
.TP
|
|
|
|
+.BI ~R string
|
|
|
|
+Use string as the Reply-To field.
|
|
|
|
+.TP
|
|
|
|
.BI ~r filename
|
|
|
|
Read the named file into the message.
|
|
|
|
.TP
|
|
|
|
--- main.c
|
2011-05-13 13:37:37 +02:00
|
|
|
+++ main.c 2011-05-13 09:18:29.747926305 +0000
|
|
|
|
@@ -52,6 +52,11 @@ static char sccsid[] = "@(#)main.c 2.51
|
2006-12-19 00:17:04 +01:00
|
|
|
* Note: We set egid to realgid ... and only if we need the egid we will
|
|
|
|
* switch back temporary. Nevertheless, I do not like seg faults.
|
|
|
|
* Werner Fink, <werner@suse.de>
|
|
|
|
+ * ---
|
|
|
|
+ * We want to set reply-to on the command line to deal with antispam rules
|
|
|
|
+ * and adresses behind firewalls.
|
|
|
|
+ * 2000-07-19, poc@pocnet.net
|
|
|
|
+ * Changes by werner@suse.de (move Option r to R, make ~R work)
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2011-05-13 13:37:37 +02:00
|
|
|
@@ -87,9 +92,9 @@ static void setscreensize(int dummy);
|
2006-12-19 00:17:04 +01:00
|
|
|
int
|
|
|
|
main(int argc, char *argv[])
|
|
|
|
{
|
2011-05-13 13:37:37 +02:00
|
|
|
- const char optstr[] = "A:BHEFINVT:RS:a:b:c:dDefh:inqr:s:tu:v~";
|
|
|
|
+ const char optstr[] = "A:BHEFINVT:R::S:a:b:c:dDefh:inqr:s:tu:v~";
|
2006-12-19 00:17:04 +01:00
|
|
|
int i, existonly = 0, headersonly = 0, sendflag = 0;
|
|
|
|
- struct name *to, *cc, *bcc, *smopts;
|
2011-05-13 13:37:37 +02:00
|
|
|
+ struct name *to, *cc, *bcc, *replyto, *smopts;
|
2006-12-19 00:17:04 +01:00
|
|
|
struct attachment *attach;
|
|
|
|
char *subject, *cp, *ef, *qf = NULL, *fromaddr = NULL, *Aflag = NULL;
|
|
|
|
char nosrc = 0;
|
2011-05-13 13:37:37 +02:00
|
|
|
@@ -179,6 +184,8 @@ main(int argc, char *argv[])
|
2006-12-19 00:17:04 +01:00
|
|
|
attach = NULL;
|
|
|
|
smopts = NULL;
|
|
|
|
subject = NULL;
|
|
|
|
+ replyto = NULL;
|
|
|
|
+
|
|
|
|
while ((i = getopt(argc, argv, optstr)) != EOF) {
|
|
|
|
switch (i) {
|
|
|
|
case 'V':
|
2011-05-13 13:37:37 +02:00
|
|
|
@@ -348,12 +355,18 @@ main(int argc, char *argv[])
|
2006-12-19 00:17:04 +01:00
|
|
|
Aflag = optarg;
|
|
|
|
break;
|
2011-05-13 13:37:37 +02:00
|
|
|
case 'R':
|
|
|
|
- Rflag = 1;
|
2006-12-19 00:17:04 +01:00
|
|
|
+ /*
|
|
|
|
+ * Set the Reply-to Address (as who we send mail)
|
|
|
|
+ */
|
|
|
|
+ if (optarg && *optarg)
|
|
|
|
+ replyto = checkaddrs(cat(replyto, extract(optarg, GREPLYTO|GFULL)));
|
2011-05-13 13:37:37 +02:00
|
|
|
+ else
|
|
|
|
+ Rflag = 1;
|
2006-12-19 00:17:04 +01:00
|
|
|
break;
|
|
|
|
case '?':
|
|
|
|
usage:
|
|
|
|
fprintf(stderr, catgets(catd, CATSET, 135,
|
2011-05-13 13:37:37 +02:00
|
|
|
-"Usage: %s -eiIUdEFntBDNHRV~ -T FILE -u USER -h hops -r address -s SUBJECT -a FILE -q FILE -f FILE -A ACCOUNT -b USERS -c USERS -S OPTION users\n"), progname);
|
|
|
|
+"Usage: %s -eiIUdEFntBDNHV~ [-R [reply-address]] -T FILE -u USER -h hops -r address -s SUBJECT -a FILE -q FILE -f FILE -A ACCOUNT -b USERS -c USERS -S OPTION users\n"), progname);
|
2006-12-19 00:17:04 +01:00
|
|
|
exit(2);
|
|
|
|
}
|
|
|
|
}
|
2011-05-13 13:37:37 +02:00
|
|
|
@@ -387,6 +400,10 @@ usage:
|
2006-12-19 00:17:04 +01:00
|
|
|
fprintf(stderr, "The -R option is meaningless in send mode.\n");
|
|
|
|
goto usage;
|
|
|
|
}
|
|
|
|
+ if (replyto && to == NULL) {
|
|
|
|
+ fprintf(stderr, "The reply-to is meaningless not in send mode.\n");
|
|
|
|
+ goto usage;
|
|
|
|
+ }
|
|
|
|
if (Iflag && ef == NULL) {
|
|
|
|
fprintf(stderr, catgets(catd, CATSET, 204,
|
|
|
|
"Need -f with -I.\n"));
|
2011-05-13 13:37:37 +02:00
|
|
|
@@ -441,8 +458,8 @@ usage:
|
2006-12-19 00:17:04 +01:00
|
|
|
if (fromaddr)
|
|
|
|
assign("from", fromaddr);
|
|
|
|
if (!rcvmode) {
|
2011-05-13 13:37:37 +02:00
|
|
|
- mail(to, cc, bcc, smopts, subject, attach, qf, Fflag, tflag,
|
|
|
|
- Eflag);
|
|
|
|
+ mail(to, cc, bcc, replyto, smopts, subject, attach, qf,
|
|
|
|
+ Fflag, tflag, Eflag);
|
2006-12-19 00:17:04 +01:00
|
|
|
/*
|
|
|
|
* why wait?
|
|
|
|
*/
|
|
|
|
--- sendout.c
|
2011-05-13 13:37:37 +02:00
|
|
|
+++ sendout.c 2011-05-13 09:19:01.288426393 +0000
|
|
|
|
@@ -712,7 +712,7 @@ savemail(char *name, FILE *fi)
|
|
|
|
* which does all the dirty work.
|
|
|
|
*/
|
2006-12-19 00:17:04 +01:00
|
|
|
int
|
2011-05-13 13:37:37 +02:00
|
|
|
-mail(struct name *to, struct name *cc, struct name *bcc,
|
|
|
|
+mail(struct name *to, struct name *cc, struct name *bcc, struct name *replyto,
|
2006-12-19 00:17:04 +01:00
|
|
|
struct name *smopts, char *subject, struct attachment *attach,
|
2011-05-13 13:37:37 +02:00
|
|
|
char *quotefile, int recipient_record, int tflag, int Eflag)
|
2006-12-19 00:17:04 +01:00
|
|
|
{
|
2011-05-13 13:37:37 +02:00
|
|
|
@@ -731,6 +731,7 @@ mail(struct name *to, struct name *cc, s
|
2006-12-19 00:17:04 +01:00
|
|
|
head.h_to = to;
|
|
|
|
head.h_cc = cc;
|
|
|
|
head.h_bcc = bcc;
|
|
|
|
+ head.h_replyto = replyto;
|
|
|
|
}
|
|
|
|
head.h_attach = attach;
|
|
|
|
head.h_smopts = smopts;
|
|
|
|
--- tty.c
|
2011-05-13 13:37:37 +02:00
|
|
|
+++ tty.c 2006-07-20 11:21:39.000000000 +0000
|
2006-12-19 00:17:04 +01:00
|
|
|
@@ -338,6 +338,12 @@ grabh(struct header *hp, enum gfield gfl
|
|
|
|
hp->h_organization = rtty_internal("Organization: ",
|
|
|
|
hp->h_organization);
|
|
|
|
}
|
|
|
|
+ if (gflags & GREPLYTO) {
|
|
|
|
+ TTYSET_CHECK(hp->h_replyto)
|
|
|
|
+ hp->h_replyto = checkaddrs(sextract(rtty_internal("Reply-To: ",
|
|
|
|
+ detract(hp->h_replyto, comma)),
|
|
|
|
+ GREPLYTO|GFULL));
|
|
|
|
+ }
|
|
|
|
if (!subjfirst)
|
|
|
|
GRAB_SUBJECT
|
|
|
|
out:
|