admin.php 7.8 KB

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