Topic: Getmail, external mail retriever
======== Required information ====
- iRedMail version:  0.8.7
- Store mail accounts in which backend MySQL 
- Linux/BSD distribution name and version: Debian
====
I just wanted to post this solution as I greatly enjoy iRedmail. This is a copy of a personal wiki and explains how to use getmail to retrieve external mail, optionally with a cronjob, to iRedmail.
==Installation==
Installing Getmail Before proceeding, make sure your system is up to date. If you’re using Debian, Ubuntu, CentOS, or Fedora, you’ll want to update your repositories and upgrade all packages to their latest versions. Select from the following commands, depending on what operating system you’re running:
 apt-get update
 apt-get upgrade
Since getmail is included by default in most distributions’ software repositories, its installation is straightforward. Issue the following command to install getmail on Debian and Ubuntu systems:
apt-get install getmail4
==Configuration==
* Create a configuration directory, and set the right permissions by executing: # mkdir -m 0700 ~/.getmail. The main configuration file often contains sensitive information, namely passwords in plain text.
* Create a configuration file, the default being: ~/.getmail/getmailrc. A separate configuration file is needed for each mailserver to pick up mail from. Configuration files other than the default, will have to be explicitly passed as arguments to the getmail command.
===Retrieving mail===
Here is an example getmailrc used with a gmail account.
[retriever]
type = SimpleIMAPSSLRetriever
server = imap.mailprovider.com
username = 
password = 
[destination]
type = Maildir
path = 
user = vmail
[options]
verbose = 2
message_log = ~/.getmail/log
# retrieve only new messages
# if set to true it will re-download ALL messages every time!
read_all = false
# delete once retrieved
delete = true
# do not alter messages
delivered_to = false
received = false
Most people will like to add the following section to their getmailrc to prevent all the mail on the server being downloaded every time getmail is ran.
[options]
read_all = False
For this guide we will be storing our mail in the maildir format. The two main mailbox formats are mbox and maildir. The main difference between the two is that mbox is one file, with all of your mails and their headers stored in it, whereas a maildir is a directory tree. Each mail is its own file, which will often speed things up.
The maildir destination is the destination as found in the MySQL.
==== First Run ====
You can test the getmail retrieval with the following command
 #getmail
If it works fine, you can create a cronjob for getmail to run every n hours/minutes. Type crontab -e to edit cronjobs, and enter the following:
  */1 * * * * /usr/bin/getmail
That will run getmail every minute.
Also, to quiet getmail down, we can reduce its verbosity to zero by adding the following to getmailrc.
[options]
verbose = 0
====More than one Email account with getmail====
By default, when you run getmail the program searches for the file getmailrc created as seen above. If you have more than one mail account you would like to get mail from, then you can create such a file for each email address, and then tell getmail to run using both of them.  Obviously if you have two accounts and two files you cannot have both of them called getmailrc. What you do is give them two different names, using myself as an example: I call one personal, and one university. These two files contain content relevant to my personal mail, and my university work mail respectively. Then to get getmail to work on these two files, instead of searching for getmailrc(default), I use the --rcfile switch like so: getmail --rcfile university --rcfile persona This can work with more files if you have more email accounts, just make sure each file is in the .getmail directory and make sure to  alter the cronjob to run the command with the --rcfile switches. E.g.
*/30 * * * * /usr/bin/getmail --rcfile university --rcfile personal
Obviously you can call your files whatever you want, providing you include them in the cronjob or shell command, and they are in the .getmail/ directory, getmail will fetch mail from those two accounts.
== Additional examples ==
[retriever]
type = SimpleIMAPSSLRetriever
server = 
port = 
username = 
password = 
[destination]
type = Maildir
path = 
user = vmail
[options]
verbose = 2
message_log = ~/.getmail/log
# retrieve only new messages
# if set to true it will re-download ALL messages every time!
read_all = false
# delete once retrieved
delete = true
# do not alter messages
delivered_to = false
received = false
[retriever]
type = SimplePOP3Retriever
server = pop.mailprovider.com
username = 
password = 
[destination]
type = Maildir
path = 
user = vmail
[options]
verbose = 2
message_log = ~/.getmail/log
# retrieve only new messages
# if set to true it will re-download ALL messages every time!
read_all = false
# delete once retrieved
delete = true
# do not alter messages
delivered_to = false
received = false
----
Spider Email Archiver: On-Premises, lightweight email archiving software developed by iRedMail team. Supports Amazon S3 compatible storage and custom branding.
