summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorthomascube <thomas@roundcube.net>2008-08-17 17:30:07 +0000
committerthomascube <thomas@roundcube.net>2008-08-17 17:30:07 +0000
commitd14a57d006ae4beb87c24a4e6584cf08bcb683ab (patch)
tree102597c6a5cefd512d603b08e0f985fdbaa180b5
parent687b224da2d390611aa364040b88841b91cbbef6 (diff)
Add option to export all folders of a mail account
-rwxr-xr-xbin/msgexport.sh85
1 files changed, 55 insertions, 30 deletions
diff --git a/bin/msgexport.sh b/bin/msgexport.sh
index 890d48a06..33d5d4b4a 100755
--- a/bin/msgexport.sh
+++ b/bin/msgexport.sh
@@ -1,4 +1,4 @@
-#!/usr/bin/php -qC
+#!/usr/bin/php
<?php
define('INSTALL_PATH', preg_replace('/bin\/$/', '', getcwd()) . '/');
@@ -43,8 +43,8 @@ function print_usage()
print "Usage: msgexport -h imap-host -u user-name -m mailbox name\n";
print "--host IMAP host\n";
print "--user IMAP user name\n";
- print "--mbox Mailbox/folder name\n";
- print "--file Mailbox/folder name\n";
+ print "--mbox Folder name, set to '*' for all\n";
+ print "--file Output file\n";
}
function vputs($str)
@@ -59,6 +59,45 @@ function progress_update($pos, $max)
vputs(sprintf("%3d%% [%-51s] %d/%d\033[K\r", $percent, @str_repeat('=', $percent / 2) . '>', $pos, $max));
}
+function export_mailbox($mbox, $filename)
+{
+ global $IMAP;
+
+ $IMAP->set_mailbox($mbox);
+
+ vputs("Getting message list of {$mbox}...");
+ vputs($IMAP->messagecount()." messages\n");
+
+ if ($filename)
+ {
+ if (!($out = fopen($filename, 'w')))
+ {
+ vputs("Cannot write to output file\n");
+ return;
+ }
+ vputs("Writing to $filename\n");
+ }
+ else
+ $out = STDOUT;
+
+ for ($count = $IMAP->messagecount(), $i=1; $i <= $count; $i++)
+ {
+ $headers = $IMAP->get_headers($i, null, false);
+ $from = current($IMAP->decode_address_list($headers->from, 1, false));
+
+ fwrite($out, sprintf("From %s %s UID %d\n", $from['mailto'], $headers->date, $headers->uid));
+ fwrite($out, iil_C_FetchPartHeader($IMAP->conn, $IMAP->mailbox, $i, null));
+ fwrite($out, iil_C_HandlePartBody($IMAP->conn, $IMAP->mailbox, $i, null, 1));
+ fwrite($out, "\n\n\n");
+
+ progress_update($i, $count);
+ }
+ vputs("\ncomplete.\n");
+
+ if ($filename)
+ fclose($out);
+}
+
// get arguments
$args = get_opt(array('h' => 'host', 'u' => 'user', 'p' => 'pass', 'm' => 'mbox', 'f' => 'file')) + array('host' => 'localhost', 'mbox' => 'INBOX');
@@ -109,35 +148,21 @@ if ($IMAP->connect($host, $args['user'], $args['pass'], $imap_port, $imap_ssl))
{
vputs("IMAP login successful.\n");
- $IMAP->set_mailbox($args['mbox']);
-
- vputs("Getting message list of {$args['mbox']}...");
- vputs($IMAP->messagecount()." messages\n");
-
- if ($args['file'])
- {
- if (!($out = fopen($args['file'], 'w')))
- {
- vputs("Cannot write to output file\n");
- exit;
- }
- }
- else
- $out = STDOUT;
-
- for ($count = $IMAP->messagecount(), $i=1; $i <= $count; $i++)
+ $filename = null;
+ $mailboxes = $args['mbox'] == '*' ? $IMAP->list_mailboxes(null) : array($args['mbox']);
+
+ foreach ($mailboxes as $mbox)
{
- $headers = $IMAP->get_headers($i, null, false);
- $from = current($IMAP->decode_address_list($headers->from, 1, false));
-
- fwrite($out, sprintf("From %s %s UID %d\n", $from['mailto'], $headers->date, $headers->uid));
- fwrite($out, iil_C_FetchPartHeader($IMAP->conn, $IMAP->mailbox, $i, null));
- fwrite($out, iil_C_HandlePartBody($IMAP->conn, $IMAP->mailbox, $i, null, 1));
- fwrite($out, "\n\n\n");
-
- progress_update($i, $count);
+ if ($args['file'])
+ $filename = preg_replace('/\.[a-z0-9]{3,4}$/i', '', $args['file']) . asciiwords($mbox) . '.mbox';
+ else if ($args['mbox'] == '*')
+ $filename = asciiwords($mbox) . '.mbox';
+
+ if ($args['mbox'] == '*' && in_array(strtolower($mbox), array('junk','spam','trash')))
+ continue;
+
+ export_mailbox($mbox, $filename);
}
- vputs("\ncomplete.\n");
}
else
{