]> Pileus Git - ~andy/fetchmail/blob - fetchmail-features.html
Minor bug fixes for socket.c
[~andy/fetchmail] / fetchmail-features.html
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>
287