ronin-support 0.5.2 → 1.0.0.beta1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (505) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/ruby.yml +5 -6
  3. data/.gitignore +7 -6
  4. data/.mailmap +1 -0
  5. data/.ruby-version +1 -1
  6. data/.yardopts +0 -1
  7. data/ChangeLog.md +516 -148
  8. data/Gemfile +17 -16
  9. data/README.md +105 -50
  10. data/Rakefile +28 -8
  11. data/data/text/homoglyphs/ascii.txt +8 -0
  12. data/data/text/homoglyphs/cyrillic.txt +33 -0
  13. data/data/text/homoglyphs/full_width.txt +81 -0
  14. data/data/text/homoglyphs/greek.txt +21 -0
  15. data/data/text/homoglyphs/latin_numbers.txt +14 -0
  16. data/data/text/homoglyphs/punctuation.txt +7 -0
  17. data/data/text/patterns/network/public_suffix.rb.erb +44 -0
  18. data/examples/ssl_proxy.rb +38 -0
  19. data/examples/tcp_proxy.rb +41 -0
  20. data/gemspec.yml +14 -13
  21. data/lib/ronin/support/archive/core_ext/file.rb +118 -0
  22. data/lib/ronin/{formatting/sql.rb → support/archive/core_ext.rb} +3 -4
  23. data/lib/ronin/support/archive/mixin.rb +213 -0
  24. data/lib/ronin/support/archive/tar/reader.rb +135 -0
  25. data/lib/ronin/support/archive/tar/writer.rb +197 -0
  26. data/lib/ronin/support/archive/tar.rb +155 -0
  27. data/lib/ronin/support/archive/zip/reader/entry.rb +134 -0
  28. data/lib/ronin/support/archive/zip/reader/statistics.rb +76 -0
  29. data/lib/ronin/support/archive/zip/reader.rb +273 -0
  30. data/lib/ronin/support/archive/zip/writer.rb +175 -0
  31. data/lib/ronin/support/archive/zip.rb +105 -0
  32. data/lib/ronin/support/archive.rb +211 -0
  33. data/lib/ronin/support/binary/array.rb +255 -0
  34. data/lib/ronin/support/binary/bit_flip.rb +147 -0
  35. data/lib/ronin/support/binary/buffer.rb +2027 -0
  36. data/lib/ronin/support/binary/byte_slice.rb +324 -0
  37. data/lib/ronin/{formatting/extensions/binary → support/binary/core_ext}/array.rb +25 -11
  38. data/lib/ronin/support/binary/core_ext/float.rb +80 -0
  39. data/lib/ronin/support/binary/core_ext/integer.rb +305 -0
  40. data/lib/ronin/support/binary/core_ext/io.rb +38 -0
  41. data/lib/ronin/support/binary/core_ext/string.rb +115 -0
  42. data/lib/ronin/{formatting/extensions/text.rb → support/binary/core_ext.rb} +6 -6
  43. data/lib/ronin/support/binary/cstring.rb +259 -0
  44. data/lib/ronin/support/binary/ctypes/aggregate_type.rb +98 -0
  45. data/lib/ronin/support/binary/ctypes/arch/arm/big_endian.rb +77 -0
  46. data/lib/ronin/support/binary/ctypes/arch/arm.rb +75 -0
  47. data/lib/ronin/support/binary/ctypes/arch/arm64/big_endian.rb +77 -0
  48. data/lib/ronin/support/binary/ctypes/arch/arm64.rb +75 -0
  49. data/lib/ronin/support/binary/ctypes/arch/mips/little_endian.rb +77 -0
  50. data/lib/ronin/support/binary/ctypes/arch/mips.rb +75 -0
  51. data/lib/ronin/support/binary/ctypes/arch/mips64/little_endian.rb +77 -0
  52. data/lib/ronin/support/binary/ctypes/arch/mips64.rb +75 -0
  53. data/lib/ronin/support/binary/ctypes/arch/ppc.rb +75 -0
  54. data/lib/ronin/support/binary/ctypes/arch/ppc64.rb +75 -0
  55. data/lib/ronin/support/binary/ctypes/arch/x86.rb +75 -0
  56. data/lib/ronin/support/binary/ctypes/arch/x86_64.rb +75 -0
  57. data/lib/ronin/support/binary/ctypes/arch.rb +30 -0
  58. data/lib/ronin/support/binary/ctypes/array_object_type.rb +164 -0
  59. data/lib/ronin/support/binary/ctypes/array_type.rb +232 -0
  60. data/lib/ronin/support/binary/ctypes/big_endian.rb +195 -0
  61. data/lib/ronin/support/binary/ctypes/char_type.rb +59 -0
  62. data/lib/ronin/support/binary/ctypes/char_types.rb +39 -0
  63. data/lib/ronin/support/binary/ctypes/enum_type.rb +181 -0
  64. data/lib/ronin/support/binary/ctypes/float32_type.rb +50 -0
  65. data/lib/ronin/support/binary/ctypes/float64_type.rb +50 -0
  66. data/lib/ronin/support/binary/ctypes/float_type.rb +62 -0
  67. data/lib/ronin/support/binary/ctypes/int16_type.rb +50 -0
  68. data/lib/ronin/support/binary/ctypes/int32_type.rb +50 -0
  69. data/lib/ronin/support/binary/ctypes/int64_type.rb +50 -0
  70. data/lib/ronin/support/{support.rb → binary/ctypes/int8_type.rb} +20 -21
  71. data/lib/ronin/support/binary/ctypes/int_type.rb +62 -0
  72. data/lib/ronin/support/binary/ctypes/little_endian.rb +195 -0
  73. data/lib/ronin/support/binary/ctypes/mixin.rb +135 -0
  74. data/lib/ronin/support/binary/ctypes/native.rb +205 -0
  75. data/lib/ronin/support/binary/ctypes/network.rb +29 -0
  76. data/lib/ronin/support/binary/ctypes/object_type.rb +55 -0
  77. data/lib/ronin/support/binary/ctypes/os/bsd.rb +65 -0
  78. data/lib/ronin/support/binary/ctypes/os/freebsd.rb +215 -0
  79. data/lib/ronin/support/binary/ctypes/os/linux.rb +193 -0
  80. data/lib/ronin/support/binary/ctypes/os/macos.rb +151 -0
  81. data/lib/ronin/support/binary/ctypes/os/netbsd.rb +147 -0
  82. data/lib/ronin/support/binary/ctypes/os/openbsd.rb +168 -0
  83. data/lib/ronin/support/binary/ctypes/os/unix.rb +78 -0
  84. data/lib/ronin/support/binary/ctypes/os/windows.rb +125 -0
  85. data/lib/ronin/support/binary/ctypes/os.rb +125 -0
  86. data/lib/ronin/support/binary/ctypes/scalar_type.rb +200 -0
  87. data/lib/ronin/support/binary/ctypes/string_type.rb +143 -0
  88. data/lib/ronin/support/binary/ctypes/struct_object_type.rb +173 -0
  89. data/lib/ronin/support/binary/ctypes/struct_type.rb +359 -0
  90. data/lib/ronin/support/binary/ctypes/type.rb +193 -0
  91. data/lib/ronin/support/binary/ctypes/type_resolver.rb +206 -0
  92. data/lib/ronin/support/binary/ctypes/uint16_type.rb +50 -0
  93. data/lib/ronin/support/binary/ctypes/uint32_type.rb +50 -0
  94. data/lib/ronin/support/binary/ctypes/uint64_type.rb +50 -0
  95. data/lib/ronin/support/binary/ctypes/uint8_type.rb +41 -0
  96. data/lib/ronin/support/binary/ctypes/uint_type.rb +59 -0
  97. data/lib/ronin/support/binary/ctypes/unbounded_array_type.rb +258 -0
  98. data/lib/ronin/support/binary/ctypes/union_object_type.rb +173 -0
  99. data/lib/ronin/support/binary/ctypes/union_type.rb +261 -0
  100. data/lib/ronin/support/binary/ctypes.rb +462 -0
  101. data/lib/ronin/support/binary/hexdump/core_ext/file.rb +118 -0
  102. data/lib/ronin/support/binary/hexdump/core_ext/string.rb +115 -0
  103. data/lib/ronin/support/binary/hexdump/core_ext.rb +20 -0
  104. data/lib/ronin/support/binary/hexdump/parser.rb +492 -0
  105. data/lib/ronin/support/binary/hexdump.rb +20 -0
  106. data/lib/ronin/support/binary/memory.rb +268 -0
  107. data/lib/ronin/support/binary/packet.rb +33 -0
  108. data/lib/ronin/support/binary/stack.rb +256 -0
  109. data/lib/ronin/support/binary/stream/methods.rb +1755 -0
  110. data/lib/ronin/support/binary/stream.rb +151 -0
  111. data/lib/ronin/support/binary/struct/member.rb +86 -0
  112. data/lib/ronin/support/binary/struct.rb +830 -0
  113. data/lib/ronin/support/binary/template.rb +284 -0
  114. data/lib/ronin/support/binary/union.rb +162 -0
  115. data/lib/ronin/{formatting/extensions → support}/binary.rb +10 -10
  116. data/lib/ronin/support/cli/ansi.rb +330 -0
  117. data/lib/ronin/support/cli/io_shell/core_ext/io.rb +67 -0
  118. data/lib/ronin/{extensions/meta.rb → support/cli/io_shell/core_ext.rb} +3 -4
  119. data/lib/ronin/support/cli/io_shell.rb +161 -0
  120. data/lib/ronin/support/cli/printing.rb +216 -0
  121. data/lib/ronin/support/cli.rb +20 -0
  122. data/lib/ronin/support/compression/core_ext/file.rb +70 -0
  123. data/lib/ronin/support/compression/core_ext/string.rb +101 -0
  124. data/lib/ronin/{fuzzing/extensions.rb → support/compression/core_ext.rb} +3 -4
  125. data/lib/ronin/support/compression/gzip/reader.rb +70 -0
  126. data/lib/ronin/support/compression/gzip/writer.rb +74 -0
  127. data/lib/ronin/support/compression/gzip.rb +105 -0
  128. data/lib/ronin/support/compression/mixin.rb +180 -0
  129. data/lib/ronin/{network/extensions/esmtp/net.rb → support/compression/zlib.rb} +6 -7
  130. data/lib/ronin/support/compression.rb +174 -0
  131. data/lib/ronin/{extensions → support/core_ext}/enumerable.rb +2 -3
  132. data/lib/ronin/{extensions → support/core_ext}/file.rb +2 -31
  133. data/lib/ronin/support/core_ext/integer.rb +37 -0
  134. data/lib/ronin/support/core_ext/ipaddr.rb +65 -0
  135. data/lib/ronin/{extensions → support/core_ext}/kernel.rb +7 -6
  136. data/lib/ronin/{extensions → support/core_ext}/resolv.rb +2 -25
  137. data/lib/ronin/{extensions → support/core_ext}/string.rb +114 -54
  138. data/lib/ronin/support/core_ext.rb +33 -0
  139. data/lib/ronin/support/crypto/cert.rb +522 -0
  140. data/lib/ronin/support/crypto/cert_chain.rb +204 -0
  141. data/lib/ronin/support/crypto/cipher/aes.rb +71 -0
  142. data/lib/ronin/support/crypto/cipher/aes128.rb +54 -0
  143. data/lib/ronin/support/crypto/cipher/aes256.rb +54 -0
  144. data/lib/ronin/support/crypto/cipher.rb +194 -0
  145. data/lib/ronin/support/crypto/core_ext/file.rb +660 -0
  146. data/lib/ronin/support/crypto/core_ext/string.rb +548 -0
  147. data/lib/ronin/{binary.rb → support/crypto/core_ext.rb} +4 -5
  148. data/lib/ronin/{network/mixins/mixin.rb → support/crypto/hmac.rb} +18 -28
  149. data/lib/ronin/support/crypto/key/dh.rb +122 -0
  150. data/lib/ronin/support/crypto/key/dsa.rb +103 -0
  151. data/lib/ronin/support/crypto/key/ec.rb +99 -0
  152. data/lib/ronin/support/crypto/key/methods.rb +163 -0
  153. data/lib/ronin/support/crypto/key/rsa.rb +169 -0
  154. data/lib/ronin/support/crypto/key.rb +105 -0
  155. data/lib/ronin/support/crypto/mixin.rb +620 -0
  156. data/lib/ronin/{network/extensions/http/net.rb → support/crypto/openssl.rb} +6 -7
  157. data/lib/ronin/support/crypto.rb +779 -0
  158. data/lib/ronin/support/encoding/base16/core_ext/string.rb +63 -0
  159. data/lib/ronin/{formatting/binary.rb → support/encoding/base16/core_ext.rb} +3 -4
  160. data/lib/ronin/support/encoding/base16.rb +82 -0
  161. data/lib/ronin/support/encoding/base32/core_ext/string.rb +63 -0
  162. data/lib/ronin/support/encoding/base32/core_ext.rb +19 -0
  163. data/lib/ronin/support/encoding/base32.rb +164 -0
  164. data/lib/ronin/support/encoding/base64/core_ext/string.rb +76 -0
  165. data/lib/ronin/support/encoding/base64/core_ext.rb +19 -0
  166. data/lib/ronin/support/encoding/base64.rb +78 -0
  167. data/lib/ronin/support/encoding/c/core_ext/integer.rb +82 -0
  168. data/lib/ronin/support/encoding/c/core_ext/string.rb +125 -0
  169. data/lib/ronin/support/encoding/c/core_ext.rb +20 -0
  170. data/lib/ronin/support/encoding/c.rb +277 -0
  171. data/lib/ronin/support/encoding/core_ext/string.rb +107 -0
  172. data/lib/ronin/support/encoding/core_ext.rb +33 -0
  173. data/lib/ronin/support/encoding/hex/core_ext/integer.rb +82 -0
  174. data/lib/ronin/support/encoding/hex/core_ext/string.rb +133 -0
  175. data/lib/ronin/support/encoding/hex/core_ext.rb +22 -0
  176. data/lib/ronin/support/encoding/hex.rb +248 -0
  177. data/lib/ronin/support/encoding/html/core_ext/integer.rb +106 -0
  178. data/lib/ronin/support/encoding/html/core_ext/string.rb +130 -0
  179. data/lib/ronin/support/encoding/html/core_ext.rb +20 -0
  180. data/lib/ronin/support/encoding/html.rb +233 -0
  181. data/lib/ronin/support/encoding/http/core_ext/integer.rb +95 -0
  182. data/lib/ronin/support/encoding/http/core_ext/string.rb +129 -0
  183. data/lib/ronin/support/encoding/http/core_ext.rb +20 -0
  184. data/lib/ronin/support/encoding/http.rb +241 -0
  185. data/lib/ronin/support/encoding/js/core_ext/integer.rb +67 -0
  186. data/lib/ronin/support/encoding/js/core_ext/string.rb +125 -0
  187. data/lib/ronin/support/encoding/js/core_ext.rb +20 -0
  188. data/lib/ronin/support/encoding/js.rb +279 -0
  189. data/lib/ronin/support/encoding/powershell/core_ext/integer.rb +87 -0
  190. data/lib/ronin/support/encoding/powershell/core_ext/string.rb +145 -0
  191. data/lib/ronin/support/encoding/powershell/core_ext.rb +20 -0
  192. data/lib/ronin/support/encoding/powershell.rb +297 -0
  193. data/lib/ronin/{formatting/extensions/http/integer.rb → support/encoding/punycode/core_ext/string.rb} +23 -29
  194. data/lib/ronin/support/encoding/punycode/core_ext.rb +19 -0
  195. data/lib/ronin/support/encoding/punycode.rb +76 -0
  196. data/lib/ronin/support/encoding/quoted_printable/core_ext/string.rb +75 -0
  197. data/lib/ronin/support/encoding/quoted_printable/core_ext.rb +19 -0
  198. data/lib/ronin/support/encoding/quoted_printable.rb +102 -0
  199. data/lib/ronin/support/encoding/ruby/core_ext/string.rb +129 -0
  200. data/lib/ronin/support/encoding/ruby/core_ext.rb +19 -0
  201. data/lib/ronin/support/encoding/ruby.rb +235 -0
  202. data/lib/ronin/support/encoding/shell/core_ext/integer.rb +89 -0
  203. data/lib/ronin/support/encoding/shell/core_ext/string.rb +134 -0
  204. data/lib/ronin/support/encoding/shell/core_ext.rb +20 -0
  205. data/lib/ronin/support/encoding/shell.rb +293 -0
  206. data/lib/ronin/{network/extensions → support/encoding}/smtp.rb +4 -4
  207. data/lib/ronin/support/encoding/sql/core_ext/string.rb +114 -0
  208. data/lib/ronin/{formatting/html.rb → support/encoding/sql/core_ext.rb} +3 -4
  209. data/lib/ronin/support/encoding/sql.rb +124 -0
  210. data/lib/ronin/support/encoding/uri/core_ext/integer.rb +149 -0
  211. data/lib/ronin/support/encoding/uri/core_ext/string.rb +195 -0
  212. data/lib/ronin/support/encoding/uri/core_ext.rb +20 -0
  213. data/lib/ronin/support/encoding/uri.rb +424 -0
  214. data/lib/ronin/support/encoding/uuencoding/core_ext/string.rb +73 -0
  215. data/lib/ronin/support/encoding/uuencoding/core_ext.rb +19 -0
  216. data/lib/ronin/support/encoding/uuencoding.rb +70 -0
  217. data/lib/ronin/support/encoding/xml/core_ext/integer.rb +100 -0
  218. data/lib/ronin/support/encoding/xml/core_ext/string.rb +124 -0
  219. data/lib/ronin/support/encoding/xml/core_ext.rb +20 -0
  220. data/lib/ronin/support/encoding/xml.rb +328 -0
  221. data/lib/ronin/support/encoding.rb +46 -0
  222. data/lib/ronin/support/home.rb +88 -0
  223. data/lib/ronin/{network/network.rb → support/mixin.rb} +17 -20
  224. data/lib/ronin/support/network/asn/dns_record.rb +112 -0
  225. data/lib/ronin/support/network/asn/list.rb +269 -0
  226. data/lib/ronin/support/network/asn/record.rb +164 -0
  227. data/lib/ronin/support/network/asn/record_set.rb +226 -0
  228. data/lib/ronin/support/network/asn.rb +88 -0
  229. data/lib/ronin/{binary/hexdump.rb → support/network/core_ext.rb} +3 -4
  230. data/lib/ronin/support/network/dns/idn.rb +38 -0
  231. data/lib/ronin/support/network/dns/mixin.rb +941 -0
  232. data/lib/ronin/support/network/dns/resolver.rb +707 -0
  233. data/lib/ronin/support/network/dns.rb +1109 -0
  234. data/lib/ronin/support/network/domain.rb +70 -0
  235. data/lib/ronin/support/network/email_address.rb +574 -0
  236. data/lib/ronin/support/network/esmtp/mixin.rb +115 -0
  237. data/lib/ronin/support/network/exceptions.rb +43 -0
  238. data/lib/ronin/support/network/ftp/mixin.rb +106 -0
  239. data/lib/ronin/support/network/host.rb +1473 -0
  240. data/lib/ronin/support/network/http/cookie.rb +245 -0
  241. data/lib/ronin/support/network/http/core_ext/uri/http.rb +63 -0
  242. data/lib/ronin/support/network/http/core_ext.rb +19 -0
  243. data/lib/ronin/support/network/http/mixin.rb +890 -0
  244. data/lib/ronin/support/network/http/request.rb +215 -0
  245. data/lib/ronin/support/network/http/set_cookie.rb +210 -0
  246. data/lib/ronin/support/network/http/user_agents.rb +115 -0
  247. data/lib/ronin/support/network/http.rb +2582 -0
  248. data/lib/ronin/support/network/imap/mixin.rb +133 -0
  249. data/lib/ronin/support/network/ip/mixin.rb +114 -0
  250. data/lib/ronin/support/network/ip.rb +540 -0
  251. data/lib/ronin/support/network/ip_range/cidr.rb +252 -0
  252. data/lib/ronin/support/network/ip_range/glob.rb +309 -0
  253. data/lib/ronin/support/network/ip_range/range.rb +249 -0
  254. data/lib/ronin/support/network/ip_range.rb +284 -0
  255. data/lib/ronin/support/network/mixin.rb +58 -0
  256. data/lib/ronin/support/network/packet.rb +27 -0
  257. data/lib/ronin/support/network/pop3/mixin.rb +113 -0
  258. data/lib/ronin/support/network/proxy.rb +602 -0
  259. data/lib/ronin/support/network/public_suffix/list.rb +339 -0
  260. data/lib/ronin/support/network/public_suffix/suffix.rb +118 -0
  261. data/lib/ronin/support/network/public_suffix/suffix_set.rb +150 -0
  262. data/lib/ronin/support/network/public_suffix.rb +41 -0
  263. data/lib/ronin/support/network/smtp/email.rb +190 -0
  264. data/lib/ronin/support/network/smtp/mixin.rb +290 -0
  265. data/lib/ronin/support/network/smtp.rb +19 -0
  266. data/lib/ronin/support/network/ssl/local_cert.rb +114 -0
  267. data/lib/ronin/support/network/ssl/local_key.rb +84 -0
  268. data/lib/ronin/support/network/ssl/mixin.rb +740 -0
  269. data/lib/ronin/{network/extensions/imap/net.rb → support/network/ssl/openssl.rb} +6 -7
  270. data/lib/ronin/support/network/ssl/proxy.rb +296 -0
  271. data/lib/ronin/support/network/ssl.rb +173 -0
  272. data/lib/ronin/support/network/tcp/mixin.rb +400 -0
  273. data/lib/ronin/support/network/tcp/proxy.rb +435 -0
  274. data/lib/ronin/support/network/tcp.rb +443 -0
  275. data/lib/ronin/support/network/telnet/mixin.rb +150 -0
  276. data/lib/ronin/support/network/telnet.rb +90 -0
  277. data/lib/ronin/support/network/tld/list.rb +266 -0
  278. data/lib/ronin/support/network/tld.rb +41 -0
  279. data/lib/ronin/support/network/tls/mixin.rb +670 -0
  280. data/lib/ronin/support/network/tls/proxy.rb +135 -0
  281. data/lib/ronin/{network/mixins/dns.rb → support/network/tls.rb} +23 -25
  282. data/lib/ronin/support/network/udp/mixin.rb +389 -0
  283. data/lib/ronin/support/network/udp/proxy.rb +192 -0
  284. data/lib/ronin/support/network/udp.rb +435 -0
  285. data/lib/ronin/support/network/unix/mixin.rb +273 -0
  286. data/lib/ronin/support/network.rb +37 -0
  287. data/lib/ronin/support/path.rb +136 -0
  288. data/lib/ronin/{network/extensions/dns/net.rb → support/text/core_ext/regexp.rb} +5 -6
  289. data/lib/ronin/support/text/core_ext/string.rb +46 -0
  290. data/lib/ronin/{formatting.rb → support/text/core_ext.rb} +7 -9
  291. data/lib/ronin/support/text/entropy/core_ext/string.rb +45 -0
  292. data/lib/ronin/{formatting/http.rb → support/text/entropy/core_ext.rb} +3 -4
  293. data/lib/ronin/support/text/entropy.rb +66 -0
  294. data/lib/ronin/support/text/erb/mixin.rb +44 -0
  295. data/lib/ronin/support/text/erb.rb +19 -0
  296. data/lib/ronin/support/text/homoglyph/core_ext/string.rb +108 -0
  297. data/lib/ronin/{formatting/digest.rb → support/text/homoglyph/core_ext.rb} +3 -4
  298. data/lib/ronin/{network/http/exceptions/unknown_request.rb → support/text/homoglyph/exceptions.rb} +7 -6
  299. data/lib/ronin/support/text/homoglyph/table.rb +228 -0
  300. data/lib/ronin/support/text/homoglyph.rb +142 -0
  301. data/lib/ronin/support/text/mixin.rb +31 -0
  302. data/lib/ronin/support/text/patterns/credentials.rb +75 -0
  303. data/lib/ronin/support/text/patterns/crypto.rb +67 -0
  304. data/lib/ronin/support/text/patterns/file_system.rb +93 -0
  305. data/lib/ronin/support/text/patterns/language.rb +37 -0
  306. data/lib/ronin/support/text/patterns/network/public_suffix.rb +44 -0
  307. data/lib/ronin/support/text/patterns/network.rb +140 -0
  308. data/lib/ronin/support/text/patterns/numeric.rb +52 -0
  309. data/lib/ronin/support/text/patterns/pii.rb +105 -0
  310. data/lib/ronin/support/text/patterns/source_code.rb +148 -0
  311. data/lib/ronin/{extensions.rb → support/text/patterns.rb} +9 -13
  312. data/lib/ronin/support/text/random/mixin.rb +437 -0
  313. data/lib/ronin/support/text/random.rb +419 -0
  314. data/lib/ronin/support/text/typo/core_ext/string.rb +123 -0
  315. data/lib/ronin/support/text/typo/core_ext.rb +19 -0
  316. data/lib/ronin/support/text/typo/exceptions.rb +28 -0
  317. data/lib/ronin/support/text/typo/generator.rb +161 -0
  318. data/lib/ronin/support/text/typo.rb +260 -0
  319. data/lib/ronin/{formatting → support}/text.rb +10 -4
  320. data/lib/ronin/support/version.rb +3 -4
  321. data/lib/ronin/support.rb +17 -12
  322. data/ronin-support.gemspec +2 -1
  323. metadata +340 -289
  324. data/lib/ronin/binary/hexdump/parser.rb +0 -403
  325. data/lib/ronin/binary/struct.rb +0 -567
  326. data/lib/ronin/binary/template.rb +0 -454
  327. data/lib/ronin/extensions/ip_addr.rb +0 -216
  328. data/lib/ronin/extensions/meta/object.rb +0 -24
  329. data/lib/ronin/extensions/regexp.rb +0 -157
  330. data/lib/ronin/formatting/extensions/binary/base64.rb +0 -106
  331. data/lib/ronin/formatting/extensions/binary/file.rb +0 -77
  332. data/lib/ronin/formatting/extensions/binary/float.rb +0 -65
  333. data/lib/ronin/formatting/extensions/binary/integer.rb +0 -180
  334. data/lib/ronin/formatting/extensions/binary/string.rb +0 -345
  335. data/lib/ronin/formatting/extensions/digest/file.rb +0 -129
  336. data/lib/ronin/formatting/extensions/digest/string.rb +0 -86
  337. data/lib/ronin/formatting/extensions/digest.rb +0 -21
  338. data/lib/ronin/formatting/extensions/html/integer.rb +0 -142
  339. data/lib/ronin/formatting/extensions/html/string.rb +0 -194
  340. data/lib/ronin/formatting/extensions/html.rb +0 -21
  341. data/lib/ronin/formatting/extensions/http/string.rb +0 -110
  342. data/lib/ronin/formatting/extensions/http.rb +0 -21
  343. data/lib/ronin/formatting/extensions/sql/string.rb +0 -130
  344. data/lib/ronin/formatting/extensions/sql.rb +0 -20
  345. data/lib/ronin/formatting/extensions/text/array.rb +0 -137
  346. data/lib/ronin/formatting/extensions/text/string.rb +0 -297
  347. data/lib/ronin/formatting/extensions.rb +0 -24
  348. data/lib/ronin/fuzzing/extensions/string.rb +0 -209
  349. data/lib/ronin/fuzzing/fuzzer.rb +0 -110
  350. data/lib/ronin/fuzzing/fuzzing.rb +0 -360
  351. data/lib/ronin/fuzzing/mutator.rb +0 -161
  352. data/lib/ronin/fuzzing/repeater.rb +0 -81
  353. data/lib/ronin/fuzzing/template.rb +0 -133
  354. data/lib/ronin/fuzzing.rb +0 -21
  355. data/lib/ronin/mixin.rb +0 -89
  356. data/lib/ronin/network/dns.rb +0 -201
  357. data/lib/ronin/network/esmtp.rb +0 -113
  358. data/lib/ronin/network/extensions/dns.rb +0 -20
  359. data/lib/ronin/network/extensions/esmtp.rb +0 -20
  360. data/lib/ronin/network/extensions/http/uri/http.rb +0 -228
  361. data/lib/ronin/network/extensions/http.rb +0 -21
  362. data/lib/ronin/network/extensions/imap.rb +0 -20
  363. data/lib/ronin/network/extensions/pop3/net.rb +0 -24
  364. data/lib/ronin/network/extensions/pop3.rb +0 -20
  365. data/lib/ronin/network/extensions/smtp/net.rb +0 -24
  366. data/lib/ronin/network/extensions/ssl/net.rb +0 -24
  367. data/lib/ronin/network/extensions/ssl.rb +0 -20
  368. data/lib/ronin/network/extensions/tcp/net.rb +0 -24
  369. data/lib/ronin/network/extensions/tcp.rb +0 -20
  370. data/lib/ronin/network/extensions/telnet/net.rb +0 -24
  371. data/lib/ronin/network/extensions/telnet.rb +0 -20
  372. data/lib/ronin/network/extensions/udp/net.rb +0 -24
  373. data/lib/ronin/network/extensions/udp.rb +0 -20
  374. data/lib/ronin/network/extensions.rb +0 -29
  375. data/lib/ronin/network/ftp.rb +0 -149
  376. data/lib/ronin/network/http/exceptions.rb +0 -20
  377. data/lib/ronin/network/http/http.rb +0 -1122
  378. data/lib/ronin/network/http/proxy.rb +0 -330
  379. data/lib/ronin/network/http.rb +0 -22
  380. data/lib/ronin/network/imap.rb +0 -158
  381. data/lib/ronin/network/mixins/esmtp.rb +0 -164
  382. data/lib/ronin/network/mixins/ftp.rb +0 -155
  383. data/lib/ronin/network/mixins/http.rb +0 -227
  384. data/lib/ronin/network/mixins/imap.rb +0 -156
  385. data/lib/ronin/network/mixins/pop3.rb +0 -149
  386. data/lib/ronin/network/mixins/smtp.rb +0 -159
  387. data/lib/ronin/network/mixins/ssl.rb +0 -148
  388. data/lib/ronin/network/mixins/tcp.rb +0 -368
  389. data/lib/ronin/network/mixins/telnet.rb +0 -208
  390. data/lib/ronin/network/mixins/udp.rb +0 -381
  391. data/lib/ronin/network/mixins/unix.rb +0 -279
  392. data/lib/ronin/network/mixins.rb +0 -29
  393. data/lib/ronin/network/pop3.rb +0 -124
  394. data/lib/ronin/network/proxy.rb +0 -578
  395. data/lib/ronin/network/smtp/email.rb +0 -174
  396. data/lib/ronin/network/smtp/smtp.rb +0 -230
  397. data/lib/ronin/network/smtp.rb +0 -22
  398. data/lib/ronin/network/ssl.rb +0 -186
  399. data/lib/ronin/network/tcp/proxy.rb +0 -417
  400. data/lib/ronin/network/tcp/tcp.rb +0 -452
  401. data/lib/ronin/network/tcp.rb +0 -21
  402. data/lib/ronin/network/telnet.rb +0 -266
  403. data/lib/ronin/network/udp/proxy.rb +0 -191
  404. data/lib/ronin/network/udp/udp.rb +0 -452
  405. data/lib/ronin/network/udp.rb +0 -21
  406. data/lib/ronin/network/unix.rb +0 -286
  407. data/lib/ronin/network.rb +0 -31
  408. data/lib/ronin/path.rb +0 -133
  409. data/lib/ronin/spec/ui/output.rb +0 -22
  410. data/lib/ronin/support/inflector.rb +0 -92
  411. data/lib/ronin/templates/erb.rb +0 -78
  412. data/lib/ronin/templates/template.rb +0 -169
  413. data/lib/ronin/templates.rb +0 -21
  414. data/lib/ronin/ui/output/helpers.rb +0 -296
  415. data/lib/ronin/ui/output/output.rb +0 -142
  416. data/lib/ronin/ui/output/terminal/color.rb +0 -124
  417. data/lib/ronin/ui/output/terminal/raw.rb +0 -103
  418. data/lib/ronin/ui/output/terminal.rb +0 -21
  419. data/lib/ronin/ui/output.rb +0 -21
  420. data/lib/ronin/ui/shell.rb +0 -286
  421. data/lib/ronin/wordlist.rb +0 -287
  422. data/spec/binary/hexdump/helpers/hexdumps/ascii.bin +0 -0
  423. data/spec/binary/hexdump/helpers/hexdumps/hexdump_decimal_shorts.txt +0 -17
  424. data/spec/binary/hexdump/helpers/hexdumps/hexdump_hex_bytes.txt +0 -17
  425. data/spec/binary/hexdump/helpers/hexdumps/hexdump_hex_shorts.txt +0 -17
  426. data/spec/binary/hexdump/helpers/hexdumps/hexdump_octal_bytes.txt +0 -17
  427. data/spec/binary/hexdump/helpers/hexdumps/hexdump_octal_shorts.txt +0 -17
  428. data/spec/binary/hexdump/helpers/hexdumps/hexdump_repeated.txt +0 -6
  429. data/spec/binary/hexdump/helpers/hexdumps/od_decimal_bytes.txt +0 -17
  430. data/spec/binary/hexdump/helpers/hexdumps/od_decimal_ints.txt +0 -17
  431. data/spec/binary/hexdump/helpers/hexdumps/od_decimal_quads.txt +0 -17
  432. data/spec/binary/hexdump/helpers/hexdumps/od_decimal_shorts.txt +0 -17
  433. data/spec/binary/hexdump/helpers/hexdumps/od_doubles.txt +0 -17
  434. data/spec/binary/hexdump/helpers/hexdumps/od_floats.txt +0 -17
  435. data/spec/binary/hexdump/helpers/hexdumps/od_hex_bytes.txt +0 -17
  436. data/spec/binary/hexdump/helpers/hexdumps/od_hex_ints.txt +0 -17
  437. data/spec/binary/hexdump/helpers/hexdumps/od_hex_quads.txt +0 -17
  438. data/spec/binary/hexdump/helpers/hexdumps/od_hex_shorts.txt +0 -17
  439. data/spec/binary/hexdump/helpers/hexdumps/od_named_chars.txt +0 -17
  440. data/spec/binary/hexdump/helpers/hexdumps/od_octal_bytes.txt +0 -17
  441. data/spec/binary/hexdump/helpers/hexdumps/od_octal_ints.txt +0 -17
  442. data/spec/binary/hexdump/helpers/hexdumps/od_octal_quads.txt +0 -17
  443. data/spec/binary/hexdump/helpers/hexdumps/od_octal_shorts.txt +0 -17
  444. data/spec/binary/hexdump/helpers/hexdumps/od_repeated.txt +0 -6
  445. data/spec/binary/hexdump/helpers/hexdumps/repeated.bin +0 -1
  446. data/spec/binary/hexdump/helpers/hexdumps.rb +0 -13
  447. data/spec/binary/hexdump/parser_spec.rb +0 -302
  448. data/spec/binary/struct_spec.rb +0 -496
  449. data/spec/binary/template_spec.rb +0 -416
  450. data/spec/extensions/enumerable_spec.rb +0 -24
  451. data/spec/extensions/file_spec.rb +0 -61
  452. data/spec/extensions/ip_addr_spec.rb +0 -203
  453. data/spec/extensions/kernel_spec.rb +0 -30
  454. data/spec/extensions/regexp_spec.rb +0 -482
  455. data/spec/extensions/resolv_spec.rb +0 -18
  456. data/spec/extensions/string_spec.rb +0 -180
  457. data/spec/formatting/binary/array_spec.rb +0 -26
  458. data/spec/formatting/binary/base64_spec.rb +0 -50
  459. data/spec/formatting/binary/float_spec.rb +0 -36
  460. data/spec/formatting/binary/integer_spec.rb +0 -166
  461. data/spec/formatting/binary/string_spec.rb +0 -199
  462. data/spec/formatting/digest/string_spec.rb +0 -82
  463. data/spec/formatting/html/integer_spec.rb +0 -66
  464. data/spec/formatting/html/string_spec.rb +0 -103
  465. data/spec/formatting/http/integer_spec.rb +0 -42
  466. data/spec/formatting/http/string_spec.rb +0 -76
  467. data/spec/formatting/sql/string_spec.rb +0 -77
  468. data/spec/formatting/text/array_spec.rb +0 -105
  469. data/spec/formatting/text/string_spec.rb +0 -162
  470. data/spec/fuzzing/extensions/string_spec.rb +0 -87
  471. data/spec/fuzzing/fuzzer_spec.rb +0 -109
  472. data/spec/fuzzing/fuzzing_spec.rb +0 -24
  473. data/spec/fuzzing/mutator_spec.rb +0 -112
  474. data/spec/fuzzing/repeater_spec.rb +0 -57
  475. data/spec/fuzzing/template_spec.rb +0 -54
  476. data/spec/mixin_spec.rb +0 -51
  477. data/spec/network/dns_spec.rb +0 -203
  478. data/spec/network/ftp_spec.rb +0 -81
  479. data/spec/network/http/http_spec.rb +0 -559
  480. data/spec/network/http/proxy_spec.rb +0 -148
  481. data/spec/network/network_spec.rb +0 -8
  482. data/spec/network/proxy_spec.rb +0 -121
  483. data/spec/network/shared/unix_server.rb +0 -31
  484. data/spec/network/smtp/email_spec.rb +0 -100
  485. data/spec/network/ssl_spec.rb +0 -70
  486. data/spec/network/tcp/proxy_spec.rb +0 -118
  487. data/spec/network/tcp/tcp_spec.rb +0 -316
  488. data/spec/network/telnet_spec.rb +0 -67
  489. data/spec/network/udp/udp_spec.rb +0 -298
  490. data/spec/network/unix_spec.rb +0 -182
  491. data/spec/path_spec.rb +0 -111
  492. data/spec/spec_helper.rb +0 -8
  493. data/spec/support/inflector_spec.rb +0 -22
  494. data/spec/support_spec.rb +0 -8
  495. data/spec/templates/classes/example_erb.rb +0 -11
  496. data/spec/templates/classes/example_template.rb +0 -35
  497. data/spec/templates/erb_spec.rb +0 -21
  498. data/spec/templates/helpers/data/includes/_relative.erb +0 -1
  499. data/spec/templates/helpers/data/templates/example.erb +0 -1
  500. data/spec/templates/helpers/data.rb +0 -9
  501. data/spec/templates/template_spec.rb +0 -54
  502. data/spec/ui/classes/test_shell.rb +0 -22
  503. data/spec/ui/output_spec.rb +0 -32
  504. data/spec/ui/shell_spec.rb +0 -83
  505. data/spec/wordlist_spec.rb +0 -151
@@ -0,0 +1,540 @@
1
+ # frozen_string_literal: true
2
+ #
3
+ # Copyright (c) 2006-2022 Hal Brodigan (postmodern.mod3 at gmail.com)
4
+ #
5
+ # ronin-support is free software: you can redistribute it and/or modify
6
+ # it under the terms of the GNU Lesser General Public License as published
7
+ # by the Free Software Foundation, either version 3 of the License, or
8
+ # (at your option) any later version.
9
+ #
10
+ # ronin-support 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 Lesser General Public License for more details.
14
+ #
15
+ # You should have received a copy of the GNU Lesser General Public License
16
+ # along with ronin-support. If not, see <https://www.gnu.org/licenses/>.
17
+ #
18
+
19
+ require 'ronin/support/network/exceptions'
20
+ require 'ronin/support/network/asn'
21
+ require 'ronin/support/network/dns'
22
+ require 'ronin/support/network/host'
23
+ require 'ronin/support/text/patterns'
24
+
25
+ require 'ipaddr'
26
+ require 'socket'
27
+ require 'net/https'
28
+
29
+ module Ronin
30
+ module Support
31
+ module Network
32
+ #
33
+ # Represents a single IP address.
34
+ #
35
+ # ## Examples
36
+ #
37
+ # ip = IP.new('192.30.255.113')
38
+ #
39
+ # Reverse DNS lookup:
40
+ #
41
+ # ip.get_name
42
+ # # => "lb-192-30-255-113-sea.github.com"
43
+ # ip.get_names
44
+ # # => ["lb-192-30-255-113-sea.github.com"]
45
+ # ip.get_host
46
+ # # => #<Ronin::Support::Network::Host: lb-192-30-255-113-sea.github.com>
47
+ # ip.get_hosts
48
+ # # => [#<Ronin::Support::Network::Host: lb-192-30-255-113-sea.github.com>]
49
+ # ip.host
50
+ # # => #<Ronin::Support::Network::Host: lb-192-30-255-113-sea.github.com>
51
+ # ip.hosts
52
+ # # => [#<Ronin::Support::Network::Host: lb-192-30-255-113-sea.github.com>]
53
+ #
54
+ # Get ASN information:
55
+ #
56
+ # ip.asn
57
+ # # => #<Ronin::Support::Network::ASN::DNSRecord:0x00007f34142de598
58
+ # @country_code="US",
59
+ # @name=nil,
60
+ # @number=15133,
61
+ # @range=#<Ronin::Support::Network::IPRange::CIDR: 93.184.216.0/24>>
62
+ #
63
+ # @api public
64
+ #
65
+ # @since 1.0.0
66
+ #
67
+ class IP < IPAddr
68
+
69
+ # The address of the IP.
70
+ #
71
+ # @return [String]
72
+ attr_reader :address
73
+
74
+ #
75
+ # Initializes the IP address.
76
+ #
77
+ # @param [String] address
78
+ # The address of the IP.
79
+ #
80
+ # @param [Integer] family
81
+ # The address family for the CIDR range. This is mainly for
82
+ # backwards compatibility with `IPAddr#initialize`.
83
+ #
84
+ # @raise [InvalidIP]
85
+ # The given address is not a valid IP address.
86
+ #
87
+ # @example
88
+ # ip = IP.new('192.30.255.113')
89
+ #
90
+ # @note
91
+ # If the IP address has an `%iface` suffix, it will be removed from
92
+ # the IP address.
93
+ #
94
+ def initialize(address,family=Socket::AF_UNSPEC)
95
+ # XXX: remove the %iface suffix for ruby < 3.1.0
96
+ if address.kind_of?(String) && address =~ /%.+$/
97
+ address = address.sub(/%.+$/,'')
98
+ end
99
+
100
+ begin
101
+ super(address,family)
102
+ rescue IPAddr::InvalidAddressError => error
103
+ raise(InvalidIP,"invalid IP address: #{address.inspect}")
104
+ end
105
+
106
+ @address = case address
107
+ when String then address.to_s
108
+ else to_s
109
+ end
110
+ end
111
+
112
+ # The URI for https://ipinfo.io/ip
113
+ IPINFO_URI = URI::HTTPS.build(host: 'ipinfo.io', path: '/ip')
114
+
115
+ #
116
+ # Determines the current public IP address.
117
+ #
118
+ # @return [String, nil]
119
+ # The public IP address according to {https://ipinfo.io/ip}.
120
+ #
121
+ def self.public_address
122
+ response = begin
123
+ Net::HTTP.get_response(IPINFO_URI)
124
+ rescue
125
+ end
126
+
127
+ if response && response.code == '200'
128
+ return response.body
129
+ end
130
+ end
131
+
132
+ #
133
+ # Determines the current public IP.
134
+ #
135
+ # @return [IP, nil]
136
+ # The public IP according to {https://ipinfo.io/ip}.
137
+ #
138
+ def self.public_ip
139
+ if (address = public_address)
140
+ new(address)
141
+ end
142
+ end
143
+
144
+ #
145
+ # Determines all local IP addresses.
146
+ #
147
+ # @return [Array<String>]
148
+ #
149
+ # @example
150
+ # IP.local_addresses
151
+ # # => ["127.0.0.1", "192.168.1.42", "::1", "fe80::4ba:612f:9e2:37e2"]
152
+ #
153
+ def self.local_addresses
154
+ Socket.ip_address_list.map do |addrinfo|
155
+ address = addrinfo.ip_address
156
+
157
+ if address =~ /%.+$/
158
+ address = address.sub(/%.+$/,'')
159
+ end
160
+
161
+ address
162
+ end
163
+ end
164
+
165
+ #
166
+ # Determines all local IPs.
167
+ #
168
+ # @return [Array<IP>]
169
+ #
170
+ # @example
171
+ # IP.local_ips
172
+ # # => [#<Ronin::Support::Network::IP: 127.0.0.1>,
173
+ # #<Ronin::Support::Network::IP: 192.168.1.42>,
174
+ # #<Ronin::Support::Network::IP: ::1>,
175
+ # #<Ronin::Support::Network::IP: fe80::04ba:612f:09e2:37e2>]
176
+ #
177
+ def self.local_ips
178
+ local_addresses.map(&method(:new))
179
+ end
180
+
181
+ #
182
+ # Determines the local IP address.
183
+ #
184
+ # @return [String]
185
+ #
186
+ # @example
187
+ # IP.local_address
188
+ # # => "127.0.0.1"
189
+ #
190
+ def self.local_address
191
+ Socket.ip_address_list.first.ip_address
192
+ end
193
+
194
+ #
195
+ # Determines the local IP.
196
+ #
197
+ # @return [IP]
198
+ #
199
+ # @example
200
+ # IP.local_ip
201
+ # # => #<Ronin::Support::Network::IP: 127.0.0.1>
202
+ #
203
+ def self.local_ip
204
+ new(local_address)
205
+ end
206
+
207
+ #
208
+ # Extracts IP Addresses from text.
209
+ #
210
+ # @param [String] text
211
+ # The text to scan for IP Addresses.
212
+ #
213
+ # @param [4, :v4, :ipv4, 6, :v6, :ipv6] version
214
+ # The version of IP Address to extract.
215
+ #
216
+ # @yield [ip]
217
+ # The given block will be passed each extracted IP Address.
218
+ #
219
+ # @yieldparam [String] ip
220
+ # An IP Address from the text.
221
+ #
222
+ # @return [Array<String>]
223
+ # The IP Addresses found in the text.
224
+ #
225
+ # @example
226
+ # IPAddr.extract("Host: 127.0.0.1\n\rHost: 10.1.1.1\n\r")
227
+ # # => ["127.0.0.1", "10.1.1.1"]
228
+ #
229
+ # @example Extract only IPv4 addresses from a large amount of text:
230
+ # IPAddr.extract(text,:v4) do |ip|
231
+ # puts ip
232
+ # end
233
+ #
234
+ def self.extract(text,version=nil,&block)
235
+ return enum_for(__method__,text,version).to_a unless block_given?
236
+
237
+ regexp = case version
238
+ when :ipv4, :v4, 4 then Text::Patterns::IPV4_ADDR
239
+ when :ipv6, :v6, 6 then Text::Patterns::IPV6_ADDR
240
+ else Text::Patterns::IP_ADDR
241
+ end
242
+
243
+ text.scan(regexp) do |match|
244
+ yield match
245
+ end
246
+
247
+ return nil
248
+ end
249
+
250
+ #
251
+ # Determines if the address is a IPv4 broadcast addresses.
252
+ #
253
+ # @return [Boolean]
254
+ #
255
+ # @example
256
+ # ip = IPAddr.new('255.255.255.255')
257
+ # ip.broadcast?
258
+ # # => true
259
+ # ip = IPAddr.new('192.168.1.255')
260
+ # ip.broadcast?
261
+ # # => true
262
+ # ip = IPAddr.new('1.1.1.1')
263
+ # ip.broadcast?
264
+ # # => false
265
+ #
266
+ def broadcast?
267
+ # NOTE: IPv6 does not have broadcast addresses
268
+ ipv4? && (@addr & 0xff) == 0xff
269
+ end
270
+
271
+ #
272
+ # Determines if the address is a "logical" IPv4 address.
273
+ #
274
+ # @return [Boolean]
275
+ #
276
+ # @example
277
+ # ip = IPAddr.new('0.0.0.0')
278
+ # ip.logical?
279
+ # # => true
280
+ # ip = IPAddr.new('192.168.1.0')
281
+ # ip.logical?
282
+ # # => true
283
+ # ip = IPAddr.new('1.1.1.1')
284
+ # ip.logical?
285
+ # # => false
286
+ #
287
+ def logical?
288
+ ipv4? && (@addr & 0xff) == 0x00
289
+ end
290
+
291
+ #
292
+ # The Autonomous System Number (ASN) information for the IP address.
293
+ #
294
+ # @return [ASN::Record]
295
+ #
296
+ # @example
297
+ # ip = IP.new('93.184.216.34')
298
+ # ip.asn
299
+ # # => #<Ronin::Support::Network::ASN::DNSRecord:0x00007f34142de598
300
+ # @country_code="US",
301
+ # @name=nil,
302
+ # @number=15133,
303
+ # @range=#<Ronin::Support::Network::IPRange::CIDR: 93.184.216.0/24>>
304
+ #
305
+ def asn
306
+ @asn ||= ASN.query(self)
307
+ end
308
+
309
+ #
310
+ # Looks up the hostname of the address.
311
+ #
312
+ # @param [Hash{Symbol => Object}] kwargs
313
+ # Additional keyword arguments.
314
+ #
315
+ # @option [Array<String>, String, nil] :nameservers
316
+ # Optional DNS nameserver(s) to query.
317
+ #
318
+ # @option [String, nil] :nameserver
319
+ # Optional DNS nameserver to query.
320
+ #
321
+ # @return [String, nil]
322
+ # The hostname of the address.
323
+ #
324
+ # @example
325
+ # ip = IP.new('192.30.255.113')
326
+ # ip.get_name
327
+ # # => "lb-192-30-255-113-sea.github.com"
328
+ #
329
+ def get_name(**kwargs)
330
+ DNS.get_name(@address,**kwargs)
331
+ end
332
+
333
+ alias reverse_lookup get_name
334
+
335
+ #
336
+ # Looks up all hostnames associated with the IP.
337
+ #
338
+ # @param [Hash{Symbol => Object}] kwargs
339
+ # Additional keyword arguments.
340
+ #
341
+ # @option [Array<String>, String, nil] :nameservers
342
+ # Optional DNS nameserver(s) to query.
343
+ #
344
+ # @option [String, nil] :nameserver
345
+ # Optional DNS nameserver to query.
346
+ #
347
+ # @return [Array<String>]
348
+ # The hostnames of the address.
349
+ #
350
+ # @example
351
+ # ip = IP.new('192.30.255.113')
352
+ # ip.get_names
353
+ # # => ["lb-192-30-255-113-sea.github.com"]
354
+ #
355
+ def get_names(**kwargs)
356
+ DNS.get_names(@address,**kwargs)
357
+ end
358
+
359
+ #
360
+ # Looks up the host for the IP.
361
+ #
362
+ # @param [Hash{Symbol => Object}] kwargs
363
+ # Additional keyword arguments.
364
+ #
365
+ # @option [Array<String>, String, nil] :nameservers
366
+ # Optional DNS nameserver(s) to query.
367
+ #
368
+ # @option [String, nil] :nameserver
369
+ # Optional DNS nameserver to query.
370
+ #
371
+ # @return [Host, nil]
372
+ # The host for the IP.
373
+ #
374
+ # @example
375
+ # ip = IP.new('192.30.255.113')
376
+ # ip.get_host
377
+ # # => #<Ronin::Support::Network::Host: lb-192-30-255-113-sea.github.com>
378
+ #
379
+ def get_host(**kwargs)
380
+ if (name = get_name(**kwargs))
381
+ Host.new(name)
382
+ end
383
+ end
384
+
385
+ #
386
+ # Looks up all hosts associated with the IP.
387
+ #
388
+ # @param [Hash{Symbol => Object}] kwargs
389
+ # Additional keyword arguments.
390
+ #
391
+ # @option [Array<String>, String, nil] :nameservers
392
+ # Optional DNS nameserver(s) to query.
393
+ #
394
+ # @option [String, nil] :nameserver
395
+ # Optional DNS nameserver to query.
396
+ #
397
+ # @return [Array<Host>]
398
+ # The hosts for the IP.
399
+ #
400
+ # @example
401
+ # ip = IP.new('192.30.255.113')
402
+ # ip.get_hosts
403
+ # # => [#<Ronin::Support::Network::Host: lb-192-30-255-113-sea.github.com>]
404
+ #
405
+ def get_hosts(**kwargs)
406
+ get_names(**kwargs).map { |name| Host.new(name) }
407
+ end
408
+
409
+ #
410
+ # The host names of the address.
411
+ #
412
+ # @return [Array<Host>]
413
+ # The host names of the address or an empty Array if the IP address
414
+ # has no host names.
415
+ #
416
+ # @example
417
+ # ip = IP.new('192.30.255.113')
418
+ # ip.hosts
419
+ # # => [#<Ronin::Support::Network::Host: lb-192-30-255-113-sea.github.com>]
420
+ #
421
+ # @note This method returns memoized data.
422
+ #
423
+ def hosts
424
+ @hosts ||= get_hosts
425
+ end
426
+
427
+ #
428
+ # The primary host name of the address.
429
+ #
430
+ # @return [Host, nil]
431
+ # The host name or `nil` if the IP address has no host names.
432
+ #
433
+ # @example
434
+ # ip = IP.new('192.30.255.113')
435
+ # ip.host
436
+ # # => #<Ronin::Support::Network::Host: lb-192-30-255-113-sea.github.com>
437
+ #
438
+ def host
439
+ hosts.first
440
+ end
441
+
442
+ #
443
+ # Queries the first `PTR` DNS record for the IP address.
444
+ #
445
+ # @param [Hash{Symbol => Object}] kwargs
446
+ # Additional keyword arguments.
447
+ #
448
+ # @option [Array<String>, String, nil] :nameservers
449
+ # Optional DNS nameserver(s) to query.
450
+ #
451
+ # @option [String, nil] :nameserver
452
+ # Optional DNS nameserver to query.
453
+ #
454
+ # @return [Resolv::DNS::Resource::PTR, nil]
455
+ # The first `PTR` DNS record of the host name or `nil` if the host
456
+ # name has no `PTR` records.
457
+ #
458
+ # @see https://rubydoc.info/stdlib/resolv/Resolv/DNS/Resource/PTR
459
+ #
460
+ def get_ptr_record(**kwargs)
461
+ DNS.get_ptr_record(@address,**kwargs)
462
+ end
463
+
464
+ #
465
+ # Queries the `PTR` host name for the IP address.
466
+ #
467
+ # @param [Hash{Symbol => Object}] kwargs
468
+ # Additional keyword arguments.
469
+ #
470
+ # @option [Array<String>, String, nil] :nameservers
471
+ # Optional DNS nameserver(s) to query.
472
+ #
473
+ # @option [String, nil] :nameserver
474
+ # Optional DNS nameserver to query.
475
+ #
476
+ # @return [String, nil]
477
+ # The host name that points to the given IP.
478
+ #
479
+ def get_ptr_name(**kwargs)
480
+ DNS.get_ptr_name(@address,**kwargs)
481
+ end
482
+
483
+ #
484
+ # Queries all `PTR` DNS records for the IP address.
485
+ #
486
+ # @param [Hash{Symbol => Object}] kwargs
487
+ # Additional keyword arguments.
488
+ #
489
+ # @option [Array<String>, String, nil] :nameservers
490
+ # Optional DNS nameserver(s) to query.
491
+ #
492
+ # @option [String, nil] :nameserver
493
+ # Optional DNS nameserver to query.
494
+ #
495
+ # @return [Array<Resolv::DNS::Resource::PTR>]
496
+ # All `PTR` DNS records for the given IP.
497
+ #
498
+ # @see https://rubydoc.info/stdlib/resolv/Resolv/DNS/Resource/PTR
499
+ #
500
+ def get_ptr_records(**kwargs)
501
+ DNS.get_ptr_records(@address,**kwargs)
502
+ end
503
+
504
+ #
505
+ # Queries all `PTR` names for the IP address.
506
+ #
507
+ # @param [Hash{Symbol => Object}] kwargs
508
+ # Additional keyword arguments.
509
+ #
510
+ # @option [Array<String>, String, nil] :nameservers
511
+ # Optional DNS nameserver(s) to query.
512
+ #
513
+ # @option [String, nil] :nameserver
514
+ # Optional DNS nameserver to query.
515
+ #
516
+ # @return [Array<String>]
517
+ # The `PTR` names for the given IP.
518
+ #
519
+ def get_ptr_names(**kwargs)
520
+ DNS.get_ptr_names(@address,**kwargs)
521
+ end
522
+
523
+ alias canonical to_string
524
+ alias to_uint to_i
525
+ alias to_str to_s
526
+
527
+ #
528
+ # Inspects the IP.
529
+ #
530
+ # @return [String]
531
+ # The inspected IP object.
532
+ #
533
+ def inspect
534
+ "#<#{self.class}: #{@address}>"
535
+ end
536
+
537
+ end
538
+ end
539
+ end
540
+ end