/
aix_version.rb
73 lines (59 loc) · 1.79 KB
/
aix_version.rb
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
##
# This module requires Metasploit: https://metasploit.com/download
# Current source: https://github.com/rapid7/metasploit-framework
##
class MetasploitModule < Msf::Auxiliary
include Msf::Exploit::Remote::SNMPClient
include Msf::Auxiliary::Report
include Msf::Auxiliary::Scanner
def initialize
super(
'Name' => 'AIX SNMP Scanner Auxiliary Module',
'Description' => 'AIX SNMP Scanner Auxiliary Module',
'Author' =>
[
'Ramon de C Valle',
'Adriano Lima <adriano[at]risesecurity.org>',
],
'License' => MSF_LICENSE
)
end
def run_host(ip)
begin
snmp = connect_snmp
value = snmp.get_value('sysDescr.0')
if value =~ /AIX/
value = value.split("\n")
description = value[0].strip
value = value[2].split(':')
value = value[1].strip
value = value.split('.')
value[0] = value[0].to_i
value[1] = value[1].to_i
value[2] = value[2].to_i
value[3] = value[3].to_i
version = "#{value[0]}.#{value[1]}.#{value[2]}.#{value[3]}"
report_note(
:host => ip,
:proto => 'udp',
:sname => 'snmp',
:port => datastore['RPORT'],
:type => 'AIX',
:data => version
)
status = "#{ip} (#{description}) is running: "
status << "IBM AIX Version #{value[0]}.#{value[1]}.#{value[3]} "
status << "(#{version})"
print_status(status)
end
# No need to make noise about timeouts
rescue ::Rex::ConnectionError, ::SNMP::RequestTimeout, ::SNMP::UnsupportedVersion
rescue ::Interrupt
raise $!
rescue Exception => e
print_error("#{ip} #{e.class}, #{e.message}")
ensure
disconnect_snmp
end
end
end