s/qmail 4.3.20
Next generation secure email transport
Loading...
Searching...
No Matches
received.c
Go to the documentation of this file.
1#include "fmt.h"
2#include "qmail.h"
3#include "now.h"
4#include "datetime.h"
5#include "date822fmt.h"
6#include "received.h"
7#include "str.h"
8#include "stralloc.h"
9#include "byte.h"
10#include "str.h"
11
12static int issafe(char ch)
13{
14 if (ch == ' ') return 1; /* accept empty spaces */
15 if (ch == '.') return 1;
16 if (ch == '@') return 1;
17 if (ch == '%') return 1;
18 if (ch == '+') return 1;
19 if (ch == '/') return 1;
20 if (ch == '=') return 1;
21 if (ch == ':') return 1;
22 if (ch == '-') return 1;
23 if ((ch >= 'a') && (ch <= 'z')) return 1;
24 if ((ch >= 'A') && (ch <= 'Z')) return 1;
25 if ((ch >= '0') && (ch <= '9')) return 1;
26 return 0;
27}
28
29void safeput(struct qmail *qqt,char *s)
30{
31 char ch;
32 while ((ch = *s++)) {
33 if (!issafe(ch)) ch = '?';
34 qmail_put(qqt,&ch,1);
35 }
36}
37
38static char buf[DATE822FMT];
39
40/* "Received: from relay1.uu.net ([E]HELO uunet.uu.net) (user@192.48.96.5)" */
41/* " for <smtprecipient>" */
42/* " de/crypted with tls-version: cipher [used/perm] DN=dn" */
43/* " by silverton.berkeley.edu with [UTF8][E]SMTP[SA]; 26 Sep 1995 04:46:54 -0000" */
44/* "X-RBL-Info: http://www.spamhaus.org/query/bl?ip=127.0.0.2 */
45
46void received(struct qmail *qqt,char *protocol,char *local,char *remoteip,char *remotehost,char *remoteinfo,char *helo,char *tlsinfo,char *rblinfo, char *mailto)
47{
48 struct datetime dt;
49 int i;
50
51 qmail_puts(qqt,"Received: from ");
53 if (helo) {
54 qmail_puts(qqt," (HELO ");
55 safeput(qqt,helo);
56 qmail_puts(qqt,")");
57 }
58 qmail_puts(qqt," (");
59 if (remoteinfo) {
61 qmail_puts(qqt,"@");
62 }
64 qmail_puts(qqt,")\n");
65
66 if (mailto) {
67 qmail_puts(qqt," for <");
69 qmail_puts(qqt,">\n");
70 } else {
71 qmail_puts(qqt," for <>\n");
72 }
73 if (tlsinfo) {
74 qmail_puts(qqt," de/crypted with ");
76 qmail_puts(qqt,"\n");
77 }
78 qmail_puts(qqt," by ");
80 qmail_puts(qqt," with ");
82 qmail_puts(qqt,"; ");
85
86 if (rblinfo) {
87 i = str_chr(rblinfo,']');
88 if (rblinfo[i] == ']') {
89 qmail_puts(qqt,"X-RBL-Info: ");
90 qmail_puts(qqt,rblinfo + i + 2);
91 qmail_puts(qqt,"\n");
92 }
93 }
94}
95
96/* "Received-SPF: pass (Helogreeting: domain of Identity " */
97/* " designates Clientip as permitted sender) receiver=Hostname " */
98/* " client-ip=Clientip; envelope-from=Mailfrom; " */
99
100void spfheader(struct qmail *qqt,char *spfinfo,char *local,char *remoteip,char *helohost,char *mailfrom)
101{
102 char *result = 0;
103 char *identity = 0;
104 char *clientip = 0;
105 char *helo = 0;
106 char *envelopefrom = 0;
107 char *receiver = 0;
108 char *problem = 0;
109 char *mechanism = 0;
110 int i, j = 0;
111 int len;
112
113 len = str_len(spfinfo);
114 if (!len) return;
115
116 for (i = 0; i < len; i++)
117 if (spfinfo[i] == ' ') spfinfo[i] = '\0';
118
119 for (i = 0; i < len; i++) {
120 if (spfinfo[i] == '\0') {
121 switch (spfinfo[i + 1]) {
122 case 'S': clientip = spfinfo + i + 3; break;
123 case 'O': envelopefrom = spfinfo + i + 3; break;
124 case 'C': identity = spfinfo + i + 3; break;
125 case 'H': helo = spfinfo + i + 3; break;
126 case 'T': receiver = spfinfo + i + 3; break;
127 case 'P': problem = spfinfo + i + 3; break;
128 case 'M': if ((j = str_chr(spfinfo + i,'='))) spfinfo[i + j] = '\0';
129 mechanism = spfinfo + i + 1; break;
130 case 'R': result = spfinfo + i + 3; break;
131 default: break;
132 }
133 }
134 }
135
136 if (!result || *result == 0) result = "o";
137 if (!clientip || *clientip == 0) clientip = remoteip;
138 if (!helo || *helo == 0) helo = helohost;
139 if (!envelopefrom || *envelopefrom == 0) envelopefrom = mailfrom;
140 if (!receiver || *receiver == 0) receiver = local;
141 if (!problem || *problem == 0) problem = "unknown";
142 if (!mechanism || *mechanism == 0) mechanism = "unknown";
143 if (!identity || *identity == 0) {
144 j = str_rchr(envelopefrom,'@');
145 if (envelopefrom[j] == '@') identity = envelopefrom + j + 1;
146 else identity = "unknown";
147 }
148
149 qmail_puts(qqt,"Received-SPF: ");
150 switch (*result) {
151 case '+': qmail_puts(qqt," pass ("); safeput(qqt,helo);
152 qmail_puts(qqt,": domain of "); safeput(qqt,identity); qmail_puts(qqt,"\n");
153 qmail_puts(qqt," designates "); safeput(qqt,clientip); qmail_puts(qqt," as permitted sender)\n");
154 qmail_puts(qqt," receiver="); safeput(qqt,receiver);
155 qmail_puts(qqt,"; client-ip="); safeput(qqt,clientip); qmail_puts(qqt,"\n");
156 qmail_puts(qqt," envelope-from="); safeput(qqt,envelopefrom); qmail_puts(qqt,";\n"); break;
157 case '-': qmail_puts(qqt," fail ("); safeput(qqt,helo);
158 qmail_puts(qqt,": domain of "); safeput(qqt,identity); qmail_puts(qqt,"\n");
159 qmail_puts(qqt," does not designate "); safeput(qqt,clientip); qmail_puts(qqt," as permitted sender)\n"); break;
160 case '~': qmail_puts(qqt," softfail ("); safeput(qqt,helo);
161 qmail_puts(qqt,": domain of transitioning "); safeput(qqt,identity); qmail_puts(qqt,"\n");
162 qmail_puts(qqt," does not designate "); safeput(qqt,clientip); qmail_puts(qqt," as permitted sender)\n"); break;
163 case '?': qmail_puts(qqt," neutral ("); safeput(qqt,helo); qmail_puts(qqt,"; client-ip="); safeput(qqt,clientip);
164 qmail_puts(qqt," is neither permitted \n"); qmail_puts(qqt," nor denied by domain of "); safeput(qqt,identity),
165 qmail_puts(qqt,")\n"); break;
166 case 'o': qmail_puts(qqt," none ("); safeput(qqt,helo);
167 qmail_puts(qqt,": domain of "); safeput(qqt,identity); qmail_puts(qqt," does\n");
168 qmail_puts(qqt," not designate permitted sender hosts)\n"); break;
169 case 't': qmail_puts(qqt," temperror ("); safeput(qqt,helo);
170 qmail_puts(qqt,": domain of "); safeput(qqt,identity); qmail_puts(qqt," evaluated\n");
171 qmail_puts(qqt," with error: "); safeput(qqt,problem); qmail_puts(qqt," for mechanism: "); safeput(qqt,mechanism);
172 qmail_puts(qqt,")\n"); break;
173 case 'e': qmail_puts(qqt," permerror ("); safeput(qqt,helo);
174 qmail_puts(qqt,": domain of "); safeput(qqt,identity); qmail_puts(qqt," evaluated\n");
175 qmail_puts(qqt," with error: "); safeput(qqt,problem); qmail_puts(qqt," for mechanism: "); safeput(qqt,mechanism);
176 qmail_puts(qqt,")\n"); break;
177 default: qmail_puts(qqt," unknown (results for "); safeput(qqt,helo);
178 qmail_puts(qqt,": domain of "); safeput(qqt,identity);
179 qmail_puts(qqt," follow an unknown mechanism: "); safeput(qqt,mechanism); qmail_puts(qqt,")\n"); break;
180 }
181}
struct qmail qqt
Definition: condredirect.c:14
unsigned int date822fmt(char *s, struct datetime *dt)
Definition: date822fmt.c:9
#define DATE822FMT
Definition: date822fmt.h:5
void datetime_tai(struct datetime *dt, datetime_sec t)
Definition: datetime.c:4
char buf[100+FMT_ULONG]
Definition: hier.c:11
datetime_sec now()
Definition: now.c:5
char * local
Definition: qmail-getpw.c:18
stralloc protocol
Definition: qmail-popup.c:70
char * remoteip
Definition: qmail-popup.c:73
stralloc tlsinfo
Definition: qmail-qmtpd.c:96
char * remoteinfo
Definition: qmail-qmtpd.c:88
struct datetime dt
Definition: qmail-queue.c:35
char * received
Definition: qmail-queue.c:69
stralloc helohost
Definition: qmail-remote.c:77
int j
Definition: qmail-send.c:926
stralloc mailto
Definition: qmail-smtpd.c:268
stralloc mailfrom
Definition: qmail-smtpd.c:532
stralloc rblinfo
Definition: qmail-smtpd.c:271
void qmail_put(struct qmail *, char *, int)
Definition: qmail.c:63
void qmail_puts(struct qmail *, char *)
Definition: qmail.c:68
int issafe(char)
Definition: qsutil.c:64
void safeput(struct qmail *qqt, char *s)
Definition: received.c:29
void spfheader(struct qmail *qqt, char *spfinfo, char *local, char *remoteip, char *helohost, char *mailfrom)
Definition: received.c:100
stralloc identity
Definition: spf.c:35
stralloc spfinfo
Definition: spf.c:17
Definition: qmail.h:14
stralloc remotehost
Definition: qmail-popup.c:74