Add yet another Nmap example, ideal to be consumed by browser
I intend to replace the nmap-streaming.pow example with this one. I've realized that nmap-streaming.pow is not actually a streaming example, since Nmap won't write its output(s) until scan is finished, and hence, kapow will serve them in one shot. Check it out, @nilp0inter, @cr0hn.
This commit is contained in:
@@ -0,0 +1,41 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<title>Nmap</title>
|
||||||
|
<style type="text/css">
|
||||||
|
.wrap {
|
||||||
|
width: 800px;
|
||||||
|
margin: 0 auto;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<form id="nmap-params" method="post" action="nmap.xml">
|
||||||
|
<fieldset>
|
||||||
|
<legend>Nmap parameters</legend>
|
||||||
|
<div>
|
||||||
|
<label for="target_spec">Target Specification:</label>
|
||||||
|
<input name="target_spec" type="text" placeholder="ip, domain, network, range" value="127.0.0.1" required autofocus>
|
||||||
|
<p>
|
||||||
|
Can pass hostnames, IP addresses, networks, etc. e.g.:
|
||||||
|
scanme.nmap.org, microsoft.com/24, 192.168.0.1;
|
||||||
|
10.0.0-255.1-254
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<label for="port_ranges">Port Ranges:</label>
|
||||||
|
<input name="port_ranges" type="text" placeholder="port, range, list" value="8080" required>
|
||||||
|
<p>
|
||||||
|
Only scan specified ports. e.g.: 22; 1-65535;
|
||||||
|
U:53,111,137,T:21-25,80,139,8080,S:9
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<input name="scan" type="submit" value="Scan">
|
||||||
|
<input name="reset" type="reset" value="Reset">
|
||||||
|
</div>
|
||||||
|
</fieldset>
|
||||||
|
</form>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
@@ -0,0 +1,55 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
#
|
||||||
|
# Copyright 2019 Banco Bilbao Vizcaya Argentaria, S.A.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Nmap produces an XML report, suitable for rendering in a web browser
|
||||||
|
#
|
||||||
|
|
||||||
|
# Call examples:
|
||||||
|
#
|
||||||
|
# $ browser http://localhost:8080
|
||||||
|
#
|
||||||
|
# $ curl -v http://localhost:8080/nmap.xml -d 'target_spec=127.0.0.1&port_ranges=9000'
|
||||||
|
#
|
||||||
|
|
||||||
|
kapow route add -X GET / - <<-'EOF'
|
||||||
|
cat nmap.html | kapow set /response/body
|
||||||
|
EOF
|
||||||
|
|
||||||
|
kapow route add -X GET /nmap.xsl - <<-'EOF'
|
||||||
|
curl --silent https://svn.nmap.org/nmap/docs/nmap.xsl \
|
||||||
|
| kapow set /response/body
|
||||||
|
EOF
|
||||||
|
|
||||||
|
kapow route add -X POST /nmap.xml - <<-'EOF'
|
||||||
|
|
||||||
|
TARGET_SPEC=$(kapow get /request/form/target_spec)
|
||||||
|
: ${TARGET_SPEC:=127.0.0.1}
|
||||||
|
|
||||||
|
PORT_RANGES=$(kapow get /request/form/port_ranges)
|
||||||
|
: ${PORT_RANGES:=8080}
|
||||||
|
|
||||||
|
nmap \
|
||||||
|
-Pn \
|
||||||
|
-n \
|
||||||
|
-p "$PORT_RANGES" \
|
||||||
|
-oX - \
|
||||||
|
--stylesheet /nmap.xsl \
|
||||||
|
"$TARGET_SPEC" \
|
||||||
|
| kapow set /response/body
|
||||||
|
EOF
|
||||||
Reference in New Issue
Block a user