1
0
mirror of https://github.com/clementine-player/Clementine synced 2025-01-28 10:09:24 +01:00

If use auth code is enabled, check if the client has sent the correct auth code before processing any messages.

This commit is contained in:
Andreas 2013-03-21 10:57:52 +01:00
parent ed86c7b09b
commit be68c9f702
3 changed files with 17 additions and 4 deletions

View File

@ -157,6 +157,7 @@ message RequestConnect {
enum ReasonDisconnect {
Server_Shutdown = 1;
Wrong_Auth_Code = 2;
Not_Authenticated = 3;
}
message ResponseDisconnect {
optional ReasonDisconnect reason_disconnect = 1;

View File

@ -43,6 +43,9 @@ RemoteClient::RemoteClient(Application* app, QTcpSocket* client)
auth_code_ = s.value("auth_code", 0).toInt();
s.endGroup();
// If we don't use an auth code, we don't need to authenticate the client.
authenticated_ = !use_auth_code_;
}
@ -95,23 +98,31 @@ void RemoteClient::ParseMessage(const QByteArray &data) {
if (msg.type() == pb::remote::CONNECT && use_auth_code_) {
if (msg.request_connect().auth_code() != auth_code_) {
DisconnectClientWrongAuthCode();
DisconnectClient(pb::remote::Wrong_Auth_Code);
return;
} else {
authenticated_ = true;
}
}
// Check if the client has sent the correct auth code
if (!authenticated_) {
DisconnectClient(pb::remote::Not_Authenticated);
return;
}
// Now parse the other data
emit Parse(msg);
}
void RemoteClient::DisconnectClientWrongAuthCode() {
void RemoteClient::DisconnectClient(pb::remote::ReasonDisconnect reason) {
pb::remote::Message msg;
msg.set_type(pb::remote::DISCONNECT);
// Send the default version
msg.set_version(msg.default_instance().version());
msg.mutable_response_disconnect()->set_reason_disconnect(pb::remote::Wrong_Auth_Code);
msg.mutable_response_disconnect()->set_reason_disconnect(reason);
SendData(&msg);
// Just close the connection. The next time the outgoing data creator

View File

@ -25,12 +25,13 @@ signals:
private:
void ParseMessage(const QByteArray& data);
void DisconnectClientWrongAuthCode();
void DisconnectClient(pb::remote::ReasonDisconnect reason);
Application* app_;
bool use_auth_code_;
int auth_code_;
bool authenticated_;
QTcpSocket* client_;
bool reading_protobuf_;