-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathgetdomainnames.sh
67 lines (60 loc) · 2.34 KB
/
getdomainnames.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#!/bin/sh
trap cleanup 1 2 3 6
####################################################################################################
# Script: getdomainnames.sh
# VERSION=2.0.0
# Author: Xentrk
# Date: 28-June-2020
#_______________________________________________________________________________________________________________
#
# This script will collect domain names mined from /opt/var/log/dnsmasq.log while accessing a website or
# when streaming media.
#
# Usage Instructions:
#
# sh getdomainnames.sh
#
# 1. You will be prompted for file used to store the results.
# 2. Enter the IPv4 address of the LAN Client used to perform lookups.
# 3. Access the streaming service and watch some videos for a few seconds and select each menu option to generate
# domain names.
# 4. Type 'Ctrl-C' to exit
# 5. The domain names collected will appear on the screen and also stored in the file you specified in the
# /opt/var/log directory.
#_______________________________________________________________________________________________________________
# Print between line beginning with '#_' to first blank line inclusive
ShowHelp() {
awk '/^#__/{f=1} f{print; if (!NF) exit}' "$0" | more
}
cleanup() {
printf '\n%s\n' "Done capturing domains from dnsmasq.log"
echo "Sorting file."
true >"$OUTPUT_FILE"
grep "$IPv4" "${OUTPUT_FILE}_tmp" | grep "query" | awk '{ print $6 }' | sort -u >>"$OUTPUT_FILE"
printf '%s\n\n' "File contents are:"
printf '%s\n\n' "$(cat "$OUTPUT_FILE")"
printf '%s\n' "File location is: $OUTPUT_FILE"
exit 0
}
# Need assistance!???
if [ "$1" = "help" ] || [ "$1" = "-h" ]; then
ShowHelp
exit 0
fi
if [ ! -s "/opt/var/log/dnsmasq.log" ]; then
printf '\nError: /opt/var/log/dnsmasq.log file does not exist\n' && printf '\nScript expects dnsmasq.log file to exist in /opt/var/log\n' && exit 1
fi
printf '\nEnter a descriptive name of the output file ==> '
read -r "FILE"
OUTPUT_FILE="/opt/var/log/$FILE"
printf '\nEnter the IP address ==> '
read -r "IPv4"
IP=$(echo "$IPv4" | grep -oE "^(([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])$")
if [ -z "$IP" ]; then
printf 'Error! "%s" is not a valid IPv4 address\n' "$IPv4"
exit 1
fi
if [ -s "/opt/var/log/dnsmasq.log" ]; then
printf '\nPress Ctrl-C to stop logging\n'
tail -f /opt/var/log/dnsmasq.log >"${OUTPUT_FILE}_tmp"
fi