kartero.org

kartero.org

Git

This commit has been accessed 420 times via Git panel.

commit 90eb1ef74dcdd915e7565d133168e2591489bc75
tree c17135ed94cf73cd5af261c20d9fd71aedfbebb9
parent ecab88ee210761f925f8d8e3c2d3d9d47f217763
author Engels Antonio <engels@majcms.org> 1332003293 +0800
committer Engels Antonio <engels@majcms.org> 1332003293 +0800

    Add redirect (bounce) mail to other recipients support

diff --git a/index.php b/index.php
index 8288ba8..9e5bd78 100644
--- a/index.php
+++ b/index.php
@@ -863,21 +863,52 @@ $pm_now = mysql_num_rows($pm_get);
                                }
                        }
 
-                       $reply_body = preg_replace("#(?<!\r)\n#si", "\r\n", $reply_body);
-                       $reply_headers = preg_replace('#(?<!\r)\n#si', "\r\n", $reply_headers);
 
-                       mail($reply_to, $reply_subj, $reply_body, $reply_headers);
                       
                        $host = "{127.0.0.1:143/imap/notls/norsh}";
 
-                       $mbox = @imap_open($host, $_SESSION['logged_uid'], $_SESSION['logged_key']) or die("Connection to server failed");
+                       if ($_POST['redirect'] == 1) {
+
+                               $mbox = @imap_open("{$host}{$_POST['box']}", $_SESSION['logged_uid'], $_SESSION['logged_key']) or die("Connection to server failed");
+
+                               $redirect_date = date("D, j M Y H:i:s O (T)");
+
+                               $reply_headers = "Resent-Date: $redirect_date\r\nResent-To: $reply_to\r\n";
+
+
+                               if (isset($_POST['reply_cc']) and !empty($_POST['reply_cc'])) {
+                      
+                                       $reply_cc = trim($_POST['reply_cc']);
+                              
+                                       $reply_headers = $reply_headers . "Resent-Cc: $reply_cc\r\n";
+                               }
+      
+                               if (isset($_POST['reply_bcc']) and !empty($_POST['reply_bcc'])) {
+                              
+                                       $reply_bcc = trim($_POST['reply_bcc']);
+                                      
+                                       $reply_headers = $reply_headers . "Resent-Bcc: $reply_bcc\r\n";
+                               }
+
+                               $reply_headers = $reply_headers . imap_fetchheader($mbox,$_POST['msg']);
+
+                               $reply_body = imap_body($mbox,$_POST['msg']);
+                       }
+                       else {
+                               $mbox = @imap_open($host, $_SESSION['logged_uid'], $_SESSION['logged_key']) or die("Connection to server failed");
+                       }
 
                        imap_createmailbox($mbox,"{$host}Sent");
 
                        $reply_date = date ("d-M-Y H:i:s O");
                       
+                       $reply_body = preg_replace("#(?<!\r)\n#si", "\r\n", $reply_body);
+                       $reply_headers = preg_replace('#(?<!\r)\n#si', "\r\n", $reply_headers);
+
                        imap_append($mbox,"{$host}Sent","To: $reply_to\r\nSubject: $reply_subj\r\nDate: $reply_date\r\n$reply_headers\r\n\r\n$reply_body\r\n");
 
+                       mail($reply_to, $reply_subj, $reply_body, $reply_headers);
+
                        if ($_POST['ack'] == 1) {
 
                                imap_reopen($mbox, "{$host}{$_POST['box']}");
diff --git a/index.php~ b/index.php~
deleted file mode 100644
index 4eca8a8..0000000
--- a/index.php~
+++ /dev/null
@@ -1,1060 +0,0 @@
-<?php
-
-/* modify the values of $db_host, $db_name, $db_user, $db_pass, and $mail_root for basic configuration */
-
-$db_host = "localhost";
-$db_name = "kartero";
-$db_user = "kartero";
-$db_pass = "fr1ng3!";
-
-$mail_root = "/var/spool/kartero";
-
-/* feel free to hack the succeeding code to suit your needs (basic php and mysql skills required) */
-
-require_once("core.php");
-
-function rmdirr($recurse_dirname) {
-
-       if (!file_exists($recurse_dirname)) {
-               return false;
-       }
-
-       if (is_file($recurse_dirname)) {
-               return unlink($recurse_dirname);
-       }
-
-       $recurse_dir = dir($recurse_dirname);
-
-       while (false !== $recurse_entry = $recurse_dir->read()) {
-
-               if ($recurse_entry == '.' || $recurse_entry == '..') {
-                       continue;
-               }
-
-               rmdirr("$recurse_dirname/$recurse_entry");
-       }
-
-       $recurse_dir->close();
-       return rmdir($recurse_dirname);
-}
-
-function ack($ack_string) {
-       echo "<table width=\"100%\"><tr></td><div class=\"ack\">$ack_string</div></td></tr></table>";
-}
-
-function nak($nak_string) {
-       echo "<table width=\"100%\"><tr></td><div class=\"nak\">$nak_string</div></td></tr></table>";
-}
-
-if (file_exists("css.php")) {
-
-       $css = file_get_contents("css.php");
-       $css = str_replace("<style>","",$css);
-       $css = str_replace("</style>","",$css);
-
-       echo "<style>\r\n$css</style>\r\n\r\n";
-}
-
-if (!file_exists("$mail_root")) {
-
-       $mail_dirs = explode("/",$mail_root);
-
-       foreach ($mail_dirs as $mail_dir) {
-      
-               if (!empty($mail_dir)) {
-                       $mail_mkdir = $mail_mkdir . "/" . $mail_dir;
-                       mkdir("$mail_mkdir");
-               }
-       }
-
-       if (!file_exists("$mail_root")) {
-               nak("Can't create '$mail_root' (check filesystem permissions or change '&#36;mail_root' and try again)");
-               exit();
-       }
-}
-
-$db_link = mysql_pconnect($db_host, $db_user, $db_pass);
-
-if (!$db_link) {
-       nak(mysql_error());
-       exit;
-}
-
-$db_query = mysql_query("use $db_name");
-
-if (!$db_query) {
-       $pw_crypt = crypt($db_pass);
-       $db_query = mysql_query("create database $db_name");
-       $db_query = mysql_query("use $db_name");
-       $db_query = mysql_query("create table admins (id varchar(16) not null, pw varchar(64) not null, primary key (id), unique key (id))");
-       $db_query = mysql_query("create table domains (id varchar(128) not null, pw varchar(64) not null, max int(6) default '0', mode int(1) default '1', primary key (id), unique key (id), key id_2 (id))");
-       $db_query = mysql_query("create table users (id varchar(255) not null, pw varchar(64) not null, maildir varchar(255) not null, name varchar(128), domain varchar(128), mode int(1) default '1', host varchar(255), primary key (id), unique key(id), key id_2 (id))");
-       $db_query = mysql_query("create table aliases (id varchar(255) not null, alias varchar(255) not null, domain varchar(128), mode int(1) default '1', primary key (id), unique key (id), key id_2 (id))");
-       $db_query = mysql_query("insert into admins values('$db_user','$pw_crypt')");
-}
-
-$id_put = strip_tags($_POST['id']);
-$id_put = trim($id_put);
-$id_put = strtolower($id_put);
-
-if (get_magic_quotes_gpc()) {
-       $id_put = stripslashes($id_put);
-}
-
-if (!is_int($id_put)) {
-       $id_put = mysql_real_escape_string($id_put);
-}
-
-$lvl_put = strip_tags($_POST['lvl']);
-
-if ($lvl_put == "subscriber") {
-       $pw_get = mysql_query("select pw from users where id='$id_put'");
-}
-
-if ($lvl_put == "postmaster") {
-       $pw_get = mysql_query("select pw from domains where id='$id_put'");
-}
-
-if ($lvl_put == "administrator") {
-       $pw_get = mysql_query("select pw from admins where id='$id_put'");
-}
-
-$pw_get = mysql_fetch_row($pw_get);
-$pw_get = $pw_get[0];
-
-$pw_put = $_POST['pw'];
-
-if (get_magic_quotes_gpc()) {
-       $pw_put = stripslashes($pw_put);
-}
-
-if (!is_int($pw_put)) {
-       $pw_put = mysql_real_escape_string($pw_put);
-}
-
-$pw_put = strip_tags($pw_put);
-
-$pw_mbox = $pw_put;
-
-$pw_put = crypt($pw_put,$pw_get);
-
-if ($pw_put == $pw_get) {
-       $_SESSION['logged_uid'] = $id_put;
-       $_SESSION['logged_lvl'] = $lvl_put;
-
-       if ($_SESSION['logged_lvl'] == "subscriber") {
-               $_SESSION['logged_key'] = $pw_mbox;
-       }
-}
-
-unset($pw_mbox);
-
-       if ($_SESSION['logged_lvl'] == "subscriber") {
-
-               if (isset($_SESSION['clean_up_i']) and file_exists("attach/i/$fileUsr/{$_SESSION['clean_up_i']}") and (!isset($_POST['filedrop_box']) or empty($_POST['filedrop_box']))) {
-
-                       rmdirr("attach/i/$fileUsr/{$_SESSION['clean_up_i']}");
-                       unset($_SESSION['clean_up_i']);
-
-                       if (count(glob("attach/i/$fileUsr/*")) == 0) {
-                               rmdirr("attach/i/$fileUsr");
-                       }
-               }
-
-               if (isset($_SESSION['clean_up_o']) and file_exists("attach/o/$fileUsr/{$_SESSION['clean_up_o']}")) {
-                        
-                       rmdirr("attach/o/$fileUsr/{$_SESSION['clean_up_o']}");
-                       unset($_SESSION['clean_up_o']);
-
-                       if (count(glob("attach/o/$fileUsr/*")) == 0) {
-                               rmdirr("attach/o/$fileUsr");
-                       }
-               }
-       }
-
-if (isset($_GET['do']) and ($_GET['do'] == "logout")) {
-       $_SESSION = array();
-       session_destroy();
-       header("Location: .");
-       exit;
-}
-
-/* logo here? */
-
-if (!isset($_SESSION['logged_uid']) and (($pw_put != $pw_get) or !isset($_POST['id']) or !isset($_POST['pw']) or empty($_POST['id']) or empty($_POST['pw']))) {
-
-       echo "<title>Kartero</title>";
-
-       echo "<div class=\"login\"><center>";
-
-       echo "<img src=\"images/logo.png\" border=\"0\" width=\"100\" height=\"100\">";
-       echo "<br>kartero v1.0 at {$_SERVER['SERVER_NAME']}<br><br>";
-
-       echo "<table border=\"0\" cellspacing=\"1\" cellpadding=\"2\" bgcolor=\"#cccccc\">";
-       echo "<form method=\"post\">";
-       echo "<tr bgcolor=\"#ffffff\"><td><select class=\"input\" name=\"lvl\"><option value=\"subscriber\">subscriber</option><option value=\"postmaster\">postmaster</option><option value=\"administrator\">administrator</option></select></td></tr>";
-       echo "<tr bgcolor=\"#ffffff\"><td><input required autofocus class=\"input\" type=\"text\" name=\"id\" autocomplete=\"off\" maxlength=\"128\"></td></tr>";
-       echo "<tr bgcolor=\"#ffffff\"><td><input required class=\"input\" type=\"password\" name=\"pw\" autocomplete=\"off\" maxlength=\"64\"></td></tr>";
-       echo "<tr bgcolor=\"#ffffff\"><td><input class=\"button\" type=\"submit\" value=\"login\"></td></tr>";
-       echo "</form>";
-       echo "</table>";
-
-       echo "</center></div>";
-
-       echo "<iframe name=\"preload\" src=\"preload.php\" frameborder=\"0\" scrolling=\"0\" width=\"0\" height=\"0\"></iframe>";
-
-       exit;
-}
-
-if (isset($_SESSION['logged_uid'])) {
-
-       //echo "<center>";
-
-       echo "<nobr>You are currently logged in to your {$_SESSION['logged_uid']} {$_SESSION['logged_lvl']} account. Click <a href=\"?do=logout\">here</a> to logout.</nobr><br><br>";
-
-       echo "<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">";
-       echo "<tr><td colspan=\"3\" valign=\"top\">";
-
-       if ($_SESSION['logged_lvl'] == "subscriber") {
-
-               $usr_query = mysql_query("select * from users where id='{$_SESSION['logged_uid']}'");
-               $usr_data = mysql_fetch_row($usr_query);
-
-               $dom_query = mysql_query("select mode from domains where id='{$usr_data[4]}'");
-               $dom_data = mysql_fetch_row($dom_query);
-
-               if ($dom_data[0] == 0) {
-                       nak("{$usr_data[4]} disabled by admin - new settings will take effect once it is re-enabled");
-               }
-
-               if ($usr_data[5] == 0) {
-                       nak("{$_SESSION['logged_uid']} disabled by postmaster - new settings will take effect once it is re-enabled");
-               }
-      
-               $usr_name = $usr_data[3];
-      
-               if (isset($_POST['usr_name']) and !empty($_POST['usr_name'])) {
-      
-                       $usr_name = trim($_POST['usr_name']);
-                       $usr_name = ucwords($usr_name);
-      
-                       if ($usr_name != $usr_data[3]) {
-      
-                               $usr_query = mysql_query("update users set name='$usr_name' where id='{$_SESSION['logged_uid']}'");
-      
-                               if (!usr_query) {
-                                       nak(strtolower(mysql_error()));
-                               }
-                               else {
-                                       ack("name changed");
-                               }
-                       }
-                       else {
-                               $usr_name = $usr_data[3];
-                       }
-               }
-      
-               $usr_pw0 = $usr_data[1];
-      
-               if (isset($_POST['usr_pw1']) and !empty($_POST['usr_pw1']) and isset($_POST['usr_pw2']) and !empty($_POST['usr_pw2']) and isset($_POST['usr_pw3']) and !empty($_POST['usr_pw3'])) {
-      
-                       $usr_pw1 = trim($_POST['usr_pw1']);
-                       $usr_pw2 = trim($_POST['usr_pw2']);
-                       $usr_pw3 = trim($_POST['usr_pw3']);
-      
-                       if ($usr_pw0 == crypt($usr_pw1,$usr_pw0)) {
-      
-                               if ($usr_pw2 == $usr_pw3) {
-                                      
-                                       $usr_pw = crypt($usr_pw2);
-      
-                                       $usr_query = mysql_query("update users set pw='$usr_pw' where id='{$_SESSION['logged_uid']}'");
-      
-                                       if (!usr_query) {
-                                               nak(strtolower(mysql_error()));
-                                       }
-                                       else {
-                                               ack("password changed");
-                                       }
-                               }
-                               else {
-                                       nak("new passwords do not match");
-                               }
-                       }
-                       else {
-                               nak("current password entered is incorrect");
-                       }
-               }
-       }
-
-       if ($_SESSION['logged_lvl'] == "postmaster") {
-      
-               $dom_query = mysql_query("select mode from domains where id='{$_SESSION['logged_uid']}'");
-               $dom_query = mysql_fetch_row($dom_query);
-      
-               if ($dom_query[0] == "0") {
-                       nak("{$_SESSION['logged_uid']} disabled by admin - new settings will take effect once it is re-enabled");
-               }
-
-$max_get = mysql_query("select max from domains where id='{$_SESSION['logged_uid']}'");
-
-$pm_max = mysql_fetch_row($max_get);
-
-$pm_get = mysql_query("select * from users where domain='{$_SESSION['logged_uid']}' order by id");
-
-$pm_now = mysql_num_rows($pm_get);
-
-               if (isset($_POST['pm_id']) and isset($_POST['pm_name']) and isset($_POST['pm_pw']) and !empty($_POST['pm_id']) and !empty($_POST['pm_name']) and !empty($_POST['pm_pw'])) {
-
-                       if ($pm_now >= $pm_max[0]) {
-                               nak("{$_SESSION['logged_uid']} limit exceeded");
-                       }
-                       else {
-                               $pm_id = trim($_POST['pm_id']);
-                               $pm_id = strtolower($pm_id);
-              
-                               if (preg_match("/@/",$pm_id)) {
-                                       $pm_id = substr($pm_id,0,strpos($pm_id,"@"));
-                               }
-              
-                               $pm_addr = $pm_id . "@" . $_SESSION['logged_uid'];
-              
-                               $alias_query = mysql_query("select id from aliases where id='$pm_addr'");
-              
-                               if (mysql_fetch_row($alias_query) > 0) {
-                                       nak("$pm_addr alias exists");
-                               }
-                               else {
-                                       $pm_name = trim($_POST['pm_name']);
-                                       $pm_name = ucwords($pm_name);
-              
-                                       $pm_pw = trim($_POST['pm_pw']);
-                                       $pm_pw = crypt($pm_pw);
-              
-                                       $pm_init = substr($pm_id,0,1);
-              
-                                       $pm_maildir = "{$_SESSION['logged_uid']}/$pm_init/$pm_id";
-      
-                                       $pm_host = trim($_POST['pm_host']);
-                                       $pm_host = strtolower($pm_host);
-              
-                                       $pm_query = mysql_query("insert into users values('$pm_addr','$pm_pw','$pm_maildir/','$pm_name','{$_SESSION['logged_uid']}','1','$pm_host')");
-              
-                                       if (!$pm_query) {
-                                               nak(strtolower(mysql_error()));
-                                       }
-                                       else {
-                                               if (!file_exists("$mail_root/{$_SESSION['logged_uid']}")) {
-                                                       mkdir("$mail_root/{$_SESSION['logged_uid']}");
-                                               }
-              
-                                               if (!file_exists("$mail_root/{$_SESSION['logged_uid']}/$pm_init")) {
-                                                       mkdir("$mail_root/{$_SESSION['logged_uid']}/$pm_init");
-                                               }
-              
-                                               if (!file_exists("$mail_root/$pm_maildir")) {
-                                                       mkdir("$mail_root/$pm_maildir");
-                                               }
-              
-                                               if (!file_exists("$mail_root/$pm_maildir/cur")) {
-                                                       mkdir("$mail_root/$pm_maildir/cur");
-                                               }
-                      
-                                               if (!file_exists("$mail_root/$pm_maildir/new")) {
-                                                       mkdir("$mail_root/$pm_maildir/new");
-                                               }
-              
-                                               if (!file_exists("$mail_root/$pm_maildir/tmp")) {
-                                                       mkdir("$mail_root/$pm_maildir/tmp");
-                                               }
-              
-                                               ack("$pm_addr added");
-                                       }
-                               }
-                       }
-               }
-
-               if (isset($_POST['pm_mod']) and !empty($_POST['pm_mod'])) {
-                      
-                       $pm_mod = trim($_POST['pm_mod']);
-      
-                       if (isset($_POST['pm_name']) and !empty($_POST['pm_name'])) {
-      
-                               $pm_name = trim($_POST['pm_name']);
-                               $pm_name = ucwords($pm_name);
-      
-                               $pm_query = mysql_query("select name from users where id='$pm_mod'");
-      
-                               $name_get = mysql_fetch_row($pm_query);
-      
-                               if ($name_get[0] != $pm_name) {
-      
-                                       $pm_query = mysql_query("update users set name='$pm_name' where id='$pm_mod'");
-      
-                                       if (!$pm_query) {
-                                               nak(strtolower(mysql_error()));
-                                       }
-                                       else {
-                                               ack("$pm_mod complete name updated");
-                                       }
-                               }
-                       }
-      
-                       if (isset($_POST['pm_pass']) and !empty($_POST['pm_pass'])) {
-      
-                               $pm_pass = $_POST['pm_pass'];
-                               $pm_pass = crypt($pm_pass);
-      
-                               $pm_query = mysql_query("update users set pw='$pm_pass' where id='$pm_mod'");
-      
-                               if (!$pm_query) {
-                                       nak(strtolower(mysql_error()));
-                               }
-                               else {
-                                       ack("$pm_mod password updated");
-                               }
-                       }
-
-                       if (isset($_POST['pm_host'])) {
-      
-                               $pm_host = trim($_POST['pm_host']);
-                               $pm_host = strtolower($pm_host);
-      
-                               $pm_query = mysql_query("select host from users where id='$pm_mod'");
-      
-                               $host_get = mysql_fetch_row($pm_query);
-      
-                               if ($host_get[0] != $pm_host) {
-      
-                                       $pm_query = mysql_query("update users set host='$pm_host' where id='$pm_mod'");
-      
-                                       if (!$pm_query) {
-                                               nak(strtolower(mysql_error()));
-                                       }
-                                       else {
-                                               ack("$pm_mod delivery host updated");
-                                       }
-                               }
-                       }
-               }
-      
-               if (isset($_POST['pm_set']) and !empty($_POST['pm_set']) and isset($_POST['pm_do']) and !empty($_POST['pm_do'])) {
-      
-                       $pm_set = trim($_POST['pm_set']);
-                       $pm_do = trim($_POST['pm_do']);
-      
-                       if ($pm_do == "disable") {
-                               $pm_do = "0";
-                       }
-      
-                       if ($pm_do == "enable") {
-                               $pm_do = "1";
-                       }
-              
-                       $pm_query = mysql_query("update aliases set mode='$pm_do' where alias='$pm_set'");
-                       $pm_query = mysql_query("update users set mode='$pm_do' where id='$pm_set'");
-      
-                       if (!$pm_query) {
-                               nak(strtolower(mysql_error()));
-                       }
-                       else {
-      
-                               $pm_query = mysql_query("select alias from aliases where alias='$pm_set'");
-                               $pm_aka = mysql_num_rows($pm_query);
-      
-                               if ($pm_do == "0") {
-      
-                                       if ($pm_aka > 0) {
-      
-                                               if ($pm_aka < 2) {
-                                                       ack("$pm_set account and 1 alias disabled");
-                                               }
-                                               else {
-                                                       ack("$pm_set account and $pm_aka aliases disabled");
-                                               }
-                                       }
-                                       else {
-                                               ack("$pm_set account disabled");
-                                       }
-                               }
-      
-                               if ($pm_do == "1") {
-      
-                                       if (mysql_fetch_row($pm_query) > 0) {
-      
-                                               if ($pm_aka < 2) {
-                                                       ack("$pm_set account and 1 alias enabled");
-                                               }
-                                               else {
-                                                       ack("$pm_set account and $pm_aka aliases enabled");
-                                               }
-                                       }
-                                       else {
-                                               ack("$pm_set account enabled");
-                                       }
-                               }
-                       }
-               }
-      
-               if (isset($_POST['pm_del']) and !empty($_POST['pm_del'])) {
-                      
-                       $pm_del = trim($_POST['pm_del']);
-      
-                       $pm_query = mysql_query("delete from aliases where alias='$pm_del'");
-                       $pm_query = mysql_query("delete from users where id='$pm_del'");
-      
-                       if (!$pm_query) {
-                               nak(strtolower(mysql_error()));
-                       }
-                       else {
-                               $pm_init = substr($pm_del,0,1);
-                               $pm_box = substr($pm_del,0,strpos($pm_del,"@"));
-      
-                               if (file_exists("$mail_root/{$_SESSION['logged_uid']}/$pm_init/$pm_box")) {
-                                       rmdirr("$mail_root/{$_SESSION['logged_uid']}/$pm_init/$pm_box");
-                               }
-      
-                               if (count(glob("$mail_root/{$_SESSION['logged_uid']}/$pm_init/*")) < 1) {
-                                       rmdir("$mail_root/{$_SESSION['logged_uid']}/$pm_init");
-                               }
-      
-                               ack("$pm_del deleted");
-                       }
-               }
-      
-               if (isset($_POST['alias_add']) and !empty($_POST['alias_add']) and isset($_POST['alias_to']) and !empty($_POST['alias_to'])) {
-      
-                       $alias_add = trim($_POST['alias_add']);
-      
-                       if (preg_match("/@/",$alias_add)) {
-                               $alias_add = substr($alias_add,0,strpos($alias_add,"@"));
-                       }
-      
-                       $alias_add = "$alias_add@{$_SESSION['logged_uid']}";
-      
-                       $alias_to = trim($_POST['alias_to']);
-      
-                       $alias_query = mysql_query("select id from users where id='$alias_add'");
-      
-                       if (mysql_num_rows($alias_query) > 0) {
-                               nak("$alias_add account exists");
-                       }
-                       else {
-                               if (!preg_match("/@/",$alias_to) or preg_match("/@{$_SESSION['logged_uid']}/",$alias_to)) {
-      
-                                       if (preg_match("/@{$_SESSION['logged_uid']}/",$alias_to)) {
-                                               $alias_to = substr($alias_to,0,strpos($alias_to,"@"));
-                                       }
-              
-                                       $alias_to = "$alias_to@{$_SESSION['logged_uid']}";
-              
-                                       $alias_query = mysql_query("select id from users where id='$alias_to'");
-              
-                                       if (mysql_num_rows($alias_query) < 1) {
-                                               nak("$alias_to does not exist");
-                                       }
-                                       else {
-                                               $alias_query = mysql_query("insert into aliases values('$alias_add','$alias_to','{$_SESSION['logged_uid']}','1')");
-              
-                                               if (!$alias_query) {
-                                                       nak(strtolower(mysql_error()));
-                                               }
-                                               else {
-                                                       ack("$alias_add added");
-                                               }
-                                       }
-                               }
-                               else {
-                                       $alias_query = mysql_query("insert into aliases values('$alias_add','$alias_to','{$_SESSION['logged_uid']}','1')");
-      
-                                       if (!$alias_query) {
-                                               nak(strtolower(mysql_error()));
-                                       }
-                                       else {
-                                               ack("$alias_add added");
-                                       }
-                               }
-                       }
-               }
-      
-               if (isset($_POST['alias_mod']) and !empty($_POST['alias_mod']) and isset($_POST['alias_to']) and !empty($_POST['alias_to'])) {
-                      
-                       $alias_mod = trim($_POST['alias_mod']);
-      
-                       $alias_to = trim($_POST['alias_to']);
-      
-                       if (!preg_match("/@/",$alias_to) or preg_match("/@{$_SESSION['logged_uid']}/",$alias_to)) {
-      
-                               if (preg_match("/@{$_SESSION['logged_uid']}/",$alias_to)) {
-                                       $alias_to = substr($alias_to,0,strpos($alias_to,"@"));
-                               }
-      
-                               $alias_to = "$alias_to@{$_SESSION['logged_uid']}";
-      
-                               $alias_query = mysql_query("select id from users where id='$alias_to'");
-      
-                               if (mysql_num_rows($alias_query) < 1) {
-                                       nak("$alias_to does not exist");
-                               }
-                               else {
-                                       $alias_query = mysql_query("update aliases set alias='$alias_to' where id='$alias_mod'");
-      
-                                       if (!$alias_query) {
-                                               nak(strtolower(mysql_error()));
-                                       }
-                                       else {
-                                               ack("$alias_mod updated");
-                                       }
-                               }
-                       }
-                       else {
-      
-                               $alias_query = mysql_query("update aliases set alias='$alias_to' where id='$alias_mod'");
-              
-                               if (!$alias_query) {
-                                       nak(strtolower(mysql_error()));
-                               }
-                               else {
-                                       ack("$alias_mod updated");
-                               }
-                       }
-               }
-      
-               if (isset($_POST['alias_set']) and !empty($_POST['alias_set']) and isset($_POST['alias_do']) and !empty($_POST['alias_do'])) {
-      
-                       $alias_set = trim($_POST['alias_set']);
-                       $alias_do = trim($_POST['alias_do']);
-      
-                       if ($alias_do == "disable") {
-                               $alias_do = "0";
-                               $alias_query = mysql_query("update aliases set mode='$alias_do' where id='$alias_set'");
-      
-                               if (!$alias_query) {
-                                       nak(strtolower(mysql_error()));
-                               }
-                               else {
-                                       ack("$alias_set alias disabled");
-                               }
-                       }
-      
-                       if ($alias_do == "enable") {
-      
-                               $alias_query = mysql_query("select alias from aliases where id='$alias_set'");
-                               $alias_recipient = mysql_fetch_row($alias_query);
-                               $alias_recipient = $alias_recipient[0];
-      
-                               $usr_query = mysql_query("select mode from users where id='$alias_recipient'");
-                               $alias_recipient_mode = mysql_fetch_row($usr_query);
-                               $alias_recipient_mode = $alias_recipient_mode[0];
-      
-                               if ($alias_recipient_mode == "0") {
-                                       nak("cannot enable $alias_set alias while $alias_recipient recipient account is disabled");
-                               }
-                               else {
-                                       $alias_do = "1";
-                                       $alias_query = mysql_query("update aliases set mode='$alias_do' where id='$alias_set'");
-              
-                                       if (!$alias_query) {
-                                               nak(strtolower(mysql_error()));
-                                       }
-                                       else {
-                                               ack("$alias_set alias enabled");
-                                       }
-                               }
-                       }
-               }
-      
-               if (isset($_POST['alias_del']) and !empty($_POST['alias_del'])) {
-                      
-                       $alias_del = trim($_POST['alias_del']);
-                       $alias_query = mysql_query("delete from aliases where id='$alias_del'");
-      
-                       if (!$alias_query) {
-                               nak(strtolower(mysql_error()));
-                       }
-                       else {
-                               ack("$alias_del deleted");
-                       }
-               }
-       }
-      
-       if ($_SESSION['logged_lvl'] == "administrator") {
-
-               if (isset($_POST['dom_name']) and isset($_POST['dom_pass']) and isset($_POST['dom_max']) and !empty($_POST['dom_name']) and !empty($_POST['dom_pass']) and is_numeric($_POST['dom_max'])) {
-      
-                       $dom_name = trim($_POST['dom_name']);
-      
-                       $dom_pass = trim($_POST['dom_pass']);
-                       $dom_pass = crypt($dom_pass);
-      
-                       $dom_max = trim($_POST['dom_max']);
-      
-                       $dom_query = mysql_query("insert into domains values('$dom_name','$dom_pass','$dom_max','1')");
-      
-                       if (!$dom_query) {
-                               nak(strtolower(mysql_error()));
-                       }
-                       else {
-                               if (!file_exists("$mail_root/$dom_name")) {
-                                       mkdir("$mail_root/$dom_name");
-                               }
-      
-                               ack("$dom_name added");
-                       }
-               }
-      
-               if (isset($_POST['dom_mod']) and !empty($_POST['dom_mod'])) {
-                      
-                       $dom_mod = trim($_POST['dom_mod']);
-      
-                       if (isset($_POST['dom_pass']) and !empty($_POST['dom_pass'])) {
-      
-                               $dom_pass = $_POST['dom_pass'];
-                               $dom_pass = crypt($dom_pass);
-      
-                               $dom_query = mysql_query("update domains set pw='$dom_pass' where id='$dom_mod'");
-      
-                               if (!$dom_query) {
-                                       nak(strtolower(mysql_error()));
-                               }
-                               else {
-                                       ack("$dom_mod postmaster password updated");
-                               }
-                       }
-      
-                       if (isset($_POST['dom_max']) and is_numeric($_POST['dom_max'])) {
-      
-                               $dom_max = $_POST['dom_max'];
-      
-                               $dom_query = mysql_query("select max from domains where id='$dom_mod'");
-      
-                               $max_get = mysql_fetch_row($dom_query);
-      
-                               if ($max_get[0] != $dom_max) {
-      
-                                       $dom_query = mysql_query("update domains set max='$dom_max' where id='$dom_mod'");
-      
-                                       if (!$dom_query) {
-                                               nak(strtolower(mysql_error()));
-                                       }
-                                       else {
-                                               ack("$dom_mod account limit updated");
-                                       }
-                               }
-                       }
-               }
-      
-               if (isset($_POST['dom_set']) and !empty($_POST['dom_set']) and isset($_POST['dom_do']) and !empty($_POST['dom_do'])) {
-      
-                       $dom_set = trim($_POST['dom_set']);
-                       $dom_do = trim($_POST['dom_do']);
-      
-                       if ($dom_do == "disable") {
-                               $dom_do = "0";
-                       }
-      
-                       if ($dom_do == "enable") {
-                               $dom_do = "1";
-                       }
-              
-                       $dom_query = mysql_query("update domains set mode='$dom_do' where id='$dom_set'");
-      
-                       if (!$dom_query) {
-                               nak(strtolower(mysql_error()));
-                       }
-                       else {
-                               if ($dom_do == "0") {
-                                       ack("$dom_set disabled");
-                               }
-      
-                               if ($dom_do == "1") {
-                                       ack("$dom_set enabled");
-                               }
-                       }
-               }
-      
-               if (isset($_POST['dom_del']) and !empty($_POST['dom_del'])) {
-                      
-                       $dom_del = trim($_POST['dom_del']);
-      
-                       $dom_query = mysql_query("delete from aliases where domain='$dom_del'");
-                       $dom_query = mysql_query("delete from users where domain='$dom_del'");
-                       $dom_query = mysql_query("delete from domains where id='$dom_del'");
-      
-                       if (!$dom_query) {
-                               nak(strtolower(mysql_error()));
-                       }
-                       else {
-                               if (file_exists("$mail_root/$dom_del")) {
-                                       rmdirr("$mail_root/$dom_del");
-                               }
-                               ack("$dom_del deleted");
-                       }
-               }
-       }
-      
-       echo "</td></tr>";
-
-       echo "<tr><td valign=\"top\">";
-
-       if ($_SESSION['logged_lvl'] == "subscriber") {
-
-               $filedrop_box = sha1(microtime(true));
-
-               echo "<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">";
-
-               if (isset($_POST['reply_from']) and isset($_POST['reply_to']) and isset($_POST['reply_subj']) and isset($_POST['reply_body']) and !empty($_POST['reply_from']) and !empty($_POST['reply_to']) and !empty($_POST['reply_subj']) and !empty($_POST['reply_body'])) {
-              
-                       $reply_from = trim($_POST['reply_from']);
-                       $reply_to = trim($_POST['reply_to']);
-                       $reply_subj = trim($_POST['reply_subj']);
-                       $reply_body = trim($_POST['reply_body']);                      
-                       $reply_headers = "From: $reply_from\r\nX-Mailer: Kartero/1.0 (PHP/" . phpversion() . ")";
-
-                       if (isset($_POST['reply_cc']) and !empty($_POST['reply_cc'])) {
-                      
-                               $reply_cc = trim($_POST['reply_cc']);
-                              
-                               $reply_headers = "$reply_headers\r\nCc: $reply_cc";
-                       }
-
-                       if (isset($_POST['reply_bcc']) and !empty($_POST['reply_bcc'])) {
-                      
-                               $reply_bcc = trim($_POST['reply_bcc']);
-                              
-                               $reply_headers = "$reply_headers\r\nBcc: $reply_bcc";
-                       }
-
-                       if (isset($_POST['filedrop_box']) and !empty($_POST['filedrop_box'])) {
-
-                               $do_filedrop_box = $_POST['filedrop_box'];
-
-                               if (file_exists("attach/i/$fileUsr/$do_filedrop_box") and (count(glob("attach/i/$fileUsr/$do_filedrop_box/*")) > 0)) {
-
-                                       $mime_boundary = md5(microtime(true));
-
-                                       $reply_headers .= "\r\nMIME-Version: 1.0";
-                                       $reply_headers .= "\r\nContent-Type: multipart/mixed; boundary=\"{$mime_boundary}\"";
-                                      
-                                       $reply_body = "\r\nThis is a multi-part message in MIME format.\r\n\r\n--{$mime_boundary}\r\nContent-type: text/plain; charset=UTF-8\r\nContent-Transfer-Encoding: 8bit\r\n\r\n{$reply_body}";
-
-                                       $do_reply_from = extract_emails_from($reply_from);
-                                       $do_reply_to = extract_emails_from($reply_to);
-
-                                       $do_filedrop_msg = glob("attach/i/$fileUsr/$do_filedrop_box/*");
-
-                                       sort($do_filedrop_msg);
-                                       reset($do_filedrop_msg);
-
-                                        foreach ($do_filedrop_msg as $do_filedrop_put) {
-
-                                               $do_filedrop_nom = str_replace("attach/i/$fileUsr/$do_filedrop_box/","",$do_filedrop_put);
-
-                                               $reply_body = $reply_body . "\r\n\r\n--{$mime_boundary}\r\nContent-Type: application/octet-stream; name=\"$do_filedrop_nom\"\r\nContent-Disposition: attachment; filename=\"$do_filedrop_nom\"\r\nContent-Transfer-Encoding: base64\r\n\r\n" . chunk_split(base64_encode(file_get_contents($do_filedrop_put)));
-                                        }
-
-                                       $reply_body = $reply_body . "--{$mime_boundary}--";
-
-                                       rmdirr("attach/i/$fileUsr/$do_filedrop_box");
-
-                                       if (count(glob("attach/i/$fileUsr/*")) == 0) {
-                                               rmdirr("attach/i/$fileUsr");
-                                       }
-                               }
-                       }
-
-                       $reply_body = preg_replace("#(?<!\r)\n#si", "\r\n", $reply_body);
-                       $reply_headers = preg_replace('#(?<!\r)\n#si', "\r\n", $reply_headers);
-
-                       mail($reply_to, $reply_subj, $reply_body, $reply_headers);
-                      
-                       $host = "{127.0.0.1:143/imap/notls/norsh}";
-
-                       $mbox = @imap_open($host, $_SESSION['logged_uid'], $_SESSION['logged_key']) or die("Connection to server failed");
-
-                       imap_createmailbox($mbox,"{$host}Sent");
-
-                       $reply_date = date ("d-M-Y H:i:s O");
-                      
-                       imap_append($mbox,"{$host}Sent","To: $reply_to\r\nSubject: $reply_subj\r\nDate: $reply_date\r\n$reply_headers\r\n\r\n$reply_body\r\n");
-
-                       if ($_POST['ack'] == 1) {
-
-                               imap_reopen($mbox, "{$host}{$_POST['box']}");
-                               imap_setflag_full($mbox, $_POST['msg'], '\\Answered');
-                       }
-
-                       imap_close($mbox);
-               }
-
-               if (isset($_POST['not']) and !empty($_POST['not']) and is_numeric($_POST['not'])) {
-
-                        $host = "{127.0.0.1:143/imap/notls/norsh}";
-
-                        $mbox = @imap_open("{$host}{$_POST['box']}", $_SESSION['logged_uid'], $_SESSION['logged_key']) or die("Connection to server failed");
-
-                       imap_clearflag_full($mbox, $_POST['msg'], '\\Seen');
-
-                       imap_close($mbox, CL_EXPUNGE);
-               }
-
-                if (isset($_POST['emt']) and !empty($_POST['emt']) and is_numeric($_POST['emt'])) {
-
-                        $host = "{127.0.0.1:143/imap/notls/norsh}";
-
-                        $mbox = @imap_open("{$host}{$_POST['box']}", $_SESSION['logged_uid'], $_SESSION['logged_key']) or die("Connection to server failed");
-
-                       imap_delete($mbox,'1:*');
-
-                        imap_close($mbox, CL_EXPUNGE);
-                }
-
-               echo "<tr><td valign=\"top\" width=\"700\"><div id=\"main\" class=\"main\">";
-
-               if (isset($_POST['get']) and !empty($_POST['get'])) {
-                       include("read.php");
-               }
-               elseif (isset($_POST['rep']) and !empty($_POST['rep'])) {
-                       include("send.php");
-               }
-               elseif (isset($_POST['new']) and !empty($_POST['new'])) {
-                       include("post.php");
-               }
-               elseif (isset($_POST['dig']) and !empty($_POST['dig'])) {
-                       include("search.php");
-               }
-               else {
-                       include("inbox.php");
-
-//echo "<script type=\"text/javascript\" src=\"jquery-1.3.2.min.js\"></script>";
-
-//echo "<script type=\"text/javascript\"> $(document).ready(function() { setInterval(function() { $('#main').fadeOut(\"fast\").load('inbox.php').fadeIn(\"slow\"); }, 5000); }); </script>";
-               }
-
-               echo "</div></td>";
-
-               echo "<td width=\"10\"></td>";
-
-               echo "<td valign=\"top\" width=\"100\">";
-               include("folders.php");
-               echo "</td>";
-/*
-               echo "<td valign=\"top\" width=\"100\">";
-               echo "<table border=\"0\" cellspacing=\"1\" cellpadding=\"1\">";
-               echo "<form method=\"post\">";
-               echo "<tr bgcolor=\"#ffffff\"><td align=\"center\" valign=\"middle\"><img src=\"images/preferences-desktop-personal.png\" border=\"0\" width=\"22\" height=\"22\"></td><td><input class=\"input\" type=\"text\" name=\"usr_name\" value=\"$usr_name\" autocomplete=\"off\" maxlength=\"128\"></td></tr>";
-               echo "<tr bgcolor=\"#ffffff\"><td align=\"center\" valign=\"middle\"><img src=\"images/flag-red.png\" border=\"0\" width=\"22\" height=\"22\"></td><td><input class=\"input\" type=\"password\" name=\"usr_pw1\" autocomplete=\"off\" maxlength=\"64\"></td></tr>";
-               echo "<tr bgcolor=\"#ffffff\"><td align=\"center\" valign=\"middle\"><img src=\"images/flag-green.png\" border=\"0\" width=\"22\" height=\"22\"></td><td><input class=\"input\" type=\"password\" name=\"usr_pw2\" autocomplete=\"off\" maxlength=\"64\"></td></tr>";
-               echo "<tr bgcolor=\"#ffffff\"><td align=\"center\" valign=\"middle\"><img src=\"images/flag-green.png\" border=\"0\" width=\"22\" height=\"22\"></td><td><input class=\"input\" type=\"password\" name=\"usr_pw3\" autocomplete=\"off\" maxlength=\"64\"></td></tr>";
-               echo "<tr bgcolor=\"#ffffff\"><td align=\"center\" valign=\"middle\"></td><td><input class=\"button\" type=\"submit\" value=\"update\"></td></tr>";
-               echo "</form></table>";
-               echo "</td>";
-*/
-               echo "</tr></table>";
-       }
-
-       if ($_SESSION['logged_lvl'] == "postmaster") {
-
-               echo "<table border=\"0\" cellspacing=\"1\" cellpadding=\"2\" bgcolor=\"#cccccc\">";
-               echo "<tr bgcolor=\"#eeeeee\"><td colspan=\"4\" align=\"center\">status</td><td align=\"center\">username</td><td align=\"center\">complete name</td><td align=\"center\">password</td><td align=\"center\">host</td><td align=\"center\" colspan=\"2\">action</td></tr>";
-               echo "<form method=\"post\">";
-               echo "<tr bgcolor=\"#ffffff\"><td align=\"center\">new</td><td align=\"center\">cur</td><td align=\"center\">aka</td><td align=\"center\">rcv</td><td><input class=\"input\" type=\"text\" name=\"pm_id\" autocomplete=\"off\" maxlength=\"255\"></td><td><input class=\"input\" type=\"text\" name=\"pm_name\" autocomplete=\"off\" maxlength=\"128\"></td><td><input class=\"input\" type=\"text\" name=\"pm_pw\" autocomplete=\"off\" maxlength=\"64\"></td><td><input class=\"input\" type=\"text\" name=\"pm_host\" autocomplete=\"off\" maxlength=\"255\"></td><td colspan=\"2\"><input class=\"button\" type=\"submit\" value=\"add\"></td></tr>";
-               echo "</form>";
-      
-               $pm_get = mysql_query("select * from users where domain='{$_SESSION['logged_uid']}' order by id");
-      
-               while ($pm_row = mysql_fetch_array($pm_get)) {
-      
-                       if ($pm_row[5] == "1") {
-                               $pm_do = "disable";
-                               $pm_bg = "#ffffff";
-                       }
-      
-                       if ($pm_row[5] == "0") {
-                               $pm_do = "enable";
-                               $pm_bg = "#eeeeee";
-                       }
-      
-                       $msg_new = "$mail_root/{$_SESSION['logged_uid']}/" . substr($pm_row[0],0,1) . "/" . substr($pm_row[0],0,strpos($pm_row[0],"@")) . "/new/*";
-                       $msg_new = count(glob($msg_new));
-      
-                       $msg_cur = "$mail_root/{$_SESSION['logged_uid']}/" . substr($pm_row[0],0,1) . "/" . substr($pm_row[0],0,strpos($pm_row[0],"@")) . "/cur/*";
-                       $msg_cur = count(glob($msg_cur));
-      
-                       $pm_aka = mysql_query("select * from aliases where alias='{$pm_row[0]}'");
-                       $pm_aka = mysql_num_rows($pm_aka);
-      
-                       echo "<tr bgcolor=\"$pm_bg\"><td align=\"right\">$msg_new</td><td align=\"right\">$msg_cur</td><td align=\"right\">$pm_aka</td><form method=\"post\"><input type=\"hidden\" name=\"pm_set\" value=\"{$pm_row[0]}\"><input type=\"hidden\" name=\"pm_do\" value=\"$pm_do\"><td align=\"center\" valign=\"middle\" width=\"10\"><input type=\"image\" src=\"images/{$pm_do}.png\"></td></form><form method=\"post\"><input type=\"hidden\" name=\"pm_mod\" value=\"{$pm_row[0]}\"><td>{$pm_row[0]}</td><td><input class=\"input\" type=\"text\" name=\"pm_name\" maxlength=\"128\" autocomplete=\"off\" value=\"{$pm_row[3]}\"></td><td><input class=\"input\" type=\"text\" name=\"pm_pass\" maxlength=\"64\" autocomplete=\"off\"></td><td><input class=\"input\" type=\"text\" name=\"pm_host\" maxlength=\"255\" autocomplete=\"off\" value=\"{$pm_row[6]}\"></td><td><input class=\"button\" type=\"submit\" value=\"mod\"></td></form><form method=\"post\"><input type=\"hidden\" name=\"pm_del\" value=\"{$pm_row[0]}\"><td><input class=\"button\" type=\"submit\" value=\"del\" onclick=\"if (confirm('Do you really want to delete {$pm_row[0]} plus all messages and aliases associated with this account?')) {return true;} else {return false;}\"></td></form></tr>";
-               }
-      
-               echo "</table>";
-       }
-
-       if ($_SESSION['logged_lvl'] == "administrator") {
-      
-               echo "<table border=\"0\" cellspacing=\"1\" cellpadding=\"2\" bgcolor=\"#cccccc\">";
-               echo "<tr bgcolor=\"#eeeeee\"><td colspan=\"2\" align=\"center\">status</td><td align=\"center\"><nobr>domain name</nobr></td><td align=\"center\"><nobr>account limit</nobr></td><td align=\"center\"><nobr>postmaster password</nobr></td><td align=\"center\" colspan=\"2\">action</td></tr>";
-               echo "<form method=\"post\"><tr bgcolor=\"#ffffff\"><td align=\"center\">usr</td><td align=\"center\">rcv</td><td align=\"center\"><input class=\"input\" type=\"text\" name=\"dom_name\" maxlength=\"128\" autocomplete=\"off\"></td><td align=\"center\"><input class=\"input\" style=\"text-align: right;\" type=\"text\" name=\"dom_max\" maxlength=\"6\" autocomplete=\"off\" value=\"0\"></td><td align=\"center\"><input class=\"input\" type=\"text\" name=\"dom_pass\" maxlength=\"64\" autocomplete=\"off\"></td><td align=\"center\" colspan=\"2\"><input class=\"button\" type=\"submit\" value=\"add\"></td></tr></form>";
-      
-               $dom_get = mysql_query("select * from domains order by id");
-      
-               while ($dom_row = mysql_fetch_array($dom_get)) {
-
-                       $dom_usr = mysql_query("select * from users where domain='{$dom_row[0]}'");
-                       $dom_usr = mysql_num_rows($dom_usr);
-      
-                       if ($dom_row[3] == "1") {
-                               $dom_do = "disable";
-                               $dom_bg = "#ffffff";
-                       }
-      
-                       if ($dom_row[3] == "0") {
-                               $dom_do = "enable";
-                               $dom_bg = "#eeeeee";
-                       }
-      
-                       echo "<tr bgcolor=\"$dom_bg\"><td align=\"right\">$dom_usr</td><form method=\"post\"><input type=\"hidden\" name=\"dom_set\" value=\"{$dom_row[0]}\"><input type=\"hidden\" name=\"dom_do\" value=\"$dom_do\"><td align=\"center\" valign=\"middle\" width=\"10\"><input type=\"image\" src=\"images/{$dom_do}.png\"></td></form><form method=\"post\"><input type=\"hidden\" name=\"dom_mod\" value=\"{$dom_row[0]}\"><td>{$dom_row[0]}</td><td><input class=\"input\" style=\"text-align: right;\" type=\"text\" name=\"dom_max\" maxlength=\"6\" autocomplete=\"off\" value=\"{$dom_row[2]}\"></td><td><input class=\"input\" type=\"text\" name=\"dom_pass\" maxlength=\"64\" autocomplete=\"off\"></td><td><input class=\"button\" type=\"submit\" value=\"mod\"></td></form><form method=\"post\"><input type=\"hidden\" name=\"dom_del\" value=\"{$dom_row[0]}\"><td><input class=\"button\" type=\"submit\" value=\"del\" onclick=\"if (confirm('Do you really want to delete {$dom_row[0]} plus all accounts and messages associated with this domain?')) {return true;} else {return false;}\"></td></form></tr>";
-               }
-      
-               echo "</table>";
-       }
-      
-       echo "</td>";
-
-       if ($_SESSION['logged_lvl'] == "postmaster") {
-      
-               echo "<td width=\"10\"></td><td valign=\"top\">";
-
-               echo "<table border=\"0\" cellspacing=\"1\" cellpadding=\"2\" bgcolor=\"#cccccc\">";
-               echo "<tr bgcolor=\"#eeeeee\"><td align=\"center\">alias</td><td align=\"center\">recipient</td><td align=\"center\" colspan=\"3\">action</td></tr>";
-               echo "<form method=\"post\">";
-               echo "<tr bgcolor=\"#ffffff\"><td><input class=\"input\" type=\"text\" name=\"alias_add\" autocomplete=\"off\" maxlength=\"255\"></td><td><input class=\"input\" type=\"text\" name=\"alias_to\" autocomplete=\"off\" maxlength=\"128\"></td><td colspan=\"3\"><input class=\"button\" type=\"submit\" value=\"add\"></td></tr>";
-               echo "</form>";
-      
-               $get_aliases = mysql_query("select * from aliases where domain='{$_SESSION['logged_uid']}' order by id");
-      
-               while ($aliases_row = mysql_fetch_array($get_aliases)) {
-      
-                       if ($aliases_row[3] == "1") {
-                               $alias_do = "disable";
-                               $alias_bg = "#ffffff";
-                       }
-      
-                       if ($aliases_row[3] == "0") {
-                               $alias_do = "enable";
-                               $alias_bg = "#eeeeee";
-                       }
-      
-                       echo "<tr bgcolor=\"$alias_bg\"><form method=\"post\"><input type=\"hidden\" name=\"alias_mod\" value=\"{$aliases_row[0]}\"><td>{$aliases_row[0]}</td><td><input class=\"input\" type=\"text\" name=\"alias_to\" maxlength=\"255\" autocomplete=\"off\" value=\"{$aliases_row[1]}\"></td><td><input class=\"button\" type=\"submit\" value=\"mod\"></td></form><form method=\"post\"><input type=\"hidden\" name=\"alias_set\" value=\"{$aliases_row[0]}\"><input type=\"hidden\" name=\"alias_do\" value=\"$alias_do\"><td align=\"center\" valign=\"middle\" width=\"10\"><input type=\"image\" src=\"images/{$alias_do}.png\"></td></form><form method=\"post\"><input type=\"hidden\" name=\"alias_del\" value=\"{$aliases_row[0]}\"><td><input class=\"button\" type=\"submit\" value=\"del\" onclick=\"if (confirm('Do you really want to delete the {$aliases_row[0]} alias of {$aliases_row[1]}?')) {return true;} else {return false;}\"></td></form></tr>";
-               }
-      
-               echo "</table>";
-       }
-
-       echo "</td></tr>";
-       echo "</table>";
-}
-
-mysql_close($db_link);
-
-?>
diff --git a/read.php b/read.php
index 3fa97d2..f49efa8 100644
--- a/read.php
+++ b/read.php
@@ -156,6 +156,22 @@ if (isset($_POST['msg']) and !empty($_POST['msg']) and is_numeric($_POST['msg'])
       
        echo "<td width=\"5\"></td>";
 
+        echo "<form method=\"post\"><td class=\"label\">";
+        echo "<input type=\"hidden\" name=\"mbox_min\" value=\"$mbox_min\">";
+        echo "<input type=\"hidden\" name=\"box\" value=\"$folder\">";
+        echo "<input type=\"hidden\" name=\"msg\" value=\"$msgno\">";
+        echo "<input type=\"hidden\" name=\"rep\" value=\"4\">";
+
+        if (isset($_POST['imap_search_query']) and !empty($_POST['imap_search_query']) and isset($_POST['imap_search_where']) and !empty($_POST['imap_search_where'])) {
+                echo "<input type=\"hidden\" name=\"imap_search_query\" value=\"{$_POST['imap_search_query']}\">";
+                echo "<input type=\"hidden\" name=\"imap_search_where\" value=\"{$_POST['imap_search_where']}\">";
+        }
+
+        echo "<input type=\"image\" src=\"images/mail-forward.png\">";
+        echo "</td></form>";
+
+        echo "<td width=\"5\"></td>";
+
        echo "<form method=\"post\"><td class=\"label\">";
        echo "<input type=\"hidden\" name=\"mbox_min\" value=\"$mbox_min\">";
        echo "<input type=\"hidden\" name=\"box\" value=\"$folder\">";
@@ -245,6 +261,10 @@ if (isset($_POST['msg']) and !empty($_POST['msg']) and is_numeric($_POST['msg'])
        echo "<td></td>";
        echo "<td class=\"label\">unread</td>";
        echo "<td width=\"5\"></td>";
+
+       echo "<td class=\"label\">redirect</td>";
+       echo "<td width=\"5\"></td>";
+
        echo "<td class=\"label\">forward</td>";
        echo "<td width=\"5\"></td>";
 
@@ -369,6 +389,9 @@ if (isset($_POST['msg']) and !empty($_POST['msg']) and is_numeric($_POST['msg'])
        $msgBody = mb_convert_encoding($msgBody,"UTF-8","auto");
        $msgBody = mb_convert_encoding($msgBody,"UTF-8","UTF-8");
 
+//echo nl2br(htmlentities(imap_fetchheader($mbox,$msgno)));
+//echo nl2br(htmlentities(imap_body($mbox,$msgno)));
+
        echo $msgBody;
 
        echo "</div>";
diff --git a/send.php b/send.php
index cdcc1dc..87c45ea 100644
--- a/send.php
+++ b/send.php
@@ -60,7 +60,7 @@ if (isset($_POST['msg']) and !empty($_POST['msg']) and is_numeric($_POST['msg'])
                $reply_to = $reply_to . ", " . $header->toaddress;
        }
 
-       if ($_POST['rep'] == 2) {
+       if (($_POST['rep'] == 2) or ($_POST['rep'] == 4)) {
 
                $reply_cc ="";
        }
@@ -70,11 +70,16 @@ if (isset($_POST['msg']) and !empty($_POST['msg']) and is_numeric($_POST['msg'])
 
        $reply_subject = $header->subject;
 
-       if ($_POST['rep'] == 2) {
+       if (($_POST['rep'] == 2) or ($_POST['rep'] == 4)) {
+
+               $redirect_from = htmlentities($reply_to,ENT_QUOTES);
 
                $reply_to = "";
 
-               $reply_subject = "Fwd: " . $reply_subject;
+               if ($_POST['rep'] == 2) {
+                       $reply_subject = "Fwd: " . $reply_subject;
+               }
+
                $reply_subject = str_replace("Fwd: Fwd: ","Fwd: ",$reply_subject);
        }
        else {
@@ -123,28 +128,34 @@ if (isset($_POST['msg']) and !empty($_POST['msg']) and is_numeric($_POST['msg'])
        }
 
        echo "<tr><td width=\"50\"><b>From:</b></td><td rowspan=\"7\" width=\"5\"></td><td>";
-
-       if (mysql_num_rows($send_alias_query) > 0) {
       
-               echo "<select class=\"input\" name=\"reply_from\">";
-               echo "<option>$reply_from</option>";
-
-               while ($row = mysql_fetch_assoc($send_alias_query)) {
-    
-                       echo "<option";
-
-                       if ($row[id] == $header_tos[0]) {
-                               echo " selected";
+       if ($_POST['rep'] == 4) {
+               echo "<input type=\"hidden\" name=\"redirect\" value=\"1\">";
+               echo "<input class=\"input\" type=\"text\" name=\"reply_from\" value=\"$redirect_from\" readonly>";
+       }
+       else {
+               if (mysql_num_rows($send_alias_query) > 0) {
+              
+                       echo "<select class=\"input\" name=\"reply_from\">";
+                       echo "<option>$reply_from</option>";
+      
+                       while ($row = mysql_fetch_assoc($send_alias_query)) {
+          
+                               echo "<option";
+      
+                               if ($row[id] == $header_tos[0]) {
+                                       echo " selected";
+                               }
+      
+                               echo ">\"$usr_name\" &lt;$row[id]&gt;";
+                               echo "</option>";
                        }
 
-                       echo ">\"$usr_name\" &lt;$row[id]&gt;";
-                       echo "</option>";
+                       echo "</select>";
+               }
+               else {
+                       echo "<input class=\"input\" type=\"text\" name=\"reply_from\" value=\"$reply_from\" readonly>";
                }
-
-               echo "</select>";
-       }
-       else {
-               echo "<input class=\"input\" type=\"text\" name=\"reply_from\" value=\"$reply_from\" readonly>";
        }
 
        echo "</td></tr>";
@@ -154,13 +165,28 @@ if (isset($_POST['msg']) and !empty($_POST['msg']) and is_numeric($_POST['msg'])
        echo "<tr><td><b>To:</b></td><td><input required class=\"input\" type=\"text\" name=\"reply_to\" value=\"$reply_to\" required></td></tr>";
        echo "<tr><td><b>Cc:</b></td><td><input class=\"input\" type=\"text\" name=\"reply_cc\" value=\"$reply_cc\"></td></tr>";
        echo "<tr><td><b>Bcc:</b></td><td><input class=\"input\" type=\"text\" name=\"reply_bcc\"></td></tr>";
-       echo "<tr><td><b>Subject:</b></td><td><input required class=\"input\" type=\"text\" name=\"reply_subj\" value=\"$reply_subject\" required></td></tr>";
 
-       echo "<tr><td></td><td><textarea required class=\"input\" name=\"reply_body\" rows=\"$reply_quote_rows\">";
+       echo "<tr><td><b>Subject:</b></td><td><input required class=\"input\" type=\"text\" name=\"reply_subj\" value=\"$reply_subject\" required";
 
-       if ($_POST['rep'] == 2) {
+       if ($_POST['rep'] == 4) {
+               echo " readonly";
+       }
 
-               echo "---------------------------------------- Begin Forwarded Message ----------------------------------------\r\n";  
+       echo "></td></tr>";
+
+       echo "<tr><td></td><td><textarea required class=\"input\" name=\"reply_body\" rows=\"$reply_quote_rows\"";
+
+       if ($_POST['rep'] == 4) {
+               echo " readonly=\"yes\"";
+       }
+
+       echo ">";
+
+       if (($_POST['rep'] == 2) or ($_POST['rep'] == 4)) {
+
+               if ($_POST['rep'] == 2) {
+                       echo "---------------------------------------- Begin Forwarded Message ----------------------------------------\r\n";  
+               }
 
                echo $reply_quote;
 
@@ -232,7 +258,18 @@ if (isset($_POST['msg']) and !empty($_POST['msg']) and is_numeric($_POST['msg'])
 <tr><td>
 <input type="hidden" name="MAX_FILE_SIZE" value="<?php echo $max_file_size; ?>">
 <input type="hidden" name="filedrop_box" value="<?php echo $filedrop_box; ?>">
-<input type="file" name="filedrop_obj">
+
+<?php
+
+if ($_POST['rep'] == 4) {
+       echo "<input type=\"file\" name=\"filedrop_obj\" disabled>";
+}
+else {
+       echo "<input type=\"file\" name=\"filedrop_obj\">";
+}
+
+?>
+
 <input type="submit" name="filedrop_submit" value="Upload">
 </td>
 
 
filedropkartero.git-41992ae.tar.bz2 new
412.12 KB
258 downloads
filedropkartero.git-41992ae.zip
448.41 KB
235 downloads
filedropkartero.git-b404ba2.tar.bz2
411.70 KB
245 downloads
filedropkartero.git-b404ba2.zip
447.96 KB
227 downloads
filedropkartero.git-a7684d9.tar.bz2
411.72 KB
230 downloads
filedropkartero.git-a7684d9.zip
447.96 KB
260 downloads
filedropkartero.git-83512be.tar.bz2
410.26 KB
222 downloads
filedropkartero.git-83512be.zip
445.30 KB
198 downloads
filedropkartero.git-1954b25.tar.bz2
410.21 KB
215 downloads
filedropkartero.git-1954b25.zip
445.30 KB
193 downloads
filedropkartero.git-2f7c910.tar.bz2
410.25 KB
205 downloads
filedropkartero.git-2f7c910.zip
445.29 KB
180 downloads
filedropkartero.git-6317ffb.tar.bz2
410.40 KB
190 downloads
filedropkartero.git-6317ffb.zip
445.28 KB
162 downloads
filedropkartero.git-60ccd7a.tar.bz2
410.40 KB
178 downloads
filedropkartero.git-60ccd7a.zip
445.20 KB
158 downloads
filedropkartero.git-ea6f885.tar.bz2
410.47 KB
165 downloads
filedropkartero.git-ea6f885.zip
445.26 KB
140 downloads
filedropkartero.git-7f580e5.zip
445.17 KB
130 downloads
filedropkartero.git-7f580e5.tar.bz2
410.18 KB
138 downloads
filedropkartero.git-b9364de.tar.bz2
409.41 KB
128 downloads
filedropkartero.git-b9364de.zip
444.09 KB
390 downloads
filedropkartero.git-e9bcd78.zip
444.03 KB
370 downloads
filedropkartero.git-e9bcd78.tar.bz2
409.39 KB
393 downloads
filedropkartero.git-96c60ff.tar.bz2
407.96 KB
385 downloads
filedropkartero.git-96c60ff.zip
441.87 KB
342 downloads
filedropkartero.git-4357b59.tar.bz2
407.17 KB
384 downloads
filedropkartero.git-4357b59.zip
440.69 KB
345 downloads
filedropkartero.git-c6ff319.tar.bz2
407.28 KB
381 downloads
filedropkartero.git-c6ff319.zip
440.70 KB
326 downloads
filedropkartero.git-8b87a29.tar.bz2
407.27 KB
362 downloads
filedropkartero.git-8b87a29.zip
440.71 KB
325 downloads
filedropkartero.git-ee42942.tar.bz2
406.49 KB
321 downloads
filedropkartero.git-ee42942.zip
439.92 KB
303 downloads
filedropkartero.git-867e7e6.tar.bz2
406.75 KB
343 downloads
filedropkartero.git-867e7e6.zip
440.03 KB
306 downloads
filedropkartero.git-3f3fc02.tar.bz2
406.38 KB
340 downloads
filedropkartero.git-3f3fc02.zip
439.71 KB
332 downloads
filedropkartero.git-b6f779d.tar.bz2
406.55 KB
360 downloads
filedropkartero.git-b6f779d.zip
440.00 KB
291 downloads
filedropkartero.git-83f24b0.zip
439.12 KB
273 downloads
filedropkartero.git-52316ec.tar.bz2
406.17 KB
316 downloads
filedropkartero.git-52316ec.zip
439.18 KB
296 downloads
filedropkartero.git-83f24b0.tar.bz2
405.84 KB
310 downloads
filedropkartero.git-8a42d47.tar.bz2
405.73 KB
289 downloads
filedropkartero.git-8a42d47.zip
439.02 KB
269 downloads
filedropkartero.git-830c9cb.tar.bz2
406.08 KB
293 downloads
filedropkartero.git-830c9cb.zip
439.08 KB
268 downloads
filedropkartero.git-ebec1be.tar.bz2
406.16 KB
295 downloads
filedropkartero.git-ebec1be.zip
439.09 KB
296 downloads
filedropkartero.git-7c0b70f.tar.bz2
402.43 KB
282 downloads
filedropkartero.git-7c0b70f.zip
435.91 KB
261 downloads
filedropkartero.git-80edc03.tar.bz2
402.75 KB
294 downloads
filedropkartero.git-80edc03.zip
435.84 KB
272 downloads
filedropkartero.git-b408c23.tar.bz2
402.19 KB
285 downloads
filedropkartero.git-b408c23.zip
435.59 KB
276 downloads
filedropkartero.git-29c0e1f.tar.bz2
401.84 KB
290 downloads
filedropkartero.git-29c0e1f.zip
435.25 KB
288 downloads
filedropkartero.git-9086094.tar.bz2
401.94 KB
289 downloads
filedropkartero.git-9086094.zip
435.34 KB
288 downloads
filedropkartero.git-47ca624.tar.bz2
402.10 KB
288 downloads
filedropkartero.git-47ca624.zip
435.51 KB
256 downloads
filedropkartero.git-81314a5.zip
435.53 KB
276 downloads
filedropkartero.git-81314a5.tar.bz2
402.25 KB
283 downloads
filedropkartero.git-cae7074.zip
435.20 KB
272 downloads
filedropkartero.git-cae7074.tar.bz2
401.98 KB
299 downloads
filedropkartero.git-cc68e56.tar.bz2
402.07 KB
282 downloads
filedropkartero.git-cc68e56.zip
435.16 KB
302 downloads
filedropkartero.git-230f35d.tar.bz2
401.43 KB
268 downloads
filedropkartero.git-230f35d.zip
434.68 KB
289 downloads
filedropkartero.git-5ae58a2.tar.bz2
401.54 KB
270 downloads
filedropkartero.git-5ae58a2.zip
434.68 KB
262 downloads
filedropkartero.git-a591f4b.tar.bz2
401.76 KB
270 downloads
filedropkartero.git-a591f4b.zip
435.17 KB
269 downloads
filedropkartero.git-36876c8.tar.bz2
400.44 KB
268 downloads
filedropkartero.git-36876c8.zip
432.36 KB
292 downloads
filedropkartero.git-a34c9ed.tar.bz2
400.57 KB
290 downloads
filedropkartero.git-a34c9ed.zip
432.27 KB
282 downloads
filedropkartero.git-e828148.zip
433.58 KB
263 downloads
filedropkartero.git-e828148.tar.bz2
400.88 KB
277 downloads
filedropkartero.git-476cdda.tar.bz2
400.60 KB
307 downloads
filedropkartero.git-476cdda.zip
432.26 KB
275 downloads
filedropkartero.git-054c286.tar.bz2
98.09 KB
346 downloads
filedropkartero.git-054c286.zip
109.53 KB
333 downloads
filedropkartero.git-071b099.tar.bz2
98.76 KB
349 downloads
filedropkartero.git-071b099.zip
110.21 KB
335 downloads
filedropkartero.git-551c38d.tar.bz2
98.51 KB
355 downloads
filedropkartero.git-551c38d.zip
110.20 KB
325 downloads
filedropkartero.git-569dc0c.tar.bz2
98.40 KB
349 downloads
filedropkartero.git-569dc0c.zip
109.86 KB
317 downloads
filedropkartero.git-58a052b.tar.bz2
97.95 KB
345 downloads
filedropkartero.git-58a052b.zip
109.36 KB
331 downloads
filedropkartero.git-43a5af3.tar.bz2
97.80 KB
342 downloads
filedropkartero.git-43a5af3.zip
109.30 KB
328 downloads
filedropkartero.git-bbe069d.tar.bz2
98.03 KB
354 downloads
filedropkartero.git-bbe069d.zip
109.19 KB
333 downloads
filedropkartero.git-02f97e1.tar.bz2
97.76 KB
321 downloads
filedropkartero.git-02f97e1.zip
109.24 KB
423 downloads
filedropkartero.git-d82e393.tar.bz2
97.74 KB
354 downloads
filedropkartero.git-d82e393.zip
109.24 KB
334 downloads
filedropkartero.git-7cdd1f5.tar.bz2
98.03 KB
338 downloads
filedropkartero.git-7cdd1f5.zip
109.24 KB
315 downloads
filedropkartero.git-40825aa.tar.bz2
97.71 KB
337 downloads
filedropkartero.git-40825aa.zip
109.16 KB
352 downloads
filedropkartero.git-3dd941b.tar.bz2
97.69 KB
337 downloads
filedropkartero.git-3dd941b.zip
109.12 KB
325 downloads
filedropkartero.git-50f1e46.tar.bz2
97.65 KB
345 downloads
filedropkartero.git-50f1e46.zip
109.02 KB
329 downloads
filedropkartero.git-fdf9225.tar.bz2
93.19 KB
377 downloads
filedropkartero.git-fdf9225.zip
104.25 KB
339 downloads
filedropkartero.git-21415da.tar.bz2
93.24 KB
333 downloads
filedropkartero.git-21415da.zip
104.22 KB
341 downloads
filedropkartero.git-aff5e89.tar.bz2
93.17 KB
355 downloads
filedropkartero.git-aff5e89.zip
104.22 KB
330 downloads
filedropkartero.git-b27ef39.tar.bz2
91.97 KB
354 downloads
filedropkartero.git-b27ef39.zip
102.80 KB
356 downloads
filedropkartero.git-3d6e8a2.tar.bz2
91.99 KB
338 downloads
filedropkartero.git-3d6e8a2.zip
102.77 KB
351 downloads
filedropkartero.git-1442b69.tar.bz2
91.79 KB
331 downloads
filedropkartero.git-1442b69.zip
102.50 KB
356 downloads
filedropkartero.git-6d15918.tar.bz2
91.56 KB
354 downloads
filedropkartero.git-6d15918.zip
102.28 KB
322 downloads
filedropkartero.git-45140d8.tar.bz2
91.52 KB
357 downloads
filedropkartero.git-45140d8.zip
102.23 KB
328 downloads
filedropkartero.git-d5b48e5.tar.bz2
91.35 KB
344 downloads
filedropkartero.git-d5b48e5.zip
102.01 KB
340 downloads
filedropkartero.git-e007e55.tar.bz2
91.35 KB
355 downloads
filedropkartero.git-e007e55.zip
102.01 KB
313 downloads
filedropkartero.git-30fd7e3.tar.bz2
90.87 KB
331 downloads
filedropkartero.git-30fd7e3.zip
101.44 KB
340 downloads
filedropkartero.git-421a4a7.tar.bz2
88.02 KB
70 downloads
filedropkartero.git-421a4a7.zip
97.96 KB
317 downloads
filedropkartero.git-b49b8bc.tar.bz2
88.09 KB
375 downloads
filedropkartero.git-b49b8bc.zip
97.99 KB
333 downloads
filedropkartero.git-1cc9571.tar.bz2
87.74 KB
352 downloads
filedropkartero.git-1cc9571.zip
97.70 KB
337 downloads
filedropkartero.git-159152f.tar.bz2
87.60 KB
350 downloads
filedropkartero.git-159152f.zip
97.52 KB
343 downloads
filedropkartero.git-35caaf3.tar.bz2
87.74 KB
333 downloads
filedropkartero.git-35caaf3.zip
97.57 KB
326 downloads
filedropkartero.git-3c9d305.zip
96.67 KB
329 downloads
filedropkartero.git-3c9d305.tar.bz2
86.77 KB
341 downloads
filedropkartero.git-14cb2af.tar.bz2
86.41 KB
340 downloads
filedropkartero.git-14cb2af.zip
96.13 KB
332 downloads
filedropkartero.git-e8f00cb.tar.bz2
86.46 KB
356 downloads
filedropkartero.git-e8f00cb.zip
96.21 KB
321 downloads
filedropkartero.git-bdab380.tar.bz2
86.14 KB
353 downloads
filedropkartero.git-bdab380.zip
95.79 KB
326 downloads
filedropkartero.git-48f9134.tar.bz2
85.78 KB
357 downloads
filedropkartero.git-48f9134.zip
95.48 KB
336 downloads
filedropkartero.git-adb9757.tar.bz2
85.67 KB
345 downloads
filedropkartero.git-adb9757.zip
95.37 KB
326 downloads
filedropkartero.git-1601cbd.zip
95.30 KB
338 downloads
filedropkartero.git-1601cbd.tar.bz2
85.69 KB
327 downloads
filedropkartero.git-18a5106.tar.bz2
85.72 KB
328 downloads
filedropkartero.git-18a5106.zip
95.48 KB
342 downloads
filedropkartero.git-a5b1caa.tar.bz2
85.61 KB
363 downloads
filedropkartero.git-a5b1caa.zip
95.36 KB
336 downloads
filedropkartero.git-effff82.zip
97.06 KB
347 downloads
filedropkartero.git-effff82.tar.bz2
87.13 KB
351 downloads
filedropkartero.git-b70d364.tar.bz2
84.09 KB
389 downloads
filedropkartero.git-b70d364.zip
93.67 KB
342 downloads
filedropkartero.git-48f0e53.tar.bz2
84.16 KB
363 downloads
filedropkartero.git-48f0e53.zip
93.66 KB
335 downloads
filedropkartero.git-c17135e.tar.bz2
84.09 KB
344 downloads
filedropkartero.git-c17135e.zip
93.57 KB
321 downloads
filedropkartero.git-a2e2848.tar.bz2
85.59 KB
349 downloads
filedropkartero.git-a2e2848.zip
100.10 KB
334 downloads
filedropkartero.git-1f683db.tar.bz2
83.55 KB
349 downloads
filedropkartero.git-1f683db.zip
93.24 KB
330 downloads
filedropkartero.git-d342596.tar.bz2
83.57 KB
347 downloads
filedropkartero.git-d342596.zip
93.28 KB
322 downloads
filedropkartero.git-e0131d5.tar.bz2
83.55 KB
350 downloads
filedropkartero.git-e0131d5.zip
93.27 KB
339 downloads
filedropkartero.git-ad467e8.tar.bz2
83.13 KB
358 downloads
filedropkartero.git-ad467e8.zip
92.78 KB
327 downloads
filedropkartero.git-b20e27d.tar.bz2
83.46 KB
363 downloads
filedropkartero.git-b20e27d.zip
93.19 KB
355 downloads
filedropkartero.git-eefd8fe.zip
92.67 KB
359 downloads
filedropkartero.git-eefd8fe.tar.bz2
83.01 KB
347 downloads
filedropkartero.git-bea685a.zip
96.88 KB
335 downloads
filedropkartero.git-bea685a.tar.bz2
84.44 KB
343 downloads
filedropkartero.git-a8bd019.tar.bz2
84.25 KB
357 downloads
filedropkartero.git-a8bd019.zip
96.60 KB
329 downloads
filedropkartero.git-cbc914d.tar.bz2
84.38 KB
351 downloads
filedropkartero.git-cbc914d.zip
96.64 KB
319 downloads
filedropkartero.git-09a2e70.tar.bz2
84.40 KB
331 downloads
filedropkartero.git-09a2e70.zip
96.70 KB
341 downloads
filedropkartero.git-641dc05.tar.bz2
84.37 KB
349 downloads
filedropkartero.git-641dc05.zip
96.73 KB
330 downloads
filedropkartero.git-cde49c6.tar.bz2
84.26 KB
360 downloads
filedropkartero.git-cde49c6.zip
96.59 KB
334 downloads
filedropkartero.git-1d004e0.tar.bz2
77.42 KB
362 downloads
filedropkartero.git-1d004e0.zip
87.56 KB
986 downloads
filedropkartero.git-1f0bf17.tar.bz2
77.47 KB
357 downloads
filedropkartero.git-1f0bf17.zip
87.56 KB
328 downloads
filedropkartero.git-265e63c.tar.bz2
77.43 KB
338 downloads
filedropkartero.git-265e63c.zip
87.52 KB
363 downloads
filedropkartero.git-635a5db.zip
87.60 KB
331 downloads
filedropkartero.git-a041f85.tar.bz2
77.37 KB
363 downloads
filedropkartero.git-a041f85.zip
87.52 KB
361 downloads
filedropkartero.git-ae049a7.tar.bz2
77.44 KB
359 downloads
filedropkartero.git-ae049a7.zip
87.52 KB
332 downloads
filedropkartero.git-eef571a.tar.bz2
20.56 KB
470 downloads
filedropkartero.git-eef571a.zip
25.69 KB
461 downloads
filedropkartero.git-0bc16f5.tar.bz2
82.61 KB
375 downloads
filedropkartero.git-0bc16f5.zip
94.75 KB
368 downloads
filedropkartero.git-2afc0f7.tar.bz2
83.61 KB
378 downloads
filedropkartero.git-2afc0f7.zip
96.00 KB
385 downloads
filedropkartero.git-3529bdf.tar.bz2
77.72 KB
343 downloads
filedropkartero.git-3529bdf.zip
87.92 KB
361 downloads
filedropkartero.git-49aac92.tar.bz2
78.98 KB
388 downloads
filedropkartero.git-49aac92.zip
90.01 KB
363 downloads
filedropkartero.git-5d48f21.tar.bz2
78.65 KB
61 downloads
filedropkartero.git-5d48f21.zip
89.51 KB
393 downloads
filedropkartero.git-635a5db.tar.bz2
77.50 KB
398 downloads
filedropkartero.git-6e34786.tar.bz2
77.76 KB
408 downloads
filedropkartero.git-6e34786.zip
88.09 KB
405 downloads
filedropkartero.git-7dc2fd2.tar.bz2
83.51 KB
457 downloads
filedropkartero.git-7dc2fd2.zip
95.99 KB
411 downloads
filedropkartero.git-9cad005.tar.bz2
78.85 KB
454 downloads
filedropkartero.git-9cad005.zip
90.00 KB
452 downloads
filedropkartero.git-b303f61.tar.bz2
82.57 KB
489 downloads
filedropkartero.git-b303f61.zip
94.78 KB
128 downloads
filedropkartero.git-c15ef85.tar.bz2
77.76 KB
143 downloads
filedropkartero.git-c15ef85.zip
88.16 KB
145 downloads
filedropkartero.git-c99e84d.tar.bz2
83.58 KB
165 downloads
filedropkartero.git-c99e84d.zip
96.01 KB
159 downloads
filedropkartero.git-e5009e6.tar.bz2
78.73 KB
173 downloads
filedropkartero.git-e5009e6.zip
89.69 KB
171 downloads
filedropkartero.git-0502d01.tar.bz2
83.54 KB
188 downloads
filedropkartero.git-0502d01.zip
96.00 KB
184 downloads
filedropkartero.git-44ca46d.tar.bz2
83.73 KB
201 downloads
filedropkartero.git-44ca46d.zip
96.20 KB
193 downloads
filedropkartero.git-834f923.tar.bz2
83.75 KB
206 downloads
filedropkartero.git-834f923.zip
96.14 KB
201 downloads