-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathdaily_scan_options.sh
147 lines (127 loc) · 5.21 KB
/
daily_scan_options.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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
#!/bin/bash
file=""
ouput="nuclei_output.txt"
output_domains="new_domain.txt"
threads=500
function prepare_template {
echo "step prepare templates ?"
rm -rf ./ncl_temp 2&> /dev/null
mkdir ./ncl_temp
cp -r ~/nuclei-templates/ ./ncl_temp
cp -r ~/ncl/templates ./ncl_temp
cp -r ~/tools/pikpik/nuclei/ ./ncl_temp
cd ./ncl_temp
if [[ -f ../.templates ]]; then
for i in $(cat ../.templates);do
find ./ -iname "$i" -exec rm -rf {} \;
done
else
touch ../.templates
fi
cd -
}
function update_templates {
echo " update template"
nuclei -update-templates -silent
# cd ~/tools/pikpik/nuclei/ && git pull && cd -
cd ~/ncl && git pull && cd -
}
function scan {
echo "scan "
cat $file |nuclei -t ./ncl_temp -c $threads -stats -timeout 5 -severity critical,high,medium,low | anew $ouput |notify -silent
}
function update_log {
echo "update Log"
cd ./ncl_temp && find ./ -iname "*.yaml" |grep -r "$4" |cut -d ":" -f 1 | rev | cut -d'/' -f1 | rev >> ../.templates
cd .. && cat .templates |sort -uo .templates
rm -rf ./ncl_temp
}
function crl() {
echo "rapide"
curl -s "https://rapiddns.io/subdomain/$1?full=1#result" | grep "<td><a" | cut -d '"' -f 2 | grep http | cut -d '/' -f3 | sed 's/#results//g' | sort -u >> $output_domains
echo "threatcrowd"
curl --silent "https://www.threatcrowd.org/searchApi/v2/domain/report/?domain=$1" |jq -r .subdomains[] |sort -u >> $output_domains
echo "bufferover"
curl -s "https://dns.bufferover.run/dns?q=.$1" |jq -r .FDNS_A[]|cut -d',' -f2|sort -u >> $output_domains
echo "riddle"
curl -s "https://riddler.io/search/exportcsv?q=pld:$1" | grep -Po "(([\w.-]*)\.([\w]*)\.([A-z]))\w+" | sort -u >> $output_domains
echo "virustotal"
curl -s "https://www.virustotal.com/ui/domains/$1/subdomains?limit=400" | grep -Po "((http|https):\/\/)?(([\w.-]*)\.([\w]*)\.([A-z]))\w+" | sort -u >> $output_domains
echo "certspoter"
# curl -s "https://certspotter.com/api/v0/certs?domain=$1" | grep -Po "((http|https):\/\/)?(([\w.-]*)\.([\w]*)\.([A-z]))\w+" | sort -u >> $output_domains
# echo "archive"
curl -s "http://web.archive.org/cdx/search/cdx?url=*.$1/*&output=text&fl=original&collapse=urlkey" | sed -e 's_https*://__' -e "s/\/.*//" | sort -u >> $output_domains
echo "jldc"
curl -s "https://jldc.me/anubis/subdomains/$1" | grep -Po "((http|https):\/\/)?(([\w.-]*)\.([\w]*)\.([A-z]))\w+" | sort -u >> $output_domains
echo "secutrails"
curl -s "https://securitytrails.com/list/apex_domain/$1" | grep -Po "((http|https):\/\/)?(([\w.-]*)\.([\w]*)\.([A-z]))\w+" | grep ".$1" | sort -u >> $output_domains
echo "crt"
curl -s "https://crt.sh/?q=%25.$1&output=json" | jq -r '.[].name_value' | sed 's/\*\.//g' | sort -u >> $output_domains
echo "recon"
curl "https://recon.dev/api/search?key=$rec_dev_key&domain=$1" |jq -r '.[].raw$output_domains[]' | sed 's/ //g' | sort -u >> $output_domains
echo "sonar"
curl --silent "https://sonar.omnisint.io/subdomains/$1" |grep -oE "[a-zA-Z0-9._-]+\.$1" | sort -u >> $output_domains
echo "synapsint"
# curl --silent -X POST "https://synapsint.com/report.php" -d "name=https%3A%2F%2F$1" |grep -oE "[a-zA-Z0-9._-]+\.$1" | sort -u >> $output_domains
}
function new_assets {
echo "search for new asset"
for domain in $(cat ./scope);do
crl $domain
echo "$domain" |subfinder |tee -a $output_domains
git_domains -d $domains -t $github_api |tee -a $output_domains
done
cat Hosts > a
cat $output_domains | httpx -threads 200 -timeout 5 -silent | anew a | tee -a daily_hosts.txt
cat daily_hosts.txt | grep -f scope | sort -uo daily_hosts.txt
cat daily_hosts.txt >> new_Hosts
rm a
}
function scan_new_assets {
echo "scan new asset"
cat daily_hosts.txt | nuclei -t ~/nuclei-templates/ -t ~/ncl/templates -t ~/tools/pikpik/nuclei/ -c 500 -stats -timeout 5 -severity critical | anew new_host_output.txt |notify -silent
cat daily_hosts.txt | nuclei -t ~/nuclei-templates/ -t ~/ncl/templates -t ~/tools/pikpik/nuclei/ -c 500 -stats -timeout 5 -severity high | anew new_host_output.txt |notify -silent
cat daily_hosts.txt | nuclei -t ~/nuclei-templates/ -t ~/ncl/templates -t ~/tools/pikpik/nuclei/ -c 500 -stats -timeout 5 -severity medium | anew new_host_output.txt |notify -silent
cat daily_hosts.txt | anew Hosts
rm daily_hosts.txt
}
function help {
echo "usage:"
echo "dailyscan.sh -f Hosts -t threads"
}
while getopts ":f:c:" OPTION
do
case $OPTION in
f)
file="$OPTARG"
;;
t)
threads="$OPTARG"
;;
:)
help
exit 1
;;
\?)
help
exit 1
;;
esac
done
if [[ $file != "" ]];then
mkdir -p output
while true ;do
echo "scan for $time"
update_templates
prepare_template
scan
update_log
if [[ -f ./scope ]];then
new_assets
scan_new_assets
fi
output
done
else
echo "file required !!!"
fi