1
<?xml version="1.0" encoding="ISO-8859-1"?>
2
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
3
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
4
<html xmlns="http://www.w3.org/1999/xhtml">
5
<head>
6
<title>Fetchmail Feature List</title>
7
<link rev="made" href="mailto:esr@snark.thyrsus.com" />
8
<meta name="description" content="The fetchmail brag sheet." />
9
<meta name="keywords" content="fetchmail, POP, POP3, IMAP, IMAP2bis, IMAP4" />
10
<style type="text/css">
11
/*<![CDATA[*/
12
 h1.c1 {text-align: center}
13
/*]]>*/
14
</style>
15
</head>
16
<body>
17
<table width="100%" cellpadding="0" summary="Canned page header">
18
<tr>
19
<td width="30%">Back to <a href="index.html">Fetchmail Home Page</a></td>
20
<td width="30%" align="right">$Date$</td>
21
</tr>
22
</table>
23
24
<hr />
25
<h1 class="c1">Fetchmail Feature List</h1>
26
27
<h2>Since 5.0:</h2>
28
29
<ul>
30
<li>STARTTLS is supported in both POP and IMAP.</li>
31
32
<li>ESMTP AUTH (RFC 2554) is supported.</li>
33
34
<li>Has the capability of adding trace information to the Received
35
header to faciliate mail filtering by mailserver and remote
36
account.</li>
37
38
<li>Fetchmail now has options to handle SSL certificate
39
validation.</li>
40
41
<li>Fetchmail can be told to fall back to delivering via local
42
sendmail if it can't open port 25.</li>
43
44
<li>Support for AUTH=CRAM-MD5 under POP3, a la RFC2195.</li>
45
46
<li>Support for ODMR (On-Demand Mail Relay), RFC 2645.</li>
47
48
<li>It's now easy to deliver mail to a local LMTP socket.</li>
49
50
<li>The interface option now checks both local and remote interface
51
IPs.</li>
52
53
<li>The plugin facility has been enhanced; %h and %p options are
54
now available to pass in the hostname and service port number.</li>
55
56
<li>Added a dropdelivered option to discard Delivered-To headers.
57
This addresses a problem with using fetchmail and postfix as a
58
relay inside a domain; when postfix sees incoming messages with
59
delivered-to headers looking exactly the same as the ones it adds
60
himself, it bounces the message.</li>
61
62
<li>Added --smtpname to set username and domain portion of SMTP
63
"RCPT TO" command. &lt;fetchmail@mail.julianhaight.com&gt;.</li>
64
65
<li>Added "from" server's IP address to inserted Received line
66
&lt;fetchmail@mail.julianhaight.com&gt;.</li>
67
68
<li>Fetchmail now runs on BeOS, thanks to David Reid
69
&lt;david@jetnet.co.uk&gt;.</li>
70
71
<li>In IMAP, unseen-message counting and indexing is now done by
72
SEARCH UNSEEN at the beginning of each poll or re-poll (rather than
73
with the UNSEEN and RECENT responses and FLAGS queries on
74
individual messages). This significantly cuts down on traffic to
75
and from the server, and gives more reliable results.</li>
76
77
<li>The aka option now matches hostname suffixes, so (for example)
78
saying `aka netaxs.com' will match not just netaxs.com but also
79
(say) pop3.netaxs.com and mail.netaxs.com.</li>
80
81
<li>Fetchmail can optionally use the RFC 2177 IDLE extension on an
82
IMAP server that supports it. On IMAP servers that don't, it can
83
simulate it using periodic NOOP commands.</li>
84
85
<li>Fetchmail now recognizes the RFC 2449 extended responses
86
[IN-USE] and [LOGIN-DELAY].</li>
87
88
<li>Fetchmail running in daemon mode now restarts itself quietly
89
when the rc file is touched.</li>
90
91
<li>Following recent court decisions and changes in U.S. federal
92
regulatory policy, hooks for Secure Sockets Layer (SSL) are now
93
part of the main fetchmail distribution. The distribution still
94
contains no actual cryptographic code.</li>
95
96
<li>NTLM support under IMAP, so fetchmail can query Microsoft
97
Exchange servers.</li>
98
99
<li>Expunge option can now be used to break POP3 retrieval into
100
subsessions.</li>
101
102
<li>Support for AUTH=CRAM-MD5 under IMAP, a la RFC2195.</li>
103
</ul>
104
105
<h2>Since 4.0:</h2>
106
107
<ul>
108
<li>The interface and monitor options now work with freeBSD.</li>
109
110
<li>Fetchmail now sends RFC1894-conformant bouncemail on SMTP and
111
LMTP errors.</li>
112
113
<li>Full support for LMTP according to RFC2033.</li>
114
115
<li>True multi-language support using GNU gettext.</li>
116
117
<li>Support for use of HESIOD with Kerberos.</li>
118
119
<li>The --bsmtp option supports recording fetched mail as a BSMTP
120
batch.</li>
121
122
<li>The --limit option can now be used in daemon mode, with
123
oversized-message notifications being mailed to the calling
124
user.</li>
125
126
<li>Configurable support for the <a
127
href="http://www.demon.net/helpdesk/producthelp/mail/sdps-tech.html/">
128
SDPS extensions</a> in <a
129
href="http://www.demon.net/">www.demon.net</a>'s POP3 service.</li>
130
131
<li>There is now an interactive GUI fetchmail configurator,
132
fetchmailconf.</li>
133
134
<li>Code is 64-bit clean and Y2K-safe.</li>
135
136
<li>Automatically decodes armored 7-bit MIME into 8 bits (this can
137
be suppressed).</li>
138
139
<li>You can specify which SMTP error is recognized as a spam
140
block.</li>
141
142
<li>Support for Kerberos V authentication.</li>
143
144
<li>Support for IMAP-OTP authentication using Craig Metz's patches
145
for UW IMAP.</li>
146
147
<li>Support for IPv6</li>
148
149
<li>Support for IMAP with RFC1731-conformant GSSAPI
150
authentication.</li>
151
152
<li>Fixed and verified support for Cyrus IMAP server, M$ Exchange,
153
and Post Office/NT.</li>
154
155
<li>Support for responding with a one-time password when a POP3
156
server issues an RFC1938-conforming OTP challenge.</li>
157
158
<li>Support for Compuserve's RPA authentication protocol for POP3
159
(not compiled in by default, but configurable).</li>
160
</ul>
161
162
<h2>Since 3.0:</h2>
163
164
<ul>
165
<li>Support for IMAP RFC 1731 authentication with Kerberos v4.</li>
166
167
<li>Support for multiple-folder retrieval in a single session under
168
IMAP.</li>
169
170
<li>Following SMTP 571 response to a From line, fetchmail no longer
171
downloads the bodies of spam messages.</li>
172
173
<li>Support for a `hunt list' of SMTP hosts.</li>
174
175
<li>Support for ESMTP 8BITMIME and SIZE options.</li>
176
177
<li>Support for ESMTP ETRN command.</li>
178
179
<li>The stripcr &amp; forcecr options to explicitly control
180
carriage-return stripping and LF-&gt;CRLF mapping before mail
181
forwarding.</li>
182
</ul>
183
184
<h2>Since 2.0:</h2>
185
186
<ul>
187
<li>Support for secure use with ssh.</li>
188
189
<li>Mailserver passwords can be parsed out of your .netrc
190
file.</li>
191
192
<li>When forwarding mail via SMTP, fetchmail respects the 571 "spam
193
filter" response and discards any mail that triggers it.</li>
194
195
<li>Transaction and error logging may optionally be done via
196
syslog.</li>
197
198
<li>(Linux only) Security option to permit fetchmail to poll a host
199
only when a point-to-point link to a particular IP address is
200
up.</li>
201
202
<li>RPOP support (restored; had been removed in 1.8).</li>
203
</ul>
204
205
<h2>2.0 and earlier versions:</h2>
206
207
<ul>
208
<li>Support POP2, APOP, RPOP, IMAP2, IMAP2bis, IMAP3, IMAP4,
209
IMAP4rev1. .</li>
210
211
<li>Support for Kerberos V4 user authentication (either MIT or
212
Cygnus).</li>
213
214
<li>Host is auto-probed for a working server if no protocol is
215
specified for the connection. Thus you don't need to know what
216
servers are running on your mail host in advance; the verbose
217
option will tell you which one succeeds.</li>
218
219
<li>Delivery via SMTP to the client machine's port 25. This means
220
the retrieved mail automatically goes to the system default MDA as
221
if it were normal sender-initiated SMTP mail.</li>
222
223
<li>Configurable timeout to detect if server connection is
224
dropped.</li>
225
226
<li>Support for retrieving and forwarding from multi-drop mailboxes
227
that is guaranteed not to cause mail loops.</li>
228
229
<li>Large user community -- fetchmail has a large user base (the
230
author's beta list includes well over two hundred people). This
231
means feedback is rapid, bugs get found and fixed rapidly.</li>
232
233
<li>Carefully written, comprehensive and up-to-date man page
234
describing not only modes of operation but also how to diagnose the
235
most common kinds of problems and what to do about deficient
236
servers.</li>
237
238
<li>Rugged, simple, and well-tested code -- the author relies on it
239
every day and it has never lost mail, not even in experimental
240
versions. (In the project's entire history there has only been one
241
recorded instance of lost mail, and that was due to a quirk in some
242
Microsoft code.)</li>
243
244
<li>Strict conformance to relevant RFCs and good debugging options.
245
You could use fetchmail to test and debug server
246
implementatations.</li>
247
248
<li>For anybody who cares, fetchmail is Y2K safe.</li>
249
</ul>
250
251
<h2>Features in common with other remote-mail retrieval
252
programs:</h2>
253
254
The other programs I have checked include fetchpop1.9,
255
PopTart-0.9.3, get-mail, gwpop, pimp-1.0, pop-perl5-1.2, popc,
256
popmail-1.6 and upop. 
257
258
<ul>
259
<li>Support for POP3.</li>
260
261
<li>Easy control via command line or free-format run control
262
file.</li>
263
264
<li>Daemon mode -- fetchmail can be run in background to poll one
265
or more hosts at a specified interval.</li>
266
267
<li>From:, To:, Cc:, and Reply-To: headers are rewritten so that
268
usernames relative to the fetchmail host become fully-qualified
269
Internet addresses. This enables replies to work correctly. (Would
270
be unique to fetchmail if I hadn't added it to fetchpop.)</li>
271
272
<li>Message and header processing are 8-bit clean.</li>
273
</ul>
274
275
<hr />
276
<table width="100%" cellpadding="0" summary="Canned page footer">
277
<tr>
278
<td width="30%">Back to <a href="index.html">Fetchmail Home Page</a></td>
279
<td width="30%" align="right">$Date$</td>
280
</tr>
281
</table>
282
283
<br clear="left" />
284
<address>Eric S. Raymond <a href="mailto:esr@thyrsus.com">&lt;esr@snark.thyrsus.com&gt;</a></address>
285
</body>
286
</html>