summaryrefslogtreecommitdiff
path: root/usr.sbin/sendmail/contrib/mh.patch
blob: 7b23a5b71dd4f73e35dbc65f57acb75364524e3d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
Message-Id: <199309031900.OAA19417@ignatz.acs.depaul.edu>
To: bug-mh@ics.uci.edu
cc: mh-users@ics.uci.edu, eric@cs.berkeley.edu
Subject: MH-6.8.1/Sendmail 8.X (MH patch) updated
Date: Fri, 03 Sep 1993 14:00:46 -0500
From: Dave Nelson <dcn@ignatz.acs.depaul.edu>


	This patch will fix the "X-auth..." warnings from the newer
Sendmails (8.X) while continuing to work with the old sendmails.

	I think the following patch will make everyone happy.

	1)  Anybody with MH-6.8.1 can install this.  It doesn't matter
	    what version of sendmail you're running.  It doesn't matter
	    if you're not running sendmail (but it won't fix anything
	    for you).

	2)  No configuration file hacks. If the -client switch is
	    absent (the default), the new sendmails will get an EHLO 
	    using what LocalName() returns as the hostname.  On my systems, 
	    this returns the FQDN.  If the EHLO fails with a result between 
	    500 and 599  and the -client switch is not set, we give up on 
	    sending EHLO/HELO and just go deliver the mail.

	3)  No new configuration options.

	4)  Retains the undocumented -client switch.  One warning:  it
	    is possible using the -client switch to cause the old sendmails
	    to return "I refuse to talk to myself".  You could do this under
	    the old code as well.  This will happen if you claim to be the
	    same system as the sendmail you're sending to is running on.  
	    That's pointless, but possible.  If you do this, just like under
	    the old code, you will get an error.

	5)  If you're running a site with both old and new sendmails, you only
	    have to build MH once.  The code's the same; works with them
	    both.

	If you decide to install this, make sure that you look the patch
over and that you agree with what it is doing.  It works for me, but I
can't test it on every possible combination.  Make sure that it works
before you really install it for your users, if any.  No promises.

	To install this, save this to a file in the mts/sendmail directory.
Feed it to patch.  Patch will ignore the non-patch stuff.  You should have
"mts sendmail/smtp" in your configuration file.  This works with old and
new sendmails.  Using "mts sendmail"  will cause the new sendmails to
print an "X-auth..." warning about who owns the process piping the mail 
message.  I don't know of anyway of getting rid of these.

	mh-config (if necessary), make, make inst-all.


I hope this helps people.
	
/dcn

Dave Nelson
Academic Computer Services
DePaul University, Chicago

*** smail.c	Fri Sep  3 11:58:05 1993
--- smail.c	Fri Sep  3 11:57:27 1993
***************
*** 239,261 ****
  		    return RP_RPLY;
  	    }
  
! 	    if (client && *client) {
! 		doingEHLO = 1;
! 		result = smtalk (SM_HELO, "EHLO %s", client);
! 		doingEHLO = 0;
  
! 		if (500 <= result && result <= 599)
  		    result = smtalk (SM_HELO, "HELO %s", client);
! 
! 		switch (result) {
  		    case 250:
! 		        break;
  
  		    default:
  			(void) sm_end (NOTOK);
  			return RP_RPLY;
  		}
  	    }
  
  #ifndef	ZMAILER
  	    if (onex)
--- 239,276 ----
  		    return RP_RPLY;
  	    }
  
! 	    doingEHLO = 1;
! 	    result = smtalk (SM_HELO, "EHLO %s", 
! 			     (client && *client) ? client : LocalName());
! 	    doingEHLO = 0;
! 
! 	    switch (result)
! 	    {
! 	    case 250:
! 		break;
  
! 	    default:
! 		if (!(500 <= result && result <= 599))
! 		{
! 		    (void) sm_end (NOTOK);
! 		    return RP_RPLY;
! 		}
! 		
! 		if (client && *client)
! 		{
  		    result = smtalk (SM_HELO, "HELO %s", client);
! 		    switch (result)
! 		    {
  		    case 250:
! 			break;
  
  		    default:
  			(void) sm_end (NOTOK);
  			return RP_RPLY;
+ 		    }
  		}
  	    }
+ 	    
  
  #ifndef	ZMAILER
  	    if (onex)
***************
*** 357,380 ****
  	    return RP_RPLY;
      }
  
!     if (client && *client) {
! 	doingEHLO = 1;
! 	result = smtalk (SM_HELO, "EHLO %s", client);
! 	doingEHLO = 0;
  
! 	if (500 <= result && result <= 599)
  	    result = smtalk (SM_HELO, "HELO %s", client);
! 
! 	switch (result) {
! 	    case 250: 
  		break;
  
! 	    default: 
  		(void) sm_end (NOTOK);
  		return RP_RPLY;
  	}
      }
! 
  send_options: ;
      if (watch && EHLOset ("XVRB"))
  	(void) smtalk (SM_HELO, "VERB on");
--- 372,409 ----
  	    return RP_RPLY;
      }
  
!     doingEHLO = 1;
!     result = smtalk (SM_HELO, "EHLO %s", 
! 		     (client && *client) ? client : LocalName());
!     doingEHLO = 0;
! 
!     switch (result)
!     {
!     case 250:
! 	break;
! 
!     default:
! 	if (!(500 <= result && result <= 599))
! 	{
! 	    (void) sm_end (NOTOK);
! 	    return RP_RPLY;
! 	}
  
! 	if (client && *client)
! 	{
  	    result = smtalk (SM_HELO, "HELO %s", client);
! 	    switch (result)
! 	    {
! 	    case 250:
  		break;
  
! 	    default:
  		(void) sm_end (NOTOK);
  		return RP_RPLY;
+ 	    }
  	}
      }
!     
  send_options: ;
      if (watch && EHLOset ("XVRB"))
  	(void) smtalk (SM_HELO, "VERB on");