1 <!doctype HTML public "-//W3O//DTD W3 HTML 3.2//EN">
4 <TITLE>Fetchmail Feature List</TITLE>
5 <link rev=made href="mailto:esr@snark.thyrsus.com">
6 <meta name="description" content="The fetchmail brag sheet.">
7 <meta name="keywords" content="fetchmail, POP, POP3, IMAP, IMAP2bis, IMAP4">
10 <table width="100%" cellpadding=0><tr>
11 <td width="30%">Back to <a href="index.html">Fetchmail Home Page</a>
12 <td width="30%" align=center>To <a href="/~esr/sitemap.html">Site Map</a>
13 <td width="30%" align=right>$Date: 2000/12/06 17:42:20 $
17 <H1 ALIGN=CENTER>Fetchmail Feature List</H1>
21 <LI>It's now easy to deliver mail to a local LMTP socket.<p>
23 <LI>The interface option now checks both local and remote interface IPs.<p>
26 The plugin facility has been enhanced; %h and %p options are now
27 available to pass in the hostname and service port number.
30 Added a dropdelivered option to discard Delivered-To headers. This
31 addresses a problem with using fetchmail and postfix as a relay inside
32 a domain; when postfix sees incoming messages with delivered-to
33 headers looking exactly the same as the ones it adds himself, it
37 Added --smtpname to set username and domain portion of SMTP "RCPT TO"
38 command. >fetchmail@mail.julianhaight.com>.
41 Added "from" server's IP address to inserted Received line
42 >fetchmail@mail.julianhaight.com<.
45 Fetchmail now runs on BeOS, thanks to David Reid <david@jetnet.co.uk>.
48 In IMAP, unseen-message counting and indexing is now done by SEARCH
49 UNSEEN at the beginning of each poll or re-poll (rather than with
50 the UNSEEN and RECENT responses and FLAGS queries on individual
51 messages). This significantly cuts down on traffic to and from the
52 server, and gives more reliable results.<p>
55 The aka option now matches hostname suffixes, so (for example) saying
56 `aka netaxs.com' will match not just netaxs.com but also (say)
57 pop3.netaxs.com and mail.netaxs.com.
60 Fetchmail can optionally use the RFC 2177 IDLE extension on an IMAP
61 server that supports it.
64 Fetchmail now recognizes the RFC 2449 extended responses [IN-USE] and
68 Fetchmail running in daemon mode now restarts itself quietly when the
71 <LI>Following recent court decisions and changes in U.S. federal
72 regulatory policy, hooks for Secure Sockets Layer (SSL) are now part
73 of the main fetchmail distribution. The distribution still contains
74 no actual cryptographic code.
76 <LI>NTLM support, so fetchmail can query Microsoft Exchange servers.
78 <LI>Expunge option can now be used to break POP3 retrieval into subsessions.
80 <LI>Support for AUTH=CRAM-MD5 under IMAP, a la RFC2195.
85 <LI>The interface and monitor options now work with freeBSD.
87 <LI> Fetchmail now sends RFC1894-conformant bouncemail on SMTP and LMTP errors.
89 <LI> Full support for LMTP according to RFC2033.
91 <LI> True multi-language support using GNU gettext.
93 <LI> Support for use of HESIOD with Kerberos.
95 <LI> The --bsmtp option supports recording fetched mail as a BSMTP batch.
97 <LI> The --limit option can now be used in daemon mode, with oversized-message
98 notifications being mailed to the calling user.
101 Configurable support for the <a
102 href="http://www.demon.net/info/helpdesk/demon_products/mail/sdps-tech.shtml">SDPS
103 extensions</a> in <a href="http://www.demon.net/">www.demon.net</a>'s
106 <LI> There is now an interactive GUI fetchmail configurator, fetchmailconf.
108 <LI> Code is 64-bit clean and Y2K-safe.
110 <LI> Automatically decodes armored 7-bit MIME into 8 bits (this can be
113 <LI> You can specify which SMTP error is recognized as a spam block.
115 <LI> Support for Kerberos V authentication.
117 <LI> Support for IMAP-OTP authentication using Craig Metz's patches
120 <LI> Support for IPv6 (using glibc or Craig Metz's inet6-apps library).
122 <Li> Support for IPSEC (using Craig Metz's inet6-apps library).
124 <LI> Support for IMAP with RFC1731-conformant GSSAPI authentication.
126 <LI> Fixed and verified support for Cyrus IMAP server, M$ Exchange,
129 <LI> Support for responding with a one-time password when a POP3 server
130 issues an RFC1938-conforming OTP challenge.
132 <LI> Support for Compuserve's RPA authentication protocol for POP3
133 (not compiled in by default, but configurable).
138 <LI> Support for IMAP RFC 1731 authentication with Kerberos v4.
140 <LI> Support for multiple-folder retrieval in a single session
143 <LI> Following SMTP 571 response to a From line, fetchmail no longer
144 downloads the bodies of spam messages.
146 <LI> Support for a `hunt list' of SMTP hosts.
148 <LI> Support for ESMTP 8BITMIME and SIZE options.
150 <LI> Support for ESMTP ETRN command.
152 <LI> The stripcr & forcecr options to explicitly control carriage-return
153 stripping and LF->CRLF mapping before mail forwarding.
158 <LI> Support for secure use with ssh.
160 <LI> Mailserver passwords can be parsed out of your .netrc file.
162 <LI> When forwarding mail via SMTP, fetchmail respects the 571
163 "spam filter" response and discards any mail that triggers it.
165 <LI> Transaction and error logging may optionally be done via syslog.
167 <LI> (Linux only) Security option to permit fetchmail to poll a host
168 only when a point-to-point link to a particular IP address is
171 <LI> RPOP support (restored; had been removed in 1.8).
174 <H2>2.0 and earlier versions:</H2>
176 <LI> Support POP2, APOP, RPOP, IMAP2, IMAP2bis, IMAP3, IMAP4, IMAP4rev1. .
178 <LI> Support for Kerberos V4 user authentication (either MIT or Cygnus).
180 <LI> Host is auto-probed for a working server if no protocol is
181 specified for the connection. Thus you don't need to know
182 what servers are running on your mail host in advance; the
183 verbose option will tell you which one succeeds.
185 <LI> Delivery via SMTP to the client machine's port 25. This
186 means the retrieved mail automatically goes to the system
187 default MDA as if it were normal sender-initiated SMTP mail.
189 <LI> Configurable timeout to detect if server connection is dropped.
191 <LI> Support for retrieving and forwarding from multi-drop mailboxes
192 that is guaranteed not to cause mail loops.
194 <LI> Large user community -- fetchmail has a large user base (the
195 author's beta list includes well over two hundred people). This
196 means feedback is rapid, bugs get found and fixed rapidly.
198 <LI> Carefully written, comprehensive and up-to-date man page describing
199 not only modes of operation but also how to diagnose the most
200 common kinds of problems and what to do about deficient servers.
202 <LI> Rugged, simple, and well-tested code -- the author relies on it
203 every day and it has never lost mail, not even in experimental
204 versions. (In the project's entire history there has only been
205 one recorded instance of lost mail, and that was due to a quirk
206 in some Microsoft code.)
208 <LI> Strict conformance to relevant RFCs and good debugging options.
209 You could use fetchmail to test and debug server implementatations.
211 <LI> For anybody who cares, fetchmail is Y2K safe.
214 <H2>Features in common with other remote-mail retrieval programs:</H2>
216 The other programs I have checked include fetchpop1.9, PopTart-0.9.3,
217 get-mail, gwpop, pimp-1.0, pop-perl5-1.2, popc, popmail-1.6 and upop.<P>
220 <LI> Support for POP3.
222 <LI> Easy control via command line or free-format run control file.
224 <LI> Daemon mode -- fetchmail can be run in background to poll
225 one or more hosts at a specified interval.
227 <LI> From:, To:, Cc:, and Reply-To: headers are rewritten so that
228 usernames relative to the fetchmail host become fully-qualified
229 Internet addresses. This enables replies to work correctly.
230 (Would be unique to fetchmail if I hadn't added it to fetchpop.)
232 <LI> Message and header processing are 8-bit clean.
236 <table width="100%" cellpadding=0><tr>
237 <td width="30%">Back to <a href="index.html">Fetchmail Home Page</a>
238 <td width="30%" align=center>To <a href="/~esr/sitemap.html">Site Map</a>
239 <td width="30%" align=right>$Date: 2000/12/06 17:42:20 $
242 <P><ADDRESS>Eric S. Raymond <A HREF="mailto:esr@thyrsus.com"><esr@snark.thyrsus.com></A></ADDRESS>