FreeRDP
Loading...
Searching...
No Matches
wf_interface.c
1
21#include <freerdp/config.h>
22
23#include <winpr/tchar.h>
24#include <winpr/windows.h>
25#include <winpr/winsock.h>
26#include <winpr/assert.h>
27
28#include <freerdp/freerdp.h>
29#include <freerdp/listener.h>
30#include <freerdp/constants.h>
31#include <freerdp/channels/wtsvc.h>
32#include <freerdp/channels/channels.h>
33#include <freerdp/build-config.h>
34
35#include "wf_peer.h"
36#include "wf_settings.h"
37#include "wf_info.h"
38
39#include "wf_interface.h"
40
41#include <freerdp/log.h>
42#define TAG SERVER_TAG("windows")
43
44#define SERVER_KEY "Software\\" FREERDP_VENDOR_STRING "\\" FREERDP_PRODUCT_STRING "\\Server"
45
46static cbCallback cbEvent = nullptr;
47
48int get_screen_info(int id, _TCHAR* name, size_t length, int* width, int* height, int* bpp)
49{
50 DISPLAY_DEVICE dd = WINPR_C_ARRAY_INIT;
51
52 dd.cb = sizeof(DISPLAY_DEVICE);
53
54 if (EnumDisplayDevices(nullptr, id, &dd, 0) != 0)
55 {
56 HDC dc;
57
58 if (name != nullptr)
59 _stprintf_s(name, length, _T("%s (%s)"), dd.DeviceName, dd.DeviceString);
60
61 dc = CreateDC(dd.DeviceName, nullptr, nullptr, nullptr);
62 *width = GetDeviceCaps(dc, HORZRES);
63 *height = GetDeviceCaps(dc, VERTRES);
64 *bpp = GetDeviceCaps(dc, BITSPIXEL);
65 // ReleaseDC(nullptr, dc);
66 DeleteDC(dc);
67 }
68 else
69 {
70 return 0;
71 }
72
73 return 1;
74}
75
76void set_screen_id(int id)
77{
78 wfInfo* wfi;
79
80 wfi = wf_info_get_instance();
81 if (!wfi)
82 return;
83 wfi->screenID = id;
84
85 return;
86}
87
88static DWORD WINAPI wf_server_main_loop(LPVOID lpParam)
89{
90 freerdp_listener* instance;
91 wfInfo* wfi;
92
93 wfi = wf_info_get_instance();
94 if (!wfi)
95 {
96 WLog_ERR(TAG, "Failed to get instance");
97 return -1;
98 }
99
100 wfi->force_all_disconnect = FALSE;
101
102 instance = (freerdp_listener*)lpParam;
103 WINPR_ASSERT(instance);
104 WINPR_ASSERT(instance->GetEventHandles);
105 WINPR_ASSERT(instance->CheckFileDescriptor);
106
107 while (wfi->force_all_disconnect == FALSE)
108 {
109 DWORD status;
110 HANDLE handles[MAXIMUM_WAIT_OBJECTS] = WINPR_C_ARRAY_INIT;
111 DWORD count = instance->GetEventHandles(instance, handles, ARRAYSIZE(handles));
112
113 if (count == 0)
114 {
115 WLog_ERR(TAG, "Failed to get FreeRDP file descriptor");
116 break;
117 }
118
119 status = WaitForMultipleObjects(count, handles, FALSE, INFINITE);
120 if (status == WAIT_FAILED)
121 {
122 WLog_ERR(TAG, "WaitForMultipleObjects failed");
123 break;
124 }
125
126 if (instance->CheckFileDescriptor(instance) != TRUE)
127 {
128 WLog_ERR(TAG, "Failed to check FreeRDP file descriptor");
129 break;
130 }
131 }
132
133 WLog_INFO(TAG, "wf_server_main_loop terminating");
134 instance->Close(instance);
135
136 return 0;
137}
138
139BOOL wfreerdp_server_start(wfServer* server)
140{
141 freerdp_listener* instance;
142
143 server->instance = freerdp_listener_new();
144 server->instance->PeerAccepted = wf_peer_accepted;
145 instance = server->instance;
146
147 wf_settings_read_dword(HKEY_LOCAL_MACHINE, SERVER_KEY, _T("DefaultPort"), &server->port);
148
149 if (!instance->Open(instance, nullptr, (UINT16)server->port))
150 return FALSE;
151
152 if (!(server->thread =
153 CreateThread(nullptr, 0, wf_server_main_loop, (void*)instance, 0, nullptr)))
154 return FALSE;
155
156 return TRUE;
157}
158
159BOOL wfreerdp_server_stop(wfServer* server)
160{
161 wfInfo* wfi;
162
163 wfi = wf_info_get_instance();
164 if (!wfi)
165 return FALSE;
166 WLog_INFO(TAG, "Stopping server");
167 wfi->force_all_disconnect = TRUE;
168 server->instance->Close(server->instance);
169 return TRUE;
170}
171
172wfServer* wfreerdp_server_new()
173{
174 WSADATA wsaData;
175 wfServer* server;
176
177 if (WSAStartup(MAKEWORD(2, 2), &wsaData) != 0)
178 return nullptr;
179
180 server = (wfServer*)calloc(1, sizeof(wfServer));
181
182 if (server)
183 {
184 server->port = 3389;
185 }
186
187 WTSRegisterWtsApiFunctionTable(FreeRDP_InitWtsApi());
188
189 cbEvent = nullptr;
190
191 return server;
192}
193
194void wfreerdp_server_free(wfServer* server)
195{
196 free(server);
197
198 WSACleanup();
199}
200
201BOOL wfreerdp_server_is_running(wfServer* server)
202{
203 DWORD tStatus;
204 BOOL bRet;
205
206 bRet = GetExitCodeThread(server->thread, &tStatus);
207 if (bRet == 0)
208 {
209 WLog_ERR(TAG, "Error in call to GetExitCodeThread");
210 return FALSE;
211 }
212
213 if (tStatus == STILL_ACTIVE)
214 return TRUE;
215 return FALSE;
216}
217
218UINT32 wfreerdp_server_num_peers()
219{
220 wfInfo* wfi;
221
222 wfi = wf_info_get_instance();
223 if (!wfi)
224 return -1;
225 return wfi->peerCount;
226}
227
228UINT32 wfreerdp_server_get_peer_hostname(int pId, wchar_t* dstStr)
229{
230 wfInfo* wfi;
231 freerdp_peer* peer;
232
233 wfi = wf_info_get_instance();
234 if (!wfi)
235 return 0;
236 peer = wfi->peers[pId];
237
238 if (peer)
239 {
240 UINT32 sLen;
241
242 sLen = strnlen_s(peer->hostname, 50);
243 swprintf(dstStr, 50, L"%hs", peer->hostname);
244 return sLen;
245 }
246 else
247 {
248 WLog_WARN(TAG, "nonexistent peer id=%d", pId);
249 return 0;
250 }
251}
252
253BOOL wfreerdp_server_peer_is_local(int pId)
254{
255 wfInfo* wfi;
256 freerdp_peer* peer;
257
258 wfi = wf_info_get_instance();
259 if (!wfi)
260 return FALSE;
261 peer = wfi->peers[pId];
262
263 if (peer)
264 {
265 return peer->local;
266 }
267 else
268 {
269 return FALSE;
270 }
271}
272
273BOOL wfreerdp_server_peer_is_connected(int pId)
274{
275 wfInfo* wfi;
276 freerdp_peer* peer;
277
278 wfi = wf_info_get_instance();
279 if (!wfi)
280 return FALSE;
281 peer = wfi->peers[pId];
282
283 if (peer)
284 {
285 return peer->connected;
286 }
287 else
288 {
289 return FALSE;
290 }
291}
292
293BOOL wfreerdp_server_peer_is_activated(int pId)
294{
295 wfInfo* wfi;
296 freerdp_peer* peer;
297
298 wfi = wf_info_get_instance();
299 if (!wfi)
300 return FALSE;
301 peer = wfi->peers[pId];
302
303 if (peer)
304 {
305 return peer->activated;
306 }
307 else
308 {
309 return FALSE;
310 }
311}
312
313BOOL wfreerdp_server_peer_is_authenticated(int pId)
314{
315 wfInfo* wfi;
316 freerdp_peer* peer;
317
318 wfi = wf_info_get_instance();
319 if (!wfi)
320 return FALSE;
321 peer = wfi->peers[pId];
322
323 if (peer)
324 {
325 return peer->authenticated;
326 }
327 else
328 {
329 return FALSE;
330 }
331}
332
333void wfreerdp_server_register_callback_event(cbCallback cb)
334{
335 cbEvent = cb;
336}
337
338void wfreerdp_server_peer_callback_event(int pId, UINT32 eType)
339{
340 if (cbEvent)
341 cbEvent(pId, eType);
342}