librex 0.0.20 → 0.0.21

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (435) hide show
  1. data/Rakefile +1 -0
  2. data/lib/rex/LICENSE +29 -0
  3. data/lib/rex/arch.rb +103 -0
  4. data/lib/rex/arch/sparc.rb +75 -0
  5. data/lib/rex/arch/sparc.rb.ut.rb +18 -0
  6. data/lib/rex/arch/x86.rb +513 -0
  7. data/lib/rex/arch/x86.rb.ut.rb +93 -0
  8. data/lib/rex/assembly/nasm.rb +104 -0
  9. data/lib/rex/assembly/nasm.rb.ut.rb +22 -0
  10. data/lib/rex/codepage.map +104 -0
  11. data/lib/rex/compat.rb +311 -0
  12. data/lib/rex/constants.rb +113 -0
  13. data/lib/rex/elfparsey.rb +11 -0
  14. data/lib/rex/elfparsey/elf.rb +123 -0
  15. data/lib/rex/elfparsey/elfbase.rb +258 -0
  16. data/lib/rex/elfparsey/exceptions.rb +27 -0
  17. data/lib/rex/elfscan.rb +12 -0
  18. data/lib/rex/elfscan/scanner.rb +207 -0
  19. data/lib/rex/elfscan/search.rb +46 -0
  20. data/lib/rex/encoder/alpha2.rb +31 -0
  21. data/lib/rex/encoder/alpha2/alpha_mixed.rb +68 -0
  22. data/lib/rex/encoder/alpha2/alpha_upper.rb +79 -0
  23. data/lib/rex/encoder/alpha2/generic.rb +114 -0
  24. data/lib/rex/encoder/alpha2/unicode_mixed.rb +117 -0
  25. data/lib/rex/encoder/alpha2/unicode_upper.rb +129 -0
  26. data/lib/rex/encoder/ndr.rb +89 -0
  27. data/lib/rex/encoder/ndr.rb.ut.rb +44 -0
  28. data/lib/rex/encoder/nonalpha.rb +61 -0
  29. data/lib/rex/encoder/nonupper.rb +64 -0
  30. data/lib/rex/encoder/xdr.rb +106 -0
  31. data/lib/rex/encoder/xdr.rb.ut.rb +29 -0
  32. data/lib/rex/encoder/xor.rb +69 -0
  33. data/lib/rex/encoder/xor/dword.rb +13 -0
  34. data/lib/rex/encoder/xor/dword_additive.rb +13 -0
  35. data/lib/rex/encoders/xor_dword.rb +35 -0
  36. data/lib/rex/encoders/xor_dword_additive.rb +53 -0
  37. data/lib/rex/encoders/xor_dword_additive.rb.ut.rb +12 -0
  38. data/lib/rex/encoding/xor.rb +20 -0
  39. data/lib/rex/encoding/xor.rb.ts.rb +14 -0
  40. data/lib/rex/encoding/xor/byte.rb +15 -0
  41. data/lib/rex/encoding/xor/byte.rb.ut.rb +21 -0
  42. data/lib/rex/encoding/xor/dword.rb +21 -0
  43. data/lib/rex/encoding/xor/dword.rb.ut.rb +15 -0
  44. data/lib/rex/encoding/xor/dword_additive.rb +92 -0
  45. data/lib/rex/encoding/xor/dword_additive.rb.ut.rb +15 -0
  46. data/lib/rex/encoding/xor/exceptions.rb +17 -0
  47. data/lib/rex/encoding/xor/generic.rb +146 -0
  48. data/lib/rex/encoding/xor/generic.rb.ut.rb +120 -0
  49. data/lib/rex/encoding/xor/qword.rb +15 -0
  50. data/lib/rex/encoding/xor/word.rb +21 -0
  51. data/lib/rex/encoding/xor/word.rb.ut.rb +13 -0
  52. data/lib/rex/exceptions.rb +275 -0
  53. data/lib/rex/exceptions.rb.ut.rb +44 -0
  54. data/lib/rex/exploitation/cmdstager.rb +9 -0
  55. data/lib/rex/exploitation/cmdstager/base.rb +175 -0
  56. data/lib/rex/exploitation/cmdstager/debug_asm.rb +142 -0
  57. data/lib/rex/exploitation/cmdstager/debug_write.rb +136 -0
  58. data/lib/rex/exploitation/cmdstager/tftp.rb +63 -0
  59. data/lib/rex/exploitation/cmdstager/vbs.rb +128 -0
  60. data/lib/rex/exploitation/egghunter.rb +277 -0
  61. data/lib/rex/exploitation/egghunter.rb.ut.rb +25 -0
  62. data/lib/rex/exploitation/encryptjs.rb +77 -0
  63. data/lib/rex/exploitation/heaplib.js.b64 +331 -0
  64. data/lib/rex/exploitation/heaplib.rb +94 -0
  65. data/lib/rex/exploitation/javascriptosdetect.rb +897 -0
  66. data/lib/rex/exploitation/obfuscatejs.rb +335 -0
  67. data/lib/rex/exploitation/omelet.rb +320 -0
  68. data/lib/rex/exploitation/omelet.rb.ut.rb +13 -0
  69. data/lib/rex/exploitation/opcodedb.rb +818 -0
  70. data/lib/rex/exploitation/opcodedb.rb.ut.rb +279 -0
  71. data/lib/rex/exploitation/seh.rb +92 -0
  72. data/lib/rex/exploitation/seh.rb.ut.rb +19 -0
  73. data/lib/rex/file.rb +112 -0
  74. data/lib/rex/file.rb.ut.rb +16 -0
  75. data/lib/rex/image_source.rb +12 -0
  76. data/lib/rex/image_source/disk.rb +60 -0
  77. data/lib/rex/image_source/image_source.rb +46 -0
  78. data/lib/rex/image_source/memory.rb +37 -0
  79. data/lib/rex/io/bidirectional_pipe.rb +157 -0
  80. data/lib/rex/io/datagram_abstraction.rb +35 -0
  81. data/lib/rex/io/ring_buffer.rb +364 -0
  82. data/lib/rex/io/stream.rb +319 -0
  83. data/lib/rex/io/stream_abstraction.rb +197 -0
  84. data/lib/rex/io/stream_server.rb +211 -0
  85. data/lib/rex/job_container.rb +187 -0
  86. data/lib/rex/logging.rb +4 -0
  87. data/lib/rex/logging/log_dispatcher.rb +179 -0
  88. data/lib/rex/logging/log_sink.rb +42 -0
  89. data/lib/rex/logging/sinks/flatfile.rb +55 -0
  90. data/lib/rex/logging/sinks/stderr.rb +43 -0
  91. data/lib/rex/machparsey.rb +9 -0
  92. data/lib/rex/machparsey/exceptions.rb +34 -0
  93. data/lib/rex/machparsey/mach.rb +209 -0
  94. data/lib/rex/machparsey/machbase.rb +408 -0
  95. data/lib/rex/machscan.rb +9 -0
  96. data/lib/rex/machscan/scanner.rb +217 -0
  97. data/lib/rex/mime.rb +9 -0
  98. data/lib/rex/mime/header.rb +77 -0
  99. data/lib/rex/mime/message.rb +144 -0
  100. data/lib/rex/mime/part.rb +20 -0
  101. data/lib/rex/nop/opty2.rb +108 -0
  102. data/lib/rex/nop/opty2.rb.ut.rb +23 -0
  103. data/lib/rex/nop/opty2_tables.rb +300 -0
  104. data/lib/rex/ole.rb +205 -0
  105. data/lib/rex/ole/clsid.rb +47 -0
  106. data/lib/rex/ole/difat.rb +141 -0
  107. data/lib/rex/ole/directory.rb +231 -0
  108. data/lib/rex/ole/direntry.rb +240 -0
  109. data/lib/rex/ole/docs/dependencies.txt +8 -0
  110. data/lib/rex/ole/docs/references.txt +1 -0
  111. data/lib/rex/ole/fat.rb +99 -0
  112. data/lib/rex/ole/header.rb +204 -0
  113. data/lib/rex/ole/minifat.rb +77 -0
  114. data/lib/rex/ole/propset.rb +144 -0
  115. data/lib/rex/ole/samples/create_ole.rb +27 -0
  116. data/lib/rex/ole/samples/dir.rb +35 -0
  117. data/lib/rex/ole/samples/dump_stream.rb +34 -0
  118. data/lib/rex/ole/samples/ole_info.rb +23 -0
  119. data/lib/rex/ole/storage.rb +395 -0
  120. data/lib/rex/ole/stream.rb +53 -0
  121. data/lib/rex/ole/substorage.rb +49 -0
  122. data/lib/rex/ole/util.rb +157 -0
  123. data/lib/rex/parser/arguments.rb +97 -0
  124. data/lib/rex/parser/arguments.rb.ut.rb +67 -0
  125. data/lib/rex/parser/ini.rb +185 -0
  126. data/lib/rex/parser/ini.rb.ut.rb +29 -0
  127. data/lib/rex/parser/ip360_aspl_xml.rb +102 -0
  128. data/lib/rex/parser/ip360_xml.rb +97 -0
  129. data/lib/rex/parser/nessus_xml.rb +118 -0
  130. data/lib/rex/parser/netsparker_xml.rb +94 -0
  131. data/lib/rex/parser/nexpose_xml.rb +136 -0
  132. data/lib/rex/parser/nmap_xml.rb +137 -0
  133. data/lib/rex/parser/retina_xml.rb +109 -0
  134. data/lib/rex/payloads.rb +1 -0
  135. data/lib/rex/payloads/win32.rb +2 -0
  136. data/lib/rex/payloads/win32/common.rb +26 -0
  137. data/lib/rex/payloads/win32/kernel.rb +53 -0
  138. data/lib/rex/payloads/win32/kernel/common.rb +54 -0
  139. data/lib/rex/payloads/win32/kernel/migration.rb +12 -0
  140. data/lib/rex/payloads/win32/kernel/recovery.rb +50 -0
  141. data/lib/rex/payloads/win32/kernel/stager.rb +194 -0
  142. data/lib/rex/peparsey.rb +12 -0
  143. data/lib/rex/peparsey/exceptions.rb +32 -0
  144. data/lib/rex/peparsey/pe.rb +212 -0
  145. data/lib/rex/peparsey/pe_memdump.rb +63 -0
  146. data/lib/rex/peparsey/pebase.rb +1680 -0
  147. data/lib/rex/peparsey/section.rb +136 -0
  148. data/lib/rex/pescan.rb +13 -0
  149. data/lib/rex/pescan/analyze.rb +309 -0
  150. data/lib/rex/pescan/scanner.rb +206 -0
  151. data/lib/rex/pescan/search.rb +56 -0
  152. data/lib/rex/platforms.rb +1 -0
  153. data/lib/rex/platforms/windows.rb +51 -0
  154. data/lib/rex/poly.rb +132 -0
  155. data/lib/rex/poly/block.rb +477 -0
  156. data/lib/rex/poly/register.rb +100 -0
  157. data/lib/rex/poly/register/x86.rb +40 -0
  158. data/lib/rex/post.rb +8 -0
  159. data/lib/rex/post/dir.rb +51 -0
  160. data/lib/rex/post/file.rb +172 -0
  161. data/lib/rex/post/file_stat.rb +220 -0
  162. data/lib/rex/post/gen.pl +13 -0
  163. data/lib/rex/post/io.rb +182 -0
  164. data/lib/rex/post/meterpreter.rb +4 -0
  165. data/lib/rex/post/meterpreter/channel.rb +445 -0
  166. data/lib/rex/post/meterpreter/channel_container.rb +54 -0
  167. data/lib/rex/post/meterpreter/channels/pool.rb +160 -0
  168. data/lib/rex/post/meterpreter/channels/pools/file.rb +62 -0
  169. data/lib/rex/post/meterpreter/channels/pools/stream_pool.rb +103 -0
  170. data/lib/rex/post/meterpreter/channels/stream.rb +87 -0
  171. data/lib/rex/post/meterpreter/client.rb +364 -0
  172. data/lib/rex/post/meterpreter/client_core.rb +274 -0
  173. data/lib/rex/post/meterpreter/dependencies.rb +3 -0
  174. data/lib/rex/post/meterpreter/extension.rb +32 -0
  175. data/lib/rex/post/meterpreter/extensions/espia/espia.rb +58 -0
  176. data/lib/rex/post/meterpreter/extensions/espia/tlv.rb +16 -0
  177. data/lib/rex/post/meterpreter/extensions/incognito/incognito.rb +94 -0
  178. data/lib/rex/post/meterpreter/extensions/incognito/tlv.rb +21 -0
  179. data/lib/rex/post/meterpreter/extensions/networkpug/networkpug.rb +57 -0
  180. data/lib/rex/post/meterpreter/extensions/networkpug/tlv.rb +15 -0
  181. data/lib/rex/post/meterpreter/extensions/priv/fs.rb +118 -0
  182. data/lib/rex/post/meterpreter/extensions/priv/passwd.rb +61 -0
  183. data/lib/rex/post/meterpreter/extensions/priv/priv.rb +111 -0
  184. data/lib/rex/post/meterpreter/extensions/priv/tlv.rb +28 -0
  185. data/lib/rex/post/meterpreter/extensions/sniffer/sniffer.rb +101 -0
  186. data/lib/rex/post/meterpreter/extensions/sniffer/tlv.rb +26 -0
  187. data/lib/rex/post/meterpreter/extensions/stdapi/constants.rb +333 -0
  188. data/lib/rex/post/meterpreter/extensions/stdapi/fs/dir.rb +282 -0
  189. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file.rb +266 -0
  190. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file_stat.rb +103 -0
  191. data/lib/rex/post/meterpreter/extensions/stdapi/fs/io.rb +48 -0
  192. data/lib/rex/post/meterpreter/extensions/stdapi/net/config.rb +144 -0
  193. data/lib/rex/post/meterpreter/extensions/stdapi/net/interface.rb +73 -0
  194. data/lib/rex/post/meterpreter/extensions/stdapi/net/route.rb +56 -0
  195. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket.rb +137 -0
  196. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_client_channel.rb +180 -0
  197. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_server_channel.rb +167 -0
  198. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/udp_channel.rb +208 -0
  199. data/lib/rex/post/meterpreter/extensions/stdapi/railgun.rb.ts.rb +6 -0
  200. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/api_constants.rb +38106 -0
  201. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/api_constants.rb.ut.rb +31 -0
  202. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/buffer_item.rb +47 -0
  203. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/buffer_item.rb.ut.rb +36 -0
  204. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_advapi32.rb +1818 -0
  205. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_iphlpapi.rb +96 -0
  206. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_kernel32.rb +3848 -0
  207. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_netapi32.rb +26 -0
  208. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ntdll.rb +153 -0
  209. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_shell32.rb +21 -0
  210. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_user32.rb +3169 -0
  211. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ws2_32.rb +599 -0
  212. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll.rb +318 -0
  213. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_function.rb +100 -0
  214. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_function.rb.ut.rb +42 -0
  215. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_helper.rb +148 -0
  216. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_helper.rb.ut.rb +127 -0
  217. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/multicall.rb +309 -0
  218. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/railgun.rb +204 -0
  219. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/tlv.rb +51 -0
  220. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/util.rb +630 -0
  221. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/win_const_manager.rb +75 -0
  222. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/win_const_manager.rb.ut.rb +103 -0
  223. data/lib/rex/post/meterpreter/extensions/stdapi/stdapi.rb +149 -0
  224. data/lib/rex/post/meterpreter/extensions/stdapi/sys/config.rb +97 -0
  225. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log.rb +192 -0
  226. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log_subsystem/event_record.rb +41 -0
  227. data/lib/rex/post/meterpreter/extensions/stdapi/sys/power.rb +61 -0
  228. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process.rb +370 -0
  229. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/image.rb +129 -0
  230. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/io.rb +55 -0
  231. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/memory.rb +336 -0
  232. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/thread.rb +141 -0
  233. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb +279 -0
  234. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_key.rb +193 -0
  235. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_value.rb +102 -0
  236. data/lib/rex/post/meterpreter/extensions/stdapi/sys/thread.rb +180 -0
  237. data/lib/rex/post/meterpreter/extensions/stdapi/tlv.rb +211 -0
  238. data/lib/rex/post/meterpreter/extensions/stdapi/ui.rb +227 -0
  239. data/lib/rex/post/meterpreter/extensions/stdapi/webcam/webcam.rb +63 -0
  240. data/lib/rex/post/meterpreter/inbound_packet_handler.rb +30 -0
  241. data/lib/rex/post/meterpreter/object_aliases.rb +83 -0
  242. data/lib/rex/post/meterpreter/packet.rb +688 -0
  243. data/lib/rex/post/meterpreter/packet_dispatcher.rb +431 -0
  244. data/lib/rex/post/meterpreter/packet_parser.rb +94 -0
  245. data/lib/rex/post/meterpreter/packet_response_waiter.rb +83 -0
  246. data/lib/rex/post/meterpreter/ui/console.rb +137 -0
  247. data/lib/rex/post/meterpreter/ui/console/command_dispatcher.rb +62 -0
  248. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/core.rb +730 -0
  249. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/espia.rb +108 -0
  250. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/incognito.rb +241 -0
  251. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/networkpug.rb +231 -0
  252. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv.rb +61 -0
  253. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/elevate.rb +98 -0
  254. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/passwd.rb +51 -0
  255. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/timestomp.rb +132 -0
  256. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/sniffer.rb +187 -0
  257. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi.rb +65 -0
  258. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/fs.rb +442 -0
  259. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/net.rb +298 -0
  260. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/sys.rb +486 -0
  261. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/ui.rb +315 -0
  262. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/webcam.rb +157 -0
  263. data/lib/rex/post/meterpreter/ui/console/interactive_channel.rb +95 -0
  264. data/lib/rex/post/permission.rb +26 -0
  265. data/lib/rex/post/process.rb +57 -0
  266. data/lib/rex/post/thread.rb +57 -0
  267. data/lib/rex/post/ui.rb +52 -0
  268. data/lib/rex/proto.rb +13 -0
  269. data/lib/rex/proto.rb.ts.rb +8 -0
  270. data/lib/rex/proto/dcerpc.rb +6 -0
  271. data/lib/rex/proto/dcerpc.rb.ts.rb +9 -0
  272. data/lib/rex/proto/dcerpc/client.rb +361 -0
  273. data/lib/rex/proto/dcerpc/client.rb.ut.rb +491 -0
  274. data/lib/rex/proto/dcerpc/exceptions.rb +150 -0
  275. data/lib/rex/proto/dcerpc/handle.rb +47 -0
  276. data/lib/rex/proto/dcerpc/handle.rb.ut.rb +85 -0
  277. data/lib/rex/proto/dcerpc/ndr.rb +72 -0
  278. data/lib/rex/proto/dcerpc/ndr.rb.ut.rb +41 -0
  279. data/lib/rex/proto/dcerpc/packet.rb +253 -0
  280. data/lib/rex/proto/dcerpc/packet.rb.ut.rb +56 -0
  281. data/lib/rex/proto/dcerpc/response.rb +187 -0
  282. data/lib/rex/proto/dcerpc/response.rb.ut.rb +15 -0
  283. data/lib/rex/proto/dcerpc/uuid.rb +84 -0
  284. data/lib/rex/proto/dcerpc/uuid.rb.ut.rb +46 -0
  285. data/lib/rex/proto/dhcp.rb +7 -0
  286. data/lib/rex/proto/dhcp/constants.rb +33 -0
  287. data/lib/rex/proto/dhcp/server.rb +292 -0
  288. data/lib/rex/proto/drda.rb +5 -0
  289. data/lib/rex/proto/drda.rb.ts.rb +17 -0
  290. data/lib/rex/proto/drda/constants.rb +49 -0
  291. data/lib/rex/proto/drda/constants.rb.ut.rb +23 -0
  292. data/lib/rex/proto/drda/packet.rb +252 -0
  293. data/lib/rex/proto/drda/packet.rb.ut.rb +109 -0
  294. data/lib/rex/proto/drda/utils.rb +123 -0
  295. data/lib/rex/proto/drda/utils.rb.ut.rb +84 -0
  296. data/lib/rex/proto/http.rb +5 -0
  297. data/lib/rex/proto/http.rb.ts.rb +12 -0
  298. data/lib/rex/proto/http/client.rb +821 -0
  299. data/lib/rex/proto/http/client.rb.ut.rb +95 -0
  300. data/lib/rex/proto/http/handler.rb +46 -0
  301. data/lib/rex/proto/http/handler/erb.rb +128 -0
  302. data/lib/rex/proto/http/handler/erb.rb.ut.rb +21 -0
  303. data/lib/rex/proto/http/handler/erb.rb.ut.rb.rhtml +1 -0
  304. data/lib/rex/proto/http/handler/proc.rb +60 -0
  305. data/lib/rex/proto/http/handler/proc.rb.ut.rb +24 -0
  306. data/lib/rex/proto/http/header.rb +161 -0
  307. data/lib/rex/proto/http/header.rb.ut.rb +46 -0
  308. data/lib/rex/proto/http/packet.rb +407 -0
  309. data/lib/rex/proto/http/packet.rb.ut.rb +165 -0
  310. data/lib/rex/proto/http/request.rb +356 -0
  311. data/lib/rex/proto/http/request.rb.ut.rb +214 -0
  312. data/lib/rex/proto/http/response.rb +90 -0
  313. data/lib/rex/proto/http/response.rb.ut.rb +149 -0
  314. data/lib/rex/proto/http/server.rb +369 -0
  315. data/lib/rex/proto/http/server.rb.ut.rb +79 -0
  316. data/lib/rex/proto/ntlm.rb +7 -0
  317. data/lib/rex/proto/ntlm.rb.ut.rb +177 -0
  318. data/lib/rex/proto/ntlm/base.rb +326 -0
  319. data/lib/rex/proto/ntlm/constants.rb +74 -0
  320. data/lib/rex/proto/ntlm/crypt.rb +415 -0
  321. data/lib/rex/proto/ntlm/exceptions.rb +16 -0
  322. data/lib/rex/proto/ntlm/message.rb +536 -0
  323. data/lib/rex/proto/ntlm/utils.rb +764 -0
  324. data/lib/rex/proto/proxy/socks4a.rb +440 -0
  325. data/lib/rex/proto/rfb.rb +19 -0
  326. data/lib/rex/proto/rfb.rb.ut.rb +37 -0
  327. data/lib/rex/proto/rfb/cipher.rb +84 -0
  328. data/lib/rex/proto/rfb/client.rb +207 -0
  329. data/lib/rex/proto/rfb/constants.rb +52 -0
  330. data/lib/rex/proto/smb.rb +7 -0
  331. data/lib/rex/proto/smb.rb.ts.rb +8 -0
  332. data/lib/rex/proto/smb/client.rb +1952 -0
  333. data/lib/rex/proto/smb/client.rb.ut.rb +223 -0
  334. data/lib/rex/proto/smb/constants.rb +1047 -0
  335. data/lib/rex/proto/smb/constants.rb.ut.rb +18 -0
  336. data/lib/rex/proto/smb/crypt.rb +36 -0
  337. data/lib/rex/proto/smb/evasions.rb +66 -0
  338. data/lib/rex/proto/smb/exceptions.rb +858 -0
  339. data/lib/rex/proto/smb/simpleclient.rb +306 -0
  340. data/lib/rex/proto/smb/simpleclient.rb.ut.rb +128 -0
  341. data/lib/rex/proto/smb/utils.rb +103 -0
  342. data/lib/rex/proto/smb/utils.rb.ut.rb +20 -0
  343. data/lib/rex/proto/sunrpc.rb +1 -0
  344. data/lib/rex/proto/sunrpc/client.rb +195 -0
  345. data/lib/rex/proto/tftp.rb +12 -0
  346. data/lib/rex/proto/tftp/constants.rb +39 -0
  347. data/lib/rex/proto/tftp/server.rb +497 -0
  348. data/lib/rex/proto/tftp/server.rb.ut.rb +28 -0
  349. data/lib/rex/script.rb +42 -0
  350. data/lib/rex/script/base.rb +59 -0
  351. data/lib/rex/script/meterpreter.rb +15 -0
  352. data/lib/rex/script/shell.rb +9 -0
  353. data/lib/rex/service.rb +48 -0
  354. data/lib/rex/service_manager.rb +141 -0
  355. data/lib/rex/service_manager.rb.ut.rb +32 -0
  356. data/lib/rex/services/local_relay.rb +423 -0
  357. data/lib/rex/socket.rb +684 -0
  358. data/lib/rex/socket.rb.ut.rb +107 -0
  359. data/lib/rex/socket/comm.rb +119 -0
  360. data/lib/rex/socket/comm/local.rb +412 -0
  361. data/lib/rex/socket/comm/local.rb.ut.rb +75 -0
  362. data/lib/rex/socket/ip.rb +130 -0
  363. data/lib/rex/socket/parameters.rb +345 -0
  364. data/lib/rex/socket/parameters.rb.ut.rb +51 -0
  365. data/lib/rex/socket/range_walker.rb +346 -0
  366. data/lib/rex/socket/range_walker.rb.ut.rb +55 -0
  367. data/lib/rex/socket/ssl_tcp.rb +184 -0
  368. data/lib/rex/socket/ssl_tcp.rb.ut.rb +39 -0
  369. data/lib/rex/socket/ssl_tcp_server.rb +122 -0
  370. data/lib/rex/socket/ssl_tcp_server.rb.ut.rb +61 -0
  371. data/lib/rex/socket/subnet_walker.rb +75 -0
  372. data/lib/rex/socket/subnet_walker.rb.ut.rb +28 -0
  373. data/lib/rex/socket/switch_board.rb +278 -0
  374. data/lib/rex/socket/switch_board.rb.ut.rb +52 -0
  375. data/lib/rex/socket/tcp.rb +76 -0
  376. data/lib/rex/socket/tcp.rb.ut.rb +64 -0
  377. data/lib/rex/socket/tcp_server.rb +66 -0
  378. data/lib/rex/socket/tcp_server.rb.ut.rb +44 -0
  379. data/lib/rex/socket/udp.rb +164 -0
  380. data/lib/rex/socket/udp.rb.ut.rb +44 -0
  381. data/lib/rex/struct2.rb +5 -0
  382. data/lib/rex/struct2/c_struct.rb +181 -0
  383. data/lib/rex/struct2/c_struct_template.rb +39 -0
  384. data/lib/rex/struct2/constant.rb +26 -0
  385. data/lib/rex/struct2/element.rb +44 -0
  386. data/lib/rex/struct2/generic.rb +73 -0
  387. data/lib/rex/struct2/restraint.rb +54 -0
  388. data/lib/rex/struct2/s_string.rb +72 -0
  389. data/lib/rex/struct2/s_struct.rb +111 -0
  390. data/lib/rex/sync.rb +6 -0
  391. data/lib/rex/sync/event.rb +94 -0
  392. data/lib/rex/sync/read_write_lock.rb +176 -0
  393. data/lib/rex/sync/ref.rb +57 -0
  394. data/lib/rex/sync/thread_safe.rb +82 -0
  395. data/lib/rex/test.rb +35 -0
  396. data/lib/rex/text.rb +1163 -0
  397. data/lib/rex/text.rb.ut.rb +190 -0
  398. data/lib/rex/thread_factory.rb +42 -0
  399. data/lib/rex/time.rb +65 -0
  400. data/lib/rex/transformer.rb +115 -0
  401. data/lib/rex/transformer.rb.ut.rb +38 -0
  402. data/lib/rex/ui.rb +21 -0
  403. data/lib/rex/ui/interactive.rb +298 -0
  404. data/lib/rex/ui/output.rb +78 -0
  405. data/lib/rex/ui/output/none.rb +18 -0
  406. data/lib/rex/ui/progress_tracker.rb +96 -0
  407. data/lib/rex/ui/subscriber.rb +149 -0
  408. data/lib/rex/ui/text/color.rb +97 -0
  409. data/lib/rex/ui/text/color.rb.ut.rb +18 -0
  410. data/lib/rex/ui/text/dispatcher_shell.rb +467 -0
  411. data/lib/rex/ui/text/input.rb +117 -0
  412. data/lib/rex/ui/text/input/buffer.rb +75 -0
  413. data/lib/rex/ui/text/input/readline.rb +129 -0
  414. data/lib/rex/ui/text/input/socket.rb +95 -0
  415. data/lib/rex/ui/text/input/stdio.rb +45 -0
  416. data/lib/rex/ui/text/irb_shell.rb +57 -0
  417. data/lib/rex/ui/text/output.rb +80 -0
  418. data/lib/rex/ui/text/output/buffer.rb +61 -0
  419. data/lib/rex/ui/text/output/file.rb +43 -0
  420. data/lib/rex/ui/text/output/socket.rb +43 -0
  421. data/lib/rex/ui/text/output/stdio.rb +40 -0
  422. data/lib/rex/ui/text/progress_tracker.rb +56 -0
  423. data/lib/rex/ui/text/progress_tracker.rb.ut.rb +34 -0
  424. data/lib/rex/ui/text/shell.rb +328 -0
  425. data/lib/rex/ui/text/table.rb +279 -0
  426. data/lib/rex/ui/text/table.rb.ut.rb +55 -0
  427. data/lib/rex/zip.rb +93 -0
  428. data/lib/rex/zip/archive.rb +184 -0
  429. data/lib/rex/zip/blocks.rb +182 -0
  430. data/lib/rex/zip/entry.rb +104 -0
  431. data/lib/rex/zip/samples/comment.rb +32 -0
  432. data/lib/rex/zip/samples/mkwar.rb +138 -0
  433. data/lib/rex/zip/samples/mkzip.rb +19 -0
  434. data/lib/rex/zip/samples/recursive.rb +58 -0
  435. metadata +434 -1
@@ -0,0 +1,141 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'rex/post/meterpreter/client'
4
+ require 'rex/post/meterpreter/extensions/stdapi/constants'
5
+ require 'rex/post/meterpreter/extensions/stdapi/sys/thread'
6
+
7
+ module Rex
8
+ module Post
9
+ module Meterpreter
10
+ module Extensions
11
+ module Stdapi
12
+ module Sys
13
+ module ProcessSubsystem
14
+
15
+ ###
16
+ #
17
+ # Interfaces with a process' executing threads by enumerating,
18
+ # opening, and creating threads.
19
+ #
20
+ ###
21
+ class Thread
22
+
23
+ ##
24
+ #
25
+ # Constructor
26
+ #
27
+ ##
28
+
29
+ #
30
+ # Initializes a thread instance that operates in the context of the
31
+ # supplied process instance.
32
+ #
33
+ def initialize(process)
34
+ self.process = process
35
+ end
36
+
37
+ ##
38
+ #
39
+ # Process thread interaction
40
+ #
41
+ ##
42
+
43
+ #
44
+ # Opens an existing thread that is running within the context
45
+ # of the process and returns a Sys::Thread instance.
46
+ #
47
+ def open(tid, access = THREAD_ALL)
48
+ request = Packet.create_request('stdapi_sys_process_thread_open')
49
+ real = 0
50
+
51
+ # Translate access
52
+ if (access & THREAD_READ)
53
+ real |= THREAD_GET_CONTEXT | THREAD_QUERY_INFORMATION | SYNCHRONIZE
54
+ end
55
+
56
+ if (access & THREAD_WRITE)
57
+ real |= THREAD_SET_CONTEXT | THREAD_SET_INFORMATION | THREAD_SET_THREAD_TOKEN | THREAD_IMPERSONATE | THREAD_DIRECT_IMPERSONATION
58
+ end
59
+
60
+ if (access & THREAD_EXECUTE)
61
+ real |= THREAD_TERMINATE | THREAD_SUSPEND_RESUME | SYNCHRONIZE
62
+ end
63
+
64
+ # Add the thread identifier and permissions
65
+ request.add_tlv(TLV_TYPE_THREAD_ID, tid)
66
+ request.add_tlv(TLV_TYPE_THREAD_PERMS, real)
67
+
68
+ # Transmit the request
69
+ response = process.client.send_request(request)
70
+
71
+ # Create a thread class instance
72
+ return Rex::Post::Meterpreter::Extensions::Stdapi::Sys::Thread.new(
73
+ process, response.get_tlv_value(TLV_TYPE_THREAD_HANDLE), tid)
74
+ end
75
+
76
+ #
77
+ # Creates a new thread in the context of the process and
78
+ # returns a Sys::Thread instance.
79
+ #
80
+ def create(entry, parameter = nil, suspended = false)
81
+ request = Packet.create_request('stdapi_sys_process_thread_create')
82
+ creation_flags = 0
83
+
84
+ request.add_tlv(TLV_TYPE_PROCESS_HANDLE, process.handle)
85
+ request.add_tlv(TLV_TYPE_ENTRY_POINT, entry)
86
+
87
+ # Are we passing a parameter to the entry point of the thread?
88
+ if (parameter != nil)
89
+ request.add_tlv(TLV_TYPE_ENTRY_PARAMETER, parameter)
90
+ end
91
+
92
+ # Should we create the thread suspended?
93
+ if (suspended)
94
+ creation_flags |= CREATE_SUSPENDED
95
+ end
96
+
97
+ request.add_tlv(TLV_TYPE_CREATION_FLAGS, creation_flags)
98
+
99
+ # Transmit the request
100
+ response = process.client.send_request(request)
101
+
102
+
103
+ thread_id = response.get_tlv_value(TLV_TYPE_THREAD_ID)
104
+ thread_handle = response.get_tlv_value(TLV_TYPE_THREAD_HANDLE)
105
+
106
+ # Create a thread class instance
107
+ return Rex::Post::Meterpreter::Extensions::Stdapi::Sys::Thread.new(
108
+ process, thread_handle, thread_id)
109
+ end
110
+
111
+ #
112
+ # Enumerate through each thread identifier.
113
+ #
114
+ def each_thread(&block)
115
+ get_threads.each(&block)
116
+ end
117
+
118
+ #
119
+ # Returns an array of thread identifiers.
120
+ #
121
+ def get_threads
122
+ request = Packet.create_request('stdapi_sys_process_thread_get_threads')
123
+ threads = []
124
+
125
+ request.add_tlv(TLV_TYPE_PID, process.pid)
126
+
127
+ response = process.client.send_request(request)
128
+
129
+ response.each(TLV_TYPE_THREAD_ID) { |thr|
130
+ threads << thr.value
131
+ }
132
+
133
+ return threads
134
+ end
135
+
136
+ protected
137
+ attr_accessor :process # :nodoc:
138
+
139
+ end
140
+
141
+ end; end; end; end; end; end; end
@@ -0,0 +1,279 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'rex/post/process'
4
+ require 'rex/post/meterpreter/packet'
5
+ require 'rex/post/meterpreter/client'
6
+ require 'rex/post/meterpreter/extensions/stdapi/constants'
7
+ require 'rex/post/meterpreter/extensions/stdapi/stdapi'
8
+ require 'rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_key'
9
+ require 'rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_value'
10
+
11
+ module Rex
12
+ module Post
13
+ module Meterpreter
14
+ module Extensions
15
+ module Stdapi
16
+ module Sys
17
+
18
+ ###
19
+ #
20
+ # This class provides access to the Windows registry on the remote
21
+ # machine.
22
+ #
23
+ ###
24
+ class Registry
25
+
26
+ class << self
27
+ attr_accessor :client
28
+ end
29
+
30
+ ##
31
+ #
32
+ # Registry key interaction
33
+ #
34
+ ##
35
+
36
+ #
37
+ # Opens the supplied registry key relative to the root key with
38
+ # the supplied permissions. Right now this is merely a wrapper around
39
+ # create_key.
40
+ #
41
+ def Registry.open_key(root_key, base_key, perm = KEY_READ)
42
+ # If no base key was provided, just return the root_key.
43
+ if (base_key == nil or base_key.length == 0)
44
+ return RegistrySubsystem::RegistryKey.new(client, root_key, base_key, perm, root_key)
45
+ end
46
+
47
+ return self.create_key(root_key, base_key, perm)
48
+ end
49
+
50
+ #
51
+ # Creates the supplied registry key or opens it if it already exists.
52
+ #
53
+ def Registry.create_key(root_key, base_key, perm = KEY_READ)
54
+ request = Packet.create_request('stdapi_registry_create_key')
55
+
56
+ request.add_tlv(TLV_TYPE_ROOT_KEY, root_key)
57
+ request.add_tlv(TLV_TYPE_BASE_KEY, base_key)
58
+ request.add_tlv(TLV_TYPE_PERMISSION, perm)
59
+
60
+ response = client.send_request(request)
61
+
62
+ return Rex::Post::Meterpreter::Extensions::Stdapi::Sys::RegistrySubsystem::RegistryKey.new(
63
+ client, root_key, base_key, perm, response.get_tlv(TLV_TYPE_HKEY).value)
64
+ end
65
+
66
+ #
67
+ # Deletes the supplied registry key.
68
+ #
69
+ def Registry.delete_key(root_key, base_key, recursive = true)
70
+ request = Packet.create_request('stdapi_registry_delete_key')
71
+ flags = 0
72
+
73
+ if (recursive)
74
+ flags |= DELETE_KEY_FLAG_RECURSIVE
75
+ end
76
+
77
+ request.add_tlv(TLV_TYPE_ROOT_KEY, root_key)
78
+ request.add_tlv(TLV_TYPE_BASE_KEY, base_key)
79
+ request.add_tlv(TLV_TYPE_FLAGS, flags)
80
+
81
+ if (client.send_request(request) != nil)
82
+ return true
83
+ end
84
+
85
+ return false
86
+ end
87
+
88
+ #
89
+ # Closes the supplied registry key.
90
+ #
91
+ def Registry.close_key(hkey)
92
+ request = Packet.create_request('stdapi_registry_close_key')
93
+
94
+ request.add_tlv(TLV_TYPE_HKEY, hkey)
95
+
96
+ client.send_packet(request)
97
+
98
+ return true
99
+ end
100
+
101
+ #
102
+ # Enumerates the supplied registry key returning an array of key names.
103
+ #
104
+ def Registry.enum_key(hkey)
105
+ keys = []
106
+ request = Packet.create_request('stdapi_registry_enum_key')
107
+
108
+ request.add_tlv(TLV_TYPE_HKEY, hkey)
109
+
110
+ response = client.send_request(request)
111
+
112
+ # Enumerate through all of the registry keys
113
+ response.each(TLV_TYPE_KEY_NAME) { |key_name|
114
+ keys << key_name.value
115
+ }
116
+
117
+ return keys
118
+ end
119
+
120
+ ##
121
+ #
122
+ # Registry value interaction
123
+ #
124
+ ##
125
+
126
+ #
127
+ # Sets the registry value relative to the supplied hkey.
128
+ #
129
+ def Registry.set_value(hkey, name, type, data)
130
+ request = Packet.create_request('stdapi_registry_set_value')
131
+
132
+ request.add_tlv(TLV_TYPE_HKEY, hkey)
133
+ request.add_tlv(TLV_TYPE_VALUE_NAME, name)
134
+ request.add_tlv(TLV_TYPE_VALUE_TYPE, type)
135
+
136
+ if (type == REG_SZ)
137
+ data += "\x00"
138
+ elsif (type == REG_DWORD)
139
+ data = [ data.to_i ].pack("V")
140
+ end
141
+
142
+ request.add_tlv(TLV_TYPE_VALUE_DATA, data)
143
+
144
+ response = client.send_request(request)
145
+
146
+ return true
147
+ end
148
+
149
+ #
150
+ # Queries the registry value supplied in name and returns an
151
+ # initialized RegistryValue instance if a match is found.
152
+ #
153
+ def Registry.query_value(hkey, name)
154
+ request = Packet.create_request('stdapi_registry_query_value')
155
+
156
+ request.add_tlv(TLV_TYPE_HKEY, hkey)
157
+ request.add_tlv(TLV_TYPE_VALUE_NAME, name)
158
+
159
+ response = client.send_request(request)
160
+
161
+ data = response.get_tlv(TLV_TYPE_VALUE_DATA).value;
162
+ type = response.get_tlv(TLV_TYPE_VALUE_TYPE).value;
163
+
164
+ if (type == REG_SZ)
165
+ data = data[0..-2]
166
+ elsif (type == REG_DWORD)
167
+ data = data.unpack("N")[0]
168
+ end
169
+
170
+ return Rex::Post::Meterpreter::Extensions::Stdapi::Sys::RegistrySubsystem::RegistryValue.new(
171
+ client, hkey, name, type, data)
172
+ end
173
+
174
+ #
175
+ # Deletes the registry value supplied in name from the supplied
176
+ # registry key.
177
+ #
178
+ def Registry.delete_value(hkey, name)
179
+ request = Packet.create_request('stdapi_registry_delete_value')
180
+
181
+ request.add_tlv(TLV_TYPE_HKEY, hkey)
182
+ request.add_tlv(TLV_TYPE_VALUE_NAME, name)
183
+
184
+ if (client.send_request(request) != nil)
185
+ return true
186
+ end
187
+
188
+ return false
189
+ end
190
+
191
+ #
192
+ # Queries the registry class name and returns a string
193
+ #
194
+ def Registry.query_class(hkey)
195
+ request = Packet.create_request('stdapi_registry_query_class')
196
+
197
+ request.add_tlv(TLV_TYPE_HKEY, hkey)
198
+
199
+ response = client.send_request(request)
200
+ cls = response.get_tlv(TLV_TYPE_VALUE_DATA)
201
+ return nil if not cls
202
+ data = cls.value.gsub(/\x00.*/, '')
203
+ return data
204
+ end
205
+
206
+ #
207
+ # Enumerates all of the values at the supplied hkey including their
208
+ # names. An array of RegistryValue's is returned.
209
+ #
210
+ def Registry.enum_value(hkey)
211
+ request = Packet.create_request('stdapi_registry_enum_value')
212
+ values = []
213
+
214
+ request.add_tlv(TLV_TYPE_HKEY, hkey)
215
+
216
+ response = client.send_request(request)
217
+
218
+ response.each(TLV_TYPE_VALUE_NAME) { |value_name|
219
+ values << Rex::Post::Meterpreter::Extensions::Stdapi::Sys::RegistrySubsystem::RegistryValue.new(
220
+ client, hkey, value_name.value)
221
+ }
222
+
223
+ return values
224
+ end
225
+
226
+ #
227
+ # Return the key value associated with the supplied string. This is useful
228
+ # for converting HKLM as a string into its actual integer representation.
229
+ #
230
+ def self.key2str(key)
231
+ if (key == 'HKLM' or key == 'HKEY_LOCAL_MACHINE')
232
+ return HKEY_LOCAL_MACHINE
233
+ elsif (key == 'HKCU' or key == 'HKEY_CURRENT_USER')
234
+ return HKEY_CURRENT_USER
235
+ elsif (key == 'HKU' or key == 'HKEY_USERS')
236
+ return HKEY_USERS
237
+ elsif (key == 'HKCR' or key == 'HKEY_CLASSES_ROOT')
238
+ return HKEY_CLASSES_ROOT
239
+ elsif (key == 'HKEY_CURRENT_CONFIG')
240
+ return HKEY_CURRENT_CONFIG
241
+ elsif (key == 'HKEY_PERFORMANCE_DATA')
242
+ return HKEY_PERFORMANCE_DATA
243
+ elsif (key == 'HKEY_DYN_DATA')
244
+ return HKEY_DYN_DATA
245
+ else
246
+ raise ArgumentError, "Unknown key: #{key}"
247
+ end
248
+ end
249
+
250
+ #
251
+ # Returns the integer value associated with the supplied registry value
252
+ # type (like REG_SZ).
253
+ #
254
+ def self.type2str(type)
255
+ return REG_SZ if (type == 'REG_SZ')
256
+ return REG_DWORD if (type == 'REG_DWORD')
257
+ return REG_BINARY if (type == 'REG_BINARY')
258
+ return REG_EXPAND_SZ if (type == 'REG_EXPAND_SZ')
259
+ return REG_NONE if (type == 'REG_NONE')
260
+ return nil
261
+ end
262
+
263
+ #
264
+ # Split the supplied full registry key into its root key and base key. For
265
+ # instance, passing HKLM\Software\Dog will return [ HKEY_LOCAL_MACHINE,
266
+ # 'Software\Dog' ]
267
+ #
268
+ def self.splitkey(str)
269
+ if (str =~ /^(.+?)\\(.*)$/)
270
+ [ key2str($1), $2 ]
271
+ else
272
+ [ key2str(str), nil ]
273
+ end
274
+ end
275
+
276
+ end
277
+
278
+ end; end; end; end; end; end
279
+
@@ -0,0 +1,193 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'rex/post/meterpreter/extensions/stdapi/constants'
4
+ require 'rex/post/meterpreter/extensions/stdapi/sys/registry'
5
+
6
+ module Rex
7
+ module Post
8
+ module Meterpreter
9
+ module Extensions
10
+ module Stdapi
11
+ module Sys
12
+ module RegistrySubsystem
13
+
14
+ ###
15
+ #
16
+ # Class wrapper around a logical registry key on the remote side
17
+ #
18
+ ###
19
+ class RegistryKey
20
+
21
+
22
+ #
23
+ # Initializes an instance of a registry key using the supplied properties
24
+ # and HKEY handle from the server.
25
+ #
26
+ def initialize(client, root_key, base_key, perm, hkey)
27
+ self.client = client
28
+ self.root_key = root_key
29
+ self.base_key = base_key
30
+ self.perm = perm
31
+ self.hkey = hkey
32
+
33
+ ObjectSpace.define_finalizer( self, self.class.finalize(self.client, self.hkey) )
34
+ end
35
+
36
+ def self.finalize(client,hkey)
37
+ proc { self.close(client,hkey) }
38
+ end
39
+
40
+ ##
41
+ #
42
+ # Enumerators
43
+ #
44
+ ##
45
+
46
+ #
47
+ # Enumerates all of the child keys within this registry key.
48
+ #
49
+ def each_key(&block)
50
+ return enum_key.each(&block)
51
+ end
52
+
53
+ #
54
+ # Enumerates all of the child values within this registry key.
55
+ #
56
+ def each_value(&block)
57
+ return enum_value.each(&block)
58
+ end
59
+
60
+ #
61
+ # Retrieves all of the registry keys that are direct descendents of
62
+ # the class' registry key.
63
+ #
64
+ def enum_key()
65
+ return self.client.sys.registry.enum_key(self.hkey)
66
+ end
67
+
68
+ #
69
+ # Retrieves all of the registry values that exist within the opened
70
+ # registry key.
71
+ #
72
+ def enum_value()
73
+ return self.client.sys.registry.enum_value(self.hkey)
74
+ end
75
+
76
+
77
+ ##
78
+ #
79
+ # Registry key interaction
80
+ #
81
+ ##
82
+
83
+ #
84
+ # Opens a registry key that is relative to this registry key.
85
+ #
86
+ def open_key(base_key, perm = KEY_READ)
87
+ return self.client.sys.registry.open_key(self.hkey, base_key, perm)
88
+ end
89
+
90
+ #
91
+ # Creates a registry key that is relative to this registry key.
92
+ #
93
+ def create_key(base_key, perm = KEY_READ)
94
+ return self.client.sys.registry.create_key(self.hkey, base_key, perm)
95
+ end
96
+
97
+ #
98
+ # Deletes a registry key that is relative to this registry key.
99
+ #
100
+ def delete_key(base_key, recursive = true)
101
+ return self.client.sys.registry.delete_key(self.hkey, base_key, recursive)
102
+ end
103
+
104
+ #
105
+ # Closes the open key. This must be called if the registry
106
+ # key was opened.
107
+ #
108
+ def self.close(client, hkey)
109
+ if hkey != nil
110
+ return client.sys.registry.close_key(hkey)
111
+ end
112
+
113
+ return false
114
+ end
115
+
116
+ # Instance method for the same
117
+ def close()
118
+ self.class.close(self.client, self.hkey)
119
+ end
120
+
121
+ ##
122
+ #
123
+ # Registry value interaction
124
+ #
125
+ ##
126
+
127
+ #
128
+ # Sets a value relative to the opened registry key.
129
+ #
130
+ def set_value(name, type, data)
131
+ return self.client.sys.registry.set_value(self.hkey, name, type, data)
132
+ end
133
+
134
+ #
135
+ # Queries the attributes of the supplied registry value relative to
136
+ # the opened registry key.
137
+ #
138
+ def query_value(name)
139
+ return self.client.sys.registry.query_value(self.hkey, name)
140
+ end
141
+
142
+ #
143
+ # Queries the class of the specified key
144
+ #
145
+ def query_class
146
+ return self.client.sys.registry.query_class(self.hkey)
147
+ end
148
+
149
+ #
150
+ # Delete the supplied registry value.
151
+ #
152
+ def delete_value(name)
153
+ return self.client.sys.registry.delete_value(self.hkey, name)
154
+ end
155
+
156
+ ##
157
+ #
158
+ # Serializers
159
+ #
160
+ ##
161
+
162
+ #
163
+ # Returns the path to the key.
164
+ #
165
+ def to_s
166
+ return self.root_key.to_s + "\\" + self.base_key
167
+ end
168
+
169
+ #
170
+ # The open handle to the key on the server.
171
+ #
172
+ attr_reader :hkey
173
+ #
174
+ # The root key name, such as HKEY_LOCAL_MACHINE.
175
+ #
176
+ attr_reader :root_key
177
+ #
178
+ # The base key name, such as Software\Foo.
179
+ #
180
+ attr_reader :base_key
181
+ #
182
+ # The permissions that the key was opened with.
183
+ #
184
+ attr_reader :perm
185
+
186
+ protected
187
+
188
+ attr_accessor :client # :nodoc:
189
+ attr_writer :hkey, :root_key, :base_key, :perm # :nodoc:
190
+ end
191
+
192
+ end; end; end; end; end; end; end
193
+