Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/owncloud/client.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Molkentin <danimo@owncloud.com>2014-11-10 00:30:05 +0300
committerDaniel Molkentin <danimo@owncloud.com>2014-11-10 00:30:05 +0300
commit9ebc41ed6f0edf94e1f38f43de6f6e80b47e14d1 (patch)
treeabcde5d08a5f6f30e170f195ff23a29ee05c6b36 /src/libsync/accessmanager.cpp
parentf25d175b5d4494f6c1cd5c81c46cf6627f55c51a (diff)
Remove "Mirall" from cmake project files
Diffstat (limited to 'src/libsync/accessmanager.cpp')
-rw-r--r--src/libsync/accessmanager.cpp91
1 files changed, 91 insertions, 0 deletions
diff --git a/src/libsync/accessmanager.cpp b/src/libsync/accessmanager.cpp
new file mode 100644
index 000000000..0c4531bbd
--- /dev/null
+++ b/src/libsync/accessmanager.cpp
@@ -0,0 +1,91 @@
+/*
+ * Copyright (C) by Krzesimir Nowak <krzesimir@endocode.com>
+ *
+ * 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; version 2 of the License.
+ *
+ * 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.
+ */
+
+#include <QNetworkRequest>
+#include <QNetworkReply>
+#include <QNetworkProxy>
+#include <QAuthenticator>
+#include <QSslConfiguration>
+
+#include "authenticationdialog.h"
+#include "cookiejar.h"
+#include "mirallaccessmanager.h"
+#include "utility.h"
+
+namespace Mirall
+{
+
+MirallAccessManager::MirallAccessManager(QObject* parent)
+ : QNetworkAccessManager (parent)
+{
+#if QT_VERSION >= QT_VERSION_CHECK(5, 0, 0) && defined(Q_OS_MAC)
+ // FIXME Workaround http://stackoverflow.com/a/15707366/2941 https://bugreports.qt-project.org/browse/QTBUG-30434
+ QNetworkProxy proxy = this->proxy();
+ proxy.setHostName(" ");
+ setProxy(proxy);
+#endif
+ setCookieJar(new CookieJar);
+ connect(this, SIGNAL(proxyAuthenticationRequired(QNetworkProxy,QAuthenticator*)),
+ this, SLOT(slotProxyAuthenticationRequired(QNetworkProxy,QAuthenticator*)));
+ connect(this, SIGNAL(authenticationRequired(QNetworkReply*,QAuthenticator*)),
+ this, SLOT(slotAuthenticationRequired(QNetworkReply*,QAuthenticator*)));
+
+}
+
+QNetworkReply* MirallAccessManager::createRequest(QNetworkAccessManager::Operation op, const QNetworkRequest& request, QIODevice* outgoingData)
+{
+ QNetworkRequest newRequest(request);
+ newRequest.setRawHeader(QByteArray("User-Agent"), Utility::userAgentString());
+ QByteArray verb = newRequest.attribute(QNetworkRequest::CustomVerbAttribute).toByteArray();
+ // For PROPFIND (assumed to be a WebDAV op), set xml/utf8 as content type/encoding
+ // This needs extension
+ if (verb == "PROPFIND") {
+ newRequest.setHeader( QNetworkRequest::ContentTypeHeader, QLatin1String("text/xml; charset=utf-8"));
+ }
+ return QNetworkAccessManager::createRequest(op, newRequest, outgoingData);
+}
+
+void MirallAccessManager::slotProxyAuthenticationRequired(const QNetworkProxy &proxy, QAuthenticator *authenticator)
+{
+ Q_UNUSED(authenticator);
+ qDebug() << Q_FUNC_INFO << proxy.type();
+ // We put in the password here and in ClientProxy in the proxy itself.
+ if (!proxy.user().isEmpty() || !proxy.password().isEmpty()) {
+ authenticator->setUser(proxy.user());
+ authenticator->setPassword(proxy.password());
+ }
+}
+void MirallAccessManager::slotAuthenticationRequired(QNetworkReply *reply, QAuthenticator *authenticator)
+{
+ // do not handle 401 created by the networkjobs. We may want
+ // to eventually exempt some, but for now we need
+ // it only for other things, e.g. the browser. Would we handle
+ // network jobs, this would break the wizard logic
+ if (reply->property("doNotHandleAuth").toBool()) {
+ return;
+ }
+ QUrl url = reply->url();
+ // show only scheme, host and port
+ QUrl reducedUrl;
+ reducedUrl.setScheme(url.scheme());
+ reducedUrl.setHost(url.host());
+ reducedUrl.setPort(url.port());
+
+ AuthenticationDialog dialog(authenticator->realm(), reducedUrl.toString());
+ if (dialog.exec() == QDialog::Accepted) {
+ authenticator->setUser(dialog.user());
+ authenticator->setPassword(dialog.password());
+ }
+}
+
+} // ns Mirall