File: RFI-Scanner-Bot.rb

package info (click to toggle)
whatweb 0.4.8~git20120606-1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 7,956 kB
  • sloc: ruby: 53,738; sh: 577; makefile: 34
file content (93 lines) | stat: -rw-r--r-- 3,314 bytes parent folder | download
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
##
# This file is part of WhatWeb and may be subject to
# redistribution and commercial restrictions. Please see the WhatWeb
# web site for more information on licensing and terms of use.
# http://www.morningstarsecurity.com/research/whatweb
##
Plugin.define "RFI-Scanner-Bot" do
author "Brendan Coles <bcoles@gmail.com>" # 2010-10-15
version "0.1"
description "This plugin idenitfies instances of Remote File Include Scanner bots (aka feelscanz.pl, gmjk.pl, FeeLCoMz.pl, rfi.pl) and extracts the command and control servers, channels and passwords."

# 57 results for "##[ RUTIN SEARCH ENGINE ]##" "my @servers" "#!/usr/bin/perl" @ 2010-10-15
# 21 results for "perl feelscanz.pl <chan w/o #> <server> <port>" @ 2010-10-15
# 57 results for "my @servers" "#!/usr/bin/perl" +chan +nick ext:txt
examples %w|
armypratama.eu/file:/bot/rfi1.txt
beltps.by/images/File/zayavlenie/rss.txt
beltps.by/images/File/zayavlenie/scn.txt
brandon420.fileave.com/scan/rfi-scanner3.txt
brandon420.fileave.com/scan/rfi-scanner3n.txt
capsud-hotel.com/eng/gmjk2.txt
filesplus.abunawaf.com/2007-04/s.txt.3
frank79.idv.tw/wp-content/uploads/2009/03/klorovers.txt
host67.hrwebservices.net/~allstag/AllstagePhotos/data/media/a/caks.txt
im3tulungagung.zoomshare.com/files/s7.txt
jatidowo.zoomshare.com/files/sc.txt
leoboy1.fileave.com/f.txt
love-to.net/log/scanmild.txt
makras8.webs.com/embat.txt
momok.org/tools/unix.txt
nautilus.fis.uc.pt/aif/forms/coisas/concelho.txt
nmta.info/meidi/mei1.txt
upelmaturintv.com.ve/canaltv/scan.txt
wan8.fileave.com/bar.txt
www.bulltear.com/catalog/images/p.txt
www.bookguild.co.uk/skin1/images/zen.txt
www.kortech.cn/bbs/scan.txt
www.porto.napoli.it/tt/data/scanerA.txt
www.porto.napoli.it/tt/data/scanerB.txt
www.prosyachtdelivery.com/downloads/bot_e107.txt
www.prunk.si/mediawiki/images/4/45/R.txt
www.ulster.irishhome.net/archive/asu.txt
www.ulster.irishhome.net/archive/byz.txt
www.xn--9iqr86bsxdx46a.com/Public/Js/FCKeditor/editor/filemanager/connectors/php/20100901_123943569.txt
|

# Extract bot config
def passive
	m=[]

	if @body =~ /^## + RFI Scan & Exploit \(Exploit per engine\)        ##/ or @body =~ /^######################################################/ or @body =~ /^##   perl feelscanz.pl <chan w\/o #> <server> <port> ##/ or @body =~ /##\[ RUTIN SEARCH ENGINE \]##/ or @body =~ /^## + Fixed cryptz command \(v4.5\)/ and @body =~ /^#!\/usr\/bin\/perl/

		# Servers
		if @body =~ /^my @servers[\s]*=[\s]*\(([^\)]+)/
			modules=@body.scan(/^my @servers[\s]*=[\s]*\(([^\)]+)/)
			m << {:module=>modules}
		end

		# Port
		if @body =~ /^my @ports[\s]*=[\s]*\(([^\)]+)/
			modules=@body.scan(/^my @ports[\s]*=[\s]*\(([^\)]+)/)
			m << {:module=>modules}
		elsif @body =~ /^[\s]+port[\s]*=>[\s]*([^\r^\n]+)/
			modules=@body.scan(/^[\s]+port[\s]*=>[\s]*([^\r^\n]+)/)
			m << {:module=>modules}
		end

		# Channels
		if @body =~ /^[\s]+chan[\s]*=>[\s]*([^\r^\n]+)/
			modules=@body.scan(/^[\s]+chan[\s]*=>[\s]*([^\r^\n]+)/)
			m << {:module=>modules}
		end

		# Accounts
		if @body =~ /^[\s]*pass[\s]*=>[\s]*([^,^\r^\n]+)/
			accounts=@body.scan(/^[\s]*pass[\s]*=>[\s]*([^,^\r^\n]+)/)
			m << {:account=>accounts}
		end

		# Version
		if @body =~ /^my \$versi[\s]*=[\s]*"([^\"]+)/
			version=@body.scan(/^my \$versi[\s]*=[\s]*"([^\"]+)/)
			m << {:version=>version}
		end

	end

	m

end

end