ronin-support 0.4.1 → 0.5.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (224) hide show
  1. checksums.yaml +7 -0
  2. data/.editorconfig +11 -0
  3. data/.github/workflows/ruby.yml +28 -0
  4. data/.ruby-version +1 -0
  5. data/.yardopts +1 -1
  6. data/ChangeLog.md +121 -33
  7. data/Gemfile +17 -18
  8. data/README.md +57 -33
  9. data/Rakefile +10 -3
  10. data/gemspec.yml +16 -7
  11. data/lib/ronin/binary.rb +21 -0
  12. data/lib/ronin/binary/hexdump.rb +20 -0
  13. data/lib/ronin/binary/hexdump/parser.rb +403 -0
  14. data/lib/ronin/binary/struct.rb +567 -0
  15. data/lib/ronin/binary/template.rb +454 -0
  16. data/lib/ronin/extensions.rb +5 -5
  17. data/lib/ronin/extensions/enumerable.rb +5 -5
  18. data/lib/ronin/extensions/file.rb +39 -33
  19. data/lib/ronin/extensions/ip_addr.rb +29 -31
  20. data/lib/ronin/extensions/kernel.rb +5 -5
  21. data/lib/ronin/extensions/meta.rb +5 -5
  22. data/lib/ronin/extensions/regexp.rb +50 -5
  23. data/lib/ronin/extensions/resolv.rb +7 -9
  24. data/lib/ronin/extensions/string.rb +10 -10
  25. data/lib/ronin/formatting.rb +5 -5
  26. data/lib/ronin/formatting/binary.rb +5 -5
  27. data/lib/ronin/formatting/digest.rb +5 -5
  28. data/lib/ronin/formatting/extensions.rb +5 -5
  29. data/lib/ronin/formatting/extensions/binary.rb +7 -5
  30. data/lib/ronin/formatting/extensions/binary/array.rb +61 -0
  31. data/lib/ronin/formatting/extensions/binary/base64.rb +106 -0
  32. data/lib/ronin/formatting/extensions/binary/file.rb +44 -11
  33. data/lib/ronin/formatting/extensions/binary/float.rb +65 -0
  34. data/lib/ronin/formatting/extensions/binary/integer.rb +66 -50
  35. data/lib/ronin/formatting/extensions/binary/string.rb +81 -205
  36. data/lib/ronin/formatting/extensions/digest.rb +5 -5
  37. data/lib/ronin/formatting/extensions/digest/file.rb +5 -5
  38. data/lib/ronin/formatting/extensions/digest/string.rb +5 -5
  39. data/lib/ronin/formatting/extensions/html.rb +5 -5
  40. data/lib/ronin/formatting/extensions/html/integer.rb +9 -13
  41. data/lib/ronin/formatting/extensions/html/string.rb +31 -39
  42. data/lib/ronin/formatting/extensions/http.rb +5 -5
  43. data/lib/ronin/formatting/extensions/http/integer.rb +6 -6
  44. data/lib/ronin/formatting/extensions/http/string.rb +7 -7
  45. data/lib/ronin/formatting/extensions/sql.rb +5 -5
  46. data/lib/ronin/formatting/extensions/sql/string.rb +22 -24
  47. data/lib/ronin/formatting/extensions/text.rb +5 -5
  48. data/lib/ronin/formatting/extensions/text/array.rb +13 -11
  49. data/lib/ronin/formatting/extensions/text/string.rb +70 -13
  50. data/lib/ronin/formatting/html.rb +5 -5
  51. data/lib/ronin/formatting/http.rb +5 -5
  52. data/lib/ronin/formatting/sql.rb +5 -5
  53. data/lib/ronin/formatting/text.rb +5 -5
  54. data/lib/ronin/fuzzing.rb +5 -5
  55. data/lib/ronin/fuzzing/extensions.rb +5 -5
  56. data/lib/ronin/fuzzing/extensions/string.rb +42 -213
  57. data/lib/ronin/fuzzing/fuzzer.rb +110 -0
  58. data/lib/ronin/fuzzing/fuzzing.rb +33 -26
  59. data/lib/ronin/fuzzing/mutator.rb +161 -0
  60. data/lib/ronin/fuzzing/repeater.rb +81 -0
  61. data/lib/ronin/fuzzing/template.rb +133 -0
  62. data/lib/ronin/mixin.rb +2 -2
  63. data/lib/ronin/network.rb +7 -5
  64. data/lib/ronin/network/dns.rb +64 -24
  65. data/lib/ronin/network/esmtp.rb +5 -5
  66. data/lib/ronin/network/extensions.rb +5 -5
  67. data/lib/ronin/network/extensions/dns.rb +5 -5
  68. data/lib/ronin/network/extensions/dns/net.rb +5 -5
  69. data/lib/ronin/network/extensions/esmtp.rb +5 -5
  70. data/lib/ronin/network/extensions/esmtp/net.rb +5 -5
  71. data/lib/ronin/network/extensions/http.rb +5 -5
  72. data/lib/ronin/network/extensions/http/net.rb +5 -5
  73. data/lib/ronin/network/extensions/http/uri/http.rb +5 -5
  74. data/lib/ronin/network/extensions/imap.rb +5 -5
  75. data/lib/ronin/network/extensions/imap/net.rb +5 -5
  76. data/lib/ronin/network/extensions/pop3.rb +5 -5
  77. data/lib/ronin/network/extensions/pop3/net.rb +5 -5
  78. data/lib/ronin/network/extensions/smtp.rb +5 -5
  79. data/lib/ronin/network/extensions/smtp/net.rb +5 -5
  80. data/lib/ronin/network/extensions/ssl.rb +5 -5
  81. data/lib/ronin/network/extensions/ssl/net.rb +5 -5
  82. data/lib/ronin/network/extensions/tcp.rb +5 -5
  83. data/lib/ronin/network/extensions/tcp/net.rb +5 -5
  84. data/lib/ronin/network/extensions/telnet.rb +5 -5
  85. data/lib/ronin/network/extensions/telnet/net.rb +5 -5
  86. data/lib/ronin/network/extensions/udp.rb +5 -5
  87. data/lib/ronin/network/extensions/udp/net.rb +5 -5
  88. data/lib/ronin/network/ftp.rb +149 -0
  89. data/lib/ronin/network/http.rb +5 -5
  90. data/lib/ronin/network/http/exceptions.rb +5 -5
  91. data/lib/ronin/network/http/exceptions/unknown_request.rb +5 -5
  92. data/lib/ronin/network/http/http.rb +65 -70
  93. data/lib/ronin/network/http/proxy.rb +5 -5
  94. data/lib/ronin/network/imap.rb +16 -15
  95. data/lib/ronin/network/mixins.rb +6 -5
  96. data/lib/ronin/network/mixins/dns.rb +5 -5
  97. data/lib/ronin/network/mixins/esmtp.rb +5 -5
  98. data/lib/ronin/network/mixins/ftp.rb +155 -0
  99. data/lib/ronin/network/mixins/http.rb +58 -587
  100. data/lib/ronin/network/mixins/imap.rb +5 -5
  101. data/lib/ronin/network/mixins/mixin.rb +5 -5
  102. data/lib/ronin/network/mixins/pop3.rb +5 -5
  103. data/lib/ronin/network/mixins/smtp.rb +5 -5
  104. data/lib/ronin/network/mixins/ssl.rb +5 -5
  105. data/lib/ronin/network/mixins/tcp.rb +43 -10
  106. data/lib/ronin/network/mixins/telnet.rb +5 -5
  107. data/lib/ronin/network/mixins/udp.rb +126 -6
  108. data/lib/ronin/network/mixins/unix.rb +279 -0
  109. data/lib/ronin/network/network.rb +5 -5
  110. data/lib/ronin/network/pop3.rb +10 -10
  111. data/lib/ronin/network/proxy.rb +578 -0
  112. data/lib/ronin/network/smtp.rb +5 -5
  113. data/lib/ronin/network/smtp/email.rb +6 -6
  114. data/lib/ronin/network/smtp/smtp.rb +12 -13
  115. data/lib/ronin/network/ssl.rb +16 -17
  116. data/lib/ronin/network/tcp.rb +7 -310
  117. data/lib/ronin/network/tcp/proxy.rb +417 -0
  118. data/lib/ronin/network/tcp/tcp.rb +452 -0
  119. data/lib/ronin/network/telnet.rb +34 -28
  120. data/lib/ronin/network/udp.rb +7 -271
  121. data/lib/ronin/network/udp/proxy.rb +191 -0
  122. data/lib/ronin/network/udp/udp.rb +452 -0
  123. data/lib/ronin/network/unix.rb +286 -0
  124. data/lib/ronin/path.rb +35 -39
  125. data/lib/ronin/spec/ui/output.rb +6 -12
  126. data/lib/ronin/support.rb +6 -5
  127. data/lib/ronin/support/inflector.rb +8 -12
  128. data/lib/ronin/support/support.rb +7 -5
  129. data/lib/ronin/support/version.rb +6 -6
  130. data/lib/ronin/templates.rb +5 -5
  131. data/lib/ronin/templates/erb.rb +5 -5
  132. data/lib/ronin/templates/template.rb +5 -5
  133. data/lib/ronin/ui/output.rb +5 -5
  134. data/lib/ronin/ui/output/helpers.rb +42 -28
  135. data/lib/ronin/ui/output/output.rb +17 -21
  136. data/lib/ronin/ui/output/terminal.rb +5 -5
  137. data/lib/ronin/ui/output/terminal/color.rb +15 -9
  138. data/lib/ronin/ui/output/terminal/raw.rb +5 -5
  139. data/lib/ronin/ui/shell.rb +8 -11
  140. data/lib/ronin/wordlist.rb +110 -30
  141. data/ronin-support.gemspec +39 -109
  142. data/spec/binary/hexdump/helpers/hexdumps.rb +13 -0
  143. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/ascii.bin +0 -0
  144. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/hexdump_decimal_shorts.txt +0 -0
  145. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/hexdump_hex_bytes.txt +0 -0
  146. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/hexdump_hex_shorts.txt +0 -0
  147. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/hexdump_octal_bytes.txt +0 -0
  148. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/hexdump_octal_shorts.txt +0 -0
  149. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/hexdump_repeated.txt +0 -0
  150. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_decimal_bytes.txt +0 -0
  151. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_decimal_ints.txt +0 -0
  152. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_decimal_quads.txt +0 -0
  153. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_decimal_shorts.txt +0 -0
  154. data/spec/binary/hexdump/helpers/hexdumps/od_doubles.txt +17 -0
  155. data/spec/binary/hexdump/helpers/hexdumps/od_floats.txt +17 -0
  156. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_hex_bytes.txt +0 -0
  157. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_hex_ints.txt +0 -0
  158. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_hex_quads.txt +0 -0
  159. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_hex_shorts.txt +0 -0
  160. data/spec/binary/hexdump/helpers/hexdumps/od_named_chars.txt +17 -0
  161. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_octal_bytes.txt +0 -0
  162. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_octal_ints.txt +0 -0
  163. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_octal_quads.txt +0 -0
  164. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_octal_shorts.txt +0 -0
  165. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_repeated.txt +0 -0
  166. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/repeated.bin +0 -0
  167. data/spec/binary/hexdump/parser_spec.rb +302 -0
  168. data/spec/binary/struct_spec.rb +496 -0
  169. data/spec/binary/template_spec.rb +416 -0
  170. data/spec/extensions/enumerable_spec.rb +4 -4
  171. data/spec/extensions/file_spec.rb +12 -14
  172. data/spec/extensions/ip_addr_spec.rb +76 -50
  173. data/spec/extensions/kernel_spec.rb +7 -7
  174. data/spec/extensions/regexp_spec.rb +119 -59
  175. data/spec/extensions/resolv_spec.rb +2 -2
  176. data/spec/extensions/string_spec.rb +31 -30
  177. data/spec/formatting/binary/array_spec.rb +26 -0
  178. data/spec/formatting/binary/base64_spec.rb +50 -0
  179. data/spec/formatting/binary/float_spec.rb +36 -0
  180. data/spec/formatting/binary/integer_spec.rb +76 -50
  181. data/spec/formatting/binary/string_spec.rb +91 -198
  182. data/spec/formatting/digest/string_spec.rb +5 -5
  183. data/spec/formatting/html/integer_spec.rb +6 -6
  184. data/spec/formatting/html/string_spec.rb +10 -10
  185. data/spec/formatting/http/integer_spec.rb +3 -3
  186. data/spec/formatting/http/string_spec.rb +5 -5
  187. data/spec/formatting/sql/string_spec.rb +21 -19
  188. data/spec/formatting/text/array_spec.rb +15 -15
  189. data/spec/formatting/text/string_spec.rb +58 -28
  190. data/spec/fuzzing/extensions/string_spec.rb +87 -0
  191. data/spec/fuzzing/fuzzer_spec.rb +109 -0
  192. data/spec/fuzzing/fuzzing_spec.rb +24 -0
  193. data/spec/fuzzing/mutator_spec.rb +112 -0
  194. data/spec/fuzzing/repeater_spec.rb +57 -0
  195. data/spec/fuzzing/template_spec.rb +54 -0
  196. data/spec/mixin_spec.rb +10 -12
  197. data/spec/network/dns_spec.rb +89 -23
  198. data/spec/network/ftp_spec.rb +81 -0
  199. data/spec/network/http/http_spec.rb +237 -144
  200. data/spec/network/http/proxy_spec.rb +37 -37
  201. data/spec/network/network_spec.rb +2 -2
  202. data/spec/network/proxy_spec.rb +121 -0
  203. data/spec/network/shared/unix_server.rb +31 -0
  204. data/spec/network/smtp/email_spec.rb +14 -14
  205. data/spec/network/ssl_spec.rb +53 -3
  206. data/spec/network/tcp/proxy_spec.rb +118 -0
  207. data/spec/network/tcp/tcp_spec.rb +316 -0
  208. data/spec/network/telnet_spec.rb +67 -0
  209. data/spec/network/udp/udp_spec.rb +298 -0
  210. data/spec/network/unix_spec.rb +182 -0
  211. data/spec/path_spec.rb +43 -18
  212. data/spec/spec_helper.rb +2 -3
  213. data/spec/support/inflector_spec.rb +4 -4
  214. data/spec/support_spec.rb +1 -1
  215. data/spec/templates/erb_spec.rb +3 -3
  216. data/spec/templates/template_spec.rb +10 -10
  217. data/spec/ui/shell_spec.rb +15 -15
  218. data/spec/wordlist_spec.rb +80 -19
  219. metadata +176 -121
  220. data/.gemtest +0 -0
  221. data/spec/formatting/binary/helpers/hexdumps.rb +0 -16
  222. data/spec/fuzzing/string_spec.rb +0 -158
  223. data/spec/network/tcp_spec.rb +0 -247
  224. data/spec/network/udp_spec.rb +0 -248
@@ -1,20 +1,20 @@
1
1
  #
2
- # Copyright (c) 2006-2012 Hal Brodigan (postmodern.mod3 at gmail.com)
2
+ # Copyright (c) 2006-2021 Hal Brodigan (postmodern.mod3 at gmail.com)
3
3
  #
4
- # This file is part of Ronin Support.
4
+ # This file is part of ronin-support.
5
5
  #
6
- # Ronin Support is free software: you can redistribute it and/or modify
6
+ # ronin-support is free software: you can redistribute it and/or modify
7
7
  # it under the terms of the GNU Lesser General Public License as published
8
8
  # by the Free Software Foundation, either version 3 of the License, or
9
9
  # (at your option) any later version.
10
10
  #
11
- # Ronin Support is distributed in the hope that it will be useful,
11
+ # ronin-support is distributed in the hope that it will be useful,
12
12
  # but WITHOUT ANY WARRANTY; without even the implied warranty of
13
13
  # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
14
  # GNU Lesser General Public License for more details.
15
15
  #
16
16
  # You should have received a copy of the GNU Lesser General Public License
17
- # along with Ronin Support. If not, see <http://www.gnu.org/licenses/>.
17
+ # along with ronin-support. If not, see <https://www.gnu.org/licenses/>.
18
18
  #
19
19
 
20
20
  require 'net/telnet'
@@ -24,6 +24,8 @@ module Ronin
24
24
  #
25
25
  # Provides helper methods for communicating with Telnet services.
26
26
  #
27
+ # @deprecated Will be removed in 1.0.0.
28
+ #
27
29
  module Telnet
28
30
  # Default telnet port
29
31
  DEFAULT_PORT = 23
@@ -40,7 +42,7 @@ module Ronin
40
42
  #
41
43
  # @api public
42
44
  #
43
- def Telnet.default_port
45
+ def self.default_port
44
46
  @default_port ||= DEFAULT_PORT
45
47
  end
46
48
 
@@ -52,7 +54,7 @@ module Ronin
52
54
  #
53
55
  # @api public
54
56
  #
55
- def Telnet.default_port=(port)
57
+ def self.default_port=(port)
56
58
  @default_port = port
57
59
  end
58
60
 
@@ -62,7 +64,7 @@ module Ronin
62
64
  #
63
65
  # @api public
64
66
  #
65
- def Telnet.default_prompt
67
+ def self.default_prompt
66
68
  @default_prompt ||= DEFAULT_PROMPT
67
69
  end
68
70
 
@@ -74,7 +76,7 @@ module Ronin
74
76
  #
75
77
  # @api public
76
78
  #
77
- def Telnet.default_prompt=(prompt)
79
+ def self.default_prompt=(prompt)
78
80
  @default_prompt = prompt
79
81
  end
80
82
 
@@ -84,7 +86,7 @@ module Ronin
84
86
  #
85
87
  # @api public
86
88
  #
87
- def Telnet.default_timeout
89
+ def self.default_timeout
88
90
  @default_timeout ||= DEFAULT_TIMEOUT
89
91
  end
90
92
 
@@ -96,7 +98,7 @@ module Ronin
96
98
  #
97
99
  # @api public
98
100
  #
99
- def Telnet.default_timeout=(timeout)
101
+ def self.default_timeout=(timeout)
100
102
  @default_timeout = timeout
101
103
  end
102
104
 
@@ -106,7 +108,7 @@ module Ronin
106
108
  #
107
109
  # @api public
108
110
  #
109
- def Telnet.proxy
111
+ def self.proxy
110
112
  @proxy ||= nil
111
113
  end
112
114
 
@@ -118,7 +120,7 @@ module Ronin
118
120
  #
119
121
  # @api public
120
122
  #
121
- def Telnet.proxy=(new_proxy)
123
+ def self.proxy=(new_proxy)
122
124
  @proxy = new_proxy
123
125
  end
124
126
 
@@ -191,29 +193,33 @@ module Ronin
191
193
  # @api public
192
194
  #
193
195
  def telnet_connect(host,options={})
194
- host = host.to_s
195
- telnet_options = {}
196
-
197
- telnet_options['Host'] = host
198
- telnet_options['Port'] = (options[:port] || Telnet.default_port)
199
- telnet_options['Binmode'] = options[:binmode]
200
- telnet_options['Output_log'] = options[:output_log]
201
- telnet_options['Dump_log'] = options[:dump_log]
202
- telnet_options['Prompt'] = (options[:prompt] || Telnet.default_prompt)
196
+ telnet_options = {
197
+ 'Host' => host.to_s,
198
+ 'Port' => (options[:port] || Telnet.default_port),
199
+ 'Binmode' => (options[:binmode] || false),
200
+ 'Waittime' => (options[:wait_time] || 0),
201
+ 'Prompt' => (options[:prompt] || Telnet.default_prompt),
202
+ 'Timeout' => (options[:timeout] || Telnet.default_timeout)
203
+ }
203
204
 
204
205
  if (options[:telnet] && !options[:plain])
205
206
  telnet_options['Telnetmode'] = true
206
207
  end
207
208
 
208
- telnet_options['Timeout'] = (options[:timeout] || Telnet.default_timeout)
209
- telnet_options['Waittime'] = options[:wait_time]
210
- telnet_options['Proxy'] = (options[:proxy] || Telnet.proxy)
209
+ if options[:output_log]
210
+ telnet_options['Output_log'] = options[:output_log]
211
+ end
212
+
213
+ if options[:dump_log]
214
+ telnet_options['Dump_log'] = options[:dump_log]
215
+ end
211
216
 
212
- user = options[:user]
213
- passwd = options[:passwd]
217
+ if (proxy = (options[:proxy] || Telnet.proxy))
218
+ telnet_options['Proxy'] = proxy
219
+ end
214
220
 
215
221
  session = Net::Telnet.new(telnet_options)
216
- session.login(user,passwd) if user
222
+ session.login(options[:user],options[:password]) if options[:user]
217
223
 
218
224
  yield session if block_given?
219
225
  return session
@@ -1,285 +1,21 @@
1
1
  #
2
- # Copyright (c) 2006-2012 Hal Brodigan (postmodern.mod3 at gmail.com)
2
+ # Copyright (c) 2006-2021 Hal Brodigan (postmodern.mod3 at gmail.com)
3
3
  #
4
- # This file is part of Ronin Support.
4
+ # This file is part of ronin-support.
5
5
  #
6
- # Ronin Support is free software: you can redistribute it and/or modify
6
+ # ronin-support is free software: you can redistribute it and/or modify
7
7
  # it under the terms of the GNU Lesser General Public License as published
8
8
  # by the Free Software Foundation, either version 3 of the License, or
9
9
  # (at your option) any later version.
10
10
  #
11
- # Ronin Support is distributed in the hope that it will be useful,
11
+ # ronin-support is distributed in the hope that it will be useful,
12
12
  # but WITHOUT ANY WARRANTY; without even the implied warranty of
13
13
  # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
14
  # GNU Lesser General Public License for more details.
15
15
  #
16
16
  # You should have received a copy of the GNU Lesser General Public License
17
- # along with Ronin Support. If not, see <http://www.gnu.org/licenses/>.
17
+ # along with ronin-support. If not, see <https://www.gnu.org/licenses/>.
18
18
  #
19
19
 
20
- require 'socket'
21
-
22
- module Ronin
23
- module Network
24
- #
25
- # Provides helper methods for using the UDP protocol.
26
- #
27
- module UDP
28
- #
29
- # Creates a new UDPSocket object connected to a given host and port.
30
- #
31
- # @param [String] host
32
- # The host to connect to.
33
- #
34
- # @param [Integer] port
35
- # The port to connect to.
36
- #
37
- # @param [String] local_host (nil)
38
- # The local host to bind to.
39
- #
40
- # @param [Integer] local_port (nil)
41
- # The local port to bind to.
42
- #
43
- # @yield [socket]
44
- # If a block is given, it will be passed the newly created socket.
45
- #
46
- # @yieldparam [UDPsocket] socket
47
- # The newly created UDPSocket object.
48
- #
49
- # @return [UDPSocket]
50
- # The newly created UDPSocket object.
51
- #
52
- # @example
53
- # udp_connect('www.hackety.org',80)
54
- # # => UDPSocket
55
- #
56
- # @example
57
- # udp_connect('www.wired.com',80) do |socket|
58
- # puts socket.readlines
59
- # end
60
- #
61
- # @api public
62
- #
63
- def udp_connect(host,port,local_host=nil,local_port=0)
64
- host = host.to_s
65
- local_host = (local_host || '0.0.0.0').to_s
66
-
67
- socket = UDPSocket.new
68
- socket.bind(local_host,local_port) if (local_host && local_port)
69
- socket.connect(host,port)
70
-
71
- yield socket if block_given?
72
- return socket
73
- end
74
-
75
- #
76
- # Creates a new UDPSocket object, connected to a given host and port.
77
- # The given data will then be written to the newly created UDPSocket.
78
- #
79
- # @param [String] data
80
- # The data to send through the connection.
81
- #
82
- # @param [String] host
83
- # The host to connect to.
84
- #
85
- # @param [Integer] port
86
- # The port to connect to.
87
- #
88
- # @param [String] local_host (nil)
89
- # The local host to bind to.
90
- #
91
- # @param [Integer] local_port (nil)
92
- # The local port to bind to.
93
- #
94
- # @yield [socket]
95
- # If a block is given, it will be passed the newly created socket.
96
- #
97
- # @yieldparam [UDPsocket] socket
98
- # The newly created UDPSocket object.
99
- #
100
- # @return [UDPSocket]
101
- # The newly created UDPSocket object.
102
- #
103
- # @api public
104
- #
105
- def udp_connect_and_send(data,host,port,local_host=nil,local_port=0)
106
- socket = udp_connect(host,port,local_host,local_port)
107
- socket.write(data)
108
-
109
- yield socket if block_given?
110
- return socket
111
- end
112
-
113
- #
114
- # Creates a new temporary UDPSocket object, connected to the given host
115
- # and port.
116
- #
117
- # @param [String] host
118
- # The host to connect to.
119
- #
120
- # @param [Integer] port
121
- # The port to connect to.
122
- #
123
- # @param [String] local_host (nil)
124
- # The local host to bind to.
125
- #
126
- # @param [Integer] local_port (nil)
127
- # The local port to bind to.
128
- #
129
- # @yield [socket]
130
- # If a block is given, it will be passed the newly created socket.
131
- # After the block has returned, the socket will then be closed.
132
- #
133
- # @yieldparam [UDPsocket] socket
134
- # The newly created UDPSocket object.
135
- #
136
- # @return [nil]
137
- #
138
- # @api public
139
- #
140
- def udp_session(host,port,local_host=nil,local_port=0)
141
- socket = udp_connect(host,port,local_host,local_port)
142
-
143
- yield socket if block_given?
144
-
145
- socket.close
146
- return nil
147
- end
148
-
149
- #
150
- # Connects to a specified host and port, sends the given data and then
151
- # closes the connection.
152
- #
153
- # @param [String] data
154
- # The data to send through the connection.
155
- #
156
- # @param [String] host
157
- # The host to connect to.
158
- #
159
- # @param [Integer] port
160
- # The port to connect to.
161
- #
162
- # @param [String] local_host (nil)
163
- # The local host to bind to.
164
- #
165
- # @param [Integer] local_port (nil)
166
- # The local port to bind to.
167
- #
168
- # @return [true]
169
- # The data was successfully sent.
170
- #
171
- # @example
172
- # buffer = "GET /" + ('A' * 4096) + "\n\r"
173
- # udp_send(buffer,'victim.com',80)
174
- # # => true
175
- #
176
- # @api public
177
- #
178
- # @since 0.4.0
179
- #
180
- def udp_send(data,host,port,local_host=nil,local_port=0)
181
- udp_session(host,port,local_host,local_port) do |socket|
182
- socket.write(data)
183
- end
184
-
185
- return true
186
- end
187
-
188
- #
189
- # Reads the banner from the service running on the given host and port.
190
- #
191
- # @param [String] host
192
- # The host to connect to.
193
- #
194
- # @param [Integer] port
195
- # The port to connect to.
196
- #
197
- # @param [String] local_host (nil)
198
- # The local host to bind to.
199
- #
200
- # @param [Integer] local_port (nil)
201
- # The local port to bind to.
202
- #
203
- # @yield [banner]
204
- # If a block is given, it will be passed the grabbed banner.
205
- #
206
- # @yieldparam [String] banner
207
- # The grabbed banner.
208
- #
209
- # @return [String]
210
- # The grabbed banner.
211
- #
212
- # @api public
213
- #
214
- def udp_banner(host,port,local_host=nil,local_port=0)
215
- banner = nil
216
-
217
- udp_session(host,port,local_host,local_port) do |socket|
218
- banner = socket.readline
219
- end
220
-
221
- yield banner if block_given?
222
- return banner
223
- end
224
-
225
- #
226
- # Creates a new UDPServer listening on a given host and port.
227
- #
228
- # @param [Integer] port
229
- # The local port to listen on.
230
- #
231
- # @param [String] host ('0.0.0.0')
232
- # The host to bind to.
233
- #
234
- # @return [UDPServer]
235
- # The new UDP server.
236
- #
237
- # @example
238
- # udp_server(1337)
239
- #
240
- # @api public
241
- #
242
- def udp_server(port=0,host=nil)
243
- host = (host || '0.0.0.0').to_s
244
- server = UDPSocket.new
245
-
246
- server.bind(host,port)
247
-
248
- yield server if block_given?
249
- return server
250
- end
251
-
252
- #
253
- # Creates a new temporary UDPServer listening on a given host and port.
254
- #
255
- # @param [Integer] port
256
- # The local port to bind to.
257
- #
258
- # @param [String] host ('0.0.0.0')
259
- # The host to bind to.
260
- #
261
- # @yield [server]
262
- # The block which will be called after the server has been created.
263
- # After the block has finished, the server will be closed.
264
- #
265
- # @yieldparam [UDPServer] server
266
- # The newly created UDP server.
267
- #
268
- # @return [nil]
269
- #
270
- # @example
271
- # udp_server_session(1337) do |server|
272
- # data, sender = server.recvfrom(1024)
273
- # end
274
- #
275
- # @api public
276
- #
277
- def udp_server_session(port=0,host=nil,&block)
278
- server = udp_server(port,host,&block)
279
-
280
- server.close()
281
- return nil
282
- end
283
- end
284
- end
285
- end
20
+ require 'ronin/network/udp/udp'
21
+ require 'ronin/network/udp/proxy'
@@ -0,0 +1,191 @@
1
+ #
2
+ # Copyright (c) 2006-2021 Hal Brodigan (postmodern.mod3 at gmail.com)
3
+ #
4
+ # This file is part of ronin-support.
5
+ #
6
+ # ronin-support is free software: you can redistribute it and/or modify
7
+ # it under the terms of the GNU Lesser General Public License as published
8
+ # by the Free Software Foundation, either version 3 of the License, or
9
+ # (at your option) any later version.
10
+ #
11
+ # ronin-support is distributed in the hope that it will be useful,
12
+ # but WITHOUT ANY WARRANTY; without even the implied warranty of
13
+ # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
+ # GNU Lesser General Public License for more details.
15
+ #
16
+ # You should have received a copy of the GNU Lesser General Public License
17
+ # along with ronin-support. If not, see <https://www.gnu.org/licenses/>.
18
+ #
19
+
20
+ require 'ronin/network/proxy'
21
+
22
+ require 'socket'
23
+
24
+ module Ronin
25
+ module Network
26
+ module UDP
27
+ #
28
+ # The UDP Proxy allows for inspecting and manipulating UDP protocols.
29
+ #
30
+ # ## Example
31
+ #
32
+ # require 'ronin/network/udp/proxy'
33
+ # require 'hexdump'
34
+ #
35
+ # Ronin::Network::UDP::Proxy.start(:port => 1337, :server => ['4.2.2.1', 53]) do |proxy|
36
+ # hex = Hexdump::Dumper.new
37
+ #
38
+ # proxy.on_client_data do |(client,(host,port)),server,data|
39
+ # puts "#{host}:#{port} -> #{proxy}"
40
+ # hex.dump(data)
41
+ # end
42
+ #
43
+ # proxy.on_server_data do |(client,(host,port)),server,data|
44
+ # puts "#{host}:#{port} <- #{proxy}"
45
+ # hex.dump(data)
46
+ # end
47
+ #
48
+ # end
49
+ #
50
+ # @since 0.5.0
51
+ #
52
+ class Proxy < Network::Proxy
53
+
54
+ #
55
+ # Opens the UDP Proxy.
56
+ #
57
+ # @api public
58
+ #
59
+ def open
60
+ @socket = UDPSocket.new
61
+ @socket.bind(@host,@port)
62
+ end
63
+
64
+ #
65
+ # Polls the connections for data/errors and the proxy socket for
66
+ # new client connections.
67
+ #
68
+ # @api public
69
+ #
70
+ def poll
71
+ sockets = [@socket] + server_connections
72
+
73
+ readable, writtable, errors = IO.select(sockets,nil,sockets)
74
+
75
+ (errors & server_connections).each do |server_socket|
76
+ client_socket = client_connection_for(server_socket)
77
+
78
+ close_connection(client_socket,server_socket)
79
+ end
80
+
81
+ (readable & server_connections).each do |server_socket|
82
+ client_socket = client_connection_for(server_socket)
83
+ data, addrinfo = recv(server_socket)
84
+
85
+ server_data(client_socket,server_socket,data)
86
+ end
87
+
88
+ if readable.include?(@socket)
89
+ data, addrinfo = recv(@socket)
90
+
91
+ client_socket = [@socket, [addrinfo[3], addrinfo[1]]]
92
+ server_socket = (@connections[client_socket] ||= open_server_connection)
93
+
94
+ client_data(client_socket,server_socket,data)
95
+ end
96
+ end
97
+
98
+ #
99
+ # Sends data to a connection.
100
+ #
101
+ # @param [UDPSocket, (UDPSocket, (String, Integer))] connection
102
+ # The connection from the proxy to the server, or the proxy socket
103
+ # and host/port of the client.
104
+ #
105
+ # @param [String] data
106
+ # The data to be sent.
107
+ #
108
+ # @api public
109
+ #
110
+ def send(connection,data)
111
+ case connection
112
+ when Array
113
+ socket, (host, port) = connection
114
+
115
+ socket.send(data,0,host,port)
116
+ when UDPSocket
117
+ connection.send(data,0)
118
+ end
119
+ end
120
+
121
+ #
122
+ # Receives data from a connection.
123
+ #
124
+ # @param [UDPSocket, (UDPSocket, (String, Integer))] connection
125
+ # The connection from the proxy to the server, or the proxy socket
126
+ # and the address of a client.
127
+ #
128
+ # @return [String, (String, Array)]
129
+ # The data received.
130
+ #
131
+ # @api public
132
+ #
133
+ def recv(connection)
134
+ case connection
135
+ when Array
136
+ socket, (host, port) = connection
137
+
138
+ socket.recvfrom(@buffer_size)
139
+ when UDPSocket
140
+ connection.recvfrom(@buffer_size)
141
+ end
142
+ end
143
+
144
+ protected
145
+
146
+ #
147
+ # Creates a new connection from the proxy to the server.
148
+ #
149
+ # @return [UDPSocket]
150
+ # The new UDPSocket to the server.
151
+ #
152
+ def open_server_connection
153
+ socket = UDPSocket.new
154
+ socket.connect(@server_host,@server_port)
155
+
156
+ return socket
157
+ end
158
+
159
+ #
160
+ # Closes a connection from the client to the proxy.
161
+ #
162
+ # @param [(UDPSocket, (String, Integer))] connection
163
+ # The UDP Proxy socket and the host/port of the client.
164
+ #
165
+ # @note no-op
166
+ #
167
+ def close_client_connection(connection)
168
+ # no-op
169
+ end
170
+
171
+ #
172
+ # Closes the connection from the proxy to the server.
173
+ #
174
+ # @param [UDPSocket] connection
175
+ # The UDPSocket from the proxy to the server.
176
+ #
177
+ def close_server_connection(connection)
178
+ connection.close
179
+ end
180
+
181
+ #
182
+ # Closes the UDP proxy socket.
183
+ #
184
+ def close_proxy
185
+ @socket.close
186
+ end
187
+
188
+ end
189
+ end
190
+ end
191
+ end