rework getClient into getClientsByIpid, alter /ban and /kick to report number of clients affected
This commit is contained in:
		
							parent
							
								
									18f76d68ea
								
							
						
					
					
						commit
						2a8ed66c4f
					
				| @ -46,7 +46,7 @@ class Server : public QObject { | ||||
|     ~Server(); | ||||
| 
 | ||||
|     void start(); | ||||
|     AOClient* getClient(QString ipid); | ||||
|     QList<AOClient*> getClientsByIpid(QString ipid); | ||||
|     AOClient* getClientByID(int id); | ||||
|     void updateCharsTaken(AreaData* area); | ||||
|     void broadcast(AOPacket packet, int area_index); | ||||
|  | ||||
| @ -95,6 +95,7 @@ void AOClient::cmdBan(int argc, QStringList argv) | ||||
|     unsigned long time = QDateTime::currentDateTime().toTime_t(); | ||||
|     QString reason = argv[1]; | ||||
|     bool ban_logged = false; | ||||
|     int kick_counter = 0; | ||||
| 
 | ||||
|     if (argc > 2) { | ||||
|         for (int i = 2; i < argv.length(); i++) { | ||||
| @ -102,20 +103,21 @@ void AOClient::cmdBan(int argc, QStringList argv) | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     for (AOClient* client : server->clients) { | ||||
|         if (client->getIpid() == target_ipid) { | ||||
|             if (!ban_logged) { | ||||
|                 ip = client->remote_ip; | ||||
|                 hdid = client->hwid; | ||||
|                 server->db_manager->addBan(target_ipid, ip, hdid, time, reason); | ||||
|                 sendServerMessage("Banned user with ipid " + target_ipid + " for reason: " + reason); | ||||
|                 ban_logged = true; | ||||
|             } | ||||
|             client->sendPacket("KB", {reason}); | ||||
|             client->socket->close(); | ||||
|     for (AOClient* client : server->getClientsByIpid(target_ipid)) { | ||||
|         if (!ban_logged) { | ||||
|             ip = client->remote_ip; | ||||
|             hdid = client->hwid; | ||||
|             server->db_manager->addBan(target_ipid, ip, hdid, time, reason); | ||||
|             sendServerMessage("Banned user with ipid " + target_ipid + " for reason: " + reason); | ||||
|             ban_logged = true; | ||||
|         } | ||||
|         client->sendPacket("KB", {reason}); | ||||
|         client->socket->close(); | ||||
|         kick_counter++; | ||||
|     } | ||||
| 
 | ||||
|     if (kick_counter > 1) | ||||
|         sendServerMessage("Kicked " + QString::number(kick_counter) + " clients with matching ipids"); | ||||
|     if (!ban_logged) | ||||
|         sendServerMessage("User with ipid not found!"); | ||||
| } | ||||
| @ -124,7 +126,7 @@ void AOClient::cmdKick(int argc, QStringList argv) | ||||
| { | ||||
|     QString target_ipid = argv[0]; | ||||
|     QString reason = argv[1]; | ||||
|     bool did_kick = false; | ||||
|     int kick_counter = 0; | ||||
| 
 | ||||
|     if (argc > 2) { | ||||
|         for (int i = 2; i < argv.length(); i++) { | ||||
| @ -132,16 +134,14 @@ void AOClient::cmdKick(int argc, QStringList argv) | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     for (AOClient* client : server->clients) { | ||||
|         if (client->getIpid() == target_ipid) { | ||||
|             client->sendPacket("KK", {reason}); | ||||
|             client->socket->close(); | ||||
|             did_kick = true; | ||||
|         } | ||||
|     for (AOClient* client : server->getClientsByIpid(target_ipid)) { | ||||
|         client->sendPacket("KK", {reason}); | ||||
|         client->socket->close(); | ||||
|         kick_counter++; | ||||
|     } | ||||
| 
 | ||||
|     if (did_kick) | ||||
|         sendServerMessage("Kicked user with ipid " + target_ipid + " for reason: " + reason); | ||||
|     if (kick_counter > 0) | ||||
|         sendServerMessage("Kicked " + QString::number(kick_counter) + " client(s) with ipid " + target_ipid + " for reason: " + reason); | ||||
|     else | ||||
|         sendServerMessage("User with ipid not found!"); | ||||
| } | ||||
|  | ||||
| @ -185,13 +185,14 @@ int Server::getDiceValue(QString value_type) | ||||
|     return value; | ||||
| } | ||||
| 
 | ||||
| AOClient* Server::getClient(QString ipid) | ||||
| QList<AOClient*> Server::getClientsByIpid(QString ipid) | ||||
| { | ||||
|     QList<AOClient*> return_clients; | ||||
|     for (AOClient* client : clients) { | ||||
|         if (client->getIpid() == ipid) | ||||
|             return client; | ||||
|             return_clients.append(client); | ||||
|     } | ||||
|     return nullptr; | ||||
|     return return_clients; | ||||
| } | ||||
| 
 | ||||
| AOClient* Server::getClientByID(int id) | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 in1tiate
						in1tiate