summaryrefslogtreecommitdiffstats
path: root/src/webenginewidgets/api/qwebenginedownloaditem.cpp
diff options
context:
space:
mode:
authorAndras Becsi <andras.becsi@theqtcompany.com>2015-01-27 13:11:06 +0100
committerAndras Becsi <andras.becsi@theqtcompany.com>2015-02-02 14:24:27 +0000
commitb4864da72e5861c3958c66cc9018aaf5b681320b (patch)
treed99b73c1e2bc476fd5126474ee8421d924e0da41 /src/webenginewidgets/api/qwebenginedownloaditem.cpp
parent6d896290a020babe5fbaf6c444485df8b1d5d353 (diff)
Add widgets download API
This patch adds a QWebEngineDownloadItem class to the widget API and extends QWebEngineProfile with a signal to notify about initiated downloads, similar to the QML API. [ChangeLog][QtWebEngineWidgets] Add widgets download API Change-Id: I532de640934e1e93d63dfc347efb4113cb4a3d66 Reviewed-by: Jocelyn Turcotte <jturcotte@woboq.com>
Diffstat (limited to 'src/webenginewidgets/api/qwebenginedownloaditem.cpp')
-rw-r--r--src/webenginewidgets/api/qwebenginedownloaditem.cpp302
1 files changed, 302 insertions, 0 deletions
diff --git a/src/webenginewidgets/api/qwebenginedownloaditem.cpp b/src/webenginewidgets/api/qwebenginedownloaditem.cpp
new file mode 100644
index 000000000..f97b25431
--- /dev/null
+++ b/src/webenginewidgets/api/qwebenginedownloaditem.cpp
@@ -0,0 +1,302 @@
+/****************************************************************************
+**
+** Copyright (C) 2015 Digia Plc and/or its subsidiary(-ies).
+** Contact: http://www.qt-project.org/legal
+**
+** This file is part of the QtWebEngine module of the Qt Toolkit.
+**
+** $QT_BEGIN_LICENSE:LGPL$
+** Commercial License Usage
+** Licensees holding valid commercial Qt licenses may use this file in
+** accordance with the commercial license agreement provided with the
+** Software or, alternatively, in accordance with the terms contained in
+** a written agreement between you and Digia. For licensing terms and
+** conditions see http://qt.digia.com/licensing. For further information
+** use the contact form at http://qt.digia.com/contact-us.
+**
+** GNU Lesser General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU Lesser
+** General Public License version 3 as published by the Free Software
+** Foundation and appearing in the file LICENSE.LGPLv3 included in the
+** packaging of this file. Please review the following information to
+** ensure the GNU Lesser General Public License version 3 requirements
+** will be met: https://www.gnu.org/licenses/lgpl.html.
+**
+** GNU General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU
+** General Public License version 2.0 or later as published by the Free
+** Software Foundation and appearing in the file LICENSE.GPL included in
+** the packaging of this file. Please review the following information to
+** ensure the GNU General Public License version 2.0 requirements will be
+** met: http://www.gnu.org/licenses/gpl-2.0.html.
+**
+** $QT_END_LICENSE$
+**
+****************************************************************************/
+
+#include "qwebenginedownloaditem.h"
+
+#include "qwebenginedownloaditem_p.h"
+#include "qwebengineprofile_p.h"
+
+QT_BEGIN_NAMESPACE
+
+static inline QWebEngineDownloadItem::DownloadState toDownloadState(int state)
+{
+ switch (state) {
+ case BrowserContextAdapterClient::DownloadInProgress:
+ return QWebEngineDownloadItem::DownloadInProgress;
+ case BrowserContextAdapterClient::DownloadCompleted:
+ return QWebEngineDownloadItem::DownloadCompleted;
+ case BrowserContextAdapterClient::DownloadCancelled:
+ return QWebEngineDownloadItem::DownloadCancelled;
+ case BrowserContextAdapterClient::DownloadInterrupted:
+ return QWebEngineDownloadItem::DownloadInterrupted;
+ default:
+ Q_UNREACHABLE();
+ return QWebEngineDownloadItem::DownloadCancelled;
+ }
+}
+
+/*!
+ \class QWebEngineDownloadItem
+ \brief The QWebEngineDownloadItem class provides information about a download.
+
+ \since 5.5
+
+ \inmodule QtWebEngineWidgets
+
+ QWebEngineDownloadItem stores the state of a download to be used to manage requested downloads.
+*/
+
+QWebEngineDownloadItemPrivate::QWebEngineDownloadItemPrivate(QWebEngineProfilePrivate *p, const QUrl &url)
+ : profile(p)
+ , downloadFinished(false)
+ , downloadId(-1)
+ , downloadState(QWebEngineDownloadItem::DownloadCancelled)
+ , downloadUrl(url)
+ , totalBytes(-1)
+ , receivedBytes(0)
+{
+}
+
+QWebEngineDownloadItemPrivate::~QWebEngineDownloadItemPrivate()
+{
+ profile->downloadDestroyed(downloadId);
+}
+
+void QWebEngineDownloadItemPrivate::update(const BrowserContextAdapterClient::DownloadItemInfo &info)
+{
+ Q_Q(QWebEngineDownloadItem);
+
+ Q_ASSERT(downloadState != QWebEngineDownloadItem::DownloadRequested);
+
+ if (info.state != downloadState) {
+ downloadState = toDownloadState(info.state);
+ Q_EMIT q->stateChanged(downloadState);
+ }
+
+ if (info.receivedBytes != receivedBytes || info.totalBytes != totalBytes) {
+ receivedBytes = info.receivedBytes;
+ totalBytes = info.totalBytes;
+ Q_EMIT q->downloadProgress(receivedBytes, totalBytes);
+ }
+
+ downloadFinished = downloadState != QWebEngineDownloadItem::DownloadInProgress;
+
+ if (downloadFinished)
+ Q_EMIT q->finished();
+}
+
+/*!
+ Accepts the current download request, which will start the download.
+
+ \sa finished(), stateChanged()
+*/
+
+void QWebEngineDownloadItem::accept()
+{
+ Q_D(QWebEngineDownloadItem);
+
+ if (d->downloadState != QWebEngineDownloadItem::DownloadRequested)
+ return;
+
+ d->downloadState = QWebEngineDownloadItem::DownloadInProgress;
+ Q_EMIT stateChanged(d->downloadState);
+}
+
+/*!
+ Cancels the current download.
+
+ \sa finished(), stateChanged()
+*/
+
+void QWebEngineDownloadItem::cancel()
+{
+ Q_D(QWebEngineDownloadItem);
+
+ QWebEngineDownloadItem::DownloadState state = d->downloadState;
+
+ if (state == QWebEngineDownloadItem::DownloadCompleted
+ || state == QWebEngineDownloadItem::DownloadCancelled)
+ return;
+
+ d->downloadState = QWebEngineDownloadItem::DownloadCancelled;
+ Q_EMIT stateChanged(d->downloadState);
+
+ // We directly cancel the download request if the user cancels
+ // before it even started, so no need to notify the profile here.
+ if (state == QWebEngineDownloadItem::DownloadInProgress)
+ d->profile->cancelDownload(d->downloadId);
+}
+
+/*!
+ Returns the download item's id.
+*/
+
+quint32 QWebEngineDownloadItem::id()
+{
+ Q_D(QWebEngineDownloadItem);
+ return d->downloadId;
+}
+
+/*!
+ \fn QWebEngineDownloadItem::finished()
+
+ This signal is emitted whenever the download finishes.
+
+ \sa state(), isFinished()
+*/
+
+/*!
+ \fn QWebEngineDownloadItem::stateChanged(DownloadState state)
+
+ This signal is emitted whenever the download's \a state changes.
+
+ \sa state(), QWebEngineDownloadItem::DownloadState
+*/
+
+/*!
+ \fn QWebEngineDownloadItem::downloadProgress(qint64 bytesReceived, qint64 bytesTotal)
+
+ This signal is emitted whenever the download's \a bytesReceived or
+ \a bytesTotal changes.
+
+ \sa totalBytes(), receivedBytes()
+*/
+
+/*!
+ \enum QWebEngineDownloadItem::DownloadState
+
+ This enum describes the state in which the download is in.
+
+ \value DownloadRequested The download has been requested, but has not been accepted yet.
+ \value DownloadInProgress The download is in progress.
+ \value DownloadCompleted The download completed successfully.
+ \value DownloadCancelled The download has been cancelled.
+ \value DownloadInterrupted The download has been interrupted (by the server or because of lost connectivity).
+*/
+
+/*!
+ Returns the download item's current state.
+
+ \sa QWebEngineDownloadItem::DownloadState
+*/
+
+QWebEngineDownloadItem::DownloadState QWebEngineDownloadItem::state()
+{
+ Q_D(QWebEngineDownloadItem);
+ return d->downloadState;
+}
+
+/*!
+ Returns the download's total size in bytes.
+
+ -1 means the size is unknown.
+*/
+
+qint64 QWebEngineDownloadItem::totalBytes()
+{
+ Q_D(QWebEngineDownloadItem);
+ return d->totalBytes;
+}
+
+/*!
+ Returns the download's bytes that have been received so far.
+
+ -1 means the size is unknown.
+*/
+
+qint64 QWebEngineDownloadItem::receivedBytes()
+{
+ Q_D(QWebEngineDownloadItem);
+ return d->receivedBytes;
+}
+
+/*!
+ Returns the download's origin url.
+*/
+
+QUrl QWebEngineDownloadItem::url()
+{
+ Q_D(QWebEngineDownloadItem);
+ return d->downloadUrl;
+}
+
+/*!
+ Returns the download's full target path where it is being downloaded to.
+
+ The path includes the file name. The default suggested path is the standard download location
+ and file name is deduced not to overwrite already existing files.
+*/
+
+QString QWebEngineDownloadItem::path()
+{
+ Q_D(QWebEngineDownloadItem);
+ return d->downloadPath;
+}
+
+/*!
+ Sets the download's full target path, where the file should be downloaded to.
+
+ The \a path should also include the file name. The download path can only be set in response
+ to the QWebEngineProfile::downloadRequested() signal before the download is accepted.
+ Past that point this function has no effect on the download item's state.
+*/
+void QWebEngineDownloadItem::setPath(QString path)
+{
+ Q_D(QWebEngineDownloadItem);
+ if (d->downloadState != QWebEngineDownloadItem::DownloadRequested) {
+ qWarning("Setting the download path is not allowed after the download has been accepted.");
+ return;
+ }
+
+ d->downloadPath = path;
+}
+
+/*!
+ Returns whether this download is finished (not in progress).
+
+ \sa finished(), state(),
+*/
+
+bool QWebEngineDownloadItem::isFinished()
+{
+ Q_D(QWebEngineDownloadItem);
+ return d->downloadFinished;
+}
+
+QWebEngineDownloadItem::QWebEngineDownloadItem(QWebEngineDownloadItemPrivate *p, QObject *parent)
+ : QObject(parent)
+ , d_ptr(p)
+{
+ p->q_ptr = this;
+}
+
+/*! \internal
+*/
+QWebEngineDownloadItem::~QWebEngineDownloadItem()
+{
+}
+
+QT_END_NAMESPACE