/************************************************************************* * UrBackup - Client/Server backup system * Copyright (C) 2011-2014 Martin Raiber * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . **************************************************************************/ #ifndef CLIENT_ONLY #include "server_ping.h" #include "server_get.h" #include "../Interface/Server.h" #include "../stringtools.h" const int64 ping_intervall=10000; extern std::string server_token; ServerPingThread::ServerPingThread(BackupServerGet *pServer_get, bool with_eta) : server_get(pServer_get), with_eta(with_eta) { stop=false; is_timeout=false; } void ServerPingThread::operator()(void) { int64 last_ping_ok=Server->getTimeMS(); while(stop==false) { //Server->Log("Sending ping running...", LL_DEBUG); std::string pcdone; int i_pcdone = server_get->getPCDone(); if(i_pcdone>=0) { pcdone=nconvert(i_pcdone); } int64 etams = server_get->getETAms(); if(!with_eta || etams<0) { if(server_get->sendClientMessage("PING RUNNING -"+pcdone+"-#token="+server_token, "OK", L"Error sending 'running' ping to client", 30000, false, LL_DEBUG)) { last_ping_ok=Server->getTimeMS(); } } else { if(etams>0 && etams<60*1000) { etams=61*1000; } if(server_get->sendClientMessage("2PING RUNNING pc_done="+pcdone+"&eta_ms="+nconvert(etams)+"#token="+server_token, "OK", L"Error sending 'running' (2) ping to client", 30000, false, LL_DEBUG)) { last_ping_ok=Server->getTimeMS(); } } //Server->Log("Done sending ping running.", LL_DEBUG); if(Server->getTimeMS()-last_ping_ok>ping_intervall*6) { is_timeout=true; } else { is_timeout=false; } Server->wait(ping_intervall); } Server->wait(1000); delete this; } void ServerPingThread::setStop(bool b) { stop=b; } bool ServerPingThread::isTimeout(void) { return is_timeout; } #endif //CLIENT_ONLY