From 3069686075559d7bfce594c40e919a0b1683a064 Mon Sep 17 00:00:00 2001 From: Niklas Date: Tue, 16 Aug 2011 14:32:01 +0200 Subject: new function for checkInternetConnection, check with sessions for each config and test if you can get a valid response with a qhostInfo --- workspace/LogReceiver/logreceiver.cpp | 25 ++++++++++++++++++++++--- 1 file changed, 22 insertions(+), 3 deletions(-) (limited to 'workspace/LogReceiver/logreceiver.cpp') diff --git a/workspace/LogReceiver/logreceiver.cpp b/workspace/LogReceiver/logreceiver.cpp index 60e8b5c..2f41e08 100644 --- a/workspace/LogReceiver/logreceiver.cpp +++ b/workspace/LogReceiver/logreceiver.cpp @@ -55,8 +55,8 @@ void LogReceiver::initAndRun(QString serverPath, dhcpcdArguments.append(*args); } - dhcpcdArguments.append("-d"); - QString ifName("eth1"); + //dhcpcdArguments.append("-d"); + QString ifName("eth0"); runDHCPCD(ifName); } @@ -280,6 +280,25 @@ bool LogReceiver::checkCarrierState(QString interface) { } +void LogReceiver::checkInternetConnection(/*QList &interfaces*/) { + qDebug() << "check internet connection"; + QList allConfigs = manager.allConfigurations(QNetworkConfiguration::Discovered); + foreach(QNetworkConfiguration nC, allConfigs) { + qDebug() << nC.name(); + if(nC.isValid()) { + qDebug() << "config is valid"; + qDebug() << "try to open a new session"; + QNetworkSession session = new QNetworkSession(nC, this); + conntect(session,SIGNAL(error), this, SLOT(handleSessionError())); + conntect(session,SIGNAL(opened), this, SLOT(handleSessionOpened())); + session.open(); + session.waitForOpened(); + + } + } + qDebug() << "check internet connection done"; +} + void LogReceiver::handleProcessFinished(int exitCode, QProcess::ExitStatus exitStatus) { @@ -291,6 +310,7 @@ void LogReceiver::handleProcessFinished(int exitCode, } else { qDebug() << "process finished: " << client->pid() << exitCode << exitStatus; + checkInternetConnection(); } } @@ -299,7 +319,6 @@ void LogReceiver::handleProcessStarted() { } - bool LogReceiver::checkBlackList(QString i) { if (i.startsWith("v", Qt::CaseInsensitive)) { return true; -- cgit v1.2.3-55-g7522