You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							47 lines
						
					
					
						
							925 B
						
					
					
				
			
		
		
	
	
							47 lines
						
					
					
						
							925 B
						
					
					
				| <?php
 | |
| use function Hestiacp\quoteshellarg\quoteshellarg;
 | |
| 
 | |
| ob_start();
 | |
| 
 | |
| // Main include
 | |
| include $_SERVER["DOCUMENT_ROOT"] . "/inc/main.php";
 | |
| 
 | |
| // Check token
 | |
| verify_csrf($_POST);
 | |
| 
 | |
| // Check user
 | |
| if ($_SESSION["userContext"] != "admin") {
 | |
| 	header("Location: /list/user");
 | |
| 	exit();
 | |
| }
 | |
| 
 | |
| if (empty($_POST["ipchain"])) {
 | |
| 	header("Location: /list/firewall/banlist/");
 | |
| 	exit();
 | |
| }
 | |
| if (empty($_POST["action"])) {
 | |
| 	header("Location: /list/firewall/banlist/");
 | |
| 	exit();
 | |
| }
 | |
| 
 | |
| $ipchain = $_POST["ipchain"];
 | |
| $action = $_POST["action"];
 | |
| 
 | |
| switch ($action) {
 | |
| 	case "delete":
 | |
| 		$cmd = "v-delete-firewall-ban";
 | |
| 		break;
 | |
| 	default:
 | |
| 		header("Location: /list/firewall/banlist/");
 | |
| 		exit();
 | |
| }
 | |
| 
 | |
| foreach ($ipchain as $value) {
 | |
| 	[$ip, $chain] = explode(":", $value);
 | |
| 	$v_ip = quoteshellarg($ip);
 | |
| 	$v_chain = quoteshellarg($chain);
 | |
| 	exec(HESTIA_CMD . $cmd . " " . $v_ip . " " . $v_chain, $output, $return_var);
 | |
| }
 | |
| 
 | |
| header("Location: /list/firewall/banlist");
 |