if(!m_webView) {
m_webView = new QWebView;
- connectWebViewSignals(true);
+ connect(m_webView, SIGNAL(urlChanged(const QUrl &)),
+ this, SIGNAL(updateCredentials(QUrl)));
+ connect(m_webView, SIGNAL(loadFinished(bool)),
+ this, SLOT(loadDone(bool)));
m_webView->hide();
}
m_webView->page()->networkAccessManager()->setCookieJar(m_cookieJar);
}
-void MainWindow::connectWebViewSignals(bool connectSignals)
-{
- qDebug() << __PRETTY_FUNCTION__;
-
- if(connectSignals) {
- connect(m_webView, SIGNAL(urlChanged(const QUrl &)),
- this, SIGNAL(updateCredentials(QUrl)));
- connect(m_webView, SIGNAL(loadFinished(bool)),
- this, SLOT(loadDone(bool)));
- }
- else {
- disconnect(m_webView, SIGNAL(loadFinished(bool)),
- this, SLOT(loadDone(bool)));
- disconnect(m_webView, SIGNAL(urlChanged(const QUrl &)),
- this, SLOT(updateCredentials(const QUrl &)));
- }
-}
-
void MainWindow::createMenus()
{
qDebug() << __PRETTY_FUNCTION__;
QString cookies = settings.value(COOKIES, EMPTY).toString();
if(!cookies.isEmpty()) {
QStringList list = cookies.split("|");
+ list.removeDuplicates();
QList<QNetworkCookie> cookieList;
for(int i=0;i<list.count();i++) {
QNetworkCookie tmpCookie;
- QList<QNetworkCookie> parserList = tmpCookie.parseCookies(list.at(i).toAscii());
- cookieList.append(parserList.at(0));
+ cookieList.append(tmpCookie.parseCookies(list.at(i).toAscii()));
}
- if(!m_cookieJar) {
+ if(!m_cookieJar)
m_cookieJar = new NetworkCookieJar(new QNetworkCookieJar(this));
- }
m_cookieJar->setAllCookies(cookieList);
m_webView->page()->networkAccessManager()->setCookieJar(m_cookieJar);
QByteArray byteArray = cookie.toRawForm(QNetworkCookie::Full);
list.append(QString(byteArray));
}
- QSettings settings(DIRECTORY_NAME, FILE_NAME);
+ list.removeDuplicates();
+ QSettings settings(DIRECTORY_NAME, FILE_NAME);
settings.setValue(COOKIES, list.join("|"));
}
if(m_loginDialog->exec() != QDialog::Accepted) {
// if login dialog was canceled we need to stop processing webview
- // stop and disconnect m_webView;
m_webView->stop();
- connectWebViewSignals(false);
emit cancelLoginProcess();
}
else {
- // connect webview signals again since they might have been disconnected
- connectWebViewSignals(true);
-
m_webView->load(url);
toggleProgressIndicator(true);
m_refresh = true;