QGIS API Documentation 4.1.0-Master (5bf3c20f3c9)
Loading...
Searching...
No Matches
qgsserverogcapi.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsserverogcapi.h - QgsServerOgcApi
3
4 ---------------------
5 begin : 10.7.2019
6 copyright : (C) 2019 by Alessandro Pasotti
7 email : elpaso at itopen dot it
8 ***************************************************************************
9 * *
10 * This program is free software; you can redistribute it and/or modify *
11 * it under the terms of the GNU General Public License as published by *
12 * the Free Software Foundation; either version 2 of the License, or *
13 * (at your option) any later version. *
14 * *
15 ***************************************************************************/
16#ifndef QGSSERVEROGCAPI_H
17#define QGSSERVEROGCAPI_H
18
19#include "qgis_server.h"
20#include "qgsserverapi.h"
21
23
47class SERVER_EXPORT QgsServerOgcApi : public QgsServerApi
48{
49 Q_GADGET
50
51 public:
52 // Note: non a scoped enum or qHash fails
54 enum Rel
55 {
56 // The following registered link relation types are used
67 // In addition the following link relation types are used for which no applicable registered link relation type could be identified:
71 };
72 Q_ENUM( Rel )
73
74 // Note: cannot be a scoped enum because qHash does not support them
84 Q_ENUM( ContentType )
85
86
94 QgsServerOgcApi( QgsServerInterface *serverIface, const QString &rootPath, const QString &name, const QString &description = QString(), const QString &version = QString() );
95
96 // QgsServerApi interface
97 const QString name() const override { return mName; }
98 const QString description() const override { return mDescription; }
99 const QString version() const override { return mVersion; }
100 const QString rootPath() const override { return mRootPath; }
101
102 ~QgsServerOgcApi() override;
103
107 void executeRequest( const QgsServerApiContext &context ) const override SIP_THROW( QgsServerApiBadRequestException ) SIP_VIRTUALERRORHANDLER( serverapi_badrequest_exception_handler );
108
113 static const QMap<QgsServerOgcApi::ContentType, QStringList> contentTypeMimes() SIP_SKIP;
114
119 static const QHash<QgsServerOgcApi::ContentType, QList<QgsServerOgcApi::ContentType>> contentTypeAliases() SIP_SKIP;
120
121 // Utilities
122#ifndef SIP_RUN
123
128 template<class T, typename... Args> void registerHandler( Args... args ) { mHandlers.emplace_back( std::make_shared<T>( args... ) ); }
129#endif
130
134 void registerHandler( QgsServerOgcApiHandler *handler SIP_TRANSFER );
135
140 static QUrl sanitizeUrl( const QUrl &url );
141
145 static std::string relToString( const QgsServerOgcApi::Rel &rel );
146
150 static QString contentTypeToString( const QgsServerOgcApi::ContentType &ct );
151
155 static std::string contentTypeToStdString( const QgsServerOgcApi::ContentType &ct );
156
160 static QString contentTypeToExtension( const QgsServerOgcApi::ContentType &ct );
161
166 Q_DECL_DEPRECATED static QgsServerOgcApi::ContentType contenTypeFromExtension( const std::string &extension ) SIP_DEPRECATED { return contentTypeFromExtension( extension ); } // spellok
167
172 static QgsServerOgcApi::ContentType contentTypeFromExtension( const std::string &extension );
173
177 static std::string mimeType( const QgsServerOgcApi::ContentType &contentType );
178
182 const std::vector<std::shared_ptr<QgsServerOgcApiHandler>> handlers() const SIP_SKIP;
183
184 private:
185 QString mRootPath;
186 QString mName;
187 QString mDescription;
188 QString mVersion;
189
190 //Note: this cannot be unique because of SIP bindings
191 std::vector<std::shared_ptr<QgsServerOgcApiHandler>> mHandlers;
192
194 static QMap<QgsServerOgcApi::ContentType, QStringList> sContentTypeMime;
195
201 static QHash<QgsServerOgcApi::ContentType, QList<QgsServerOgcApi::ContentType>> sContentTypeAliases;
202};
203
204#endif // QGSSERVEROGCAPI_H
Bad request error API exception.
Encapsulates the resources for a particular client request.
QgsServerApi(QgsServerInterface *serverIface)
Creates a QgsServerApi object.
virtual void executeRequest(const QgsServerApiContext &context) const =0
Executes a request by passing the given context to the API handlers.
Defines interfaces exposed by QGIS Server and made available to plugins.
An abstract class which represents an OGC API handler to be registered in QgsServerOgcApi class.
QGIS Server OGC API endpoint.
const QString rootPath() const override
Returns the root path for the API.
void registerHandler(Args... args)
Registers an OGC API handler passing Args to the constructor.
QgsServerOgcApi(QgsServerInterface *serverIface, const QString &rootPath, const QString &name, const QString &description=QString(), const QString &version=QString())
QgsServerOgcApi constructor.
const QString description() const override
Returns the API description.
ContentType
Media types used for content negotiation, insert more specific first.
@ OPENAPI3
"application/openapi+json;version=3.0"
Rel
Rel link types.
@ alternate
Refers to a substitute for this context.
@ collection
The target IRI points to a resource that is a member of the collection represented by the context IRI...
@ self
Conveys an identifier for the link’s context.
@ prev
Indicates that the link’s context is a part of a series, and that the previous in the series is the l...
@ service_doc
Identifies service documentation for the context that is primarily intended for human consumption.
@ conformance
The target IRI points to a resource which represents the collection resource for the context IRI.
@ describedBy
Refers to a resource providing information about the link’s context.
@ next
Indicates that the link’s context is a part of a series, and that the next in the series is the link ...
@ license
Refers to a license associated with this context.
@ data
The target IRI points to resource data.
@ service_desc
Identifies service description for the context that is primarily intended for consumption by machines...
@ items
Refers to a resource that is comprised of members of the collection represented by the link’s context...
@ item
The target IRI points to a resource that is a member of the collection represented by the context IRI...
const QString version() const override
Returns the version of the service.
const QString name() const override
Returns the API name.
static Q_DECL_DEPRECATED QgsServerOgcApi::ContentType contenTypeFromExtension(const std::string &extension)
Returns the Content-Type value corresponding to extension.
static QgsServerOgcApi::ContentType contentTypeFromExtension(const std::string &extension)
Returns the Content-Type value corresponding to extension.
#define SIP_DEPRECATED
Definition qgis_sip.h:113
#define SIP_SKIP
Definition qgis_sip.h:133
#define SIP_TRANSFER
Definition qgis_sip.h:35
#define SIP_VIRTUALERRORHANDLER(name)
Definition qgis_sip.h:203
#define SIP_THROW(name,...)
Definition qgis_sip.h:210