Simple tool for downloading email attachments for all emails in a given folder using an IMAP client.
Install:
$ pip install attachment-downloader
Usage:
Usage: attachment-downloader [options]
Options:
-h, --help show this help message and exit
--host=HOST IMAP Host
--username=USERNAME IMAP Username
--password=PASSWORD IMAP Password
--imap-folder=IMAP_FOLDER
IMAP Folder to extract attachments from
--subject-regex=SUBJECT_REGEX
Regex that the subject must start with
--subject-regex-ignore-case
Ignore case when matching subject
--subject-regex-match-anywhere
Search entire subject for regex match
--date-after=DATE_AFTER
Select messages after this date
--date-before=DATE_BEFORE
Select messages before this date
--filename-template=FILENAME_TEMPLATE
Attachment filename (jinja2) template.
--output=DOWNLOAD_FOLDER
Output directory for attachment download
--delete Delete downloaded emails from Mailbox
--delete-copy-folder=DELETE_COPY_FOLDER
IMAP folder to copy emails to before deleting them
--port=PORT Specify imap server port (defaults to 993 for TLS and
143 otherwise
--unsecure disable encrypted connection (not recommended)
--starttls enable STARTTLS (not recommended)
Example:
$ attachment-downloader --host imap.example.com --username [email protected] --password pa55word \\
--imap-folder invoices --output ~/Downloads
If you wish to search through all messages regardless of folder, omit the --imap-folder
argument.
Date filtering can be performed by specifying one or both of the date arguments:
--date-after="2021-02-06T13:00:00" --date-before="2021-02-06T13:25:00"
Dates should be provided in ISO format, e.g: 2021-02-06T13:25:00
or 2021-02-06T13:25:00
.
If a zone offset is not provided UTC will be assumed.
This tool requires Python 3+
This is not compatible with Python 2.
By default attachments will be downloaded using their original filename to the folder specified by -output
.
You can customise the download filename using a jinja2 template for the argument --filename-template
.
The following variables are supported:
message_id
attachment_name
attachment_idx
subject
date
In the following example, downloads will be placed within the output folder grouped into a folder hierarchy of date, message ID, subject:
--filename-template="{{date}}/{{ message_id }}/{{ subject }}/{{ attachment_name }}"
The datetime of the message can also be formatted in the output filename, for example:
--filename-template "{{date.strftime('%Y-%m-%d')}} {{ attachment_name }}"
If you spot any issues or have a feature request please feel free to raise an issue, or even better, propose a pull request.
For local testing of the tool, a docker-compose stack is included which provides a Postfix, Dovecot, PostfixAdmin and Roundcube setup.
Docker compose can be run using
docker-compose up
The login for PostfixAdmin is root
/ L3tm31n
The following mailboxes will also be created which can be accessed via roundcube:
Mailbox | Password |
---|---|
[email protected] |
Pass11 |
[email protected] |
Pass22 |