File: qgsserverapi.sip.in

package info (click to toggle)
qgis 3.40.11%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,183,800 kB
  • sloc: cpp: 1,595,841; python: 372,637; xml: 23,474; sh: 3,761; perl: 3,664; ansic: 2,257; sql: 2,137; yacc: 1,068; lex: 577; javascript: 540; lisp: 411; makefile: 154
file content (122 lines) | stat: -rw-r--r-- 3,802 bytes parent folder | download | duplicates (12)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/************************************************************************
 * This file has been generated automatically from                      *
 *                                                                      *
 * src/server/qgsserverapi.h                                            *
 *                                                                      *
 * Do not edit manually ! Edit header and run scripts/sipify.py again   *
 ************************************************************************/






class QgsServerApi
{
%Docstring(signature="appended")
Server generic API endpoint abstract base class.

.. seealso:: :py:class:`QgsServerOgcApi` for an OGC API (aka WFS3) implementation.

An API must have a name and a (possibly empty) version and define a
(possibly empty) root path (e.g. "/wfs3").

The server routing logic will check incoming request URLs by passing
them to the API's accept(url) method, the default implementation
performs a simple check for the presence of the API's root path string
in the URL. This simple logic implies that APIs must be registered in
reverse order from the most specific to the most generic: given two APIs
with root paths '/wfs' and '/wfs3', '/wfs3' must be registered first or
it will be shadowed by '/wfs'. APIs developers are encouraged to
implement a more robust accept(url) logic by making sure that their APIs
accept only URLs they can actually handle, if they do, the APIs
registration order becomes irrelevant.

After the API has been registered to the server API registry:

.. code-block:: python

       class API(QgsServerApi):

         def name(self):
           return "Test API"

         def rootPath(self):
           return "/testapi"

         def executeRequest(self, request_context):
           request_context.response().write(b"\"Test API\"")

       server = QgsServer()
       api = API(server.serverInterface())
       server.serverInterface().serviceRegistry().registerApi(api)

the incoming calls with an URL path starting with the API root path will
be routed to the first matching API and :py:func:`~executeRequest`
method of the API will be invoked.

.. versionadded:: 3.10
%End

%TypeHeaderCode
#include "qgsserverapi.h"
%End
  public:
    QgsServerApi( QgsServerInterface *serverIface );
%Docstring
Creates a QgsServerApi object
%End

    virtual ~QgsServerApi();

    virtual const QString name() const = 0;
%Docstring
Returns the API name
%End

    virtual const QString description() const = 0;
%Docstring
Returns the API description
%End

    virtual const QString version() const;
%Docstring
Returns the version of the service

.. note::

   the default implementation returns an empty string
%End

    virtual const QString rootPath() const = 0;
%Docstring
Returns the root path for the API
%End

    virtual bool accept( const QUrl &url ) const;
%Docstring
Returns ``True`` if the given ``url`` is handled by the API, default
implementation checks for the presence of rootPath inside the ``url``
path.
%End

    virtual void executeRequest( const QgsServerApiContext &context ) const = 0;
%Docstring
Executes a request by passing the given ``context`` to the API handlers.
%End

    QgsServerInterface *serverIface() const;
%Docstring
Returns the server interface
%End

};


/************************************************************************
 * This file has been generated automatically from                      *
 *                                                                      *
 * src/server/qgsserverapi.h                                            *
 *                                                                      *
 * Do not edit manually ! Edit header and run scripts/sipify.py again   *
 ************************************************************************/