54 lines
1.6 KiB
Ruby
54 lines
1.6 KiB
Ruby
##
|
|
# This module requires Metasploit: https://metasploit.com/download
|
|
# Current source: https://github.com/rapid7/metasploit-framework
|
|
##
|
|
|
|
class MetasploitModule < Msf::Post
|
|
include Msf::Post::File
|
|
include Msf::Post::Solaris::System
|
|
|
|
def initialize(info = {})
|
|
super(
|
|
update_info(
|
|
info,
|
|
'Name' => 'Solaris Gather Configured Services',
|
|
'Description' => %q{
|
|
Post module to enumerate services on a Solaris System
|
|
},
|
|
'License' => MSF_LICENSE,
|
|
'Author' => [ 'Carlos Perez <carlos_perez[at]darkoperator.com>'],
|
|
'Platform' => [ 'solaris' ],
|
|
'SessionTypes' => [ 'shell' ]
|
|
)
|
|
)
|
|
end
|
|
|
|
# Run Method for when run command is issued
|
|
def run
|
|
distro = get_sysinfo
|
|
store_loot('solaris.version', 'text/plain', session, "Distro: #{distro[:hostname]}, Version: #{distro[:version]}, Kernel: #{distro[:kernel]}", 'solaris_info.txt', 'Solaris Version')
|
|
|
|
# Print the info
|
|
print_good('Info:')
|
|
print_good("\t#{distro[:version]}")
|
|
print_good("\t#{distro[:kernel]}")
|
|
installed_pkg = get_services
|
|
pkg_loot = store_loot('solaris.services', 'text/plain', session, installed_pkg, 'configured_services.txt', 'Solaris Configured Services')
|
|
print_good("Service list saved to loot file: #{pkg_loot}")
|
|
if datastore['VERBOSE']
|
|
print_good('Services:')
|
|
|
|
# Print the Packages
|
|
installed_pkg.each_line do |p|
|
|
print_good("\t#{p.chomp}")
|
|
end
|
|
end
|
|
end
|
|
|
|
def get_services
|
|
services_installed = ''
|
|
services_installed = cmd_exec('/usr/bin/svcs -a')
|
|
return services_installed
|
|
end
|
|
end
|