QGIS API Documentation 3.37.0-Master (fdefdf9c27f)
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
49 enum Method
50 {
56 PatchMethod
57 };
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
98 QgsServerRequest() = default;
99
107 QgsServerRequest( const QString &url, QgsServerRequest::Method method = QgsServerRequest::GetMethod, const QgsServerRequest::Headers &headers = QgsServerRequest::Headers() );
108
116 QgsServerRequest( const QUrl &url, QgsServerRequest::Method method = QgsServerRequest::GetMethod, const QgsServerRequest::Headers &headers = QgsServerRequest::Headers() );
117
121 QgsServerRequest( const QgsServerRequest &other );
122
123 QgsServerRequest &operator=( const QgsServerRequest & ) = default;
124
126 virtual ~QgsServerRequest() = default;
127
132 static QString methodToString( const Method &method );
133
134
141 QUrl url() const;
142
146 QgsServerRequest::Method method() const;
147
152 QgsServerRequest::Parameters parameters() const;
153
157 QgsServerParameters serverParameters() const;
158
162 virtual void setParameter( const QString &key, const QString &value );
163
167 QString parameter( const QString &key, const QString &defaultValue = QString() ) const;
168
172 virtual void removeParameter( const QString &key );
173
179 virtual QString header( const QString &name ) const;
180
186 virtual QString header( const RequestHeader &headerEnum ) const;
187
193 void setHeader( const QString &name, const QString &value );
194
199 QMap<QString, QString> headers() const;
200
206 void removeHeader( const QString &name );
207
213 virtual QByteArray data() const;
214
218 virtual void setUrl( const QUrl &url );
219
227 QUrl originalUrl() const;
228
237 QUrl baseUrl() const;
238
242 void setMethod( QgsServerRequest::Method method );
243
248 const QString queryParameter( const QString &name, const QString &defaultValue = QString( ) ) const;
249
250 protected:
251
258 void setOriginalUrl( const QUrl &url );
259
265 void setBaseUrl( const QUrl &url );
266
267 private:
268 // Url as seen by QGIS server after web server rewrite
269 QUrl mUrl;
270 // Unrewritten url as seen by the web server
271 QUrl mOriginalUrl;
272 QUrl mBaseUrl;
273 Method mMethod = GetMethod;
274 // We mark as mutable in order
275 // to support lazy initialization
276 mutable Headers mHeaders;
277 QgsServerParameters mParams;
278};
279
280#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.