kartero.org

kartero.org

Git

This blob has been accessed 494 times via Git panel.

  1. <?php
  2.  
  3. /* modify the values of $db_host, $db_name, $db_user, $db_pass, and $mail_root for basic configuration */
  4.  
  5. $db_host = "localhost";
  6. $db_name = "kartero";
  7. $db_user = "kartero";
  8. $db_pass = "fr1ng3!";
  9.  
  10. $mail_root = "/kartero/mail";
  11. $mail_home = "/kartero/home";
  12.  
  13. /* feel free to hack the succeeding code to suit your needs (basic php and mysql skills required) */
  14.  
  15. require_once("core.php");
  16.  
  17. function rmdirr($recurse_dirname) {
  18.  
  19.         if (!file_exists($recurse_dirname)) {
  20.                 return false;
  21.         }
  22.  
  23.         if (is_file($recurse_dirname)) {
  24.                 return unlink($recurse_dirname);
  25.         }
  26.  
  27.         $recurse_dir = dir($recurse_dirname);
  28.  
  29.         while (false !== $recurse_entry = $recurse_dir->read()) {
  30.  
  31.                 if ($recurse_entry == '.' || $recurse_entry == '..') {
  32.                         continue;
  33.                 }
  34.  
  35.                 rmdirr("$recurse_dirname/$recurse_entry");
  36.         }
  37.  
  38.         $recurse_dir->close();
  39.         return rmdir($recurse_dirname);
  40. }
  41.  
  42. function ack($ack_string) {
  43.         echo "<table width=\"100%\"><tr></td><div class=\"ack\">$ack_string</div></td></tr></table>";
  44. }
  45.  
  46. function nak($nak_string) {
  47.         echo "<table width=\"100%\"><tr></td><div class=\"nak\">$nak_string</div></td></tr></table>";
  48. }
  49.  
  50. if (file_exists("css.php")) {
  51.  
  52.         $css = file_get_contents("css.php");
  53.         $css = str_replace("<style>","",$css);
  54.         $css = str_replace("</style>","",$css);
  55.  
  56.         echo "<style>\r\n$css</style>\r\n\r\n";
  57. }
  58.  
  59. if (!file_exists("$mail_root")) {
  60.  
  61.         $mail_dirs = explode("/",$mail_root);
  62.  
  63.         foreach ($mail_dirs as $mail_dir) {
  64.        
  65.                 if (!empty($mail_dir)) {
  66.                         $mail_mkdir = $mail_mkdir . "/" . $mail_dir;
  67.                         mkdir("$mail_mkdir");
  68.                 }
  69.         }
  70.  
  71.         if (!file_exists("$mail_root")) {
  72.                 nak("Can't create '$mail_root' (check filesystem permissions or change '&#36;mail_root' and try again)");
  73.                 exit();
  74.         }
  75. }
  76.  
  77. $db_link = mysql_pconnect($db_host, $db_user, $db_pass);
  78.  
  79. if (!$db_link) {
  80.         nak(mysql_error());
  81.         exit;
  82. }
  83.  
  84. $db_query = mysql_query("use $db_name");
  85.  
  86. if (!$db_query) {
  87.         $pw_crypt = crypt($db_pass);
  88.         $db_query = mysql_query("create database $db_name");
  89.         $db_query = mysql_query("use $db_name");
  90.         $db_query = mysql_query("create table admins (id varchar(16) not null, pw varchar(64) not null, primary key (id), unique key (id))");
  91.         $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))");
  92.         $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))");
  93.         $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))");
  94.         $db_query = mysql_query("insert into admins values('$db_user','$pw_crypt')");
  95. }
  96.  
  97. $id_put = strip_tags($_POST['id']);
  98. $id_put = trim($id_put);
  99. $id_put = strtolower($id_put);
  100.  
  101. if (get_magic_quotes_gpc()) {
  102.         $id_put = stripslashes($id_put);
  103. }
  104.  
  105. if (!is_int($id_put)) {
  106.         $id_put = mysql_real_escape_string($id_put);
  107. }
  108.  
  109. $lvl_put = strip_tags($_POST['lvl']);
  110.  
  111. if ($lvl_put == "subscriber") {
  112.         $pw_get = mysql_query("select pw from users where id='$id_put'");
  113. }
  114.  
  115. if ($lvl_put == "postmaster") {
  116.         $pw_get = mysql_query("select pw from domains where id='$id_put'");
  117. }
  118.  
  119. if ($lvl_put == "administrator") {
  120.         $pw_get = mysql_query("select pw from admins where id='$id_put'");
  121. }
  122.  
  123. $pw_get = mysql_fetch_row($pw_get);
  124. $pw_get = $pw_get[0];
  125.  
  126. $pw_put = $_POST['pw'];
  127.  
  128. if (get_magic_quotes_gpc()) {
  129.         $pw_put = stripslashes($pw_put);
  130. }
  131.  
  132. if (!is_int($pw_put)) {
  133.         $pw_put = mysql_real_escape_string($pw_put);
  134. }
  135.  
  136. $pw_put = strip_tags($pw_put);
  137.  
  138. $pw_mbox = $pw_put;
  139.  
  140. $pw_put = crypt($pw_put,$pw_get);
  141.  
  142. if ($pw_put == $pw_get) {
  143.         $_SESSION['logged_uid'] = $id_put;
  144.         $_SESSION['logged_lvl'] = $lvl_put;
  145.  
  146.         if ($_SESSION['logged_lvl'] == "subscriber") {
  147.                 $_SESSION['logged_key'] = $pw_mbox;
  148.         }
  149. }
  150.  
  151. unset($pw_mbox);
  152.  
  153. if ($_SESSION['logged_lvl'] == "subscriber") {
  154.  
  155.         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']))) {
  156.  
  157.                 rmdirr("attach/i/$fileUsr/{$_SESSION['clean_up_i']}");
  158.                 unset($_SESSION['clean_up_i']);
  159.  
  160.                 if (count(glob("attach/i/$fileUsr/*")) == 0) {
  161.                         rmdirr("attach/i/$fileUsr");
  162.                 }
  163.         }
  164.  
  165.         if (isset($_SESSION['clean_up_o']) and file_exists("attach/o/$fileUsr/{$_SESSION['clean_up_o']}")) {
  166.                        
  167.                 rmdirr("attach/o/$fileUsr/{$_SESSION['clean_up_o']}");
  168.                 unset($_SESSION['clean_up_o']);
  169.  
  170.                 if (count(glob("attach/o/$fileUsr/*")) == 0) {
  171.                         rmdirr("attach/o/$fileUsr");
  172.                 }
  173.         }
  174. }
  175.  
  176. if (isset($_GET['do']) and ($_GET['do'] == "logout")) {
  177.  
  178.         if ($mbox) {
  179.                 imap_close($mbox, CL_EXPUNGE);
  180.         }
  181.  
  182.         $_SESSION = array();
  183.         session_destroy();
  184.         header("Location: .");
  185.         exit;
  186. }
  187.  
  188. 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']))) {
  189.  
  190.         echo "<title>Kartero</title>";
  191.  
  192.         echo "<div class=\"login\"><center>";
  193.  
  194.         if (file_exists("images/{$_SERVER['SERVER_NAME']}.png")) {
  195.  
  196.                 $logo_info = getimagesize("images/{$_SERVER['SERVER_NAME']}.png");
  197.  
  198.                 if (($logo_info[mime] == "image/png") and ($logo_info[0] > 0) and ($logo_info[1] > 0)) {
  199.                         echo "<img src=\"images/{$_SERVER['SERVER_NAME']}.png\" border=\"0\" width=\"{$logo_info[0]}\" height=\"{$logo_info[1]}\">";
  200.                 }
  201.                 else {
  202.                         echo "<img src=\"images/logo.png\" border=\"0\" width=\"100\" height=\"100\">";
  203.                 }
  204.         }
  205.         else {
  206.                 echo "<img src=\"images/logo.png\" border=\"0\" width=\"100\" height=\"100\">";
  207.         }
  208.  
  209.         echo "<br>kartero v1.0 at {$_SERVER['SERVER_NAME']}<br><br>";
  210.  
  211.         echo "<table border=\"0\" cellspacing=\"1\" cellpadding=\"2\" bgcolor=\"#cccccc\">";
  212.         echo "<form method=\"post\">";
  213.         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>";
  214.         echo "<tr bgcolor=\"#ffffff\"><td><input required autofocus class=\"input\" type=\"text\" name=\"id\" autocomplete=\"off\" maxlength=\"128\"></td></tr>";
  215.         echo "<tr bgcolor=\"#ffffff\"><td><input required class=\"input\" type=\"password\" name=\"pw\" autocomplete=\"off\" maxlength=\"64\"></td></tr>";
  216.         echo "<tr bgcolor=\"#ffffff\"><td><input class=\"button\" type=\"submit\" value=\"login\"></td></tr>";
  217.         echo "</form>";
  218.         echo "</table>";
  219.  
  220.         echo "</center></div>";
  221.  
  222.         echo "<iframe name=\"preload\" src=\"preload.php\" frameborder=\"0\" scrolling=\"0\" width=\"0\" height=\"0\"></iframe>";
  223.  
  224.         exit;
  225. }
  226.  
  227. if (isset($_SESSION['logged_uid'])) {
  228.  
  229.         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>";
  230.  
  231.         echo "<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">";
  232.         echo "<tr><td colspan=\"3\" valign=\"top\">";
  233.  
  234.         if ($_SESSION['logged_lvl'] == "subscriber") {
  235.  
  236.                 $usr_query = mysql_query("select * from users where id='{$_SESSION['logged_uid']}'");
  237.                 $usr_data = mysql_fetch_row($usr_query);
  238.  
  239.                 $dom_query = mysql_query("select mode from domains where id='{$usr_data[4]}'");
  240.                 $dom_data = mysql_fetch_row($dom_query);
  241.  
  242.                 if ($dom_data[0] == 0) {
  243.                         nak("{$usr_data[4]} disabled by admin");
  244.                         exit();
  245.                 }
  246.  
  247.                 if ($usr_data[5] == 0) {
  248.                         nak("{$_SESSION['logged_uid']} disabled by postmaster");
  249.                         exit();
  250.                 }
  251.        
  252.                 $usr_name = $usr_data[3];
  253.        
  254.                 if (isset($_POST['usr_name']) and !empty($_POST['usr_name']) and (strlen($_POST['usr_name']) <= 128) and (strlen($_POST['usr_name']) > 2)) {
  255.        
  256.                         $usr_name = trim($_POST['usr_name']);
  257.                         $usr_name = ucwords($usr_name);
  258.        
  259.                         if ($usr_name != $usr_data[3]) {
  260.        
  261.                                 $usr_query = mysql_query("update users set name='$usr_name' where id='{$_SESSION['logged_uid']}'");
  262.        
  263.                                 if (!usr_query) {
  264.                                         nak(strtolower(mysql_error()));
  265.                                 }
  266.                                 else {
  267.                                         ack("name changed");
  268.                                 }
  269.                         }
  270.                         else {
  271.                                 $usr_name = $usr_data[3];
  272.                         }
  273.                 }
  274.        
  275.                 $usr_pw0 = $usr_data[1];
  276.        
  277.                 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']) and (strlen($_POST['usr_pw2']) <= 64) and (strlen($_POST['usr_pw3']) <= 64) and (strlen($_POST['usr_pw2']) >= 8) and (strlen($_POST['usr_pw3']) >= 8)) {
  278.        
  279.                         $usr_pw1 = trim($_POST['usr_pw1']);
  280.                         $usr_pw2 = trim($_POST['usr_pw2']);
  281.                         $usr_pw3 = trim($_POST['usr_pw3']);
  282.        
  283.                         if ($usr_pw0 == crypt($usr_pw1,$usr_pw0)) {
  284.        
  285.                                 if ($usr_pw2 == $usr_pw3) {
  286.                                        
  287.                                         $usr_pw = crypt($usr_pw2);
  288.        
  289.                                         $usr_query = mysql_query("update users set pw='$usr_pw' where id='{$_SESSION['logged_uid']}'");
  290.        
  291.                                         if (!usr_query) {
  292.                                                 nak(strtolower(mysql_error()));
  293.                                         }
  294.                                         else {
  295.                                                 ack("password changed");
  296.                                                 $_SESSION['logged_key'] = $usr_pw2;
  297.                                         }
  298.                                 }
  299.                                 else {
  300.                                         nak("new passwords do not match");
  301.                                 }
  302.                         }
  303.                         else {
  304.                                 nak("current password entered is incorrect");
  305.                         }
  306.                 }
  307.         }
  308.  
  309.         if ($_SESSION['logged_lvl'] == "postmaster") {
  310.        
  311.                 $dom_query = mysql_query("select mode from domains where id='{$_SESSION['logged_uid']}'");
  312.                 $dom_query = mysql_fetch_row($dom_query);
  313.        
  314.                 if ($dom_query[0] == "0") {
  315.                         nak("{$_SESSION['logged_uid']} disabled by admin - new settings will take effect once it is re-enabled");
  316.                 }
  317.  
  318.                 $max_get = mysql_query("select max from domains where id='{$_SESSION['logged_uid']}'");
  319.  
  320.                 $pm_max = mysql_fetch_row($max_get);
  321.  
  322.                 $pm_get = mysql_query("select * from users where domain='{$_SESSION['logged_uid']}' order by id");
  323.  
  324.                 $pm_now = mysql_num_rows($pm_get);
  325.  
  326.                 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'])) {
  327.  
  328.                         if (($pm_now >= $pm_max[0]) and ($pm_max[0] != 0)) {
  329.                                 nak("{$_SESSION['logged_uid']} limit exceeded");
  330.                         }
  331.                         else {
  332.                                 $pm_id = trim($_POST['pm_id']);
  333.                                 $pm_id = strtolower($pm_id);
  334.                
  335.                                 if (preg_match("/@/",$pm_id)) {
  336.                                         $pm_id = substr($pm_id,0,strpos($pm_id,"@"));
  337.                                 }
  338.                
  339.                                 $pm_addr = $pm_id . "@" . $_SESSION['logged_uid'];
  340.                
  341.                                 $alias_query = mysql_query("select id from aliases where id='$pm_addr'");
  342.                
  343.                                 if (mysql_fetch_row($alias_query) > 0) {
  344.                                         nak("$pm_addr alias exists");
  345.                                 }
  346.                                 else {
  347.                                         $pm_name = trim($_POST['pm_name']);
  348.                                         $pm_name = ucwords($pm_name);
  349.                
  350.                                         $pm_pw = trim($_POST['pm_pw']);
  351.                                         $pm_pw = crypt($pm_pw);
  352.                
  353.                                         $pm_init = substr($pm_id,0,1);
  354.                
  355.                                         $pm_maildir = "{$_SESSION['logged_uid']}/$pm_init/$pm_id";
  356.        
  357.                                         $pm_host = trim($_POST['pm_host']);
  358.                                         $pm_host = strtolower($pm_host);
  359.                
  360.                                         $pm_query = mysql_query("insert into users values('$pm_addr','$pm_pw','$pm_maildir/','$pm_name','{$_SESSION['logged_uid']}','1','$pm_host')");
  361.                
  362.                                         if (!$pm_query) {
  363.                                                 nak(strtolower(mysql_error()));
  364.                                         }
  365.                                         else {
  366.                                                 if (!file_exists("$mail_root/{$_SESSION['logged_uid']}")) {
  367.                                                         mkdir("$mail_root/{$_SESSION['logged_uid']}");
  368.                                                 }
  369.                
  370.                                                 if (!file_exists("$mail_root/{$_SESSION['logged_uid']}/$pm_init")) {
  371.                                                         mkdir("$mail_root/{$_SESSION['logged_uid']}/$pm_init");
  372.                                                 }
  373.                
  374.                                                 if (!file_exists("$mail_root/$pm_maildir")) {
  375.                                                         mkdir("$mail_root/$pm_maildir");
  376.                                                 }
  377.                
  378.                                                 if (!file_exists("$mail_root/$pm_maildir/cur")) {
  379.                                                         mkdir("$mail_root/$pm_maildir/cur");
  380.                                                 }
  381.                        
  382.                                                 if (!file_exists("$mail_root/$pm_maildir/new")) {
  383.                                                         mkdir("$mail_root/$pm_maildir/new");
  384.                                                 }
  385.                
  386.                                                 if (!file_exists("$mail_root/$pm_maildir/tmp")) {
  387.                                                         mkdir("$mail_root/$pm_maildir/tmp");
  388.                                                 }
  389.                
  390.                                                 ack("$pm_addr added");
  391.                                         }
  392.                                 }
  393.                         }
  394.                 }
  395.  
  396.                 if (isset($_POST['pm_mod']) and !empty($_POST['pm_mod'])) {
  397.                        
  398.                         $pm_mod = trim($_POST['pm_mod']);
  399.        
  400.                         if (isset($_POST['pm_name']) and !empty($_POST['pm_name'])) {
  401.        
  402.                                 $pm_name = trim($_POST['pm_name']);
  403.                                 $pm_name = ucwords($pm_name);
  404.        
  405.                                 $pm_query = mysql_query("select name from users where id='$pm_mod'");
  406.        
  407.                                 $name_get = mysql_fetch_row($pm_query);
  408.        
  409.                                 if ($name_get[0] != $pm_name) {
  410.        
  411.                                         $pm_query = mysql_query("update users set name='$pm_name' where id='$pm_mod'");
  412.        
  413.                                         if (!$pm_query) {
  414.                                                 nak(strtolower(mysql_error()));
  415.                                         }
  416.                                         else {
  417.                                                 ack("$pm_mod complete name updated");
  418.                                         }
  419.                                 }
  420.                         }
  421.        
  422.                         if (isset($_POST['pm_pass']) and !empty($_POST['pm_pass'])) {
  423.        
  424.                                 $pm_pass = $_POST['pm_pass'];
  425.                                 $pm_pass = crypt($pm_pass);
  426.        
  427.                                 $pm_query = mysql_query("update users set pw='$pm_pass' where id='$pm_mod'");
  428.        
  429.                                 if (!$pm_query) {
  430.                                         nak(strtolower(mysql_error()));
  431.                                 }
  432.                                 else {
  433.                                         ack("$pm_mod password updated");
  434.                                 }
  435.                         }
  436.  
  437.                         if (isset($_POST['pm_host'])) {
  438.        
  439.                                 $pm_host = trim($_POST['pm_host']);
  440.                                 $pm_host = strtolower($pm_host);
  441.        
  442.                                 $pm_query = mysql_query("select host from users where id='$pm_mod'");
  443.        
  444.                                 $host_get = mysql_fetch_row($pm_query);
  445.        
  446.                                 if ($host_get[0] != $pm_host) {
  447.        
  448.                                         $pm_query = mysql_query("update users set host='$pm_host' where id='$pm_mod'");
  449.        
  450.                                         if (!$pm_query) {
  451.                                                 nak(strtolower(mysql_error()));
  452.                                         }
  453.                                         else {
  454.                                                 ack("$pm_mod delivery host updated");
  455.                                         }
  456.                                 }
  457.                         }
  458.                 }
  459.        
  460.                 if (isset($_POST['pm_set']) and !empty($_POST['pm_set']) and isset($_POST['pm_do']) and !empty($_POST['pm_do'])) {
  461.        
  462.                         $pm_set = trim($_POST['pm_set']);
  463.                         $pm_do = trim($_POST['pm_do']);
  464.        
  465.                         if ($pm_do == "disable") {
  466.                                 $pm_do = "0";
  467.                         }
  468.        
  469.                         if ($pm_do == "enable") {
  470.                                 $pm_do = "1";
  471.                         }
  472.                
  473.                         $pm_query = mysql_query("update aliases set mode='$pm_do' where alias='$pm_set'");
  474.                         $pm_query = mysql_query("update users set mode='$pm_do' where id='$pm_set'");
  475.        
  476.                         if (!$pm_query) {
  477.                                 nak(strtolower(mysql_error()));
  478.                         }
  479.                         else {
  480.        
  481.                                 $pm_query = mysql_query("select alias from aliases where alias='$pm_set'");
  482.                                 $pm_aka = mysql_num_rows($pm_query);
  483.        
  484.                                 if ($pm_do == "0") {
  485.        
  486.                                         if ($pm_aka > 0) {
  487.        
  488.                                                 if ($pm_aka < 2) {
  489.                                                         ack("$pm_set account and 1 alias disabled");
  490.                                                 }
  491.                                                 else {
  492.                                                         ack("$pm_set account and $pm_aka aliases disabled");
  493.                                                 }
  494.                                         }
  495.                                         else {
  496.                                                 ack("$pm_set account disabled");
  497.                                         }
  498.                                 }
  499.        
  500.                                 if ($pm_do == "1") {
  501.        
  502.                                         if (mysql_fetch_row($pm_query) > 0) {
  503.        
  504.                                                 if ($pm_aka < 2) {
  505.                                                         ack("$pm_set account and 1 alias enabled");
  506.                                                 }
  507.                                                 else {
  508.                                                         ack("$pm_set account and $pm_aka aliases enabled");
  509.                                                 }
  510.                                         }
  511.                                         else {
  512.                                                 ack("$pm_set account enabled");
  513.                                         }
  514.                                 }
  515.                         }
  516.                 }
  517.        
  518.                 if (isset($_POST['pm_del']) and !empty($_POST['pm_del'])) {
  519.                        
  520.                         $pm_del = trim($_POST['pm_del']);
  521.        
  522.                         $pm_query = mysql_query("delete from aliases where alias='$pm_del'");
  523.                         $pm_query = mysql_query("delete from users where id='$pm_del'");
  524.        
  525.                         if (!$pm_query) {
  526.                                 nak(strtolower(mysql_error()));
  527.                         }
  528.                         else {
  529.                                 $pm_init = substr($pm_del,0,1);
  530.                                 $pm_box = substr($pm_del,0,strpos($pm_del,"@"));
  531.        
  532.                                 if (file_exists("$mail_root/{$_SESSION['logged_uid']}/$pm_init/$pm_box")) {
  533.                                         rmdirr("$mail_root/{$_SESSION['logged_uid']}/$pm_init/$pm_box");
  534.                                 }
  535.        
  536.                                 if (count(glob("$mail_root/{$_SESSION['logged_uid']}/$pm_init/*")) < 1) {
  537.                                         rmdir("$mail_root/{$_SESSION['logged_uid']}/$pm_init");
  538.                                 }
  539.        
  540.                                 ack("$pm_del deleted");
  541.                         }
  542.                 }
  543.        
  544.                 if (isset($_POST['alias_add']) and !empty($_POST['alias_add']) and isset($_POST['alias_to']) and !empty($_POST['alias_to'])) {
  545.        
  546.                         $alias_add = trim($_POST['alias_add']);
  547.        
  548.                         if (preg_match("/@/",$alias_add)) {
  549.                                 $alias_add = substr($alias_add,0,strpos($alias_add,"@"));
  550.                         }
  551.        
  552.                         $alias_add = "$alias_add@{$_SESSION['logged_uid']}";
  553.        
  554.                         $alias_to = trim($_POST['alias_to']);
  555.        
  556.                         $alias_query = mysql_query("select id from users where id='$alias_add'");
  557.        
  558.                         if (mysql_num_rows($alias_query) > 0) {
  559.                                 nak("$alias_add account exists");
  560.                         }
  561.                         else {
  562.                                 if (!preg_match("/@/",$alias_to) or preg_match("/@{$_SESSION['logged_uid']}/",$alias_to)) {
  563.        
  564.                                         if (preg_match("/@{$_SESSION['logged_uid']}/",$alias_to)) {
  565.                                                 $alias_to = substr($alias_to,0,strpos($alias_to,"@"));
  566.                                         }
  567.                
  568.                                         $alias_to = "$alias_to@{$_SESSION['logged_uid']}";
  569.                
  570.                                         $alias_query = mysql_query("select id from users where id='$alias_to'");
  571.                
  572.                                         if (mysql_num_rows($alias_query) < 1) {
  573.                                                 nak("$alias_to does not exist");
  574.                                         }
  575.                                         else {
  576.                                                 $alias_query = mysql_query("insert into aliases values('$alias_add','$alias_to','{$_SESSION['logged_uid']}','1')");
  577.                
  578.                                                 if (!$alias_query) {
  579.                                                         nak(strtolower(mysql_error()));
  580.                                                 }
  581.                                                 else {
  582.                                                         ack("$alias_add added");
  583.                                                 }
  584.                                         }
  585.                                 }
  586.                                 else {
  587.                                         $alias_query = mysql_query("insert into aliases values('$alias_add','$alias_to','{$_SESSION['logged_uid']}','1')");
  588.        
  589.                                         if (!$alias_query) {
  590.                                                 nak(strtolower(mysql_error()));
  591.                                         }
  592.                                         else {
  593.                                                 ack("$alias_add added");
  594.                                         }
  595.                                 }
  596.                         }
  597.                 }
  598.        
  599.                 if (isset($_POST['alias_mod']) and !empty($_POST['alias_mod']) and isset($_POST['alias_to']) and !empty($_POST['alias_to'])) {
  600.                        
  601.                         $alias_mod = trim($_POST['alias_mod']);
  602.        
  603.                         $alias_to = trim($_POST['alias_to']);
  604.        
  605.                         if (!preg_match("/@/",$alias_to) or preg_match("/@{$_SESSION['logged_uid']}/",$alias_to)) {
  606.        
  607.                                 if (preg_match("/@{$_SESSION['logged_uid']}/",$alias_to)) {
  608.                                         $alias_to = substr($alias_to,0,strpos($alias_to,"@"));
  609.                                 }
  610.        
  611.                                 $alias_to = "$alias_to@{$_SESSION['logged_uid']}";
  612.        
  613.                                 $alias_query = mysql_query("select id from users where id='$alias_to'");
  614.        
  615.                                 if (mysql_num_rows($alias_query) < 1) {
  616.                                         nak("$alias_to does not exist");
  617.                                 }
  618.                                 else {
  619.                                         $alias_query = mysql_query("update aliases set alias='$alias_to' where id='$alias_mod'");
  620.        
  621.                                         if (!$alias_query) {
  622.                                                 nak(strtolower(mysql_error()));
  623.                                         }
  624.                                         else {
  625.                                                 ack("$alias_mod updated");
  626.                                         }
  627.                                 }
  628.                         }
  629.                         else {
  630.        
  631.                                 $alias_query = mysql_query("update aliases set alias='$alias_to' where id='$alias_mod'");
  632.                
  633.                                 if (!$alias_query) {
  634.                                         nak(strtolower(mysql_error()));
  635.                                 }
  636.                                 else {
  637.                                         ack("$alias_mod updated");
  638.                                 }
  639.                         }
  640.                 }
  641.        
  642.                 if (isset($_POST['alias_set']) and !empty($_POST['alias_set']) and isset($_POST['alias_do']) and !empty($_POST['alias_do'])) {
  643.        
  644.                         $alias_set = trim($_POST['alias_set']);
  645.                         $alias_do = trim($_POST['alias_do']);
  646.        
  647.                         if ($alias_do == "disable") {
  648.                                 $alias_do = "0";
  649.                                 $alias_query = mysql_query("update aliases set mode='$alias_do' where id='$alias_set'");
  650.        
  651.                                 if (!$alias_query) {
  652.                                         nak(strtolower(mysql_error()));
  653.                                 }
  654.                                 else {
  655.                                         ack("$alias_set alias disabled");
  656.                                 }
  657.                         }
  658.        
  659.                         if ($alias_do == "enable") {
  660.        
  661.                                 $alias_query = mysql_query("select alias from aliases where id='$alias_set'");
  662.                                 $alias_recipient = mysql_fetch_row($alias_query);
  663.                                 $alias_recipient = $alias_recipient[0];
  664.        
  665.                                 $usr_query = mysql_query("select mode from users where id='$alias_recipient'");
  666.                                 $alias_recipient_mode = mysql_fetch_row($usr_query);
  667.                                 $alias_recipient_mode = $alias_recipient_mode[0];
  668.        
  669.                                 if ($alias_recipient_mode == "0") {
  670.                                         nak("cannot enable $alias_set alias while $alias_recipient recipient account is disabled");
  671.                                 }
  672.                                 else {
  673.                                         $alias_do = "1";
  674.                                         $alias_query = mysql_query("update aliases set mode='$alias_do' where id='$alias_set'");
  675.                
  676.                                         if (!$alias_query) {
  677.                                                 nak(strtolower(mysql_error()));
  678.                                         }
  679.                                         else {
  680.                                                 ack("$alias_set alias enabled");
  681.                                         }
  682.                                 }
  683.                         }
  684.                 }
  685.        
  686.                 if (isset($_POST['alias_del']) and !empty($_POST['alias_del'])) {
  687.                        
  688.                         $alias_del = trim($_POST['alias_del']);
  689.                         $alias_query = mysql_query("delete from aliases where id='$alias_del'");
  690.        
  691.                         if (!$alias_query) {
  692.                                 nak(strtolower(mysql_error()));
  693.                         }
  694.                         else {
  695.                                 ack("$alias_del deleted");
  696.                         }
  697.                 }
  698.         }
  699.        
  700.         if ($_SESSION['logged_lvl'] == "administrator") {
  701.  
  702.                 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'])) {
  703.        
  704.                         $dom_name = trim($_POST['dom_name']);
  705.        
  706.                         $dom_pass = trim($_POST['dom_pass']);
  707.                         $dom_pass = crypt($dom_pass);
  708.        
  709.                         $dom_max = trim($_POST['dom_max']);
  710.        
  711.                         $dom_query = mysql_query("insert into domains values('$dom_name','$dom_pass','$dom_max','1')");
  712.        
  713.                         if (!$dom_query) {
  714.                                 nak(strtolower(mysql_error()));
  715.                         }
  716.                         else {
  717.                                 if (!file_exists("$mail_root/$dom_name")) {
  718.                                         mkdir("$mail_root/$dom_name");
  719.                                 }
  720.        
  721.                                 ack("$dom_name added");
  722.                         }
  723.                 }
  724.        
  725.                 if (isset($_POST['dom_mod']) and !empty($_POST['dom_mod'])) {
  726.                        
  727.                         $dom_mod = trim($_POST['dom_mod']);
  728.        
  729.                         if (isset($_POST['dom_pass']) and !empty($_POST['dom_pass'])) {
  730.        
  731.                                 $dom_pass = $_POST['dom_pass'];
  732.                                 $dom_pass = crypt($dom_pass);
  733.        
  734.                                 $dom_query = mysql_query("update domains set pw='$dom_pass' where id='$dom_mod'");
  735.        
  736.                                 if (!$dom_query) {
  737.                                         nak(strtolower(mysql_error()));
  738.                                 }
  739.                                 else {
  740.                                         ack("$dom_mod postmaster password updated");
  741.                                 }
  742.                         }
  743.        
  744.                         if (isset($_POST['dom_max']) and is_numeric($_POST['dom_max'])) {
  745.        
  746.                                 $dom_max = $_POST['dom_max'];
  747.        
  748.                                 $dom_query = mysql_query("select max from domains where id='$dom_mod'");
  749.        
  750.                                 $max_get = mysql_fetch_row($dom_query);
  751.        
  752.                                 if ($max_get[0] != $dom_max) {
  753.        
  754.                                         $dom_query = mysql_query("update domains set max='$dom_max' where id='$dom_mod'");
  755.        
  756.                                         if (!$dom_query) {
  757.                                                 nak(strtolower(mysql_error()));
  758.                                         }
  759.                                         else {
  760.                                                 ack("$dom_mod account limit updated");
  761.                                         }
  762.                                 }
  763.                         }
  764.                 }
  765.        
  766.                 if (isset($_POST['dom_set']) and !empty($_POST['dom_set']) and isset($_POST['dom_do']) and !empty($_POST['dom_do'])) {
  767.        
  768.                         $dom_set = trim($_POST['dom_set']);
  769.                         $dom_do = trim($_POST['dom_do']);
  770.        
  771.                         if ($dom_do == "disable") {
  772.                                 $dom_do = "0";
  773.                         }
  774.        
  775.                         if ($dom_do == "enable") {
  776.                                 $dom_do = "1";
  777.                         }
  778.                
  779.                         $dom_query = mysql_query("update domains set mode='$dom_do' where id='$dom_set'");
  780.        
  781.                         if (!$dom_query) {
  782.                                 nak(strtolower(mysql_error()));
  783.                         }
  784.                         else {
  785.                                 if ($dom_do == "0") {
  786.                                         ack("$dom_set disabled");
  787.                                 }
  788.        
  789.                                 if ($dom_do == "1") {
  790.                                         ack("$dom_set enabled");
  791.                                 }
  792.                         }
  793.                 }
  794.        
  795.                 if (isset($_POST['dom_del']) and !empty($_POST['dom_del'])) {
  796.                        
  797.                         $dom_del = trim($_POST['dom_del']);
  798.        
  799.                         $dom_query = mysql_query("delete from aliases where domain='$dom_del'");
  800.                         $dom_query = mysql_query("delete from users where domain='$dom_del'");
  801.                         $dom_query = mysql_query("delete from domains where id='$dom_del'");
  802.        
  803.                         if (!$dom_query) {
  804.                                 nak(strtolower(mysql_error()));
  805.                         }
  806.                         else {
  807.                                 if (file_exists("$mail_root/$dom_del")) {
  808.                                         rmdirr("$mail_root/$dom_del");
  809.                                 }
  810.                                 ack("$dom_del deleted");
  811.                         }
  812.                 }
  813.         }
  814.        
  815.         echo "</td></tr>";
  816.  
  817.         echo "<tr><td valign=\"top\">";
  818.  
  819.         if ($_SESSION['logged_lvl'] == "subscriber") {
  820.  
  821.                 $filedrop_box = sha1(microtime(true));
  822.  
  823.                 $host = "{127.0.0.1:143/imap/notls/norsh}";
  824.  
  825.                 if (!isset($_POST['box']) or empty($_POST['box'])) {
  826.                         $folder = "INBOX";
  827.                 }
  828.                 else {
  829.                         $folder = trim(strip_tags($_POST['box']));
  830.                 }
  831.  
  832.                 $mbox = @imap_open("{$host}$folder", $_SESSION['logged_uid'], $_SESSION['logged_key'], CL_EXPUNGE) or die(imap_last_error());
  833.  
  834.                 if (isset($_POST['move_msg']) and !empty($_POST['move_msg']) and isset($_POST['move_box']) and !empty($_POST['move_box'])) {
  835.  
  836.                         $move_msg = trim(strip_tags($_POST['move_msg']));
  837.                         $move_box = imap_utf7_encode(ucwords(trim(preg_replace("/[^a-z0-9 ]/i","",strip_tags($_POST['move_box'])))));
  838.  
  839.                         if (($move_box != "Sent") and ($move_box != "Trash")) {
  840.                                 imap_mail_move($mbox,$move_msg,$move_box,CP_UID);
  841.                                 imap_expunge($mbox);
  842.                         }
  843.                 }
  844.  
  845.                 if (isset($_POST['new_box']) and !empty($_POST['new_box'])) {
  846.  
  847.                         $new_box = imap_utf7_encode(ucwords(trim(preg_replace("/[^a-z0-9 ]/i","",strip_tags($_POST['new_box'])))));
  848.                         imap_createmailbox($mbox,"{$host}$new_box");
  849.                 }
  850.  
  851.                 if (isset($_POST['del_box']) and !empty($_POST['del_box'])) {
  852.  
  853.                         $del_box = imap_utf7_encode(ucwords(trim(preg_replace("/[^a-z0-9 ]/i","",strip_tags($_POST['del_box'])))));
  854.                         $del_siv = $del_box;
  855.  
  856.                         if (($del_box != "INBOX") and ($del_box != "Sent") and ($del_box != "Trash")) {
  857.                                 imap_deletemailbox($mbox,"{$host}$del_box");
  858.                         }
  859.                 }
  860.  
  861.                 echo "<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">";
  862.  
  863.                 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'])) {
  864.                
  865.                         $reply_from = trim($_POST['reply_from']);
  866.                         $reply_to = trim($_POST['reply_to']);
  867.                         $reply_subj = trim($_POST['reply_subj']);
  868.                         $reply_body = trim($_POST['reply_body']);                      
  869.                         $reply_headers = "From: $reply_from\r\nX-Mailer: Kartero/1.0 (PHP/" . phpversion() . ")";
  870.  
  871.                         if (isset($_POST['reply_cc']) and !empty($_POST['reply_cc'])) {
  872.                        
  873.                                 $reply_cc = trim($_POST['reply_cc']);
  874.                                
  875.                                 $reply_headers = "$reply_headers\r\nCc: $reply_cc";
  876.                         }
  877.  
  878.                         if (isset($_POST['reply_bcc']) and !empty($_POST['reply_bcc'])) {
  879.                        
  880.                                 $reply_bcc = trim($_POST['reply_bcc']);
  881.                                
  882.                                 $reply_headers = "$reply_headers\r\nBcc: $reply_bcc";
  883.                         }
  884.  
  885.                         if (isset($_POST['filedrop_box']) and !empty($_POST['filedrop_box'])) {
  886.  
  887.                                 $do_filedrop_box = $_POST['filedrop_box'];
  888.  
  889.                                 if (file_exists("attach/i/$fileUsr/$do_filedrop_box") and (count(glob("attach/i/$fileUsr/$do_filedrop_box/*")) > 0)) {
  890.  
  891.                                         $mime_boundary = md5(microtime(true));
  892.  
  893.                                         $reply_headers .= "\r\nMIME-Version: 1.0";
  894.                                         $reply_headers .= "\r\nContent-Type: multipart/mixed; boundary=\"{$mime_boundary}\"";
  895.                                        
  896.                                         $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}";
  897.  
  898.                                         $do_reply_from = extract_emails_from($reply_from);
  899.                                         $do_reply_to = extract_emails_from($reply_to);
  900.  
  901.                                         $do_filedrop_msg = glob("attach/i/$fileUsr/$do_filedrop_box/*");
  902.  
  903.                                         sort($do_filedrop_msg);
  904.                                         reset($do_filedrop_msg);
  905.  
  906.                                         foreach ($do_filedrop_msg as $do_filedrop_put) {
  907.  
  908.                                                 $do_filedrop_nom = str_replace("attach/i/$fileUsr/$do_filedrop_box/","",$do_filedrop_put);
  909.  
  910.                                                 $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)));
  911.                                         }
  912.  
  913.                                         $reply_body = $reply_body . "--{$mime_boundary}--";
  914.  
  915.                                         rmdirr("attach/i/$fileUsr/$do_filedrop_box");
  916.  
  917.                                         if (count(glob("attach/i/$fileUsr/*")) == 0) {
  918.                                                 rmdirr("attach/i/$fileUsr");
  919.                                         }
  920.                                 }
  921.                         }
  922.  
  923.                         if ($_POST['redirect'] == 1) {
  924.  
  925.                                 $redirect_date = date("D, j M Y H:i:s O (T)");
  926.  
  927.                                 $reply_headers = "Resent-Date: $redirect_date\r\nResent-To: $reply_to\r\n";
  928.  
  929.  
  930.                                 if (isset($_POST['reply_cc']) and !empty($_POST['reply_cc'])) {
  931.                        
  932.                                         $reply_cc = trim($_POST['reply_cc']);
  933.                                
  934.                                         $reply_headers = $reply_headers . "Resent-Cc: $reply_cc\r\n";
  935.                                 }
  936.        
  937.                                 if (isset($_POST['reply_bcc']) and !empty($_POST['reply_bcc'])) {
  938.                                
  939.                                         $reply_bcc = trim($_POST['reply_bcc']);
  940.                                        
  941.                                         $reply_headers = $reply_headers . "Resent-Bcc: $reply_bcc\r\n";
  942.                                 }
  943.  
  944.                                 $reply_headers = $reply_headers . imap_fetchheader($mbox,$_POST['msg'],FT_UID|FT_PREFETCHTEXT);
  945.  
  946.                                 $reply_body = imap_body($mbox,$_POST['msg'],FT_UID);
  947.                         }
  948.  
  949.                         imap_createmailbox($mbox,"{$host}Sent");
  950.  
  951.                         $reply_date = date ("d-M-Y H:i:s O");
  952.                        
  953.                         $reply_body = preg_replace("#(?<!\r)\n#si", "\r\n", $reply_body);
  954.                         $reply_headers = preg_replace('#(?<!\r)\n#si', "\r\n", $reply_headers);
  955.  
  956.                         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");
  957.  
  958.                         $reply_fenv = extract_emails_from($reply_from);
  959.  
  960.                         mail($reply_to, $reply_subj, $reply_body, $reply_headers, "-f {$reply_fenv[0]}");
  961.  
  962.                         if ($_POST['ack'] == 1) {
  963.  
  964.                                 imap_setflag_full($mbox, $_POST['msg'], '\\Answered',ST_UID);
  965.                         }
  966.                 }
  967.  
  968.                 if (isset($_POST['not']) and !empty($_POST['not']) and is_numeric($_POST['not'])) {
  969.  
  970.                         imap_clearflag_full($mbox, $_POST['msg'], '\\Seen',ST_UID);
  971.                         imap_expunge($mbox);
  972.                 }
  973.  
  974.                 if (isset($_POST['emt']) and !empty($_POST['emt']) and is_numeric($_POST['emt'])) {
  975.  
  976.                         imap_delete($mbox,'1:*');
  977.                         imap_expunge($mbox);
  978.                 }
  979.  
  980.                 echo "<tr><td valign=\"top\" width=\"700\"><div id=\"main\" class=\"main\">";
  981.  
  982.                 if (isset($_POST['get']) and !empty($_POST['get'])) {
  983.                         include("read.php");
  984.                 }
  985.                 elseif (isset($_POST['rep']) and !empty($_POST['rep'])) {
  986.                         include("send.php");
  987.                 }
  988.                 elseif (isset($_POST['new']) and !empty($_POST['new'])) {
  989.                         include("post.php");
  990.                 }
  991.                 elseif (isset($_POST['dig']) and !empty($_POST['dig'])) {
  992.                         include("search.php");
  993.                 }
  994.                 elseif (isset($_POST['set']) and !empty($_POST['set'])) {
  995.  
  996.                         echo "<title>Kartero - Settings</title>";
  997.                         echo "<table border=\"0\" cellspacing=\"1\" cellpadding=\"1\" width=\"800\">";
  998.                         echo "<form method=\"post\">";
  999.                         echo "<input type=\"hidden\" name=\"set\" value=\"1\">";
  1000.                         echo "<tr bgcolor=\"#ffffff\"><td width=\"400\"><input class=\"input\" type=\"text\" name=\"usr_name\" value=\"$usr_name\" autocomplete=\"off\" maxlength=\"128\" required autofocus></td><td>name</td></tr>";
  1001.                         echo "<tr bgcolor=\"#ffffff\"><td><input class=\"input\" type=\"password\" name=\"usr_pw1\" autocomplete=\"off\" maxlength=\"64\"></td><td>current password</td></tr>";
  1002.  
  1003.                         echo "<tr bgcolor=\"#ffffff\"><td><input class=\"input\" type=\"password\" name=\"usr_pw2\" autocomplete=\"off\" maxlength=\"64\"></td><td>new password";
  1004.  
  1005.                         if (isset($_POST['usr_pw1']) and !empty($_POST['usr_pw1']) and isset($_POST['usr_pw2']) and (strlen($_POST['usr_pw2']) < 8)) {
  1006.                                 echo " <font color=\"red\">too short</font>";
  1007.                         }
  1008.  
  1009.                         echo "</td></tr>";
  1010.  
  1011.                         echo "<tr bgcolor=\"#ffffff\"><td><input class=\"input\" type=\"password\" name=\"usr_pw3\" autocomplete=\"off\" maxlength=\"64\"></td><td>new password";
  1012.  
  1013.                         if (isset($_POST['usr_pw1']) and !empty($_POST['usr_pw1']) and isset($_POST['usr_pw3']) and (strlen($_POST['usr_pw3']) < 8)) {
  1014.                                 echo " <font color=\"red\">too short</font>";
  1015.                         }
  1016.  
  1017.                         echo "</td></tr>";
  1018.  
  1019.                         echo "<tr bgcolor=\"#ffffff\"><td><input class=\"button\" type=\"submit\" value=\"update\"></td><td></td></tr>";
  1020.                         echo "</form></table>";
  1021.  
  1022.                         echo "<br><table border=\"0\" cellspacing=\"1\" cellpadding=\"1\" width=\"800\">";
  1023.                         echo "<form method=\"post\">";
  1024.                         echo "<input type=\"hidden\" name=\"set\" value=\"1\">";
  1025.                         echo "<tr bgcolor=\"#ffffff\"><td width=\"200\"><input class=\"input\" type=\"text\" name=\"new_box\" autocomplete=\"off\" maxlength=\"200\" required autofocus></td>";
  1026.                         echo "<td width=\"197\"><input class=\"button\" type=\"submit\" value=\"create folder\"></td><td></td></tr>";
  1027.                         echo "</form>";
  1028.  
  1029.                         $usr_box = imap_list($mbox,$host,"*");
  1030.                         $usr_box = array_diff($usr_box,array("{$host}INBOX","{$host}Sent","{$host}Trash"));
  1031.  
  1032.                         if (count($usr_box) > 0) {
  1033.  
  1034.                                 sort($usr_box);
  1035.  
  1036.                                 echo "<form method=\"post\">";
  1037.                                 echo "<input type=\"hidden\" name=\"set\" value=\"1\">";
  1038.                                 echo "<tr bgcolor=\"#ffffff\"><td width=\"200\"><select class=\"input\" name=\"del_box\">";
  1039.  
  1040.                                 foreach ($usr_box as $del_box) {
  1041.        
  1042.                                         $del_box = imap_utf7_decode(str_replace($host,"",$del_box));
  1043.                                        
  1044.                                         echo "<option value=\"$del_box\">$del_box</option>";
  1045.                                 }              
  1046.                
  1047.                                 echo "</select></td><td width=\"197\"><input class=\"button\" type=\"submit\" value=\"delete folder\" onclick=\"if (confirm('Delete folder and all messages in it?')) {return true;} else {return false;}\"></td><td></td></tr>";
  1048.                                 echo "</form>";
  1049.                         }
  1050.                         echo "</table>";
  1051.  
  1052.                         if (isset($mail_home) and !empty($mail_home)) {
  1053.  
  1054.                                 $sivU = explode("@",$_SESSION['logged_uid']);
  1055.                                 $sivN = $sivU[0];
  1056.                                 $sivD = $sivU[1];
  1057.                                 $sivP = "$mail_home/$sivD/{$sivN[0]}/$sivN";
  1058.                                 $sivR = glob("$sivP/*.sieve",GLOB_NOSORT);
  1059.  
  1060.                                 if ($del_siv) {
  1061.                        
  1062.                                         foreach ($sivR as $sivI) {
  1063.                        
  1064.                                                 if (stripos(file_get_contents($sivI),"fileinto \"$del_siv\";")) {
  1065.                                                         unlink($sivI);
  1066.                                                 }
  1067.                                         }
  1068.                                 }
  1069.  
  1070.                                 if (isset($_POST['sieveT']) and !empty($_POST['sieveT']) and isset($_POST['sieveV']) and !empty($_POST['sieveV']) and isset($_POST['sieveF']) and !empty($_POST['sieveF'])) {
  1071.  
  1072.                                         $sieveT = strtolower(trim(strip_tags($_POST['sieveT'])));
  1073.                                         $sieveV = trim($_POST['sieveV']);
  1074.                                         $sieveF = imap_utf7_encode(trim(strip_tags($_POST['sieveF'])));
  1075.  
  1076.                                         if ($sieveT == "from") {
  1077.  
  1078.                                                 $sieveP = "from";
  1079.  
  1080.                                                 $sieveV = extract_emails_from($sieveV);
  1081.                                                 $sieveV = $sieveV[0];
  1082.  
  1083.                                                 if ($sieveV != "") {
  1084.                                                         $sieveW = "require \"fileinto\"; if address :is \"from\" \"$sieveV\" { fileinto \"$sieveF\"; }";
  1085.                                                 }
  1086.                                         }
  1087.  
  1088.                                         if ($sieveT == "subject") {
  1089.  
  1090.                                                 $sieveP = "subj";
  1091.  
  1092.                                                 $sieveV = strip_tags($sieveV);
  1093.  
  1094.                                                 if ($sieveV != "") {
  1095.                                                         $sieveW = "require \"fileinto\"; if header :contains \"subject\" \"$sieveV\" { fileinto \"$sieveF\"; }";
  1096.                                                 }
  1097.                                         }
  1098.  
  1099.                                         if ($sieveW != ""){
  1100.  
  1101.                                                 if (count($sivR) > 0) {
  1102.                                        
  1103.                                                         foreach ($sivR as $sieveR) {
  1104.  
  1105.                                                                 if (strtolower(trim(file_get_contents($sieveR))) != strtolower($sieveW)) {
  1106.                                                                         continue;
  1107.                                                                 }
  1108.                                                        
  1109.                                                                 unlink($sieveR);
  1110.                                                         }
  1111.                                                 }
  1112.  
  1113.                                                 $sieveP = "$sivP/{$sieveP}-" . date("YmdHis") . ".sieve";
  1114.  
  1115.                                                 $fp = fopen($sieveP,"w");
  1116.                                                 fwrite($fp,$sieveW);
  1117.                                                 fclose($fp);
  1118.                                         }
  1119.                                 }
  1120.  
  1121.                                 if (isset($_POST['sieve']) and !empty($_POST['sieve'])) {
  1122.  
  1123.                                         $sieve = strtolower(trim(strip_tags($_POST['sieve'])));
  1124.  
  1125.                                         if (file_exists("$sivP/$sieve") and ($_POST['set'] == "sivD")) {
  1126.                                                 unlink("$sivP/$sieve");
  1127.                                         }
  1128.                                 }
  1129.  
  1130.                                 echo "<br><table border=\"0\" cellspacing=\"1\" cellpadding=\"1\" width=\"100%\">";
  1131.                                 echo "<form method=\"post\"><input type=\"hidden\" name=\"set\" value=\"sivA\"><tr>";
  1132.                                 echo "<td width=\"200\"><select class=\"input\" name=\"sieveT\"><option value=\"from\">If message is from</option><option value=\"subject\">If message subject contains</option></td>";
  1133.                                 echo "<td><input class=\"input\" type=\"text\" name=\"sieveV\" autocomplete=\"off\" required></td>";
  1134.                                 echo "<td><select class=\"input\" name=\"sieveF\"><option value=\"Trash\" selected>then move to Trash</option>";
  1135.  
  1136.                                 foreach ($usr_box as $sieveF) {
  1137.  
  1138.                                         $sieveF = str_replace($host,"",$sieveF);
  1139.  
  1140.                                         echo "<option value=\"$sieveF\">then move to $sieveF</option>";
  1141.                                 }
  1142.  
  1143.                                 echo "</select></td>";
  1144.                                 echo "<td><input type=\"submit\" value=\"add\"></td>";
  1145.                                 echo "</tr></form>";
  1146.                                 echo "</table>";
  1147.  
  1148.                                 $sivR = glob("$sivP/*.sieve");
  1149.  
  1150.                                 if (count($sivR) > 0) {
  1151.  
  1152.                                         $sivW = 'require "include";';
  1153.        
  1154.                                         echo "<br><table border=\"0\" cellspacing=\"1\" cellpadding=\"1\">";
  1155.  
  1156.                                         foreach ($sivR as $sivS) {
  1157.                
  1158.                                                 $sivC = (explode('"',file_get_contents($sivS)));
  1159.                                                 $sivF = basename($sivS);
  1160.  
  1161.                                                 $sivW = $sivW . "\r\ninclude \"" . str_replace(".sieve","",$sivF) . '";';
  1162.  
  1163.                                                 echo "<form method=\"post\">";
  1164.                                                 echo "<input type=\"hidden\" name=\"set\" value=\"sivD\">";
  1165.                                                 echo "<input type=\"hidden\" name=\"sieve\" value=\"$sivF\">";
  1166.                                                 echo "<tr>";
  1167.                                                 echo "<td><input type=\"submit\" value=\"del\"></td>";
  1168.  
  1169.                                                 if ($sivC[3] == "from") {
  1170.                                                         echo "<td>If message is {$sivC[3]} {$sivC[5]} then move to {$sivC[7]}</td>";
  1171.                                                 }
  1172.                                                 else {
  1173.                                                         echo "<td>If message {$sivC[3]} contains {$sivC[5]} then move to {$sivC[7]}</td>";
  1174.                                                 }
  1175.  
  1176.                                                 echo "</tr>";
  1177.                                                 echo "</form>";
  1178.                                         }
  1179.                        
  1180.                                         echo "</table>";
  1181.  
  1182.                                         if ($sivW != file_get_contents("$sivP/.dovecot.sieve")) {
  1183.  
  1184.                                                 $fp = fopen("$sivP/.dovecot.sieve","w");
  1185.                                                 fwrite($fp,$sivW);
  1186.                                                 fclose($fp);
  1187.                                         }
  1188.                                 }
  1189.                                 else {
  1190.                                         if (file_exists("$sivP/.dovecot.sieve")) {
  1191.                                                         unlink("$sivP/.dovecot.sieve");
  1192.                                         }
  1193.  
  1194.                                         if (file_exists("$sivP/.dovecot.svbin")) {
  1195.                                                         unlink("$sivP/.dovecot.svbin");
  1196.                                         }
  1197.                                 }
  1198.                         }
  1199.                 }
  1200.                 else {
  1201.                         include("inbox.php");
  1202.  
  1203. //echo "<script type=\"text/javascript\" src=\"jquery-1.3.2.min.js\"></script>";
  1204.  
  1205. //echo "<script type=\"text/javascript\"> $(document).ready(function() { setInterval(function() { $('#main').fadeOut(\"fast\").load('inbox.php').fadeIn(\"slow\"); }, 5000); }); </script>";
  1206.                 }
  1207.  
  1208.                 echo "</div></td>";
  1209.  
  1210.                 echo "<td width=\"10\"></td>";
  1211.  
  1212.                 echo "<td valign=\"top\" width=\"100\">";
  1213.                 include("folders.php");
  1214.                 echo "</td>";
  1215.  
  1216.                 echo "</tr></table>";
  1217.         }
  1218.  
  1219.         if ($_SESSION['logged_lvl'] == "postmaster") {
  1220.  
  1221.                 echo "<table border=\"0\" cellspacing=\"1\" cellpadding=\"2\" bgcolor=\"#cccccc\">";
  1222.                 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>";
  1223.                 echo "<form method=\"post\">";
  1224.                 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>";
  1225.                 echo "</form>";
  1226.        
  1227.                 $pm_get = mysql_query("select * from users where domain='{$_SESSION['logged_uid']}' order by id");
  1228.        
  1229.                 while ($pm_row = mysql_fetch_array($pm_get)) {
  1230.        
  1231.                         if ($pm_row[5] == "1") {
  1232.                                 $pm_do = "disable";
  1233.                                 $pm_bg = "#ffffff";
  1234.                         }
  1235.        
  1236.                         if ($pm_row[5] == "0") {
  1237.                                 $pm_do = "enable";
  1238.                                 $pm_bg = "#eeeeee";
  1239.                         }
  1240.        
  1241.                         $msg_new = "$mail_root/{$_SESSION['logged_uid']}/" . substr($pm_row[0],0,1) . "/" . substr($pm_row[0],0,strpos($pm_row[0],"@")) . "/new/*";
  1242.                         $msg_new = count(glob($msg_new));
  1243.        
  1244.                         $msg_cur = "$mail_root/{$_SESSION['logged_uid']}/" . substr($pm_row[0],0,1) . "/" . substr($pm_row[0],0,strpos($pm_row[0],"@")) . "/cur/*";
  1245.                         $msg_cur = count(glob($msg_cur));
  1246.        
  1247.                         $pm_aka = mysql_query("select * from aliases where alias='{$pm_row[0]}'");
  1248.                         $pm_aka = mysql_num_rows($pm_aka);
  1249.        
  1250.                         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>";
  1251.                 }
  1252.        
  1253.                 echo "</table>";
  1254.         }
  1255.  
  1256.         if ($_SESSION['logged_lvl'] == "administrator") {
  1257.        
  1258.                 echo "<table border=\"0\" cellspacing=\"1\" cellpadding=\"2\" bgcolor=\"#cccccc\">";
  1259.                 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>";
  1260.                 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>";
  1261.        
  1262.                 $dom_get = mysql_query("select * from domains order by id");
  1263.        
  1264.                 while ($dom_row = mysql_fetch_array($dom_get)) {
  1265.  
  1266.                         $dom_usr = mysql_query("select * from users where domain='{$dom_row[0]}'");
  1267.                         $dom_usr = mysql_num_rows($dom_usr);
  1268.        
  1269.                         if ($dom_row[3] == "1") {
  1270.                                 $dom_do = "disable";
  1271.                                 $dom_bg = "#ffffff";
  1272.                         }
  1273.        
  1274.                         if ($dom_row[3] == "0") {
  1275.                                 $dom_do = "enable";
  1276.                                 $dom_bg = "#eeeeee";
  1277.                         }
  1278.        
  1279.                         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>";
  1280.                 }
  1281.        
  1282.                 echo "</table>";
  1283.         }
  1284.        
  1285.         echo "</td>";
  1286.  
  1287.         if ($_SESSION['logged_lvl'] == "postmaster") {
  1288.        
  1289.                 echo "<td width=\"10\"></td><td valign=\"top\">";
  1290.  
  1291.                 echo "<table border=\"0\" cellspacing=\"1\" cellpadding=\"2\" bgcolor=\"#cccccc\">";
  1292.                 echo "<tr bgcolor=\"#eeeeee\"><td align=\"center\">alias</td><td align=\"center\">recipient</td><td align=\"center\" colspan=\"3\">action</td></tr>";
  1293.                 echo "<form method=\"post\">";
  1294.                 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>";
  1295.                 echo "</form>";
  1296.        
  1297.                 $get_aliases = mysql_query("select * from aliases where domain='{$_SESSION['logged_uid']}' order by id");
  1298.        
  1299.                 while ($aliases_row = mysql_fetch_array($get_aliases)) {
  1300.        
  1301.                         if ($aliases_row[3] == "1") {
  1302.                                 $alias_do = "disable";
  1303.                                 $alias_bg = "#ffffff";
  1304.                         }
  1305.        
  1306.                         if ($aliases_row[3] == "0") {
  1307.                                 $alias_do = "enable";
  1308.                                 $alias_bg = "#eeeeee";
  1309.                         }
  1310.        
  1311.                         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>";
  1312.                 }
  1313.        
  1314.                 echo "</table>";
  1315.         }
  1316.  
  1317.         echo "</td></tr>";
  1318.         echo "</table>";
  1319. }
  1320.  
  1321. mysql_close($db_link);
  1322.  
  1323. ?>
  1324.  
filedropkartero.git-41992ae.tar.bz2 new
412.12 KB
92 downloads
filedropkartero.git-41992ae.zip
448.41 KB
53 downloads
filedropkartero.git-b404ba2.tar.bz2
411.70 KB
82 downloads
filedropkartero.git-b404ba2.zip
447.96 KB
52 downloads
filedropkartero.git-a7684d9.tar.bz2
411.72 KB
330 downloads
filedropkartero.git-a7684d9.zip
447.96 KB
10 downloads
filedropkartero.git-83512be.tar.bz2
410.26 KB
303 downloads
filedropkartero.git-83512be.zip
445.30 KB
247 downloads
filedropkartero.git-1954b25.tar.bz2
410.21 KB
309 downloads
filedropkartero.git-1954b25.zip
445.30 KB
1 download
filedropkartero.git-2f7c910.tar.bz2
410.25 KB
48 downloads
filedropkartero.git-2f7c910.zip
445.29 KB
38 downloads
filedropkartero.git-6317ffb.tar.bz2
410.40 KB
268 downloads
filedropkartero.git-6317ffb.zip
445.28 KB
14 downloads
filedropkartero.git-60ccd7a.tar.bz2
410.40 KB
259 downloads
filedropkartero.git-60ccd7a.zip
445.20 KB
11 downloads
filedropkartero.git-ea6f885.tar.bz2
410.47 KB
66 downloads
filedropkartero.git-ea6f885.zip
445.26 KB
188 downloads
filedropkartero.git-7f580e5.zip
445.17 KB
178 downloads
filedropkartero.git-7f580e5.tar.bz2
410.18 KB
211 downloads
filedropkartero.git-b9364de.tar.bz2
409.41 KB
205 downloads
filedropkartero.git-b9364de.zip
444.09 KB
429 downloads
filedropkartero.git-e9bcd78.zip
444.03 KB
416 downloads
filedropkartero.git-e9bcd78.tar.bz2
409.39 KB
473 downloads
filedropkartero.git-96c60ff.tar.bz2
407.96 KB
14 downloads
filedropkartero.git-96c60ff.zip
441.87 KB
385 downloads
filedropkartero.git-4357b59.tar.bz2
407.17 KB
458 downloads
filedropkartero.git-4357b59.zip
440.69 KB
384 downloads
filedropkartero.git-c6ff319.tar.bz2
407.28 KB
14 downloads
filedropkartero.git-c6ff319.zip
440.70 KB
363 downloads
filedropkartero.git-8b87a29.tar.bz2
407.27 KB
429 downloads
filedropkartero.git-8b87a29.zip
440.71 KB
361 downloads
filedropkartero.git-ee42942.tar.bz2
406.49 KB
394 downloads
filedropkartero.git-ee42942.zip
439.92 KB
348 downloads
filedropkartero.git-867e7e6.tar.bz2
406.75 KB
40 downloads
filedropkartero.git-867e7e6.zip
440.03 KB
350 downloads
filedropkartero.git-3f3fc02.tar.bz2
406.38 KB
418 downloads
filedropkartero.git-3f3fc02.zip
439.71 KB
370 downloads
filedropkartero.git-b6f779d.tar.bz2
406.55 KB
444 downloads
filedropkartero.git-b6f779d.zip
440.00 KB
332 downloads
filedropkartero.git-83f24b0.zip
439.12 KB
307 downloads
filedropkartero.git-52316ec.tar.bz2
406.17 KB
389 downloads
filedropkartero.git-52316ec.zip
439.18 KB
334 downloads
filedropkartero.git-83f24b0.tar.bz2
405.84 KB
386 downloads
filedropkartero.git-8a42d47.tar.bz2
405.73 KB
345 downloads
filedropkartero.git-8a42d47.zip
439.02 KB
301 downloads
filedropkartero.git-830c9cb.tar.bz2
406.08 KB
350 downloads
filedropkartero.git-830c9cb.zip
439.08 KB
304 downloads
filedropkartero.git-ebec1be.tar.bz2
406.16 KB
356 downloads
filedropkartero.git-ebec1be.zip
439.09 KB
331 downloads
filedropkartero.git-7c0b70f.tar.bz2
402.43 KB
337 downloads
filedropkartero.git-7c0b70f.zip
435.91 KB
296 downloads
filedropkartero.git-80edc03.tar.bz2
402.75 KB
39 downloads
filedropkartero.git-80edc03.zip
435.84 KB
306 downloads
filedropkartero.git-b408c23.tar.bz2
402.19 KB
38 downloads
filedropkartero.git-b408c23.zip
435.59 KB
314 downloads
filedropkartero.git-29c0e1f.tar.bz2
401.84 KB
348 downloads
filedropkartero.git-29c0e1f.zip
435.25 KB
325 downloads
filedropkartero.git-9086094.tar.bz2
401.94 KB
1 download
filedropkartero.git-9086094.zip
435.34 KB
324 downloads
filedropkartero.git-47ca624.tar.bz2
402.10 KB
350 downloads
filedropkartero.git-47ca624.zip
435.51 KB
292 downloads
filedropkartero.git-81314a5.zip
435.53 KB
313 downloads
filedropkartero.git-81314a5.tar.bz2
402.25 KB
344 downloads
filedropkartero.git-cae7074.zip
435.20 KB
308 downloads
filedropkartero.git-cae7074.tar.bz2
401.98 KB
354 downloads
filedropkartero.git-cc68e56.tar.bz2
402.07 KB
345 downloads
filedropkartero.git-cc68e56.zip
435.16 KB
336 downloads
filedropkartero.git-230f35d.tar.bz2
401.43 KB
323 downloads
filedropkartero.git-230f35d.zip
434.68 KB
1 download
filedropkartero.git-5ae58a2.tar.bz2
401.54 KB
330 downloads
filedropkartero.git-5ae58a2.zip
434.68 KB
297 downloads
filedropkartero.git-a591f4b.tar.bz2
401.76 KB
329 downloads
filedropkartero.git-a591f4b.zip
435.17 KB
306 downloads
filedropkartero.git-36876c8.tar.bz2
400.44 KB
325 downloads
filedropkartero.git-36876c8.zip
432.36 KB
329 downloads
filedropkartero.git-a34c9ed.tar.bz2
400.57 KB
341 downloads
filedropkartero.git-a34c9ed.zip
432.27 KB
317 downloads
filedropkartero.git-e828148.zip
433.58 KB
297 downloads
filedropkartero.git-e828148.tar.bz2
400.88 KB
338 downloads
filedropkartero.git-476cdda.tar.bz2
400.60 KB
367 downloads
filedropkartero.git-476cdda.zip
432.26 KB
309 downloads
filedropkartero.git-054c286.tar.bz2
98.09 KB
89 downloads
filedropkartero.git-054c286.zip
109.53 KB
375 downloads
filedropkartero.git-071b099.tar.bz2
98.76 KB
465 downloads
filedropkartero.git-071b099.zip
110.21 KB
374 downloads
filedropkartero.git-551c38d.tar.bz2
98.51 KB
85 downloads
filedropkartero.git-551c38d.zip
110.20 KB
367 downloads
filedropkartero.git-569dc0c.tar.bz2
98.40 KB
87 downloads
filedropkartero.git-569dc0c.zip
109.86 KB
360 downloads
filedropkartero.git-58a052b.tar.bz2
97.95 KB
84 downloads
filedropkartero.git-58a052b.zip
109.36 KB
371 downloads
filedropkartero.git-43a5af3.tar.bz2
97.80 KB
457 downloads
filedropkartero.git-43a5af3.zip
109.30 KB
368 downloads
filedropkartero.git-bbe069d.tar.bz2
98.03 KB
466 downloads
filedropkartero.git-bbe069d.zip
109.19 KB
376 downloads
filedropkartero.git-02f97e1.tar.bz2
97.76 KB
435 downloads
filedropkartero.git-02f97e1.zip
109.24 KB
464 downloads
filedropkartero.git-d82e393.tar.bz2
97.74 KB
468 downloads
filedropkartero.git-d82e393.zip
109.24 KB
374 downloads
filedropkartero.git-7cdd1f5.tar.bz2
98.03 KB
449 downloads
filedropkartero.git-7cdd1f5.zip
109.24 KB
358 downloads
filedropkartero.git-40825aa.tar.bz2
97.71 KB
451 downloads
filedropkartero.git-40825aa.zip
109.16 KB
392 downloads
filedropkartero.git-3dd941b.tar.bz2
97.69 KB
449 downloads
filedropkartero.git-3dd941b.zip
109.12 KB
368 downloads
filedropkartero.git-50f1e46.tar.bz2
97.65 KB
83 downloads
filedropkartero.git-50f1e46.zip
109.02 KB
367 downloads
filedropkartero.git-fdf9225.tar.bz2
93.19 KB
493 downloads
filedropkartero.git-fdf9225.zip
104.25 KB
380 downloads
filedropkartero.git-21415da.tar.bz2
93.24 KB
448 downloads
filedropkartero.git-21415da.zip
104.22 KB
381 downloads
filedropkartero.git-aff5e89.tar.bz2
93.17 KB
467 downloads
filedropkartero.git-aff5e89.zip
104.22 KB
371 downloads
filedropkartero.git-b27ef39.tar.bz2
91.97 KB
466 downloads
filedropkartero.git-b27ef39.zip
102.80 KB
396 downloads
filedropkartero.git-3d6e8a2.tar.bz2
91.99 KB
85 downloads
filedropkartero.git-3d6e8a2.zip
102.77 KB
391 downloads
filedropkartero.git-1442b69.tar.bz2
91.79 KB
447 downloads
filedropkartero.git-1442b69.zip
102.50 KB
396 downloads
filedropkartero.git-6d15918.tar.bz2
91.56 KB
471 downloads
filedropkartero.git-6d15918.zip
102.28 KB
365 downloads
filedropkartero.git-45140d8.tar.bz2
91.52 KB
86 downloads
filedropkartero.git-45140d8.zip
102.23 KB
370 downloads
filedropkartero.git-d5b48e5.tar.bz2
91.35 KB
457 downloads
filedropkartero.git-d5b48e5.zip
102.01 KB
381 downloads
filedropkartero.git-e007e55.tar.bz2
91.35 KB
468 downloads
filedropkartero.git-e007e55.zip
102.01 KB
354 downloads
filedropkartero.git-30fd7e3.tar.bz2
90.87 KB
85 downloads
filedropkartero.git-30fd7e3.zip
101.44 KB
383 downloads
filedropkartero.git-421a4a7.tar.bz2
88.02 KB
189 downloads
filedropkartero.git-421a4a7.zip
97.96 KB
356 downloads
filedropkartero.git-b49b8bc.tar.bz2
88.09 KB
485 downloads
filedropkartero.git-b49b8bc.zip
97.99 KB
376 downloads
filedropkartero.git-1cc9571.tar.bz2
87.74 KB
465 downloads
filedropkartero.git-1cc9571.zip
97.70 KB
381 downloads
filedropkartero.git-159152f.tar.bz2
87.60 KB
463 downloads
filedropkartero.git-159152f.zip
97.52 KB
385 downloads
filedropkartero.git-35caaf3.tar.bz2
87.74 KB
448 downloads
filedropkartero.git-35caaf3.zip
97.57 KB
368 downloads
filedropkartero.git-3c9d305.zip
96.67 KB
369 downloads
filedropkartero.git-3c9d305.tar.bz2
86.77 KB
451 downloads
filedropkartero.git-14cb2af.tar.bz2
86.41 KB
450 downloads
filedropkartero.git-14cb2af.zip
96.13 KB
372 downloads
filedropkartero.git-e8f00cb.tar.bz2
86.46 KB
474 downloads
filedropkartero.git-e8f00cb.zip
96.21 KB
364 downloads
filedropkartero.git-bdab380.tar.bz2
86.14 KB
461 downloads
filedropkartero.git-bdab380.zip
95.79 KB
366 downloads
filedropkartero.git-48f9134.tar.bz2
85.78 KB
466 downloads
filedropkartero.git-48f9134.zip
95.48 KB
375 downloads
filedropkartero.git-adb9757.tar.bz2
85.67 KB
457 downloads
filedropkartero.git-adb9757.zip
95.37 KB
369 downloads
filedropkartero.git-1601cbd.zip
95.30 KB
381 downloads
filedropkartero.git-1601cbd.tar.bz2
85.69 KB
439 downloads
filedropkartero.git-18a5106.tar.bz2
85.72 KB
442 downloads
filedropkartero.git-18a5106.zip
95.48 KB
382 downloads
filedropkartero.git-a5b1caa.tar.bz2
85.61 KB
474 downloads
filedropkartero.git-a5b1caa.zip
95.36 KB
376 downloads
filedropkartero.git-effff82.zip
97.06 KB
389 downloads
filedropkartero.git-effff82.tar.bz2
87.13 KB
459 downloads
filedropkartero.git-b70d364.tar.bz2
84.09 KB
500 downloads
filedropkartero.git-b70d364.zip
93.67 KB
383 downloads
filedropkartero.git-48f0e53.tar.bz2
84.16 KB
81 downloads
filedropkartero.git-48f0e53.zip
93.66 KB
373 downloads
filedropkartero.git-c17135e.tar.bz2
84.09 KB
458 downloads
filedropkartero.git-c17135e.zip
93.57 KB
362 downloads
filedropkartero.git-a2e2848.tar.bz2
85.59 KB
83 downloads
filedropkartero.git-a2e2848.zip
100.10 KB
376 downloads
filedropkartero.git-1f683db.tar.bz2
83.55 KB
460 downloads
filedropkartero.git-1f683db.zip
93.24 KB
367 downloads
filedropkartero.git-d342596.tar.bz2
83.57 KB
83 downloads
filedropkartero.git-d342596.zip
93.28 KB
362 downloads
filedropkartero.git-e0131d5.tar.bz2
83.55 KB
83 downloads
filedropkartero.git-e0131d5.zip
93.27 KB
378 downloads
filedropkartero.git-ad467e8.tar.bz2
83.13 KB
81 downloads
filedropkartero.git-ad467e8.zip
92.78 KB
369 downloads
filedropkartero.git-b20e27d.tar.bz2
83.46 KB
82 downloads
filedropkartero.git-b20e27d.zip
93.19 KB
395 downloads
filedropkartero.git-eefd8fe.zip
92.67 KB
398 downloads
filedropkartero.git-eefd8fe.tar.bz2
83.01 KB
463 downloads
filedropkartero.git-bea685a.zip
96.88 KB
374 downloads
filedropkartero.git-bea685a.tar.bz2
84.44 KB
456 downloads
filedropkartero.git-a8bd019.tar.bz2
84.25 KB
92 downloads
filedropkartero.git-a8bd019.zip
96.60 KB
369 downloads
filedropkartero.git-cbc914d.tar.bz2
84.38 KB
464 downloads
filedropkartero.git-cbc914d.zip
96.64 KB
358 downloads
filedropkartero.git-09a2e70.tar.bz2
84.40 KB
442 downloads
filedropkartero.git-09a2e70.zip
96.70 KB
382 downloads
filedropkartero.git-641dc05.tar.bz2
84.37 KB
464 downloads
filedropkartero.git-641dc05.zip
96.73 KB
371 downloads
filedropkartero.git-cde49c6.tar.bz2
84.26 KB
476 downloads
filedropkartero.git-cde49c6.zip
96.59 KB
377 downloads
filedropkartero.git-1d004e0.tar.bz2
77.42 KB
473 downloads
filedropkartero.git-1d004e0.zip
87.56 KB
23 downloads
filedropkartero.git-1f0bf17.tar.bz2
77.47 KB
471 downloads
filedropkartero.git-1f0bf17.zip
87.56 KB
369 downloads
filedropkartero.git-265e63c.tar.bz2
77.43 KB
449 downloads
filedropkartero.git-265e63c.zip
87.52 KB
403 downloads
filedropkartero.git-635a5db.zip
87.60 KB
371 downloads
filedropkartero.git-a041f85.tar.bz2
77.37 KB
83 downloads
filedropkartero.git-a041f85.zip
87.52 KB
403 downloads
filedropkartero.git-ae049a7.tar.bz2
77.44 KB
474 downloads
filedropkartero.git-ae049a7.zip
87.52 KB
370 downloads
filedropkartero.git-eef571a.tar.bz2
20.56 KB
580 downloads
filedropkartero.git-eef571a.zip
25.69 KB
502 downloads
filedropkartero.git-0bc16f5.tar.bz2
82.61 KB
88 downloads
filedropkartero.git-0bc16f5.zip
94.75 KB
407 downloads
filedropkartero.git-2afc0f7.tar.bz2
83.61 KB
492 downloads
filedropkartero.git-2afc0f7.zip
96.00 KB
425 downloads
filedropkartero.git-3529bdf.tar.bz2
77.72 KB
81 downloads
filedropkartero.git-3529bdf.zip
87.92 KB
402 downloads
filedropkartero.git-49aac92.tar.bz2
78.98 KB
507 downloads
filedropkartero.git-49aac92.zip
90.01 KB
403 downloads
filedropkartero.git-5d48f21.tar.bz2
78.65 KB
91 downloads
filedropkartero.git-5d48f21.zip
89.51 KB
432 downloads
filedropkartero.git-635a5db.tar.bz2
77.50 KB
513 downloads
filedropkartero.git-6e34786.tar.bz2
77.76 KB
95 downloads
filedropkartero.git-6e34786.zip
88.09 KB
447 downloads
filedropkartero.git-7dc2fd2.tar.bz2
83.51 KB
93 downloads
filedropkartero.git-7dc2fd2.zip
95.99 KB
453 downloads
filedropkartero.git-9cad005.tar.bz2
78.85 KB
87 downloads
filedropkartero.git-9cad005.zip
90.00 KB
497 downloads
filedropkartero.git-b303f61.tar.bz2
82.57 KB
88 downloads
filedropkartero.git-b303f61.zip
94.78 KB
171 downloads
filedropkartero.git-c15ef85.tar.bz2
77.76 KB
260 downloads
filedropkartero.git-c15ef85.zip
88.16 KB
189 downloads
filedropkartero.git-c99e84d.tar.bz2
83.58 KB
85 downloads
filedropkartero.git-c99e84d.zip
96.01 KB
203 downloads
filedropkartero.git-e5009e6.tar.bz2
78.73 KB
295 downloads
filedropkartero.git-e5009e6.zip
89.69 KB
219 downloads
filedropkartero.git-0502d01.tar.bz2
83.54 KB
310 downloads
filedropkartero.git-0502d01.zip
96.00 KB
228 downloads
filedropkartero.git-44ca46d.tar.bz2
83.73 KB
78 downloads
filedropkartero.git-44ca46d.zip
96.20 KB
239 downloads
filedropkartero.git-834f923.tar.bz2
83.75 KB
323 downloads
filedropkartero.git-834f923.zip
96.14 KB
249 downloads