Class: Rex::Post::Meterpreter::Extensions::Stdapi::Sys::Registry

Inherits:
Object
  • Object
show all
Defined in:
lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb

Overview

This class provides access to the Windows registry on the remote machine.

Class Attribute Summary collapse

Class Method Summary collapse

Class Attribute Details

.clientObject

Returns the value of attribute client.



29
30
31
# File 'lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb', line 29

def client
  @client
end

Class Method Details

.close_key(hkey) ⇒ Object

Closes the supplied registry key.



141
142
143
144
145
146
147
148
149
# File 'lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb', line 141

def Registry.close_key(hkey)
	request = Packet.create_request('stdapi_registry_close_key')

	request.add_tlv(TLV_TYPE_HKEY, hkey)

	client.send_packet(request)

	return true
end

.create_key(root_key, base_key, perm = KEY_READ) ⇒ Object

Creates the supplied registry key or opens it if it already exists.



103
104
105
106
107
108
109
110
111
112
113
114
# File 'lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb', line 103

def Registry.create_key(root_key, base_key, perm = KEY_READ)
	request = Packet.create_request('stdapi_registry_create_key')

	request.add_tlv(TLV_TYPE_ROOT_KEY, root_key)
	request.add_tlv(TLV_TYPE_BASE_KEY, base_key)
	request.add_tlv(TLV_TYPE_PERMISSION, perm)

	response = client.send_request(request)

	return Rex::Post::Meterpreter::Extensions::Stdapi::Sys::RegistrySubsystem::RegistryKey.new(
			client, root_key, base_key, perm, response.get_tlv(TLV_TYPE_HKEY).value)
end

.delete_key(root_key, base_key, recursive = true) ⇒ Object

Deletes the supplied registry key.



119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
# File 'lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb', line 119

def Registry.delete_key(root_key, base_key, recursive = true)
	request = Packet.create_request('stdapi_registry_delete_key')
	flags   = 0

	if (recursive)
		flags |= DELETE_KEY_FLAG_RECURSIVE
	end

	request.add_tlv(TLV_TYPE_ROOT_KEY, root_key)
	request.add_tlv(TLV_TYPE_BASE_KEY, base_key)
	request.add_tlv(TLV_TYPE_FLAGS, flags)

	if (client.send_request(request) != nil)
		return true
	end

	return false
end

.delete_value(hkey, name) ⇒ Object

Deletes the registry value supplied in name from the supplied registry key.



228
229
230
231
232
233
234
235
236
237
238
239
# File 'lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb', line 228

def Registry.delete_value(hkey, name)
	request = Packet.create_request('stdapi_registry_delete_value')

	request.add_tlv(TLV_TYPE_HKEY, hkey)
	request.add_tlv(TLV_TYPE_VALUE_NAME, name)

	if (client.send_request(request) != nil)
		return true
	end

	return false
end

.enum_key(hkey) ⇒ Object

Enumerates the supplied registry key returning an array of key names.



154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
# File 'lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb', line 154

def Registry.enum_key(hkey)
	keys    = []
	request = Packet.create_request('stdapi_registry_enum_key')

	request.add_tlv(TLV_TYPE_HKEY, hkey)

	response = client.send_request(request)

	# Enumerate through all of the registry keys
	response.each(TLV_TYPE_KEY_NAME) { |key_name|
		keys << key_name.value
	}

	return keys
end

.enum_value(hkey) ⇒ Object

Enumerates all of the values at the supplied hkey including their names. An array of RegistryValue’s is returned.



260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
# File 'lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb', line 260

def Registry.enum_value(hkey)
	request = Packet.create_request('stdapi_registry_enum_value')
	values  = []

	request.add_tlv(TLV_TYPE_HKEY, hkey)

	response = client.send_request(request)

	response.each(TLV_TYPE_VALUE_NAME) { |value_name|
		values << Rex::Post::Meterpreter::Extensions::Stdapi::Sys::RegistrySubsystem::RegistryValue.new(
				client, hkey, value_name.value)
	}

	return values
end

.key2str(key) ⇒ Object

Return the key value associated with the supplied string. This is useful for converting HKLM as a string into its actual integer representation.



280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
# File 'lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb', line 280

def self.key2str(key)
	if (key == 'HKLM' or key == 'HKEY_LOCAL_MACHINE')
		return HKEY_LOCAL_MACHINE
	elsif (key == 'HKCU' or key == 'HKEY_CURRENT_USER')
		return HKEY_CURRENT_USER
	elsif (key == 'HKU' or key == 'HKEY_USERS')
		return HKEY_USERS
	elsif (key == 'HKCR' or key == 'HKEY_CLASSES_ROOT')
		return HKEY_CLASSES_ROOT
	elsif (key == 'HKEY_CURRENT_CONFIG')
		return HKEY_CURRENT_CONFIG
	elsif (key == 'HKEY_PERFORMANCE_DATA')
		return HKEY_PERFORMANCE_DATA
	elsif (key == 'HKEY_DYN_DATA')
		return HKEY_DYN_DATA
	else
		raise ArgumentError, "Unknown key: #{key}"
	end
end

.load_key(root_key, base_key, hive_file) ⇒ Object

Opens the supplied registry key relative to the root key with the supplied permissions. Right now this is merely a wrapper around create_key.



44
45
46
47
48
49
50
51
52
# File 'lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb', line 44

def Registry.load_key(root_key,base_key,hive_file)
	request = Packet.create_request('stdapi_registry_load_key')
	request.add_tlv(TLV_TYPE_ROOT_KEY, root_key)
	request.add_tlv(TLV_TYPE_BASE_KEY, base_key)
	request.add_tlv(TLV_TYPE_FILE_PATH, client.unicode_filter_decode( hive_file ))

	response = client.send_request(request)
	return response.get_tlv(TLV_TYPE_RESULT).value
end

.open_key(root_key, base_key, perm = KEY_READ) ⇒ Object



63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
# File 'lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb', line 63

def Registry.open_key(root_key, base_key, perm = KEY_READ)
	# If no base key was provided, just return the root_key.
	if (base_key == nil or base_key.length == 0)
		return RegistrySubsystem::RegistryKey.new(client, root_key, base_key, perm, root_key)
	end

	request = Packet.create_request('stdapi_registry_open_key')

	request.add_tlv(TLV_TYPE_ROOT_KEY, root_key)
	request.add_tlv(TLV_TYPE_BASE_KEY, base_key)
	request.add_tlv(TLV_TYPE_PERMISSION, perm)

	response = client.send_request(request)

	return Rex::Post::Meterpreter::Extensions::Stdapi::Sys::RegistrySubsystem::RegistryKey.new(
			client, root_key, base_key, perm, response.get_tlv(TLV_TYPE_HKEY).value)
end

.open_remote_key(target_host, root_key) ⇒ Object

Opens the supplied registry key on the specified remote host. Requires that the current process has credentials to access the target and that the target has the remote registry service running.



86
87
88
89
90
91
92
93
94
95
96
97
98
# File 'lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb', line 86

def Registry.open_remote_key(target_host, root_key)

	request = Packet.create_request('stdapi_registry_open_remote_key')

	request.add_tlv(TLV_TYPE_TARGET_HOST, target_host)
	request.add_tlv(TLV_TYPE_ROOT_KEY, root_key)


	response = client.send_request(request)

	return Rex::Post::Meterpreter::Extensions::Stdapi::Sys::RegistrySubsystem::RemoteRegistryKey.new(
			client, target_host, root_key, response.get_tlv(TLV_TYPE_HKEY).value)
end

.query_class(hkey) ⇒ Object

Queries the registry class name and returns a string



244
245
246
247
248
249
250
251
252
253
254
# File 'lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb', line 244

def Registry.query_class(hkey)
	request = Packet.create_request('stdapi_registry_query_class')

	request.add_tlv(TLV_TYPE_HKEY, hkey)

	response = client.send_request(request)
	cls = response.get_tlv(TLV_TYPE_VALUE_DATA)
	return nil if not cls
	data = cls.value.gsub(/\x00.*/, '')
	return data
end

.query_value(hkey, name) ⇒ Object

Queries the registry value supplied in name and returns an initialized RegistryValue instance if a match is found.



203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
# File 'lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb', line 203

def Registry.query_value(hkey, name)
	request = Packet.create_request('stdapi_registry_query_value')

	request.add_tlv(TLV_TYPE_HKEY, hkey)
	request.add_tlv(TLV_TYPE_VALUE_NAME, name)

	response = client.send_request(request)

	data = response.get_tlv(TLV_TYPE_VALUE_DATA).value;
	type = response.get_tlv(TLV_TYPE_VALUE_TYPE).value;

	if (type == REG_SZ)
		data = data[0..-2]
	elsif (type == REG_DWORD)
		data = data.unpack("N")[0]
	end

	return Rex::Post::Meterpreter::Extensions::Stdapi::Sys::RegistrySubsystem::RegistryValue.new(
			client, hkey, name, type, data)
end

.set_value(hkey, name, type, data) ⇒ Object

Sets the registry value relative to the supplied hkey.



179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
# File 'lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb', line 179

def Registry.set_value(hkey, name, type, data)
	request = Packet.create_request('stdapi_registry_set_value')

	request.add_tlv(TLV_TYPE_HKEY, hkey)
	request.add_tlv(TLV_TYPE_VALUE_NAME, name)
	request.add_tlv(TLV_TYPE_VALUE_TYPE, type)

	if (type == REG_SZ)
		data += "\x00"
	elsif (type == REG_DWORD)
		data = [ data.to_i ].pack("V")
	end

	request.add_tlv(TLV_TYPE_VALUE_DATA, data)

	response = client.send_request(request)

	return true
end

.splitkey(str) ⇒ Object

Split the supplied full registry key into its root key and base key. For instance, passing HKLMSoftwareDog will return [ HKEY_LOCAL_MACHINE, ‘SoftwareDog’ ]



318
319
320
321
322
323
324
# File 'lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb', line 318

def self.splitkey(str)
	if (str =~ /^(.+?)\\(.*)$/)
		[ key2str($1), $2 ]
	else
		[ key2str(str), nil ]
	end
end

.type2str(type) ⇒ Object

Returns the integer value associated with the supplied registry value type (like REG_SZ).



304
305
306
307
308
309
310
311
# File 'lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb', line 304

def self.type2str(type)
	return REG_SZ if (type == 'REG_SZ')
	return REG_DWORD if (type == 'REG_DWORD')
	return REG_BINARY if (type == 'REG_BINARY')
	return REG_EXPAND_SZ if (type == 'REG_EXPAND_SZ')
	return REG_NONE if (type == 'REG_NONE')
	return nil
end

.unload_key(root_key, base_key) ⇒ Object



54
55
56
57
58
59
60
# File 'lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb', line 54

def Registry.unload_key(root_key,base_key)
	request = Packet.create_request('stdapi_registry_unload_key')
	request.add_tlv(TLV_TYPE_ROOT_KEY, root_key)
	request.add_tlv(TLV_TYPE_BASE_KEY, base_key)
	response = client.send_request(request)
	return response.get_tlv(TLV_TYPE_RESULT).value
end