kartero.org

kartero.org

Git

This commit has been accessed 692 times via Git panel.

commit ecab88ee210761f925f8d8e3c2d3d9d47f217763
tree a2e284845e97eb5293e3eeedbc854502599f7150
parent 4deda3a4e1336316ee1be9a4c7b68f0e57da49a9
author Engels Antonio <engels@majcms.org> 1332001743 +0800
committer Engels Antonio <engels@majcms.org> 1332001743 +0800

    Fix per-domain account limit

diff --git a/index.php b/index.php
index 4eca8a8..8288ba8 100644
--- a/index.php
+++ b/index.php
@@ -306,7 +306,7 @@ $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]) {
+                       if (($pm_now >= $pm_max[0]) and ($pm_max[0] != 0)) {
                                nak("{$_SESSION['logged_uid']} limit exceeded");
                        }
                        else {
diff --git a/index.php~ b/index.php~
new file mode 100644
index 0000000..4eca8a8
--- /dev/null
+++ b/index.php~
@@ -0,0 +1,1060 @@
+<?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);
+
+?>
 
filedropkartero.git-41992ae.tar.bz2 new
412.12 KB
18 downloads
filedropkartero.git-41992ae.zip
448.41 KB
9 downloads
filedropkartero.git-b404ba2.tar.bz2
411.70 KB
16 downloads
filedropkartero.git-b404ba2.zip
447.96 KB
7 downloads
filedropkartero.git-a7684d9.tar.bz2
411.72 KB
251 downloads
filedropkartero.git-a7684d9.zip
447.96 KB
345 downloads
filedropkartero.git-83512be.tar.bz2
410.26 KB
242 downloads
filedropkartero.git-83512be.zip
445.30 KB
206 downloads
filedropkartero.git-1954b25.tar.bz2
410.21 KB
236 downloads
filedropkartero.git-1954b25.zip
445.30 KB
202 downloads
filedropkartero.git-2f7c910.tar.bz2
410.25 KB
225 downloads
filedropkartero.git-2f7c910.zip
445.29 KB
188 downloads
filedropkartero.git-6317ffb.tar.bz2
410.40 KB
208 downloads
filedropkartero.git-6317ffb.zip
445.28 KB
170 downloads
filedropkartero.git-60ccd7a.tar.bz2
410.40 KB
196 downloads
filedropkartero.git-60ccd7a.zip
445.20 KB
166 downloads
filedropkartero.git-ea6f885.tar.bz2
410.47 KB
1 download
filedropkartero.git-ea6f885.zip
445.26 KB
147 downloads
filedropkartero.git-7f580e5.zip
445.17 KB
137 downloads
filedropkartero.git-7f580e5.tar.bz2
410.18 KB
154 downloads
filedropkartero.git-b9364de.tar.bz2
409.41 KB
143 downloads
filedropkartero.git-b9364de.zip
444.09 KB
394 downloads
filedropkartero.git-e9bcd78.zip
444.03 KB
375 downloads
filedropkartero.git-e9bcd78.tar.bz2
409.39 KB
411 downloads
filedropkartero.git-96c60ff.tar.bz2
407.96 KB
406 downloads
filedropkartero.git-96c60ff.zip
441.87 KB
348 downloads
filedropkartero.git-4357b59.tar.bz2
407.17 KB
397 downloads
filedropkartero.git-4357b59.zip
440.69 KB
350 downloads
filedropkartero.git-c6ff319.tar.bz2
407.28 KB
396 downloads
filedropkartero.git-c6ff319.zip
440.70 KB
331 downloads
filedropkartero.git-8b87a29.tar.bz2
407.27 KB
378 downloads
filedropkartero.git-8b87a29.zip
440.71 KB
330 downloads
filedropkartero.git-ee42942.tar.bz2
406.49 KB
337 downloads
filedropkartero.git-ee42942.zip
439.92 KB
308 downloads
filedropkartero.git-867e7e6.tar.bz2
406.75 KB
360 downloads
filedropkartero.git-867e7e6.zip
440.03 KB
311 downloads
filedropkartero.git-3f3fc02.tar.bz2
406.38 KB
354 downloads
filedropkartero.git-3f3fc02.zip
439.71 KB
335 downloads
filedropkartero.git-b6f779d.tar.bz2
406.55 KB
375 downloads
filedropkartero.git-b6f779d.zip
440.00 KB
295 downloads
filedropkartero.git-83f24b0.zip
439.12 KB
277 downloads
filedropkartero.git-52316ec.tar.bz2
406.17 KB
331 downloads
filedropkartero.git-52316ec.zip
439.18 KB
301 downloads
filedropkartero.git-83f24b0.tar.bz2
405.84 KB
325 downloads
filedropkartero.git-8a42d47.tar.bz2
405.73 KB
297 downloads
filedropkartero.git-8a42d47.zip
439.02 KB
273 downloads
filedropkartero.git-830c9cb.tar.bz2
406.08 KB
300 downloads
filedropkartero.git-830c9cb.zip
439.08 KB
271 downloads
filedropkartero.git-ebec1be.tar.bz2
406.16 KB
303 downloads
filedropkartero.git-ebec1be.zip
439.09 KB
301 downloads
filedropkartero.git-7c0b70f.tar.bz2
402.43 KB
287 downloads
filedropkartero.git-7c0b70f.zip
435.91 KB
263 downloads
filedropkartero.git-80edc03.tar.bz2
402.75 KB
301 downloads
filedropkartero.git-80edc03.zip
435.84 KB
276 downloads
filedropkartero.git-b408c23.tar.bz2
402.19 KB
294 downloads
filedropkartero.git-b408c23.zip
435.59 KB
280 downloads
filedropkartero.git-29c0e1f.tar.bz2
401.84 KB
295 downloads
filedropkartero.git-29c0e1f.zip
435.25 KB
292 downloads
filedropkartero.git-9086094.tar.bz2
401.94 KB
297 downloads
filedropkartero.git-9086094.zip
435.34 KB
293 downloads
filedropkartero.git-47ca624.tar.bz2
402.10 KB
295 downloads
filedropkartero.git-47ca624.zip
435.51 KB
260 downloads
filedropkartero.git-81314a5.zip
435.53 KB
280 downloads
filedropkartero.git-81314a5.tar.bz2
402.25 KB
291 downloads
filedropkartero.git-cae7074.zip
435.20 KB
276 downloads
filedropkartero.git-cae7074.tar.bz2
401.98 KB
307 downloads
filedropkartero.git-cc68e56.tar.bz2
402.07 KB
290 downloads
filedropkartero.git-cc68e56.zip
435.16 KB
306 downloads
filedropkartero.git-230f35d.tar.bz2
401.43 KB
275 downloads
filedropkartero.git-230f35d.zip
434.68 KB
293 downloads
filedropkartero.git-5ae58a2.tar.bz2
401.54 KB
279 downloads
filedropkartero.git-5ae58a2.zip
434.68 KB
266 downloads
filedropkartero.git-a591f4b.tar.bz2
401.76 KB
276 downloads
filedropkartero.git-a591f4b.zip
435.17 KB
274 downloads
filedropkartero.git-36876c8.tar.bz2
400.44 KB
274 downloads
filedropkartero.git-36876c8.zip
432.36 KB
296 downloads
filedropkartero.git-a34c9ed.tar.bz2
400.57 KB
298 downloads
filedropkartero.git-a34c9ed.zip
432.27 KB
287 downloads
filedropkartero.git-e828148.zip
433.58 KB
266 downloads
filedropkartero.git-e828148.tar.bz2
400.88 KB
285 downloads
filedropkartero.git-476cdda.tar.bz2
400.60 KB
317 downloads
filedropkartero.git-476cdda.zip
432.26 KB
279 downloads
filedropkartero.git-054c286.tar.bz2
98.09 KB
355 downloads
filedropkartero.git-054c286.zip
109.53 KB
338 downloads
filedropkartero.git-071b099.tar.bz2
98.76 KB
358 downloads
filedropkartero.git-071b099.zip
110.21 KB
338 downloads
filedropkartero.git-551c38d.tar.bz2
98.51 KB
363 downloads
filedropkartero.git-551c38d.zip
110.20 KB
330 downloads
filedropkartero.git-569dc0c.tar.bz2
98.40 KB
359 downloads
filedropkartero.git-569dc0c.zip
109.86 KB
322 downloads
filedropkartero.git-58a052b.tar.bz2
97.95 KB
356 downloads
filedropkartero.git-58a052b.zip
109.36 KB
334 downloads
filedropkartero.git-43a5af3.tar.bz2
97.80 KB
352 downloads
filedropkartero.git-43a5af3.zip
109.30 KB
332 downloads
filedropkartero.git-bbe069d.tar.bz2
98.03 KB
365 downloads
filedropkartero.git-bbe069d.zip
109.19 KB
336 downloads
filedropkartero.git-02f97e1.tar.bz2
97.76 KB
331 downloads
filedropkartero.git-02f97e1.zip
109.24 KB
428 downloads
filedropkartero.git-d82e393.tar.bz2
97.74 KB
364 downloads
filedropkartero.git-d82e393.zip
109.24 KB
337 downloads
filedropkartero.git-7cdd1f5.tar.bz2
98.03 KB
347 downloads
filedropkartero.git-7cdd1f5.zip
109.24 KB
318 downloads
filedropkartero.git-40825aa.tar.bz2
97.71 KB
347 downloads
filedropkartero.git-40825aa.zip
109.16 KB
355 downloads
filedropkartero.git-3dd941b.tar.bz2
97.69 KB
345 downloads
filedropkartero.git-3dd941b.zip
109.12 KB
329 downloads
filedropkartero.git-50f1e46.tar.bz2
97.65 KB
355 downloads
filedropkartero.git-50f1e46.zip
109.02 KB
332 downloads
filedropkartero.git-fdf9225.tar.bz2
93.19 KB
386 downloads
filedropkartero.git-fdf9225.zip
104.25 KB
342 downloads
filedropkartero.git-21415da.tar.bz2
93.24 KB
342 downloads
filedropkartero.git-21415da.zip
104.22 KB
343 downloads
filedropkartero.git-aff5e89.tar.bz2
93.17 KB
363 downloads
filedropkartero.git-aff5e89.zip
104.22 KB
334 downloads
filedropkartero.git-b27ef39.tar.bz2
91.97 KB
363 downloads
filedropkartero.git-b27ef39.zip
102.80 KB
359 downloads
filedropkartero.git-3d6e8a2.tar.bz2
91.99 KB
345 downloads
filedropkartero.git-3d6e8a2.zip
102.77 KB
356 downloads
filedropkartero.git-1442b69.tar.bz2
91.79 KB
341 downloads
filedropkartero.git-1442b69.zip
102.50 KB
359 downloads
filedropkartero.git-6d15918.tar.bz2
91.56 KB
363 downloads
filedropkartero.git-6d15918.zip
102.28 KB
327 downloads
filedropkartero.git-45140d8.tar.bz2
91.52 KB
365 downloads
filedropkartero.git-45140d8.zip
102.23 KB
332 downloads
filedropkartero.git-d5b48e5.tar.bz2
91.35 KB
354 downloads
filedropkartero.git-d5b48e5.zip
102.01 KB
344 downloads
filedropkartero.git-e007e55.tar.bz2
91.35 KB
365 downloads
filedropkartero.git-e007e55.zip
102.01 KB
316 downloads
filedropkartero.git-30fd7e3.tar.bz2
90.87 KB
340 downloads
filedropkartero.git-30fd7e3.zip
101.44 KB
345 downloads
filedropkartero.git-421a4a7.tar.bz2
88.02 KB
81 downloads
filedropkartero.git-421a4a7.zip
97.96 KB
320 downloads
filedropkartero.git-b49b8bc.tar.bz2
88.09 KB
383 downloads
filedropkartero.git-b49b8bc.zip
97.99 KB
337 downloads
filedropkartero.git-1cc9571.tar.bz2
87.74 KB
361 downloads
filedropkartero.git-1cc9571.zip
97.70 KB
341 downloads
filedropkartero.git-159152f.tar.bz2
87.60 KB
359 downloads
filedropkartero.git-159152f.zip
97.52 KB
347 downloads
filedropkartero.git-35caaf3.tar.bz2
87.74 KB
342 downloads
filedropkartero.git-35caaf3.zip
97.57 KB
330 downloads
filedropkartero.git-3c9d305.zip
96.67 KB
333 downloads
filedropkartero.git-3c9d305.tar.bz2
86.77 KB
349 downloads
filedropkartero.git-14cb2af.tar.bz2
86.41 KB
348 downloads
filedropkartero.git-14cb2af.zip
96.13 KB
337 downloads
filedropkartero.git-e8f00cb.tar.bz2
86.46 KB
366 downloads
filedropkartero.git-e8f00cb.zip
96.21 KB
326 downloads
filedropkartero.git-bdab380.tar.bz2
86.14 KB
361 downloads
filedropkartero.git-bdab380.zip
95.79 KB
328 downloads
filedropkartero.git-48f9134.tar.bz2
85.78 KB
366 downloads
filedropkartero.git-48f9134.zip
95.48 KB
340 downloads
filedropkartero.git-adb9757.tar.bz2
85.67 KB
354 downloads
filedropkartero.git-adb9757.zip
95.37 KB
331 downloads
filedropkartero.git-1601cbd.zip
95.30 KB
343 downloads
filedropkartero.git-1601cbd.tar.bz2
85.69 KB
336 downloads
filedropkartero.git-18a5106.tar.bz2
85.72 KB
337 downloads
filedropkartero.git-18a5106.zip
95.48 KB
346 downloads
filedropkartero.git-a5b1caa.tar.bz2
85.61 KB
371 downloads
filedropkartero.git-a5b1caa.zip
95.36 KB
339 downloads
filedropkartero.git-effff82.zip
97.06 KB
352 downloads
filedropkartero.git-effff82.tar.bz2
87.13 KB
359 downloads
filedropkartero.git-b70d364.tar.bz2
84.09 KB
397 downloads
filedropkartero.git-b70d364.zip
93.67 KB
345 downloads
filedropkartero.git-48f0e53.tar.bz2
84.16 KB
372 downloads
filedropkartero.git-48f0e53.zip
93.66 KB
339 downloads
filedropkartero.git-c17135e.tar.bz2
84.09 KB
353 downloads
filedropkartero.git-c17135e.zip
93.57 KB
325 downloads
filedropkartero.git-a2e2848.tar.bz2
85.59 KB
356 downloads
filedropkartero.git-a2e2848.zip
100.10 KB
338 downloads
filedropkartero.git-1f683db.tar.bz2
83.55 KB
357 downloads
filedropkartero.git-1f683db.zip
93.24 KB
334 downloads
filedropkartero.git-d342596.tar.bz2
83.57 KB
357 downloads
filedropkartero.git-d342596.zip
93.28 KB
325 downloads
filedropkartero.git-e0131d5.tar.bz2
83.55 KB
358 downloads
filedropkartero.git-e0131d5.zip
93.27 KB
342 downloads
filedropkartero.git-ad467e8.tar.bz2
83.13 KB
367 downloads
filedropkartero.git-ad467e8.zip
92.78 KB
331 downloads
filedropkartero.git-b20e27d.tar.bz2
83.46 KB
372 downloads
filedropkartero.git-b20e27d.zip
93.19 KB
357 downloads
filedropkartero.git-eefd8fe.zip
92.67 KB
363 downloads
filedropkartero.git-eefd8fe.tar.bz2
83.01 KB
357 downloads
filedropkartero.git-bea685a.zip
96.88 KB
338 downloads
filedropkartero.git-bea685a.tar.bz2
84.44 KB
351 downloads
filedropkartero.git-a8bd019.tar.bz2
84.25 KB
367 downloads
filedropkartero.git-a8bd019.zip
96.60 KB
333 downloads
filedropkartero.git-cbc914d.tar.bz2
84.38 KB
360 downloads
filedropkartero.git-cbc914d.zip
96.64 KB
322 downloads
filedropkartero.git-09a2e70.tar.bz2
84.40 KB
339 downloads
filedropkartero.git-09a2e70.zip
96.70 KB
346 downloads
filedropkartero.git-641dc05.tar.bz2
84.37 KB
359 downloads
filedropkartero.git-641dc05.zip
96.73 KB
334 downloads
filedropkartero.git-cde49c6.tar.bz2
84.26 KB
368 downloads
filedropkartero.git-cde49c6.zip
96.59 KB
337 downloads
filedropkartero.git-1d004e0.tar.bz2
77.42 KB
368 downloads
filedropkartero.git-1d004e0.zip
87.56 KB
1 download
filedropkartero.git-1f0bf17.tar.bz2
77.47 KB
366 downloads
filedropkartero.git-1f0bf17.zip
87.56 KB
333 downloads
filedropkartero.git-265e63c.tar.bz2
77.43 KB
348 downloads
filedropkartero.git-265e63c.zip
87.52 KB
366 downloads
filedropkartero.git-635a5db.zip
87.60 KB
335 downloads
filedropkartero.git-a041f85.tar.bz2
77.37 KB
369 downloads
filedropkartero.git-a041f85.zip
87.52 KB
365 downloads
filedropkartero.git-ae049a7.tar.bz2
77.44 KB
368 downloads
filedropkartero.git-ae049a7.zip
87.52 KB
335 downloads
filedropkartero.git-eef571a.tar.bz2
20.56 KB
480 downloads
filedropkartero.git-eef571a.zip
25.69 KB
465 downloads
filedropkartero.git-0bc16f5.tar.bz2
82.61 KB
387 downloads
filedropkartero.git-0bc16f5.zip
94.75 KB
372 downloads
filedropkartero.git-2afc0f7.tar.bz2
83.61 KB
386 downloads
filedropkartero.git-2afc0f7.zip
96.00 KB
389 downloads
filedropkartero.git-3529bdf.tar.bz2
77.72 KB
353 downloads
filedropkartero.git-3529bdf.zip
87.92 KB
366 downloads
filedropkartero.git-49aac92.tar.bz2
78.98 KB
398 downloads
filedropkartero.git-49aac92.zip
90.01 KB
368 downloads
filedropkartero.git-5d48f21.tar.bz2
78.65 KB
1 download
filedropkartero.git-5d48f21.zip
89.51 KB
397 downloads
filedropkartero.git-635a5db.tar.bz2
77.50 KB
410 downloads
filedropkartero.git-6e34786.tar.bz2
77.76 KB
420 downloads
filedropkartero.git-6e34786.zip
88.09 KB
410 downloads
filedropkartero.git-7dc2fd2.tar.bz2
83.51 KB
467 downloads
filedropkartero.git-7dc2fd2.zip
95.99 KB
416 downloads
filedropkartero.git-9cad005.tar.bz2
78.85 KB
462 downloads
filedropkartero.git-9cad005.zip
90.00 KB
457 downloads
filedropkartero.git-b303f61.tar.bz2
82.57 KB
500 downloads
filedropkartero.git-b303f61.zip
94.78 KB
132 downloads
filedropkartero.git-c15ef85.tar.bz2
77.76 KB
155 downloads
filedropkartero.git-c15ef85.zip
88.16 KB
153 downloads
filedropkartero.git-c99e84d.tar.bz2
83.58 KB
178 downloads
filedropkartero.git-c99e84d.zip
96.01 KB
167 downloads
filedropkartero.git-e5009e6.tar.bz2
78.73 KB
187 downloads
filedropkartero.git-e5009e6.zip
89.69 KB
181 downloads
filedropkartero.git-0502d01.tar.bz2
83.54 KB
202 downloads
filedropkartero.git-0502d01.zip
96.00 KB
192 downloads
filedropkartero.git-44ca46d.tar.bz2
83.73 KB
215 downloads
filedropkartero.git-44ca46d.zip
96.20 KB
201 downloads
filedropkartero.git-834f923.tar.bz2
83.75 KB
219 downloads
filedropkartero.git-834f923.zip
96.14 KB
211 downloads