/* * All or portions of this file Copyright (c) Amazon.com, Inc. or its affiliates or * its licensors. * * For complete copyright and license terms please see the LICENSE at the root of this * distribution (the "License"). All use of this software is governed by the License, * or, if provided, by the license below or the license accompanying this file. Do not * remove or modify any license notices. This file is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * */ #pragma once #include #include #include #include class QNetworkAccessManager; class QNetworkReply; class QThread; namespace News { //! QtDownloader is a wrapper around Qt's file download functions /*! The QtDownloader spins up another thread and does all downloads in that thread. The public slot methods (Finish, Download and Abort) can all be called from any thread. The response signals (successfullyFinished and failed) should be QObject::connect to with Qt::QueuedConnection, as they will be emitted from the worker thread. */ class QtDownloader : public QObject { Q_OBJECT public: QtDownloader(); ~QtDownloader(); public Q_SLOTS: void Finish(); int Download(const QString& url); void Abort(); Q_SIGNALS: void successfullyFinished(int downloadId, QByteArray data); void failed(int downloadId); // *********************************************** // private - DO NOT CONNECT TO outside of the class! // (qt signals can't be made private) void triggerAbortAll(); void triggerDownload(int downloadId, QString url); void triggerQuit(); // *********************************************** private: void downloadFinished(QNetworkReply* reply); int m_lastId = 0; QMap m_downloads; QNetworkAccessManager* m_networkManager = nullptr; QThread* m_thread; }; }