QGIS API Documentation 4.1.0-Master (31622b25bb0)
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
85 Q_ENUM( ContentType )
86
87
88 enum class Profile
89 {
90 NONE,
91 RFC7946,
92 // This not supported yet but I am leaving it here because
93 // I am very optimistic that it will be supported soon!
94 // JSONFG, //!< JSON Feature Geometry profile according to OGC API - Features 1.0
95 // JSONFG_PLUS //!< JSON Feature Geometry profile with GeoJSON compatibility extensions
96 };
97 Q_ENUM( Profile )
98
99
107 QgsServerOgcApi( QgsServerInterface *serverIface, const QString &rootPath, const QString &name, const QString &description = QString(), const QString &version = QString() );
108
109 // QgsServerApi interface
110 const QString name() const override { return mName; }
111 const QString description() const override { return mDescription; }
112 const QString version() const override { return mVersion; }
113 const QString rootPath() const override { return mRootPath; }
114
115 ~QgsServerOgcApi() override;
116
120 void executeRequest( const QgsServerApiContext &context ) const override SIP_THROW( QgsServerApiBadRequestException ) SIP_VIRTUALERRORHANDLER( serverapi_badrequest_exception_handler );
121
126 static const QMap<QgsServerOgcApi::ContentType, QStringList> contentTypeMimes() SIP_SKIP;
127
132 static const QHash<QgsServerOgcApi::ContentType, QList<QgsServerOgcApi::ContentType>> contentTypeAliases() SIP_SKIP;
133
138 static QString profileToString( const QgsServerOgcApi::Profile &profile ) SIP_SKIP;
139
144 static QString profileToUri( const QgsServerOgcApi::Profile &profile ) SIP_SKIP;
145
146 // Utilities
147#ifndef SIP_RUN
148
153 template<class T, typename... Args> void registerHandler( Args... args ) { mHandlers.emplace_back( std::make_shared<T>( args... ) ); }
154#endif
155
159 void registerHandler( QgsServerOgcApiHandler *handler SIP_TRANSFER );
160
165 static QUrl sanitizeUrl( const QUrl &url );
166
170 static std::string relToString( const QgsServerOgcApi::Rel &rel );
171
175 static QString contentTypeToString( const QgsServerOgcApi::ContentType &ct );
176
180 static std::string contentTypeToStdString( const QgsServerOgcApi::ContentType &ct );
181
185 static QString contentTypeToExtension( const QgsServerOgcApi::ContentType &ct );
186
191 Q_DECL_DEPRECATED static QgsServerOgcApi::ContentType contenTypeFromExtension( const std::string &extension ) SIP_DEPRECATED { return contentTypeFromExtension( extension ); } // spellok
192
197 static QgsServerOgcApi::ContentType contentTypeFromExtension( const std::string &extension );
198
202 static std::string mimeType( const QgsServerOgcApi::ContentType &contentType );
203
207 const std::vector<std::shared_ptr<QgsServerOgcApiHandler>> handlers() const SIP_SKIP;
208
209 private:
210 QString mRootPath;
211 QString mName;
212 QString mDescription;
213 QString mVersion;
214
215 //Note: this cannot be unique because of SIP bindings
216 std::vector<std::shared_ptr<QgsServerOgcApiHandler>> mHandlers;
217
219 static QMap<QgsServerOgcApi::ContentType, QStringList> sContentTypeMime;
220
226 static QHash<QgsServerOgcApi::ContentType, QList<QgsServerOgcApi::ContentType>> sContentTypeAliases;
227};
228
229#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"
@ FLATGEOBUF
"application/flatgeobuf"
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.
Profile
JSON profile.
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