kartero.org

kartero.org

Git

This blob has been accessed 135 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
722 downloads
filedropkartero.git-41992ae.zip
448.41 KB
614 downloads
filedropkartero.git-b404ba2.tar.bz2
411.70 KB
224 downloads
filedropkartero.git-b404ba2.zip
447.96 KB
269 downloads
filedropkartero.git-a7684d9.tar.bz2
411.72 KB
264 downloads
filedropkartero.git-a7684d9.zip
447.96 KB
448 downloads
filedropkartero.git-83512be.tar.bz2
410.26 KB
249 downloads
filedropkartero.git-83512be.zip
445.30 KB
254 downloads
filedropkartero.git-1954b25.tar.bz2
410.21 KB
260 downloads
filedropkartero.git-1954b25.zip
445.30 KB
257 downloads
filedropkartero.git-2f7c910.tar.bz2
410.25 KB
248 downloads
filedropkartero.git-2f7c910.zip
445.29 KB
269 downloads
filedropkartero.git-6317ffb.tar.bz2
410.40 KB
272 downloads
filedropkartero.git-6317ffb.zip
445.28 KB
270 downloads
filedropkartero.git-60ccd7a.tar.bz2
410.40 KB
269 downloads
filedropkartero.git-60ccd7a.zip
445.20 KB
260 downloads
filedropkartero.git-ea6f885.tar.bz2
410.47 KB
260 downloads
filedropkartero.git-ea6f885.zip
445.26 KB
249 downloads
filedropkartero.git-7f580e5.zip
445.17 KB
266 downloads
filedropkartero.git-7f580e5.tar.bz2
410.18 KB
267 downloads
filedropkartero.git-b9364de.tar.bz2
409.41 KB
304 downloads
filedropkartero.git-b9364de.zip
444.09 KB
277 downloads
filedropkartero.git-e9bcd78.zip
444.03 KB
268 downloads
filedropkartero.git-e9bcd78.tar.bz2
409.39 KB
272 downloads
filedropkartero.git-96c60ff.tar.bz2
407.96 KB
281 downloads
filedropkartero.git-96c60ff.zip
441.87 KB
271 downloads
filedropkartero.git-4357b59.tar.bz2
407.17 KB
294 downloads
filedropkartero.git-4357b59.zip
440.69 KB
285 downloads
filedropkartero.git-c6ff319.tar.bz2
407.28 KB
302 downloads
filedropkartero.git-c6ff319.zip
440.70 KB
276 downloads
filedropkartero.git-8b87a29.tar.bz2
407.27 KB
291 downloads
filedropkartero.git-8b87a29.zip
440.71 KB
288 downloads
filedropkartero.git-ee42942.tar.bz2
406.49 KB
261 downloads
filedropkartero.git-ee42942.zip
439.92 KB
271 downloads
filedropkartero.git-867e7e6.tar.bz2
406.75 KB
286 downloads
filedropkartero.git-867e7e6.zip
440.03 KB
277 downloads
filedropkartero.git-3f3fc02.tar.bz2
406.38 KB
288 downloads
filedropkartero.git-3f3fc02.zip
439.71 KB
305 downloads
filedropkartero.git-b6f779d.tar.bz2
406.55 KB
313 downloads
filedropkartero.git-b6f779d.zip
440.00 KB
273 downloads
filedropkartero.git-83f24b0.zip
439.12 KB
256 downloads
filedropkartero.git-52316ec.tar.bz2
406.17 KB
274 downloads
filedropkartero.git-52316ec.zip
439.18 KB
280 downloads
filedropkartero.git-83f24b0.tar.bz2
405.84 KB
271 downloads
filedropkartero.git-8a42d47.tar.bz2
405.73 KB
269 downloads
filedropkartero.git-8a42d47.zip
439.02 KB
259 downloads
filedropkartero.git-830c9cb.tar.bz2
406.08 KB
274 downloads
filedropkartero.git-830c9cb.zip
439.08 KB
259 downloads
filedropkartero.git-ebec1be.tar.bz2
406.16 KB
271 downloads
filedropkartero.git-ebec1be.zip
439.09 KB
290 downloads
filedropkartero.git-7c0b70f.tar.bz2
402.43 KB
263 downloads
filedropkartero.git-7c0b70f.zip
435.91 KB
255 downloads
filedropkartero.git-80edc03.tar.bz2
402.75 KB
276 downloads
filedropkartero.git-80edc03.zip
435.84 KB
266 downloads
filedropkartero.git-b408c23.tar.bz2
402.19 KB
267 downloads
filedropkartero.git-b408c23.zip
435.59 KB
272 downloads
filedropkartero.git-29c0e1f.tar.bz2
401.84 KB
272 downloads
filedropkartero.git-29c0e1f.zip
435.25 KB
282 downloads
filedropkartero.git-9086094.tar.bz2
401.94 KB
274 downloads
filedropkartero.git-9086094.zip
435.34 KB
281 downloads
filedropkartero.git-47ca624.tar.bz2
402.10 KB
274 downloads
filedropkartero.git-47ca624.zip
435.51 KB
252 downloads
filedropkartero.git-81314a5.zip
435.53 KB
271 downloads
filedropkartero.git-81314a5.tar.bz2
402.25 KB
269 downloads
filedropkartero.git-cae7074.zip
435.20 KB
267 downloads
filedropkartero.git-cae7074.tar.bz2
401.98 KB
285 downloads
filedropkartero.git-cc68e56.tar.bz2
402.07 KB
269 downloads
filedropkartero.git-cc68e56.zip
435.16 KB
295 downloads
filedropkartero.git-230f35d.tar.bz2
401.43 KB
254 downloads
filedropkartero.git-230f35d.zip
434.68 KB
285 downloads
filedropkartero.git-5ae58a2.tar.bz2
401.54 KB
257 downloads
filedropkartero.git-5ae58a2.zip
434.68 KB
256 downloads
filedropkartero.git-a591f4b.tar.bz2
401.76 KB
257 downloads
filedropkartero.git-a591f4b.zip
435.17 KB
263 downloads
filedropkartero.git-36876c8.tar.bz2
400.44 KB
256 downloads
filedropkartero.git-36876c8.zip
432.36 KB
288 downloads
filedropkartero.git-a34c9ed.tar.bz2
400.57 KB
278 downloads
filedropkartero.git-a34c9ed.zip
432.27 KB
277 downloads
filedropkartero.git-e828148.zip
433.58 KB
257 downloads
filedropkartero.git-e828148.tar.bz2
400.88 KB
265 downloads
filedropkartero.git-476cdda.tar.bz2
400.60 KB
294 downloads
filedropkartero.git-476cdda.zip
432.26 KB
269 downloads
filedropkartero.git-054c286.tar.bz2
98.09 KB
328 downloads
filedropkartero.git-054c286.zip
109.53 KB
327 downloads
filedropkartero.git-071b099.tar.bz2
98.76 KB
331 downloads
filedropkartero.git-071b099.zip
110.21 KB
329 downloads
filedropkartero.git-551c38d.tar.bz2
98.51 KB
338 downloads
filedropkartero.git-551c38d.zip
110.20 KB
319 downloads
filedropkartero.git-569dc0c.tar.bz2
98.40 KB
332 downloads
filedropkartero.git-569dc0c.zip
109.86 KB
309 downloads
filedropkartero.git-58a052b.tar.bz2
97.95 KB
328 downloads
filedropkartero.git-58a052b.zip
109.36 KB
324 downloads
filedropkartero.git-43a5af3.tar.bz2
97.80 KB
324 downloads
filedropkartero.git-43a5af3.zip
109.30 KB
320 downloads
filedropkartero.git-bbe069d.tar.bz2
98.03 KB
335 downloads
filedropkartero.git-bbe069d.zip
109.19 KB
327 downloads
filedropkartero.git-02f97e1.tar.bz2
97.76 KB
304 downloads
filedropkartero.git-02f97e1.zip
109.24 KB
417 downloads
filedropkartero.git-d82e393.tar.bz2
97.74 KB
334 downloads
filedropkartero.git-d82e393.zip
109.24 KB
326 downloads
filedropkartero.git-7cdd1f5.tar.bz2
98.03 KB
320 downloads
filedropkartero.git-7cdd1f5.zip
109.24 KB
309 downloads
filedropkartero.git-40825aa.tar.bz2
97.71 KB
318 downloads
filedropkartero.git-40825aa.zip
109.16 KB
344 downloads
filedropkartero.git-3dd941b.tar.bz2
97.69 KB
318 downloads
filedropkartero.git-3dd941b.zip
109.12 KB
318 downloads
filedropkartero.git-50f1e46.tar.bz2
97.65 KB
327 downloads
filedropkartero.git-50f1e46.zip
109.02 KB
322 downloads
filedropkartero.git-fdf9225.tar.bz2
93.19 KB
360 downloads
filedropkartero.git-fdf9225.zip
104.25 KB
333 downloads
filedropkartero.git-21415da.tar.bz2
93.24 KB
316 downloads
filedropkartero.git-21415da.zip
104.22 KB
334 downloads
filedropkartero.git-aff5e89.tar.bz2
93.17 KB
335 downloads
filedropkartero.git-aff5e89.zip
104.22 KB
322 downloads
filedropkartero.git-b27ef39.tar.bz2
91.97 KB
337 downloads
filedropkartero.git-b27ef39.zip
102.80 KB
348 downloads
filedropkartero.git-3d6e8a2.tar.bz2
91.99 KB
319 downloads
filedropkartero.git-3d6e8a2.zip
102.77 KB
345 downloads
filedropkartero.git-1442b69.tar.bz2
91.79 KB
311 downloads
filedropkartero.git-1442b69.zip
102.50 KB
350 downloads
filedropkartero.git-6d15918.tar.bz2
91.56 KB
334 downloads
filedropkartero.git-6d15918.zip
102.28 KB
316 downloads
filedropkartero.git-45140d8.tar.bz2
91.52 KB
337 downloads
filedropkartero.git-45140d8.zip
102.23 KB
320 downloads
filedropkartero.git-d5b48e5.tar.bz2
91.35 KB
326 downloads
filedropkartero.git-d5b48e5.zip
102.01 KB
334 downloads
filedropkartero.git-e007e55.tar.bz2
91.35 KB
335 downloads
filedropkartero.git-e007e55.zip
102.01 KB
306 downloads
filedropkartero.git-30fd7e3.tar.bz2
90.87 KB
312 downloads
filedropkartero.git-30fd7e3.zip
101.44 KB
332 downloads
filedropkartero.git-421a4a7.tar.bz2
88.02 KB
52 downloads
filedropkartero.git-421a4a7.zip
97.96 KB
310 downloads
filedropkartero.git-b49b8bc.tar.bz2
88.09 KB
357 downloads
filedropkartero.git-b49b8bc.zip
97.99 KB
327 downloads
filedropkartero.git-1cc9571.tar.bz2
87.74 KB
335 downloads
filedropkartero.git-1cc9571.zip
97.70 KB
331 downloads
filedropkartero.git-159152f.tar.bz2
87.60 KB
332 downloads
filedropkartero.git-159152f.zip
97.52 KB
336 downloads
filedropkartero.git-35caaf3.tar.bz2
87.74 KB
315 downloads
filedropkartero.git-35caaf3.zip
97.57 KB
320 downloads
filedropkartero.git-3c9d305.zip
96.67 KB
322 downloads
filedropkartero.git-3c9d305.tar.bz2
86.77 KB
324 downloads
filedropkartero.git-14cb2af.tar.bz2
86.41 KB
320 downloads
filedropkartero.git-14cb2af.zip
96.13 KB
326 downloads
filedropkartero.git-e8f00cb.tar.bz2
86.46 KB
337 downloads
filedropkartero.git-e8f00cb.zip
96.21 KB
315 downloads
filedropkartero.git-bdab380.tar.bz2
86.14 KB
334 downloads
filedropkartero.git-bdab380.zip
95.79 KB
319 downloads
filedropkartero.git-48f9134.tar.bz2
85.78 KB
342 downloads
filedropkartero.git-48f9134.zip
95.48 KB
329 downloads
filedropkartero.git-adb9757.tar.bz2
85.67 KB
326 downloads
filedropkartero.git-adb9757.zip
95.37 KB
320 downloads
filedropkartero.git-1601cbd.zip
95.30 KB
332 downloads
filedropkartero.git-1601cbd.tar.bz2
85.69 KB
308 downloads
filedropkartero.git-18a5106.tar.bz2
85.72 KB
307 downloads
filedropkartero.git-18a5106.zip
95.48 KB
334 downloads
filedropkartero.git-a5b1caa.tar.bz2
85.61 KB
343 downloads
filedropkartero.git-a5b1caa.zip
95.36 KB
328 downloads
filedropkartero.git-effff82.zip
97.06 KB
339 downloads
filedropkartero.git-effff82.tar.bz2
87.13 KB
333 downloads
filedropkartero.git-b70d364.tar.bz2
84.09 KB
371 downloads
filedropkartero.git-b70d364.zip
93.67 KB
335 downloads
filedropkartero.git-48f0e53.tar.bz2
84.16 KB
345 downloads
filedropkartero.git-48f0e53.zip
93.66 KB
328 downloads
filedropkartero.git-c17135e.tar.bz2
84.09 KB
327 downloads
filedropkartero.git-c17135e.zip
93.57 KB
315 downloads
filedropkartero.git-a2e2848.tar.bz2
85.59 KB
331 downloads
filedropkartero.git-a2e2848.zip
100.10 KB
327 downloads
filedropkartero.git-1f683db.tar.bz2
83.55 KB
329 downloads
filedropkartero.git-1f683db.zip
93.24 KB
322 downloads
filedropkartero.git-d342596.tar.bz2
83.57 KB
328 downloads
filedropkartero.git-d342596.zip
93.28 KB
316 downloads
filedropkartero.git-e0131d5.tar.bz2
83.55 KB
332 downloads
filedropkartero.git-e0131d5.zip
93.27 KB
332 downloads
filedropkartero.git-ad467e8.tar.bz2
83.13 KB
341 downloads
filedropkartero.git-ad467e8.zip
92.78 KB
320 downloads
filedropkartero.git-b20e27d.tar.bz2
83.46 KB
345 downloads
filedropkartero.git-b20e27d.zip
93.19 KB
347 downloads
filedropkartero.git-eefd8fe.zip
92.67 KB
347 downloads
filedropkartero.git-eefd8fe.tar.bz2
83.01 KB
328 downloads
filedropkartero.git-bea685a.zip
96.88 KB
329 downloads
filedropkartero.git-bea685a.tar.bz2
84.44 KB
325 downloads
filedropkartero.git-a8bd019.tar.bz2
84.25 KB
340 downloads
filedropkartero.git-a8bd019.zip
96.60 KB
321 downloads
filedropkartero.git-cbc914d.tar.bz2
84.38 KB
334 downloads
filedropkartero.git-cbc914d.zip
96.64 KB
311 downloads
filedropkartero.git-09a2e70.tar.bz2
84.40 KB
312 downloads
filedropkartero.git-09a2e70.zip
96.70 KB
333 downloads
filedropkartero.git-641dc05.tar.bz2
84.37 KB
331 downloads
filedropkartero.git-641dc05.zip
96.73 KB
324 downloads
filedropkartero.git-cde49c6.tar.bz2
84.26 KB
341 downloads
filedropkartero.git-cde49c6.zip
96.59 KB
328 downloads
filedropkartero.git-1d004e0.tar.bz2
77.42 KB
339 downloads
filedropkartero.git-1d004e0.zip
87.56 KB
885 downloads
filedropkartero.git-1f0bf17.tar.bz2
77.47 KB
338 downloads
filedropkartero.git-1f0bf17.zip
87.56 KB
319 downloads
filedropkartero.git-265e63c.tar.bz2
77.43 KB
318 downloads
filedropkartero.git-265e63c.zip
87.52 KB
355 downloads
filedropkartero.git-635a5db.zip
87.60 KB
322 downloads
filedropkartero.git-a041f85.tar.bz2
77.37 KB
333 downloads
filedropkartero.git-a041f85.zip
87.52 KB
344 downloads
filedropkartero.git-ae049a7.tar.bz2
77.44 KB
328 downloads
filedropkartero.git-ae049a7.zip
87.52 KB
314 downloads
filedropkartero.git-eef571a.tar.bz2
20.56 KB
437 downloads
filedropkartero.git-eef571a.zip
25.69 KB
438 downloads
filedropkartero.git-0bc16f5.tar.bz2
82.61 KB
327 downloads
filedropkartero.git-0bc16f5.zip
94.75 KB
338 downloads
filedropkartero.git-2afc0f7.tar.bz2
83.61 KB
336 downloads
filedropkartero.git-2afc0f7.zip
96.00 KB
350 downloads
filedropkartero.git-3529bdf.tar.bz2
77.72 KB
297 downloads
filedropkartero.git-3529bdf.zip
87.92 KB
318 downloads
filedropkartero.git-49aac92.tar.bz2
78.98 KB
335 downloads
filedropkartero.git-49aac92.zip
90.01 KB
313 downloads
filedropkartero.git-5d48f21.tar.bz2
78.65 KB
336 downloads
filedropkartero.git-5d48f21.zip
89.51 KB
336 downloads
filedropkartero.git-635a5db.tar.bz2
77.50 KB
322 downloads
filedropkartero.git-6e34786.tar.bz2
77.76 KB
329 downloads
filedropkartero.git-6e34786.zip
88.09 KB
331 downloads
filedropkartero.git-7dc2fd2.tar.bz2
83.51 KB
353 downloads
filedropkartero.git-7dc2fd2.zip
95.99 KB
315 downloads
filedropkartero.git-9cad005.tar.bz2
78.85 KB
336 downloads
filedropkartero.git-9cad005.zip
90.00 KB
334 downloads
filedropkartero.git-b303f61.tar.bz2
82.57 KB
347 downloads
filedropkartero.git-b303f61.zip
94.78 KB
363 downloads
filedropkartero.git-c15ef85.tar.bz2
77.76 KB
340 downloads
filedropkartero.git-c15ef85.zip
88.16 KB
49 downloads
filedropkartero.git-c99e84d.tar.bz2
83.58 KB
373 downloads
filedropkartero.git-c99e84d.zip
96.01 KB
349 downloads
filedropkartero.git-e5009e6.tar.bz2
78.73 KB
337 downloads
filedropkartero.git-e5009e6.zip
89.69 KB
321 downloads
filedropkartero.git-0502d01.tar.bz2
83.54 KB
338 downloads
filedropkartero.git-0502d01.zip
96.00 KB
363 downloads
filedropkartero.git-44ca46d.tar.bz2
83.73 KB
339 downloads
filedropkartero.git-44ca46d.zip
96.20 KB
315 downloads
filedropkartero.git-834f923.tar.bz2
83.75 KB
336 downloads
filedropkartero.git-834f923.zip
96.14 KB
325 downloads