diff options
author | TBK <tbk@jjtc.eu> | 2020-02-26 23:11:33 +0100 |
---|---|---|
committer | TBK <tbk@jjtc.eu> | 2020-03-23 15:19:06 +0100 |
commit | 1c31d3f269c706f7080c34510d9abac2d3ceee0a (patch) | |
tree | caa3b664c140ef32b20246dbe3cf0030d64bb1eb /community/heirloom-mailx | |
parent | b3885777f00606b1f3e553143ad336afa267a46e (diff) | |
download | aports-1c31d3f269c706f7080c34510d9abac2d3ceee0a.tar.bz2 aports-1c31d3f269c706f7080c34510d9abac2d3ceee0a.tar.xz |
community/heirloom-mailx: upgrade to 12.5
Diffstat (limited to 'community/heirloom-mailx')
15 files changed, 351 insertions, 1340 deletions
diff --git a/community/heirloom-mailx/0001-outof-Introduce-expandaddr-flag.patch b/community/heirloom-mailx/0001-outof-Introduce-expandaddr-flag.patch deleted file mode 100644 index c56e8a79a7..0000000000 --- a/community/heirloom-mailx/0001-outof-Introduce-expandaddr-flag.patch +++ /dev/null @@ -1,65 +0,0 @@ ->From 9984ae5cb0ea0d61df1612b06952a61323c083d9 Mon Sep 17 00:00:00 2001 -From: Florian Weimer <fweimer () redhat com> -Date: Mon, 17 Nov 2014 11:13:38 +0100 -Subject: [PATCH 1/4] outof: Introduce expandaddr flag - -Document that address expansion is disabled unless the expandaddr -binary option is set. - -This has been assigned CVE-2014-7844 for BSD mailx, but it is not -a vulnerability in Heirloom mailx because this feature was documented. ---- - mailx.1 | 14 ++++++++++++++ - names.c | 3 +++ - 2 files changed, 17 insertions(+) - -diff --git a/mailx.1 b/mailx.1 -index 70a7859..22a171b 100644 ---- a/mailx.1 -+++ b/mailx.1 -@@ -656,6 +656,14 @@ but any reply returned to the machine - will have the system wide alias expanded - as all mail goes through sendmail. - .SS "Recipient address specifications" -+If the -+.I expandaddr -+option is not set (the default), recipient addresses must be names of -+local mailboxes or Internet mail addresses. -+.PP -+If the -+.I expandaddr -+option is set, the following rules apply: - When an address is used to name a recipient - (in any of To, Cc, or Bcc), - names of local mail folders -@@ -2391,6 +2399,12 @@ and exits immediately. - If this option is set, - \fImailx\fR starts even with an empty mailbox. - .TP -+.B expandaddr -+Causes -+.I mailx -+to expand message recipient addresses, as explained in the section, -+Recipient address specifications. -+.TP - .B flipr - Exchanges the - .I Respond -diff --git a/names.c b/names.c -index 66e976b..c69560f 100644 ---- a/names.c -+++ b/names.c -@@ -268,6 +268,9 @@ outof(struct name *names, FILE *fo, struct header *hp) - FILE *fout, *fin; - int ispipe; - -+ if (value("expandaddr") == NULL) -+ return names; -+ - top = names; - np = names; - time(&now); --- -1.9.3 - - diff --git a/community/heirloom-mailx/0002-unpack-Disable-option-processing-for-email-addresses.patch b/community/heirloom-mailx/0002-unpack-Disable-option-processing-for-email-addresses.patch deleted file mode 100644 index 9baf6088a0..0000000000 --- a/community/heirloom-mailx/0002-unpack-Disable-option-processing-for-email-addresses.patch +++ /dev/null @@ -1,75 +0,0 @@ ->From e34e2ac67b80497080ebecccec40c3b61456167d Mon Sep 17 00:00:00 2001 -From: Florian Weimer <fweimer () redhat com> -Date: Mon, 17 Nov 2014 11:14:06 +0100 -Subject: [PATCH 2/4] unpack: Disable option processing for email addresses - when calling sendmail - ---- - extern.h | 2 +- - names.c | 8 ++++++-- - sendout.c | 2 +- - 3 files changed, 8 insertions(+), 4 deletions(-) - -diff --git a/extern.h b/extern.h -index 6b85ba0..8873fe8 100644 ---- a/extern.h -+++ b/extern.h -@@ -396,7 +396,7 @@ struct name *outof(struct name *names, FILE *fo, struct header *hp); - int is_fileaddr(char *name); - struct name *usermap(struct name *names); - struct name *cat(struct name *n1, struct name *n2); --char **unpack(struct name *np); -+char **unpack(struct name *smopts, struct name *np); - struct name *elide(struct name *names); - int count(struct name *np); - struct name *delete_alternates(struct name *np); -diff --git a/names.c b/names.c -index c69560f..45bbaed 100644 ---- a/names.c -+++ b/names.c -@@ -549,7 +549,7 @@ cat(struct name *n1, struct name *n2) - * Return an error if the name list won't fit. - */ - char ** --unpack(struct name *np) -+unpack(struct name *smopts, struct name *np) - { - char **ap, **top; - struct name *n; -@@ -564,7 +564,7 @@ unpack(struct name *np) - * the terminating 0 pointer. Additional spots may be needed - * to pass along -f to the host mailer. - */ -- extra = 2; -+ extra = 3 + count(smopts); - extra++; - metoo = value("metoo") != NULL; - if (metoo) -@@ -581,6 +581,10 @@ unpack(struct name *np) - *ap++ = "-m"; - if (verbose) - *ap++ = "-v"; -+ for (; smopts != NULL; smopts = smopts->n_flink) -+ if ((smopts->n_type & GDEL) == 0) -+ *ap++ = smopts->n_name; -+ *ap++ = "--"; - for (; n != NULL; n = n->n_flink) - if ((n->n_type & GDEL) == 0) - *ap++ = n->n_name; -diff --git a/sendout.c b/sendout.c -index 7b7f2eb..c52f15d 100644 ---- a/sendout.c -+++ b/sendout.c -@@ -835,7 +835,7 @@ start_mta(struct name *to, struct name *mailargs, FILE *input, - #endif /* HAVE_SOCKETS */ - - if ((smtp = value("smtp")) == NULL) { -- args = unpack(cat(mailargs, to)); -+ args = unpack(mailargs, to); - if (debug || value("debug")) { - printf(catgets(catd, CATSET, 181, - "Sendmail arguments:")); --- -1.9.3 - - diff --git a/community/heirloom-mailx/0003-fio_c-Unconditionally-require-wordexp-support.patch b/community/heirloom-mailx/0003-fio_c-Unconditionally-require-wordexp-support.patch deleted file mode 100644 index 05fe00f2cb..0000000000 --- a/community/heirloom-mailx/0003-fio_c-Unconditionally-require-wordexp-support.patch +++ /dev/null @@ -1,109 +0,0 @@ ->From 2bae8ecf04ec2ba6bb9f0af5b80485dd0edb427d Mon Sep 17 00:00:00 2001 -From: Florian Weimer <fweimer () redhat com> -Date: Mon, 17 Nov 2014 12:48:25 +0100 -Subject: [PATCH 3/4] fio.c: Unconditionally require wordexp support - ---- - fio.c | 67 +++++-------------------------------------------------------------- - 1 file changed, 5 insertions(+), 62 deletions(-) - -diff --git a/fio.c b/fio.c -index 65e8f10..1529236 100644 ---- a/fio.c -+++ b/fio.c -@@ -43,12 +43,15 @@ static char sccsid[] = "@(#)fio.c 2.76 (gritter) 9/16/09"; - #endif /* not lint */ - - #include "rcv.h" -+ -+#ifndef HAVE_WORDEXP -+#error wordexp support is required -+#endif -+ - #include <sys/stat.h> - #include <sys/file.h> - #include <sys/wait.h> --#ifdef HAVE_WORDEXP - #include <wordexp.h> --#endif /* HAVE_WORDEXP */ - #include <unistd.h> - - #if defined (USE_NSS) -@@ -481,7 +484,6 @@ next: - static char * - globname(char *name) - { --#ifdef HAVE_WORDEXP - wordexp_t we; - char *cp; - sigset_t nset; -@@ -527,65 +529,6 @@ globname(char *name) - } - wordfree(&we); - return cp; --#else /* !HAVE_WORDEXP */ -- char xname[PATHSIZE]; -- char cmdbuf[PATHSIZE]; /* also used for file names */ -- int pid, l; -- char *cp, *shell; -- int pivec[2]; -- extern int wait_status; -- struct stat sbuf; -- -- if (pipe(pivec) < 0) { -- perror("pipe"); -- return name; -- } -- snprintf(cmdbuf, sizeof cmdbuf, "echo %s", name); -- if ((shell = value("SHELL")) == NULL) -- shell = SHELL; -- pid = start_command(shell, 0, -1, pivec[1], "-c", cmdbuf, NULL); -- if (pid < 0) { -- close(pivec[0]); -- close(pivec[1]); -- return NULL; -- } -- close(pivec[1]); --again: -- l = read(pivec[0], xname, sizeof xname); -- if (l < 0) { -- if (errno == EINTR) -- goto again; -- perror("read"); -- close(pivec[0]); -- return NULL; -- } -- close(pivec[0]); -- if (wait_child(pid) < 0 && WTERMSIG(wait_status) != SIGPIPE) { -- fprintf(stderr, catgets(catd, CATSET, 81, -- "\"%s\": Expansion failed.\n"), name); -- return NULL; -- } -- if (l == 0) { -- fprintf(stderr, catgets(catd, CATSET, 82, -- "\"%s\": No match.\n"), name); -- return NULL; -- } -- if (l == sizeof xname) { -- fprintf(stderr, catgets(catd, CATSET, 83, -- "\"%s\": Expansion buffer overflow.\n"), name); -- return NULL; -- } -- xname[l] = 0; -- for (cp = &xname[l-1]; *cp == '\n' && cp > xname; cp--) -- ; -- cp[1] = '\0'; -- if (strchr(xname, ' ') && stat(xname, &sbuf) < 0) { -- fprintf(stderr, catgets(catd, CATSET, 84, -- "\"%s\": Ambiguous.\n"), name); -- return NULL; -- } -- return savestr(xname); --#endif /* !HAVE_WORDEXP */ - } - - /* --- -1.9.3 - - diff --git a/community/heirloom-mailx/0004-globname-Invoke-wordexp-with-WRDE_NOCMD-CVE-2004-277.patch b/community/heirloom-mailx/0004-globname-Invoke-wordexp-with-WRDE_NOCMD-CVE-2004-277.patch deleted file mode 100644 index 173378f36a..0000000000 --- a/community/heirloom-mailx/0004-globname-Invoke-wordexp-with-WRDE_NOCMD-CVE-2004-277.patch +++ /dev/null @@ -1,26 +0,0 @@ ->From 73fefa0c1ac70043ec84f2d8b8f9f683213f168d Mon Sep 17 00:00:00 2001 -From: Florian Weimer <fweimer () redhat com> -Date: Mon, 17 Nov 2014 13:11:32 +0100 -Subject: [PATCH 4/4] globname: Invoke wordexp with WRDE_NOCMD (CVE-2004-2771) - ---- - fio.c | 2 +- - 1 file changed, 1 insertion(+), 1 deletion(-) - -diff --git a/fio.c b/fio.c -index 1529236..774a204 100644 ---- a/fio.c -+++ b/fio.c -@@ -497,7 +497,7 @@ globname(char *name) - sigemptyset(&nset); - sigaddset(&nset, SIGCHLD); - sigprocmask(SIG_BLOCK, &nset, NULL); -- i = wordexp(name, &we, 0); -+ i = wordexp(name, &we, WRDE_NOCMD); - sigprocmask(SIG_UNBLOCK, &nset, NULL); - switch (i) { - case 0: --- -1.9.3 - - diff --git a/community/heirloom-mailx/12.4-to-12.5pre.patch b/community/heirloom-mailx/12.4-to-12.5pre.patch deleted file mode 100644 index 9fd5c8fab0..0000000000 --- a/community/heirloom-mailx/12.4-to-12.5pre.patch +++ /dev/null @@ -1,1001 +0,0 @@ ---- mailx-12.4/ChangeLog -+++ nail/ChangeLog -@@ -1,3 +1,38 @@ -+[12.5] as of 7/5/10 -+* The undocumented contenttype-cntrl option works again (patch by -+ Laurent Parenteau). -+ -+[12.5] as of 6/20/10 -+* Fixed a message corruption that occurred when the "inc" command was used -+ with a mbox format mailbox after encrypted messages had been viewed -+ (reported by Martin Neitzel). -+* Fixed a condition that caused mailx to hang when looking at a message, -+ copying that message, and issuing a "z" command evaluating an uncached -+ portion of an IMAP folder. -+* Make it compile with OpenSSL 1.0.0-beta2 (patch by Bernhard Rosenkränzer). -+* When executing an "account" command, ensure that the values of the "hold", -+ "keepsave", "append", and "emptybox" variables remain those of the previous -+ account for all outstanding operations on that account (bug reported by -+ Jeff Woodall). -+* Support Gmail IMAP semantics of "delete" turning into "archive". Previously, -+ when mailx was setting the "\Deleted" flag on a message, it did not set any -+ other flags. This caused mails that had been read and then deleted to appear -+ as unread in Gmail's "All Mail". Now, flags besides "\Deleted" are also set, -+ so that they are kept in the archived copy (reported by Jeremy O'Brien). -+* For RFC 2047 MIME "encoded-word" parts in headers, assume that the end of -+ each word resets the conversion state (Yedidyah Bar-David). -+* When the ORGANIZATION variable has an empty value, do not generate an -+ "Organization:" header field. Previously, this condition resulted in -+ mailx refusing to send mail (Thomas E. Kammeyer). -+* When classifying messages with the junk filter, when selecting the most -+ representative tokens, prefer non-junk tokens over junk tokens if both -+ have the same (reversed) probability, in order to avoid false positives. -+* When calculating the probabilities of tokens that have occurred only in -+ good messages or only in junk messages so far, and these tokens occurred -+ less than ten times, give them slightly less than the minimum/maximum. -+* Fixed "unignore" and similar commands; they did not work at all so far -+ (http://www.freebsd.org/cgi/query-pr.cgi?pr=146280). -+ - [12.4] released 7/29/08 - * With the "-E" command line option or if the "skipemptybody" variable is - set, outgoing messages that contain no text in their first or only part ---- mailx-12.4/cmd2.c -+++ nail/cmd2.c -@@ -38,7 +38,7 @@ - - #ifndef lint - #ifdef DOSCCS --static char sccsid[] = "@(#)cmd2.c 2.46 (gritter) 3/4/06"; -+static char sccsid[] = "@(#)cmd2.c 2.47 (gritter) 5/9/10"; - #endif - #endif /* not lint */ - -@@ -803,16 +803,17 @@ - int h = hash(name); - - for (ip = tab->i_head[h]; ip; ip = ip->i_link) { -- if (asccasecmp(ip->i_field, name)) { -+ if (asccasecmp(ip->i_field, name) == 0) { - free(ip->i_field); - if (iq != NULL) - iq->i_link = ip->i_link; - else -- tab->i_head[h] = NULL; -+ tab->i_head[h] = ip->i_link; - free(ip); - tab->i_count--; - break; - } -+ iq = ip; - } - } - ---- mailx-12.4/cmd3.c -+++ nail/cmd3.c -@@ -38,7 +38,7 @@ - - #ifndef lint - #ifdef DOSCCS --static char sccsid[] = "@(#)cmd3.c 2.86 (gritter) 10/1/07"; -+static char sccsid[] = "@(#)cmd3.c 2.87 (gritter) 10/1/08"; - #endif - #endif /* not lint */ - -@@ -1311,7 +1311,7 @@ - char **args = (char **)v; - struct oldaccount *a; - char *cp; -- int i, mc; -+ int i, mc, oqf, nqf; - FILE *fp = stdout; - - if (args[0] == NULL) { -@@ -1345,6 +1345,7 @@ - return define1(args[0], 1); - } - strncpy(mboxname, expand("&"), sizeof mboxname)[sizeof mboxname-1]='\0'; -+ oqf = savequitflags(); - if ((a = get_oldaccount(args[0])) == NULL) { - if (args[1]) { - a = scalloc(1, sizeof *a); -@@ -1368,8 +1369,13 @@ - unset_allow_undefined = 1; - set(a->ac_vars); - unset_allow_undefined = 0; -- setf: if (!starting) -- return file1("%"); -+ setf: if (!starting) { -+ nqf = savequitflags(); -+ restorequitflags(oqf); -+ i = file1("%"); -+ restorequitflags(nqf); -+ return i; -+ } - } - return 0; - } ---- mailx-12.4/extern.h -+++ nail/extern.h -@@ -35,7 +35,7 @@ - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - * SUCH DAMAGE. - * -- * Sccsid @(#)extern.h 2.161 (gritter) 10/1/07 -+ * Sccsid @(#)extern.h 2.162 (gritter) 10/1/08 - */ - - /* aux.c */ -@@ -446,6 +446,8 @@ - void quit(void); - int holdbits(void); - enum okay makembox(void); -+int savequitflags(void); -+void restorequitflags(int); - /* send.c */ - char *foldergets(char **s, size_t *size, size_t *count, size_t *llen, - FILE *stream); -@@ -513,12 +515,12 @@ - void demail(void); - char *username(void); - /* vars.c */ --void assign(char *name, char *value); -+void assign(const char *name, const char *value); - char *vcopy(const char *str); - char *value(const char *name); - struct grouphead *findgroup(char *name); - void printgroup(char *name); - int hash(const char *name); --int unset_internal(char *name); -+int unset_internal(const char *name); - void remove_group(const char *name); - /* version.c */ ---- mailx-12.4/fio.c -+++ nail/fio.c -@@ -38,7 +38,7 @@ - - #ifndef lint - #ifdef DOSCCS --static char sccsid[] = "@(#)fio.c 2.73 (gritter) 1/7/08"; -+static char sccsid[] = "@(#)fio.c 2.76 (gritter) 9/16/09"; - #endif - #endif /* not lint */ - -@@ -108,6 +108,7 @@ - memset(&this, 0, sizeof this); - this.m_flag = MUSED|MNEW|MNEWEST; - filesize = mailsize - offset; -+ offset = ftell(mb.mb_otf); - for (;;) { - if (fgetline(&linebuf, &linesize, &filesize, &count, ibuf, 0) - == NULL) { -@@ -1050,7 +1051,8 @@ - NI_NUMERICHOST) != 0) - strcpy(hbuf, "unknown host"); - fprintf(stderr, catgets(catd, CATSET, 192, -- "Connecting to %s . . ."), hbuf); -+ "Connecting to %s:%s . . ."), -+ hbuf, portstr); - } - if ((sockfd = socket(res->ai_family, res->ai_socktype, - res->ai_protocol)) >= 0) { -@@ -1068,26 +1070,25 @@ - freeaddrinfo(res0); - #else /* !HAVE_IPv6_FUNCS */ - if (port == 0) { -- if ((ep = getservbyname((char *)portstr, "tcp")) == NULL) { -- if (equal(portstr, "smtp")) -- port = htons(25); -- else if (equal(portstr, "smtps")) -- port = htons(465); -- else if (equal(portstr, "imap")) -- port = htons(143); -- else if (equal(portstr, "imaps")) -- port = htons(993); -- else if (equal(portstr, "pop3")) -- port = htons(110); -- else if (equal(portstr, "pop3s")) -- port = htons(995); -- else { -- fprintf(stderr, catgets(catd, CATSET, 251, -- "Unknown service: %s\n"), portstr); -- return STOP; -- } -- } else -+ if (equal(portstr, "smtp")) -+ port = htons(25); -+ else if (equal(portstr, "smtps")) -+ port = htons(465); -+ else if (equal(portstr, "imap")) -+ port = htons(143); -+ else if (equal(portstr, "imaps")) -+ port = htons(993); -+ else if (equal(portstr, "pop3")) -+ port = htons(110); -+ else if (equal(portstr, "pop3s")) -+ port = htons(995); -+ else if ((ep = getservbyname((char *)portstr, "tcp")) != NULL) - port = ep->s_port; -+ else { -+ fprintf(stderr, catgets(catd, CATSET, 251, -+ "Unknown service: %s\n"), portstr); -+ return STOP; -+ } - } else - port = htons(port); - if (verbose) -@@ -1109,7 +1110,8 @@ - memcpy(&servaddr.sin_addr, *pptr, sizeof(struct in_addr)); - if (verbose) - fprintf(stderr, catgets(catd, CATSET, 192, -- "Connecting to %s . . ."), inet_ntoa(**pptr)); -+ "Connecting to %s:%d . . ."), -+ inet_ntoa(**pptr), ntohs(port)); - if (connect(sockfd, (struct sockaddr *)&servaddr, sizeof servaddr) - != 0) { - perror(catgets(catd, CATSET, 254, "could not connect")); ---- mailx-12.4/imap.c -+++ nail/imap.c -@@ -38,7 +38,7 @@ - - #ifndef lint - #ifdef DOSCCS --static char sccsid[] = "@(#)imap.c 1.219 (gritter) 1/6/08"; -+static char sccsid[] = "@(#)imap.c 1.222 (gritter) 3/13/09"; - #endif - #endif /* not lint */ - -@@ -1821,57 +1821,62 @@ - * reading their results. - */ - needstat = stored > 0 && stored % 800 == 0; -+ /* -+ * Even if this message has been deleted, continue -+ * to set further flags. This is necessary to support -+ * Gmail semantics, where "delete" actually means -+ * "archive", and the flags are applied to the copy -+ * in "All Mail". -+ */ -+ if ((m->m_flag&(MREAD|MSTATUS)) == (MREAD|MSTATUS)) { -+ imap_store(mp, m, m-message+1, -+ '+', "\\Seen", needstat); -+ stored++; -+ } -+ if (m->m_flag & MFLAG) { -+ imap_store(mp, m, m-message+1, -+ '+', "\\Flagged", needstat); -+ stored++; -+ } -+ if (m->m_flag & MUNFLAG) { -+ imap_store(mp, m, m-message+1, -+ '-', "\\Flagged", needstat); -+ stored++; -+ } -+ if (m->m_flag & MANSWER) { -+ imap_store(mp, m, m-message+1, -+ '+', "\\Answered", needstat); -+ stored++; -+ } -+ if (m->m_flag & MUNANSWER) { -+ imap_store(mp, m, m-message+1, -+ '-', "\\Answered", needstat); -+ stored++; -+ } -+ if (m->m_flag & MDRAFT) { -+ imap_store(mp, m, m-message+1, -+ '+', "\\Draft", needstat); -+ stored++; -+ } -+ if (m->m_flag & MUNDRAFT) { -+ imap_store(mp, m, m-message+1, -+ '-', "\\Draft", needstat); -+ stored++; -+ } - if (dodel) { - imap_delete(mp, m-message+1, m, needstat); - stored++; - gotcha++; -- } else { -- if ((m->m_flag&(MREAD|MSTATUS)) == (MREAD|MSTATUS)) { -- imap_store(mp, m, m-message+1, -- '+', "\\Seen", needstat); -- stored++; -- } -- if (m->m_flag & MFLAG) { -- imap_store(mp, m, m-message+1, -- '+', "\\Flagged", needstat); -- stored++; -- } -- if (m->m_flag & MUNFLAG) { -- imap_store(mp, m, m-message+1, -- '-', "\\Flagged", needstat); -- stored++; -- } -- if (m->m_flag & MANSWER) { -- imap_store(mp, m, m-message+1, -- '+', "\\Answered", needstat); -- stored++; -- } -- if (m->m_flag & MUNANSWER) { -- imap_store(mp, m, m-message+1, -- '-', "\\Answered", needstat); -- stored++; -- } -- if (m->m_flag & MDRAFT) { -- imap_store(mp, m, m-message+1, -- '+', "\\Draft", needstat); -- stored++; -- } -- if (m->m_flag & MUNDRAFT) { -- imap_store(mp, m, m-message+1, -- '-', "\\Draft", needstat); -- stored++; -- } -- if (mp->mb_type != MB_CACHE || -- !edit && (!(m->m_flag&(MBOXED|MSAVED|MDELETED)) -- || (m->m_flag & -- (MBOXED|MPRESERVE|MTOUCH)) == -- (MPRESERVE|MTOUCH)) || -- edit && !(m->m_flag & MDELETED)) -- held++; -- if (m->m_flag & MNEW) { -- m->m_flag &= ~MNEW; -- m->m_flag |= MSTATUS; -- } -+ } else if (mp->mb_type != MB_CACHE || -+ !edit && (!(m->m_flag&(MBOXED|MSAVED|MDELETED)) -+ || (m->m_flag & -+ (MBOXED|MPRESERVE|MTOUCH)) == -+ (MPRESERVE|MTOUCH)) || -+ edit && !(m->m_flag & MDELETED)) -+ held++; -+ if (m->m_flag & MNEW) { -+ m->m_flag &= ~MNEW; -+ m->m_flag |= MSTATUS; - } - } - bypass: if (readstat != NULL) -@@ -2571,6 +2576,7 @@ - const char *qname; - enum okay ok = STOP; - int twice = 0; -+ int stored = 0; - FILE *queuefp = NULL; - - if (mp->mb_type == MB_CACHE) { -@@ -2629,20 +2635,38 @@ - * ... and reset the flag to its initial value so that - * the 'exit' command still leaves the message unread. - */ --out: if ((m->m_flag&(MREAD|MSTATUS)) == (MREAD|MSTATUS)) -+out: if ((m->m_flag&(MREAD|MSTATUS)) == (MREAD|MSTATUS)) { - imap_store(mp, m, n, '-', "\\Seen", 0); -- if (m->m_flag&MFLAG) -+ stored++; -+ } -+ if (m->m_flag&MFLAG) { - imap_store(mp, m, n, '-', "\\Flagged", 0); -- if (m->m_flag&MUNFLAG) -+ stored++; -+ } -+ if (m->m_flag&MUNFLAG) { - imap_store(mp, m, n, '+', "\\Flagged", 0); -- if (m->m_flag&MANSWER) -+ stored++; -+ } -+ if (m->m_flag&MANSWER) { - imap_store(mp, m, n, '-', "\\Answered", 0); -- if (m->m_flag&MUNANSWER) -+ stored++; -+ } -+ if (m->m_flag&MUNANSWER) { - imap_store(mp, m, n, '+', "\\Answered", 0); -- if (m->m_flag&MDRAFT) -+ stored++; -+ } -+ if (m->m_flag&MDRAFT) { - imap_store(mp, m, n, '-', "\\Draft", 0); -- if (m->m_flag&MUNDRAFT) -+ stored++; -+ } -+ if (m->m_flag&MUNDRAFT) { - imap_store(mp, m, n, '+', "\\Draft", 0); -+ stored++; -+ } -+ if (stored) { -+ mp->mb_active |= MB_COMD; -+ imap_finish(mp); -+ } - return ok; - } - ---- mailx-12.4/junk.c -+++ nail/junk.c -@@ -38,7 +38,7 @@ - - #ifndef lint - #ifdef DOSCCS --static char sccsid[] = "@(#)junk.c 1.73 (gritter) 3/4/06"; -+static char sccsid[] = "@(#)junk.c 1.75 (gritter) 9/14/08"; - #endif - #endif /* not lint */ - -@@ -920,6 +920,10 @@ - smin(1.0, nbad ? (float)b/nbad : 0.0)); - p = smin(TOP, p); - p = smax(BOT, p); -+ if (p == TOP && b <= 10 && g == 0) -+ p -= BOT; -+ else if (p == BOT && g <= 10 && b == 0) -+ p += BOT; - } else if (g == 0 && b == 0) - p = DFL; - else -@@ -1095,13 +1099,20 @@ - if (h1 == best[i].hash1 && h2 == best[i].hash2) - break; - /* -- * This selection prefers words from the end of the -- * header and from the start of the body. It does -- * probably not matter much at all, but gives at -- * least the most interesting verbose output. -+ * For equal distance, this selection prefers -+ * words with a low probability, since a false -+ * negative is better than a false positive, -+ * and since experience has shown that false -+ * positives are more likely otherwise. Then, -+ * words from the end of the header and from -+ * the start of the body are preferred. This -+ * gives the most interesting verbose output. - */ -- if (d > best[i].dist || best[i].loc == HEADER && -- d >= best[i].dist) { -+ if (d > best[i].dist || -+ d == best[i].dist && -+ p < best[i].prob || -+ best[i].loc == HEADER && -+ d == best[i].dist) { - for (j = BEST-2; j >= i; j--) - best[j+1] = best[j]; - best[i].dist = d; ---- mailx-12.4/list.c -+++ nail/list.c -@@ -38,7 +38,7 @@ - - #ifndef lint - #ifdef DOSCCS --static char sccsid[] = "@(#)list.c 2.61 (gritter) 01/07/07"; -+static char sccsid[] = "@(#)list.c 2.62 (gritter) 12/11/08"; - #endif - #endif /* not lint */ - -@@ -438,7 +438,7 @@ - if (!inhook) - printf(tback ? - "No previously marked messages.\n" : -- "No messages satify (criteria).\n"); -+ "No messages satisfy (criteria).\n"); - markall_ret(-1) - } - } ---- mailx-12.4/mailx.1 -+++ nail/mailx.1 -@@ -34,9 +34,9 @@ - .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - .\" SUCH DAMAGE. - .\" --.\" Sccsid: @(#)mailx.1 2.326 (gritter) 10/1/07 -+.\" Sccsid: @(#)mailx.1 2.329 (gritter) 10/9/10 - .\" --.TH MAILX 1 "10/1/07" "Heirloom mailx 12.4" "User Commands" -+.TH MAILX 1 "10/9/10" "Heirloom mailx 12.5" "User Commands" - .SH NAME - mailx \- send and receive Internet mail - .SH SYNOPSIS -@@ -418,6 +418,21 @@ - .I address - All messages from - .IR address . -+By default, this is a case-sensitive search -+for the complete email address. -+If the -+.I allnet -+variable is set, -+only the local part of the addresses is evaluated for the comparison. -+Otherwise if the -+.I showname -+variable is set, -+a case-sensitive search for the complete real name -+of a sender is performed. -+The IMAP-style -+.BI (from\ address) -+expression can be used instead -+if substring matches are desired. - .TP - .BI ( criterion ) - All messages that satisfy the given IMAP-style SEARCH -@@ -3766,7 +3781,7 @@ - .sp - .fi - which might cause --.N mailx -+.B mailx - to respond with, for example: - .nf - .sp ---- mailx-12.4/makeconfig -+++ nail/makeconfig -@@ -1,7 +1,7 @@ - #!/bin/sh - - # --# Sccsid @(#)makeconfig 1.43 (gritter) 4/14/07 -+# Sccsid @(#)makeconfig 1.44 (gritter) 5/26/09 - # - - tmp=___build$$ -@@ -393,6 +393,25 @@ - ! - fi - -+if test x$have_openssl = xyes -+then -+ compile_check stack_of 'for STACK_OF()' '#define HAVE_STACK_OF' <<\! -+#include <openssl/ssl.h> -+#include <openssl/err.h> -+#include <openssl/x509v3.h> -+#include <openssl/x509.h> -+#include <openssl/rand.h> -+ -+int main(void) -+{ -+ STACK_OF(GENERAL_NAME) *gens = NULL; -+ printf("%p", gens); /* to make it used */ -+ SSLv23_client_method(); -+ PEM_read_PrivateKey(0, 0, 0, 0); -+ return 0; -+} -+! -+fi - - cat >$tmp2.c <<\! - #include <gssapi/gssapi.h> ---- mailx-12.4/mime.c -+++ nail/mime.c -@@ -40,7 +40,7 @@ - #ifdef DOSCCS - static char copyright[] - = "@(#) Copyright (c) 2000, 2002 Gunnar Ritter. All rights reserved.\n"; --static char sccsid[] = "@(#)mime.c 2.69 (gritter) 6/29/08"; -+static char sccsid[] = "@(#)mime.c 2.71 (gritter) 7/5/10"; - #endif /* DOSCCS */ - #endif /* not lint */ - -@@ -788,8 +788,7 @@ - - *isclean = mime_isclean(fp); - if (*isclean & MIME_HASNUL || -- *contenttype && ascncasecmp(*contenttype, "text/", 5) || -- *contenttype == NULL && *isclean & MIME_CTRLCHAR) { -+ *contenttype && ascncasecmp(*contenttype, "text/", 5)) { - convert = CONV_TOB64; - if (*contenttype == NULL || - ascncasecmp(*contenttype, "text/", 5) == 0) -@@ -809,6 +808,7 @@ - *contenttype = "application/octet-stream"; - *charset = NULL; - } if (*isclean & MIME_CTRLCHAR) { -+ convert = CONV_TOB64; - /* - * RFC 2046 forbids control characters other than - * ^I or ^L in text/plain bodies. However, some -@@ -1048,12 +1048,22 @@ - uptr = nptr + outleft; - iptr = cout.s; - if (iconv_ft(fhicd, &iptr, &inleft, -- &nptr, &outleft) != 0 && -+ &nptr, &outleft) == (size_t)-1 && - errno == E2BIG) { - iconv(fhicd, NULL, NULL, NULL, NULL); - mime_fromhdr_inc(inleft); - goto again; - } -+ /* -+ * For state-dependent encodings, -+ * reset the state here, assuming -+ * that states are restricted to -+ * single encoded-word parts. -+ */ -+ while (iconv(fhicd, NULL, NULL, -+ &nptr, &outleft) == (size_t)-1 && -+ errno == E2BIG) -+ mime_fromhdr_inc(16); - out->l += uptr - mptr - outleft; - q += uptr - mptr - outleft; - } else { -@@ -1295,7 +1305,7 @@ - isz = len; - op = cbuf; - osz = cbufsz; -- if (iconv(iconvd, &ip, &isz, &op, &osz) != 0) { -+ if (iconv(iconvd, &ip, &isz, &op, &osz) == (size_t)-1) { - if (errno != E2BIG) { - ac_free(cbuf); - return 0; -@@ -1489,7 +1499,8 @@ - outleft = mptrsz; - nptr = mptr; - iptr = ptr; -- if (iconv_ft(iconvd, &iptr, &inleft, &nptr, &outleft) != 0 && -+ if (iconv_ft(iconvd, &iptr, &inleft, &nptr, &outleft) == -+ (size_t)-1 && - errno == E2BIG) { - iconv(iconvd, NULL, NULL, NULL, NULL); - ac_free(mptr); ---- mailx-12.4/nail.rc -+++ nail/nail.rc -@@ -4,7 +4,7 @@ - # This file is not overwritten when 'make install' is run in - # the mailx build process again. - --# Sccsid @(#)nail.rc 2.10 (gritter) 3/4/06 -+# Sccsid @(#)nail.rc 2.11 (gritter) 8/2/08 - - # Do not forward to mbox by default since this is likely to be - # irritating for most users today. -@@ -54,6 +54,9 @@ - - # If threaded mode is activated, automatically collapse thread. - set autocollapse -+ -+# Mark messages that have been answered. -+set markanswered - - # Hide some header fields which are uninteresting for most human readers. - ignore received in-reply-to message-id references ---- mailx-12.4/openssl.c -+++ nail/openssl.c -@@ -38,7 +38,7 @@ - - #ifndef lint - #ifdef DOSCCS --static char sccsid[] = "@(#)openssl.c 1.25 (gritter) 8/4/07"; -+static char sccsid[] = "@(#)openssl.c 1.26 (gritter) 5/26/09"; - #endif - #endif /* not lint */ - -@@ -101,12 +101,17 @@ - static int ssl_rand_init(void); - static void ssl_init(void); - static int ssl_verify_cb(int success, X509_STORE_CTX *store); --static SSL_METHOD *ssl_select_method(const char *uhp); -+static const SSL_METHOD *ssl_select_method(const char *uhp); - static void ssl_load_verifications(struct sock *sp); - static void ssl_certificate(struct sock *sp, const char *uhp); - static enum okay ssl_check_host(const char *server, struct sock *sp); -+#ifdef HAVE_STACK_OF -+static int smime_verify(struct message *m, int n, STACK_OF(X509) *chain, -+ X509_STORE *store); -+#else - static int smime_verify(struct message *m, int n, STACK *chain, - X509_STORE *store); -+#endif - static EVP_CIPHER *smime_cipher(const char *name); - static int ssl_password_cb(char *buf, int size, int rwflag, void *userdata); - static FILE *smime_sign_cert(const char *xname, const char *xname2, int warn); -@@ -203,10 +208,10 @@ - return 1; - } - --static SSL_METHOD * -+static const SSL_METHOD * - ssl_select_method(const char *uhp) - { -- SSL_METHOD *method; -+ const SSL_METHOD *method; - char *cp; - - cp = ssl_method_string(uhp); -@@ -308,7 +313,11 @@ - X509 *cert; - X509_NAME *subj; - char data[256]; -+#ifdef HAVE_STACK_OF -+ STACK_OF(GENERAL_NAME) *gens; -+#else - /*GENERAL_NAMES*/STACK *gens; -+#endif - GENERAL_NAME *gen; - int i; - -@@ -357,7 +366,8 @@ - - ssl_init(); - ssl_set_vrfy_level(uhp); -- if ((sp->s_ctx = SSL_CTX_new(ssl_select_method(uhp))) == NULL) { -+ if ((sp->s_ctx = -+ SSL_CTX_new((SSL_METHOD *)ssl_select_method(uhp))) == NULL) { - ssl_gen_err(catgets(catd, CATSET, 261, "SSL_CTX_new() failed")); - return STOP; - } -@@ -496,7 +506,11 @@ - } - - static int -+#ifdef HAVE_STACK_OF -+smime_verify(struct message *m, int n, STACK_OF(X509) *chain, X509_STORE *store) -+#else - smime_verify(struct message *m, int n, STACK *chain, X509_STORE *store) -+#endif - { - struct message *x; - char *cp, *sender, *to, *cc, *cnttype; -@@ -505,7 +519,12 @@ - off_t size; - BIO *fb, *pb; - PKCS7 *pkcs7; -+#ifdef HAVE_STACK_OF -+ STACK_OF(X509) *certs; -+ STACK_OF(GENERAL_NAME) *gens; -+#else - STACK *certs, *gens; -+#endif - X509 *cert; - X509_NAME *subj; - char data[LINESIZE]; -@@ -614,7 +633,11 @@ - { - int *msgvec = vp, *ip; - int ec = 0; -+#ifdef HAVE_STACK_OF -+ STACK_OF(X509) *chain = NULL; -+#else - STACK *chain = NULL; -+#endif - X509_STORE *store; - char *ca_dir, *ca_file; - -@@ -687,7 +710,11 @@ - X509 *cert; - PKCS7 *pkcs7; - BIO *bb, *yb; -+#ifdef HAVE_STACK_OF -+ STACK_OF(X509) *certs; -+#else - STACK *certs; -+#endif - EVP_CIPHER *cipher; - - certfile = expand((char *)certfile); -@@ -950,9 +977,14 @@ - off_t size; - BIO *fb, *pb; - PKCS7 *pkcs7; -+#ifdef HAVE_STACK_OF -+ STACK_OF(X509) *certs; -+ STACK_OF(X509) *chain = NULL; -+#else - STACK *certs; -- X509 *cert; - STACK *chain = NULL; -+#endif -+ X509 *cert; - enum okay ok = OKAY; - - message_number = n; ---- mailx-12.4/quit.c -+++ nail/quit.c -@@ -38,7 +38,7 @@ - - #ifndef lint - #ifdef DOSCCS --static char sccsid[] = "@(#)quit.c 2.28 (gritter) 3/4/06"; -+static char sccsid[] = "@(#)quit.c 2.30 (gritter) 11/11/08"; - #endif - #endif /* not lint */ - -@@ -584,4 +584,47 @@ - - done: - relsesigs(); -+} -+ -+enum quitflags { -+ QUITFLAG_HOLD = 001, -+ QUITFLAG_KEEPSAVE = 002, -+ QUITFLAG_APPEND = 004, -+ QUITFLAG_EMPTYBOX = 010 -+}; -+ -+static const struct quitnames { -+ enum quitflags flag; -+ const char *name; -+} quitnames[] = { -+ { QUITFLAG_HOLD, "hold" }, -+ { QUITFLAG_KEEPSAVE, "keepsave" }, -+ { QUITFLAG_APPEND, "append" }, -+ { QUITFLAG_EMPTYBOX, "emptybox" }, -+ { 0, NULL } -+}; -+ -+int -+savequitflags(void) -+{ -+ enum quitflags qf = 0; -+ int i; -+ -+ for (i = 0; quitnames[i].name; i++) -+ if (value(quitnames[i].name)) -+ qf |= quitnames[i].flag; -+ return qf; -+} -+ -+void -+restorequitflags(int qf) -+{ -+ int i; -+ -+ for (i = 0; quitnames[i].name; i++) -+ if (qf & quitnames[i].flag) { -+ if (value(quitnames[i].name) == NULL) -+ assign(quitnames[i].name, ""); -+ } else if (value(quitnames[i].name)) -+ unset_internal(quitnames[i].name); - } ---- mailx-12.4/sendout.c -+++ nail/sendout.c -@@ -38,7 +38,7 @@ - - #ifndef lint - #ifdef DOSCCS --static char sccsid[] = "@(#)sendout.c 2.99 (gritter) 7/4/08"; -+static char sccsid[] = "@(#)sendout.c 2.100 (gritter) 3/1/09"; - #endif - #endif /* not lint */ - -@@ -1219,8 +1219,9 @@ - if (putname(addr, w, action, &gotcha, "From:", fo, - &fromfield)) - return 1; -- if ((addr = hp->h_organization) != NULL || -- (addr = value("ORGANIZATION")) != NULL) { -+ if (((addr = hp->h_organization) != NULL || -+ (addr = value("ORGANIZATION")) != NULL) -+ && strlen(addr) > 0) { - fwrite("Organization: ", sizeof (char), 14, fo); - if (mime_write(addr, strlen(addr), fo, - action == SEND_TODISP ? -@@ -1269,7 +1270,8 @@ - fwrite("Subject: ", sizeof (char), 9, fo); - if (ascncasecmp(hp->h_subject, "re: ", 4) == 0) { - fwrite("Re: ", sizeof (char), 4, fo); -- if (mime_write(hp->h_subject + 4, -+ if (strlen(hp->h_subject + 4) > 0 && -+ mime_write(hp->h_subject + 4, - strlen(hp->h_subject + 4), - fo, action == SEND_TODISP ? - CONV_NONE:CONV_TOHDR, ---- mailx-12.4/vars.c -+++ nail/vars.c -@@ -38,7 +38,7 @@ - - #ifndef lint - #ifdef DOSCCS --static char sccsid[] = "@(#)vars.c 2.11 (gritter) 3/4/06"; -+static char sccsid[] = "@(#)vars.c 2.12 (gritter) 10/1/08"; - #endif - #endif /* not lint */ - -@@ -81,7 +81,7 @@ - * Assign a value to a variable. - */ - void --assign(char *name, char *value) -+assign(const char *name, const char *value) - { - struct var *vp; - int h; -@@ -221,7 +221,7 @@ - } - - int --unset_internal(char *name) -+unset_internal(const char *name) - { - struct var *vp, *vp2; - int h; ---- mailx-12.4/version.c -+++ nail/version.c -@@ -1,4 +1,4 @@ --#define V "12.4" -+#define V "12.5" - /* - * Heirloom mailx - a mail user agent derived from Berkeley Mail. - * -@@ -39,7 +39,7 @@ - - #ifndef lint - #ifdef DOSCCS --static char sccsid[] = "@(#)version.c 2.386 (gritter) 7/29/08"; -+static char sccsid[] = "@(#)version.c 2.404 (gritter) 7/5/10"; - #endif - #endif /* not lint */ - -@@ -48,7 +48,7 @@ - * Load this file first to get a "total" Mail version. - */ - /*char *version = "8.1 6/6/93";*/ --const char *version = V " 7/29/08"; -+const char *version = V " 7/5/10"; - #ifndef lint - #if __GNUC__ >= 3 && __GNUC_MINOR__ >= 4 || __GNUC__ >= 4 - #define USED __attribute__ ((used)) -@@ -57,7 +57,7 @@ - #else - #define USED - #endif --static const char *versionid USED = "@(#)mailx " V " (gritter) 7/29/08"; -+static const char *versionid USED = "@(#)mailx " V " (gritter) 7/5/10"; - #endif /* !lint */ - /* SLIST */ - /* -@@ -65,42 +65,42 @@ - base64.c:static char sccsid[] = "@(#)base64.c 2.14 (gritter) 4/21/06"; - cache.c:static char sccsid[] = "@(#)cache.c 1.61 (gritter) 3/4/06"; - cmd1.c:static char sccsid[] = "@(#)cmd1.c 2.97 (gritter) 6/16/07"; --cmd2.c:static char sccsid[] = "@(#)cmd2.c 2.46 (gritter) 3/4/06"; --cmd3.c:static char sccsid[] = "@(#)cmd3.c 2.86 (gritter) 10/1/07"; -+cmd2.c:static char sccsid[] = "@(#)cmd2.c 2.47 (gritter) 5/9/10"; -+cmd3.c:static char sccsid[] = "@(#)cmd3.c 2.87 (gritter) 10/1/08"; - cmdtab.c:static char sccsid[] = "@(#)cmdtab.c 2.51 (gritter) 3/4/06"; - collect.c:static char sccsid[] = "@(#)collect.c 2.54 (gritter) 6/16/07"; - def.h: * Sccsid @(#)def.h 2.104 (gritter) 3/4/06 - dotlock.c:static char sccsid[] = "@(#)dotlock.c 2.9 (gritter) 3/20/06"; - edit.c:static char sccsid[] = "@(#)edit.c 2.24 (gritter) 3/4/06"; --extern.h: * Sccsid @(#)extern.h 2.161 (gritter) 10/1/07 --fio.c:static char sccsid[] = "@(#)fio.c 2.73 (gritter) 1/7/08"; -+extern.h: * Sccsid @(#)extern.h 2.162 (gritter) 10/1/08 -+fio.c:static char sccsid[] = "@(#)fio.c 2.76 (gritter) 9/16/09"; - getname.c:static char sccsid[] = "@(#)getname.c 2.5 (gritter) 3/4/06"; - getopt.c: Sccsid @(#)getopt.c 1.7 (gritter) 12/16/07 - glob.h: * Sccsid @(#)glob.h 2.27 (gritter) 6/16/07 - head.c:static char sccsid[] = "@(#)head.c 2.17 (gritter) 3/4/06"; - hmac.c: Sccsid @(#)hmac.c 1.8 (gritter) 3/4/06 --imap.c:static char sccsid[] = "@(#)imap.c 1.219 (gritter) 1/6/08"; -+imap.c:static char sccsid[] = "@(#)imap.c 1.222 (gritter) 3/13/09"; - imap_gssapi.c:static char sccsid[] = "@(#)imap_gssapi.c 1.10 (gritter) 3/4/06"; - imap_search.c:static char sccsid[] = "@(#)imap_search.c 1.29 (gritter) 3/4/06"; --junk.c:static char sccsid[] = "@(#)junk.c 1.73 (gritter) 3/4/06"; -+junk.c:static char sccsid[] = "@(#)junk.c 1.75 (gritter) 9/14/08"; - lex.c:static char sccsid[] = "@(#)lex.c 2.86 (gritter) 12/25/06"; --list.c:static char sccsid[] = "@(#)list.c 2.61 (gritter) 01/07/07"; -+list.c:static char sccsid[] = "@(#)list.c 2.62 (gritter) 12/11/08"; - lzw.c: * Sccsid @(#)lzw.c 1.11 (gritter) 3/4/06 - macro.c:static char sccsid[] = "@(#)macro.c 1.13 (gritter) 3/4/06"; - maildir.c:static char sccsid[] = "@(#)maildir.c 1.20 (gritter) 12/28/06"; - main.c:static char sccsid[] = "@(#)main.c 2.51 (gritter) 10/1/07"; - md5.c: Sccsid @(#)md5.c 1.8 (gritter) 3/4/06 - md5.h: Sccsid @(#)md5.h 1.8 (gritter) 3/4/06 --mime.c:static char sccsid[] = "@(#)mime.c 2.69 (gritter) 6/29/08"; -+mime.c:static char sccsid[] = "@(#)mime.c 2.71 (gritter) 7/5/10"; - names.c:static char sccsid[] = "@(#)names.c 2.22 (gritter) 3/4/06"; - nss.c:static char sccsid[] = "@(#)nss.c 1.48 (gritter) 8/4/07"; --openssl.c:static char sccsid[] = "@(#)openssl.c 1.25 (gritter) 8/4/07"; -+openssl.c:static char sccsid[] = "@(#)openssl.c 1.26 (gritter) 5/26/09"; - pop3.c:static char sccsid[] = "@(#)pop3.c 2.43 (gritter) 3/4/06"; - popen.c:static char sccsid[] = "@(#)popen.c 2.20 (gritter) 3/4/06"; --quit.c:static char sccsid[] = "@(#)quit.c 2.28 (gritter) 3/4/06"; -+quit.c:static char sccsid[] = "@(#)quit.c 2.30 (gritter) 11/11/08"; - rcv.h: * Sccsid @(#)rcv.h 2.7 (gritter) 3/4/06 - send.c:static char sccsid[] = "@(#)send.c 2.86 (gritter) 2/4/08"; --sendout.c:static char sccsid[] = "@(#)sendout.c 2.99 (gritter) 7/4/08"; -+sendout.c:static char sccsid[] = "@(#)sendout.c 2.100 (gritter) 3/1/09"; - smtp.c:static char sccsid[] = "@(#)smtp.c 2.43 (gritter) 8/4/07"; - ssl.c:static char sccsid[] = "@(#)ssl.c 1.39 (gritter) 6/12/06"; - strings.c:static char sccsid[] = "@(#)strings.c 2.6 (gritter) 3/4/06"; -@@ -108,5 +108,5 @@ - thread.c:static char sccsid[] = "@(#)thread.c 1.57 (gritter) 3/4/06"; - tty.c:static char sccsid[] = "@(#)tty.c 2.29 (gritter) 3/9/07"; - v7.local.c:static char sccsid[] = "@(#)v7.local.c 2.10 (gritter) 3/4/06"; --vars.c:static char sccsid[] = "@(#)vars.c 2.11 (gritter) 3/4/06"; -+vars.c:static char sccsid[] = "@(#)vars.c 2.12 (gritter) 10/1/08"; - */ diff --git a/community/heirloom-mailx/APKBUILD b/community/heirloom-mailx/APKBUILD index b9e48b6ff9..3095cdbd67 100644 --- a/community/heirloom-mailx/APKBUILD +++ b/community/heirloom-mailx/APKBUILD @@ -1,43 +1,44 @@ # Contributor: Isaac Dunham <ibid.ag@gmail.com> # Maintainer: Isaac Dunham <ibid.ag@gmail.com> pkgname=heirloom-mailx -pkgver=12.4 -pkgrel=7 +pkgver=12.5 +pkgrel=0 pkgdesc="A free clone of SysV mailx" url="http://heirloom.sourceforge.net/mailx.html" arch="all" -license="BSD" +license="BSD-4-Clause" +options="!check" # No test suite makedepends="openssl-dev krb5-dev" subpackages="$pkgname-doc" -source="https://sourceforge.net/projects/heirloom/files/heirloom-mailx/$pkgver/mailx-$pkgver.tar.bz2 - 12.4-to-12.5pre.patch +source="http://ftp.debian.org/debian/pool/main/h/heirloom-mailx/heirloom-mailx_$pkgver.orig.tar.gz makevars.patch - 0001-outof-Introduce-expandaddr-flag.patch - 0002-unpack-Disable-option-processing-for-email-addresses.patch - 0003-fio_c-Unconditionally-require-wordexp-support.patch - 0004-globname-Invoke-wordexp-with-WRDE_NOCMD-CVE-2004-277.patch - libressl.patch + heirloom-mailx-12.5-fixes-1.patch + openssl.patch + nail-11.25-config.patch + mailx-12.5-usage.patch + mailx-12.5-lzw.patch + mailx-12.5-fname-null.patch + mailx-12.5-collect.patch + mailx-12.3-pager.patch " -builddir="$srcdir"/mailx-$pkgver - build() { - cd "$builddir" make } package() { - cd "$builddir" make DESTDIR="$pkgdir" install install -Dm 0644 COPYING "$pkgdir"/usr/share/licenses/"$pkgname"/COPYING cd "$pkgdir"/usr/share/man/man1/ && mv mailx.1 "$pkgname".1 } -sha512sums="a0e29972f552bd630ce1a14f70e61661815118520bcd4a00b6cad53f3270d3d08c835ff6982ba8800eb380a5b46f54eb6e60fb7533b5f41c916af45d29605af8 mailx-12.4.tar.bz2 -c2435c18b3e972a77bbaa1b915cae567cafcd65cba1710cd78e7b934d33662361aa1e72fb99d0f109945c603ec847552345a4a5c3ec64dbc307cbb811a6d74d0 12.4-to-12.5pre.patch +sha512sums="eb4aea0c668354f6fe28137f72bf49d291ce58671a7b70c7775777532e17e59ac52156e68f02937256f0a2f90c132b7c0948553b55daad92a664bd8bbb64774f heirloom-mailx_12.5.orig.tar.gz 4d7267cfd2c730922aef32fdb71bdf31d44d80ec6b41e150c627ad92fa0b812a2c5e486ffd8fe2729083be86208654c863a96282fdaeed8fea53d6fe32eba578 makevars.patch -fc5a22bf17e998c5228ff581388a3e2f8ffad9c70b46f7e94edc63d304e5e9576b59c57df07dc7e40cf234fc8b89bf2c52248592ad834fc4b4d29e25a673edc8 0001-outof-Introduce-expandaddr-flag.patch -b10a5ec515ba447e828dbf4562b07b65bc2c812f0d731b244f77cc43152bf14200e40d218ebb080fd820dc18ed4666c4f66de579b562a9231d8a0e95b4c0bb25 0002-unpack-Disable-option-processing-for-email-addresses.patch -c41ad1e90ebc6060ce0a7badfde5fc01b87c4c0c9eacf7e2f55444212cbd93097b37a3e426bcdcb4a565c1b0d16010996d9aca1d61c0d918a1d4acb41754d516 0003-fio_c-Unconditionally-require-wordexp-support.patch -bee2afb9f691a5c7b715eaa9adb14afbde0694235bb22449741f464812276c3f44d1b90e8b07255d1378b941d2b14133161a1575c40605b0911d8e28afaf578a 0004-globname-Invoke-wordexp-with-WRDE_NOCMD-CVE-2004-277.patch -53ce1c5ac1e41d875e8dc77cf41d1843a8f1b9e49a6eb7990c984c54be123b686cfe8c0003ad1b6adab447a96349a2b5c12f3790145537f606363c5b82cf953e libressl.patch" +5ad6440518c41a91df161ab3bccdcd71fa6136c4d27f82f2838cc80a2c43825993f3f3ea17b9e1fd4048168926cbb24e9f93a65da4cb3cd6abe720831f5a3d5e heirloom-mailx-12.5-fixes-1.patch +e9c87cea343ce11ca2b439b58c1adff2f508d1ab1b7e13479914cfb870459937a7c410c3930f672f8b32d05da808b964588f7e91c7b738151595b8fbbfb6ee32 openssl.patch +c2473fb73442e5215c6ba92bac9317197b4fbc28494fbb0d3fc8efbbd5156c9fff5b83343d450b6e51e57ce3156927079175bde0d53bcb55f67bcb619dcd9da7 nail-11.25-config.patch +a9fbbaef440cb2c6b9a3b100fb11852795631924b9a99f5a31d773e904db4bf160cf72fad5b8cba5379bf6abffdb075eabbc0971e6b15f804bf5cf27a082302e mailx-12.5-usage.patch +a69e6db84dc2fbd5543dd22261ac050724266289ab993c045d132804987ec5811620a0e8b2b8f8296844925ca72afe93cdc719e4251a2986b9f18855ca8a29cf mailx-12.5-lzw.patch +50ca85bb188257b1839b60bd37bf7e16bb39781a4575dc21b5a1b9dc6e40d6b7ec3c93f922729b6ece873a2b19a46085871f32a23109063cf5b961318fcc1ffb mailx-12.5-fname-null.patch +26ef4cb784c19cd09b16f5e4d944a3e3d51b9163e5e0c1d5d8934ad16f1add7b3c911c160e3e19b41c9c3a9a7c2275f88baa95535a953f2ce1a28823c51582ea mailx-12.5-collect.patch +29fcd878a46d9575d62f6a6f7f3fbe0387c9d2f23c5f8f86dc28c7293b52ac90c6a03180cb718061cd19fdd5c006f6f34b25f74f9a091531a0a8d2a4ec74fea8 mailx-12.3-pager.patch" diff --git a/community/heirloom-mailx/heirloom-mailx-12.5-fixes-1.patch b/community/heirloom-mailx/heirloom-mailx-12.5-fixes-1.patch new file mode 100644 index 0000000000..d84491b50a --- /dev/null +++ b/community/heirloom-mailx/heirloom-mailx-12.5-fixes-1.patch @@ -0,0 +1,218 @@ +Submitted By: Ken Moffat <ken at linuxfromscratch dot org> +Date: 2014-12-27 +Initial Package Version: 12.5 +Upstream Status: Unknown +Origin: Changes to remove SSL2 found at debian, remainder from redhat. +Description: Removes support for SSL2 (openssl no longer supports it) +and fixes CVE-2004-2771 [sic] and CVE-2014-7844. + +diff -Naur heirloom-mailx-12.5/extern.h heirloom-mailx-12.5-patched/extern.h +--- heirloom-mailx-12.5/extern.h 2011-04-26 22:23:22.000000000 +0100 ++++ heirloom-mailx-12.5-patched/extern.h 2014-12-27 01:26:59.654169487 +0000 +@@ -396,7 +396,7 @@ + int is_fileaddr(char *name); + struct name *usermap(struct name *names); + struct name *cat(struct name *n1, struct name *n2); +-char **unpack(struct name *np); ++char **unpack(struct name *smopts, struct name *np); + struct name *elide(struct name *names); + int count(struct name *np); + struct name *delete_alternates(struct name *np); +diff -Naur heirloom-mailx-12.5/fio.c heirloom-mailx-12.5-patched/fio.c +--- heirloom-mailx-12.5/fio.c 2011-04-26 22:23:22.000000000 +0100 ++++ heirloom-mailx-12.5-patched/fio.c 2014-12-27 01:27:15.634561413 +0000 +@@ -43,12 +43,15 @@ + #endif /* not lint */ + + #include "rcv.h" ++ ++#ifndef HAVE_WORDEXP ++#error wordexp support is required ++#endif ++ + #include <sys/stat.h> + #include <sys/file.h> + #include <sys/wait.h> +-#ifdef HAVE_WORDEXP + #include <wordexp.h> +-#endif /* HAVE_WORDEXP */ + #include <unistd.h> + + #if defined (USE_NSS) +@@ -481,7 +484,6 @@ + static char * + globname(char *name) + { +-#ifdef HAVE_WORDEXP + wordexp_t we; + char *cp; + sigset_t nset; +@@ -495,7 +497,7 @@ + sigemptyset(&nset); + sigaddset(&nset, SIGCHLD); + sigprocmask(SIG_BLOCK, &nset, NULL); +- i = wordexp(name, &we, 0); ++ i = wordexp(name, &we, WRDE_NOCMD); + sigprocmask(SIG_UNBLOCK, &nset, NULL); + switch (i) { + case 0: +@@ -527,65 +529,6 @@ + } + wordfree(&we); + return cp; +-#else /* !HAVE_WORDEXP */ +- char xname[PATHSIZE]; +- char cmdbuf[PATHSIZE]; /* also used for file names */ +- int pid, l; +- char *cp, *shell; +- int pivec[2]; +- extern int wait_status; +- struct stat sbuf; +- +- if (pipe(pivec) < 0) { +- perror("pipe"); +- return name; +- } +- snprintf(cmdbuf, sizeof cmdbuf, "echo %s", name); +- if ((shell = value("SHELL")) == NULL) +- shell = SHELL; +- pid = start_command(shell, 0, -1, pivec[1], "-c", cmdbuf, NULL); +- if (pid < 0) { +- close(pivec[0]); +- close(pivec[1]); +- return NULL; +- } +- close(pivec[1]); +-again: +- l = read(pivec[0], xname, sizeof xname); +- if (l < 0) { +- if (errno == EINTR) +- goto again; +- perror("read"); +- close(pivec[0]); +- return NULL; +- } +- close(pivec[0]); +- if (wait_child(pid) < 0 && WTERMSIG(wait_status) != SIGPIPE) { +- fprintf(stderr, catgets(catd, CATSET, 81, +- "\"%s\": Expansion failed.\n"), name); +- return NULL; +- } +- if (l == 0) { +- fprintf(stderr, catgets(catd, CATSET, 82, +- "\"%s\": No match.\n"), name); +- return NULL; +- } +- if (l == sizeof xname) { +- fprintf(stderr, catgets(catd, CATSET, 83, +- "\"%s\": Expansion buffer overflow.\n"), name); +- return NULL; +- } +- xname[l] = 0; +- for (cp = &xname[l-1]; *cp == '\n' && cp > xname; cp--) +- ; +- cp[1] = '\0'; +- if (strchr(xname, ' ') && stat(xname, &sbuf) < 0) { +- fprintf(stderr, catgets(catd, CATSET, 84, +- "\"%s\": Ambiguous.\n"), name); +- return NULL; +- } +- return savestr(xname); +-#endif /* !HAVE_WORDEXP */ + } + + /* +diff -Naur heirloom-mailx-12.5/mailx.1 heirloom-mailx-12.5-patched/mailx.1 +--- heirloom-mailx-12.5/mailx.1 2011-04-26 22:23:22.000000000 +0100 ++++ heirloom-mailx-12.5-patched/mailx.1 2014-12-27 01:26:53.838026857 +0000 +@@ -656,6 +656,14 @@ + will have the system wide alias expanded + as all mail goes through sendmail. + .SS "Recipient address specifications" ++If the ++.I expandaddr ++option is not set (the default), recipient addresses must be names of ++local mailboxes or Internet mail addresses. ++.PP ++If the ++.I expandaddr ++option is set, the following rules apply: + When an address is used to name a recipient + (in any of To, Cc, or Bcc), + names of local mail folders +@@ -2391,6 +2399,12 @@ + If this option is set, + \fImailx\fR starts even with an empty mailbox. + .TP ++.B expandaddr ++Causes ++.I mailx ++to expand message recipient addresses, as explained in the section, ++Recipient address specifications. ++.TP + .B flipr + Exchanges the + .I Respond +@@ -3575,7 +3589,7 @@ + .TP + .B ssl-method + Selects a SSL/TLS protocol version; +-valid values are `ssl2', `ssl3', and `tls1'. ++valid values are `ssl3', and `tls1'. + If unset, the method is selected automatically, + if possible. + .TP +diff -Naur heirloom-mailx-12.5/names.c heirloom-mailx-12.5-patched/names.c +--- heirloom-mailx-12.5/names.c 2011-04-26 22:23:22.000000000 +0100 ++++ heirloom-mailx-12.5-patched/names.c 2014-12-27 01:26:59.654169487 +0000 +@@ -268,6 +268,9 @@ + FILE *fout, *fin; + int ispipe; + ++ if (value("expandaddr") == NULL) ++ return names; ++ + top = names; + np = names; + time(&now); +@@ -546,7 +549,7 @@ + * Return an error if the name list won't fit. + */ + char ** +-unpack(struct name *np) ++unpack(struct name *smopts, struct name *np) + { + char **ap, **top; + struct name *n; +@@ -561,7 +564,7 @@ + * the terminating 0 pointer. Additional spots may be needed + * to pass along -f to the host mailer. + */ +- extra = 2; ++ extra = 3 + count(smopts); + extra++; + metoo = value("metoo") != NULL; + if (metoo) +@@ -578,6 +581,10 @@ + *ap++ = "-m"; + if (verbose) + *ap++ = "-v"; ++ for (; smopts != NULL; smopts = smopts->n_flink) ++ if ((smopts->n_type & GDEL) == 0) ++ *ap++ = smopts->n_name; ++ *ap++ = "--"; + for (; n != NULL; n = n->n_flink) + if ((n->n_type & GDEL) == 0) + *ap++ = n->n_name; +diff -Naur heirloom-mailx-12.5/sendout.c heirloom-mailx-12.5-patched/sendout.c +--- heirloom-mailx-12.5/sendout.c 2011-04-26 22:23:22.000000000 +0100 ++++ heirloom-mailx-12.5-patched/sendout.c 2014-12-27 01:26:59.654169487 +0000 +@@ -835,7 +835,7 @@ + #endif /* HAVE_SOCKETS */ + + if ((smtp = value("smtp")) == NULL) { +- args = unpack(cat(mailargs, to)); ++ args = unpack(mailargs, to); + if (debug || value("debug")) { + printf(catgets(catd, CATSET, 181, + "Sendmail arguments:")); diff --git a/community/heirloom-mailx/libressl.patch b/community/heirloom-mailx/libressl.patch deleted file mode 100644 index 992b576f4c..0000000000 --- a/community/heirloom-mailx/libressl.patch +++ /dev/null @@ -1,43 +0,0 @@ -diff --git a/openssl.c b/openssl.c -index b4e33fc..a7c57e7 100644 ---- a/openssl.c -+++ b/openssl.c -@@ -135,6 +135,7 @@ ssl_rand_init(void) - char *cp; - int state = 0; - -+#ifndef OPENSSL_NO_EGD - if ((cp = value("ssl-rand-egd")) != NULL) { - cp = expand(cp); - if (RAND_egd(cp) == -1) { -@@ -143,7 +144,9 @@ ssl_rand_init(void) - cp); - } else - state = 1; -- } else if ((cp = value("ssl-rand-file")) != NULL) { -+ } else -+#endif -+ if ((cp = value("ssl-rand-file")) != NULL) { - cp = expand(cp); - if (RAND_load_file(cp, 1024) == -1) { - fprintf(stderr, catgets(catd, CATSET, 246, -@@ -216,11 +219,17 @@ ssl_select_method(const char *uhp) - - cp = ssl_method_string(uhp); - if (cp != NULL) { -+#if !defined(OPENSSL_NO_SSL2) && OPENSSL_VERSION_NUMBER < 0x10100000L - if (equal(cp, "ssl2")) - method = SSLv2_client_method(); -- else if (equal(cp, "ssl3")) -+ else -+#endif -+#if !defined(OPENSSL_NO_SSL3_METHOD) -+ if (equal(cp, "ssl3")) - method = SSLv3_client_method(); -- else if (equal(cp, "tls1")) -+ else -+#endif -+ if (equal(cp, "tls1")) - method = TLSv1_client_method(); - else { - fprintf(stderr, catgets(catd, CATSET, 244, diff --git a/community/heirloom-mailx/mailx-12.3-pager.patch b/community/heirloom-mailx/mailx-12.3-pager.patch new file mode 100644 index 0000000000..d4b243929c --- /dev/null +++ b/community/heirloom-mailx/mailx-12.3-pager.patch @@ -0,0 +1,12 @@ +diff -Nrbu mailx-12.3/cmd1.c mailx-12.3-OK/cmd1.c +--- mailx-12.3/cmd1.c 2007-06-16 16:48:39.000000000 +0400 ++++ mailx-12.3-OK/cmd1.c 2008-06-26 19:57:38.000000000 +0400 +@@ -78,7 +78,7 @@ + + cp = value("PAGER"); + if (cp == NULL || *cp == '\0') +- cp = value("bsdcompat") ? "more" : "pg"; ++ cp = value("bsdcompat") ? "more" : "less"; + return cp; + } + diff --git a/community/heirloom-mailx/mailx-12.5-collect.patch b/community/heirloom-mailx/mailx-12.5-collect.patch new file mode 100644 index 0000000000..b84d2e8f36 --- /dev/null +++ b/community/heirloom-mailx/mailx-12.5-collect.patch @@ -0,0 +1,13 @@ +--- mailx-12.4.orig/collect.c 2012-09-12 16:07:53.653103796 -0400 ++++ mailx-12.4/collect.c 2012-09-12 21:27:05.092259236 -0400 +@@ -905,7 +905,9 @@ err: + if (collf != NULL) { + Fclose(collf); + collf = NULL; +- } ++ } else { ++ exit(1); ++ } + out: + if (collf != NULL) { + if ((cp = value("MAILX_TAIL")) != NULL) { diff --git a/community/heirloom-mailx/mailx-12.5-fname-null.patch b/community/heirloom-mailx/mailx-12.5-fname-null.patch new file mode 100644 index 0000000000..3b3fb58c5a --- /dev/null +++ b/community/heirloom-mailx/mailx-12.5-fname-null.patch @@ -0,0 +1,12 @@ +diff -upr mailx-12.5.orig/names.c mailx-12.5/names.c +--- mailx-12.5.orig/names.c 2006-03-04 01:32:16.000000000 +0100 ++++ mailx-12.5/names.c 2012-11-01 15:28:43.883573793 +0100 +@@ -360,7 +360,7 @@ outof(struct name *names, FILE *fo, stru + free_child(pid); + } else { + int f; +- if ((fout = Zopen(fname, "a", NULL)) == NULL) { ++ if ((fname == NULL) || ((fout = Zopen(fname, "a", NULL)) == NULL)) { + perror(fname); + senderr++; + goto cant; diff --git a/community/heirloom-mailx/mailx-12.5-lzw.patch b/community/heirloom-mailx/mailx-12.5-lzw.patch new file mode 100644 index 0000000000..2dc1fbccf9 --- /dev/null +++ b/community/heirloom-mailx/mailx-12.5-lzw.patch @@ -0,0 +1,12 @@ +diff -Nrbu mailx-12.5/lzw.c mailx-12.5-OK/lzw.c +--- mailx-12.5/lzw.c 2006-03-04 03:32:16.000000000 +0300 ++++ mailx-12.5-OK/lzw.c 2011-08-17 16:30:01.000000000 +0400 +@@ -516,6 +516,8 @@ + + /* Generate output characters in reverse order. */ + while (code >= 256) { ++ if (stackp - de_stack >= HSIZE - 1) ++ return -1; + *stackp++ = tab_suffixof(code); + code = tab_prefixof(code); + } diff --git a/community/heirloom-mailx/mailx-12.5-usage.patch b/community/heirloom-mailx/mailx-12.5-usage.patch new file mode 100644 index 0000000000..3c375ade9b --- /dev/null +++ b/community/heirloom-mailx/mailx-12.5-usage.patch @@ -0,0 +1,12 @@ +diff -upr mailx-12.5.orig/main.c mailx-12.5/main.c +--- mailx-12.5.orig/main.c 2007-10-02 14:15:50.000000000 +0200 ++++ mailx-12.5/main.c 2013-07-22 16:06:56.960765683 +0200 +@@ -353,7 +353,7 @@ main(int argc, char *argv[]) + case '?': + usage: + fprintf(stderr, catgets(catd, CATSET, 135, +-"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 -eiIUdEFntBDNHRVv~ -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); + exit(2); + } + } diff --git a/community/heirloom-mailx/nail-11.25-config.patch b/community/heirloom-mailx/nail-11.25-config.patch new file mode 100644 index 0000000000..10264206d2 --- /dev/null +++ b/community/heirloom-mailx/nail-11.25-config.patch @@ -0,0 +1,11 @@ +diff -Nrbu nail-11.25/nail.rc nail-11.25-OK/nail.rc +--- nail-11.25/nail.rc 2005-01-15 17:33:16.000000000 +0300 ++++ nail-11.25-OK/nail.rc 2005-08-19 16:55:09.000000000 +0400 +@@ -64,3 +64,7 @@ + + # Only include selected header fields when forwarding messages. + fwdretain subject date from to ++ ++# For Linux and BSD, this should be set. ++set bsdcompat ++ diff --git a/community/heirloom-mailx/openssl.patch b/community/heirloom-mailx/openssl.patch new file mode 100644 index 0000000000..15767d2669 --- /dev/null +++ b/community/heirloom-mailx/openssl.patch @@ -0,0 +1,39 @@ +--- a/openssl.c.orig 2014-07-22 20:59:16.024655378 +0200 ++++ b/openssl.c 2014-07-22 21:00:45.754482770 +0200 +@@ -137,11 +137,13 @@ ssl_rand_init(void) + + if ((cp = value("ssl-rand-egd")) != NULL) { + cp = expand(cp); ++#ifdef HAVE_OPENSSL_RAND_EGD + if (RAND_egd(cp) == -1) { + fprintf(stderr, catgets(catd, CATSET, 245, + "entropy daemon at \"%s\" not available\n"), + cp); + } else ++#endif + state = 1; + } else if ((cp = value("ssl-rand-file")) != NULL) { + cp = expand(cp); +@@ -216,9 +218,7 @@ ssl_select_method(const char *uhp) + + cp = ssl_method_string(uhp); + if (cp != NULL) { +- if (equal(cp, "ssl2")) +- method = SSLv2_client_method(); +- else if (equal(cp, "ssl3")) ++ if (equal(cp, "ssl3")) + method = SSLv3_client_method(); + else if (equal(cp, "tls1")) + method = TLSv1_client_method(); + +--- a/openssl.c.orig 2016-03-30 17:03:49.491514269 +0200 ++++ b/openssl.c 2016-03-30 17:04:03.026491689 +0200 +@@ -219,7 +219,7 @@ ssl_select_method(const char *uhp) + cp = ssl_method_string(uhp); + if (cp != NULL) { + if (equal(cp, "ssl3")) +- method = SSLv3_client_method(); ++ method = SSLv23_client_method(); + else if (equal(cp, "tls1")) + method = TLSv1_client_method(); + else { |