Module: Msf::Exploit::Remote::Udp
- Included in:
- DNS::Client, MSSQL, SNMPClient, Rex::Proto::MSSQL::Client
- Defined in:
- lib/msf/core/exploit/remote/udp.rb
Overview
This module provides methods for communicating with a host over UDP
Instance Attribute Summary collapse
-
#udp_sock ⇒ Object
protected
Returns the value of attribute udp_sock.
Instance Method Summary collapse
-
#chost ⇒ Object
Returns the local host for outgoing connections.
-
#cleanup ⇒ Object
Performs cleanup, disconnects the socket if necessary.
-
#connect_udp(global = true, opts = {}) ⇒ Object
Creates a UDP socket for communicating with a remote host.
-
#cport ⇒ Object
Returns the local port for outgoing connections.
- #deregister_udp_options ⇒ Object
-
#disconnect_udp(nsock = self.udp_sock) ⇒ Object
Closes the UDP socket.
-
#handler(nsock = self.udp_sock) ⇒ Object
Claims the UDP socket if the payload so desires.
-
#initialize(info = {}) ⇒ Object
Initializes an instance of an exploit module that exploits a vulnerability in a UDP service.
-
#lhost ⇒ Object
Returns the local host.
-
#lport ⇒ Object
Returns the local port.
-
#rhost ⇒ Object
Returns the target host.
-
#rport ⇒ Object
Returns the remote port.
Instance Attribute Details
permalink #udp_sock ⇒ Object (protected)
Returns the value of attribute udp_sock.
157 158 159 |
# File 'lib/msf/core/exploit/remote/udp.rb', line 157 def udp_sock @udp_sock end |
Instance Method Details
permalink #chost ⇒ Object
Returns the local host for outgoing connections
116 117 118 |
# File 'lib/msf/core/exploit/remote/udp.rb', line 116 def chost datastore['CHOST'] end |
permalink #cleanup ⇒ Object
Performs cleanup, disconnects the socket if necessary
102 103 104 105 |
# File 'lib/msf/core/exploit/remote/udp.rb', line 102 def cleanup super disconnect_udp end |
permalink #connect_udp(global = true, opts = {}) ⇒ Object
Creates a UDP socket for communicating with a remote host
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 |
# File 'lib/msf/core/exploit/remote/udp.rb', line 39 def connect_udp(global = true, opts={}) nsock = Rex::Socket::Udp.create( 'PeerHost' => opts['RHOST'] || rhost, 'PeerPort' => (opts['RPORT'] || rport).to_i, 'LocalHost' => opts['CHOST'] || chost || "0.0.0.0", 'LocalPort' => (opts['CPORT'] || cport || 0).to_i, 'Context' => { 'Msf' => framework, 'MsfExploit' => self, }) # Set this socket to the global socket as necessary self.udp_sock = nsock if (global) # Add this socket to the list of sockets created by this exploit add_socket(nsock) return nsock end |
permalink #cport ⇒ Object
Returns the local port for outgoing connections
123 124 125 |
# File 'lib/msf/core/exploit/remote/udp.rb', line 123 def cport datastore['CPORT'] end |
permalink #deregister_udp_options ⇒ Object
[View source] [View on GitHub]
32 33 34 |
# File 'lib/msf/core/exploit/remote/udp.rb', line 32 def ('RHOST', 'RPORT') end |
permalink #disconnect_udp(nsock = self.udp_sock) ⇒ Object
Closes the UDP socket
63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 |
# File 'lib/msf/core/exploit/remote/udp.rb', line 63 def disconnect_udp(nsock = self.udp_sock) begin if (nsock) nsock.shutdown nsock.close end rescue IOError end if (nsock == udp_sock) self.udp_sock = nil end # Remove this socket from the list of sockets created by this exploit remove_socket(nsock) end |
permalink #handler(nsock = self.udp_sock) ⇒ Object
Claims the UDP socket if the payload so desires.
83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 |
# File 'lib/msf/core/exploit/remote/udp.rb', line 83 def handler(nsock = self.udp_sock) # If the handler claims the socket, then we don't want it to get closed # during cleanup if ((rv = super) == Handler::Claimed) if (nsock == self.udp_sock) self.sock = nil end # Remove this socket from the list of sockets so that it will not be # aborted. remove_socket(nsock) end return rv end |
permalink #initialize(info = {}) ⇒ Object
Initializes an instance of an exploit module that exploits a vulnerability in a UDP service
15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 |
# File 'lib/msf/core/exploit/remote/udp.rb', line 15 def initialize(info = {}) super ( [ Opt::RHOST, Opt::RPORT, ], Msf::Exploit::Remote::Udp) ( [ Opt::CPORT, Opt::CHOST ], Msf::Exploit::Remote::Udp ) end |
permalink #lhost ⇒ Object
Returns the local host
130 131 132 |
# File 'lib/msf/core/exploit/remote/udp.rb', line 130 def lhost datastore['LHOST'] end |
permalink #lport ⇒ Object
Returns the local port
137 138 139 |
# File 'lib/msf/core/exploit/remote/udp.rb', line 137 def lport datastore['LPORT'] end |
permalink #rhost ⇒ Object
Returns the target host
144 145 146 |
# File 'lib/msf/core/exploit/remote/udp.rb', line 144 def rhost datastore['RHOST'] end |
permalink #rport ⇒ Object
Returns the remote port
151 152 153 |
# File 'lib/msf/core/exploit/remote/udp.rb', line 151 def rport datastore['RPORT'] end |