QGIS API Documentation 3.39.0-Master (3aed037ce22)
Loading...
Searching...
No Matches
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
34// Note about design: this interface must be passed along to Python and thus signatures methods must be
35// compatible with pyQGIS/pyQT api and rules.
36
37class SERVER_EXPORT QgsServerRequest
38{
39 Q_GADGET
40
41 public:
42
43 typedef QMap<QString, QString> Parameters;
44 typedef QMap<QString, QString> Headers;
45
58 Q_ENUM( Method )
59
60
64 {
65 // https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Host
67 // https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Forwarded
68 // https://tools.ietf.org/html/rfc7239
70 // https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Forwarded-For
72 // https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Forwarded-Host
74 // https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Forwarded-Proto
76 // The QGIS service URL
78 // The QGIS WMS service URL
80 // The QGIS WFS service URL
82 // The QGIS WCS service URL
84 // The QGIS WMTS service URL
86 // https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Accept
88 // https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/User-Agent
90 // https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Authorization
92 };
93 Q_ENUM( RequestHeader )
94
95 QgsServerRequest() = default;
96
104 QgsServerRequest( const QString &url, QgsServerRequest::Method method = QgsServerRequest::GetMethod, const QgsServerRequest::Headers &headers = QgsServerRequest::Headers() );
105
113 QgsServerRequest( const QUrl &url, QgsServerRequest::Method method = QgsServerRequest::GetMethod, const QgsServerRequest::Headers &headers = QgsServerRequest::Headers() );
114
115 QgsServerRequest( const QgsServerRequest &other );
116
117 QgsServerRequest &operator=( const QgsServerRequest & ) = default;
118 virtual ~QgsServerRequest() = default;
119
124 static QString methodToString( const Method &method );
125
126
133 QUrl url() const;
134
138 QgsServerRequest::Method method() const;
139
144 QgsServerRequest::Parameters parameters() const;
145
149 QgsServerParameters serverParameters() const;
150
154 virtual void setParameter( const QString &key, const QString &value );
155
159 QString parameter( const QString &key, const QString &defaultValue = QString() ) const;
160
164 virtual void removeParameter( const QString &key );
165
171 virtual QString header( const QString &name ) const;
172
178 virtual QString header( const RequestHeader &headerEnum ) const;
179
185 void setHeader( const QString &name, const QString &value );
186
191 QMap<QString, QString> headers() const;
192
198 void removeHeader( const QString &name );
199
205 virtual QByteArray data() const;
206
210 virtual void setUrl( const QUrl &url );
211
219 QUrl originalUrl() const;
220
229 QUrl baseUrl() const;
230
234 void setMethod( QgsServerRequest::Method method );
235
240 const QString queryParameter( const QString &name, const QString &defaultValue = QString( ) ) const;
241
242 protected:
243
250 void setOriginalUrl( const QUrl &url );
251
257 void setBaseUrl( const QUrl &url );
258
259 private:
260 // Url as seen by QGIS server after web server rewrite
261 QUrl mUrl;
262 // Unrewritten url as seen by the web server
263 QUrl mOriginalUrl;
264 QUrl mBaseUrl;
265 Method mMethod = GetMethod;
266 // We mark as mutable in order
267 // to support lazy initialization
268 mutable Headers mHeaders;
269 QgsServerParameters mParams;
270};
271
272#endif
QgsServerParameters provides an interface to retrieve and manipulate global parameters received from ...
QgsServerRequest Class defining request interface passed to services QgsService::executeRequest() met...
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.