/usr/include/qgis/qgshttptransaction.h is in libqgis-dev 2.18.17+dfsg-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 | /***************************************************************************
qgshttptransaction.h - Tracks a HTTP request with its response,
with particular attention to tracking
HTTP redirect responses
-------------------
begin : 17 Mar, 2005
copyright : (C) 2005 by Brendan Morley
email : morb at ozemail dot com dot au
***************************************************************************/
/***************************************************************************
* *
* 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; either version 2 of the License, or *
* (at your option) any later version. *
* *
***************************************************************************/
#ifndef QGSHTTPTRANSACTION_H
#define QGSHTTPTRANSACTION_H
#include <QHttp>
#include <QNetworkProxy>
#include <QString>
class QTimer;
/** \ingroup core
* HTTP request/response manager that is redirect-aware.
* This class extends the Qt QHttp concept by being able to recognise
* and respond to redirection responses (e.g. HTTP code 302)
*/
class CORE_EXPORT QgsHttpTransaction : public QObject
{
Q_OBJECT
public:
/**
* Constructor.
*/
QgsHttpTransaction( const QString& uri,
const QString& proxyHost = QString(),
int proxyPort = 80,
const QString& proxyUser = QString(),
const QString& proxyPass = QString(),
QNetworkProxy::ProxyType proxyType = QNetworkProxy::NoProxy,
const QString& userName = QString(),
const QString& password = QString() );
//! Destructor
virtual ~QgsHttpTransaction();
void getAsynchronously();
//! Gets the response synchronously. Note that signals will still be emitted
//! while in this function.
/*!
The function returns false if there is an error while getting the response.
@param[out] respondedContent is replaced with the new content.
@param[in] redirections is used to measure how many http redirections we've been through.
Clients typically don't need to set this.
@param postData data to send with the http message. This is only used for HTTP POST. If
0 then the request is done with HTTP GET.
@return true in case of success
*/
bool getSynchronously( QByteArray &respondedContent, int redirections = 0, const QByteArray* postData = nullptr );
QString responseContentType();
/**
* If an operation returns 0 (e.g. getSynchronously()), this function
* returns the text of the error associated with the failure.
* Interactive users of this provider can then, for example,
* call a QMessageBox to display the contents.
*/
QString errorString();
/** Apply proxy settings from QSettings to a http object
@return true if proxy settings was applied, false else*/
static bool applyProxySettings( QHttp& http, const QString& url );
/** Set the credentials (username and password) */
void setCredentials( const QString& username, const QString &password );
/** Returns the network timeout in msec*/
int networkTimeout() const { return mNetworkTimeoutMsec;}
/** Sets the network timeout in milliseconds*/
void setNetworkTimeout( int msec ) { mNetworkTimeoutMsec = msec;}
public slots:
void dataStarted( int id );
void dataHeaderReceived( const QHttpResponseHeader& resp );
void dataReceived( const QHttpResponseHeader& resp );
void dataProgress( int done, int total );
void dataFinished( int id, bool error );
void transactionFinished( bool error );
void dataStateChanged( int state );
void networkTimedOut();
/** Aborts the current transaction*/
void abort();
signals:
/** Legacy code. This signal is currently not emitted and only kept for API compatibility*/
void setProgress( int done, int total );
/** Signal for progress update */
void dataReadProgress( int theProgress );
/** Signal for adjusted number of steps*/
void totalSteps( int theTotalSteps );
/** \brief emit a signal to be caught by qgisapp and display a msg on status bar */
void statusChanged( const QString& theStatusQString );
private:
/** Default constructor is forbidden*/
QgsHttpTransaction();
/**
* Indicates the associated QHttp object
*
* \note We tried to use this as a plain QHttp object
* but strange things were happening with the signals -
* therefore we use the "pointer to" instead.
*/
QHttp* http;
/**
* Indicates the QHttp ID
*/
int httpid;
/**
* Indicates if the transaction is in progress
*/
bool httpactive;
/*
* Indicates the response from the QHttp
*/
QByteArray httpresponse;
/*
* Indicates the content type of the response from the QHttp
*/
QString httpresponsecontenttype;
/**
* The original URL requested for this transaction
*/
QString httpurl;
/**
* The host being used for this transaction
*/
QString httphost;
/**
* If not empty, indicates that the QHttp is a redirect
* to the contents of this variable
*/
QString httpredirecturl;
/**
* Number of http redirections this transaction has been
* subjected to.
*
* TODO: Use this as part of a redirection loop detector
*
*/
int httpredirections;
/**
* Indicates the associated QTimer object - used to detect network timeouts
*/
QTimer * mWatchdogTimer;
/**
* The error message associated with the last HTTP error.
*/
QString mError;
/**
* User name
*/
QString mUserName;
/**
* Password
*/
QString mPassword;
/** Network timeout in milliseconds*/
int mNetworkTimeoutMsec;
};
#endif
// ENDS
|