kartero.org

kartero.org

Git

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