ronin 1.5.1 → 2.0.0.beta1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (499) hide show
  1. checksums.yaml +4 -4
  2. data/.document +0 -1
  3. data/.github/workflows/ruby.yml +4 -5
  4. data/.gitignore +1 -0
  5. data/.mailmap +1 -0
  6. data/.ruby-version +1 -1
  7. data/.yardopts +0 -2
  8. data/ChangeLog.md +239 -148
  9. data/Gemfile +58 -45
  10. data/README.md +147 -178
  11. data/Rakefile +3 -50
  12. data/bin/ronin +2 -3
  13. data/data/new/project/.gitignore +15 -0
  14. data/data/new/project/.ruby-version.erb +1 -0
  15. data/data/new/project/Dockerfile.erb +9 -0
  16. data/data/new/project/Gemfile.erb +16 -0
  17. data/data/new/project/Rakefile +43 -0
  18. data/data/new/project/project.rb.erb +14 -0
  19. data/data/new/script.rb.erb +6 -0
  20. data/data/tips/cli/console.txt +4 -0
  21. data/data/tips/cli/help.txt +12 -0
  22. data/data/tips/ruby/array_join.txt +5 -0
  23. data/data/tips/ruby/binary_string.txt +4 -0
  24. data/data/tips/ruby/file_binread.txt +4 -0
  25. data/data/tips/ruby/file_each_line.txt +6 -0
  26. data/data/tips/ruby/force_encoding.txt +4 -0
  27. data/data/tips/ruby/integer_binary_format.txt +10 -0
  28. data/data/tips/ruby/integer_chr.txt +5 -0
  29. data/data/tips/ruby/integer_hex_format.txt +10 -0
  30. data/data/tips/ruby/string_bytes.txt +17 -0
  31. data/data/tips/ruby/string_chars.txt +17 -0
  32. data/data/tips/ruby/string_ord.txt +5 -0
  33. data/data/tips/ruby/string_split.txt +13 -0
  34. data/data/tips/scripting/array_pack.txt +5 -0
  35. data/data/tips/scripting/base64_decode.txt +5 -0
  36. data/data/tips/scripting/base64_encode.txt +5 -0
  37. data/data/tips/scripting/build_wordlist.txt +9 -0
  38. data/data/tips/scripting/chars.txt +8 -0
  39. data/data/tips/scripting/chars_strings_in.txt +12 -0
  40. data/data/tips/scripting/dir_traversal.txt +5 -0
  41. data/data/tips/scripting/dns_get_address.txt +5 -0
  42. data/data/tips/scripting/dns_get_addresses.txt +5 -0
  43. data/data/tips/scripting/extract_ips.txt +6 -0
  44. data/data/tips/scripting/file_each_row.txt +6 -0
  45. data/data/tips/scripting/file_hexdump.txt +4 -0
  46. data/data/tips/scripting/float_pack.txt +5 -0
  47. data/data/tips/scripting/ftp_connect.txt +14 -0
  48. data/data/tips/scripting/generate_self_signed_cert.txt +20 -0
  49. data/data/tips/scripting/http_get_body.txt +5 -0
  50. data/data/tips/scripting/http_get_headers.txt +17 -0
  51. data/data/tips/scripting/integer_pack.txt +5 -0
  52. data/data/tips/scripting/ip_range_cidr.txt +6 -0
  53. data/data/tips/scripting/ip_range_glob.txt +6 -0
  54. data/data/tips/scripting/load_cert.txt +5 -0
  55. data/data/tips/scripting/md5.txt +5 -0
  56. data/data/tips/scripting/printing_messages.txt +11 -0
  57. data/data/tips/scripting/random_alpha.txt +5 -0
  58. data/data/tips/scripting/random_alpha_numeric.txt +5 -0
  59. data/data/tips/scripting/random_hex.txt +5 -0
  60. data/data/tips/scripting/read_wordlist.txt +7 -0
  61. data/data/tips/scripting/ronin_support.txt +5 -0
  62. data/data/tips/scripting/sha1.txt +5 -0
  63. data/data/tips/scripting/sha256.txt +5 -0
  64. data/data/tips/scripting/sha512.txt +5 -0
  65. data/data/tips/scripting/ssl_cert.txt +10 -0
  66. data/data/tips/scripting/ssl_socket.txt +12 -0
  67. data/data/tips/scripting/string_hexdump.txt +5 -0
  68. data/data/tips/scripting/string_random_case.txt +5 -0
  69. data/data/tips/scripting/string_unpack.txt +5 -0
  70. data/data/tips/scripting/tcp_accept.txt +6 -0
  71. data/data/tips/scripting/tcp_banner.txt +5 -0
  72. data/data/tips/scripting/tcp_connect.txt +12 -0
  73. data/data/tips/scripting/tcp_open.txt +5 -0
  74. data/data/tips/scripting/tcp_send.txt +5 -0
  75. data/data/tips/scripting/tcp_server_loop.txt +6 -0
  76. data/data/tips/scripting/try.txt +4 -0
  77. data/data/tips/scripting/udp_connect.txt +8 -0
  78. data/data/tips/scripting/udp_open.txt +5 -0
  79. data/data/tips/scripting/udp_recv.txt +7 -0
  80. data/data/tips/scripting/udp_send.txt +5 -0
  81. data/data/tips/scripting/udp_server_loop.txt +7 -0
  82. data/data/tips/scripting/unix_accept.txt +7 -0
  83. data/data/tips/scripting/unix_connect.txt +12 -0
  84. data/data/tips/scripting/zlib_deflate.txt +5 -0
  85. data/data/tips/scripting/zlib_inflate.txt +5 -0
  86. data/gemspec.yml +73 -57
  87. data/lib/ronin/cli/char_set_options.rb +181 -0
  88. data/lib/ronin/cli/cipher_command.rb +149 -0
  89. data/lib/ronin/{script/exceptions/build_failed.rb → cli/command.rb} +11 -6
  90. data/lib/ronin/cli/commands/asn.rb +284 -0
  91. data/lib/ronin/cli/commands/banner_grab.rb +84 -0
  92. data/lib/ronin/cli/commands/bitflip.rb +132 -0
  93. data/lib/ronin/cli/commands/cert_dump.rb +285 -0
  94. data/lib/ronin/cli/commands/cert_gen.rb +395 -0
  95. data/lib/ronin/cli/commands/cert_grab.rb +128 -0
  96. data/lib/ronin/cli/commands/decode.rb +143 -0
  97. data/lib/ronin/cli/commands/decrypt.rb +67 -0
  98. data/lib/ronin/cli/commands/dns.rb +183 -0
  99. data/lib/ronin/cli/commands/email_addr.rb +127 -0
  100. data/lib/ronin/cli/commands/encode.rb +143 -0
  101. data/lib/ronin/cli/commands/encrypt.rb +67 -0
  102. data/lib/ronin/cli/commands/entropy.rb +75 -0
  103. data/lib/ronin/cli/commands/escape.rb +121 -0
  104. data/lib/ronin/cli/commands/extract.rb +138 -0
  105. data/lib/ronin/cli/commands/grep.rb +238 -0
  106. data/lib/ronin/cli/commands/hexdump.rb +475 -0
  107. data/lib/ronin/cli/commands/highlight.rb +121 -0
  108. data/lib/ronin/cli/commands/hmac.rb +102 -0
  109. data/lib/ronin/cli/commands/homoglyph.rb +98 -0
  110. data/lib/ronin/cli/commands/host.rb +305 -0
  111. data/lib/ronin/cli/commands/http.rb +354 -0
  112. data/lib/ronin/cli/commands/ip.rb +242 -0
  113. data/lib/ronin/cli/commands/iprange.rb +138 -0
  114. data/lib/ronin/cli/commands/irb.rb +106 -0
  115. data/lib/ronin/cli/commands/md5.rb +67 -0
  116. data/lib/ronin/cli/commands/netcat.rb +419 -0
  117. data/lib/ronin/cli/commands/new/project.rb +119 -0
  118. data/lib/ronin/cli/commands/new/script.rb +68 -0
  119. data/lib/ronin/cli/commands/new.rb +65 -0
  120. data/lib/ronin/cli/commands/proxy.rb +519 -0
  121. data/lib/ronin/cli/commands/public_suffix_list.rb +118 -0
  122. data/lib/ronin/cli/commands/quote.rb +114 -0
  123. data/lib/ronin/cli/commands/rot.rb +114 -0
  124. data/lib/ronin/cli/commands/sha1.rb +58 -0
  125. data/lib/ronin/cli/commands/sha256.rb +67 -0
  126. data/lib/ronin/cli/commands/sha512.rb +67 -0
  127. data/lib/ronin/cli/commands/strings.rb +151 -0
  128. data/lib/ronin/cli/commands/tips.rb +190 -0
  129. data/lib/ronin/cli/commands/tld_list.rb +118 -0
  130. data/lib/ronin/cli/commands/typo.rb +80 -0
  131. data/lib/ronin/cli/commands/typosquat.rb +123 -0
  132. data/lib/ronin/cli/commands/unescape.rb +121 -0
  133. data/lib/ronin/cli/commands/unhexdump.rb +213 -0
  134. data/lib/ronin/cli/commands/unquote.rb +114 -0
  135. data/lib/ronin/cli/commands/url.rb +151 -0
  136. data/lib/ronin/cli/commands/xor.rb +91 -0
  137. data/lib/ronin/cli/file_processor_command.rb +94 -0
  138. data/lib/ronin/cli/http_shell.rb +362 -0
  139. data/lib/ronin/cli/key_options.rb +61 -0
  140. data/lib/ronin/cli/method_options.rb +71 -0
  141. data/lib/ronin/cli/pattern_options.rb +343 -0
  142. data/lib/ronin/cli/printing/http.rb +153 -0
  143. data/lib/ronin/cli/printing/syntax_highlighting.rb +96 -0
  144. data/lib/ronin/{ui/cli/commands.rb → cli/string_methods_command.rb} +23 -12
  145. data/lib/ronin/cli/string_processor_command.rb +185 -0
  146. data/lib/ronin/cli/typo_options.rb +80 -0
  147. data/lib/ronin/cli/value_processor_command.rb +97 -0
  148. data/lib/ronin/cli.rb +70 -0
  149. data/lib/ronin/config.rb +2 -10
  150. data/lib/ronin/{database/exceptions/invalid_config.rb → root.rb} +6 -7
  151. data/lib/ronin/ui.rb +4 -4
  152. data/lib/ronin/version.rb +3 -4
  153. data/lib/ronin.rb +9 -5
  154. data/man/ronin-asn.1 +124 -0
  155. data/man/ronin-asn.1.md +86 -0
  156. data/man/ronin-banner-grab.1 +45 -0
  157. data/man/ronin-banner-grab.1.md +33 -0
  158. data/man/ronin-bitflip.1 +123 -0
  159. data/man/ronin-bitflip.1.md +92 -0
  160. data/man/ronin-cert-dump.1 +99 -0
  161. data/man/ronin-cert-dump.1.md +68 -0
  162. data/man/ronin-cert-gen.1 +144 -0
  163. data/man/ronin-cert-gen.1.md +104 -0
  164. data/man/ronin-cert-grab.1 +68 -0
  165. data/man/ronin-cert-grab.1.md +47 -0
  166. data/man/ronin-decode.1 +103 -0
  167. data/man/ronin-decode.1.md +77 -0
  168. data/man/ronin-decrypt.1 +75 -0
  169. data/man/ronin-decrypt.1.md +56 -0
  170. data/man/ronin-dns.1 +45 -0
  171. data/man/ronin-dns.1.md +33 -0
  172. data/man/ronin-email-addr.1 +76 -0
  173. data/man/ronin-email-addr.1.md +54 -0
  174. data/man/ronin-encode.1 +103 -0
  175. data/man/ronin-encode.1.md +77 -0
  176. data/man/ronin-encrypt.1 +75 -0
  177. data/man/ronin-encrypt.1.md +56 -0
  178. data/man/ronin-entropy.1 +43 -0
  179. data/man/ronin-entropy.1.md +32 -0
  180. data/man/ronin-escape.1 +94 -0
  181. data/man/ronin-escape.1.md +70 -0
  182. data/man/ronin-extract.1 +263 -0
  183. data/man/ronin-extract.1.md +197 -0
  184. data/man/ronin-grep.1 +275 -0
  185. data/man/ronin-grep.1.md +206 -0
  186. data/man/ronin-help.1 +3 -15
  187. data/man/ronin-help.1.md +3 -12
  188. data/man/ronin-hexdump.1 +323 -0
  189. data/man/ronin-hexdump.1.md +197 -0
  190. data/man/ronin-highlight.1 +42 -0
  191. data/man/ronin-highlight.1.md +31 -0
  192. data/man/ronin-hmac.1 +66 -0
  193. data/man/ronin-hmac.1.md +49 -0
  194. data/man/ronin-homoglyph.1 +49 -0
  195. data/man/ronin-homoglyph.1.md +36 -0
  196. data/man/ronin-host.1 +99 -0
  197. data/man/ronin-host.1.md +74 -0
  198. data/man/ronin-http.1 +141 -0
  199. data/man/ronin-http.1.md +105 -0
  200. data/man/ronin-ip.1 +145 -0
  201. data/man/ronin-ip.1.md +103 -0
  202. data/man/ronin-iprange.1 +46 -0
  203. data/man/ronin-iprange.1.md +34 -0
  204. data/man/ronin-irb.1 +35 -0
  205. data/man/ronin-irb.1.md +25 -0
  206. data/man/ronin-md5.1 +54 -0
  207. data/man/ronin-md5.1.md +40 -0
  208. data/man/ronin-netcat.1 +110 -0
  209. data/man/ronin-netcat.1.md +82 -0
  210. data/man/ronin-new-project.1 +54 -0
  211. data/man/ronin-new-project.1.md +40 -0
  212. data/man/ronin-new-script.1 +37 -0
  213. data/man/ronin-new-script.1.md +27 -0
  214. data/man/ronin-new.1 +51 -0
  215. data/man/ronin-new.1.md +38 -0
  216. data/man/{ronin-net-proxy.1 → ronin-proxy.1} +45 -37
  217. data/man/{ronin-net-proxy.1.md → ronin-proxy.1.md} +39 -32
  218. data/man/ronin-public-suffix-list.1 +55 -0
  219. data/man/ronin-public-suffix-list.1.md +41 -0
  220. data/man/ronin-quote.1 +78 -0
  221. data/man/ronin-quote.1.md +58 -0
  222. data/man/ronin-rot.1 +62 -0
  223. data/man/ronin-rot.1.md +46 -0
  224. data/man/ronin-sha1.1 +54 -0
  225. data/man/ronin-sha1.1.md +40 -0
  226. data/man/ronin-sha256.1 +54 -0
  227. data/man/ronin-sha256.1.md +40 -0
  228. data/man/ronin-sha512.1 +54 -0
  229. data/man/ronin-sha512.1.md +40 -0
  230. data/man/ronin-strings.1 +115 -0
  231. data/man/ronin-strings.1.md +86 -0
  232. data/man/ronin-tips.1 +35 -0
  233. data/man/ronin-tips.1.md +25 -0
  234. data/man/ronin-tld-list.1 +55 -0
  235. data/man/ronin-tld-list.1.md +41 -0
  236. data/man/ronin-typo.1 +61 -0
  237. data/man/ronin-typo.1.md +45 -0
  238. data/man/ronin-typosquat.1 +65 -0
  239. data/man/ronin-typosquat.1.md +48 -0
  240. data/man/ronin-unescape.1 +94 -0
  241. data/man/ronin-unescape.1.md +70 -0
  242. data/man/ronin-unhexdump.1 +187 -0
  243. data/man/ronin-unhexdump.1.md +107 -0
  244. data/man/ronin-unquote.1 +78 -0
  245. data/man/ronin-unquote.1.md +58 -0
  246. data/man/ronin-url.1 +85 -0
  247. data/man/ronin-url.1.md +63 -0
  248. data/man/ronin-xor.1 +62 -0
  249. data/man/ronin-xor.1.md +46 -0
  250. data/man/ronin.1 +25 -6
  251. data/man/ronin.1.md +20 -5
  252. data/ronin.gemspec +1 -1
  253. data/spec/cli/command_spec.rb +10 -0
  254. data/spec/cli/commands/decode_spec.rb +152 -0
  255. data/spec/cli/commands/encode_spec.rb +152 -0
  256. data/spec/cli/commands/escape_spec.rb +128 -0
  257. data/spec/cli/commands/quote_spec.rb +76 -0
  258. data/spec/cli/commands/unescape_spec.rb +128 -0
  259. data/spec/cli/commands/unquote_spec.rb +80 -0
  260. data/spec/cli/fixtures/file.txt +3 -0
  261. data/spec/cli/fixtures/file2.txt +3 -0
  262. data/spec/cli/key_options_spec.rb +56 -0
  263. data/spec/cli/method_options_spec.rb +71 -0
  264. data/spec/cli/string_methods_command_spec.rb +25 -0
  265. data/spec/cli/string_processor_command_spec.rb +258 -0
  266. data/spec/cli/value_processor_command_spec.rb +127 -0
  267. data/spec/spec_helper.rb +2 -57
  268. data/spec/version_spec.rb +11 -0
  269. metadata +301 -455
  270. data/bin/ronin-campaigns +0 -20
  271. data/bin/ronin-console +0 -20
  272. data/bin/ronin-creds +0 -20
  273. data/bin/ronin-database +0 -20
  274. data/bin/ronin-emails +0 -20
  275. data/bin/ronin-exec +0 -20
  276. data/bin/ronin-fuzzer +0 -20
  277. data/bin/ronin-help +0 -20
  278. data/bin/ronin-hosts +0 -20
  279. data/bin/ronin-install +0 -20
  280. data/bin/ronin-ips +0 -20
  281. data/bin/ronin-net-proxy +0 -20
  282. data/bin/ronin-repos +0 -20
  283. data/bin/ronin-uninstall +0 -20
  284. data/bin/ronin-update +0 -20
  285. data/bin/ronin-urls +0 -20
  286. data/bin/ronin-wordlist +0 -20
  287. data/lib/bond/completions/ronin.rb +0 -154
  288. data/lib/ronin/address.rb +0 -124
  289. data/lib/ronin/arch.rb +0 -136
  290. data/lib/ronin/author.rb +0 -66
  291. data/lib/ronin/auto_load.rb +0 -91
  292. data/lib/ronin/bootstrap.rb +0 -27
  293. data/lib/ronin/campaign.rb +0 -129
  294. data/lib/ronin/credential.rb +0 -119
  295. data/lib/ronin/database/database.rb +0 -325
  296. data/lib/ronin/database/exceptions/unknown_repository.rb +0 -25
  297. data/lib/ronin/database/exceptions.rb +0 -21
  298. data/lib/ronin/database/migrations/1.0.0.rb +0 -569
  299. data/lib/ronin/database/migrations/1.1.0.rb +0 -125
  300. data/lib/ronin/database/migrations/exceptions/duplicate_migration.rb +0 -29
  301. data/lib/ronin/database/migrations/exceptions/unknown_migration.rb +0 -27
  302. data/lib/ronin/database/migrations/exceptions.rb +0 -21
  303. data/lib/ronin/database/migrations/graph.rb +0 -300
  304. data/lib/ronin/database/migrations/migration.rb +0 -66
  305. data/lib/ronin/database/migrations/migrations.rb +0 -185
  306. data/lib/ronin/database/migrations.rb +0 -22
  307. data/lib/ronin/database.rb +0 -21
  308. data/lib/ronin/email_address.rb +0 -257
  309. data/lib/ronin/environment.rb +0 -30
  310. data/lib/ronin/exceptions/duplicate_repository.rb +0 -23
  311. data/lib/ronin/exceptions/repository_not_found.rb +0 -23
  312. data/lib/ronin/exceptions.rb +0 -21
  313. data/lib/ronin/host_name.rb +0 -271
  314. data/lib/ronin/host_name_ip_address.rb +0 -45
  315. data/lib/ronin/installation.rb +0 -225
  316. data/lib/ronin/ip_address.rb +0 -348
  317. data/lib/ronin/ip_address_mac_address.rb +0 -45
  318. data/lib/ronin/license.rb +0 -121
  319. data/lib/ronin/mac_address.rb +0 -111
  320. data/lib/ronin/model/has_authors.rb +0 -111
  321. data/lib/ronin/model/has_description.rb +0 -73
  322. data/lib/ronin/model/has_license.rb +0 -129
  323. data/lib/ronin/model/has_name.rb +0 -91
  324. data/lib/ronin/model/has_title.rb +0 -71
  325. data/lib/ronin/model/has_unique_name.rb +0 -127
  326. data/lib/ronin/model/has_version.rb +0 -77
  327. data/lib/ronin/model/importable.rb +0 -65
  328. data/lib/ronin/model/model.rb +0 -165
  329. data/lib/ronin/model/types/description.rb +0 -60
  330. data/lib/ronin/model/types.rb +0 -20
  331. data/lib/ronin/model.rb +0 -20
  332. data/lib/ronin/open_port.rb +0 -112
  333. data/lib/ronin/organization.rb +0 -46
  334. data/lib/ronin/os.rb +0 -157
  335. data/lib/ronin/os_guess.rb +0 -45
  336. data/lib/ronin/password.rb +0 -165
  337. data/lib/ronin/port.rb +0 -126
  338. data/lib/ronin/repositories.rb +0 -23
  339. data/lib/ronin/repository.rb +0 -771
  340. data/lib/ronin/ronin.rb +0 -43
  341. data/lib/ronin/script/buildable.rb +0 -156
  342. data/lib/ronin/script/deployable.rb +0 -202
  343. data/lib/ronin/script/exceptions/deploy_failed.rb +0 -27
  344. data/lib/ronin/script/exceptions/exception.rb +0 -25
  345. data/lib/ronin/script/exceptions/not_built.rb +0 -27
  346. data/lib/ronin/script/exceptions/test_failed.rb +0 -27
  347. data/lib/ronin/script/exceptions.rb +0 -24
  348. data/lib/ronin/script/path.rb +0 -293
  349. data/lib/ronin/script/script.rb +0 -384
  350. data/lib/ronin/script/testable.rb +0 -365
  351. data/lib/ronin/script.rb +0 -21
  352. data/lib/ronin/service.rb +0 -39
  353. data/lib/ronin/service_credential.rb +0 -31
  354. data/lib/ronin/software.rb +0 -55
  355. data/lib/ronin/spec/database.rb +0 -56
  356. data/lib/ronin/target.rb +0 -66
  357. data/lib/ronin/tcp_port.rb +0 -36
  358. data/lib/ronin/udp_port.rb +0 -32
  359. data/lib/ronin/ui/cli/class_command.rb +0 -137
  360. data/lib/ronin/ui/cli/cli.rb +0 -148
  361. data/lib/ronin/ui/cli/command.rb +0 -649
  362. data/lib/ronin/ui/cli/commands/campaigns.rb +0 -165
  363. data/lib/ronin/ui/cli/commands/console.rb +0 -106
  364. data/lib/ronin/ui/cli/commands/creds.rb +0 -108
  365. data/lib/ronin/ui/cli/commands/database.rb +0 -204
  366. data/lib/ronin/ui/cli/commands/emails.rb +0 -86
  367. data/lib/ronin/ui/cli/commands/exec.rb +0 -127
  368. data/lib/ronin/ui/cli/commands/fuzzer.rb +0 -306
  369. data/lib/ronin/ui/cli/commands/help.rb +0 -87
  370. data/lib/ronin/ui/cli/commands/hosts.rb +0 -177
  371. data/lib/ronin/ui/cli/commands/install.rb +0 -136
  372. data/lib/ronin/ui/cli/commands/ips.rb +0 -178
  373. data/lib/ronin/ui/cli/commands/net/proxy.rb +0 -411
  374. data/lib/ronin/ui/cli/commands/repos.rb +0 -164
  375. data/lib/ronin/ui/cli/commands/uninstall.rb +0 -90
  376. data/lib/ronin/ui/cli/commands/update.rb +0 -125
  377. data/lib/ronin/ui/cli/commands/urls.rb +0 -141
  378. data/lib/ronin/ui/cli/commands/wordlist.rb +0 -181
  379. data/lib/ronin/ui/cli/exceptions/unknown_command.rb +0 -27
  380. data/lib/ronin/ui/cli/exceptions.rb +0 -20
  381. data/lib/ronin/ui/cli/model_command.rb +0 -182
  382. data/lib/ronin/ui/cli/printing.rb +0 -167
  383. data/lib/ronin/ui/cli/resources_command.rb +0 -117
  384. data/lib/ronin/ui/cli/script_command.rb +0 -212
  385. data/lib/ronin/ui/cli.rb +0 -21
  386. data/lib/ronin/ui/console/commands.rb +0 -86
  387. data/lib/ronin/ui/console/console.rb +0 -215
  388. data/lib/ronin/ui/console/context.rb +0 -106
  389. data/lib/ronin/ui/console/shell.rb +0 -184
  390. data/lib/ronin/ui/console.rb +0 -22
  391. data/lib/ronin/url.rb +0 -546
  392. data/lib/ronin/url_query_param.rb +0 -73
  393. data/lib/ronin/url_query_param_name.rb +0 -89
  394. data/lib/ronin/url_scheme.rb +0 -53
  395. data/lib/ronin/user_name.rb +0 -47
  396. data/lib/ronin/vendor.rb +0 -39
  397. data/lib/ronin/web_credential.rb +0 -76
  398. data/man/ronin-campaigns.1 +0 -105
  399. data/man/ronin-campaigns.1.md +0 -78
  400. data/man/ronin-console.1 +0 -96
  401. data/man/ronin-console.1.md +0 -72
  402. data/man/ronin-creds.1 +0 -89
  403. data/man/ronin-creds.1.md +0 -66
  404. data/man/ronin-database.1 +0 -111
  405. data/man/ronin-database.1.md +0 -82
  406. data/man/ronin-emails.1 +0 -97
  407. data/man/ronin-emails.1.md +0 -72
  408. data/man/ronin-exec.1 +0 -65
  409. data/man/ronin-exec.1.md +0 -49
  410. data/man/ronin-fuzzer.1 +0 -95
  411. data/man/ronin-fuzzer.1.md +0 -73
  412. data/man/ronin-hosts.1 +0 -105
  413. data/man/ronin-hosts.1.md +0 -78
  414. data/man/ronin-install.1 +0 -104
  415. data/man/ronin-install.1.md +0 -79
  416. data/man/ronin-ips.1 +0 -109
  417. data/man/ronin-ips.1.md +0 -81
  418. data/man/ronin-repos.1 +0 -102
  419. data/man/ronin-repos.1.md +0 -77
  420. data/man/ronin-uninstall.1 +0 -88
  421. data/man/ronin-uninstall.1.md +0 -67
  422. data/man/ronin-update.1 +0 -88
  423. data/man/ronin-update.1.md +0 -67
  424. data/man/ronin-urls.1 +0 -113
  425. data/man/ronin-urls.1.md +0 -84
  426. data/man/ronin-wordlist.1 +0 -71
  427. data/man/ronin-wordlist.1.md +0 -54
  428. data/spec/arch_spec.rb +0 -77
  429. data/spec/author_spec.rb +0 -26
  430. data/spec/campaign_spec.rb +0 -13
  431. data/spec/classes/my_script.rb +0 -21
  432. data/spec/credential_spec.rb +0 -29
  433. data/spec/database_spec.rb +0 -28
  434. data/spec/email_address_spec.rb +0 -83
  435. data/spec/helpers/repos/installed/ronin.yml +0 -7
  436. data/spec/helpers/repos/installed/scripts/.keep +0 -0
  437. data/spec/helpers/repos/local/lib/init.rb +0 -1
  438. data/spec/helpers/repos/local/lib/stuff/another_test.rb +0 -6
  439. data/spec/helpers/repos/local/lib/stuff/test.rb +0 -4
  440. data/spec/helpers/repos/local/ronin.yml +0 -7
  441. data/spec/helpers/repos/local/scripts/.keep +0 -0
  442. data/spec/helpers/repos/remote/ronin.yml +0 -7
  443. data/spec/helpers/repos/remote/scripts/.keep +0 -0
  444. data/spec/helpers/repos/scripts/ronin.yml +0 -7
  445. data/spec/helpers/repos/scripts/scripts/cached/cached.rb +0 -10
  446. data/spec/helpers/repos/scripts/scripts/cached/missing.rb +0 -10
  447. data/spec/helpers/repos/scripts/scripts/cached/modified.rb +0 -10
  448. data/spec/helpers/repos/scripts/scripts/cached/unmodified.rb +0 -10
  449. data/spec/helpers/repos/scripts/scripts/failures/exceptions.rb +0 -11
  450. data/spec/helpers/repos/scripts/scripts/failures/load_errors.rb +0 -11
  451. data/spec/helpers/repos/scripts/scripts/failures/name_errors.rb +0 -8
  452. data/spec/helpers/repos/scripts/scripts/failures/no_method_errors.rb +0 -10
  453. data/spec/helpers/repos/scripts/scripts/failures/syntax_errors.rb +0 -11
  454. data/spec/helpers/repos/scripts/scripts/failures/validation_errors.rb +0 -11
  455. data/spec/helpers/repos/scripts/scripts/my_scripts/test.rb +0 -16
  456. data/spec/helpers/repositories.rb +0 -11
  457. data/spec/host_name_spec.rb +0 -92
  458. data/spec/installation_spec.rb +0 -40
  459. data/spec/ip_address_spec.rb +0 -109
  460. data/spec/license_spec.rb +0 -25
  461. data/spec/mac_address_spec.rb +0 -47
  462. data/spec/model/has_authors_spec.rb +0 -79
  463. data/spec/model/has_description_spec.rb +0 -76
  464. data/spec/model/has_license_spec.rb +0 -73
  465. data/spec/model/has_name_spec.rb +0 -54
  466. data/spec/model/has_title_spec.rb +0 -42
  467. data/spec/model/has_version_spec.rb +0 -87
  468. data/spec/model/model_spec.rb +0 -98
  469. data/spec/model/models/authored_model.rb +0 -11
  470. data/spec/model/models/base_model.rb +0 -13
  471. data/spec/model/models/described_model.rb +0 -9
  472. data/spec/model/models/inherited_model.rb +0 -16
  473. data/spec/model/models/licensed_model.rb +0 -11
  474. data/spec/model/models/named_model.rb +0 -9
  475. data/spec/model/models/titled_model.rb +0 -9
  476. data/spec/model/models/versioned_model.rb +0 -11
  477. data/spec/os_spec.rb +0 -48
  478. data/spec/password_spec.rb +0 -47
  479. data/spec/port_spec.rb +0 -51
  480. data/spec/repository_spec.rb +0 -270
  481. data/spec/ronin_spec.rb +0 -25
  482. data/spec/script/buildable_spec.rb +0 -51
  483. data/spec/script/classes/buildable_class.rb +0 -15
  484. data/spec/script/classes/deployable_class.rb +0 -13
  485. data/spec/script/classes/script_class.rb +0 -19
  486. data/spec/script/classes/testable_class.rb +0 -19
  487. data/spec/script/deployable_spec.rb +0 -55
  488. data/spec/script/path_spec.rb +0 -185
  489. data/spec/script/script_spec.rb +0 -128
  490. data/spec/script/testable_spec.rb +0 -117
  491. data/spec/service_spec.rb +0 -24
  492. data/spec/software_spec.rb +0 -46
  493. data/spec/ui/cli/classes/test_command.rb +0 -26
  494. data/spec/ui/cli/cli_spec.rb +0 -34
  495. data/spec/ui/cli/command_spec.rb +0 -291
  496. data/spec/url_query_param_spec.rb +0 -41
  497. data/spec/url_scheme_spec.rb +0 -21
  498. data/spec/url_spec.rb +0 -179
  499. data/spec/vendor_spec.rb +0 -25
@@ -0,0 +1,285 @@
1
+ # frozen_string_literal: true
2
+ #
3
+ # Copyright (c) 2006-2023 Hal Brodigan (postmodern.mod3 at gmail.com)
4
+ #
5
+ # Ronin is free software: you can redistribute it and/or modify
6
+ # it under the terms of the GNU General Public License as published by
7
+ # the Free Software Foundation, either version 3 of the License, or
8
+ # (at your option) any later version.
9
+ #
10
+ # Ronin is distributed in the hope that it will be useful,
11
+ # but WITHOUT ANY WARRANTY; without even the implied warranty of
12
+ # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
+ # GNU General Public License for more details.
14
+ #
15
+ # You should have received a copy of the GNU General Public License
16
+ # along with Ronin. If not, see <https://www.gnu.org/licenses/>.
17
+ #
18
+
19
+ require 'ronin/cli/value_processor_command'
20
+ require 'ronin/support/crypto/cert'
21
+ require 'ronin/support/network/ssl/mixin'
22
+
23
+ require 'command_kit/printing/indent'
24
+ require 'command_kit/printing/fields'
25
+ require 'command_kit/printing/lists'
26
+
27
+ require 'uri'
28
+
29
+ module Ronin
30
+ class CLI
31
+ module Commands
32
+ #
33
+ # Prints information for SSL/TLS certificates.
34
+ #
35
+ # ## Usage
36
+ #
37
+ # ronin cert-dump [options] {HOST:PORT | URL | FILE} ...
38
+ #
39
+ # ## Options
40
+ #
41
+ # -f, --file FILE Optional file to read values from
42
+ # -C, --common-name Only prints the Common Name (CN)
43
+ # -A, --subject-alt-names Only prints the subjectAltNames
44
+ # -E, --extensions Print all certificate extensions
45
+ # -h, --help Print help information
46
+ #
47
+ # ## Arguments
48
+ #
49
+ # HOST:PORT | URL | FILE ... A HOST:PORT, URL, or cert FILE
50
+ #
51
+ # ## Examples
52
+ #
53
+ # ronin cert-dump ssl.crt
54
+ # ronin cert-dump github.com:443
55
+ # ronin cert-dump https://github.com/
56
+ # ronin cert-dump -C 93.184.216.34:443
57
+ # ronin cert-dump -A wired.com:443
58
+ #
59
+ class CertDump < ValueProcessorCommand
60
+
61
+ include Support::Network::SSL::Mixin
62
+ include CommandKit::Printing::Indent
63
+ include CommandKit::Printing::Fields
64
+ include CommandKit::Printing::Lists
65
+
66
+ usage '[options] {HOST:PORT | URL | FILE} ...'
67
+
68
+ option :common_name, short: '-C',
69
+ desc: 'Only prints the Common Name (CN)'
70
+
71
+ option :subject_alt_names, short: '-A',
72
+ desc: 'Only prints the subjectAltNames'
73
+
74
+ option :extensions, short: '-E',
75
+ desc: 'Print all certificate extensions'
76
+
77
+ argument :target, required: true,
78
+ repeats: true,
79
+ usage: 'HOST:PORT | URL | FILE',
80
+ desc: 'A HOST:PORT, URL, or cert FILE'
81
+
82
+ description "Prints SSL/TLS certificate information"
83
+
84
+ examples [
85
+ 'ssl.crt',
86
+ 'github.com:443',
87
+ 'https://github.com/',
88
+ '-C 93.184.216.34:443',
89
+ '-A wired.com:443'
90
+ ]
91
+
92
+ man_page 'ronin-cert-dump.1'
93
+
94
+ #
95
+ # Runs the `ronin cert-dump` command.
96
+ #
97
+ # @param [String] value
98
+ # The `HOST:PORT`, `URL`, or `FILE` value to process.
99
+ #
100
+ def process_value(value)
101
+ case value
102
+ when /\A[^:]+:\d+\z/
103
+ host, port = value.split(':',2)
104
+ port = port.to_i
105
+
106
+ print_cert(ssl_cert(host,port))
107
+ when /\Ahttps:/
108
+ uri = URI.parse(value)
109
+ host = uri.host
110
+ port = uri.port
111
+
112
+ print_cert(ssl_cert(host,port))
113
+ else
114
+ unless File.file?(value)
115
+ print_error "no such file or directory: #{value}"
116
+ exit(1)
117
+ end
118
+
119
+ cert = Support::Crypto::Cert.load_file(value)
120
+
121
+ print_cert(cert)
122
+ end
123
+ end
124
+
125
+ #
126
+ # Prints the certificate.
127
+ #
128
+ # @param [Ronin::Support::Crypto::Cert] cert
129
+ #
130
+ def print_cert(cert)
131
+ if options[:common_name]
132
+ puts "#{cert.common_name}"
133
+ elsif options[:subject_alt_names]
134
+ if (alt_names = cert.subject_alt_names)
135
+ alt_names.each { |name| puts name }
136
+ end
137
+ else
138
+ print_full_cert(cert)
139
+ end
140
+ end
141
+
142
+ #
143
+ # Prints the full verbose information about the certificate.
144
+ #
145
+ # @param [Ronin::Support::Crypto::Cert] cert
146
+ #
147
+ def print_full_cert(cert)
148
+ fields = {}
149
+
150
+ fields["Serial"] = cert.serial
151
+ fields["Version"] = cert.version
152
+ fields["Not Before"] = cert.not_before if cert.not_before
153
+ fields["Not After"] = cert.not_after if cert.not_after
154
+ print_fields(fields)
155
+ puts
156
+
157
+ print_public_key(cert.public_key)
158
+ puts
159
+
160
+ puts "Subject:"
161
+ indent do
162
+ print_cert_name(cert.subject)
163
+
164
+ if (alt_names = cert.subject_alt_names)
165
+ puts "Alt Names:"
166
+ puts
167
+
168
+ indent do
169
+ alt_names.each { |name| puts name }
170
+ end
171
+ end
172
+ end
173
+
174
+ puts
175
+
176
+ puts "Issuer:"
177
+ indent do
178
+ print_cert_name(cert.issuer)
179
+ end
180
+
181
+ puts
182
+
183
+ fields = {}
184
+
185
+ if options[:extensions]
186
+ puts "Extensions:"
187
+ indent do
188
+ print_extensions(cert)
189
+ end
190
+ end
191
+ end
192
+
193
+ #
194
+ # Prints the public key.
195
+ #
196
+ # @param [OpenSSL::PKey::RSA, OpenSSL::PKey::EC] public_key
197
+ #
198
+ def print_public_key(public_key)
199
+ puts "Public Key:"
200
+
201
+ indent do
202
+ fields = {}
203
+
204
+ case public_key
205
+ when OpenSSL::PKey::RSA
206
+ fields['Type'] = 'RSA'
207
+ when OpenSSL::PKey::EC
208
+ fields['Type'] = 'EC'
209
+ end
210
+
211
+ print_fields(fields)
212
+
213
+ public_key.to_text.each_line do |line|
214
+ puts line
215
+ end
216
+ end
217
+ end
218
+
219
+ #
220
+ # Prints the X509 name.
221
+ #
222
+ # @param [Ronin::Support::Crypto::Cert::Name] name
223
+ #
224
+ def print_cert_name(name)
225
+ fields = {}
226
+
227
+ if name.common_name
228
+ fields["Common Name"] = name.common_name
229
+ end
230
+
231
+ if name.organization
232
+ fields["Organization"] = name.organization
233
+ end
234
+
235
+ if name.organizational_unit
236
+ fields["Organizational Unit"] = name.organizational_unit
237
+ end
238
+
239
+ if name.locality
240
+ fields["Locality"] = name.locality
241
+ end
242
+
243
+ if name.state
244
+ fields["State"] = name.state
245
+ end
246
+
247
+ if name.country
248
+ fields["Country"] = name.country
249
+ end
250
+
251
+ print_fields(fields)
252
+ end
253
+
254
+ #
255
+ # Prints the certificates extensions.
256
+ #
257
+ # @param [Ronin::Support::Crypto::Cert] cert
258
+ #
259
+ def print_extensions(cert)
260
+ cert.extensions.each_with_index do |ext,index|
261
+ puts if index > 0
262
+
263
+ print_extension(ext)
264
+ end
265
+ end
266
+
267
+ #
268
+ # Prints a certificate extension.
269
+ #
270
+ # @param [OpenSSL::X509::Extension] ext
271
+ #
272
+ def print_extension(ext)
273
+ puts "#{ext.oid}:"
274
+
275
+ indent do
276
+ ext.value.each_line do |line|
277
+ puts line
278
+ end
279
+ end
280
+ end
281
+
282
+ end
283
+ end
284
+ end
285
+ end
@@ -0,0 +1,395 @@
1
+ # frozen_string_literal: true
2
+ #
3
+ # Copyright (c) 2006-2023 Hal Brodigan (postmodern.mod3 at gmail.com)
4
+ #
5
+ # Ronin is free software: you can redistribute it and/or modify
6
+ # it under the terms of the GNU General Public License as published by
7
+ # the Free Software Foundation, either version 3 of the License, or
8
+ # (at your option) any later version.
9
+ #
10
+ # Ronin is distributed in the hope that it will be useful,
11
+ # but WITHOUT ANY WARRANTY; without even the implied warranty of
12
+ # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
+ # GNU General Public License for more details.
14
+ #
15
+ # You should have received a copy of the GNU General Public License
16
+ # along with Ronin. If not, see <https://www.gnu.org/licenses/>.
17
+ #
18
+
19
+ require 'ronin/cli/command'
20
+ require 'ronin/support/crypto/cert'
21
+ require 'ronin/support/text/patterns'
22
+
23
+ require 'ronin/core/cli/logging'
24
+
25
+ module Ronin
26
+ class CLI
27
+ module Commands
28
+ #
29
+ # Generates a new X509 certificate.
30
+ #
31
+ # ## Usage
32
+ #
33
+ # ronin cert-gen [options]
34
+ #
35
+ # ## Options
36
+ #
37
+ # --version NUM The certificate version number (Default: 2)
38
+ # --serial NUM The certificate serial number (Default: 0)
39
+ # --not-before TIME When the certificate becomes valid. Defaults to the current time.
40
+ # --not-after TIME When the certificate becomes no longer valid. Defaults to one year from now.
41
+ # -c, --common-name DOMAIN The Common Name (CN) for the certificate
42
+ # -A, --subject-alt-name HOST|IP Adds HOST or IP to subjectAltName
43
+ # -O, --organization NAME The Organization (O) for the certificate
44
+ # -U, --organizational-unit NAME The Organizational Unit (OU)
45
+ # -L, --locality NAME The locality for the certificate
46
+ # -S, --state XX The two-letter State (ST) code for the certificate
47
+ # -C, --country XX The two-letter Country (C) code for the certificate
48
+ # -t, --key-type rsa|ec The signing key type
49
+ # --generate-key PATH Generates and saves a random key (Default: key.pem)
50
+ # -k, --key-file FILE Loads the signing key from the FILE
51
+ # -H sha256|sha1|md5, The hash algorithm to use for signing (Default: sha256)
52
+ # --signing-hash
53
+ # --ca-key FILE The Certificate Authority (CA) key
54
+ # --ca-cert FILE The Certificate Authority (CA) certificate
55
+ # --ca Generates a CA certificate
56
+ # -o, --output FILE The output file (Default: cert.crt)
57
+ # -h, --help Print help information
58
+ #
59
+ # ### Examples
60
+ #
61
+ # ronin cert_gen -c test.com -O "Test Co" -U "Test Dept" -L "Test City" -S NY -C US
62
+ # ronin cert_gen -c test.com -O "Test Co" -U "Test Dept" -L "Test City" -S NY -C US --key-file private.key
63
+ # ronin cert_gen -c test.com -A www.test.com -O "Test Co" -U "Test Dept" -L "Test City" -S NY -C US
64
+ # ronin cert_gen --ca -c "Test CA" -O "Test Co" -U "Test Dept" -L "Test City" -S NY -C US
65
+ # ronin cert_gen -c test.com -O "Test Co" -U "Test Dept" -L "Test City" -S NY -C US --ca-key ca.key --ca-cert ca.crt
66
+ #
67
+ class CertGen < Command
68
+
69
+ include Core::CLI::Logging
70
+
71
+ option :version, value: {
72
+ type: Integer,
73
+ usage: 'NUM',
74
+ default: 2
75
+ },
76
+ desc: 'The certificate version number'
77
+
78
+ option :serial, value: {
79
+ type: Integer,
80
+ usage: 'NUM',
81
+ default: 0
82
+ },
83
+ desc: 'The certificate serial number'
84
+
85
+ option :not_before, value: {
86
+ type: String,
87
+ usage: 'TIME'
88
+ },
89
+ desc: 'When the certificate becomes valid. Defaults to the current time.'
90
+
91
+ option :not_after, value: {
92
+ type: String,
93
+ usage: 'TIME'
94
+ },
95
+ desc: 'When the certificate becomes no longer valid. Defaults to one year from now.'
96
+
97
+ option :common_name, short: '-c',
98
+ value: {
99
+ type: String,
100
+ usage: 'DOMAIN'
101
+ },
102
+ desc: 'The Common Name (CN) for the certificate'
103
+
104
+ option :subject_alt_name, short: '-A',
105
+ value: {
106
+ type: /[a-z0-9:\._-]+/,
107
+ usage: 'HOST|IP'
108
+ },
109
+ desc: 'Adds HOST or IP to subjectAltName' do |value|
110
+ @subject_alt_names << value
111
+ end
112
+
113
+ option :organization, short: '-O',
114
+ value: {
115
+ type: String,
116
+ usage: 'NAME'
117
+ },
118
+ desc: 'The Organization (O) for the certificate'
119
+
120
+ option :organizational_unit, short: '-U',
121
+ value: {
122
+ type: String,
123
+ usage: 'NAME'
124
+ },
125
+ desc: 'The Organizational Unit (OU)'
126
+
127
+ option :locality, short: '-L',
128
+ value: {
129
+ type: String,
130
+ usage: 'NAME'
131
+ },
132
+ desc: 'The locality for the certificate'
133
+
134
+ option :state, short: '-S',
135
+ value: {
136
+ type: String,
137
+ usage: 'XX'
138
+ },
139
+ desc: 'The two-letter State (ST) code for the certificate'
140
+
141
+ option :country, short: '-C',
142
+ value: {
143
+ type: String,
144
+ usage: 'XX'
145
+ },
146
+ desc: 'The two-letter Country (C) code for the certificate'
147
+
148
+ option :key_type, short: '-t',
149
+ value: {
150
+ type: [:rsa, :ec]
151
+ },
152
+ desc: 'The signing key type'
153
+
154
+ option :generate_key, value: {
155
+ type: String,
156
+ usage: 'PATH',
157
+ default: 'key.pem'
158
+ },
159
+ desc: 'Generates and saves a random key'
160
+
161
+ option :key_file, short: '-k',
162
+ value: {
163
+ type: String,
164
+ usage: 'FILE'
165
+ },
166
+ desc: 'Loads the signing key from the FILE'
167
+
168
+ option :signing_hash, short: '-H',
169
+ value: {
170
+ type: [:sha256, :sha1, :md5],
171
+ default: :sha256
172
+ },
173
+ desc: 'The hash algorithm to use for signing'
174
+
175
+ option :ca_key, value: {
176
+ type: String,
177
+ usage: 'FILE'
178
+ },
179
+ desc: 'The Certificate Authority (CA) key'
180
+
181
+ option :ca_cert, value: {
182
+ type: String,
183
+ usage: 'FILE'
184
+ },
185
+ desc: 'The Certificate Authority (CA) certificate'
186
+
187
+ option :ca, desc: 'Generates a CA certificate'
188
+
189
+ option :output, short: '-o',
190
+ value: {
191
+ type: String,
192
+ usage: 'FILE',
193
+ default: 'cert.crt'
194
+ },
195
+ desc: 'The output file'
196
+
197
+ examples [
198
+ '-c test.com -O "Test Co" -U "Test Dept" -L "Test City" -S NY -C US',
199
+ '-c test.com -O "Test Co" -U "Test Dept" -L "Test City" -S NY -C US --key-file private.key',
200
+ '-c test.com -A www.test.com -O "Test Co" -U "Test Dept" -L "Test City" -S NY -C US',
201
+ '--ca -c "Test CA" -O "Test Co" -U "Test Dept" -L "Test City" -S NY -C US',
202
+ '-c test.com -O "Test Co" -U "Test Dept" -L "Test City" -S NY -C US --ca-key ca.key --ca-cert ca.crt'
203
+ ]
204
+
205
+ description 'Generates a new X509 certificate'
206
+
207
+ man_page 'ronin-cert-gen.1'
208
+
209
+ #
210
+ # Initializes the `ronin cert-gen` command.
211
+ #
212
+ # @param [Hash{Symbol => Object}] kwargs
213
+ # Additional keyword arguments.
214
+ #
215
+ def initialize(**kwargs)
216
+ super(**kwargs)
217
+
218
+ @subject_alt_names = []
219
+ end
220
+
221
+ #
222
+ # Runs the `ronin cert-gen` command.
223
+ #
224
+ def run
225
+ if options[:generate_key]
226
+ log_info "Generating new #{options.fetch(:key_type,:rsa).upcase} key ..."
227
+ end
228
+
229
+ key = signing_key
230
+ cert = Ronin::Support::Crypto::Cert.generate(
231
+ version: options[:version],
232
+ serial: options[:serial],
233
+ not_before: not_before,
234
+ not_after: not_after,
235
+ key: key,
236
+ ca_key: ca_key,
237
+ ca_cert: ca_cert,
238
+ subject: {
239
+ common_name: options[:common_name],
240
+ organization: options[:organization],
241
+ organizational_unit: options[:organizational_unit],
242
+ locality: options[:locality],
243
+ state: options[:state],
244
+ country: options[:country]
245
+ },
246
+ extensions: extensions
247
+ )
248
+
249
+ if options[:generate_key]
250
+ log_info "Saving key to #{options[:generate_key]} ..."
251
+ key.save(options[:generate_key])
252
+ end
253
+
254
+ log_info "Saving certificate to #{options[:output]} ..."
255
+ cert.save(options[:output])
256
+ end
257
+
258
+ #
259
+ # The parsed `--not-before` time or now.
260
+ #
261
+ # @return [Time]
262
+ #
263
+ def not_before
264
+ @not_before ||= if options[:not_before]
265
+ Time.parse(options[:not_before])
266
+ else
267
+ Time.now
268
+ end
269
+ end
270
+
271
+ #
272
+ # The parsed `--not-after` time or one year from now.
273
+ #
274
+ # @return [Time]
275
+ #
276
+ def not_after
277
+ @not_after ||= if options[:not_after]
278
+ Time.parse(options[:not_after])
279
+ else
280
+ not_before+Support::Crypto::Cert::ONE_YEAR
281
+ end
282
+ end
283
+
284
+ #
285
+ # The `--key-type` key class.
286
+ #
287
+ # @return [Class<Ronin::Support::Key::RSA>,
288
+ # Class<Ronin::Support::Key::EC>, nil]
289
+ #
290
+ def key_class
291
+ case options[:key_type]
292
+ when :rsa then Support::Crypto::Key::RSA
293
+ when :ec then Support::Crypto::Key::EC
294
+ end
295
+ end
296
+
297
+ #
298
+ # Loads the `--key-file` key file or generates a new signing key.
299
+ #
300
+ # @return [Ronin::Support::Key::RSA, Ronin::Support::Key::EC, nil]
301
+ #
302
+ def signing_key
303
+ if options[:key_file]
304
+ if options[:key_type]
305
+ key_class.load_file(options[:key_file])
306
+ else
307
+ begin
308
+ Support::Crypto::Key.load_file(options[:key_file])
309
+ rescue ArgumentError => error
310
+ print_error(error.message)
311
+ exit(-1)
312
+ end
313
+ end
314
+ else
315
+ (key_class || Support::Crypto::Key::RSA).random
316
+ end
317
+ end
318
+
319
+ #
320
+ # Loads the `--ca-key` key file.
321
+ #
322
+ # @return [Ronin::Support::Key::RSA, nil]
323
+ #
324
+ def ca_key
325
+ if options[:ca_key]
326
+ Support::Crypto::Key::RSA.load_file(options[:ca_key])
327
+ end
328
+ end
329
+
330
+ #
331
+ # Loads the `--ca-cert` certificate file.
332
+ #
333
+ # @return [Ronin::Support::Crypto::Cert, nil]
334
+ #
335
+ def ca_cert
336
+ if options[:ca_cert]
337
+ Support::Crypto::Cert.load_file(options[:ca_cert])
338
+ end
339
+ end
340
+
341
+ #
342
+ # Builds the extensions.
343
+ #
344
+ # @return [Hash{String => Object}, nil]
345
+ #
346
+ def extensions
347
+ exts = {}
348
+
349
+ if (ext = basic_constraints_ext)
350
+ exts['basicConstraints'] = ext
351
+ end
352
+
353
+ if (ext = subject_alt_name_ext)
354
+ exts['subjectAltName'] = ext
355
+ end
356
+
357
+ exts unless exts.empty?
358
+ end
359
+
360
+ #
361
+ # Builds the `basicConstraints` extension.
362
+ #
363
+ # @return [(String, Boolean), nil]
364
+ #
365
+ def basic_constraints_ext
366
+ if options[:ca]
367
+ ['CA:TRUE', true]
368
+ elsif options[:ca_key] || options[:ca_cert]
369
+ ['CA:FALSE', true]
370
+ end
371
+ end
372
+
373
+ IP_REGEXP = Support::Text::Patterns::IP
374
+
375
+ #
376
+ # Builds the `subjectAltName` extension.
377
+ #
378
+ # @return [String, nil]
379
+ #
380
+ def subject_alt_name_ext
381
+ if !@subject_alt_names.empty?
382
+ @subject_alt_names.map { |name|
383
+ if name =~ IP_REGEXP
384
+ "IP: #{name}"
385
+ else
386
+ "DNS: #{name}"
387
+ end
388
+ }.join(', ')
389
+ end
390
+ end
391
+
392
+ end
393
+ end
394
+ end
395
+ end