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 = wf_info_get_instance();
162 if (!wfi)
163 return FALSE;
164 WLog_INFO(TAG, "Stopping server");
165 wfi->force_all_disconnect = TRUE;
166 server->instance->Close(server->instance);
167 return TRUE;
168}
169
170wfServer* wfreerdp_server_new()
171{
172 WSADATA wsaData = WINPR_C_ARRAY_INIT;
173
174 if (WSAStartup(MAKEWORD(2, 2), &wsaData) != 0)
175 return nullptr;
176
177 if (!WTSRegisterWtsApiFunctionTable(FreeRDP_InitWtsApi()))
178 return nullptr;
179
180 wfServer* server = (wfServer*)calloc(1, sizeof(wfServer));
181
182 if (server)
183 {
184 server->port = 3389;
185 }
186
187 cbEvent = nullptr;
188
189 return server;
190}
191
192void wfreerdp_server_free(wfServer* server)
193{
194 free(server);
195
196 WSACleanup();
197}
198
199BOOL wfreerdp_server_is_running(wfServer* server)
200{
201 DWORD tStatus;
202 BOOL bRet;
203
204 bRet = GetExitCodeThread(server->thread, &tStatus);
205 if (bRet == 0)
206 {
207 WLog_ERR(TAG, "Error in call to GetExitCodeThread");
208 return FALSE;
209 }
210
211 if (tStatus == STILL_ACTIVE)
212 return TRUE;
213 return FALSE;
214}
215
216UINT32 wfreerdp_server_num_peers()
217{
218 wfInfo* wfi;
219
220 wfi = wf_info_get_instance();
221 if (!wfi)
222 return -1;
223 return wfi->peerCount;
224}
225
226UINT32 wfreerdp_server_get_peer_hostname(int pId, wchar_t* dstStr)
227{
228 wfInfo* wfi;
229 freerdp_peer* peer;
230
231 wfi = wf_info_get_instance();
232 if (!wfi)
233 return 0;
234 peer = wfi->peers[pId];
235
236 if (peer)
237 {
238 UINT32 sLen;
239
240 sLen = strnlen_s(peer->hostname, 50);
241 swprintf(dstStr, 50, L"%hs", peer->hostname);
242 return sLen;
243 }
244 else
245 {
246 WLog_WARN(TAG, "nonexistent peer id=%d", pId);
247 return 0;
248 }
249}
250
251BOOL wfreerdp_server_peer_is_local(int pId)
252{
253 wfInfo* wfi;
254 freerdp_peer* peer;
255
256 wfi = wf_info_get_instance();
257 if (!wfi)
258 return FALSE;
259 peer = wfi->peers[pId];
260
261 if (peer)
262 {
263 return peer->local;
264 }
265 else
266 {
267 return FALSE;
268 }
269}
270
271BOOL wfreerdp_server_peer_is_connected(int pId)
272{
273 wfInfo* wfi;
274 freerdp_peer* peer;
275
276 wfi = wf_info_get_instance();
277 if (!wfi)
278 return FALSE;
279 peer = wfi->peers[pId];
280
281 if (peer)
282 {
283 return peer->connected;
284 }
285 else
286 {
287 return FALSE;
288 }
289}
290
291BOOL wfreerdp_server_peer_is_activated(int pId)
292{
293 wfInfo* wfi;
294 freerdp_peer* peer;
295
296 wfi = wf_info_get_instance();
297 if (!wfi)
298 return FALSE;
299 peer = wfi->peers[pId];
300
301 if (peer)
302 {
303 return peer->activated;
304 }
305 else
306 {
307 return FALSE;
308 }
309}
310
311BOOL wfreerdp_server_peer_is_authenticated(int pId)
312{
313 wfInfo* wfi;
314 freerdp_peer* peer;
315
316 wfi = wf_info_get_instance();
317 if (!wfi)
318 return FALSE;
319 peer = wfi->peers[pId];
320
321 if (peer)
322 {
323 return peer->authenticated;
324 }
325 else
326 {
327 return FALSE;
328 }
329}
330
331void wfreerdp_server_register_callback_event(cbCallback cb)
332{
333 cbEvent = cb;
334}
335
336void wfreerdp_server_peer_callback_event(int pId, UINT32 eType)
337{
338 if (cbEvent)
339 cbEvent(pId, eType);
340}