QGIS API Documentation 3.99.0-Master (26c88405ac0)
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>
129 void registerHandler( Args... args )
130 {
131 mHandlers.emplace_back( std::make_shared<T>( args... ) );
132 }
133#endif
134
138 void registerHandler( QgsServerOgcApiHandler *handler SIP_TRANSFER );
139
144 static QUrl sanitizeUrl( const QUrl &url );
145
149 static std::string relToString( const QgsServerOgcApi::Rel &rel );
150
154 static QString contentTypeToString( const QgsServerOgcApi::ContentType &ct );
155
159 static std::string contentTypeToStdString( const QgsServerOgcApi::ContentType &ct );
160
164 static QString contentTypeToExtension( const QgsServerOgcApi::ContentType &ct );
165
170 Q_DECL_DEPRECATED static QgsServerOgcApi::ContentType contenTypeFromExtension( const std::string &extension ) SIP_DEPRECATED { return contentTypeFromExtension( extension ); } // spellok
171
176 static QgsServerOgcApi::ContentType contentTypeFromExtension( const std::string &extension );
177
181 static std::string mimeType( const QgsServerOgcApi::ContentType &contentType );
182
186 const std::vector<std::shared_ptr<QgsServerOgcApiHandler>> handlers() const SIP_SKIP;
187
188 private:
189 QString mRootPath;
190 QString mName;
191 QString mDescription;
192 QString mVersion;
193
194 //Note: this cannot be unique because of SIP bindings
195 std::vector<std::shared_ptr<QgsServerOgcApiHandler>> mHandlers;
196
198 static QMap<QgsServerOgcApi::ContentType, QStringList> sContentTypeMime;
199
205 static QHash<QgsServerOgcApi::ContentType, QList<QgsServerOgcApi::ContentType>> sContentTypeAliases;
206};
207
208#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:114
#define SIP_SKIP
Definition qgis_sip.h:134
#define SIP_TRANSFER
Definition qgis_sip.h:36
#define SIP_VIRTUALERRORHANDLER(name)
Definition qgis_sip.h:204
#define SIP_THROW(name,...)
Definition qgis_sip.h:211