<?xml version="1.0" encoding="utf-8"?> <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:xs="http://www.w3.org/2001/XMLSchema" version="1.1"> <xsl:import href="lib/parseCommand.xsl"/> <xsl:import href="lib/serviceLabel.xsl"/> <xsl:output method="html" encoding="UTF-8"/> <xsl:output indent="yes"/> <xsl:strip-space elements='*'/> <xsl:param name="savedAs" select=""/> <xsl:param name="compareWith" select=""/> <xsl:param name="refreshPeriod" select="0"/> <xsl:param name="sudo" select="false"/> <xsl:variable name="current" select="./nmaprun"/> <xsl:variable name="stylesheetURL" select="substring-before(substring-after(processing-instruction('xml-stylesheet'),'href="'),'"')"/> <xsl:variable name="basedir" select="concat($stylesheetURL, '/../..')"/> <xsl:variable name="init" select="document($compareWith)/nmaprun"/> <xsl:variable name="nextCompareWith"> <xsl:choose> <xsl:when test="$savedAs"><xsl:value-of select="$savedAs"/></xsl:when> <xsl:when test="$compareWith"><xsl:value-of select="$compareWith"/></xsl:when> <xsl:otherwise></xsl:otherwise> </xsl:choose> </xsl:variable> <xsl:template match="nmaprun"> <xsl:variable name="targets" select="substring-after(@args, '.xml ')"/> <html lang="fr"> <head> <meta charset="utf-8"/> <xsl:if test="$refreshPeriod > 0"> <meta http-equiv="refresh"> <xsl:attribute name="content"> <xsl:value-of select="$refreshPeriod"/> <xsl:text>;URL=</xsl:text> <xsl:value-of select="$basedir"/> <xsl:text>/scan.php?targets=</xsl:text> <xsl:value-of select="$targets"/> <xsl:text>&</xsl:text> <xsl:call-template name="parseCommand"> <xsl:with-param name="argList" select="substring-before(substring-after(@args, ' -'), ' -oX')"/> <xsl:with-param name="asURL" select="true()"/> </xsl:call-template> <xsl:text>compareWith=</xsl:text> <xsl:value-of select="$nextCompareWith"/> <xsl:text>&refreshPeriod=</xsl:text> <xsl:value-of select="$refreshPeriod"/> <xsl:text>&sudo=</xsl:text> <xsl:value-of select="$sudo"/> </xsl:attribute> </meta> </xsl:if> <title> <xsl:text>lanScan - </xsl:text> <xsl:value-of select="$targets"/> </title> <link rel="icon" href="{$basedir}/favicon.ico"/> <link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/npm/fomantic-ui@2.9.3/dist/semantic.min.css"/> <link href="https://cdn.jsdelivr.net/npm/@yaireo/tagify/dist/tagify.css" rel="stylesheet" type="text/css"/> <link href="https://cdn.datatables.net/v/se/jszip-3.10.1/dt-2.1.8/b-3.1.2/b-html5-3.1.2/b-print-3.1.2/cr-2.0.4/fc-5.0.3/fh-4.0.1/r-3.0.3/datatables.min.css" rel="stylesheet"/> <link href="{$basedir}/style.css" rel="stylesheet" type="text/css"/> <script src="https://code.jquery.com/jquery-3.7.1.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/fomantic-ui/2.9.2/semantic.min.js"></script> <script src="https://cdn.jsdelivr.net/npm/@yaireo/tagify"></script> <script src="https://cdn.jsdelivr.net/npm/@yaireo/tagify/dist/tagify.polyfills.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/pdfmake/0.2.7/pdfmake.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/pdfmake/0.2.7/vfs_fonts.js"></script> <script src="https://cdn.datatables.net/v/se/jszip-3.10.1/dt-2.1.8/b-3.1.2/b-html5-3.1.2/b-print-3.1.2/cr-2.0.4/fc-5.0.3/fh-4.0.1/r-3.0.3/datatables.min.js"></script> </head> <body> <nav class="ui inverted teal fixed menu"> <a class="ui teal button item" href="{$basedir}"> <xsl:text>lan</xsl:text> <svg class="logo" version="1.1" id="Layer_1" x="0px" y="0px" viewBox="0 0 24 24" xml:space="preserve" width="40" height="40" xmlns="http://www.w3.org/2000/svg" xmlns:svg="http://www.w3.org/2000/svg"><defs id="defs206"/><g id="g998" transform="matrix(0,0.04687491,-0.04687491,0,24,2.2682373e-5)"><g id="g147"><g id="g145"><path d="m 322.065,92.046 c -46.24,0 -83.851,37.619 -83.851,83.857 v 168.712 c 0,25.224 -21.148,45.745 -46.372,45.745 -25.224,0 -46.372,-20.521 -46.372,-45.745 V 199.464 h -38.114 v 145.151 c 0,46.24 38.246,83.859 84.486,83.859 46.24,0 84.486,-37.619 84.486,-83.859 V 175.903 c 0,-25.223 20.514,-45.743 45.737,-45.743 25.223,0 45.737,20.521 45.737,45.743 v 134.092 h 38.114 V 175.903 c 0,-46.239 -37.611,-83.857 -83.851,-83.857 z" id="path143"/></g></g><g id="g153"><g id="g151"><path d="M 144.198,0 H 108.625 C 98.101,0 89.568,8.746 89.568,19.271 c 0,1.157 0.121,2.328 0.318,3.598 h 73.052 c 0.197,-1.27 0.318,-2.441 0.318,-3.598 C 163.256,8.746 154.723,0 144.198,0 Z" id="path149"/></g></g><g id="g159"><g id="g157"><path d="m 420.183,486.591 h -71.731 c -0.626,2.541 -0.978,4.077 -0.978,6.176 0,10.525 8.532,19.234 19.057,19.234 h 35.573 c 10.525,0 19.057,-8.709 19.057,-19.234 0,-2.098 -0.352,-3.635 -0.978,-6.176 z" id="path155"/></g></g><g id="g165"><g id="g163"><rect x="87.027" y="41.925999" width="80.040001" height="138.481" id="rect161"/></g></g><g id="g171"><g id="g169"><rect x="344.93301" y="329.052" width="80.040001" height="138.481" id="rect167"/></g></g><g id="g173"></g><g id="g175"></g><g id="g177"></g><g id="g179"></g><g id="g181"></g><g id="g183"></g><g id="g185"></g><g id="g187"></g><g id="g189"></g><g id="g191"></g><g id="g193"></g><g id="g195"></g><g id="g197"></g><g id="g199"></g><g id="g201"></g></g></svg> <xsl:text>can</xsl:text> </a> <form id="lanScanForm" class="right menu"> <xsl:call-template name="parseCommand"> <xsl:with-param name="argList" select="substring-before(substring-after(@args, ' -'), ' -oX')"/> <xsl:with-param name="asURL" select="false()"/> </xsl:call-template> <div class="ui category search item"> <div id="targetsInputDiv" class="ui icon input"> <input class="prompt" type="text" id="targetsInput" name="targets" oninput="hiddenInput.value=this.value" pattern="[a-zA-Z0-9._\/ \-]+" value="{$targets}" placeholder="Scanner un réseau..." title="Les cibles peuvent être spécifiées par des noms d'hôtes, des adresses IP, des adresses de réseaux, etc. Exemples: 192.168.1.0/24 scanme.nmap.org 10.0-255.0-255.1-254"/> <i class="satellite dish icon"></i> </div> <input type="hidden" name="compareWith" value="{$nextCompareWith}"/> <input type="hidden" name="refreshPeriod" value="{$refreshPeriod}"/> <input type="hidden" name="sudo" value="{$sudo}"/> <button id="hiddenButton" style="display: none;" type="submit" formmethod="get" formaction="{$basedir}/scan.php"></button> <button id="refreshButton" class="ui teal icon submit button" type="submit" formmethod="get" formaction="{$basedir}/scan.php"> <i class="sync icon"></i> </button> <button class="ui teal icon submit button" type="submit" formmethod="get" formaction="{$basedir}/"> <i class="sliders horizontal icon"></i> </button> <a class="ui teal icon button" href="https://nmap.org/man/fr/index.html" target="_blank"> <i class="question circle icon"></i> </a> </div> </form> </nav> <main class="ui main container"> <h1 class="ui header"><xsl:value-of select="$targets"/></h1> <table id="scanResultsTable" style="width:100%" role="grid" class="ui sortable small table"> <thead> <tr> <th>Etat</th> <th>Adresse IP</th> <th>Nom</th> <th>Fabricant</th> <th class="eight wide">Services</th> <th>Scanner les services</th> </tr> </thead> <tbody> <xsl:apply-templates select="host | $init/host[not(address/@addr=$current/host/address/@addr)][not(status/@state='down')]"/> </tbody> </table> </main> <footer class="ui footer segment"> lanScan est basé sur <a href="https://nmap.org/" target="_blank">Nmap</a> </footer> <script> DataTable.ext.type.detect.unshift(function (d) { return /[\d]+\.[\d]+\.[\d]+\.[\d]+/.test(d) ? 'ipv4-address' : null; }); DataTable.ext.type.order['ipv4-address-pre'] = function (ipAddress) { [a, b, c, d] = ipAddress.split(".").map(Number) return 16777216*a + 65536*b + 256*c + d; }; var table = $('#scanResultsTable').DataTable({ buttons : ['copy', 'excel', 'pdf'], fixedHeader: true, lengthMenu : [ [256, 512, 1024, 2048, -1], [256, 512, 1024, 2048, "All"] ], responsive: true, colReorder: true, buttons : ['copy', 'excel', 'pdf'] }) table.order([1, 'asc']).draw() $('.ui.dropdown').dropdown() <xsl:if test="runstats/finished/@summary"> $.toast({ title : '<xsl:value-of select="runstats/finished/@exit"/>', message : '<xsl:value-of select="runstats/finished/@summary"/>', showIcon : 'satellite dish', displayTime: 0, closeIcon : true, position : 'bottom right', }) </xsl:if> <xsl:if test="runstats/finished/@errormsg"> $.toast({ title : '<xsl:value-of select="runstats/finished/@exit"/>', message : '<xsl:value-of select="runstats/finished/@errormsg"/>', showIcon : 'exclamation triangle', class : 'error', displayTime: 0, closeIcon : true, position : 'bottom right', }) </xsl:if> <xsl:if test="$init"> $.toast({ message : 'Comparaison avec les résultats du <xsl:value-of select="$init/runstats/finished/@timestr"/>', class : 'info', showIcon : 'calendar', displayTime: 0, closeIcon : true, position : 'bottom right', }) </xsl:if> hiddenButton.onclick = function(event) { if (lanScanForm.checkValidity()) { targetsInputDiv.classList.add('loading') $.toast({ title : 'Scan en cours...', message : 'Merci de patienter', class : 'info', showIcon : 'satellite dish', displayTime: 0, closeIcon : true, position : 'bottom right', }) } } refreshButton.onclick = function(event) { refreshButton.getElementsByTagName('i')[0].className = 'loading spinner icon' $.toast({ title : 'Scan en cours...', message : 'Merci de patienter', class : 'info', showIcon : 'satellite dish', displayTime: 0, closeIcon : true, position : 'bottom right', }) } function hostScanning(link) { link.getElementsByTagName('i')[0].className = 'loading spinner icon' $.toast({ title : 'Scan en cours...', message : 'Merci de patienter', class : 'info', showIcon : 'satellite dish', displayTime: 0, closeIcon : true, position : 'bottom right', }) } </script> </body> </html> </xsl:template> <xsl:template match="host"> <xsl:variable name="addr" select="address/@addr"/> <xsl:variable name="initHost" select="$init/host[address/@addr=$addr]"/> <xsl:variable name="currentHost" select="$current/host[address/@addr=$addr]"/> <xsl:variable name="hostAddress"> <xsl:choose> <xsl:when test="hostnames/hostname/@name"> <xsl:value-of select="hostnames/hostname/@name"/> </xsl:when> <xsl:otherwise> <xsl:value-of select="address/@addr"/> </xsl:otherwise> </xsl:choose> </xsl:variable> <tr> <xsl:attribute name="class"> <xsl:choose> <xsl:when test="$currentHost/status/@state='up'">positive</xsl:when> <xsl:otherwise>negative</xsl:otherwise> </xsl:choose> </xsl:attribute> <td> <xsl:choose> <xsl:when test="$currentHost"> <div> <xsl:attribute name="class"> <xsl:text>ui mini circular label </xsl:text> <xsl:choose> <xsl:when test="$currentHost/status/@state='up'">green</xsl:when> <xsl:otherwise>red</xsl:otherwise> </xsl:choose> </xsl:attribute> <xsl:value-of select="$currentHost/status/@state"/> </div> </xsl:when> <xsl:otherwise><div class="ui red circular label">down</div></xsl:otherwise> </xsl:choose> </td> <td> <xsl:value-of select="address/@addr"/> </td> <td> <div><b><xsl:value-of select="substring-before(hostnames/hostname/@name, '.')"/></b></div> <xsl:if test="substring-after(hostnames/hostname/@name, '.')"> <div>.<xsl:value-of select="substring-after(hostnames/hostname/@name, '.')"/></div> </xsl:if> </td> <td> <xsl:value-of select="address[@addrtype='mac']/@vendor"/> </td> <td> <xsl:apply-templates select="$initHost/ports/port[not(@portid=$currentHost/ports/port/@portid)][not(state/@state='closed')] | $currentHost/ports/port"> <xsl:with-param name="initHost" select="$initHost"/> <xsl:with-param name="currentHost" select="$currentHost"/> <xsl:with-param name="hostAddress" select="$hostAddress"/> <xsl:sort select="number(@portid)" order="ascending"/> </xsl:apply-templates> </td> <td> <div class="ui mini right labeled button"> <a class="ui mini icon teal button" onclick="hostScanning(this)"> <xsl:attribute name="href"> <xsl:value-of select="$basedir"/> <xsl:text>/scan.php?preset=host&targets=</xsl:text> <xsl:value-of select="$hostAddress"/> </xsl:attribute> <i class="satellite dish icon"></i> <xsl:text> Services</xsl:text> </a> <a class="ui mini icon teal label"> <xsl:attribute name="href"> <xsl:value-of select="$basedir"/> <xsl:text>/?preset=host&targets=</xsl:text> <xsl:value-of select="$hostAddress"/> </xsl:attribute> <i class="sliders horizontal icon"></i> </a> </div> </td> </tr> </xsl:template> </xsl:stylesheet>