QGIS API Documentation  2.2.0-Valmiera
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
qgsnetworkaccessmanager.h
Go to the documentation of this file.
1 /***************************************************************************
2  qgsnetworkaccessmanager.h - description
3  -------------------
4  begin : 2010-05-08
5  copyright : (C) 2010 by Juergen E. Fischer
6  email : jef at norbit dot de
7  ***************************************************************************/
8 
9 /***************************************************************************
10  * *
11  * This program is free software; you can redistribute it and/or modify *
12  * it under the terms of the GNU General Public License as published by *
13  * the Free Software Foundation; either version 2 of the License, or *
14  * (at your option) any later version. *
15  * *
16  ***************************************************************************/
17 
18 #ifndef QGSNETWORKACCESSMANAGER_H
19 #define QGSNETWORKACCESSMANAGER_H
20 
21 #include <QList>
22 #include <QStringList>
23 #include <QNetworkAccessManager>
24 #include <QNetworkProxy>
25 #include <QNetworkRequest>
26 
27 class QTimer;
28 
29 /*
30  * \class QgsNetworkAccessManager
31  * \brief network access manager for QGIS
32  * \ingroup core
33  * \since 1.5
34  *
35  * This class implements the QGIS network access manager. It's a singleton
36  * that can be used across QGIS.
37  *
38  * Plugins can insert proxy factories and thereby redirect requests to
39  * individual proxies.
40  *
41  * If no proxy factories are there or none returns a proxy for an URL a
42  * fallback proxy can be set. There's also a exclude list that defines URLs
43  * that the fallback proxy should not be used for, then no proxy will be used.
44  *
45  */
46 class CORE_EXPORT QgsNetworkAccessManager : public QNetworkAccessManager
47 {
48  Q_OBJECT
49 
50  public:
52  // and creates that instance on the first call.
53  static QgsNetworkAccessManager *instance();
54 
57 
59  void insertProxyFactory( QNetworkProxyFactory *factory );
60 
62  void removeProxyFactory( QNetworkProxyFactory *factory );
63 
65  const QList<QNetworkProxyFactory *> proxyFactories() const;
66 
68  const QNetworkProxy &fallbackProxy() const;
69 
71  const QStringList &excludeList() const;
72 
74  void setFallbackProxyAndExcludes( const QNetworkProxy &proxy, const QStringList &excludes );
75 
77  static QString cacheLoadControlName( QNetworkRequest::CacheLoadControl theControl );
78 
80  static QNetworkRequest::CacheLoadControl cacheLoadControlFromName( const QString &theName );
81 
82  signals:
83  void requestAboutToBeCreated( QNetworkAccessManager::Operation, const QNetworkRequest &, QIODevice * );
84  void requestCreated( QNetworkReply * );
85 
86  private slots:
87  void connectionProgress();
88  void connectionDestroyed( QObject* );
89  void abortRequest();
90 
91  protected:
92  virtual QNetworkReply *createRequest( QNetworkAccessManager::Operation op, const QNetworkRequest &req, QIODevice *outgoingData = 0 );
93 
94  private:
95  QgsNetworkAccessManager( QObject *parent = 0 );
96  QList<QNetworkProxyFactory*> mProxyFactories;
97  QNetworkProxy mFallbackProxy;
98  QStringList mExcludedURLs;
99 
100  QMap<QNetworkReply*, QTimer*> mActiveRequests;
101 };
102 
103 #endif // QGSNETWORKACCESSMANAGER_H