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
@@ -0,0 +1,298 @@
1
+ require 'spec_helper'
2
+ require 'ronin/network/udp'
3
+
4
+ require 'resolv'
5
+
6
+ describe Network::UDP do
7
+ describe "helper methods", :network do
8
+ let(:host) { 'scanme.nmap.org' }
9
+ let(:port) { 123 }
10
+
11
+ subject do
12
+ obj = Object.new
13
+ obj.extend described_class
14
+ obj
15
+ end
16
+
17
+ shared_examples "UDP Server" do
18
+ let(:server_host) { local_host }
19
+ let(:server_port) { 1024 + rand(65535 - 1024) }
20
+ let(:server) { UDPSocket.new }
21
+ let(:server_bind_ip) { server.addr[3] }
22
+ let(:server_bind_port) { server.addr[1] }
23
+
24
+ before(:each) { server.bind(server_host,server_port) }
25
+ after(:each) { server.close }
26
+ end
27
+
28
+ describe "#udp_open?" do
29
+ let(:host) { server_bind_ip }
30
+ let(:port) { server_bind_port }
31
+
32
+ include_context "UDP Server"
33
+
34
+ it "should return true for open ports" do
35
+ expect(subject.udp_open?(host,port)).to be(true)
36
+ end
37
+
38
+ let(:closed_port) { port + 1 }
39
+
40
+ it "should return false for closed ports" do
41
+ expect(subject.udp_open?(host,closed_port)).to be(false)
42
+ end
43
+
44
+ it "should have a timeout for firewalled ports" do
45
+ timeout = 2
46
+
47
+ t1 = Time.now
48
+ subject.udp_open?(host,1337,nil,nil,timeout)
49
+ t2 = Time.now
50
+
51
+ expect((t2 - t1).to_i).to be <= timeout
52
+ end
53
+ end
54
+
55
+ describe "#udp_connect" do
56
+ it "should open a UDPSocket" do
57
+ socket = subject.udp_connect(host,port)
58
+
59
+ expect(socket).to be_kind_of(UDPSocket)
60
+ expect(socket).not_to be_closed
61
+
62
+ socket.close
63
+ end
64
+
65
+ context "when given a local port" do
66
+ let(:local_port) { 1024 + rand(65535 - 1024) }
67
+
68
+ it "should bind to a local port" do
69
+ socket = subject.udp_connect(host,port,nil,local_port)
70
+ bound_port = socket.addr[1]
71
+
72
+ expect(bound_port).to eq(local_port)
73
+
74
+ socket.close
75
+ end
76
+ end
77
+
78
+ context "when given a block" do
79
+ it "should yield the new UDPSocket" do
80
+ socket = nil
81
+
82
+ subject.udp_connect(host,port) do |yielded_socket|
83
+ socket = yielded_socket
84
+ end
85
+
86
+ expect(socket).not_to be_closed
87
+ socket.close
88
+ end
89
+ end
90
+ end
91
+
92
+ describe "#udp_connect_and_send" do
93
+ pending "need to find a UDP Service for these specs" do
94
+ let(:data) { "HELO ronin\n" }
95
+ let(:local_port) { 1024 + rand(65535 - 1024) }
96
+
97
+ it "should connect and then send data" do
98
+ socket = subject.udp_connect_and_send(data,host,port)
99
+ banner = socket.readline
100
+ response = socket.readline
101
+
102
+ expect(response.start_with?('250')).to be_true
103
+
104
+ socket.close
105
+ end
106
+
107
+ it "should bind to a local port" do
108
+ socket = subject.udp_connect_and_send(data,host,port,nil,local_port)
109
+ bound_port = socket.addr[1]
110
+
111
+ expect(bound_port).to eq(local_port)
112
+
113
+ socket.close
114
+ end
115
+
116
+ it "should yield the UDPSocket" do
117
+ response = nil
118
+
119
+ socket = subject.udp_connect_and_send(data,host,port) do |socket|
120
+ banner = socket.readline
121
+ response = socket.readline
122
+ end
123
+
124
+ expect(response.start_with?('250')).to be_true
125
+
126
+ socket.close
127
+ end
128
+ end
129
+ end
130
+
131
+ describe "#udp_session" do
132
+ let(:local_port) { 1024 + rand(65535 - 1024) }
133
+
134
+ it "should open then close a UDPSocket" do
135
+ socket = nil
136
+
137
+ subject.udp_session(host,port) do |yielded_socket|
138
+ socket = yielded_socket
139
+ end
140
+
141
+ expect(socket).to be_kind_of(UDPSocket)
142
+ expect(socket).to be_closed
143
+ end
144
+
145
+ context "when given a local host and port" do
146
+ it "should bind to a local host and port" do
147
+ bound_port = nil
148
+
149
+ subject.udp_session(host,port,nil,local_port) do |socket|
150
+ bound_port = socket.addr[1]
151
+ end
152
+
153
+ expect(bound_port).to eq(local_port)
154
+ end
155
+ end
156
+ end
157
+
158
+ describe "#udp_banner" do
159
+ pending "need to find a UDP service that sends a banner" do
160
+ let(:host) { 'smtp.gmail.com' }
161
+ let(:port) { 25 }
162
+
163
+ let(:local_port) { 1024 + rand(65535 - 1024) }
164
+
165
+ it "should read the service banner" do
166
+ banner = subject.udp_banner(host,port)
167
+
168
+ expect(banner.start_with?('220')).to be_true
169
+ end
170
+
171
+ context "when given a local host and port" do
172
+ it "should bind to a local host and port" do
173
+ banner = subject.udp_banner(host,port,nil,local_port)
174
+
175
+ expect(banner.start_with?('220')).to be_true
176
+ end
177
+ end
178
+
179
+ context "when given a block" do
180
+ it "should yield the banner" do
181
+ banner = nil
182
+
183
+ subject.udp_banner(host,port) do |yielded_banner|
184
+ banner = yielded_banner
185
+ end
186
+
187
+ expect(banner.start_with?('220')).to be_true
188
+ end
189
+ end
190
+ end
191
+ end
192
+
193
+ let(:local_host) { 'localhost' }
194
+ let(:local_ip) { '127.0.0.1' } # XXX: UPDSocket defaults to using IPv4
195
+
196
+ describe "#udp_send" do
197
+ include_context "UDP Server"
198
+
199
+ let(:data) { "hello\n" }
200
+
201
+ it "should send data to a service" do
202
+ subject.udp_send(data,server_bind_ip,server_bind_port)
203
+
204
+ mesg = server.recvfrom(data.length)
205
+
206
+ expect(mesg[0]).to eq(data)
207
+ end
208
+
209
+ context "when given a local host and port" do
210
+ let(:local_port) { 1024 + rand(65535 - 1024) }
211
+
212
+ it "should bind to a local host and port" do
213
+ subject.udp_send(data,server_bind_ip,server_bind_port,server_bind_ip,local_port)
214
+
215
+ mesg = server.recvfrom(data.length)
216
+
217
+ client_address = mesg[1]
218
+ expect(client_address[1]).to eq(local_port)
219
+ end
220
+ end
221
+ end
222
+
223
+ describe "#udp_server" do
224
+ it "should create a new UDPSocket" do
225
+ server = subject.udp_server
226
+
227
+ expect(server).to be_kind_of(UDPSocket)
228
+ expect(server).not_to be_closed
229
+
230
+ server.close
231
+ end
232
+
233
+ context "when given a port and host" do
234
+ let(:local_port) { 1024 + rand(65535 - 1024) }
235
+
236
+ it "should bind to a specific port and host" do
237
+ server = subject.udp_server(local_port,local_host)
238
+ bound_host = server.addr[3]
239
+ bound_port = server.addr[1]
240
+
241
+ expect(bound_host).to eq(local_ip)
242
+ expect(bound_port).to eq(local_port)
243
+
244
+ server.close
245
+ end
246
+ end
247
+
248
+ context "when a block is given" do
249
+ it "should yield the new UDPSocket" do
250
+ server = nil
251
+
252
+ subject.udp_server do |yielded_server|
253
+ server = yielded_server
254
+ end
255
+
256
+ expect(server).to be_kind_of(UDPSocket)
257
+ expect(server).not_to be_closed
258
+
259
+ server.close
260
+ end
261
+ end
262
+ end
263
+
264
+ describe "#udp_server_session" do
265
+ it "should create a temporary UDPSocket" do
266
+ server = nil
267
+
268
+ subject.udp_server_session do |yielded_server|
269
+ server = yielded_server
270
+ end
271
+
272
+ expect(server).to be_kind_of(UDPSocket)
273
+ expect(server).to be_closed
274
+ end
275
+
276
+ context "when given a port and a host" do
277
+ let(:local_port) { 1024 + rand(65535 - 1024) }
278
+
279
+ it "should bind to a specific port and host" do
280
+ bound_host = nil
281
+ bound_port = nil
282
+
283
+ subject.udp_server_session(local_port,local_host) do |new_server|
284
+ bound_host = new_server.addr[3]
285
+ bound_port = new_server.addr[1]
286
+ end
287
+
288
+ expect(bound_host).to eq(local_ip)
289
+ expect(bound_port).to eq(local_port)
290
+ end
291
+ end
292
+ end
293
+
294
+ describe "#udp_recv" do
295
+ let(:server_port) { 1024 + rand(65535 - 1024) }
296
+ end
297
+ end
298
+ end
@@ -0,0 +1,182 @@
1
+ require 'spec_helper'
2
+ require 'network/shared/unix_server'
3
+ require 'ronin/network/unix'
4
+
5
+ require 'fileutils'
6
+
7
+ describe Network::UNIX do
8
+ describe "helper methods", :network do
9
+ subject do
10
+ obj = Object.new
11
+ obj.extend described_class
12
+ obj
13
+ end
14
+
15
+ describe "#unix_open?" do
16
+ include_context "UNIX Server"
17
+
18
+ it "should return true for listening UNIX sockets" do
19
+ expect(subject.unix_open?(path)).to be(true)
20
+ end
21
+
22
+ it "should return false for closed UNIX sockets" do
23
+ old_path = socket_path('ronin_old_unix_socket')
24
+ UNIXServer.new(old_path).close
25
+
26
+ expect(subject.unix_open?(old_path)).to be(false)
27
+
28
+ FileUtils.rm(old_path)
29
+ end
30
+
31
+ it "should have a timeout for non-existent UNIX sockets" do
32
+ bad_path = socket_path('ronin_bad_unix_socket')
33
+ timeout = 2
34
+
35
+ t1 = Time.now
36
+ subject.unix_open?(bad_path,timeout)
37
+ t2 = Time.now
38
+
39
+ expect((t2 - t1).to_i).to be <= timeout
40
+ end
41
+ end
42
+
43
+ describe "#unix_connect" do
44
+ include_context "UNIX Server"
45
+
46
+ it "should open a UNIXSocket" do
47
+ socket = subject.unix_connect(path)
48
+
49
+ expect(socket).to be_kind_of(UNIXSocket)
50
+ expect(socket).not_to be_closed
51
+
52
+ socket.close
53
+ end
54
+
55
+ it "should yield the new UNIXSocket" do
56
+ socket = nil
57
+
58
+ subject.unix_connect(path) do |yielded_socket|
59
+ socket = yielded_socket
60
+ end
61
+
62
+ expect(socket).not_to be_closed
63
+ socket.close
64
+ end
65
+ end
66
+
67
+ describe "#unix_connect_and_send" do
68
+ include_context "UNIX Server"
69
+
70
+ let(:data) { "HELO ronin\n" }
71
+
72
+ it "should connect and then send data" do
73
+ socket = subject.unix_connect_and_send(data,path)
74
+ response = socket.readline
75
+
76
+ expect(response).to eq(data)
77
+
78
+ socket.close
79
+ end
80
+
81
+ it "should yield the UNIXSocket" do
82
+ response = nil
83
+
84
+ socket = subject.unix_connect_and_send(data,path) do |socket|
85
+ response = socket.readline
86
+ end
87
+
88
+ expect(response).to eq(data)
89
+
90
+ socket.close
91
+ end
92
+ end
93
+
94
+ describe "#unix_session" do
95
+ include_context "UNIX Server"
96
+
97
+ it "should open then close a UNIXSocket" do
98
+ socket = nil
99
+
100
+ subject.unix_session(path) do |yielded_socket|
101
+ socket = yielded_socket
102
+ end
103
+
104
+ expect(socket).to be_kind_of(UNIXSocket)
105
+ expect(socket).to be_closed
106
+ end
107
+ end
108
+
109
+ describe "#unix_send" do
110
+ let(:server_path) { File.join(Dir.tmpdir,'ronin_unix_server') }
111
+ let(:data) { "hello\n" }
112
+
113
+ before(:each) { @server = UNIXServer.new(server_path) }
114
+
115
+ it "should send data to a service" do
116
+ subject.unix_send(data,server_path)
117
+
118
+ client = @server.accept
119
+ sent = client.readline
120
+
121
+ client.close
122
+
123
+ expect(sent).to eq(data)
124
+ end
125
+
126
+ after(:each) do
127
+ @server.close
128
+
129
+ FileUtils.rm(server_path)
130
+ end
131
+ end
132
+
133
+ describe "#unix_server" do
134
+ let(:server_path) { File.join(Dir.tmpdir,'ronin_unix_server') }
135
+
136
+ it "should create a new UNIXServer" do
137
+ server = subject.unix_server(server_path)
138
+
139
+ expect(server).to be_kind_of(UNIXServer)
140
+ expect(server).not_to be_closed
141
+
142
+ server.close
143
+ end
144
+
145
+ it "should yield the new UNIXServer" do
146
+ server = nil
147
+
148
+ subject.unix_server(server_path) do |yielded_server|
149
+ server = yielded_server
150
+ end
151
+
152
+ expect(server).to be_kind_of(UNIXServer)
153
+ expect(server).not_to be_closed
154
+
155
+ server.close
156
+ end
157
+
158
+ after(:each) { FileUtils.rm(server_path) }
159
+ end
160
+
161
+ describe "#unix_server_session" do
162
+ let(:server_path) { File.join(Dir.tmpdir,'ronin_unix_server') }
163
+
164
+ it "should create a temporary UNIXServer" do
165
+ server = nil
166
+
167
+ subject.unix_server_session(server_path) do |yielded_server|
168
+ server = yielded_server
169
+ end
170
+
171
+ expect(server).to be_kind_of(UNIXServer)
172
+ expect(server).to be_closed
173
+ end
174
+
175
+ after(:each) { FileUtils.rm(server_path) }
176
+ end
177
+
178
+ describe "#unix_accept" do
179
+ pending "need to automate connecting to the UNIXServer"
180
+ end
181
+ end
182
+ end