jgoerzen 993f85bfa6 /head: changeset 64
Fixed a bug with the status call
2002-07-04 02:00:58 +01:00
..
2002-07-04 00:49:00 +01:00
2002-07-04 02:00:58 +01:00
2002-07-03 07:56:12 +01:00
2005-04-16 14:59:17 +01:00
2002-06-22 05:46:25 +01:00
2002-06-22 05:46:25 +01:00
2002-07-03 12:01:23 +01:00
2002-07-04 01:02:10 +01:00
2002-06-22 07:24:30 +01:00
2002-06-22 05:10:49 +01:00
2002-06-23 13:37:05 +01:00

OfflineIMAP
Copyright (C) 2002 John Goerzen <jgoerzen@complete.org>
This software comes with ABSOLUTELY NO WARRANTY; see the file
COPYING for details.  This is free software, and you are welcome
to distribute it under the conditions laid out in COPYING.

gopher://quux.org/1/devel/offlineimap
http://quux.org/devel/offlineimap

==================================================
Welcome
==================================================

OfflineIMAP is a tool to simplify your e-mail reading.  With
OfflimeIMAP, you can:

 * Read the same mailbox from multiple computers, and have your
   changes (deletions, etc.) be automatically reflected on
   all computers

 * Use various mail clients to read a single mail box

 * Read mail while offline (on a laptop) and have all changes
   synchronized when you get connected again

 * Read IMAP mail with mail readers that do not support IMAP

 * Use SSL (secure connections) to read IMAP mail even if your reader
   doesn't support SSL

 * Synchronize your mail using a completely safe and fault-tolerant
   algorithm.  (At least I think it is!)

In short, OfflineIMAP is a tool to let you read mail how YOU want to.

==================================================
Requirements
==================================================

To use OfflineIMAP, you must:

1. Have your mail delivered to a server that supports IMAP

2. Have Python 2.2 or above installed

3. Have a mail reader that supports Maildirs (most modern ones do)

These requirements are easy to meet, and most people will have met
them already without even being aware of it.

If you do not have Python already, check your operating system vendor
or download it from http://www.python.org/

==================================================
Installation
==================================================

Basic installation for a single user requires only these steps:

1. Copy offlineimap.conf to ~/.offlineimaprc and edit that file
   for your accounts.  Full instructions are in it.

2. Make the directory that you will store your folders in.
   (~/Test in the example)

You can then just run "python2.2 offlineimap.py" to synchronize your
mail.

------------------------------
Systemwide

If you wish to install OfflineIMAP for all users on your system:

1. Either install the Debian package or run "python2.2 setup.py" and
   follow the prompts

2. Advise users to perform steps 1 and 2 above

3. Run OfflineIMAP by typing "offlineimap"

That's it!

==================================================
Frequently Asked Questions
==================================================

Q. I get a message saying "UID validity problem for folder; skipping".
What does this mean and how do I fix it?

A. IMAP servers use a unique ID (UID) to refer to a specific message.
This number is guaranteed to be unique to a particular 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 the server.

Sometimes, the UIDs on the server might get reset.  Usually 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.

You can fix it by removing your local folder and cache data.  For
instance, if your folders are under ~/Folders and the folder with the
problem is INBOX, you'd type this:

rm -r ~/Folders/INBOX
rm ~/.offlineimap/AccountName/INBOX

(replacing AccountName with the account name as specified in
~/.offlineimaprc)

Next time you run OfflineIMAP, it will re-download the folder with the
new UIDs.  Note that the procedure specified above will lose any local
changes made to the folder.

Some IMAP servers are broken and do not support UIDs properly.  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 the same time,
it will not actually synchronize it either.  (OfflineIMAP will detect
this condition and abort prior to synchronization)

--------------------------------------------------

Q. What platforms does OfflineIMAP run on?

A. It should run on most platforms supported by Python, which are
quite a few.

--------------------------------------------------

Q. I'm using Mutt.  Other IMAP synchronization programs require me to
"set maildir_trash=yes".  Do I need to do that with OfflineIMAP?

A. No.  OfflineIMAP is smart enough to figure out message deletion
without this extra crutch.  You'll get the best results if you don't
use that setting, in fact.

--------------------------------------------------

Q. How do I specify the names of my folders?

A. You do not need to.  OfflineIMAP is smart enough to automatically
figure out what folders are present on the IMAP server and synchronize
them.

--------------------------------------------------

Q. How can I prevent certain folders from being synced?

A. This feature will be introduced in a future version of OfflineIMAP.

--------------------------------------------------

Q. How can I add or delete a folder?

A. OfflineIMAP does not currently provide this feature.

--------------------------------------------------

Q. Are there any specific warnings or things I should be aware of
before using OfflineIMAP?

A. Yes.  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 people 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 status
cache (~/.offlineimap by default).  Otherwise, OfflineIMAP will take
this as an intentional deletion of 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)

--------------------------------------------------

Q. What's thie Mailbox name recorder (mbnames) thing all about?

A. The Mutt mail reader is not capable of automatically determining
the names of your mailboxes.  OfflineIMAP can help it (or many other)
programs out be writing these names out in a format you specify.  See
the example offlineimap.conf file for details.

--------------------------------------------------

Q. Can I synchronize multiple accounts with OfflineIMAP?

A. Sure.  Just name them all in the accounts line in the general
section of the config file, and add a per-account section for each one.

--------------------------------------------------

Q. Do you support POP?

A. No.  POP is not robust enough to do a completely reliable
multi-machine synchronization like OfflineIMAP can do.  OfflineIMAP
will not support it.

--------------------------------------------------

Q. Do you support mailbox formats other than Maildir?

A. Not at present.  There is no technical reason not to; just no
demand yet.  Maildir is a superior format anyway.

--------------------------------------------------

Q. [technical] Why are your Maildir message filenames so huge?

A. 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 usually be as well, BUT
some mail clients move messages between folders by simply moving the
file, leaving the name intact.

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 facilitate this.

--------------------------------------------------

Q. Can you provide an example of using OfflineIMAP with Mutt and
multiple accounts?

A. Sure.  I set it up to have a single Mail directory with additional
directories under that for each account.  So, mkdir ~/Mail.  Then, 
in your ~/.offlineimaprc:

Set "accounts = Personal, Work"

Make sure you have a [Personal] and a [Work] section, with different
pathnames.  Enable [mbnames].

In each account section, do something like this:

localfolders = ~/Mail/Personal

or

localfolders = ~/Mail/Work

In Mutt:

add lines like this 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!