2002-07-12 07:43:07 +01:00
|
|
|
OFFLINEIMAP(1) OfflineIMAP manual OFFLINEIMAP(1)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
NAME
|
|
|
|
OfflineIMAP - Powerful IMAP/Maildir synchronization and
|
|
|
|
reader support
|
|
|
|
|
|
|
|
SYNOPSIS
|
2002-07-23 02:48:15 +01:00
|
|
|
offlineimap [ -1 ] [ -P profiledir ] [ -a accountlist ] [
|
2002-08-08 21:21:56 +01:00
|
|
|
-c configfile ] [ -d debugtype[,debugtype...] ] [ -o ] [
|
|
|
|
-u interface ]
|
2002-07-12 07:43:07 +01:00
|
|
|
|
|
|
|
offlineimap -h | --help
|
|
|
|
|
|
|
|
DESCRIPTION
|
2002-08-08 21:21:56 +01:00
|
|
|
OfflineIMAP is a tool to simplify your e-mail reading.
|
|
|
|
With OfflineIMAP, you can read the same mailbox from mul-
|
|
|
|
tiple computers. You get a current copy of your messages
|
|
|
|
on each computer, and changes you make one place will be
|
|
|
|
visible on all other systems. For instance, you can
|
2002-07-12 07:43:07 +01:00
|
|
|
delete a message on your home computer, and it will appear
|
2002-08-08 21:21:56 +01:00
|
|
|
deleted on your work computer as well. OfflineIMAP is
|
2002-07-12 07:43:07 +01:00
|
|
|
also useful if you want to use a mail reader that does not
|
|
|
|
have IMAP support, has poor IMAP support, or does not pro-
|
|
|
|
vide disconnected operation.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
OfflineIMAP is FAST; it synchronizes my two accounts with
|
|
|
|
over 50 folders in 3 seconds. Other similar tools might
|
|
|
|
take over a minute, and achieve a less-reliable result.
|
|
|
|
Some mail readers can take over 10 minutes to do the same
|
|
|
|
thing, and some don't even support it at all. Unlike
|
|
|
|
other mail tools, OfflineIMAP features a multi-threaded
|
|
|
|
synchronization algorithm that can dramatically speed up
|
|
|
|
performance in many situations by synchronizing several
|
2002-07-12 07:43:07 +01:00
|
|
|
different things simultaneously.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
OfflineIMAP is FLEXIBLE; you can customize which folders
|
|
|
|
are synced via regular expressions, lists, or Python
|
|
|
|
expressions; a versatile and comprehensive configuration
|
|
|
|
file is used to control behavior; two user interfaces are
|
|
|
|
built-in; fine-tuning of synchronization performance is
|
|
|
|
possible; internal or external automation is supported;
|
|
|
|
SSL and PREAUTH tunnels are both supported; offline (or
|
|
|
|
"unplugged") reading is supported; and esoteric IMAP fea-
|
|
|
|
tures are supported to ensure compatibility with the
|
2002-07-12 07:43:07 +01:00
|
|
|
widest variety of IMAP servers.
|
|
|
|
|
|
|
|
OfflineIMAP is SAFE; it uses an algorithm designed to pre-
|
2002-08-08 21:21:56 +01:00
|
|
|
vent mail loss at all costs. Because of the design of
|
|
|
|
this algorithm, even programming errors should not result
|
|
|
|
in loss of mail. I am so confident in the algorithm that
|
|
|
|
I use my own personal and work accounts for testing of
|
2002-07-12 07:43:07 +01:00
|
|
|
OfflineIMAP pre-release, development, and beta releases.
|
|
|
|
|
|
|
|
METHOD OF OPERATION
|
2002-08-08 21:21:56 +01:00
|
|
|
OfflineIMAP operates by maintaining a hierarchy of mail
|
|
|
|
folders in Maildir format locally. Your own mail reader
|
|
|
|
will read mail from this tree, and need never know that
|
2002-07-12 07:43:07 +01:00
|
|
|
the mail comes from IMAP. OfflineIMAP will detect changes
|
2002-08-08 21:21:56 +01:00
|
|
|
to the mail folders on your IMAP server and your own com-
|
2002-07-12 07:43:07 +01:00
|
|
|
puter and bi-directionally synchronize them, copying,
|
|
|
|
marking, and deleting messages as necessary.
|
|
|
|
|
|
|
|
INSTALLATION
|
|
|
|
If you are reading this document via the "man" command, it
|
2002-08-08 21:21:56 +01:00
|
|
|
is likely that you have no installation tasks to perform;
|
|
|
|
your system administrator has already installed it. If
|
2002-07-12 07:43:07 +01:00
|
|
|
you need to install it yourself, you have three options: a
|
2002-08-08 21:21:56 +01:00
|
|
|
system-wide installation with Debian, system-wide instal-
|
2002-07-12 07:43:07 +01:00
|
|
|
lation with other systems, and a single-user installation.
|
2002-08-08 21:21:56 +01:00
|
|
|
You can download the latest version of OfflineIMAP from
|
2002-07-12 07:43:07 +01:00
|
|
|
http://quux.org/devel/offlineimap/.
|
|
|
|
|
|
|
|
PREREQUISITES
|
|
|
|
In order to use OfflineIMAP, you need to have these condi-
|
|
|
|
tions satisfied:
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
o Your mail server must support IMAP. Most Internet
|
|
|
|
Service Providers and corporate networks do, and
|
|
|
|
most operating systems have an IMAP implementation
|
2002-07-12 07:43:07 +01:00
|
|
|
readily available.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
o You must have Python version 2.2.1 or above
|
2002-07-12 07:43:07 +01:00
|
|
|
installed. If you are running on Debian GNU/Linux,
|
2002-08-08 21:21:56 +01:00
|
|
|
this requirement will automatically be taken care
|
|
|
|
of for you. If you do not have Python already,
|
|
|
|
check with your system administrator or operating
|
|
|
|
system vendor; or, download it from
|
|
|
|
http://www.python.org/. If you intend to use the
|
2002-08-10 02:52:09 +01:00
|
|
|
Tk interface, you must have Tkinter (python-tk)
|
2002-07-12 07:43:07 +01:00
|
|
|
installed. If you intend to use the SSL interface,
|
2002-08-08 21:21:56 +01:00
|
|
|
your Python must have been built with SSL support.
|
2002-07-12 07:43:07 +01:00
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
o Have a mail reader that supports the Maildir mail-
|
|
|
|
box format. Most modern mail readers have this
|
|
|
|
support built-in, so you can choose from a wide
|
2002-07-12 07:43:07 +01:00
|
|
|
variety of mail servers. This format is also known
|
2002-08-08 21:21:56 +01:00
|
|
|
as the "qmail" format, so any mail reader compati-
|
2002-07-12 07:43:07 +01:00
|
|
|
ble with it will work with OfflineIMAP.
|
|
|
|
|
|
|
|
DEBIAN SYSTEM-WIDE INSTALLATION
|
2002-08-08 21:21:56 +01:00
|
|
|
If you are tracking Debian unstable, you may install
|
|
|
|
OfflineIMAP by simply running the following command as
|
2002-07-12 07:43:07 +01:00
|
|
|
root:
|
|
|
|
|
|
|
|
apt-get install offlineimap
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
If you are not tracking Debian unstable, download the
|
|
|
|
Debian .deb package from the OfflineIMAP website and then
|
|
|
|
run dpkg -i to install the downloaded package. Then, go
|
|
|
|
to CONFIGURATION below. You will type offlineimap to
|
2002-07-12 07:43:07 +01:00
|
|
|
invoke the program.
|
|
|
|
|
|
|
|
OTHER SYSTEM-WIDE INSTALLATION
|
2002-08-08 21:21:56 +01:00
|
|
|
Download the tar.gz version of the package from the web-
|
2002-07-12 07:43:07 +01:00
|
|
|
site. Then run these commands:
|
|
|
|
|
|
|
|
tar -zxvf offlineimap-x.y.z.tar.gz
|
|
|
|
cd offlineimap-x.y.z
|
|
|
|
python2.2 setup.py
|
|
|
|
|
|
|
|
Some systems will need to use python instead of python2.2.
|
|
|
|
Next, proceed to configuration. You will type offlineimap
|
|
|
|
to invoke the program.
|
|
|
|
|
|
|
|
SINGLE-ACCOUNT INSTALLATION
|
2002-08-08 21:21:56 +01:00
|
|
|
Download the tar.gz version of the package from the web-
|
2002-07-12 07:43:07 +01:00
|
|
|
site. Then run these commands:
|
|
|
|
|
|
|
|
tar -zxvf offlineimap-x.y.z.tar.gz
|
|
|
|
cd offlineimap-x.y.z
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
When you want to run OfflineIMAP, you will issue the cd
|
|
|
|
command as above and then type ./offlineimap; there is no
|
2002-07-12 07:43:07 +01:00
|
|
|
installation step necessary.
|
|
|
|
|
|
|
|
CONFIGURATION
|
2002-08-08 21:21:56 +01:00
|
|
|
OfflineIMAP is regulated by a configuration file that is
|
|
|
|
normally stored in ~/.offlineimaprc. OfflineIMAP ships
|
2002-07-12 07:43:07 +01:00
|
|
|
with a file named offlineimap.conf that you should copy to
|
|
|
|
that location and then edit. This file is vital to proper
|
2002-08-08 21:21:56 +01:00
|
|
|
operation of the system; it sets everything you need to
|
2002-07-12 07:43:07 +01:00
|
|
|
run OfflineIMAP. Full documentation for the configuration
|
|
|
|
file is included within the sample file.
|
|
|
|
|
|
|
|
OPTIONS
|
2002-08-08 21:21:56 +01:00
|
|
|
Most configuration is done via the configuration file.
|
2002-07-12 07:43:07 +01:00
|
|
|
Nevertheless, there are a few options that you may set for
|
|
|
|
OfflineIMAP.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
-1 Disable all multithreading operations and use
|
2002-07-12 07:43:07 +01:00
|
|
|
solely a single-thread sync. This effectively sets
|
|
|
|
the maxsyncaccounts and all maxconnections configu-
|
|
|
|
ration file variables to 1.
|
|
|
|
|
2002-07-23 02:48:15 +01:00
|
|
|
-P profiledir
|
2002-08-08 21:21:56 +01:00
|
|
|
Sets OfflineIMAP into profile mode. The program
|
2002-07-23 02:48:15 +01:00
|
|
|
will create profiledir (it must not already exist).
|
|
|
|
As it runs, Python profiling information about each
|
2002-08-08 21:21:56 +01:00
|
|
|
thread is logged into profiledir. Please note:
|
|
|
|
This option is present for debugging and optimiza-
|
2002-07-23 02:48:15 +01:00
|
|
|
tion only, and should NOT be used unless you have a
|
2002-08-08 21:21:56 +01:00
|
|
|
specific reason to do so. It will significantly
|
|
|
|
slow program performance, may reduce reliability,
|
|
|
|
and can generate huge amounts of data. You must
|
2002-07-23 02:48:15 +01:00
|
|
|
use the -1 option when you use -P.
|
|
|
|
|
|
|
|
|
2002-07-12 07:43:07 +01:00
|
|
|
-a accountlist
|
2002-08-08 21:21:56 +01:00
|
|
|
Overrides the accounts section in the config file.
|
|
|
|
Lets you specify a particular account or set of
|
|
|
|
accounts to sync without having to edit the config
|
2002-07-12 07:43:07 +01:00
|
|
|
file. You might use this to exclude certain
|
2002-08-08 21:21:56 +01:00
|
|
|
accounts, or to sync some accounts that you nor-
|
2002-07-12 07:43:07 +01:00
|
|
|
mally prefer not to.
|
|
|
|
|
|
|
|
-c configfile
|
2002-08-08 21:21:56 +01:00
|
|
|
Specifies a configuration file to use in lieu of
|
2002-07-12 07:43:07 +01:00
|
|
|
the default, ~/.offlineimaprc.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
-d debugtype[,debugtype...]
|
|
|
|
Enables debugging for OfflineIMAP. This is useful
|
|
|
|
if you are trying to track down a malfunction or
|
|
|
|
figure out what is going on under the hood. I sug-
|
|
|
|
gest that you use this with -1 in order to make the
|
|
|
|
results more sensible.
|
|
|
|
|
|
|
|
-d now requires one or more debugtypes, separated
|
|
|
|
by commas. These define what exactly will be
|
|
|
|
debugged, and so far include two options: imap and
|
|
|
|
maildir. The imap option will enable IMAP protocol
|
|
|
|
stream and parsing debugging. Note that the output
|
|
|
|
may contain passwords, so take care to remove that
|
|
|
|
from the debugging output before sending it to any-
|
|
|
|
one else. The maildir option will enable debugging
|
|
|
|
for certain Maildir operations.
|
|
|
|
|
|
|
|
-o Run only once, ignoring any autorefresh setting in
|
2002-07-16 03:26:58 +01:00
|
|
|
the config file.
|
|
|
|
|
2002-07-12 07:43:07 +01:00
|
|
|
-h, --help
|
|
|
|
Show summary of options.
|
|
|
|
|
|
|
|
-u interface
|
2002-08-08 21:21:56 +01:00
|
|
|
Specifies an alternative user interface module to
|
|
|
|
use. This overrides the default specified in the
|
|
|
|
configuration file. The UI specified with -u will
|
|
|
|
be forced to be used, even if its isuable() method
|
|
|
|
states that it cannot be. Use this option with
|
|
|
|
care. The pre-defined options are listed in the
|
2002-07-25 00:13:09 +01:00
|
|
|
USER INTERFACES section.
|
|
|
|
|
|
|
|
USER INTERFACES
|
2002-08-08 21:21:56 +01:00
|
|
|
OfflineIMAP has a pluggable user interface system that
|
|
|
|
lets you choose how the program communicates information
|
|
|
|
to you. There are two graphical interfaces, one terminal
|
|
|
|
interface, and two noninteractive interfaces suitable for
|
|
|
|
scripting or logging purposes. The ui option in the con-
|
|
|
|
figuration file specifies the user interface preferences.
|
|
|
|
The -u command-line option can override the configuration
|
|
|
|
file. The available values for the configuration file or
|
2002-07-25 00:13:09 +01:00
|
|
|
command-line are describef in this section.
|
|
|
|
|
|
|
|
Tk.Blinkenlights
|
2002-08-08 21:21:56 +01:00
|
|
|
This is an interface designed to be sleek, fun to watch,
|
2002-07-25 00:13:09 +01:00
|
|
|
and informative of the overall picture of what OfflineIMAP
|
2002-08-08 21:21:56 +01:00
|
|
|
is doing. I consider it to be the best general-purpose
|
|
|
|
interface in OfflineIMAP. Tk.Blinkenlights contains, by
|
|
|
|
default, a small window with a row of LEDs and a row of
|
|
|
|
command buttons. The total size of the window is very
|
|
|
|
small, so it uses little desktop space, yet it is quite
|
2002-07-25 00:13:09 +01:00
|
|
|
functional. There is also an optional, toggable, log that
|
2002-08-08 21:21:56 +01:00
|
|
|
shows more detail about what is happening and is color-
|
2002-07-25 00:13:09 +01:00
|
|
|
coded to match the color of the lights.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
Tk.Blinkenlights is the only user interface that has con-
|
2002-07-25 00:13:09 +01:00
|
|
|
figurable parameters; see the example offlineimap.conf for
|
|
|
|
more details.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
Each light in the Tk.Blinkenlights interface represents a
|
|
|
|
thread of execution -- that is, a particular task that
|
|
|
|
OfflineIMAP is performing right now. The color indicates
|
|
|
|
what task the particular thread is performing, and are as
|
2002-07-25 00:13:09 +01:00
|
|
|
follows:
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
Black indicates that this light's thread has terminated;
|
2002-07-25 00:13:09 +01:00
|
|
|
it will light up again later when new threads start
|
|
|
|
up. So, black indicates no activity.
|
|
|
|
|
|
|
|
Red (Meaning 1)
|
2002-08-08 21:21:56 +01:00
|
|
|
is the color of the main program's thread, which
|
|
|
|
basically does nothing but monitor the others. It
|
2002-07-25 00:13:09 +01:00
|
|
|
might remind you of HAL 9000 in 2001.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
Gray indicates that the thread is establishing a new
|
2002-08-08 07:28:34 +01:00
|
|
|
connection to the IMAP server.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
Purple is the color of an account synchronization thread
|
|
|
|
that is monitoring the progress of the folders in
|
2002-07-25 00:13:09 +01:00
|
|
|
that account (not generating any I/O).
|
|
|
|
|
|
|
|
Cyan indicates that the thread is syncing a folder.
|
|
|
|
|
|
|
|
Green means that a folder's message list is being loaded.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
Blue is the color of a message synchronization con-
|
2002-07-25 00:13:09 +01:00
|
|
|
troller thread.
|
|
|
|
|
|
|
|
Orange indicates that an actual message is being copied.
|
|
|
|
|
|
|
|
Red (Meaning 2)
|
|
|
|
indicates that a message is being deleted.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
Yellow (bright orange) indicates that message flags are
|
2002-07-25 00:13:09 +01:00
|
|
|
being added.
|
|
|
|
|
|
|
|
Pink (bright red) indicates that message flags are being
|
|
|
|
removed.
|
|
|
|
|
|
|
|
Red / Black Flashing
|
2002-08-08 21:21:56 +01:00
|
|
|
corresponds to the countdown timer that runs
|
2002-07-25 00:13:09 +01:00
|
|
|
between synchronizations.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
The name of this interface derives from a bit of computer
|
2002-07-25 00:13:09 +01:00
|
|
|
science history. Eric Raymond's Jargon File defines
|
|
|
|
blinkenlights, in part, as:
|
|
|
|
|
|
|
|
Front-panel diagnostic lights on a computer, esp. a
|
2002-08-08 21:21:56 +01:00
|
|
|
dinosaur. Now that dinosaurs are rare, this term
|
2002-07-25 00:13:09 +01:00
|
|
|
usually refers to status lights on a modem, network
|
|
|
|
hub, or the like.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
This term derives from the last word of the famous
|
|
|
|
blackletter-Gothic sign in mangled pseudo-German
|
|
|
|
that once graced about half the computer rooms in
|
|
|
|
the English-speaking world. One version ran in its
|
2002-07-25 00:13:09 +01:00
|
|
|
entirety as follows:
|
|
|
|
|
|
|
|
ACHTUNG! ALLES LOOKENSPEEPERS!
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
Das computermachine ist nicht fuer gefingerpoken
|
|
|
|
und mittengrabben. Ist easy schnappen der sprin-
|
|
|
|
genwerk, blowenfusen und poppencorken mit
|
|
|
|
spitzensparken. Ist nicht fuer gewerken bei das
|
|
|
|
dumpkopfen. Das rubbernecken sichtseeren keepen
|
2002-07-25 00:13:09 +01:00
|
|
|
das cotten-pickenen hans in das pockets muss;
|
|
|
|
relaxen und watchen das blinkenlichten.
|
|
|
|
|
|
|
|
Tk.VerboseUI
|
2002-08-08 21:21:56 +01:00
|
|
|
This interface (formerly known as Tk.TkUI) is a graphical
|
|
|
|
interface that presents a variable-sized window. In the
|
|
|
|
window, each currently-executing thread has a section
|
|
|
|
where its name and current status are displayed. This
|
|
|
|
interface is best suited to people running on slower con-
|
2002-07-25 00:13:09 +01:00
|
|
|
nections, as you get a lot of detail, but for fast connec-
|
2002-08-08 21:21:56 +01:00
|
|
|
tions, the detail may go by too quickly to be useful.
|
|
|
|
People with fast connections may wish to use Tk.Blinken-
|
2002-07-25 00:13:09 +01:00
|
|
|
lights instead.
|
|
|
|
|
|
|
|
TTY.TTYUI
|
|
|
|
This interface is the default for people running in termi-
|
2002-08-08 21:21:56 +01:00
|
|
|
nals. It prints out basic status messages, has an inter-
|
|
|
|
ruptible timer like the graphical interfaces do, and is
|
2002-07-25 00:13:09 +01:00
|
|
|
generally friendly to use on a console or xterm.
|
|
|
|
|
|
|
|
Noninteractive.Basic
|
2002-08-08 21:21:56 +01:00
|
|
|
This interface is designed for situations where
|
2002-07-25 00:13:09 +01:00
|
|
|
OfflineIMAP will be run non-attended and the status of its
|
|
|
|
execution will be logged. You might use it, for instance,
|
2002-08-08 21:21:56 +01:00
|
|
|
to have the system run automatically and e-mail you the
|
|
|
|
results of the synchronization. This user interface is
|
|
|
|
not capable of reading a password from the keyboard;
|
|
|
|
account passwords must be specified using one of the con-
|
2002-07-25 00:13:09 +01:00
|
|
|
figuration file options.
|
|
|
|
|
|
|
|
Noninteractive.Quiet
|
2002-08-08 21:21:56 +01:00
|
|
|
This interface is designed for non-attended running in
|
|
|
|
situations where normal status messages are not desired.
|
2002-07-25 00:13:09 +01:00
|
|
|
It will output nothing except errors and serious warnings.
|
2002-08-08 21:21:56 +01:00
|
|
|
Like Noninteractive.Basic, this user interface is not
|
|
|
|
capable of reading a password from the keyboard; account
|
2002-07-25 00:13:09 +01:00
|
|
|
passwords must be specified using one of the configuration
|
|
|
|
file options.
|
2002-07-16 03:26:58 +01:00
|
|
|
|
2002-07-12 07:43:07 +01:00
|
|
|
EXAMPLES
|
2002-08-08 21:21:56 +01:00
|
|
|
Here is an example configuration for a particularly com-
|
2002-07-12 07:43:07 +01:00
|
|
|
plex situation; more examples will be added later.
|
|
|
|
|
|
|
|
MULTIPLE ACCOUNTS WITH MUTT
|
2002-08-08 21:21:56 +01:00
|
|
|
This example shows you how to set up OfflineIMAP to syn-
|
2002-07-12 07:43:07 +01:00
|
|
|
chronize multiple accounts with the mutt mail reader.
|
|
|
|
|
|
|
|
Start by creating a directory to hold your folders:
|
|
|
|
mkdir ~/Mail
|
|
|
|
|
|
|
|
In your ~/.offlineimaprc, specify this:
|
|
|
|
accounts = Personal, Work
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
Make sure that you have both a [Personal] and a [Work]
|
|
|
|
section, with different localfolder pathnames and enable
|
2002-07-12 07:43:07 +01:00
|
|
|
[mbnames].
|
|
|
|
|
|
|
|
In each account section, do something like this:
|
|
|
|
localfolders = ~/Mail/Personal
|
|
|
|
|
|
|
|
Add these lines to your ~/.muttrc:
|
|
|
|
source ~/path-to-mbnames-muttrc-mailboxes
|
|
|
|
folder-hook Personal set from="youremail@personal.com"
|
|
|
|
folder-hook Work set from="youremail@work.com"
|
|
|
|
set mbox_type=Maildir
|
|
|
|
set folder=$HOME/Mail
|
|
|
|
set spoolfile=+Personal/INBOX
|
|
|
|
|
|
|
|
That's it!
|
|
|
|
|
2002-07-22 06:56:21 +01:00
|
|
|
UW-IMAPD AND REFERENCES
|
2002-08-08 21:21:56 +01:00
|
|
|
Some users with a UW-IMAPD server need to use
|
|
|
|
OfflineIMAP's "reference" feature to get at their mail-
|
2002-07-22 06:56:21 +01:00
|
|
|
boxes, specifying a reference of "~/Mail" or "#mh/"
|
2002-08-08 21:21:56 +01:00
|
|
|
depending on the configuration. The below configuration
|
|
|
|
from docwhat@gerf.org shows using a reference of Mail, a
|
|
|
|
nametrans that strips the leading Mail/ off incoming
|
|
|
|
folder names, and a folderfilter that limits the folders
|
2002-07-22 06:56:21 +01:00
|
|
|
synced to just three.
|
|
|
|
|
|
|
|
[Gerf]
|
|
|
|
localfolders = ~/Mail
|
|
|
|
remotehost = gerf.org
|
|
|
|
ssl = yes
|
|
|
|
remoteuser = docwhat
|
|
|
|
reference = Mail
|
|
|
|
# Trims off the preceeding Mail on all the folder names.
|
|
|
|
nametrans = lambda foldername: \
|
|
|
|
re.sub('^Mail/', '', foldername)
|
|
|
|
# Yeah, you have to mention the Mail dir, even though it
|
|
|
|
# would seem intuitive that reference would trim it.
|
|
|
|
folderfilter = lambda foldername: foldername in [
|
|
|
|
'Mail/INBOX',
|
|
|
|
'Mail/list/zaurus-general',
|
|
|
|
'Mail/list/zaurus-dev',
|
|
|
|
]
|
|
|
|
maxconnections = 1
|
|
|
|
holdconnectionopen = no
|
|
|
|
|
2002-08-10 02:52:09 +01:00
|
|
|
PYTHONFILE CONFIGURATION FILE OPTION
|
|
|
|
You can have OfflineIMAP load up a Python file before
|
|
|
|
evaluating the configuration file options that are Python
|
|
|
|
expressions. This example is based on one supplied by
|
|
|
|
Tommi Virtanen for this feature.
|
|
|
|
|
|
|
|
In ~/.offlineimap.rc, he adds these options:
|
|
|
|
|
|
|
|
[general]
|
|
|
|
pythonfile=~/.offlineimap.py
|
|
|
|
[foo]
|
|
|
|
foldersort=mycmp
|
|
|
|
|
|
|
|
Then, the ~/.offlineimap.py file will contain:
|
|
|
|
|
|
|
|
prioritized = ['INBOX', 'personal', 'announce', 'list']
|
|
|
|
|
|
|
|
def mycmp(x, y):
|
|
|
|
for prefix in prioritized:
|
|
|
|
if x.startswith(prefix):
|
|
|
|
return -1
|
|
|
|
elif y.startswith(prefix):
|
|
|
|
return +1
|
|
|
|
return cmp(x, y)
|
|
|
|
|
|
|
|
def test_mycmp():
|
|
|
|
import os, os.path
|
|
|
|
folders=os.list-
|
|
|
|
dir(os.path.expanduser('~/data/mail/tv@hq.yok.utu.fi'))
|
|
|
|
folders.sort(mycmp)
|
|
|
|
print folders
|
|
|
|
|
|
|
|
This code snippet illustrates how the foldersort option
|
|
|
|
can be customized with a Python function from the python-
|
|
|
|
file to always synchronize certain folders first.
|
|
|
|
|
2002-07-12 07:43:07 +01:00
|
|
|
ERRORS
|
|
|
|
If you get one of some frequently-encountered or confusing
|
|
|
|
errors, please check this section.
|
|
|
|
|
|
|
|
UID validity problem for folder
|
2002-08-08 21:21:56 +01:00
|
|
|
IMAP servers use a unique ID (UID) to refer to a specific
|
2002-07-23 02:48:15 +01:00
|
|
|
message. This number is guaranteed to be unique to a par-
|
2002-08-08 21:21:56 +01:00
|
|
|
ticular message FOREVER. No other message in the same
|
|
|
|
folder will ever get the same UID. UIDs are an integral
|
|
|
|
part of OfflineIMAP's synchronization scheme; they are
|
|
|
|
used to match up messages on your computer to messages on
|
2002-07-12 07:43:07 +01:00
|
|
|
the server.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
Sometimes, the UIDs on the server might get reset. Usu-
|
|
|
|
ally this will happen if you delete and then recreate a
|
|
|
|
folder. When you create a folder, the server will often
|
|
|
|
start the UID back from 1. But OfflineIMAP might still
|
|
|
|
have the UIDs from the previous folder by the same name
|
|
|
|
stored. OfflineIMAP will detect this condition and skip
|
|
|
|
the folder. This is GOOD, because it prevents data loss.
|
2002-07-12 07:43:07 +01:00
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
You can fix it by removing your local folder and cache
|
|
|
|
data. For instance, if your folders are under ~/Folders
|
2002-07-12 07:43:07 +01:00
|
|
|
and the folder with the problem is INBOX, you'd type this:
|
|
|
|
|
|
|
|
rm -r ~/Folders/INBOX
|
|
|
|
rm ~/.offlineimap/AccountName/INBOX
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
(replacing AccountName with the account name as specified
|
2002-07-12 07:43:07 +01:00
|
|
|
in ~/.offlineimaprc)
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
Next time you run OfflineIMAP, it will re-download the
|
|
|
|
folder with the new UIDs. Note that the procedure speci-
|
2002-07-12 07:43:07 +01:00
|
|
|
fied above will lose any local changes made to the folder.
|
|
|
|
|
|
|
|
Some IMAP servers are broken and do not support UIDs prop-
|
2002-08-08 21:21:56 +01:00
|
|
|
erly. If you continue to get this error for all your
|
|
|
|
folders even after performing the above procedure, it is
|
|
|
|
likely that your IMAP server falls into this category.
|
|
|
|
OfflineIMAP is incompatible with such servers. Using
|
|
|
|
OfflineIMAP with them will not destroy any mail, but at
|
2002-07-12 07:43:07 +01:00
|
|
|
the same time, it will not actually synchronize it either.
|
|
|
|
(OfflineIMAP will detect this condition and abort prior to
|
|
|
|
synchronization)
|
|
|
|
|
|
|
|
|
|
|
|
OTHER FREQUENTLY ASKED QUESTIONS
|
2002-08-08 21:21:56 +01:00
|
|
|
There are some other FAQs that might not fit into another
|
2002-07-12 07:43:07 +01:00
|
|
|
section of this document, and they are enumerated here.
|
|
|
|
|
|
|
|
What platforms does OfflineIMAP run on?
|
|
|
|
It should run on most platforms supported by
|
|
|
|
Python, which are quite a few.
|
|
|
|
|
|
|
|
I'm using Mutt. Other IMAP sync programs require me to use
|
|
|
|
set maildir_trash=yes . Do I need to do that with
|
|
|
|
OfflineIMAP?
|
|
|
|
No. OfflineIMAP is smart enough to figure out mes-
|
2002-08-08 21:21:56 +01:00
|
|
|
sage deletion without this extra crutch. You'll
|
2002-07-12 07:43:07 +01:00
|
|
|
get the best results if you don't use this setting,
|
|
|
|
in fact.
|
|
|
|
|
|
|
|
How do I specify the names of my folders?
|
|
|
|
You do not need to. OfflineIMAP is smart enough to
|
2002-08-08 21:21:56 +01:00
|
|
|
automatically figure out what folders are present
|
|
|
|
on the IMAP server and synchronize them. You can
|
|
|
|
use the folderfilter and foldertrans configuration
|
|
|
|
file options to request certain folders and rename
|
2002-07-12 07:43:07 +01:00
|
|
|
them as they come in if you like.
|
|
|
|
|
|
|
|
How can I prevent certain folders from being synced?
|
2002-08-08 21:21:56 +01:00
|
|
|
Use the folderfilter option in the configuration
|
2002-07-12 07:43:07 +01:00
|
|
|
file.
|
|
|
|
|
|
|
|
How can I add or delete a folder?
|
2002-08-08 21:21:56 +01:00
|
|
|
OfflineIMAP does not currently provide this fea-
|
|
|
|
ture, but if you create a new folder on the IMAP
|
2002-07-12 07:43:07 +01:00
|
|
|
server, it will be created locally automatically.
|
|
|
|
|
|
|
|
Are there any other warnings that I should be aware of?
|
|
|
|
Yes; see the NOTES section below.
|
|
|
|
|
|
|
|
What is the mailbox name recorder (mbnames) for?
|
2002-08-08 21:21:56 +01:00
|
|
|
The Mutt mail reader is not capable of automati-
|
|
|
|
cally determining the names of your mailboxes.
|
|
|
|
OfflineIMAP can help it (or many other) programs
|
|
|
|
out be writing these names out in a format you
|
2002-07-12 07:43:07 +01:00
|
|
|
specify. See the example offlineimap.conf file for
|
|
|
|
details.
|
|
|
|
|
|
|
|
Can I synchronize multiple accounts with OfflineIMAP?
|
2002-08-08 21:21:56 +01:00
|
|
|
Sure. Just name them all in the accounts line in
|
|
|
|
the general section of the config file, and add a
|
2002-07-12 07:43:07 +01:00
|
|
|
per-account section for each one.
|
|
|
|
|
|
|
|
Does OfflineIMAP support POP?
|
2002-08-08 21:21:56 +01:00
|
|
|
No. POP is not robust enough to do a completely
|
|
|
|
reliable multi-machine synchronization like
|
|
|
|
OfflineIMAP can do. OfflineIMAP will not support
|
2002-07-12 07:43:07 +01:00
|
|
|
it.
|
|
|
|
|
|
|
|
Do you support mailbox formats other than Maildir?
|
2002-08-08 21:21:56 +01:00
|
|
|
Not at present. There is no technical reason not
|
2002-07-12 07:43:07 +01:00
|
|
|
to; just no demand yet. Maildir is a superior for-
|
|
|
|
mat anyway.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
[technical] Why are your Maildir message filenames so
|
2002-07-12 07:43:07 +01:00
|
|
|
huge?
|
2002-08-08 21:21:56 +01:00
|
|
|
OfflineIMAP has two relevant principles: 1) never
|
|
|
|
modifying your messages in any way and 2) ensuring
|
|
|
|
100% reliable synchronizations. In order to do a
|
|
|
|
reliable sync, OfflineIMAP must have a way to
|
|
|
|
uniquely identify each e-mail. Three pieces of
|
|
|
|
information are required to do this: your account
|
|
|
|
name, the folder name, and the message UID. The
|
|
|
|
account name can be calculated from the path in
|
|
|
|
which your messages are. The folder name can usu-
|
|
|
|
ally be as well, BUT some mail clients move mes-
|
|
|
|
sages between folders by simply moving the file,
|
2002-07-12 07:43:07 +01:00
|
|
|
leaving the name intact.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
So, OfflineIMAP must store both a UID folder ID.
|
|
|
|
The folder ID is necessary so OfflineIMAP can
|
|
|
|
detect a message moved to a different folder.
|
|
|
|
OfflineIMAP stores the UID (U= number) and an
|
|
|
|
md5sum of the foldername (FMD5= number) to facili-
|
2002-07-25 00:13:09 +01:00
|
|
|
tate this.
|
2002-07-12 07:43:07 +01:00
|
|
|
|
|
|
|
What is the speed of OfflineIMAP's sync?
|
|
|
|
OfflineIMAP versions 2.0 and above contain a multi-
|
2002-08-08 21:21:56 +01:00
|
|
|
threaded system. A good way to experiment is by
|
|
|
|
setting maxsyncaccounts to 3 and maxconnections to
|
2002-07-12 07:43:07 +01:00
|
|
|
3 in each account clause.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
This lets OfflineIMAP open up multiple connections
|
|
|
|
simultaneously. That will let it process multiple
|
|
|
|
folders and messages at once. In most cases, this
|
2002-07-12 07:43:07 +01:00
|
|
|
will increase performance of the sync.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
Don't set the number too high. If you do that,
|
|
|
|
things might actually slow down as your link gets
|
|
|
|
saturated. Also, too many connections can cause
|
|
|
|
mail servers to have excessive load. Administra-
|
|
|
|
tors might take unkindly to this, and the server
|
|
|
|
might bog down. There are many variables in the
|
2002-07-12 07:43:07 +01:00
|
|
|
optimal setting; experimentation may help.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
An informal benchmark yields these results for my
|
2002-07-12 07:43:07 +01:00
|
|
|
setup:
|
|
|
|
|
|
|
|
10 minutes with MacOS X Mail.app "manual cache"
|
|
|
|
5 minutes with GNUS agent sync
|
|
|
|
20 seconds with OfflineIMAP 1.x
|
|
|
|
9 seconds with OfflineIMAP 2.x
|
|
|
|
3 seconds with OfflineIMAP 3.x "cold start"
|
|
|
|
2 seconds with OfflineIMAP 3.x "held connection"
|
|
|
|
|
|
|
|
CONFORMING TO
|
|
|
|
o Internet Message Access Protocol version 4rev1
|
|
|
|
(IMAP 4rev1) as specified in RFC2060
|
|
|
|
|
|
|
|
o Maildir as specified in http://www.qmail.org/qmail-
|
|
|
|
manual-html/man5/maildir.html and
|
|
|
|
http://cr.yp.to/proto/maildir.html.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
o Standard Python 2.2.1 as implemented on POSIX-com-
|
2002-07-12 07:43:07 +01:00
|
|
|
pliant systems.
|
|
|
|
|
|
|
|
NOTES
|
|
|
|
DELETING LOCAL FOLDERS
|
2002-08-08 21:21:56 +01:00
|
|
|
OfflineIMAP does a two-way synchronization. That is, if
|
|
|
|
you make a change to the mail on the server, it will be
|
|
|
|
propogated to your local copy, and vise-versa. Some peo-
|
|
|
|
ple might think that it would be wise to just delete all
|
|
|
|
their local mail folders periodically. If you do this
|
|
|
|
with OfflineIMAP, remember to also remove your local sta-
|
|
|
|
tus cache (~/.offlineimap by default). Otherwise,
|
|
|
|
OfflineIMAP will take this as an intentional deletion of
|
2002-07-12 07:43:07 +01:00
|
|
|
many messages and will interpret your action as requesting
|
|
|
|
them to be deleted from the server as well. (If you don't
|
|
|
|
understand this, don't worry; you probably won't encounter
|
|
|
|
this situation)
|
|
|
|
|
2002-07-18 02:12:42 +01:00
|
|
|
COPYING MESSAGES BETWEEN FOLDERS
|
|
|
|
Normally, when you copy a message between folders or add a
|
2002-08-08 21:21:56 +01:00
|
|
|
new message to a folder locally, OfflineIMAP will just do
|
2002-07-18 02:12:42 +01:00
|
|
|
the right thing. However, sometimes this can be tricky --
|
2002-08-08 21:21:56 +01:00
|
|
|
if your IMAP server does not provide the SEARCH command,
|
|
|
|
or does not return something useful, OfflineIMAP cannot
|
|
|
|
determine the new UID of the message. So, in these rare
|
2002-07-18 02:12:42 +01:00
|
|
|
instances, OfflineIMAP will upload the message to the IMAP
|
2002-08-08 21:21:56 +01:00
|
|
|
server and delete it from your local folder. Then, on
|
2002-07-18 02:12:42 +01:00
|
|
|
your next sync, the message will be re-downloaded with the
|
2002-08-08 21:21:56 +01:00
|
|
|
proper UID. OfflineIMAP makes sure that the message was
|
|
|
|
properly uploaded before deleting it, so there should be
|
2002-07-18 02:12:42 +01:00
|
|
|
no risk of data loss.
|
|
|
|
|
2002-07-12 07:43:07 +01:00
|
|
|
MAILING LIST
|
|
|
|
There is an OfflineIMAP mailing list available.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
To subscribe, send the text "Subscribe" in the subject of
|
2002-07-12 07:43:07 +01:00
|
|
|
a mail to offlineimap-request@complete.org. To post, send
|
|
|
|
the message to offlineimap@complete.org.
|
|
|
|
|
|
|
|
BUGS
|
2002-08-08 21:21:56 +01:00
|
|
|
Reports of bugs should be sent via e-mail to the
|
|
|
|
OfflineIMAP bug-tracking system (BTS) at
|
|
|
|
offlineimap@bugs.complete.org or submitted on-line using
|
|
|
|
the Web interface at http://bugs.complete.org/. The Web
|
|
|
|
site also lists all current bugs, where you can check
|
2002-07-22 06:56:21 +01:00
|
|
|
their status or contribute to fixing them.
|
2002-07-12 07:43:07 +01:00
|
|
|
|
|
|
|
COPYRIGHT
|
|
|
|
OfflineIMAP is Copyright (C) 2002 John Goerzen.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
This program is free software; you can redistribute it
|
2002-07-12 07:43:07 +01:00
|
|
|
and/or modify it under the terms of the GNU General Public
|
2002-08-08 21:21:56 +01:00
|
|
|
License as published by the Free Software Foundation;
|
|
|
|
either version 2 of the License, or (at your option) any
|
2002-07-12 07:43:07 +01:00
|
|
|
later version.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
This program is distributed in the hope that it will be
|
2002-07-12 07:43:07 +01:00
|
|
|
useful, but WITHOUT ANY WARRANTY; without even the implied
|
2002-08-08 21:21:56 +01:00
|
|
|
warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
|
|
PURPOSE. See the GNU General Public License for more
|
2002-07-12 07:43:07 +01:00
|
|
|
details.
|
|
|
|
|
2002-08-08 21:21:56 +01:00
|
|
|
You should have received a copy of the GNU General Public
|
2002-07-12 07:43:07 +01:00
|
|
|
License along with this program; if not, write to:
|
|
|
|
|
|
|
|
Free Software Foundation, Inc.
|
|
|
|
59 Temple Place
|
|
|
|
Suite 330
|
|
|
|
Boston, MA 02111-1307
|
|
|
|
USA
|
|
|
|
|
|
|
|
AUTHOR
|
2002-08-08 21:21:56 +01:00
|
|
|
OfflineIMAP, its libraries, documentation, and all
|
|
|
|
included files, except where noted, was written by John
|
|
|
|
Goerzen <jgoerzen@complete.org> and copyright is held as
|
2002-07-12 07:43:07 +01:00
|
|
|
stated in the COPYRIGHT section.
|
|
|
|
|
|
|
|
OfflineIMAP may be downloaded, and information found, from
|
|
|
|
its homepage via either Gopher or HTTP:
|
|
|
|
|
|
|
|
gopher://quux.org/1/devel/offlineimap
|
|
|
|
http://quux.org/devel/offlineimap
|
|
|
|
|
2002-07-18 02:12:42 +01:00
|
|
|
OfflineIMAP may also be downloaded using Subversion.
|
|
|
|
Additionally, the distributed tar.gz may be updated with a
|
2002-08-08 21:21:56 +01:00
|
|
|
simple "svn update" command; it is ready to go. For
|
2002-07-18 02:12:42 +01:00
|
|
|
information on getting OfflineIMAP with Subversion, please
|
|
|
|
visit:
|
|
|
|
|
|
|
|
http://svn.complete.org/
|
2002-07-12 07:43:07 +01:00
|
|
|
|
|
|
|
SEE ALSO
|
|
|
|
mutt(1), python(1).
|
|
|
|
|
|
|
|
|
|
|
|
|
2002-07-25 00:13:09 +01:00
|
|
|
John Goerzen July 12, 2002 OFFLINEIMAP(1)
|