FreeRDP
Loading...
Searching...
No Matches
rdp.h
1
21#ifndef FREERDP_LIB_CORE_RDP_H
22#define FREERDP_LIB_CORE_RDP_H
23
24#include <winpr/json.h>
25#include <freerdp/config.h>
26
27#include "nla.h"
28#include "aad.h"
29#include "mcs.h"
30#include "tpkt.h"
31#include "../codec/bulk.h"
32#include "fastpath.h"
33#include "tpdu.h"
34#include "nego.h"
35#include "input.h"
36#include "update.h"
37#include "license.h"
38#include "errinfo.h"
39#include "autodetect.h"
40#include "heartbeat.h"
41#include "multitransport.h"
42#include "security.h"
43#include "transport.h"
44#include "connection.h"
45#include "redirection.h"
46#include "capabilities.h"
47#include "channels.h"
48#include "timer.h"
49
50#include <freerdp/freerdp.h>
51#include <freerdp/settings.h>
52#include <freerdp/log.h>
53#include <freerdp/api.h>
54
55#include <winpr/stream.h>
56#include <winpr/crypto.h>
57
58/* Security Header Flags */
59#define SEC_EXCHANGE_PKT 0x0001
60#define SEC_TRANSPORT_REQ 0x0002
61#define SEC_TRANSPORT_RSP 0x0004
62#define SEC_ENCRYPT 0x0008
63#define SEC_RESET_SEQNO 0x0010
64#define SEC_IGNORE_SEQNO 0x0020
65#define SEC_INFO_PKT 0x0040
66#define SEC_LICENSE_PKT 0x0080
67#define SEC_LICENSE_ENCRYPT_CS 0x0200
68#define SEC_LICENSE_ENCRYPT_SC 0x0200
69#define SEC_REDIRECTION_PKT 0x0400
70#define SEC_SECURE_CHECKSUM 0x0800
71#define SEC_AUTODETECT_REQ 0x1000
72#define SEC_AUTODETECT_RSP 0x2000
73#define SEC_HEARTBEAT 0x4000
74#define SEC_FLAGSHI_VALID 0x8000
75
76#define SEC_PKT_CS_MASK (SEC_EXCHANGE_PKT | SEC_INFO_PKT)
77#define SEC_PKT_SC_MASK (SEC_LICENSE_PKT | SEC_REDIRECTION_PKT)
78#define SEC_PKT_MASK (SEC_PKT_CS_MASK | SEC_PKT_SC_MASK)
79
80#define RDP_SECURITY_HEADER_LENGTH 4
81#define RDP_SHARE_CONTROL_HEADER_LENGTH 6
82#define RDP_SHARE_DATA_HEADER_LENGTH 12
83#define RDP_PACKET_HEADER_MAX_LENGTH (TPDU_DATA_LENGTH + MCS_SEND_DATA_HEADER_MAX_LENGTH)
84
85#define PDU_TYPE_DEMAND_ACTIVE 0x1
86#define PDU_TYPE_CONFIRM_ACTIVE 0x3
87#define PDU_TYPE_DEACTIVATE_ALL 0x6
88#define PDU_TYPE_DATA 0x7
89#define PDU_TYPE_SERVER_REDIRECTION 0xA
90
91#define PDU_TYPE_FLOW_TEST 0x41
92#define PDU_TYPE_FLOW_RESPONSE 0x42
93#define PDU_TYPE_FLOW_STOP 0x43
94
95typedef enum
96{
97 FINALIZE_SC_SYNCHRONIZE_PDU = 0x01,
98 FINALIZE_SC_CONTROL_COOPERATE_PDU = 0x02,
99 FINALIZE_SC_CONTROL_GRANTED_PDU = 0x04,
100 FINALIZE_SC_FONT_MAP_PDU = 0x08,
101
102 FINALIZE_CS_SYNCHRONIZE_PDU = 0x10,
103 FINALIZE_CS_CONTROL_COOPERATE_PDU = 0x20,
104 FINALIZE_CS_CONTROL_REQUEST_PDU = 0x40,
105 FINALIZE_CS_PERSISTENT_KEY_LIST_PDU = 0x80,
106 FINALIZE_CS_FONT_LIST_PDU = 0x100,
107
108 FINALIZE_DEACTIVATE_REACTIVATE = 0x200
109} rdpFinalizePduType;
110
111/* Data PDU Types */
112typedef enum
113{
114 DATA_PDU_TYPE_UPDATE = 0x02,
115 DATA_PDU_TYPE_CONTROL = 0x14,
116 DATA_PDU_TYPE_POINTER = 0x1B,
117 DATA_PDU_TYPE_INPUT = 0x1C,
118 DATA_PDU_TYPE_SYNCHRONIZE = 0x1F,
119 DATA_PDU_TYPE_REFRESH_RECT = 0x21,
120 DATA_PDU_TYPE_PLAY_SOUND = 0x22,
121 DATA_PDU_TYPE_SUPPRESS_OUTPUT = 0x23,
122 DATA_PDU_TYPE_SHUTDOWN_REQUEST = 0x24,
123 DATA_PDU_TYPE_SHUTDOWN_DENIED = 0x25,
124 DATA_PDU_TYPE_SAVE_SESSION_INFO = 0x26,
125 DATA_PDU_TYPE_FONT_LIST = 0x27,
126 DATA_PDU_TYPE_FONT_MAP = 0x28,
127 DATA_PDU_TYPE_SET_KEYBOARD_INDICATORS = 0x29,
128 DATA_PDU_TYPE_BITMAP_CACHE_PERSISTENT_LIST = 0x2B,
129 DATA_PDU_TYPE_BITMAP_CACHE_ERROR = 0x2C,
130 DATA_PDU_TYPE_SET_KEYBOARD_IME_STATUS = 0x2D,
131 DATA_PDU_TYPE_OFFSCREEN_CACHE_ERROR = 0x2E,
132 DATA_PDU_TYPE_SET_ERROR_INFO = 0x2F,
133 DATA_PDU_TYPE_DRAW_NINEGRID_ERROR = 0x30,
134 DATA_PDU_TYPE_DRAW_GDIPLUS_ERROR = 0x31,
135 DATA_PDU_TYPE_ARC_STATUS = 0x32,
136 DATA_PDU_TYPE_STATUS_INFO = 0x36,
137 DATA_PDU_TYPE_MONITOR_LAYOUT = 0x37,
138 DATA_PDU_TYPE_FRAME_ACKNOWLEDGE = 0x38
139} rdpPduType;
140
141/* Stream Identifiers */
142#define STREAM_UNDEFINED 0x00
143#define STREAM_LOW 0x01
144#define STREAM_MED 0x02
145#define STREAM_HI 0x04
146
148{
149 CONNECTION_STATE state;
150 rdpContext* context;
151 rdpNla* nla;
152 rdpAad* aad;
153 rdpMcs* mcs;
154 rdpNego* nego;
155 rdpBulk* bulk;
156 rdpInput* input;
157 rdpUpdate* update;
158 rdpFastPath* fastpath;
159 rdpLicense* license;
160 rdpRedirection* redirection;
161 rdpSettings* settings;
162 rdpSettings* originalSettings;
163 rdpSettings* remoteSettings;
164 rdpTransport* transport;
165 rdpAutoDetect* autodetect;
166 rdpHeartbeat* heartbeat;
167 rdpMultitransport* multitransport;
168 WINPR_RC4_CTX* rc4_decrypt_key;
169 UINT32 decrypt_use_count;
170 UINT32 decrypt_checksum_use_count;
171 WINPR_RC4_CTX* rc4_encrypt_key;
172 UINT32 encrypt_use_count;
173 UINT32 encrypt_checksum_use_count;
174 WINPR_CIPHER_CTX* fips_encrypt;
175 WINPR_CIPHER_CTX* fips_decrypt;
176 BOOL do_crypt;
177 BOOL do_crypt_license;
178 BOOL do_secure_checksum;
179 BYTE sign_key[16];
180 BYTE decrypt_key[16];
181 BYTE encrypt_key[16];
182 BYTE decrypt_update_key[16];
183 BYTE encrypt_update_key[16];
184 size_t rc4_key_len;
185 BYTE fips_sign_key[20];
186 BYTE fips_encrypt_key[24];
187 BYTE fips_decrypt_key[24];
188 UINT32 errorInfo;
189 UINT32 finalize_sc_pdus;
190 BOOL resendFocus;
191
192 UINT64 inBytes;
193 UINT64 inPackets;
194 UINT64 outBytes;
195 UINT64 outPackets;
196 CRITICAL_SECTION critical;
197 rdpTransportIo* io;
198 void* ioContext;
199 HANDLE abortEvent;
200
201 wPubSub* pubSub;
202
203 BOOL monitor_layout_pdu;
204 BOOL was_deactivated;
205 UINT32 deactivated_width;
206 UINT32 deactivated_height;
207
208 wLog* log;
209 char log_context[64];
210 WINPR_JSON* wellknown;
211 FreeRDPTimer* timer;
212 pGetCommonAccessToken GetCommonAccessToken;
213};
214
215FREERDP_LOCAL BOOL rdp_read_security_header(rdpRdp* rdp, wStream* s, UINT16* flags, UINT16* length);
216FREERDP_LOCAL BOOL rdp_write_security_header(rdpRdp* rdp, wStream* s, UINT16 flags);
217
218FREERDP_LOCAL BOOL rdp_read_share_control_header(rdpRdp* rdp, wStream* s, UINT16* tpktLength,
219 UINT16* remainingLength, UINT16* type,
220 UINT16* channel_id);
221
222FREERDP_LOCAL BOOL rdp_read_share_data_header(rdpRdp* rdp, wStream* s, UINT16* length, BYTE* type,
223 UINT32* share_id, BYTE* compressed_type,
224 UINT16* compressed_len);
225
226FREERDP_LOCAL wStream* rdp_send_stream_init(rdpRdp* rdp, UINT16* sec_flags);
227FREERDP_LOCAL wStream* rdp_send_stream_pdu_init(rdpRdp* rdp, UINT16* sec_flags);
228
229FREERDP_LOCAL BOOL rdp_read_header(rdpRdp* rdp, wStream* s, UINT16* length, UINT16* channel_id);
230FREERDP_LOCAL BOOL rdp_write_header(rdpRdp* rdp, wStream* s, size_t length, UINT16 channel_id,
231 UINT16 sec_flags);
232
233FREERDP_LOCAL BOOL rdp_send_pdu(rdpRdp* rdp, wStream* s, UINT16 type, UINT16 channel_id,
234 UINT16 sec_flags);
235
236FREERDP_LOCAL wStream* rdp_data_pdu_init(rdpRdp* rdp, UINT16* sec_flags);
237FREERDP_LOCAL BOOL rdp_send_data_pdu(rdpRdp* rdp, wStream* s, BYTE type, UINT16 channel_id,
238 UINT16 sec_flags);
239FREERDP_LOCAL state_run_t rdp_recv_data_pdu(rdpRdp* rdp, wStream* s);
240
241FREERDP_LOCAL BOOL rdp_send(rdpRdp* rdp, wStream* s, UINT16 channelId, UINT16 sec_flags);
242
243FREERDP_LOCAL BOOL rdp_send_channel_data(rdpRdp* rdp, UINT16 channelId, const BYTE* data,
244 size_t size);
245FREERDP_LOCAL BOOL rdp_channel_send_packet(rdpRdp* rdp, UINT16 channelId, size_t totalSize,
246 UINT32 flags, const BYTE* data, size_t chunkSize);
247
248FREERDP_LOCAL wStream* rdp_message_channel_pdu_init(rdpRdp* rdp, UINT16* sec_flags);
249FREERDP_LOCAL BOOL rdp_send_message_channel_pdu(rdpRdp* rdp, wStream* s, UINT16 sec_flags);
250FREERDP_LOCAL state_run_t rdp_recv_message_channel_pdu(rdpRdp* rdp, wStream* s,
251 UINT16 securityFlags);
252
253FREERDP_LOCAL state_run_t rdp_recv_out_of_sequence_pdu(rdpRdp* rdp, wStream* s, UINT16 pduType,
254 UINT16 length);
255
256FREERDP_LOCAL state_run_t rdp_recv_callback(rdpTransport* transport, wStream* s, void* extra);
257
258FREERDP_LOCAL int rdp_check_fds(rdpRdp* rdp);
259
260FREERDP_LOCAL void rdp_free(rdpRdp* rdp);
261
262WINPR_ATTR_MALLOC(rdp_free, 1)
263FREERDP_LOCAL rdpRdp* rdp_new(rdpContext* context);
264FREERDP_LOCAL BOOL rdp_reset(rdpRdp* rdp);
265
266FREERDP_LOCAL BOOL rdp_io_callback_set_event(rdpRdp* rdp, BOOL reset);
267
268FREERDP_LOCAL const rdpTransportIo* rdp_get_io_callbacks(rdpRdp* rdp);
269FREERDP_LOCAL BOOL rdp_set_io_callbacks(rdpRdp* rdp, const rdpTransportIo* io_callbacks);
270
271FREERDP_LOCAL BOOL rdp_set_io_callback_context(rdpRdp* rdp, void* usercontext);
272FREERDP_LOCAL void* rdp_get_io_callback_context(rdpRdp* rdp);
273
274#define RDP_TAG FREERDP_TAG("core.rdp")
275#ifdef WITH_DEBUG_RDP
276#define DEBUG_RDP(rdp, ...) WLog_Print(rdp->log, WLOG_DEBUG, __VA_ARGS__)
277#else
278#define DEBUG_RDP(rdp, ...) \
279 do \
280 { \
281 } while (0)
282#endif
283
284const char* data_pdu_type_to_string(UINT8 type);
285const char* pdu_type_to_str(UINT16 pduType, char* buffer, size_t length);
286
287BOOL rdp_finalize_reset_flags(rdpRdp* rdp, BOOL clearAll);
288BOOL rdp_finalize_set_flag(rdpRdp* rdp, UINT32 flag);
289BOOL rdp_finalize_is_flag_set(rdpRdp* rdp, UINT32 flag);
290const char* rdp_finalize_flags_to_str(UINT32 flags, char* buffer, size_t size);
291
292BOOL rdp_decrypt(rdpRdp* rdp, wStream* s, UINT16* pLength, UINT16 securityFlags);
293
294BOOL rdp_set_error_info(rdpRdp* rdp, UINT32 errorInfo);
295BOOL rdp_send_error_info(rdpRdp* rdp);
296
297void rdp_free_rc4_encrypt_keys(rdpRdp* rdp);
298BOOL rdp_reset_rc4_encrypt_keys(rdpRdp* rdp);
299
300void rdp_free_rc4_decrypt_keys(rdpRdp* rdp);
301BOOL rdp_reset_rc4_decrypt_keys(rdpRdp* rdp);
302
303const char* rdp_security_flag_string(UINT32 securityFlags, char* buffer, size_t size);
304
305BOOL rdp_set_backup_settings(rdpRdp* rdp);
306BOOL rdp_reset_runtime_settings(rdpRdp* rdp);
307
308void rdp_log_build_warnings(rdpRdp* rdp);
309
310FREERDP_LOCAL size_t rdp_get_event_handles(rdpRdp* rdp, HANDLE* handles, uint32_t count);
311
312#endif /* FREERDP_LIB_CORE_RDP_H */
Definition rdp.h:148