mirror of
				https://github.com/kunkundi/crossdesk.git
				synced 2025-10-26 12:15:34 +08:00 
			
		
		
		
	Add 1 second time interval for retry join transmission
This commit is contained in:
		
							
								
								
									
										
											BIN
										
									
								
								icon/捕获.PNG
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								icon/捕获.PNG
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 30 KiB | 
							
								
								
									
										
											BIN
										
									
								
								icon/捕获.ico
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								icon/捕获.ico
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 84 KiB | 
							
								
								
									
										101
									
								
								src/common/platform.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										101
									
								
								src/common/platform.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,101 @@ | |||||||
|  | #include "platform.h" | ||||||
|  |  | ||||||
|  | #include "log.h" | ||||||
|  |  | ||||||
|  | #ifdef _WIN32 | ||||||
|  | #include <Winsock2.h> | ||||||
|  | #include <iphlpapi.h> | ||||||
|  | #elif __APPLE__ | ||||||
|  | #include <ifaddrs.h> | ||||||
|  | #include <net/if_dl.h> | ||||||
|  | #include <net/if_types.h> | ||||||
|  | #include <sys/socket.h> | ||||||
|  | #include <sys/types.h> | ||||||
|  | #elif __linux__ | ||||||
|  | #include <fcntl.h> | ||||||
|  | #include <net/if.h> | ||||||
|  | #include <sys/ioctl.h> | ||||||
|  | #include <sys/socket.h> | ||||||
|  | #include <unistd.h> | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | std::string GetMac() { | ||||||
|  |   char mac_addr[16]; | ||||||
|  |   int len = 0; | ||||||
|  | #ifdef _WIN32 | ||||||
|  |   IP_ADAPTER_INFO adapterInfo[16]; | ||||||
|  |   DWORD bufferSize = sizeof(adapterInfo); | ||||||
|  |  | ||||||
|  |   DWORD result = GetAdaptersInfo(adapterInfo, &bufferSize); | ||||||
|  |   if (result == ERROR_SUCCESS) { | ||||||
|  |     PIP_ADAPTER_INFO adapter = adapterInfo; | ||||||
|  |     while (adapter) { | ||||||
|  |       for (UINT i = 0; i < adapter->AddressLength; i++) { | ||||||
|  |         len += sprintf(mac_addr + len, "%.2X", adapter->Address[i]); | ||||||
|  |       } | ||||||
|  |       break; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | #elif __APPLE__ | ||||||
|  |   std::string if_name = "en0"; | ||||||
|  |  | ||||||
|  |   struct ifaddrs *addrs; | ||||||
|  |   struct ifaddrs *cursor; | ||||||
|  |   const struct sockaddr_dl *dlAddr; | ||||||
|  |  | ||||||
|  |   if (!getifaddrs(&addrs)) { | ||||||
|  |     cursor = addrs; | ||||||
|  |     while (cursor != 0) { | ||||||
|  |       const struct sockaddr_dl *socAddr = | ||||||
|  |           (const struct sockaddr_dl *)cursor->ifa_addr; | ||||||
|  |       if ((cursor->ifa_addr->sa_family == AF_LINK) && | ||||||
|  |           (socAddr->sdl_type == IFT_ETHER) && | ||||||
|  |           strcmp(if_name.c_str(), cursor->ifa_name) == 0) { | ||||||
|  |         dlAddr = (const struct sockaddr_dl *)cursor->ifa_addr; | ||||||
|  |         const unsigned char *base = | ||||||
|  |             (const unsigned char *)&dlAddr->sdl_data[dlAddr->sdl_nlen]; | ||||||
|  |         for (int i = 0; i < dlAddr->sdl_alen; i++) { | ||||||
|  |           len += sprintf(mac_addr + len, "%.2X", base[i]); | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |       cursor = cursor->ifa_next; | ||||||
|  |     } | ||||||
|  |     freeifaddrs(addrs); | ||||||
|  |   } | ||||||
|  | #elif __linux__ | ||||||
|  |   int sock = socket(AF_INET, SOCK_DGRAM, 0); | ||||||
|  |   if (sock < 0) { | ||||||
|  |     return ""; | ||||||
|  |   } | ||||||
|  |   struct ifreq ifr; | ||||||
|  |   struct ifconf ifc; | ||||||
|  |   char buf[1024]; | ||||||
|  |   ifc.ifc_len = sizeof(buf); | ||||||
|  |   ifc.ifc_buf = buf; | ||||||
|  |   if (ioctl(sock, SIOCGIFCONF, &ifc) < 0) { | ||||||
|  |     close(sock); | ||||||
|  |     return ""; | ||||||
|  |   } | ||||||
|  |   struct ifreq *it = ifc.ifc_req; | ||||||
|  |   const struct ifreq *const end = it + (ifc.ifc_len / sizeof(struct ifreq)); | ||||||
|  |   for (; it != end; ++it) { | ||||||
|  |     std::strcpy(ifr.ifr_name, it->ifr_name); | ||||||
|  |     if (ioctl(sock, SIOCGIFFLAGS, &ifr) < 0) { | ||||||
|  |       continue; | ||||||
|  |     } | ||||||
|  |     if (ifr.ifr_flags & IFF_LOOPBACK) { | ||||||
|  |       continue; | ||||||
|  |     } | ||||||
|  |     if (ioctl(sock, SIOCGIFHWADDR, &ifr) < 0) { | ||||||
|  |       continue; | ||||||
|  |     } | ||||||
|  |     std::string mac_address; | ||||||
|  |     for (int i = 0; i < 6; ++i) { | ||||||
|  |       len += sprintf(mac_addr + len, "%.2X", ifr.ifr_hwaddr.sa_data[i] & 0xff); | ||||||
|  |     } | ||||||
|  |     break; | ||||||
|  |   } | ||||||
|  |   close(sock); | ||||||
|  | #endif | ||||||
|  |   return mac_addr; | ||||||
|  | } | ||||||
							
								
								
									
										14
									
								
								src/common/platform.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								src/common/platform.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | /* | ||||||
|  |  * @Author: DI JUNKUN | ||||||
|  |  * @Date: 2023-12-18 | ||||||
|  |  * Copyright (c) 2023 by DI JUNKUN, All Rights Reserved. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #ifndef _PLATFORM_H_ | ||||||
|  | #define _PLATFORM_H_ | ||||||
|  |  | ||||||
|  | #include <iostream> | ||||||
|  |  | ||||||
|  | std::string GetMac(); | ||||||
|  |  | ||||||
|  | #endif | ||||||
							
								
								
									
										103
									
								
								src/gui/main.cpp
									
									
									
									
									
								
							
							
						
						
									
										103
									
								
								src/gui/main.cpp
									
									
									
									
									
								
							| @@ -1,22 +1,11 @@ | |||||||
| #include <SDL.h> | #include <SDL.h> | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #ifdef _WIN32 | #ifdef _WIN32 | ||||||
| // #pragma comment(linker, "/subsystem:\"windows\" /entry:\"mainCRTStartup\"") | #ifdef REMOTE_DESK_DEBUG | ||||||
| #pragma comment(linker, "/subsystem:\"console\"") | #pragma comment(linker, "/subsystem:\"console\"") | ||||||
| #include <Winsock2.h> | #else | ||||||
| #include <iphlpapi.h> | #pragma comment(linker, "/subsystem:\"windows\" /entry:\"mainCRTStartup\"") | ||||||
| #elif __APPLE__ | #endif | ||||||
| #include <ifaddrs.h> |  | ||||||
| #include <net/if_dl.h> |  | ||||||
| #include <net/if_types.h> |  | ||||||
| #include <sys/socket.h> |  | ||||||
| #include <sys/types.h> |  | ||||||
| #elif __linux__ |  | ||||||
| #include <fcntl.h> |  | ||||||
| #include <net/if.h> |  | ||||||
| #include <sys/ioctl.h> |  | ||||||
| #include <sys/socket.h> |  | ||||||
| #include <unistd.h> |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #include <atomic> | #include <atomic> | ||||||
| @@ -27,6 +16,8 @@ | |||||||
| #include <string> | #include <string> | ||||||
| #include <thread> | #include <thread> | ||||||
|  |  | ||||||
|  | #include "platform.h" | ||||||
|  |  | ||||||
| extern "C" { | extern "C" { | ||||||
| #include <libavdevice/avdevice.h> | #include <libavdevice/avdevice.h> | ||||||
| #include <libswresample/swresample.h> | #include <libswresample/swresample.h> | ||||||
| @@ -478,87 +469,6 @@ int initResampler() { | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| std::string GetMac() { |  | ||||||
|   char mac_addr[16]; |  | ||||||
|   int len = 0; |  | ||||||
| #ifdef _WIN32 |  | ||||||
|   IP_ADAPTER_INFO adapterInfo[16]; |  | ||||||
|   DWORD bufferSize = sizeof(adapterInfo); |  | ||||||
|  |  | ||||||
|   DWORD result = GetAdaptersInfo(adapterInfo, &bufferSize); |  | ||||||
|   if (result == ERROR_SUCCESS) { |  | ||||||
|     PIP_ADAPTER_INFO adapter = adapterInfo; |  | ||||||
|     while (adapter) { |  | ||||||
|       for (UINT i = 0; i < adapter->AddressLength; i++) { |  | ||||||
|         len += sprintf(mac_addr + len, "%.2X", adapter->Address[i]); |  | ||||||
|       } |  | ||||||
|       break; |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| #elif __APPLE__ |  | ||||||
|   std::string if_name = "en0"; |  | ||||||
|  |  | ||||||
|   struct ifaddrs *addrs; |  | ||||||
|   struct ifaddrs *cursor; |  | ||||||
|   const struct sockaddr_dl *dlAddr; |  | ||||||
|  |  | ||||||
|   if (!getifaddrs(&addrs)) { |  | ||||||
|     cursor = addrs; |  | ||||||
|     while (cursor != 0) { |  | ||||||
|       const struct sockaddr_dl *socAddr = |  | ||||||
|           (const struct sockaddr_dl *)cursor->ifa_addr; |  | ||||||
|       if ((cursor->ifa_addr->sa_family == AF_LINK) && |  | ||||||
|           (socAddr->sdl_type == IFT_ETHER) && |  | ||||||
|           strcmp(if_name.c_str(), cursor->ifa_name) == 0) { |  | ||||||
|         dlAddr = (const struct sockaddr_dl *)cursor->ifa_addr; |  | ||||||
|         const unsigned char *base = |  | ||||||
|             (const unsigned char *)&dlAddr->sdl_data[dlAddr->sdl_nlen]; |  | ||||||
|         for (int i = 0; i < dlAddr->sdl_alen; i++) { |  | ||||||
|           len += sprintf(mac_addr + len, "%.2X", base[i]); |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|       cursor = cursor->ifa_next; |  | ||||||
|     } |  | ||||||
|     freeifaddrs(addrs); |  | ||||||
|   } |  | ||||||
| #elif __linux__ |  | ||||||
|   int sock = socket(AF_INET, SOCK_DGRAM, 0); |  | ||||||
|   if (sock < 0) { |  | ||||||
|     return ""; |  | ||||||
|   } |  | ||||||
|   struct ifreq ifr; |  | ||||||
|   struct ifconf ifc; |  | ||||||
|   char buf[1024]; |  | ||||||
|   ifc.ifc_len = sizeof(buf); |  | ||||||
|   ifc.ifc_buf = buf; |  | ||||||
|   if (ioctl(sock, SIOCGIFCONF, &ifc) < 0) { |  | ||||||
|     close(sock); |  | ||||||
|     return ""; |  | ||||||
|   } |  | ||||||
|   struct ifreq *it = ifc.ifc_req; |  | ||||||
|   const struct ifreq *const end = it + (ifc.ifc_len / sizeof(struct ifreq)); |  | ||||||
|   for (; it != end; ++it) { |  | ||||||
|     std::strcpy(ifr.ifr_name, it->ifr_name); |  | ||||||
|     if (ioctl(sock, SIOCGIFFLAGS, &ifr) < 0) { |  | ||||||
|       continue; |  | ||||||
|     } |  | ||||||
|     if (ifr.ifr_flags & IFF_LOOPBACK) { |  | ||||||
|       continue; |  | ||||||
|     } |  | ||||||
|     if (ioctl(sock, SIOCGIFHWADDR, &ifr) < 0) { |  | ||||||
|       continue; |  | ||||||
|     } |  | ||||||
|     std::string mac_address; |  | ||||||
|     for (int i = 0; i < 6; ++i) { |  | ||||||
|       len += sprintf(mac_addr + len, "%.2X", ifr.ifr_hwaddr.sa_data[i] & 0xff); |  | ||||||
|     } |  | ||||||
|     break; |  | ||||||
|   } |  | ||||||
|   close(sock); |  | ||||||
| #endif |  | ||||||
|   return mac_addr; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| int main() { | int main() { | ||||||
|   LOG_INFO("Remote desk"); |   LOG_INFO("Remote desk"); | ||||||
|  |  | ||||||
| @@ -713,6 +623,7 @@ int main() { | |||||||
|         { |         { | ||||||
|           while (SignalStatus::SignalConnected != server_signal_status && |           while (SignalStatus::SignalConnected != server_signal_status && | ||||||
|                  !done) { |                  !done) { | ||||||
|  |             std::this_thread::sleep_for(std::chrono::seconds(1)); | ||||||
|           } |           } | ||||||
|  |  | ||||||
|           if (done) { |           if (done) { | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								xmake.lua
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								xmake.lua
									
									
									
									
									
								
							| @@ -5,8 +5,8 @@ set_license("LGPL-3.0") | |||||||
| add_rules("mode.release", "mode.debug") | add_rules("mode.release", "mode.debug") | ||||||
| set_languages("c++17") | set_languages("c++17") | ||||||
|  |  | ||||||
| set_policy("build.warning", true) | -- set_policy("build.warning", true) | ||||||
| set_warnings("all", "extra") | -- set_warnings("all", "extra") | ||||||
|  |  | ||||||
| add_defines("UNICODE") | add_defines("UNICODE") | ||||||
| if is_mode("debug") then | if is_mode("debug") then | ||||||
| @@ -53,6 +53,12 @@ target("log") | |||||||
|     add_headerfiles("src/log/log.h") |     add_headerfiles("src/log/log.h") | ||||||
|     add_includedirs("src/log", {public = true}) |     add_includedirs("src/log", {public = true}) | ||||||
|  |  | ||||||
|  | target("common") | ||||||
|  |     set_kind("object") | ||||||
|  |     add_deps("log") | ||||||
|  |     add_files("src/common/*.cpp") | ||||||
|  |     add_includedirs("src/common", {public = true}) | ||||||
|  |  | ||||||
| target("screen_capturer") | target("screen_capturer") | ||||||
|     set_kind("object") |     set_kind("object") | ||||||
|     add_deps("log") |     add_deps("log") | ||||||
| @@ -85,7 +91,7 @@ target("device_controller") | |||||||
|  |  | ||||||
| target("remote_desk") | target("remote_desk") | ||||||
|     set_kind("binary") |     set_kind("binary") | ||||||
|     add_deps("log", "screen_capturer", "device_controller", "projectx") |     add_deps("log", "common", "screen_capturer", "device_controller", "projectx") | ||||||
|     add_files("src/gui/main.cpp") |     add_files("src/gui/main.cpp") | ||||||
|  |  | ||||||
|     -- after_install(function (target) |     -- after_install(function (target) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user