mirror of
https://github.com/9fans/plan9port.git
synced 2025-01-24 11:41:58 +00:00
upas/smtp: fix TLS connections (#163)
Both `upas/nfs` and `upas/smtp` call the currently broken `tlsClient()` from libsec. This commit copies a fix from upas/nfs into upas/smtp. In `imapdial()`, upas/nfs replaces a process call for tlsClient with `stunnel3` when not on Plan 9. upas/smtp calls tlsClient directly as a function, so imapdial was copied into mxdial.c as `smtpdial()`, and tlsClient+dial replaced with a call to smtpdial.
This commit is contained in:
parent
9c38253d1d
commit
de43b1629d
2 changed files with 49 additions and 0 deletions
|
@ -2,6 +2,7 @@
|
|||
#include <ndb.h>
|
||||
#include "smtp.h" /* to publish dial_string_parse */
|
||||
#include <ip.h>
|
||||
#include <thread.h>
|
||||
|
||||
enum
|
||||
{
|
||||
|
@ -27,6 +28,45 @@ static int callmx(DS*, char*, char*);
|
|||
static void expand_meta(DS *ds);
|
||||
extern int cistrcmp(char*, char*);
|
||||
|
||||
/* Taken from imapdial, replaces tlsclient call with stunnel */
|
||||
static int
|
||||
smtpdial(char *server)
|
||||
{
|
||||
int p[2];
|
||||
int fd[3];
|
||||
char *tmp;
|
||||
char *fpath;
|
||||
|
||||
if(pipe(p) < 0)
|
||||
return -1;
|
||||
fd[0] = dup(p[0], -1);
|
||||
fd[1] = dup(p[0], -1);
|
||||
fd[2] = dup(2, -1);
|
||||
#ifdef PLAN9PORT
|
||||
tmp = smprint("%s:587", server);
|
||||
fpath = searchpath("stunnel3");
|
||||
if (!fpath) {
|
||||
werrstr("stunnel not found. it is required for tls support.");
|
||||
return -1;
|
||||
}
|
||||
if(threadspawnl(fd, fpath, "stunnel", "-n", "smtp" , "-c", "-r", tmp, nil) < 0) {
|
||||
#else
|
||||
tmp = smprint("tcp!%s!587", server);
|
||||
if(threadspawnl(fd, "/bin/tlsclient", "tlsclient", tmp, nil) < 0){
|
||||
#endif
|
||||
free(tmp);
|
||||
close(p[0]);
|
||||
close(p[1]);
|
||||
close(fd[0]);
|
||||
close(fd[1]);
|
||||
close(fd[2]);
|
||||
return -1;
|
||||
}
|
||||
free(tmp);
|
||||
close(p[0]);
|
||||
return p[1];
|
||||
}
|
||||
|
||||
int
|
||||
mxdial(char *addr, char *ddomain, char *gdomain)
|
||||
{
|
||||
|
@ -100,13 +140,21 @@ callmx(DS *ds, char *dest, char *domain)
|
|||
}
|
||||
/* dial each one in turn */
|
||||
for(i = 0; i < nmx; i++){
|
||||
#ifdef PLAN9PORT
|
||||
snprint(addr, sizeof(addr), "%s", mx[i].host);
|
||||
#else
|
||||
snprint(addr, sizeof(addr), "%s!%s!%s", ds->proto,
|
||||
mx[i].host, ds->service);
|
||||
#endif
|
||||
if(debug)
|
||||
fprint(2, "mxdial trying %s (%d)\n", addr, i);
|
||||
atnotify(timeout, 1);
|
||||
alarm(10*1000);
|
||||
#ifdef PLAN9PORT
|
||||
fd = smtpdial(addr);
|
||||
#else
|
||||
fd = dial(addr, 0, 0, 0);
|
||||
#endif
|
||||
alarm(0);
|
||||
atnotify(timeout, 0);
|
||||
if(fd >= 0)
|
||||
|
|
|
@ -467,6 +467,7 @@ hello(char *me, int encrypted)
|
|||
}
|
||||
|
||||
ehlo = 1;
|
||||
encrypted = 1;
|
||||
Again:
|
||||
if(ehlo)
|
||||
dBprint("EHLO %s\r\n", me);
|
||||
|
|
Loading…
Reference in a new issue