QGIS API Documentation 3.43.0-Master (ac54a16a525)
qgsserverrequest.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsserverrequest.h
3
4 Define request class for getting request contents
5 -------------------
6 begin : 2016-12-05
7 copyright : (C) 2016 by David Marteau
8 email : david dot marteau at 3liz dot com
9 ***************************************************************************/
10
11/***************************************************************************
12 * *
13 * This program is free software; you can redistribute it and/or modify *
14 * it under the terms of the GNU General Public License as published by *
15 * the Free Software Foundation; either version 2 of the License, or *
16 * (at your option) any later version. *
17 * *
18 ***************************************************************************/
19#ifndef QGSSERVERREQUEST_H
20#define QGSSERVERREQUEST_H
21
22#include <QUrl>
23#include <QMap>
24#include "qgis_server.h"
25#include "qgsserverparameters.h"
26
27// Note about design: this interface must be passed along to Python and thus signatures methods must be
28// compatible with pyQGIS/pyQT api and rules.
29
34class SERVER_EXPORT QgsServerRequest
35{
36 Q_GADGET
37
38 public:
39 typedef QMap<QString, QString> Parameters;
40 typedef QMap<QString, QString> Headers;
41
54 Q_ENUM( Method )
55
56
76 Q_ENUM( RequestHeader )
77
78 QgsServerRequest() = default;
79
87 QgsServerRequest( const QString &url, QgsServerRequest::Method method = QgsServerRequest::GetMethod, const QgsServerRequest::Headers &headers = QgsServerRequest::Headers() );
88
96 QgsServerRequest( const QUrl &url, QgsServerRequest::Method method = QgsServerRequest::GetMethod, const QgsServerRequest::Headers &headers = QgsServerRequest::Headers() );
97
98 QgsServerRequest( const QgsServerRequest &other );
99
100 QgsServerRequest &operator=( const QgsServerRequest & ) = default;
101 virtual ~QgsServerRequest() = default;
102
107 static QString methodToString( const Method &method );
108
109
115 QUrl url() const;
116
120 QgsServerRequest::Method method() const;
121
126 QgsServerRequest::Parameters parameters() const;
127
131 QgsServerParameters serverParameters() const;
132
136 virtual void setParameter( const QString &key, const QString &value );
137
141 QString parameter( const QString &key, const QString &defaultValue = QString() ) const;
142
146 virtual void removeParameter( const QString &key );
147
153 virtual QString header( const QString &name ) const;
154
160 virtual QString header( const RequestHeader &headerEnum ) const;
161
167 void setHeader( const QString &name, const QString &value );
168
173 QMap<QString, QString> headers() const;
174
180 void removeHeader( const QString &name );
181
187 virtual QByteArray data() const;
188
192 virtual void setUrl( const QUrl &url );
193
201 QUrl originalUrl() const;
202
211 QUrl baseUrl() const;
212
216 void setMethod( QgsServerRequest::Method method );
217
222 const QString queryParameter( const QString &name, const QString &defaultValue = QString() ) const;
223
224 protected:
231 void setOriginalUrl( const QUrl &url );
232
238 void setBaseUrl( const QUrl &url );
239
240 private:
241 // Url as seen by QGIS server after web server rewrite
242 QUrl mUrl;
243 // Unrewritten url as seen by the web server
244 QUrl mOriginalUrl;
245 QUrl mBaseUrl;
246 Method mMethod = GetMethod;
247 // We mark as mutable in order
248 // to support lazy initialization
249 mutable Headers mHeaders;
250 QgsServerParameters mParams;
251};
252
253#endif
Provides an interface to retrieve and manipulate global parameters received from the client.
Defines requests passed to QgsService classes.
Method
HTTP Method (or equivalent) used for the request.
QMap< QString, QString > Parameters
QMap< QString, QString > Headers
RequestHeader
The internal HTTP Header used for the request as enum.
@ X_QGIS_WMS_SERVICE_URL
The QGIS WMS service URL.
@ ACCEPT
Https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Accept.
@ X_QGIS_WCS_SERVICE_URL
The QGIS WCS service URL.
@ USER_AGENT
Https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/User-Agent.
@ X_QGIS_WFS_SERVICE_URL
The QGIS WFS service URL.
@ X_FORWARDED_FOR
Https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Forwarded-For.
@ X_FORWARDED_PROTO
Https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Forwarded-Proto.
@ X_QGIS_WMTS_SERVICE_URL
The QGIS WMTS service URL.
@ X_QGIS_SERVICE_URL
The QGIS service URL.
@ X_FORWARDED_HOST
Https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Forwarded-Host.
@ FORWARDED
Https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Forwarded, https://tools....
@ HOST
Https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Host.
@ AUTHORIZATION
Https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Authorization.