File indexing completed on 2024-09-08 03:43:41

0001 /*
0002     SPDX-FileCopyrightText: 2001, 2002, 2003 Frerich Raabe <raabe@kde.org>
0003 
0004     SPDX-License-Identifier: BSD-2-Clause
0005 */
0006 
0007 #ifndef SYNDICATION_DATARETRIEVER_H
0008 #define SYNDICATION_DATARETRIEVER_H
0009 
0010 #include "syndication_export.h"
0011 
0012 #include <QObject>
0013 
0014 class QUrl;
0015 
0016 class QByteArray;
0017 
0018 namespace Syndication
0019 {
0020 /**
0021  * Abstract baseclass for all data retriever classes. Subclass this to add
0022  * a new retrieval algorithm which can then be plugged into the RSS loader.
0023  * @see Loader, FileRetriever, OutputRetriever
0024  */
0025 class SYNDICATION_EXPORT DataRetriever : public QObject
0026 {
0027     Q_OBJECT
0028 public:
0029     /**
0030      * Default constructor.
0031      */
0032     DataRetriever();
0033 
0034     /**
0035      * Destructor.
0036      */
0037     ~DataRetriever() override;
0038 
0039     /**
0040      * Retrieve data from the given URL. This method is supposed to get
0041      * reimplemented by subclasses. It will be called by the Loader
0042      * class in case it needs to retrieve the data.
0043      *
0044      * @param url the URL to retrieve data from
0045      *
0046      * @see Loader::loadFrom()
0047      */
0048     virtual void retrieveData(const QUrl &url) = 0;
0049 
0050     /**
0051      * @return An error code which might give a more precise information
0052      * about what went wrong in case the 'success' flag returned with
0053      * the dataRetrieved() signal was 'false'. Note that the meaning of
0054      * the returned integer depends on the actual data retriever.
0055      */
0056     virtual int errorCode() const = 0;
0057 
0058     /**
0059      * aborts the retrieval process.
0060      */
0061     virtual void abort() = 0;
0062 
0063 Q_SIGNALS:
0064     /**
0065      * Emit this signal to tell the Loader class that the retrieval
0066      * process was finished.
0067      * @param data Should contain the retrieved data and will get
0068      * parsed by the Loader class.
0069      * @param success Indicates whether there were any problems during
0070      * the retrieval process. Pass 'true' to indicate that everything
0071      * went seamlessy, 'false' to tell the Loader that something went
0072      * wrong and that the data parameter might contain no or invalid
0073      * data.
0074      */
0075 
0076     void dataRetrieved(const QByteArray &data, bool success);
0077 
0078 private:
0079     DataRetriever(const DataRetriever &other);
0080     DataRetriever &operator=(const DataRetriever &other);
0081 };
0082 
0083 } // namespace Syndication
0084 
0085 #endif // SYNDICATION_DATARETRIEVER_H