kartero.org

kartero.org

Git

This blob has been accessed 756 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_port = "5432";
  7. $db_name = "kartero";
  8. $db_user = "postgres";
  9. $db_pass = "password";
  10.  
  11. $mail_root = "/var/www/html/mailroot";
  12.  
  13. /* feel free to hack the succeeding code to suit your needs (basic php and mysql skills required) */
  14.  
  15. session_start();
  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 = pg_pconnect("host=$db_host port=$db_port user=$db_user password=$db_pass dbname=$db_name");
  78.  
  79. if (!$db_link) {
  80.         nak(pg_last_error());
  81.         exit;
  82. }
  83.  
  84. $pw_crypt = crypt("password");
  85. //$db_query = pg_query($db_link,"create database $db_name");
  86. //$db_query = pg_query($db_link,"use $db_name");
  87. $db_query = pg_query($db_link,"create table admins (id varchar(16) not null, pw varchar(64) not null, primary key (id), unique key (id))");
  88. $db_query = pg_query($db_link,"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))");
  89. $db_query = pg_query($db_link,"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))");
  90. $db_query = pg_query($db_link,"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))");
  91. $db_query = pg_query($db_link,"insert into admins values('root','$pw_crypt')");
  92.  
  93. $id_put = trim($_POST['id']);
  94.  
  95. if (get_magic_quotes_gpc()) {
  96.         $id_put = stripslashes($id_put);
  97. }
  98.  
  99. if (!is_int($value)) {
  100.         $id_put = pg_escape_string($id_put);
  101. }
  102.  
  103. $id_put = strip_tags($id_put);
  104.  
  105. $lvl_put = strip_tags($_POST['lvl']);
  106.  
  107. if ($lvl_put == "subscriber") {
  108.         $pw_get = pg_query($db_link,"select pw from users where id='$id_put'");
  109. }
  110.  
  111. if ($lvl_put == "postmaster") {
  112.         $pw_get = pg_query($db_link,"select pw from domains where id='$id_put'");
  113. }
  114.  
  115. if ($lvl_put == "administrator") {
  116.         $pw_get = pg_query($db_link,"select pw from admins where id='$id_put'");
  117. }
  118.  
  119. $pw_get = pg_fetch_row($pw_get);
  120. $pw_get = $pw_get[0];
  121.  
  122. $pw_put = $_POST['pw'];
  123.  
  124. if (get_magic_quotes_gpc()) {
  125.         $pw_put = stripslashes($pw_put);
  126. }
  127.  
  128. if (!is_int($value)) {
  129.         $pw_put = pg_escape_string($pw_put);
  130. }
  131.  
  132. $pw_put = strip_tags($pw_put);
  133. $pw_put = crypt($pw_put,$pw_get);
  134.  
  135. if ($pw_put == $pw_get) {
  136.         $_SESSION['logged_uid'] = $id_put;
  137.         $_SESSION['logged_lvl'] = $lvl_put;
  138. }
  139.  
  140. if (isset($_GET['do']) and ($_GET['do'] == "logout")) {
  141.         $_SESSION = array();
  142.         session_destroy();
  143.         header("Location: .");
  144.         exit;
  145. }
  146.  
  147. /* logo here? */
  148.  
  149. 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']))) {
  150.         echo "<table border=\"0\" cellspacing=\"1\" cellpadding=\"2\" bgcolor=\"#cccccc\">";
  151.         echo "<form method=\"post\">";
  152.         echo "<tr bgcolor=\"#ffffff\"><td width=\"150\"><select class=\"input\" name=\"lvl\"><option value=\"subscriber\">subscriber</option><option value=\"postmaster\">postmaster</option><option value=\"administrator\">administrator</option></select></td></tr>";
  153.         echo "<tr bgcolor=\"#ffffff\"><td width=\"150\"><input class=\"input\" type=\"text\" name=\"id\" autocomplete=\"off\" maxlength=\"128\"></td></tr>";
  154.         echo "<tr bgcolor=\"#ffffff\"><td width=\"150\"><input class=\"input\" type=\"password\" name=\"pw\" autocomplete=\"off\" maxlength=\"64\"></td></tr>";
  155.         echo "<tr bgcolor=\"#ffffff\"><td width=\"150\"><input class=\"input\" type=\"submit\" value=\"login\"></td></tr>";
  156.         echo "</form>";
  157.         echo "</table>";
  158.         exit;
  159. }
  160.  
  161. if (isset($_SESSION['logged_uid'])) {
  162.  
  163.         echo "<p><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></p>";
  164.  
  165.         echo "<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">";
  166.         echo "<tr><td colspan=\"3\" valign=\"top\">";
  167.  
  168.         if ($_SESSION['logged_lvl'] == "subscriber") {
  169.        
  170.                 $usr_query = pg_query($db_link,"select * from users where id='{$_SESSION['logged_uid']}'");
  171.                 $usr_data = pg_fetch_row($usr_query);
  172.  
  173.                 $dom_query = pg_query($db_link,"select mode from domains where id='{$usr_data[4]}'");
  174.                 $dom_data = pg_fetch_row($dom_query);
  175.  
  176.                 if ($dom_data[0] == 0) {
  177.                         nak("{$usr_data[4]} disabled by admin - new settings will take effect once it is re-enabled");
  178.                 }
  179.  
  180.                 if ($usr_data[5] == 0) {
  181.                         nak("{$_SESSION['logged_uid']} disabled by postmaster - new settings will take effect once it is re-enabled");
  182.                 }
  183.        
  184.                 $usr_name = $usr_data[3];
  185.        
  186.                 if (isset($_POST['usr_name']) and !empty($_POST['usr_name'])) {
  187.        
  188.                         $usr_name = trim($_POST['usr_name']);
  189.                         $usr_name = ucwords($usr_name);
  190.        
  191.                         if ($usr_name != $usr_data[3]) {
  192.        
  193.                                 $usr_query = pg_query($db_link,"update users set name='$usr_name' where id='{$_SESSION['logged_uid']}'");
  194.        
  195.                                 if (!usr_query) {
  196.                                         nak(strtolower(pg_last_error()));
  197.                                 }
  198.                                 else {
  199.                                         ack("name changed");
  200.                                 }
  201.                         }
  202.                         else {
  203.                                 $usr_name = $usr_data[3];
  204.                         }
  205.                 }
  206.        
  207.                 $usr_pw0 = $usr_data[1];
  208.        
  209.                 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'])) {
  210.        
  211.                         $usr_pw1 = trim($_POST['usr_pw1']);
  212.                         $usr_pw2 = trim($_POST['usr_pw2']);
  213.                         $usr_pw3 = trim($_POST['usr_pw3']);
  214.        
  215.                         if ($usr_pw0 == crypt($usr_pw1,$usr_pw0)) {
  216.        
  217.                                 if ($usr_pw2 == $usr_pw3) {
  218.                                        
  219.                                         $usr_pw = crypt($usr_pw2);
  220.        
  221.                                         $usr_query = pg_query($db_link,"update users set pw='$usr_pw' where id='{$_SESSION['logged_uid']}'");
  222.        
  223.                                         if (!usr_query) {
  224.                                                 nak(strtolower(pg_last_error()));
  225.                                         }
  226.                                         else {
  227.                                                 ack("password changed");
  228.                                         }
  229.                                 }
  230.                                 else {
  231.                                         nak("new passwords do not match");
  232.                                 }
  233.                         }
  234.                         else {
  235.                                 nak("current password entered is incorrect");
  236.                         }
  237.                 }
  238.         }
  239.  
  240.         if ($_SESSION['logged_lvl'] == "postmaster") {
  241.        
  242.                 $dom_query = pg_query($db_link,"select mode from domains where id='{$_SESSION['logged_uid']}'");
  243.                 $dom_query = pg_fetch_row($dom_query);
  244.        
  245.                 if ($dom_query[0] == "0") {
  246.                         nak("{$_SESSION['logged_uid']} disabled by admin - new settings will take effect once it is re-enabled");
  247.                 }
  248.        
  249.                 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'])) {
  250.        
  251.                         $pm_id = trim($_POST['pm_id']);
  252.                         $pm_id = strtolower($pm_id);
  253.        
  254.                         if (preg_match("/@/",$pm_id)) {
  255.                                 $pm_id = substr($pm_id,0,strpos($pm_id,"@"));
  256.                         }
  257.        
  258.                         $pm_addr = $pm_id . "@" . $_SESSION['logged_uid'];
  259.        
  260.                         $alias_query = pg_query($db_link,"select id from aliases where id='$pm_addr'");
  261.        
  262.                         if (pg_fetch_row($alias_query) > 0) {
  263.                                 nak("$pm_addr alias exists");
  264.                         }
  265.                         else {
  266.                                 $pm_name = trim($_POST['pm_name']);
  267.                                 $pm_name = ucwords($pm_name);
  268.        
  269.                                 $pm_pw = trim($_POST['pm_pw']);
  270.                                 $pm_pw = crypt($pm_pw);
  271.        
  272.                                 $pm_init = substr($pm_id,0,1);
  273.        
  274.                                 $pm_maildir = "{$_SESSION['logged_uid']}/$pm_init/$pm_id";
  275.  
  276.                                 $pm_host = trim($_POST['pm_host']);
  277.                                 $pm_host = strtolower($pm_host);
  278.        
  279.                                 $pm_query = pg_query($db_link,"insert into users values('$pm_addr','$pm_pw','$pm_maildir/','$pm_name','{$_SESSION['logged_uid']}','1','$pm_host')");
  280.        
  281.                                 if (!$pm_query) {
  282.                                         nak(strtolower(pg_last_error()));
  283.                                 }
  284.                                 else {
  285.                                         if (!file_exists("$mail_root/{$_SESSION['logged_uid']}")) {
  286.                                                 mkdir("$mail_root/{$_SESSION['logged_uid']}");
  287.                                         }
  288.        
  289.                                         if (!file_exists("$mail_root/{$_SESSION['logged_uid']}/$pm_init")) {
  290.                                                 mkdir("$mail_root/{$_SESSION['logged_uid']}/$pm_init");
  291.                                         }
  292.        
  293.                                         if (!file_exists("$mail_root/$pm_maildir")) {
  294.                                                 mkdir("$mail_root/$pm_maildir");
  295.                                         }
  296.        
  297.                                         if (!file_exists("$mail_root/$pm_maildir/cur")) {
  298.                                                 mkdir("$mail_root/$pm_maildir/cur");
  299.                                         }
  300.                
  301.                                         if (!file_exists("$mail_root/$pm_maildir/new")) {
  302.                                                 mkdir("$mail_root/$pm_maildir/new");
  303.                                         }
  304.        
  305.                                         if (!file_exists("$mail_root/$pm_maildir/tmp")) {
  306.                                                 mkdir("$mail_root/$pm_maildir/tmp");
  307.                                         }
  308.        
  309.                                         ack("$pm_addr added");
  310.                                 }
  311.                         }
  312.                 }
  313.  
  314.                 if (isset($_POST['pm_mod']) and !empty($_POST['pm_mod'])) {
  315.                        
  316.                         $pm_mod = trim($_POST['pm_mod']);
  317.        
  318.                         if (isset($_POST['pm_name']) and !empty($_POST['pm_name'])) {
  319.        
  320.                                 $pm_name = trim($_POST['pm_name']);
  321.                                 $pm_name = ucwords($pm_name);
  322.        
  323.                                 $pm_query = pg_query($db_link,"select name from users where id='$pm_mod'");
  324.        
  325.                                 $name_get = pg_fetch_row($pm_query);
  326.        
  327.                                 if ($name_get[0] != $pm_name) {
  328.        
  329.                                         $pm_query = pg_query($db_link,"update users set name='$pm_name' where id='$pm_mod'");
  330.        
  331.                                         if (!$pm_query) {
  332.                                                 nak(strtolower(pg_last_error()));
  333.                                         }
  334.                                         else {
  335.                                                 ack("$pm_mod complete name updated");
  336.                                         }
  337.                                 }
  338.                         }
  339.        
  340.                         if (isset($_POST['pm_pass']) and !empty($_POST['pm_pass'])) {
  341.        
  342.                                 $pm_pass = $_POST['pm_pass'];
  343.                                 $pm_pass = crypt($pm_pass);
  344.        
  345.                                 $pm_query = pg_query($db_link,"update users set pw='$pm_pass' where id='$pm_mod'");
  346.        
  347.                                 if (!$pm_query) {
  348.                                         nak(strtolower(pg_last_error()));
  349.                                 }
  350.                                 else {
  351.                                         ack("$pm_mod password updated");
  352.                                 }
  353.                         }
  354.  
  355.                         if (isset($_POST['pm_host'])) {
  356.        
  357.                                 $pm_host = trim($_POST['pm_host']);
  358.                                 $pm_host = strtolower($pm_host);
  359.        
  360.                                 $pm_query = pg_query($db_link,"select host from users where id='$pm_mod'");
  361.        
  362.                                 $host_get = pg_fetch_row($pm_query);
  363.        
  364.                                 if ($host_get[0] != $pm_host) {
  365.        
  366.                                         $pm_query = pg_query($db_link,"update users set host='$pm_host' where id='$pm_mod'");
  367.        
  368.                                         if (!$pm_query) {
  369.                                                 nak(strtolower(pg_last_error()));
  370.                                         }
  371.                                         else {
  372.                                                 ack("$pm_mod delivery host updated");
  373.                                         }
  374.                                 }
  375.                         }
  376.                 }
  377.        
  378.                 if (isset($_POST['pm_set']) and !empty($_POST['pm_set']) and isset($_POST['pm_do']) and !empty($_POST['pm_do'])) {
  379.        
  380.                         $pm_set = trim($_POST['pm_set']);
  381.                         $pm_do = trim($_POST['pm_do']);
  382.        
  383.                         if ($pm_do == "disable") {
  384.                                 $pm_do = "0";
  385.                         }
  386.        
  387.                         if ($pm_do == "enable") {
  388.                                 $pm_do = "1";
  389.                         }
  390.                
  391.                         $pm_query = pg_query($db_link,"update aliases set mode='$pm_do' where alias='$pm_set'");
  392.                         $pm_query = pg_query($db_link,"update users set mode='$pm_do' where id='$pm_set'");
  393.        
  394.                         if (!$pm_query) {
  395.                                 nak(strtolower(pg_last_error()));
  396.                         }
  397.                         else {
  398.        
  399.                                 $pm_query = pg_query($db_link,"select alias from aliases where alias='$pm_set'");
  400.                                 $pm_aka = pg_num_rows($pm_query);
  401.        
  402.                                 if ($pm_do == "0") {
  403.        
  404.                                         if ($pm_aka > 0) {
  405.        
  406.                                                 if ($pm_aka < 2) {
  407.                                                         ack("$pm_set account and 1 alias disabled");
  408.                                                 }
  409.                                                 else {
  410.                                                         ack("$pm_set account and $pm_aka aliases disabled");
  411.                                                 }
  412.                                         }
  413.                                         else {
  414.                                                 ack("$pm_set account disabled");
  415.                                         }
  416.                                 }
  417.        
  418.                                 if ($pm_do == "1") {
  419.        
  420.                                         if (pg_fetch_row($pm_query) > 0) {
  421.        
  422.                                                 if ($pm_aka < 2) {
  423.                                                         ack("$pm_set account and 1 alias enabled");
  424.                                                 }
  425.                                                 else {
  426.                                                         ack("$pm_set account and $pm_aka aliases enabled");
  427.                                                 }
  428.                                         }
  429.                                         else {
  430.                                                 ack("$pm_set account enabled");
  431.                                         }
  432.                                 }
  433.                         }
  434.                 }
  435.        
  436.                 if (isset($_POST['pm_del']) and !empty($_POST['pm_del'])) {
  437.                        
  438.                         $pm_del = trim($_POST['pm_del']);
  439.        
  440.                         $pm_query = pg_query($db_link,"delete from aliases where alias='$pm_del'");
  441.                         $pm_query = pg_query($db_link,"delete from users where id='$pm_del'");
  442.        
  443.                         if (!$pm_query) {
  444.                                 nak(strtolower(pg_last_error()));
  445.                         }
  446.                         else {
  447.                                 $pm_init = substr($pm_del,0,1);
  448.                                 $pm_box = substr($pm_del,0,strpos($pm_del,"@"));
  449.        
  450.                                 if (file_exists("$mail_root/{$_SESSION['logged_uid']}/$pm_init/$pm_box")) {
  451.                                         rmdirr("$mail_root/{$_SESSION['logged_uid']}/$pm_init/$pm_box");
  452.                                 }
  453.        
  454.                                 if (count(glob("$mail_root/{$_SESSION['logged_uid']}/$pm_init/*")) < 1) {
  455.                                         rmdir("$mail_root/{$_SESSION['logged_uid']}/$pm_init");
  456.                                 }
  457.        
  458.                                 ack("$pm_del deleted");
  459.                         }
  460.                 }
  461.        
  462.                 if (isset($_POST['alias_add']) and !empty($_POST['alias_add']) and isset($_POST['alias_to']) and !empty($_POST['alias_to'])) {
  463.        
  464.                         $alias_add = trim($_POST['alias_add']);
  465.        
  466.                         if (preg_match("/@/",$alias_add)) {
  467.                                 $alias_add = substr($alias_add,0,strpos($alias_add,"@"));
  468.                         }
  469.        
  470.                         $alias_add = "$alias_add@{$_SESSION['logged_uid']}";
  471.        
  472.                         $alias_to = trim($_POST['alias_to']);
  473.        
  474.                         $alias_query = pg_query($db_link,"select id from users where id='$alias_add'");
  475.        
  476.                         if (pg_num_rows($alias_query) > 0) {
  477.                                 nak("$alias_add account exists");
  478.                         }
  479.                         else {
  480.                                 if (!preg_match("/@/",$alias_to) or preg_match("/@{$_SESSION['logged_uid']}/",$alias_to)) {
  481.        
  482.                                         if (preg_match("/@{$_SESSION['logged_uid']}/",$alias_to)) {
  483.                                                 $alias_to = substr($alias_to,0,strpos($alias_to,"@"));
  484.                                         }
  485.                
  486.                                         $alias_to = "$alias_to@{$_SESSION['logged_uid']}";
  487.                
  488.                                         $alias_query = pg_query($db_link,"select id from users where id='$alias_to'");
  489.                
  490.                                         if (pg_num_rows($alias_query) < 1) {
  491.                                                 nak("$alias_to does not exist");
  492.                                         }
  493.                                         else {
  494.                                                 $alias_query = pg_query($db_link,"insert into aliases values('$alias_add','$alias_to','{$_SESSION['logged_uid']}','1')");
  495.                
  496.                                                 if (!$alias_query) {
  497.                                                         nak(strtolower(pg_last_error()));
  498.                                                 }
  499.                                                 else {
  500.                                                         ack("$alias_add added");
  501.                                                 }
  502.                                         }
  503.                                 }
  504.                                 else {
  505.                                         $alias_query = pg_query($db_link,"insert into aliases values('$alias_add','$alias_to','{$_SESSION['logged_uid']}','1')");
  506.        
  507.                                         if (!$alias_query) {
  508.                                                 nak(strtolower(pg_last_error()));
  509.                                         }
  510.                                         else {
  511.                                                 ack("$alias_add added");
  512.                                         }
  513.                                 }
  514.                         }
  515.                 }
  516.        
  517.                 if (isset($_POST['alias_mod']) and !empty($_POST['alias_mod']) and isset($_POST['alias_to']) and !empty($_POST['alias_to'])) {
  518.                        
  519.                         $alias_mod = trim($_POST['alias_mod']);
  520.        
  521.                         $alias_to = trim($_POST['alias_to']);
  522.        
  523.                         if (!preg_match("/@/",$alias_to) or preg_match("/@{$_SESSION['logged_uid']}/",$alias_to)) {
  524.        
  525.                                 if (preg_match("/@{$_SESSION['logged_uid']}/",$alias_to)) {
  526.                                         $alias_to = substr($alias_to,0,strpos($alias_to,"@"));
  527.                                 }
  528.        
  529.                                 $alias_to = "$alias_to@{$_SESSION['logged_uid']}";
  530.        
  531.                                 $alias_query = pg_query($db_link,"select id from users where id='$alias_to'");
  532.        
  533.                                 if (pg_num_rows($alias_query) < 1) {
  534.                                         nak("$alias_to does not exist");
  535.                                 }
  536.                                 else {
  537.                                         $alias_query = pg_query($db_link,"update aliases set alias='$alias_to' where id='$alias_mod'");
  538.        
  539.                                         if (!$alias_query) {
  540.                                                 nak(strtolower(pg_last_error()));
  541.                                         }
  542.                                         else {
  543.                                                 ack("$alias_mod updated");
  544.                                         }
  545.                                 }
  546.                         }
  547.                         else {
  548.        
  549.                                 $alias_query = pg_query($db_link,"update aliases set alias='$alias_to' where id='$alias_mod'");
  550.                
  551.                                 if (!$alias_query) {
  552.                                         nak(strtolower(pg_last_error()));
  553.                                 }
  554.                                 else {
  555.                                         ack("$alias_mod updated");
  556.                                 }
  557.                         }
  558.                 }
  559.        
  560.                 if (isset($_POST['alias_set']) and !empty($_POST['alias_set']) and isset($_POST['alias_do']) and !empty($_POST['alias_do'])) {
  561.        
  562.                         $alias_set = trim($_POST['alias_set']);
  563.                         $alias_do = trim($_POST['alias_do']);
  564.        
  565.                         if ($alias_do == "disable") {
  566.                                 $alias_do = "0";
  567.                                 $alias_query = pg_query($db_link,"update aliases set mode='$alias_do' where id='$alias_set'");
  568.        
  569.                                 if (!$alias_query) {
  570.                                         nak(strtolower(pg_last_error()));
  571.                                 }
  572.                                 else {
  573.                                         ack("$alias_set alias disabled");
  574.                                 }
  575.                         }
  576.        
  577.                         if ($alias_do == "enable") {
  578.        
  579.                                 $alias_query = pg_query($db_link,"select alias from aliases where id='$alias_set'");
  580.                                 $alias_recipient = pg_fetch_row($alias_query);
  581.                                 $alias_recipient = $alias_recipient[0];
  582.        
  583.                                 $usr_query = pg_query($db_link,"select mode from users where id='$alias_recipient'");
  584.                                 $alias_recipient_mode = pg_fetch_row($usr_query);
  585.                                 $alias_recipient_mode = $alias_recipient_mode[0];
  586.        
  587.                                 if ($alias_recipient_mode == "0") {
  588.                                         nak("cannot enable $alias_set alias while $alias_recipient recipient account is disabled");
  589.                                 }
  590.                                 else {
  591.                                         $alias_do = "1";
  592.                                         $alias_query = pg_query($db_link,"update aliases set mode='$alias_do' where id='$alias_set'");
  593.                
  594.                                         if (!$alias_query) {
  595.                                                 nak(strtolower(pg_last_error()));
  596.                                         }
  597.                                         else {
  598.                                                 ack("$alias_set alias enabled");
  599.                                         }
  600.                                 }
  601.                         }
  602.                 }
  603.        
  604.                 if (isset($_POST['alias_del']) and !empty($_POST['alias_del'])) {
  605.                        
  606.                         $alias_del = trim($_POST['alias_del']);
  607.                         $alias_query = pg_query($db_link,"delete from aliases where id='$alias_del'");
  608.        
  609.                         if (!$alias_query) {
  610.                                 nak(strtolower(pg_last_error()));
  611.                         }
  612.                         else {
  613.                                 ack("$alias_del deleted");
  614.                         }
  615.                 }
  616.         }
  617.        
  618.         if ($_SESSION['logged_lvl'] == "administrator") {
  619.  
  620.                 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'])) {
  621.        
  622.                         $dom_name = trim($_POST['dom_name']);
  623.        
  624.                         $dom_pass = trim($_POST['dom_pass']);
  625.                         $dom_pass = crypt($dom_pass);
  626.        
  627.                         $dom_max = trim($_POST['dom_max']);
  628.        
  629.                         $dom_query = pg_query($db_link,"insert into domains values('$dom_name','$dom_pass','$dom_max','1')");
  630.        
  631.                         if (!$dom_query) {
  632.                                 nak(strtolower(pg_last_error()));
  633.                         }
  634.                         else {
  635.                                 if (!file_exists("$mail_root/$dom_name")) {
  636.                                         mkdir("$mail_root/$dom_name");
  637.                                 }
  638.        
  639.                                 ack("$dom_name added");
  640.                         }
  641.                 }
  642.        
  643.                 if (isset($_POST['dom_mod']) and !empty($_POST['dom_mod'])) {
  644.                        
  645.                         $dom_mod = trim($_POST['dom_mod']);
  646.        
  647.                         if (isset($_POST['dom_pass']) and !empty($_POST['dom_pass'])) {
  648.        
  649.                                 $dom_pass = $_POST['dom_pass'];
  650.                                 $dom_pass = crypt($dom_pass);
  651.        
  652.                                 $dom_query = pg_query($db_link,"update domains set pw='$dom_pass' where id='$dom_mod'");
  653.        
  654.                                 if (!$dom_query) {
  655.                                         nak(strtolower(pg_last_error()));
  656.                                 }
  657.                                 else {
  658.                                         ack("$dom_mod postmaster password updated");
  659.                                 }
  660.                         }
  661.        
  662.                         if (isset($_POST['dom_max']) and is_numeric($_POST['dom_max'])) {
  663.        
  664.                                 $dom_max = $_POST['dom_max'];
  665.        
  666.                                 $dom_query = pg_query($db_link,"select max from domains where id='$dom_mod'");
  667.        
  668.                                 $max_get = pg_fetch_row($dom_query);
  669.        
  670.                                 if ($max_get[0] != $dom_max) {
  671.        
  672.                                         $dom_query = pg_query($db_link,"update domains set max='$dom_max' where id='$dom_mod'");
  673.        
  674.                                         if (!$dom_query) {
  675.                                                 nak(strtolower(pg_last_error()));
  676.                                         }
  677.                                         else {
  678.                                                 ack("$dom_mod account limit updated");
  679.                                         }
  680.                                 }
  681.                         }
  682.                 }
  683.        
  684.                 if (isset($_POST['dom_set']) and !empty($_POST['dom_set']) and isset($_POST['dom_do']) and !empty($_POST['dom_do'])) {
  685.        
  686.                         $dom_set = trim($_POST['dom_set']);
  687.                         $dom_do = trim($_POST['dom_do']);
  688.        
  689.                         if ($dom_do == "disable") {
  690.                                 $dom_do = "0";
  691.                         }
  692.        
  693.                         if ($dom_do == "enable") {
  694.                                 $dom_do = "1";
  695.                         }
  696.                
  697.                         $dom_query = pg_query($db_link,"update domains set mode='$dom_do' where id='$dom_set'");
  698.        
  699.                         if (!$dom_query) {
  700.                                 nak(strtolower(pg_last_error()));
  701.                         }
  702.                         else {
  703.                                 if ($dom_do == "0") {
  704.                                         ack("$dom_set disabled");
  705.                                 }
  706.        
  707.                                 if ($dom_do == "1") {
  708.                                         ack("$dom_set enabled");
  709.                                 }
  710.                         }
  711.                 }
  712.        
  713.                 if (isset($_POST['dom_del']) and !empty($_POST['dom_del'])) {
  714.                        
  715.                         $dom_del = trim($_POST['dom_del']);
  716.        
  717.                         $dom_query = pg_query($db_link,"delete from aliases where domain='$dom_del'");
  718.                         $dom_query = pg_query($db_link,"delete from users where domain='$dom_del'");
  719.                         $dom_query = pg_query($db_link,"delete from domains where id='$dom_del'");
  720.        
  721.                         if (!$dom_query) {
  722.                                 nak(strtolower(pg_last_error()));
  723.                         }
  724.                         else {
  725.                                 if (file_exists("$mail_root/$dom_del")) {
  726.                                         rmdirr("$mail_root/$dom_del");
  727.                                 }
  728.                                 ack("$dom_del deleted");
  729.                         }
  730.                 }
  731.         }
  732.        
  733.         echo "</td></tr>";
  734.  
  735.         echo "<tr><td valign=\"top\">";
  736.  
  737.         if ($_SESSION['logged_lvl'] == "subscriber") {
  738.  
  739.                 echo "<table border=\"0\" cellspacing=\"1\" cellpadding=\"2\" bgcolor=\"#cccccc\">";
  740.                 echo "<form method=\"post\">";
  741.                 echo "<tr bgcolor=\"#ffffff\"><td align=\"center\" valign=\"middle\"><img src=\"images/user.png\" border=\"0\" width=\"16\" height=\"16\"></td><td><input class=\"input\" type=\"text\" name=\"usr_name\" value=\"$usr_name\" autocomplete=\"off\" maxlength=\"128\"></td></tr>";
  742.                 echo "<tr bgcolor=\"#ffffff\"><td align=\"center\" valign=\"middle\"><img src=\"images/pass.png\" border=\"0\" width=\"16\" height=\"16\"></td><td><input class=\"input\" type=\"password\" name=\"usr_pw1\" autocomplete=\"off\" maxlength=\"64\"></td></tr>";
  743.                 echo "<tr bgcolor=\"#ffffff\"><td align=\"center\" valign=\"middle\"><img src=\"images/pass.png\" border=\"0\" width=\"16\" height=\"16\"></td><td><input class=\"input\" type=\"password\" name=\"usr_pw2\" autocomplete=\"off\" maxlength=\"64\"></td></tr>";
  744.                 echo "<tr bgcolor=\"#ffffff\"><td align=\"center\" valign=\"middle\"><img src=\"images/pass.png\" border=\"0\" width=\"16\" height=\"16\"></td><td><input class=\"input\" type=\"password\" name=\"usr_pw3\" autocomplete=\"off\" maxlength=\"64\"></td></tr>";
  745.                 echo "<tr bgcolor=\"#ffffff\"><td align=\"center\" valign=\"middle\"></td><td><input class=\"input\" type=\"submit\" value=\"update\"></td></tr>";
  746.                 echo "</form>";
  747.                 echo "</table>";
  748.         }
  749.  
  750.         if ($_SESSION['logged_lvl'] == "postmaster") {
  751.        
  752.                 echo "<table border=\"0\" cellspacing=\"1\" cellpadding=\"2\" bgcolor=\"#cccccc\">";
  753.                 echo "<tr bgcolor=\"#ffffff\"><td colspan=\"4\" align=\"center\"><b>status</b></td><td align=\"center\"><b>username</b></td><td align=\"center\"><b>complete name</b></td><td align=\"center\"><b>password</b></td><td align=\"center\"><b>host</b></td><td align=\"center\" colspan=\"2\"><b>action</b></td></tr>";
  754.                 echo "<form method=\"post\">";
  755.                 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=\"input\" type=\"submit\" value=\"add\"></td></tr>";
  756.                 echo "</form>";
  757.        
  758.                 $pm_get = pg_query($db_link,"select * from users where domain='{$_SESSION['logged_uid']}' order by id");
  759.        
  760.                 while ($pm_row = pg_fetch_array($pm_get)) {
  761.        
  762.                         if ($pm_row[5] == "1") {
  763.                                 $pm_do = "disable";
  764.                                 $pm_bg = "#ffffff";
  765.                         }
  766.        
  767.                         if ($pm_row[5] == "0") {
  768.                                 $pm_do = "enable";
  769.                                 $pm_bg = "#eeeeee";
  770.                         }
  771.        
  772.                         $msg_new = "$mail_root/{$_SESSION['logged_uid']}/" . substr($pm_row[0],0,1) . "/" . substr($pm_row[0],0,strpos($pm_row[0],"@")) . "/new/*";
  773.                         $msg_new = count(glob($msg_new));
  774.        
  775.                         $msg_cur = "$mail_root/{$_SESSION['logged_uid']}/" . substr($pm_row[0],0,1) . "/" . substr($pm_row[0],0,strpos($pm_row[0],"@")) . "/cur/*";
  776.                         $msg_cur = count(glob($msg_cur));
  777.        
  778.                         $pm_aka = pg_query($db_link,"select * from aliases where alias='{$pm_row[0]}'");
  779.                         $pm_aka = pg_num_rows($pm_aka);
  780.        
  781.                         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><b>{$pm_row[0]}</b></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=\"input\" type=\"submit\" value=\"mod\"></td></form><form method=\"post\"><input type=\"hidden\" name=\"pm_del\" value=\"{$pm_row[0]}\"><td><input class=\"input\" 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>";
  782.                 }
  783.        
  784.                 echo "</table>";
  785.         }
  786.  
  787.         if ($_SESSION['logged_lvl'] == "administrator") {
  788.        
  789.                 echo "<table border=\"0\" cellspacing=\"1\" cellpadding=\"2\" bgcolor=\"#cccccc\">";
  790.                 echo "<tr bgcolor=\"#ffffff\"><td colspan=\"2\" align=\"center\"><b>status</b></td><td align=\"center\"><nobr><b>domain name</b></nobr></td><td align=\"center\"><nobr><b>account limit</b></nobr></td><td align=\"center\"><nobr><b>postmaster password</b></nobr></td><td align=\"center\" colspan=\"2\"><b>action</b></td></tr>";
  791.                 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=\"rinput\" 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=\"input\" type=\"submit\" value=\"add\" autocomplete=\"off\"></td></tr></form>";
  792.        
  793.                 $dom_get = pg_query($db_link,"select * from domains order by id");
  794.        
  795.                 while ($dom_row = pg_fetch_array($dom_get)) {
  796.  
  797.                         $dom_usr = pg_query($db_link,"select * from users where domain='{$dom_row[0]}'");
  798.                         $dom_usr = pg_num_rows($dom_usr);
  799.        
  800.                         if ($dom_row[3] == "1") {
  801.                                 $dom_do = "disable";
  802.                                 $dom_bg = "#ffffff";
  803.                         }
  804.        
  805.                         if ($dom_row[3] == "0") {
  806.                                 $dom_do = "enable";
  807.                                 $dom_bg = "#eeeeee";
  808.                         }
  809.        
  810.                         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><b>{$dom_row[0]}</b></td><td><input class=\"rinput\" 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=\"input\" type=\"submit\" value=\"mod\"></td></form><form method=\"post\"><input type=\"hidden\" name=\"dom_del\" value=\"{$dom_row[0]}\"><td><input class=\"input\" 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>";
  811.                 }
  812.        
  813.                 echo "</table>";
  814.         }
  815.        
  816.         echo "</td>";
  817.  
  818.         if ($_SESSION['logged_lvl'] == "postmaster") {
  819.        
  820.                 echo "<td width=\"10\"></td><td valign=\"top\">";
  821.  
  822.                 echo "<table border=\"0\" cellspacing=\"1\" cellpadding=\"2\" bgcolor=\"#cccccc\">";
  823.                 echo "<tr bgcolor=\"#ffffff\"><td align=\"center\"><b>alias</b></td><td align=\"center\"><b>recipient</b></td><td align=\"center\" colspan=\"3\"><b>action</b></td></tr>";
  824.                 echo "<form method=\"post\">";
  825.                 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=\"input\" type=\"submit\" value=\"add\"></td></tr>";
  826.                 echo "</form>";
  827.        
  828.                 $get_aliases = pg_query($db_link,"select * from aliases where domain='{$_SESSION['logged_uid']}' order by id");
  829.        
  830.                 while ($aliases_row = pg_fetch_array($get_aliases)) {
  831.        
  832.                         if ($aliases_row[3] == "1") {
  833.                                 $alias_do = "disable";
  834.                                 $alias_bg = "#ffffff";
  835.                         }
  836.        
  837.                         if ($aliases_row[3] == "0") {
  838.                                 $alias_do = "enable";
  839.                                 $alias_bg = "#eeeeee";
  840.                         }
  841.        
  842.                         echo "<tr bgcolor=\"$alias_bg\"><form method=\"post\"><input type=\"hidden\" name=\"alias_mod\" value=\"{$aliases_row[0]}\"><td><b>{$aliases_row[0]}</b></td><td><input class=\"input\" type=\"text\" name=\"alias_to\" maxlength=\"255\" autocomplete=\"off\" value=\"{$aliases_row[1]}\"></td><td><input class=\"input\" 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=\"input\" 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>";
  843.                 }
  844.        
  845.                 echo "</table>";
  846.         }
  847.  
  848.         echo "</td></tr>";
  849.         echo "</table>";
  850. }
  851.  
  852. pg_close($db_link);
  853.  
  854. ?>
  855.  
filedropkartero.git-41992ae.tar.bz2 new
412.12 KB
88 downloads
filedropkartero.git-41992ae.zip
448.41 KB
49 downloads
filedropkartero.git-b404ba2.tar.bz2
411.70 KB
79 downloads
filedropkartero.git-b404ba2.zip
447.96 KB
48 downloads
filedropkartero.git-a7684d9.tar.bz2
411.72 KB
325 downloads
filedropkartero.git-a7684d9.zip
447.96 KB
25 downloads
filedropkartero.git-83512be.tar.bz2
410.26 KB
297 downloads
filedropkartero.git-83512be.zip
445.30 KB
242 downloads
filedropkartero.git-1954b25.tar.bz2
410.21 KB
304 downloads
filedropkartero.git-1954b25.zip
445.30 KB
242 downloads
filedropkartero.git-2f7c910.tar.bz2
410.25 KB
45 downloads
filedropkartero.git-2f7c910.zip
445.29 KB
34 downloads
filedropkartero.git-6317ffb.tar.bz2
410.40 KB
265 downloads
filedropkartero.git-6317ffb.zip
445.28 KB
9 downloads
filedropkartero.git-60ccd7a.tar.bz2
410.40 KB
254 downloads
filedropkartero.git-60ccd7a.zip
445.20 KB
6 downloads
filedropkartero.git-ea6f885.tar.bz2
410.47 KB
61 downloads
filedropkartero.git-ea6f885.zip
445.26 KB
181 downloads
filedropkartero.git-7f580e5.zip
445.17 KB
173 downloads
filedropkartero.git-7f580e5.tar.bz2
410.18 KB
207 downloads
filedropkartero.git-b9364de.tar.bz2
409.41 KB
202 downloads
filedropkartero.git-b9364de.zip
444.09 KB
425 downloads
filedropkartero.git-e9bcd78.zip
444.03 KB
411 downloads
filedropkartero.git-e9bcd78.tar.bz2
409.39 KB
468 downloads
filedropkartero.git-96c60ff.tar.bz2
407.96 KB
10 downloads
filedropkartero.git-96c60ff.zip
441.87 KB
381 downloads
filedropkartero.git-4357b59.tar.bz2
407.17 KB
455 downloads
filedropkartero.git-4357b59.zip
440.69 KB
379 downloads
filedropkartero.git-c6ff319.tar.bz2
407.28 KB
10 downloads
filedropkartero.git-c6ff319.zip
440.70 KB
358 downloads
filedropkartero.git-8b87a29.tar.bz2
407.27 KB
426 downloads
filedropkartero.git-8b87a29.zip
440.71 KB
357 downloads
filedropkartero.git-ee42942.tar.bz2
406.49 KB
389 downloads
filedropkartero.git-ee42942.zip
439.92 KB
343 downloads
filedropkartero.git-867e7e6.tar.bz2
406.75 KB
37 downloads
filedropkartero.git-867e7e6.zip
440.03 KB
343 downloads
filedropkartero.git-3f3fc02.tar.bz2
406.38 KB
415 downloads
filedropkartero.git-3f3fc02.zip
439.71 KB
366 downloads
filedropkartero.git-b6f779d.tar.bz2
406.55 KB
439 downloads
filedropkartero.git-b6f779d.zip
440.00 KB
327 downloads
filedropkartero.git-83f24b0.zip
439.12 KB
303 downloads
filedropkartero.git-52316ec.tar.bz2
406.17 KB
385 downloads
filedropkartero.git-52316ec.zip
439.18 KB
329 downloads
filedropkartero.git-83f24b0.tar.bz2
405.84 KB
382 downloads
filedropkartero.git-8a42d47.tar.bz2
405.73 KB
341 downloads
filedropkartero.git-8a42d47.zip
439.02 KB
296 downloads
filedropkartero.git-830c9cb.tar.bz2
406.08 KB
346 downloads
filedropkartero.git-830c9cb.zip
439.08 KB
299 downloads
filedropkartero.git-ebec1be.tar.bz2
406.16 KB
351 downloads
filedropkartero.git-ebec1be.zip
439.09 KB
326 downloads
filedropkartero.git-7c0b70f.tar.bz2
402.43 KB
333 downloads
filedropkartero.git-7c0b70f.zip
435.91 KB
291 downloads
filedropkartero.git-80edc03.tar.bz2
402.75 KB
34 downloads
filedropkartero.git-80edc03.zip
435.84 KB
301 downloads
filedropkartero.git-b408c23.tar.bz2
402.19 KB
35 downloads
filedropkartero.git-b408c23.zip
435.59 KB
310 downloads
filedropkartero.git-29c0e1f.tar.bz2
401.84 KB
345 downloads
filedropkartero.git-29c0e1f.zip
435.25 KB
319 downloads
filedropkartero.git-9086094.tar.bz2
401.94 KB
348 downloads
filedropkartero.git-9086094.zip
435.34 KB
319 downloads
filedropkartero.git-47ca624.tar.bz2
402.10 KB
344 downloads
filedropkartero.git-47ca624.zip
435.51 KB
287 downloads
filedropkartero.git-81314a5.zip
435.53 KB
308 downloads
filedropkartero.git-81314a5.tar.bz2
402.25 KB
340 downloads
filedropkartero.git-cae7074.zip
435.20 KB
303 downloads
filedropkartero.git-cae7074.tar.bz2
401.98 KB
350 downloads
filedropkartero.git-cc68e56.tar.bz2
402.07 KB
340 downloads
filedropkartero.git-cc68e56.zip
435.16 KB
331 downloads
filedropkartero.git-230f35d.tar.bz2
401.43 KB
319 downloads
filedropkartero.git-230f35d.zip
434.68 KB
319 downloads
filedropkartero.git-5ae58a2.tar.bz2
401.54 KB
325 downloads
filedropkartero.git-5ae58a2.zip
434.68 KB
292 downloads
filedropkartero.git-a591f4b.tar.bz2
401.76 KB
325 downloads
filedropkartero.git-a591f4b.zip
435.17 KB
301 downloads
filedropkartero.git-36876c8.tar.bz2
400.44 KB
321 downloads
filedropkartero.git-36876c8.zip
432.36 KB
324 downloads
filedropkartero.git-a34c9ed.tar.bz2
400.57 KB
338 downloads
filedropkartero.git-a34c9ed.zip
432.27 KB
313 downloads
filedropkartero.git-e828148.zip
433.58 KB
292 downloads
filedropkartero.git-e828148.tar.bz2
400.88 KB
333 downloads
filedropkartero.git-476cdda.tar.bz2
400.60 KB
363 downloads
filedropkartero.git-476cdda.zip
432.26 KB
305 downloads
filedropkartero.git-054c286.tar.bz2
98.09 KB
82 downloads
filedropkartero.git-054c286.zip
109.53 KB
370 downloads
filedropkartero.git-071b099.tar.bz2
98.76 KB
458 downloads
filedropkartero.git-071b099.zip
110.21 KB
369 downloads
filedropkartero.git-551c38d.tar.bz2
98.51 KB
76 downloads
filedropkartero.git-551c38d.zip
110.20 KB
362 downloads
filedropkartero.git-569dc0c.tar.bz2
98.40 KB
80 downloads
filedropkartero.git-569dc0c.zip
109.86 KB
355 downloads
filedropkartero.git-58a052b.tar.bz2
97.95 KB
76 downloads
filedropkartero.git-58a052b.zip
109.36 KB
366 downloads
filedropkartero.git-43a5af3.tar.bz2
97.80 KB
450 downloads
filedropkartero.git-43a5af3.zip
109.30 KB
364 downloads
filedropkartero.git-bbe069d.tar.bz2
98.03 KB
459 downloads
filedropkartero.git-bbe069d.zip
109.19 KB
371 downloads
filedropkartero.git-02f97e1.tar.bz2
97.76 KB
429 downloads
filedropkartero.git-02f97e1.zip
109.24 KB
459 downloads
filedropkartero.git-d82e393.tar.bz2
97.74 KB
461 downloads
filedropkartero.git-d82e393.zip
109.24 KB
369 downloads
filedropkartero.git-7cdd1f5.tar.bz2
98.03 KB
441 downloads
filedropkartero.git-7cdd1f5.zip
109.24 KB
353 downloads
filedropkartero.git-40825aa.tar.bz2
97.71 KB
444 downloads
filedropkartero.git-40825aa.zip
109.16 KB
387 downloads
filedropkartero.git-3dd941b.tar.bz2
97.69 KB
442 downloads
filedropkartero.git-3dd941b.zip
109.12 KB
363 downloads
filedropkartero.git-50f1e46.tar.bz2
97.65 KB
76 downloads
filedropkartero.git-50f1e46.zip
109.02 KB
362 downloads
filedropkartero.git-fdf9225.tar.bz2
93.19 KB
484 downloads
filedropkartero.git-fdf9225.zip
104.25 KB
375 downloads
filedropkartero.git-21415da.tar.bz2
93.24 KB
441 downloads
filedropkartero.git-21415da.zip
104.22 KB
376 downloads
filedropkartero.git-aff5e89.tar.bz2
93.17 KB
460 downloads
filedropkartero.git-aff5e89.zip
104.22 KB
367 downloads
filedropkartero.git-b27ef39.tar.bz2
91.97 KB
459 downloads
filedropkartero.git-b27ef39.zip
102.80 KB
392 downloads
filedropkartero.git-3d6e8a2.tar.bz2
91.99 KB
78 downloads
filedropkartero.git-3d6e8a2.zip
102.77 KB
387 downloads
filedropkartero.git-1442b69.tar.bz2
91.79 KB
440 downloads
filedropkartero.git-1442b69.zip
102.50 KB
391 downloads
filedropkartero.git-6d15918.tar.bz2
91.56 KB
464 downloads
filedropkartero.git-6d15918.zip
102.28 KB
359 downloads
filedropkartero.git-45140d8.tar.bz2
91.52 KB
79 downloads
filedropkartero.git-45140d8.zip
102.23 KB
365 downloads
filedropkartero.git-d5b48e5.tar.bz2
91.35 KB
449 downloads
filedropkartero.git-d5b48e5.zip
102.01 KB
376 downloads
filedropkartero.git-e007e55.tar.bz2
91.35 KB
461 downloads
filedropkartero.git-e007e55.zip
102.01 KB
349 downloads
filedropkartero.git-30fd7e3.tar.bz2
90.87 KB
78 downloads
filedropkartero.git-30fd7e3.zip
101.44 KB
378 downloads
filedropkartero.git-421a4a7.tar.bz2
88.02 KB
182 downloads
filedropkartero.git-421a4a7.zip
97.96 KB
351 downloads
filedropkartero.git-b49b8bc.tar.bz2
88.09 KB
478 downloads
filedropkartero.git-b49b8bc.zip
97.99 KB
371 downloads
filedropkartero.git-1cc9571.tar.bz2
87.74 KB
458 downloads
filedropkartero.git-1cc9571.zip
97.70 KB
376 downloads
filedropkartero.git-159152f.tar.bz2
87.60 KB
456 downloads
filedropkartero.git-159152f.zip
97.52 KB
380 downloads
filedropkartero.git-35caaf3.tar.bz2
87.74 KB
440 downloads
filedropkartero.git-35caaf3.zip
97.57 KB
363 downloads
filedropkartero.git-3c9d305.zip
96.67 KB
365 downloads
filedropkartero.git-3c9d305.tar.bz2
86.77 KB
445 downloads
filedropkartero.git-14cb2af.tar.bz2
86.41 KB
443 downloads
filedropkartero.git-14cb2af.zip
96.13 KB
367 downloads
filedropkartero.git-e8f00cb.tar.bz2
86.46 KB
465 downloads
filedropkartero.git-e8f00cb.zip
96.21 KB
359 downloads
filedropkartero.git-bdab380.tar.bz2
86.14 KB
454 downloads
filedropkartero.git-bdab380.zip
95.79 KB
361 downloads
filedropkartero.git-48f9134.tar.bz2
85.78 KB
460 downloads
filedropkartero.git-48f9134.zip
95.48 KB
371 downloads
filedropkartero.git-adb9757.tar.bz2
85.67 KB
449 downloads
filedropkartero.git-adb9757.zip
95.37 KB
364 downloads
filedropkartero.git-1601cbd.zip
95.30 KB
376 downloads
filedropkartero.git-1601cbd.tar.bz2
85.69 KB
432 downloads
filedropkartero.git-18a5106.tar.bz2
85.72 KB
435 downloads
filedropkartero.git-18a5106.zip
95.48 KB
377 downloads
filedropkartero.git-a5b1caa.tar.bz2
85.61 KB
467 downloads
filedropkartero.git-a5b1caa.zip
95.36 KB
371 downloads
filedropkartero.git-effff82.zip
97.06 KB
384 downloads
filedropkartero.git-effff82.tar.bz2
87.13 KB
451 downloads
filedropkartero.git-b70d364.tar.bz2
84.09 KB
493 downloads
filedropkartero.git-b70d364.zip
93.67 KB
378 downloads
filedropkartero.git-48f0e53.tar.bz2
84.16 KB
74 downloads
filedropkartero.git-48f0e53.zip
93.66 KB
368 downloads
filedropkartero.git-c17135e.tar.bz2
84.09 KB
451 downloads
filedropkartero.git-c17135e.zip
93.57 KB
357 downloads
filedropkartero.git-a2e2848.tar.bz2
85.59 KB
75 downloads
filedropkartero.git-a2e2848.zip
100.10 KB
371 downloads
filedropkartero.git-1f683db.tar.bz2
83.55 KB
453 downloads
filedropkartero.git-1f683db.zip
93.24 KB
363 downloads
filedropkartero.git-d342596.tar.bz2
83.57 KB
76 downloads
filedropkartero.git-d342596.zip
93.28 KB
357 downloads
filedropkartero.git-e0131d5.tar.bz2
83.55 KB
75 downloads
filedropkartero.git-e0131d5.zip
93.27 KB
373 downloads
filedropkartero.git-ad467e8.tar.bz2
83.13 KB
75 downloads
filedropkartero.git-ad467e8.zip
92.78 KB
364 downloads
filedropkartero.git-b20e27d.tar.bz2
83.46 KB
75 downloads
filedropkartero.git-b20e27d.zip
93.19 KB
390 downloads
filedropkartero.git-eefd8fe.zip
92.67 KB
394 downloads
filedropkartero.git-eefd8fe.tar.bz2
83.01 KB
455 downloads
filedropkartero.git-bea685a.zip
96.88 KB
369 downloads
filedropkartero.git-bea685a.tar.bz2
84.44 KB
449 downloads
filedropkartero.git-a8bd019.tar.bz2
84.25 KB
85 downloads
filedropkartero.git-a8bd019.zip
96.60 KB
364 downloads
filedropkartero.git-cbc914d.tar.bz2
84.38 KB
457 downloads
filedropkartero.git-cbc914d.zip
96.64 KB
353 downloads
filedropkartero.git-09a2e70.tar.bz2
84.40 KB
435 downloads
filedropkartero.git-09a2e70.zip
96.70 KB
377 downloads
filedropkartero.git-641dc05.tar.bz2
84.37 KB
457 downloads
filedropkartero.git-641dc05.zip
96.73 KB
366 downloads
filedropkartero.git-cde49c6.tar.bz2
84.26 KB
468 downloads
filedropkartero.git-cde49c6.zip
96.59 KB
372 downloads
filedropkartero.git-1d004e0.tar.bz2
77.42 KB
466 downloads
filedropkartero.git-1d004e0.zip
87.56 KB
67 downloads
filedropkartero.git-1f0bf17.tar.bz2
77.47 KB
464 downloads
filedropkartero.git-1f0bf17.zip
87.56 KB
364 downloads
filedropkartero.git-265e63c.tar.bz2
77.43 KB
442 downloads
filedropkartero.git-265e63c.zip
87.52 KB
398 downloads
filedropkartero.git-635a5db.zip
87.60 KB
366 downloads
filedropkartero.git-a041f85.tar.bz2
77.37 KB
76 downloads
filedropkartero.git-a041f85.zip
87.52 KB
398 downloads
filedropkartero.git-ae049a7.tar.bz2
77.44 KB
466 downloads
filedropkartero.git-ae049a7.zip
87.52 KB
365 downloads
filedropkartero.git-eef571a.tar.bz2
20.56 KB
572 downloads
filedropkartero.git-eef571a.zip
25.69 KB
497 downloads
filedropkartero.git-0bc16f5.tar.bz2
82.61 KB
81 downloads
filedropkartero.git-0bc16f5.zip
94.75 KB
402 downloads
filedropkartero.git-2afc0f7.tar.bz2
83.61 KB
485 downloads
filedropkartero.git-2afc0f7.zip
96.00 KB
420 downloads
filedropkartero.git-3529bdf.tar.bz2
77.72 KB
74 downloads
filedropkartero.git-3529bdf.zip
87.92 KB
398 downloads
filedropkartero.git-49aac92.tar.bz2
78.98 KB
500 downloads
filedropkartero.git-49aac92.zip
90.01 KB
398 downloads
filedropkartero.git-5d48f21.tar.bz2
78.65 KB
84 downloads
filedropkartero.git-5d48f21.zip
89.51 KB
427 downloads
filedropkartero.git-635a5db.tar.bz2
77.50 KB
505 downloads
filedropkartero.git-6e34786.tar.bz2
77.76 KB
88 downloads
filedropkartero.git-6e34786.zip
88.09 KB
442 downloads
filedropkartero.git-7dc2fd2.tar.bz2
83.51 KB
84 downloads
filedropkartero.git-7dc2fd2.zip
95.99 KB
448 downloads
filedropkartero.git-9cad005.tar.bz2
78.85 KB
79 downloads
filedropkartero.git-9cad005.zip
90.00 KB
492 downloads
filedropkartero.git-b303f61.tar.bz2
82.57 KB
81 downloads
filedropkartero.git-b303f61.zip
94.78 KB
166 downloads
filedropkartero.git-c15ef85.tar.bz2
77.76 KB
252 downloads
filedropkartero.git-c15ef85.zip
88.16 KB
185 downloads
filedropkartero.git-c99e84d.tar.bz2
83.58 KB
77 downloads
filedropkartero.git-c99e84d.zip
96.01 KB
199 downloads
filedropkartero.git-e5009e6.tar.bz2
78.73 KB
287 downloads
filedropkartero.git-e5009e6.zip
89.69 KB
214 downloads
filedropkartero.git-0502d01.tar.bz2
83.54 KB
303 downloads
filedropkartero.git-0502d01.zip
96.00 KB
224 downloads
filedropkartero.git-44ca46d.tar.bz2
83.73 KB
70 downloads
filedropkartero.git-44ca46d.zip
96.20 KB
234 downloads
filedropkartero.git-834f923.tar.bz2
83.75 KB
316 downloads
filedropkartero.git-834f923.zip
96.14 KB
244 downloads