98 lines
3.3 KiB
Ruby
98 lines
3.3 KiB
Ruby
# -*- coding:binary -*-
|
|
require 'spec_helper'
|
|
|
|
require 'rex/java/serialization'
|
|
require 'rex/proto/rmi'
|
|
require 'msf/java/rmi/client'
|
|
|
|
describe Msf::Java::Rmi::Client::Registry::Parser do
|
|
subject(:mod) do
|
|
mod = ::Msf::Exploit.new
|
|
mod.extend ::Msf::Java::Rmi::Client
|
|
mod.send(:initialize)
|
|
mod
|
|
end
|
|
|
|
let(:lookup_return) do
|
|
raw = "\xac\xed\x00\x05\x77\x0f\x01\x38\x7c\xdd\xc3\x00\x00\x01\x4c\x2d" +
|
|
"\x86\x47\x4c\x80\x65\x73\x72\x00\x2e\x6a\x61\x76\x61\x78\x2e\x6d" +
|
|
"\x61\x6e\x61\x67\x65\x6d\x65\x6e\x74\x2e\x72\x65\x6d\x6f\x74\x65" +
|
|
"\x2e\x72\x6d\x69\x2e\x52\x4d\x49\x53\x65\x72\x76\x65\x72\x49\x6d" +
|
|
"\x70\x6c\x5f\x53\x74\x75\x62\x00\x00\x00\x00\x00\x00\x00\x02\x02" +
|
|
"\x00\x00\x70\x78\x72\x00\x1a\x6a\x61\x76\x61\x2e\x72\x6d\x69\x2e" +
|
|
"\x73\x65\x72\x76\x65\x72\x2e\x52\x65\x6d\x6f\x74\x65\x53\x74\x75" +
|
|
"\x62\xe9\xfe\xdc\xc9\x8b\xe1\x65\x1a\x02\x00\x00\x70\x78\x72\x00" +
|
|
"\x1c\x6a\x61\x76\x61\x2e\x72\x6d\x69\x2e\x73\x65\x72\x76\x65\x72" +
|
|
"\x2e\x52\x65\x6d\x6f\x74\x65\x4f\x62\x6a\x65\x63\x74\xd3\x61\xb4" +
|
|
"\x91\x0c\x61\x33\x1e\x03\x00\x00\x70\x78\x70\x77\x37\x00\x0a\x55" +
|
|
"\x6e\x69\x63\x61\x73\x74\x52\x65\x66\x00\x0e\x31\x37\x32\x2e\x31" +
|
|
"\x36\x2e\x31\x35\x38\x2e\x31\x33\x32\x00\x00\x11\x96\x8a\xd0\x5a" +
|
|
"\x9e\xa1\xeb\x94\x3e\x38\x7c\xdd\xc3\x00\x00\x01\x4c\x2d\x86\x47" +
|
|
"\x4c\x80\x01\x01\x78"
|
|
io = StringIO.new(raw, 'rb')
|
|
rv = Rex::Proto::Rmi::Model::ReturnValue.new
|
|
rv.decode(io)
|
|
|
|
rv
|
|
end
|
|
|
|
let(:remote_object) { 'javax.management.remote.rmi.RMIServerImpl_Stub' }
|
|
let(:remote_interface) do
|
|
{
|
|
address: '172.16.158.132',
|
|
port: 4502,
|
|
object_number: -8444149663951776706
|
|
}
|
|
end
|
|
|
|
let(:list_return) do
|
|
raw = "\xac\xed\x00\x05\x77\x0f\x01\x38\x7c\xdd\xc3\x00\x00\x01\x4c\x2d" +
|
|
"\x86\x47\x4c\x80\x66\x75\x72\x00\x13\x5b\x4c\x6a\x61\x76\x61\x2e" +
|
|
"\x6c\x61\x6e\x67\x2e\x53\x74\x72\x69\x6e\x67\x3b\xad\xd2\x56\xe7" +
|
|
"\xe9\x1d\x7b\x47\x02\x00\x00\x70\x78\x70\x00\x00\x00\x01\x74\x00" +
|
|
"\x06\x6a\x6d\x78\x72\x6d\x69"
|
|
|
|
io = StringIO.new(raw, 'rb')
|
|
rv = Rex::Proto::Rmi::Model::ReturnValue.new
|
|
rv.decode(io)
|
|
|
|
rv
|
|
end
|
|
|
|
let(:names) { ['jmxrmi'] }
|
|
|
|
describe "#parse_registry_lookup_endpoint" do
|
|
it "returns the remote reference information in a Hash" do
|
|
expect(mod.parse_registry_lookup_endpoint(lookup_return)).to be_a(Hash)
|
|
end
|
|
|
|
it "returns the remote address" do
|
|
ref = mod.parse_registry_lookup_endpoint(lookup_return)
|
|
expect(ref[:address]).to eq(remote_interface[:address])
|
|
end
|
|
|
|
it "returns the remote port" do
|
|
ref = mod.parse_registry_lookup_endpoint(lookup_return)
|
|
expect(ref[:port]).to eq(remote_interface[:port])
|
|
end
|
|
|
|
it "returns the remote object number" do
|
|
ref = mod.parse_registry_lookup_endpoint(lookup_return)
|
|
expect(ref[:object_number]).to eq(remote_interface[:object_number])
|
|
end
|
|
|
|
it "returns the remote object unique identifier" do
|
|
ref = mod.parse_registry_lookup_endpoint(lookup_return)
|
|
expect(ref[:uid]).to be_a(Rex::Proto::Rmi::Model::UniqueIdentifier)
|
|
end
|
|
end
|
|
|
|
describe "#parse_registry_list" do
|
|
it "returns the list of names" do
|
|
expect(mod.parse_registry_list(list_return)).to eq(names)
|
|
end
|
|
end
|
|
|
|
end
|
|
|