ronin-exploits 0.3.1 → 1.0.0.beta1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (338) hide show
  1. checksums.yaml +7 -0
  2. data/.document +4 -0
  3. data/.editorconfig +11 -0
  4. data/.github/workflows/ruby.yml +31 -0
  5. data/.gitignore +13 -0
  6. data/.mailmap +1 -0
  7. data/.rspec +1 -0
  8. data/.ruby-version +1 -0
  9. data/.yardopts +1 -0
  10. data/COPYING.txt +161 -335
  11. data/{History.txt → ChangeLog.md} +119 -16
  12. data/Gemfile +50 -0
  13. data/README.md +454 -0
  14. data/Rakefile +37 -23
  15. data/bin/ronin-exploits +13 -6
  16. data/data/new/exploit.rb.erb +158 -0
  17. data/gemspec.yml +37 -0
  18. data/lib/ronin/exploits/advisory.rb +84 -0
  19. data/lib/ronin/exploits/cli/command.rb +39 -0
  20. data/lib/ronin/exploits/cli/commands/irb.rb +57 -0
  21. data/lib/ronin/exploits/cli/commands/list.rb +80 -0
  22. data/lib/ronin/exploits/cli/commands/new.rb +332 -0
  23. data/lib/ronin/exploits/cli/commands/run.rb +396 -0
  24. data/lib/ronin/exploits/cli/commands/show.rb +264 -0
  25. data/lib/ronin/exploits/cli/exploit_command.rb +114 -0
  26. data/lib/ronin/exploits/cli/exploit_methods.rb +114 -0
  27. data/lib/ronin/exploits/cli/ruby_shell.rb +51 -0
  28. data/lib/ronin/exploits/cli.rb +46 -0
  29. data/lib/ronin/exploits/client_side_web_vuln.rb +69 -0
  30. data/lib/ronin/exploits/exceptions.rb +27 -17
  31. data/lib/ronin/exploits/exploit.rb +501 -582
  32. data/lib/ronin/exploits/heap_overflow.rb +50 -0
  33. data/lib/ronin/exploits/lfi.rb +141 -0
  34. data/lib/ronin/exploits/loot/file.rb +113 -0
  35. data/lib/ronin/exploits/loot.rb +119 -0
  36. data/lib/ronin/exploits/memory_corruption.rb +53 -0
  37. data/lib/ronin/exploits/metadata/arch.rb +83 -0
  38. data/lib/ronin/exploits/metadata/cookie_param.rb +80 -0
  39. data/lib/ronin/exploits/metadata/default_filename.rb +69 -0
  40. data/lib/ronin/exploits/metadata/default_port.rb +69 -0
  41. data/lib/ronin/exploits/metadata/header_name.rb +80 -0
  42. data/lib/ronin/exploits/metadata/os.rb +117 -0
  43. data/lib/ronin/exploits/metadata/shouts.rb +85 -0
  44. data/lib/ronin/exploits/metadata/url_path.rb +82 -0
  45. data/lib/ronin/exploits/metadata/url_query_param.rb +80 -0
  46. data/lib/ronin/exploits/mixins/binary.rb +106 -0
  47. data/lib/ronin/exploits/mixins/build_dir.rb +61 -0
  48. data/lib/ronin/exploits/mixins/file_builder.rb +102 -0
  49. data/lib/ronin/exploits/mixins/format_string.rb +87 -0
  50. data/lib/ronin/exploits/mixins/has_payload.rb +202 -0
  51. data/lib/ronin/exploits/mixins/has_targets.rb +297 -0
  52. data/lib/ronin/exploits/mixins/html.rb +213 -0
  53. data/lib/ronin/exploits/mixins/http.rb +866 -0
  54. data/lib/ronin/exploits/mixins/loot.rb +84 -0
  55. data/lib/ronin/exploits/mixins/nops.rb +121 -0
  56. data/lib/ronin/exploits/mixins/remote_tcp.rb +272 -0
  57. data/lib/ronin/exploits/mixins/remote_udp.rb +264 -0
  58. data/lib/ronin/exploits/mixins/seh.rb +136 -0
  59. data/lib/ronin/exploits/mixins/stack_overflow.rb +124 -0
  60. data/lib/ronin/exploits/mixins/text.rb +65 -0
  61. data/lib/ronin/exploits/mixins.rb +32 -0
  62. data/lib/ronin/exploits/open_redirect.rb +103 -0
  63. data/lib/ronin/exploits/params/base_url.rb +84 -0
  64. data/lib/ronin/exploits/params/bind_host.rb +53 -0
  65. data/lib/ronin/exploits/params/bind_port.rb +53 -0
  66. data/lib/ronin/exploits/params/filename.rb +71 -0
  67. data/lib/ronin/exploits/params/host.rb +56 -0
  68. data/lib/ronin/exploits/params/port.rb +71 -0
  69. data/lib/ronin/exploits/registry.rb +32 -0
  70. data/lib/ronin/exploits/rfi.rb +106 -0
  71. data/lib/ronin/exploits/root.rb +28 -0
  72. data/lib/ronin/exploits/seh_overflow.rb +90 -0
  73. data/lib/ronin/exploits/sqli.rb +172 -0
  74. data/lib/ronin/exploits/ssti.rb +108 -0
  75. data/lib/ronin/exploits/stack_overflow.rb +90 -0
  76. data/lib/ronin/exploits/target.rb +63 -103
  77. data/lib/ronin/exploits/test_result.rb +80 -0
  78. data/lib/ronin/exploits/use_after_free.rb +50 -0
  79. data/lib/ronin/exploits/version.rb +11 -12
  80. data/lib/ronin/exploits/web.rb +18 -89
  81. data/lib/ronin/exploits/web_vuln.rb +378 -0
  82. data/lib/ronin/exploits/xss.rb +102 -0
  83. data/lib/ronin/exploits.rb +19 -26
  84. data/man/ronin-exploits-irb.1 +31 -0
  85. data/man/ronin-exploits-irb.1.md +22 -0
  86. data/man/ronin-exploits-list.1 +37 -0
  87. data/man/ronin-exploits-list.1.md +27 -0
  88. data/man/ronin-exploits-new.1 +98 -0
  89. data/man/ronin-exploits-new.1.md +73 -0
  90. data/man/ronin-exploits-run.1 +117 -0
  91. data/man/ronin-exploits-run.1.md +87 -0
  92. data/man/ronin-exploits-show.1 +45 -0
  93. data/man/ronin-exploits-show.1.md +33 -0
  94. data/man/ronin-exploits.1 +55 -0
  95. data/man/ronin-exploits.1.md +41 -0
  96. data/ronin-exploits.gemspec +62 -0
  97. data/spec/advisory_spec.rb +71 -0
  98. data/spec/cli/exploit_command_spec.rb +68 -0
  99. data/spec/cli/exploit_methods_spec.rb +208 -0
  100. data/spec/cli/ruby_shell_spec.rb +14 -0
  101. data/spec/client_side_web_vuln_spec.rb +117 -0
  102. data/spec/exploit_spec.rb +538 -0
  103. data/spec/exploits_spec.rb +3 -4
  104. data/spec/heap_overflow_spec.rb +14 -0
  105. data/spec/lfi_spec.rb +162 -0
  106. data/spec/loot/file_spec.rb +131 -0
  107. data/spec/loot_spec.rb +138 -0
  108. data/spec/memory_corruption_spec.rb +22 -0
  109. data/spec/metadata/arch_spec.rb +82 -0
  110. data/spec/metadata/cookie_param_spec.rb +67 -0
  111. data/spec/metadata/default_filename_spec.rb +62 -0
  112. data/spec/metadata/default_port_spec.rb +62 -0
  113. data/spec/metadata/header_name_spec.rb +67 -0
  114. data/spec/metadata/os_spec.rb +164 -0
  115. data/spec/metadata/shouts_spec.rb +100 -0
  116. data/spec/metadata/url_path_spec.rb +67 -0
  117. data/spec/metadata/url_query_param_spec.rb +67 -0
  118. data/spec/mixins/binary_spec.rb +129 -0
  119. data/spec/mixins/build_dir.rb +66 -0
  120. data/spec/mixins/file_builder_spec.rb +67 -0
  121. data/spec/mixins/format_string_spec.rb +44 -0
  122. data/spec/mixins/has_payload_spec.rb +333 -0
  123. data/spec/mixins/has_targets_spec.rb +434 -0
  124. data/spec/mixins/html_spec.rb +772 -0
  125. data/spec/mixins/http_spec.rb +1227 -0
  126. data/spec/mixins/loot_spec.rb +20 -0
  127. data/spec/mixins/nops_spec.rb +165 -0
  128. data/spec/mixins/remote_tcp_spec.rb +217 -0
  129. data/spec/mixins/remote_udp_spec.rb +217 -0
  130. data/spec/mixins/seh_spec.rb +89 -0
  131. data/spec/mixins/stack_overflow_spec.rb +87 -0
  132. data/spec/mixins/text_spec.rb +43 -0
  133. data/spec/open_redirect_spec.rb +71 -0
  134. data/spec/params/base_url_spec.rb +71 -0
  135. data/spec/params/bind_host_spec.rb +34 -0
  136. data/spec/params/bind_port_spec.rb +35 -0
  137. data/spec/params/filename_spec.rb +77 -0
  138. data/spec/params/host_spec.rb +34 -0
  139. data/spec/params/port_spec.rb +77 -0
  140. data/spec/rfi_spec.rb +107 -0
  141. data/spec/seh_overflow_spec.rb +18 -0
  142. data/spec/spec_helper.rb +6 -10
  143. data/spec/sqli_spec.rb +306 -0
  144. data/spec/ssti_spec.rb +121 -0
  145. data/spec/stack_overflow_spec.rb +18 -0
  146. data/spec/target_spec.rb +92 -0
  147. data/spec/test_result_spec.rb +32 -0
  148. data/spec/use_after_free_spec.rb +14 -0
  149. data/spec/web_spec.rb +12 -0
  150. data/spec/web_vuln_spec.rb +854 -0
  151. data/spec/xss_spec.rb +69 -0
  152. metadata +356 -324
  153. data/Manifest.txt +0 -196
  154. data/README.txt +0 -274
  155. data/bin/ronin-exploit +0 -12
  156. data/bin/ronin-gen-binary-payload +0 -12
  157. data/bin/ronin-gen-exploit +0 -12
  158. data/bin/ronin-gen-ftp-exploit +0 -12
  159. data/bin/ronin-gen-http-exploit +0 -12
  160. data/bin/ronin-gen-local-exploit +0 -12
  161. data/bin/ronin-gen-nops +0 -12
  162. data/bin/ronin-gen-payload +0 -12
  163. data/bin/ronin-gen-remote-exploit +0 -12
  164. data/bin/ronin-gen-remote-tcp-exploit +0 -12
  165. data/bin/ronin-gen-remote-udp-exploit +0 -12
  166. data/bin/ronin-gen-shellcode +0 -12
  167. data/bin/ronin-gen-web-exploit +0 -12
  168. data/bin/ronin-payload +0 -12
  169. data/bin/ronin-payloads +0 -12
  170. data/lib/ronin/controls/behaviors.rb +0 -133
  171. data/lib/ronin/controls/exceptions/not_implemented.rb +0 -27
  172. data/lib/ronin/controls/exceptions/program_not_found.rb +0 -27
  173. data/lib/ronin/controls/exceptions.rb +0 -23
  174. data/lib/ronin/controls/file_system.rb +0 -145
  175. data/lib/ronin/controls/helpers/command_exec.rb +0 -143
  176. data/lib/ronin/controls/helpers/dir_create.rb +0 -42
  177. data/lib/ronin/controls/helpers/dir_listing.rb +0 -62
  178. data/lib/ronin/controls/helpers/dir_remove.rb +0 -42
  179. data/lib/ronin/controls/helpers/file_ctime.rb +0 -52
  180. data/lib/ronin/controls/helpers/file_mtime.rb +0 -53
  181. data/lib/ronin/controls/helpers/file_ownership.rb +0 -53
  182. data/lib/ronin/controls/helpers/file_read.rb +0 -62
  183. data/lib/ronin/controls/helpers/file_remove.rb +0 -51
  184. data/lib/ronin/controls/helpers/file_write.rb +0 -62
  185. data/lib/ronin/controls/helpers/memory_read.rb +0 -39
  186. data/lib/ronin/controls/helpers/memory_write.rb +0 -39
  187. data/lib/ronin/controls/helpers.rb +0 -33
  188. data/lib/ronin/controls.rb +0 -23
  189. data/lib/ronin/exploits/control.rb +0 -47
  190. data/lib/ronin/exploits/exceptions/exception.rb +0 -27
  191. data/lib/ronin/exploits/exceptions/exploit_not_built.rb +0 -29
  192. data/lib/ronin/exploits/exceptions/payload_size.rb +0 -29
  193. data/lib/ronin/exploits/exceptions/restricted_char.rb +0 -29
  194. data/lib/ronin/exploits/exceptions/target_data_missing.rb +0 -29
  195. data/lib/ronin/exploits/exceptions/target_unspecified.rb +0 -29
  196. data/lib/ronin/exploits/exceptions/unknown_helper.rb +0 -29
  197. data/lib/ronin/exploits/exploit_author.rb +0 -33
  198. data/lib/ronin/exploits/ftp.rb +0 -42
  199. data/lib/ronin/exploits/helpers/binary.rb +0 -50
  200. data/lib/ronin/exploits/helpers/buffer_overflow.rb +0 -115
  201. data/lib/ronin/exploits/helpers/file_based.rb +0 -112
  202. data/lib/ronin/exploits/helpers/format_string.rb +0 -117
  203. data/lib/ronin/exploits/helpers/padding.rb +0 -101
  204. data/lib/ronin/exploits/helpers.rb +0 -26
  205. data/lib/ronin/exploits/http.rb +0 -49
  206. data/lib/ronin/exploits/local.rb +0 -40
  207. data/lib/ronin/exploits/remote.rb +0 -40
  208. data/lib/ronin/exploits/remote_tcp.rb +0 -87
  209. data/lib/ronin/exploits/remote_udp.rb +0 -87
  210. data/lib/ronin/exploits/targets/buffer_overflow.rb +0 -46
  211. data/lib/ronin/exploits/targets/format_string.rb +0 -43
  212. data/lib/ronin/exploits/targets.rb +0 -27
  213. data/lib/ronin/exploits/verifiers.rb +0 -121
  214. data/lib/ronin/generators/exploits/exploit.rb +0 -70
  215. data/lib/ronin/generators/exploits/ftp.rb +0 -42
  216. data/lib/ronin/generators/exploits/http.rb +0 -42
  217. data/lib/ronin/generators/exploits/local.rb +0 -42
  218. data/lib/ronin/generators/exploits/remote.rb +0 -42
  219. data/lib/ronin/generators/exploits/remote_tcp.rb +0 -44
  220. data/lib/ronin/generators/exploits/remote_udp.rb +0 -44
  221. data/lib/ronin/generators/exploits/static.rb +0 -30
  222. data/lib/ronin/generators/exploits/web.rb +0 -45
  223. data/lib/ronin/generators/exploits.rb +0 -23
  224. data/lib/ronin/generators/payloads/binary_payload.rb +0 -42
  225. data/lib/ronin/generators/payloads/nops.rb +0 -42
  226. data/lib/ronin/generators/payloads/payload.rb +0 -66
  227. data/lib/ronin/generators/payloads/shellcode.rb +0 -42
  228. data/lib/ronin/generators/payloads/static.rb +0 -30
  229. data/lib/ronin/generators/payloads.rb +0 -23
  230. data/lib/ronin/model/has_default_port.rb +0 -54
  231. data/lib/ronin/model/targets_arch.rb +0 -68
  232. data/lib/ronin/model/targets_os.rb +0 -69
  233. data/lib/ronin/model/targets_product.rb +0 -68
  234. data/lib/ronin/payloads/asm_payload.rb +0 -40
  235. data/lib/ronin/payloads/binary_payload.rb +0 -42
  236. data/lib/ronin/payloads/control.rb +0 -47
  237. data/lib/ronin/payloads/encoders/encoder.rb +0 -92
  238. data/lib/ronin/payloads/encoders/xor.rb +0 -79
  239. data/lib/ronin/payloads/encoders.rb +0 -32
  240. data/lib/ronin/payloads/exceptions/exception.rb +0 -27
  241. data/lib/ronin/payloads/exceptions/not_implemented.rb +0 -29
  242. data/lib/ronin/payloads/exceptions/unknown_helper.rb +0 -29
  243. data/lib/ronin/payloads/exceptions.rb +0 -23
  244. data/lib/ronin/payloads/has_payload.rb +0 -111
  245. data/lib/ronin/payloads/helpers/chained.rb +0 -61
  246. data/lib/ronin/payloads/helpers/rpc.rb +0 -93
  247. data/lib/ronin/payloads/helpers.rb +0 -23
  248. data/lib/ronin/payloads/nops.rb +0 -39
  249. data/lib/ronin/payloads/payload.rb +0 -350
  250. data/lib/ronin/payloads/payload_author.rb +0 -33
  251. data/lib/ronin/payloads/shellcode.rb +0 -40
  252. data/lib/ronin/payloads/web_payload.rb +0 -41
  253. data/lib/ronin/payloads.rb +0 -36
  254. data/lib/ronin/ui/command_line/commands/exploit.rb +0 -193
  255. data/lib/ronin/ui/command_line/commands/exploits.rb +0 -154
  256. data/lib/ronin/ui/command_line/commands/gen_binary_payload.rb +0 -34
  257. data/lib/ronin/ui/command_line/commands/gen_exploit.rb +0 -34
  258. data/lib/ronin/ui/command_line/commands/gen_ftp_exploit.rb +0 -34
  259. data/lib/ronin/ui/command_line/commands/gen_http_exploit.rb +0 -34
  260. data/lib/ronin/ui/command_line/commands/gen_local_exploit.rb +0 -34
  261. data/lib/ronin/ui/command_line/commands/gen_nops.rb +0 -34
  262. data/lib/ronin/ui/command_line/commands/gen_payload.rb +0 -34
  263. data/lib/ronin/ui/command_line/commands/gen_remote_exploit.rb +0 -34
  264. data/lib/ronin/ui/command_line/commands/gen_remote_tcp_exploit.rb +0 -34
  265. data/lib/ronin/ui/command_line/commands/gen_remote_udp_exploit.rb +0 -34
  266. data/lib/ronin/ui/command_line/commands/gen_shellcode.rb +0 -34
  267. data/lib/ronin/ui/command_line/commands/gen_web_exploit.rb +0 -34
  268. data/lib/ronin/ui/command_line/commands/payload.rb +0 -129
  269. data/lib/ronin/ui/command_line/commands/payloads.rb +0 -128
  270. data/lib/ronin/vuln/behavior.rb +0 -165
  271. data/spec/controls/behaviors_examples.rb +0 -38
  272. data/spec/exploits/binary_exploit_spec.rb +0 -44
  273. data/spec/exploits/buffer_overflow_exploit_spec.rb +0 -70
  274. data/spec/exploits/exploit_spec.rb +0 -313
  275. data/spec/exploits/file_based_exploit_spec.rb +0 -48
  276. data/spec/exploits/format_string_exploit_spec.rb +0 -32
  277. data/spec/exploits/ftp_spec.rb +0 -13
  278. data/spec/exploits/http_spec.rb +0 -17
  279. data/spec/exploits/padding_exploit_spec.rb +0 -44
  280. data/spec/exploits/remote_tcp_spec.rb +0 -28
  281. data/spec/exploits/remote_udp_spec.rb +0 -28
  282. data/spec/exploits/target_spec.rb +0 -98
  283. data/spec/exploits/targets/buffer_overflow_spec.rb +0 -22
  284. data/spec/exploits/web_spec.rb +0 -35
  285. data/spec/generators/exploits/exploit_examples.rb +0 -24
  286. data/spec/generators/exploits/exploit_spec.rb +0 -42
  287. data/spec/generators/exploits/ftp_spec.rb +0 -42
  288. data/spec/generators/exploits/http_spec.rb +0 -42
  289. data/spec/generators/exploits/local_spec.rb +0 -42
  290. data/spec/generators/exploits/remote_spec.rb +0 -42
  291. data/spec/generators/exploits/remote_tcp_spec.rb +0 -47
  292. data/spec/generators/exploits/remote_udp_spec.rb +0 -47
  293. data/spec/generators/exploits/web_spec.rb +0 -52
  294. data/spec/generators/payloads/binary_payload_spec.rb +0 -31
  295. data/spec/generators/payloads/nops_spec.rb +0 -31
  296. data/spec/generators/payloads/payload_examples.rb +0 -16
  297. data/spec/generators/payloads/payload_spec.rb +0 -31
  298. data/spec/generators/payloads/shellcode_spec.rb +0 -31
  299. data/spec/helpers/database.rb +0 -5
  300. data/spec/helpers/objects.rb +0 -22
  301. data/spec/model/has_default_port_spec.rb +0 -27
  302. data/spec/model/models/default_port_model.rb +0 -13
  303. data/spec/model/models/non_default_port_model.rb +0 -11
  304. data/spec/model/models/targets_arch_model.rb +0 -11
  305. data/spec/model/models/targets_os_model.rb +0 -11
  306. data/spec/model/models/targets_product_model.rb +0 -11
  307. data/spec/model/targets_arch_spec.rb +0 -32
  308. data/spec/model/targets_os_spec.rb +0 -33
  309. data/spec/model/targets_product_spec.rb +0 -35
  310. data/spec/objects/exploits/example.rb +0 -25
  311. data/spec/objects/exploits/simple.rb +0 -24
  312. data/spec/objects/payloads/simple.rb +0 -19
  313. data/spec/payloads/encoders/encoder_spec.rb +0 -30
  314. data/spec/payloads/encoders/xor_spec.rb +0 -20
  315. data/spec/payloads/payload_spec.rb +0 -156
  316. data/spec/vuln/behavior_spec.rb +0 -15
  317. data/static/ronin/generators/exploits/_cache.erb +0 -14
  318. data/static/ronin/generators/exploits/_header.erb +0 -1
  319. data/static/ronin/generators/exploits/_helpers.erb +0 -4
  320. data/static/ronin/generators/exploits/exploit.erb +0 -24
  321. data/static/ronin/generators/exploits/ftp.erb +0 -24
  322. data/static/ronin/generators/exploits/http.erb +0 -26
  323. data/static/ronin/generators/exploits/local.erb +0 -24
  324. data/static/ronin/generators/exploits/remote.erb +0 -24
  325. data/static/ronin/generators/exploits/remote_tcp.erb +0 -26
  326. data/static/ronin/generators/exploits/remote_udp.erb +0 -26
  327. data/static/ronin/generators/exploits/web.erb +0 -28
  328. data/static/ronin/generators/payloads/_cache.erb +0 -10
  329. data/static/ronin/generators/payloads/_header.erb +0 -1
  330. data/static/ronin/generators/payloads/_helpers.erb +0 -2
  331. data/static/ronin/generators/payloads/binary_payload.erb +0 -25
  332. data/static/ronin/generators/payloads/nops.erb +0 -19
  333. data/static/ronin/generators/payloads/payload.erb +0 -25
  334. data/static/ronin/generators/payloads/shellcode.erb +0 -25
  335. data/tasks/spec.rb +0 -10
  336. data/tasks/yard.rb +0 -13
  337. data.tar.gz.sig +0 -0
  338. metadata.gz.sig +0 -0
@@ -1,34 +0,0 @@
1
- #
2
- # Ronin Exploits - A Ruby library for Ronin that provides exploitation and
3
- # payload crafting functionality.
4
- #
5
- # Copyright (c) 2007-2009 Hal Brodigan (postmodern.mod3 at gmail.com)
6
- #
7
- # This program is free software; you can redistribute it and/or modify
8
- # it under the terms of the GNU General Public License as published by
9
- # the Free Software Foundation; either version 2 of the License, or
10
- # (at your option) any later version.
11
- #
12
- # This program is distributed in the hope that it will be useful,
13
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
14
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
- # GNU General Public License for more details.
16
- #
17
- # You should have received a copy of the GNU General Public License
18
- # along with this program; if not, write to the Free Software
19
- # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
20
- #
21
-
22
- require 'ronin/generators/exploits/remote_udp'
23
-
24
- module Ronin
25
- module UI
26
- module CommandLine
27
- module Commands
28
- class GenRemoteUdpExploit < Generators::Exploits::RemoteUDP
29
-
30
- end
31
- end
32
- end
33
- end
34
- end
@@ -1,34 +0,0 @@
1
- #
2
- # Ronin Exploits - A Ruby library for Ronin that provides exploitation and
3
- # payload crafting functionality.
4
- #
5
- # Copyright (c) 2007-2009 Hal Brodigan (postmodern.mod3 at gmail.com)
6
- #
7
- # This program is free software; you can redistribute it and/or modify
8
- # it under the terms of the GNU General Public License as published by
9
- # the Free Software Foundation; either version 2 of the License, or
10
- # (at your option) any later version.
11
- #
12
- # This program is distributed in the hope that it will be useful,
13
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
14
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
- # GNU General Public License for more details.
16
- #
17
- # You should have received a copy of the GNU General Public License
18
- # along with this program; if not, write to the Free Software
19
- # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
20
- #
21
-
22
- require 'ronin/generators/payloads/shellcode'
23
-
24
- module Ronin
25
- module UI
26
- module CommandLine
27
- module Commands
28
- class GenShellcode < Generators::Payloads::Shellcode
29
-
30
- end
31
- end
32
- end
33
- end
34
- end
@@ -1,34 +0,0 @@
1
- #
2
- # Ronin Exploits - A Ruby library for Ronin that provides exploitation and
3
- # payload crafting functionality.
4
- #
5
- # Copyright (c) 2007-2009 Hal Brodigan (postmodern.mod3 at gmail.com)
6
- #
7
- # This program is free software; you can redistribute it and/or modify
8
- # it under the terms of the GNU General Public License as published by
9
- # the Free Software Foundation; either version 2 of the License, or
10
- # (at your option) any later version.
11
- #
12
- # This program is distributed in the hope that it will be useful,
13
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
14
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
- # GNU General Public License for more details.
16
- #
17
- # You should have received a copy of the GNU General Public License
18
- # along with this program; if not, write to the Free Software
19
- # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
20
- #
21
-
22
- require 'ronin/generators/exploits/web'
23
-
24
- module Ronin
25
- module UI
26
- module CommandLine
27
- module Commands
28
- class GenWebExploit < Generators::Exploits::Web
29
-
30
- end
31
- end
32
- end
33
- end
34
- end
@@ -1,129 +0,0 @@
1
- #
2
- # Ronin Exploits - A Ruby library for Ronin that provides exploitation and
3
- # payload crafting functionality.
4
- #
5
- # Copyright (c) 2007-2009 Hal Brodigan (postmodern.mod3 at gmail.com)
6
- #
7
- # This program is free software; you can redistribute it and/or modify
8
- # it under the terms of the GNU General Public License as published by
9
- # the Free Software Foundation; either version 2 of the License, or
10
- # (at your option) any later version.
11
- #
12
- # This program is distributed in the hope that it will be useful,
13
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
14
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
- # GNU General Public License for more details.
16
- #
17
- # You should have received a copy of the GNU General Public License
18
- # along with this program; if not, write to the Free Software
19
- # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
20
- #
21
-
22
- require 'ronin/payloads'
23
- require 'ronin/ui/command_line/command'
24
- require 'ronin/database'
25
-
26
- require 'parameters/parser'
27
-
28
- module Ronin
29
- module UI
30
- module CommandLine
31
- module Commands
32
- class Payload < Command
33
-
34
- desc "payload [NAME] [options]", "Builds the specified Payload"
35
- method_option :database, :type => :string, :default => Database.config, :aliases => '-D'
36
- method_option :params, :type => :array, :default => [], :aliases => '-p'
37
- method_option :host, :type => :string
38
- method_option :port, :type => :numeric
39
- method_option :local_host, :type => :string
40
- method_option :local_port, :type => :numeric
41
- method_option :file, :type => :string, :aliases => '-f'
42
- method_option :describing, :type => :string, :aliases => '-d'
43
- method_option :version, :type => :string, :aliases => '-V'
44
- method_option :license, :type => :string, :aliases => '-l'
45
- method_option :arch, :type => :string, :aliases => '-a'
46
- method_option :os, :type => :string, :aliases => '-o'
47
- method_option :raw, :type => :boolean, :aliases => '-r'
48
-
49
- def default(name=nil)
50
- UI::Output.silent = true if options.raw?
51
- Database.setup(options[:database])
52
-
53
- # Load the payload
54
- if options[:file]
55
- load_payload!
56
- else
57
- find_payload!(name)
58
- end
59
-
60
- unless @payload
61
- print_error "Could not find the specified payload"
62
- exit -1
63
- end
64
-
65
- params = Parameters::Parser.parse(options[:params])
66
- params[:host] = options[:host] if options[:host]
67
- params[:port] = options[:port] if options[:port]
68
- params[:local_host] = options[:local_host] if options[:local_host]
69
- params[:local_port] = options[:local_port] if options[:local_port]
70
-
71
- begin
72
- # Build the payload
73
- @payload.build!(params)
74
- rescue Parameters::MissingParam, Payloads::Exception => e
75
- print_error(e.message)
76
- end
77
-
78
- raw_payload = @payload.raw_payload
79
-
80
- if options.raw?
81
- # Write the raw payload
82
- STDOUT.write(raw_payload)
83
- else
84
- # Dump the built payload
85
- puts raw_payload.dump
86
- end
87
- end
88
-
89
- protected
90
-
91
- def load_payload!
92
- @payload = Payloads::Payload.load_from(options[:file])
93
- end
94
-
95
- def find_payload!(name=nil)
96
- @payload = Payloads::Payload.load_first do |payloads|
97
- if name
98
- payloads = payloads.named(name)
99
- end
100
-
101
- if options[:describing]
102
- payloads = payloads.describing(options[:describing])
103
- end
104
-
105
- if options[:version]
106
- payloads = payloads.revision(options[:version])
107
- end
108
-
109
- if options[:license]
110
- payloads = payloads.licensed_under(options[:license])
111
- end
112
-
113
- if options[:arch]
114
- payloads = payloads.targeting_arch(options[:arch])
115
- end
116
-
117
- if options[:os]
118
- payloads = payloads.targeting_os(options[:os])
119
- end
120
-
121
- payloads
122
- end
123
- end
124
-
125
- end
126
- end
127
- end
128
- end
129
- end
@@ -1,128 +0,0 @@
1
- #
2
- # Ronin Exploits - A Ruby library for Ronin that provides exploitation and
3
- # payload crafting functionality.
4
- #
5
- # Copyright (c) 2007-2009 Hal Brodigan (postmodern.mod3 at gmail.com)
6
- #
7
- # This program is free software; you can redistribute it and/or modify
8
- # it under the terms of the GNU General Public License as published by
9
- # the Free Software Foundation; either version 2 of the License, or
10
- # (at your option) any later version.
11
- #
12
- # This program is distributed in the hope that it will be useful,
13
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
14
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
- # GNU General Public License for more details.
16
- #
17
- # You should have received a copy of the GNU General Public License
18
- # along with this program; if not, write to the Free Software
19
- # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
20
- #
21
-
22
- require 'ronin/ui/command_line/command'
23
-
24
- require 'ronin/payloads'
25
- require 'ronin/database'
26
-
27
- module Ronin
28
- module UI
29
- module CommandLine
30
- module Commands
31
- class Payloads < Command
32
-
33
- desc "payloads [options]", "Lists the available Payloads"
34
- method_option :database, :type => :string, :default => Database.config, :aliases => '-D'
35
- method_option :name, :type => :string, :aliases => '-n'
36
- method_option :version, :type => :string, :aliases => '-v'
37
- method_option :describing, :stype => :string, :aliases => '-d'
38
- method_option :license, :type => :string, :aliases => '-l'
39
- method_option :arch, :type => :string, :aliases => '-a'
40
- method_option :os, :type => :string, :aliases => '-o'
41
- method_option :verbose, :type => :boolean, :aliases => '-v'
42
-
43
- def default
44
- Database.setup(options[:database])
45
-
46
- payloads = Ronin::Payloads::Payload.all
47
-
48
- if options[:name]
49
- payloads = payloads.named(options[:name])
50
- end
51
-
52
- if options[:version]
53
- payloads = payloads.revision(options[:version])
54
- end
55
-
56
- if options[:describing]
57
- payloads = payloads.describing(options[:describing])
58
- end
59
-
60
- if options[:license]
61
- payloads = payloads.licensed_under(options[:license])
62
- end
63
-
64
- if options[:arch]
65
- payloads = payloads.targeting_arch(options[:arch])
66
- end
67
-
68
- if options[:os]
69
- payloads = payloads.targeting_os(options[:os])
70
- end
71
-
72
- if payloads.empty?
73
- print_error "Could not find similar payloads"
74
- exit -1
75
- end
76
-
77
- if options.verbose?
78
- payloads.each { |payload| print_payload(payload) }
79
- else
80
- indent do
81
- payloads.each { |payload| puts payload }
82
- end
83
- end
84
- end
85
-
86
- protected
87
-
88
- def print_payload(payload)
89
- attributes = payload.humanize_attributes(
90
- :exclude => [:description]
91
- )
92
- attributes['Arch'] = payload.arch if payload.arch
93
- attributes['OS'] = payload.os if payload.os
94
-
95
- print_hash(attributes, :title => "Payload: #{payload}")
96
-
97
- indent do
98
- if payload.description
99
- puts "Description:\n\n"
100
- indent do
101
- payload.description.each_line { |line| puts line }
102
- end
103
- puts "\n"
104
- end
105
-
106
- unless payload.authors.empty?
107
- payload.authors.each do |author|
108
- print_hash(author.humanize_attributes, :title => 'Author')
109
- end
110
- end
111
-
112
- unless payload.behaviors.empty?
113
- print_array(payload.behaviors, :title => 'Controls')
114
- end
115
-
116
- attempt { payload.load_original! }
117
-
118
- unless payload.params.empty?
119
- print_array(payload.params.values, :title => 'Parameters')
120
- end
121
- end
122
- end
123
-
124
- end
125
- end
126
- end
127
- end
128
- end
@@ -1,165 +0,0 @@
1
- #
2
- # Ronin Exploits - A Ruby library for Ronin that provides exploitation and
3
- # payload crafting functionality.
4
- #
5
- # Copyright (c) 2007-2009 Hal Brodigan (postmodern.mod3 at gmail.com)
6
- #
7
- # This program is free software; you can redistribute it and/or modify
8
- # it under the terms of the GNU General Public License as published by
9
- # the Free Software Foundation; either version 2 of the License, or
10
- # (at your option) any later version.
11
- #
12
- # This program is distributed in the hope that it will be useful,
13
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
14
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
- # GNU General Public License for more details.
16
- #
17
- # You should have received a copy of the GNU General Public License
18
- # along with this program; if not, write to the Free Software
19
- # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
20
- #
21
-
22
- require 'ronin/extensions/meta'
23
- require 'ronin/extensions/string'
24
- require 'ronin/model'
25
-
26
- require 'dm-predefined'
27
-
28
- module Ronin
29
- module Vuln
30
- class Behavior
31
-
32
- include Model
33
- include DataMapper::Predefined
34
-
35
- # Primary key of the behavior
36
- property :id, Serial
37
-
38
- # Name of the behavior
39
- property :name, String
40
-
41
- # Description for the behavior
42
- property :description, Text
43
-
44
- # Validates
45
- validates_present :name, :description
46
- validates_is_unique :name
47
-
48
- #
49
- # Converts the behavior to a String.
50
- #
51
- # @return [String]
52
- # The name of the behavior.
53
- #
54
- def to_s
55
- @name.to_s
56
- end
57
-
58
- protected
59
-
60
- #
61
- # Defines a new builtin Behavior.
62
- #
63
- # @param [Symbol, String] name
64
- # The name of the behavior to predefine.
65
- #
66
- # @param [String] description
67
- # The description of the behavior.
68
- #
69
- # @example Defining a builtin Behavior
70
- # Behavior.predefine :command_exec, "Arbitrary command execution"
71
- #
72
- # @example Retrieving a predefined behavior
73
- # Behavior.command_exec
74
- #
75
- def self.predefine(name,description=nil)
76
- super(name,:name => name.to_s, :description => description)
77
- end
78
-
79
- # The ability to read memory
80
- predefine :memory_read, "The ability to read memory"
81
-
82
- # The ability to write to memory
83
- predefine :memory_write, "The ability to write to memory"
84
-
85
- # The ability to execute from memory
86
- predefine :memory_exec, "The ability to execute memory"
87
-
88
- # The ability to create files
89
- predefine :file_create, "Arbitrary file creation"
90
-
91
- # The ability to read files
92
- predefine :file_read, "The ability to read from a file"
93
-
94
- # The ability to write to a file
95
- predefine :file_write, "The ability to write to a file"
96
-
97
- # The ability to modify existing files
98
- predefine :file_modify, "The ability to modify an existing file"
99
-
100
- # The ability to change ownership on files
101
- predefine :file_ownership, "The ability to change ownership of an existing file"
102
-
103
- # The ability to change the modification time on files
104
- predefine :file_mtime, "The ability to change the modification timestamp of a file"
105
-
106
- # The ability to change the creation time on files
107
- predefine :file_ctime, "The ability to change the creation timestamp of a file"
108
-
109
- # The ability to create directories
110
- predefine :dir_create, "The ability to create a directory"
111
-
112
- # The ability to list the contents of directories
113
- predefine :dir_listing, "The ability to list the contents of a directory"
114
-
115
- # The ability to redirect socket connections
116
- predefine :socket_redirect, "The ability to redirect a socket's connection"
117
-
118
- # The ability to create socket connections
119
- predefine :socket_connect, "The ability to create a network socket"
120
-
121
- # The ability to listen on a socket
122
- predefine :socket_listen, "The ability to listen on a network socket"
123
-
124
- # The ability to read from a socket
125
- predefine :socket_read, "The ability to read from a network socket"
126
-
127
- # The ability to write to a socket
128
- predefine :socket_write, "The ability to write to a network socket"
129
-
130
- # The ability to execute code
131
- predefine :code_exec, "Arbitrary code execution"
132
-
133
- # The ability to execute commands
134
- predefine :command_exec, "Arbitrary command execution"
135
-
136
- # The ability to bypass authentication
137
- predefine :auth_bypass, "Authentication by-pass"
138
-
139
- # The ability to gain privileges
140
- predefine :gain_privileges, "Gain privileges"
141
-
142
- # The ability to drop privileges
143
- predefine :drop_privileges, "Drop privileges"
144
-
145
- # The ability to safely exit a running program
146
- predefine :exit_program, "Exit program"
147
-
148
- # The ability to crash a running program
149
- predefine :crash_program, "Crash program"
150
-
151
- # The ability to exhaust available memory
152
- predefine :exhaust_memory, "Exhaust freely available memory"
153
-
154
- # The ability to exhaust available disk space
155
- predefine :exhaust_disk, "Exhaust freely available disk-space"
156
-
157
- # The ability to exhaust available network bandwidth
158
- predefine :exhaust_bandwidth, "Exhaust available bandwidth"
159
-
160
- # The ability to exhaust CPU access
161
- predefine :exhaust_cpu, "Exhaust CPU performance"
162
-
163
- end
164
- end
165
- end
@@ -1,38 +0,0 @@
1
- require 'spec_helper'
2
-
3
- shared_examples_for "controls behaviors" do
4
- it "should have a model to represent the controled behaviors" do
5
- @controler.control_model.include?(Ronin::Model).should == true
6
- end
7
-
8
- it "should not have any controled behaviors by default" do
9
- @controler.controls.should be_empty
10
- end
11
-
12
- it "should specify what behaviors to be controled" do
13
- @controler.control :memory_read, :memory_write
14
-
15
- @controler.behaviors.should == [:memory_read, :memory_write]
16
- end
17
-
18
- it "should extend a control module if on exists for the behavior" do
19
- @controler.control :command_exec
20
-
21
- @controler.behaviors.should == [:command_exec]
22
- @controler.kind_of?(Ronin::Controls::Helpers::CommandExec).should == true
23
- end
24
-
25
- it "should not extend a control module if none exist for the behavior" do
26
- @controler.control :exhaust_memory
27
-
28
- @controler.behaviors.should == [:exhaust_memory]
29
- end
30
-
31
- it "should load the control modules for the behaviors" do
32
- @controler.control :command_exec
33
- @controler.cache!
34
-
35
- cached = @controler.class.load_first(:name => @controler.name)
36
- cached.kind_of?(Ronin::Controls::Helpers::CommandExec).should == true
37
- end
38
- end
@@ -1,44 +0,0 @@
1
- require 'ronin/exploits/local'
2
- require 'ronin/exploits/helpers/binary'
3
-
4
- require 'spec_helper'
5
-
6
- describe Exploits::Helpers::Binary do
7
- before(:all) do
8
- @exploit = Exploits::Local.new do
9
- helper :binary
10
-
11
- targeting(:arch => Arch.i686)
12
- targeting(:arch => nil)
13
-
14
- def pack_integer
15
- pack(0xffffaaaa)
16
- end
17
-
18
- def pack_integer_with_address_length
19
- pack(0xffffaaaa,2)
20
- end
21
- end
22
- end
23
-
24
- it "should require a targeted arch" do
25
- @exploit.target = @exploit.targets.last
26
- @exploit.target.arch.should be_nil
27
-
28
- lambda {
29
- @exploit.pack_integer
30
- }.should raise_error(Exploits::TargetDataMissing)
31
- end
32
-
33
- it "should be able to pack an integer" do
34
- @exploit.target = @exploit.targets.first
35
-
36
- @exploit.pack_integer.should == "\xaa\xaa\xff\xff"
37
- end
38
-
39
- it "should be able to pack an integer with an address length" do
40
- @exploit.target = @exploit.targets.first
41
-
42
- @exploit.pack_integer_with_address_length.should == "\xaa\xaa"
43
- end
44
- end
@@ -1,70 +0,0 @@
1
- require 'ronin/exploits/local'
2
- require 'ronin/exploits/helpers/buffer_overflow'
3
-
4
- require 'spec_helper'
5
-
6
- describe Exploits::Helpers::BufferOverflow do
7
- before(:all) do
8
- @exploit = Exploits::Local.new do
9
- helper :buffer_overflow
10
-
11
- self.name = 'example_bof'
12
-
13
- targeting do |target|
14
- target.arch = Arch.i686
15
- target.buffer_length = 256
16
- target.ip = 0xffffaaaa
17
- end
18
-
19
- targeting do |target|
20
- target.arch = Arch.i686
21
- target.buffer_length = 256
22
- target.bp = 0xffffbbbb
23
- target.ip = 0xffffaaaa
24
- end
25
-
26
- targeting do |target|
27
- target.arch = Arch.i686
28
- target.buffer_length = 256
29
- target.bp = 0xffffbbbb
30
- target.ip = 0xffffaabb
31
- target.frame_repeat = 2
32
- end
33
- end
34
- end
35
-
36
- it "should use Targets::BufferOverflow for targets" do
37
- @exploit.targets.all? { |target|
38
- target.class == Exploits::Targets::BufferOverflow
39
- }.should == true
40
- end
41
-
42
- it "should build a buffer overflow" do
43
- @exploit.target = @exploit.targets[0]
44
- @exploit.build!
45
-
46
- @exploit.buffer.length.should == (256 + 4*2)
47
- @exploit.buffer[256,4].should == "\xaa\xaa\xff\xff"
48
- @exploit.buffer[260,4].should == "\xaa\xaa\xff\xff"
49
- end
50
-
51
- it "should build a buffer overflow that includes the BP" do
52
- @exploit.target = @exploit.targets[1]
53
- @exploit.build!
54
-
55
- @exploit.buffer.length.should == (256 + 4*2)
56
- @exploit.buffer[256,4].should == "\xbb\xbb\xff\xff"
57
- @exploit.buffer[260,4].should == "\xaa\xaa\xff\xff"
58
- end
59
-
60
- it "should build a buffer overflow that has repeating stack frames" do
61
- @exploit.target = @exploit.targets[2]
62
- @exploit.build!
63
-
64
- @exploit.buffer.length.should == (256 + 4*4)
65
- @exploit.buffer[256,4].should == "\xbb\xbb\xff\xff"
66
- @exploit.buffer[260,4].should == "\xbb\xaa\xff\xff"
67
- @exploit.buffer[264,4].should == "\xbb\xbb\xff\xff"
68
- @exploit.buffer[268,4].should == "\xbb\xaa\xff\xff"
69
- end
70
- end