admin.php 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>Blacklister Admin</title>
  5. </head>
  6. <body>
  7. <div>
  8. <?php
  9. require_once 'action.php';
  10. require_once 'db.php';
  11. require_once 'token.php';
  12. require_once 'stats.php';
  13. if(!isset($_GET['token'])){
  14. echo "<form action='admin.php'><input type='text' size='35' id='token' name='token'><input type='submit' value='send token'></form></div></body></html>";
  15. exit;
  16. }
  17. if(isset($_GET['ip'])) {
  18. $ip = ip2long(substr(trim($_GET['ip']),0,15));
  19. }
  20. if(isset($_GET['token'])) {
  21. $token = substr(trim($_GET['token']),0,32);
  22. }
  23. if(isset($_GET['action'])) {
  24. $action = substr(trim($_GET['action']),0,12);
  25. }
  26. if(isset($_GET['userid'])) {
  27. $userid = substr(trim($_GET['userid']),0,32);
  28. }
  29. if(isset($_GET['role'])) {
  30. $role = substr(trim($_GET['role']),0,8);
  31. }
  32. if(isset($_GET['description'])) {
  33. $description = substr(trim($_GET['description']),0,40);
  34. }
  35. $clientIP = ip2long(substr(trim($_SERVER['REMOTE_ADDR']),0,15));
  36. $stats = true;
  37. $tok = new token;
  38. $act = new action;
  39. if($act->isBlocked($clientIP)) {
  40. http_response_code(403);
  41. exit;
  42. }
  43. if (!$tok->isAdmin($token)) {
  44. $act->block($clientIP);
  45. echo "admin access denied</div></body></html>";
  46. exit;
  47. }
  48. if($stats == true) {
  49. (new stats)->log($clientIP,$ip,$action,$token);
  50. }
  51. switch($action) {
  52. case 'deluser':
  53. if($act->delUser($userid)){
  54. echo " user removed " . $userid ."\n";
  55. } else {
  56. echo " fehler\n";
  57. };
  58. break;
  59. case 'adduser':
  60. if($act->addUser($userid,$role,$description)){
  61. echo " user added, token:" . $userid . " role:" .$role . " description: " . $description . "\n";
  62. } else {
  63. echo " fehler\n";
  64. };
  65. break;
  66. case 'blacklist':
  67. if($act->blackList($ip)){
  68. echo " blacklisted " . long2ip($ip) ."\n";
  69. } else {
  70. echo " fehler\n";
  71. };
  72. break;
  73. case 'deblacklist':
  74. if($act->deBlackList($ip)){
  75. echo " deblacklisted " . long2ip($ip) ."\n";
  76. } else {
  77. echo " fehler\n";
  78. };
  79. break;
  80. case 'blocklist':
  81. if($act->adminBlock($ip)){
  82. echo " blocklisted " . long2ip($ip) ."\n";
  83. } else {
  84. echo " fehler\n";
  85. };
  86. break;
  87. case 'deblocklist':
  88. if($act->deBlockList($ip)){
  89. echo " deblocklisted " . long2ip($ip) ."\n";
  90. } else {
  91. echo " fehler\n";
  92. };
  93. break;
  94. case 'whitelist':
  95. if($act->whiteList($ip)){
  96. echo " whitelisted " . long2ip($ip) ."\n";
  97. } else {
  98. echo " fehler\n";
  99. };
  100. break;
  101. case 'dewhitelist':
  102. if($act->deWhiteList($ip)){
  103. echo " dewhitelisted " . long2ip($ip) ."\n";
  104. } else {
  105. echo " fehler\n";
  106. };
  107. break;
  108. case 'list':
  109. if($act->list($ip)){
  110. echo " listed " . long2ip($ip) ."\n";
  111. } else {
  112. echo " fehler\n";
  113. };
  114. break;
  115. case 'delist':
  116. if($act->adminDeList($ip)){
  117. echo " delisted " . long2ip($ip) ."\n";
  118. } else {
  119. echo " fehler\n";
  120. };
  121. break;
  122. }
  123. ?>
  124. </div>
  125. <h3>Clients</h3>
  126. <table>
  127. <tr><th>Token</th><th>Role</th><th>Description</th><th></th></tr>
  128. <?php
  129. $userlist = $act->getUser();
  130. foreach($userlist as $user) {
  131. echo "<tr><td>" . $user[0] . "</td><td>" . $user[1] . "</td><td>" . $user[2] . "</td><td><input type='button' id='deluser' value='remove' onclick='window.location.href=\"admin.php?token=" . $token . "&action=deluser&userid=" . $user[0] . "\"'></td></tr>";
  132. }
  133. ?>
  134. <tr>
  135. <form action="admin.php">
  136. <input type="hidden" id="token" name="token" value="<?php echo $token; ?>">
  137. <input type="hidden" id="action" name="action" value="adduser">
  138. <td>
  139. <input type='text' id='userid' name='userid' size='35' readonly value='<?php echo bin2hex(random_bytes(16)) ?>'>
  140. <input type='button' id='createtoken' value='refresh' onclick='window.location.href="admin.php?token=<?php echo $token; ?>"'>
  141. </td><td>
  142. <input type='radio' id='reporter' name='role' value='reporter'>Reporter
  143. <input type='radio' id='consumer' name='role' value='consumer'>Consumer
  144. <input type='radio' id='admin' name='role' value='admin'>Admin
  145. </td><td>
  146. <input type='text' id='description' name='description'>
  147. </td><td>
  148. <input type='submit' value='add user'>
  149. </td></form>
  150. </tr>
  151. </table>
  152. <h3>Clientblocklist</h3>
  153. Alle IP Adressen, die mehr als 5x unauthorisiert zugegriffen haben.
  154. <table>
  155. <?php
  156. $blocklist = $act->getBlockedClients();
  157. foreach($blocklist as $blip) {
  158. echo "<tr><td>" . long2ip($blip) . "</td><td><input type='button' id='deblocklist' value='remove' onclick='window.location.href=\"admin.php?token=" . $token . "&action=deblocklist&ip=" . long2ip($blip) . "\"'></td></tr>";
  159. }
  160. ?>
  161. <tr>
  162. <form action="admin.php">
  163. <input type="hidden" id="token" name="token" value="<?php echo $token; ?>">
  164. <input type="hidden" id="action" name="action" value="blocklist">
  165. <td>
  166. <input type='text' id='ip' name='ip'>
  167. </td><td>
  168. <input type='submit' value='add to blocklist'>
  169. </form>
  170. </td></tr>
  171. </table>
  172. <h3>Blacklist</h3>
  173. Manuell eingepflegte IP Adressen. Werden zusammen mit den automatischen Einträgen als Banliste ausgeliefert.
  174. <table>
  175. <?php
  176. $blacklist = $act->getBlackList();
  177. foreach($blacklist as $blip) {
  178. echo "<tr><td>" . long2ip($blip) . "</td><td><input type='button' id='deblacklist' value='remove' onclick='window.location.href=\"admin.php?token=" . $token . "&action=deblacklist&ip=" . long2ip($blip) . "\"'></td></tr>";
  179. }
  180. ?>
  181. <tr>
  182. <form action="admin.php">
  183. <input type="hidden" id="token" name="token" value="<?php echo $token; ?>">
  184. <input type="hidden" id="action" name="action" value="blacklist">
  185. <td>
  186. <input type='text' id='ip' name='ip'>
  187. </td><td>
  188. <input type='submit' value='add to blacklist'>
  189. </form>
  190. </td></tr>
  191. </table>
  192. <h3>Whitelist</h3>
  193. Manuell eingepflegte IP-Adressen, welche nicht mehr in die automatische Liste eingetragen werden können.
  194. <table border="0">
  195. <?php
  196. $whitelist = $act->getWhiteList();
  197. foreach($whitelist as $wlip) {
  198. echo "<tr><td>" . long2ip($wlip) . "</td><td><input type='button' id='dewhitelist' value='remove' onclick='window.location.href=\"admin.php?token=" . $token . "&action=dewhitelist&ip=" . long2ip($wlip) . "\"'></td></tr>";
  199. }
  200. ?>
  201. <tr>
  202. <form action="admin.php">
  203. <input type="hidden" id="token" name="token" value="<?php echo $token; ?>">
  204. <input type="hidden" id="action" name="action" value="whitelist">
  205. <td>
  206. <input type='text' id='ip' name='ip'>
  207. </td><td>
  208. <input type='submit' value='add to whitelist'>
  209. </form>
  210. </td></tr>
  211. </table>
  212. <h3>List</h3>
  213. Automatisch generierte Liste über alle via Reporter gemeldeter IP-Adressen.
  214. <table border="0">
  215. <?php
  216. $list = $act->getList();
  217. foreach($list as $lip) {
  218. echo "<tr><td>" . long2ip($lip) . "</td>";
  219. echo "<td><input type='button' id='delist' value='remove' onclick='window.location.href=\"admin.php?token=" . $token . "&action=delist&ip=" . long2ip($lip) . "\"'></td>";
  220. echo "<td><input type='button' id='blacklist' value='blacklist' onclick='window.location.href=\"admin.php?token=" . $token . "&action=blacklist&ip=" . long2ip($lip) . "\"'></td>";
  221. echo "<td><input type='button' id='whitelist' value='whitelist' onclick='window.location.href=\"admin.php?token=" . $token . "&action=whitelist&ip=" . long2ip($lip) . "\"'></td></tr>";
  222. }
  223. ?>
  224. </table>
  225. </body>
  226. </html>