rename $inputs to $args

This commit is contained in:
Adrien MALINGREY 2024-10-16 20:15:54 +02:00
parent 5e76b92b96
commit a1aeefee47
3 changed files with 45 additions and 45 deletions

View File

@ -15,12 +15,12 @@ $host = filter_input(INPUT_GET, 'host', FILTER_VALIDATE_REGEXP, ['optio
if ($lan) {
$targets = $lan;
$inputs = $LANSCAN_OPTIONS;
$args = $LANSCAN_OPTIONS;
} else if ($host) {
$targets = $host;
$inputs = $HOSTSCAN_OPTIONS;
$args = $HOSTSCAN_OPTIONS;
} else {
$inputs = filter_input_array(INPUT_GET, [
$args = filter_input_array(INPUT_GET, [
'iR' => ['filter' => FILTER_VALIDATE_INT, 'options' => ['min_range' => 0]],
'exclude' => ['filter' => FILTER_VALIDATE_REGEXP, 'options' => ['regexp' => $hostsListRegex]],

View File

@ -64,13 +64,13 @@ Exemples: <?= $_SERVER['REMOTE_ADDR']; ?>/24 <?= $_SERVER['SERVER_NAME']; ?> 10.
<div class="field" title="--exclude">
<label for="excludeInput">Exclure les hôtes ou réseaux</label>
<input type="text" id="excludeInput" name="exclude" placeholder="Hôte/réseau" list="targetsList"
pattern="[a-zA-Z0-9._\/,\-]*" value="<?= $inputs['exclude'] ?? "" ?>">
pattern="[a-zA-Z0-9._\/,\-]*" value="<?= $args['exclude'] ?? "" ?>">
</div>
<div class="field" title="-iR">
<label for="iRInput">Nombre de cibles au hasard</label>
<input type="number" min="0" id="iRInput" name="iR" placeholder="Nombre de cibles"
value="<?= $inputs['iR'] ?? "" ?>">
value="<?= $args['iR'] ?? "" ?>">
</div>
</div>
@ -81,7 +81,7 @@ Exemples: <?= $_SERVER['REMOTE_ADDR']; ?>/24 <?= $_SERVER['SERVER_NAME']; ?> 10.
<div class="content">
<div class="inline field" title="-Pn">
<div class="ui toggle checkbox">
<input type="checkbox" id="PnCheckbox" name="Pn" <?= $inputs['Pn'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="PnCheckbox" name="Pn" <?= $args['Pn'] ?? false ? 'checked' : ''; ?> />
<label for="PnCheckbox">Sauter cette étape (considérer tous les hôtes comme actifs)</label>
</div>
</div>
@ -89,21 +89,21 @@ Exemples: <?= $_SERVER['REMOTE_ADDR']; ?>/24 <?= $_SERVER['SERVER_NAME']; ?> 10.
<div class="field" title="-PS">
<label for="PSInput">TCP SYN</label>
<input type="text" id="PSInput" name="PS" placeholder="Ports" list="servicesList"
pattern="([0-9\-]+|[a-z\-]+)(,[0-9\-]+|,[a-z\-]+)*" value="<?= $inputs['PS'] ?? "" ?>"
pattern="([0-9\-]+|[a-z\-]+)(,[0-9\-]+|,[a-z\-]+)*" value="<?= $args['PS'] ?? "" ?>"
title="Liste de ports ex: 22,23,25,80,200-1024,60000-">
</div>
<div class="field" title="-PA">
<label for="PAInput">TCP ACK</label>
<input type="text" id="PAInput" name="PA" placeholder="Ports" list="servicesList"
pattern="([0-9\-]+|[a-z\-]+)(,[0-9\-]+|,[a-z\-]+)*" value="<?= $inputs['PA'] ?? "" ?>"
pattern="([0-9\-]+|[a-z\-]+)(,[0-9\-]+|,[a-z\-]+)*" value="<?= $args['PA'] ?? "" ?>"
title="Liste de ports ex: 22,23,25,80,200-1024,60000-">
</div>
<div class="field" title="-PU">
<label for="PUInput">UDP</label>
<input type="text" id="PUInput" name="PU" placeholder="Ports" list="servicesList"
pattern="([0-9\-]+|[a-z\-]+)(,[0-9\-]+|,[a-z\-]+)*" value="<?= $inputs['PU'] ?? "" ?>"
pattern="([0-9\-]+|[a-z\-]+)(,[0-9\-]+|,[a-z\-]+)*" value="<?= $args['PU'] ?? "" ?>"
title="Liste de ports ex: 22,23,25,80,200-1024,60000-">
</div>
@ -112,19 +112,19 @@ Exemples: <?= $_SERVER['REMOTE_ADDR']; ?>/24 <?= $_SERVER['SERVER_NAME']; ?> 10.
<div class="inline fields">
<div class="field" title="-PE">
<div class="ui toggle checkbox">
<input type="checkbox" id="PECheckbox" name="PE" <?= $inputs['PE'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="PECheckbox" name="PE" <?= $args['PE'] ?? false ? 'checked' : ''; ?> />
<label for="PECheckbox">Echo request</label>
</div>
</div>
<div class="field" title="-PP">
<div class="ui toggle checkbox">
<input type="checkbox" id="PPCheckbox" name="PP" <?= $inputs['PP'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="PPCheckbox" name="PP" <?= $args['PP'] ?? false ? 'checked' : ''; ?> />
<label for="PPCheckbox">Timestamp request</label>
</div>
</div>
<div class="field" title="-PM">
<div class="ui toggle checkbox">
<input type="checkbox" id="PMCheckbox" name="PM" <?= $inputs['PM'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="PMCheckbox" name="PM" <?= $args['PM'] ?? false ? 'checked' : ''; ?> />
<label for="PMCheckbox">Mask request</label>
</div>
</div>
@ -134,20 +134,20 @@ Exemples: <?= $_SERVER['REMOTE_ADDR']; ?>/24 <?= $_SERVER['SERVER_NAME']; ?> 10.
<div class="field" title="-PO">
<label for="POInput" title="PO">Protocole IP (par type)</label>
<input type="text" id="POInput" name="PO" placeholder="Protocole"
pattern="[0-9,\-]+" value="<?= $inputs['PO'] ?? "" ?>"
pattern="[0-9,\-]+" value="<?= $args['PO'] ?? "" ?>"
title="[num de protocole]">
</div>
<div class="fields">
<div class="inline field" title="-PR">
<div class="ui toggle checkbox">
<input type="checkbox" id="PRCheckbox" name="PR" <?= $inputs['PR'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="PRCheckbox" name="PR" <?= $args['PR'] ?? false ? 'checked' : ''; ?> />
<label for="PRCheckbox">Ping ARP</label>
</div>
</div>
<div class="inline field" title="--send-ip">
<div class="ui toggle checkbox">
<input type="checkbox" id="sendIPCheckbox" name="send-ip" <?= $inputs['send-ip'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="sendIPCheckbox" name="send-ip" <?= $args['send-ip'] ?? false ? 'checked' : ''; ?> />
<label for="sendIPCheckbox">Pas de scan ARP</label>
</div>
</div>
@ -156,13 +156,13 @@ Exemples: <?= $_SERVER['REMOTE_ADDR']; ?>/24 <?= $_SERVER['SERVER_NAME']; ?> 10.
<div class="fields">
<div class="inline field" title="-n">
<div class="ui toggle checkbox">
<input type="checkbox" id="nCheckbox" name="n" <?= $inputs['n'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="nCheckbox" name="n" <?= $args['n'] ?? false ? 'checked' : ''; ?> />
<label for="nCheckbox">Ne jamais résoudre les noms DNS</label>
</div>
</div>
<div class="inline field" title="-R">
<div class="ui toggle checkbox">
<input type="checkbox" id="RCheckbox" name="R" <?= $inputs['R'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="RCheckbox" name="R" <?= $args['R'] ?? false ? 'checked' : ''; ?> />
<label for="nCheckbox">Toujours résoudre les noms DNS<br />(par défault seuls les hôtes actifs sont résolus)</label>
</div>
</div>
@ -171,7 +171,7 @@ Exemples: <?= $_SERVER['REMOTE_ADDR']; ?>/24 <?= $_SERVER['SERVER_NAME']; ?> 10.
<div class="field">
<label for="dnsServersInput" title="--dns-servers">Utiliser les serveurs DNS</label>
<input type="text" id="dnsServersInput" name="dns-servers" placeholder="serveur"
pattern="[a-zA-Z0-9._,\-]*" value="<?= $inputs['dns-servers'] ?? "" ?>"
pattern="[a-zA-Z0-9._,\-]*" value="<?= $args['dns-servers'] ?? "" ?>"
title="serv1[,serv2],...">
</div>
</div>
@ -185,19 +185,19 @@ Exemples: <?= $_SERVER['REMOTE_ADDR']; ?>/24 <?= $_SERVER['SERVER_NAME']; ?> 10.
<div class="fields">
<div class="field" title="-sS">
<div class="ui toggle checkbox">
<input type="checkbox" id="sSCheckbox" name="sS" <?= $inputs['sS'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="sSCheckbox" name="sS" <?= $args['sS'] ?? false ? 'checked' : ''; ?> />
<label for="sSCheckbox">TCP SYN</label>
</div>
</div>
<div class="field" title="-sT">
<div class="ui toggle checkbox">
<input type="checkbox" id="sTCheckbox" name="sT" <?= $inputs['sT'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="sTCheckbox" name="sT" <?= $args['sT'] ?? false ? 'checked' : ''; ?> />
<label for="sTCheckbox">TCP Connect()</label>
</div>
</div>
<div class="field" title="-sA">
<div class="ui toggle checkbox">
<input type="checkbox" id="sACheckbox" name="sA" <?= $inputs['sA'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="sACheckbox" name="sA" <?= $args['sA'] ?? false ? 'checked' : ''; ?> />
<label for="sACheckbox">TCP ACK</label>
</div>
</div>
@ -206,19 +206,19 @@ Exemples: <?= $_SERVER['REMOTE_ADDR']; ?>/24 <?= $_SERVER['SERVER_NAME']; ?> 10.
<div class="fields">
<div class="field" title="-sW">
<div class="ui toggle checkbox">
<input type="checkbox" id="sWCheckbox" name="sW" <?= $inputs['sW'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="sWCheckbox" name="sW" <?= $args['sW'] ?? false ? 'checked' : ''; ?> />
<label for="sWCheckbox">Fenêtre TCP</label>
</div>
</div>
<div class="field" title="-sM">
<div class="ui toggle checkbox">
<input type="checkbox" id="sMCheckbox" name="sM" <?= $inputs['sM'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="sMCheckbox" name="sM" <?= $args['sM'] ?? false ? 'checked' : ''; ?> />
<label for="sMCheckbox">Maimon</label>
</div>
</div>
<div class="field" title="-sN">
<div class="ui toggle checkbox">
<input type="checkbox" id="sNCheckbox" name="sN" <?= $inputs['sN'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="sNCheckbox" name="sN" <?= $args['sN'] ?? false ? 'checked' : ''; ?> />
<label for="sNCheckbox">TCP Null</label>
</div>
</div>
@ -227,19 +227,19 @@ Exemples: <?= $_SERVER['REMOTE_ADDR']; ?>/24 <?= $_SERVER['SERVER_NAME']; ?> 10.
<div class="fields">
<div class="field" title="-sF">
<div class="ui toggle checkbox">
<input type="checkbox" id="sFCheckbox" name="sF" <?= $inputs['sF'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="sFCheckbox" name="sF" <?= $args['sF'] ?? false ? 'checked' : ''; ?> />
<label for="sFCheckbox">TCP FIN</label>
</div>
</div>
<div class="field" title="-sX">
<div class="ui toggle checkbox">
<input type="checkbox" id="sXCheckbox" name="sX" <?= $inputs['sX'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="sXCheckbox" name="sX" <?= $args['sX'] ?? false ? 'checked' : ''; ?> />
<label for="sXCheckbox">Sapin de Noël</label>
</div>
</div>
<div class="field" title="-sU">
<div class="ui toggle checkbox">
<input type="checkbox" id="sUCheckbox" name="sU" <?= $inputs['sU'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="sUCheckbox" name="sU" <?= $args['sU'] ?? false ? 'checked' : ''; ?> />
<label for="sUCheckbox">UDP</label>
</div>
</div>
@ -248,27 +248,27 @@ Exemples: <?= $_SERVER['REMOTE_ADDR']; ?>/24 <?= $_SERVER['SERVER_NAME']; ?> 10.
<div class="field" title="-scanflags">
<label for="scanflagsInput">Scan TCP personnalisé</label>
<input type="text" id="scanflagsInput" name="scanflags" placeholder="Drapeaux TCP" list="flagsList"
pattern="(URG|ACK|PSH|RST|SYN|FIN|,)+|[1-9]?[0-9]|[1-2][0-9][0-9]" value="<?= $inputs['scanflags'] ?? "" ?>"
pattern="(URG|ACK|PSH|RST|SYN|FIN|,)+|[1-9]?[0-9]|[1-2][0-9][0-9]" value="<?= $args['scanflags'] ?? "" ?>"
title="Mélanger simplement les drapeaux URG, ACK, PSH, RST, SYN et FIN.">
</div>
<div class="field" title="-sI">
<label for="sIInput">Hôte zombie</label>
<input type="text" id="sIInput" name="p" placeholder="zombie host[:probeport]"
pattern="[a-zA-Z0-9._\-]+(:[0-9]+)?" value="<?= $inputs['sI'] ?? "" ?>"
pattern="[a-zA-Z0-9._\-]+(:[0-9]+)?" value="<?= $args['sI'] ?? "" ?>"
title="zombie host[:probeport]">
</div>
<div class="field" title="-b">
<label for="bInput">Rebond FTP</label>
<input type="text" id="bInput" name="p" placeholder="[<username>[:<password>]@]<server>[:<port>]"
pattern="([a-zA-Z0-9._\-]+(:.+)?@)?[a-zA-Z0-9._\-]+(:[0-9]+)?" value="<?= $inputs['b'] ?? "" ?>"
pattern="([a-zA-Z0-9._\-]+(:.+)?@)?[a-zA-Z0-9._\-]+(:[0-9]+)?" value="<?= $args['b'] ?? "" ?>"
title="[<username>[:<password>]@]<server>[:<port>]">
</div>
<div class="field" title="-sO">
<div class="ui toggle checkbox">
<input type="checkbox" id="sUCheckbox" name="sU" <?= $inputs['sU'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="sUCheckbox" name="sU" <?= $args['sU'] ?? false ? 'checked' : ''; ?> />
<label for="sUCheckbox">Scan des protocoles supportés par la couche IP</label>
</div>
</div>
@ -282,14 +282,14 @@ Exemples: <?= $_SERVER['REMOTE_ADDR']; ?>/24 <?= $_SERVER['SERVER_NAME']; ?> 10.
<div class="content">
<div class="inline field" title="-sP">
<div class="ui toggle checkbox">
<input type="checkbox" id="sPCheckbox" name="sP" <?= $inputs['sP'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="sPCheckbox" name="sP" <?= $args['sP'] ?? false ? 'checked' : ''; ?> />
<label for="sPCheckbox">Sauter cette étape</label>
</div>
</div>
<div class="inline field" title="-F">
<div class="ui toggle checkbox">
<input type="checkbox" id="FCheckbox" name="F" <?= $inputs['F'] ?? false ? 'checked' : ''; ?>
<input type="checkbox" id="FCheckbox" name="F" <?= $args['F'] ?? false ? 'checked' : ''; ?>
onchange="pInput.disabled = FCheckbox.checked" />
<label for="FCheckbox">Scanner les ports connus</label>
</div>
@ -297,14 +297,14 @@ Exemples: <?= $_SERVER['REMOTE_ADDR']; ?>/24 <?= $_SERVER['SERVER_NAME']; ?> 10.
<div class="field" title="-p">
<label for="pInput">Scanner les ports</label>
<input type="text" id="pInput" name="p" placeholder="Ports" list="servicesList" <?= $inputs['F'] ?? false ? 'disabled' : ''; ?>
pattern="(([TU]:)?[0-9\-]+|[a-z\-]+)(,([TU]:)?[0-9\-]+|,[a-z\-]+)*" value="<?= $inputs['p'] ?? "" ?>"
<input type="text" id="pInput" name="p" placeholder="Ports" list="servicesList" <?= $args['F'] ?? false ? 'disabled' : ''; ?>
pattern="(([TU]:)?[0-9\-]+|[a-z\-]+)(,([TU]:)?[0-9\-]+|,[a-z\-]+)*" value="<?= $args['p'] ?? "" ?>"
title="Liste de ports ex: ssh,ftp,U:53,111,137,T:21-25,80,139,8080">
</div>
<div class="inline field" title="-r">
<div class="ui toggle checkbox">
<input type="checkbox" id="rCheckbox" name="r" <?= $inputs['r'] ?? false ? 'checked' : ''; ?> />
<input type="checkbox" id="rCheckbox" name="r" <?= $args['r'] ?? false ? 'checked' : ''; ?> />
<label for="rCheckbox">Ne pas mélanger les ports</label>
</div>
</div>
@ -317,13 +317,13 @@ Exemples: <?= $_SERVER['REMOTE_ADDR']; ?>/24 <?= $_SERVER['SERVER_NAME']; ?> 10.
<div class="content">
<div class="field" title="--stylesheet">
<label for="stylesheetSelect">Feuille de style</label>
<select class="ui dropdown" id="stylesheetSelect" name="stylesheet" value="<?= $inputs["stylesheet"] ?? ""?>">
<select class="ui dropdown" id="stylesheetSelect" name="stylesheet" value="<?= $args["stylesheet"] ?? ""?>">
<?php
foreach (scandir('.') as $filename) {
if (substr($filename, -4) === '.xsl') {
$name = substr($filename, 0, -4);
$URL = htmlentities("$BASEDIR/$filename", ENT_QUOTES);
if (isset($inputs["stylesheet"]) && $URL == $inputs["stylesheet"]) {
if (isset($args["stylesheet"]) && $URL == $args["stylesheet"]) {
echo " <option value='$URL' selected>$name</option>\n";
} else {
echo " <option value='$URL'>$name</option>\n";

View File

@ -4,8 +4,8 @@ include_once 'filter_inputs.php';
if (!file_exists($SCANSDIR)) mkdir($SCANSDIR);
$args = '';
foreach ($inputs as $arg => $value) {
$command = ($sudo? "sudo " : "") . "nmap";
foreach ($args as $arg => $value) {
if (is_null($value)) {
http_response_code(400);
$errorMessage = "Valeur incorecte pour le paramètre <var>$arg</var> : " . filter_input(INPUT_GET, $arg, FILTER_SANITIZE_FULL_SPECIAL_CHARS);
@ -13,18 +13,18 @@ foreach ($inputs as $arg => $value) {
die();
} else if ($value) {
if ($value === true) {
if (strlen($arg) <= 2) $args .= " -$arg";
else $args .= " --$arg";
if (strlen($arg) <= 2) $command .= " -$arg";
else $command .= " --$arg";
} else {
if (strlen($arg) <= 2) $args .= " -$arg$value";
else $args .= " --$arg $value";
if (strlen($arg) <= 2) $command .= " -$arg$value";
else $command .= " --$arg $value";
}
}
}
$tempPath = tempnam(sys_get_temp_dir(), 'scan_').".xml";
$command = ($sudo? "sudo " : "") . "nmap$args -oX '$tempPath' $targets 2>&1";
$command .= " -oX '$tempPath' $targets 2>&1";
exec($command, $stderr, $retcode);