[944] | 1 | |
---|
[659] | 2 | .. _kernel_config: |
---|
| 3 | |
---|
| 4 | ZOO-Kernel configuration |
---|
[713] | 5 | ======================== |
---|
[659] | 6 | |
---|
| 7 | Main configuration file |
---|
| 8 | ----------------------- |
---|
| 9 | |
---|
| 10 | ZOO-Kernel general settings are defined in a configuration file called |
---|
| 11 | ``main.cfg``. This file is stored in the same directory as ZOO-Kernel |
---|
| 12 | (``/usr/lib/cgi-bin/`` in most cases). It provides usefull metadata information on your ZOO-Kernel installation. |
---|
| 13 | |
---|
| 14 | .. warning:: |
---|
| 15 | ZOO-Kernel (``/usr/lib/cgi-bin/zoo_loader.cgi``) and its |
---|
| 16 | configuration file (``/usr/lib/cgi-bin/main.cfg``) must be in the |
---|
| 17 | same directory. |
---|
| 18 | |
---|
| 19 | .. note:: |
---|
| 20 | Information contained by ``/usr/lib/cgi-bin/main.cfg`` is accessible from WPS Services at runtime, so when *Execute* requests are used. |
---|
| 21 | |
---|
| 22 | Default main.cfg |
---|
| 23 | ............................... |
---|
| 24 | |
---|
| 25 | An example *main.cfg* file is given here as reference. |
---|
| 26 | |
---|
| 27 | .. code-block:: guess |
---|
| 28 | :linenos: |
---|
| 29 | |
---|
| 30 | [headers] |
---|
| 31 | X-Powered-By=ZOO@ZOO-Project |
---|
| 32 | |
---|
| 33 | [main] |
---|
| 34 | version=1.0.0 |
---|
| 35 | encoding=utf-8 |
---|
| 36 | dataPath=/var/data |
---|
| 37 | tmpPath=/var/www/temp |
---|
| 38 | cacheDir=/var/www/cache |
---|
| 39 | sessPath=/tmp |
---|
| 40 | serverAddress=http://localhost/cgi-bin/zoo_loader.cgi |
---|
| 41 | lang=fr-FR,ja-JP |
---|
| 42 | language=en-US |
---|
| 43 | mapserverAddress=http://localhost/cgi-bin/mapserv.cgi |
---|
| 44 | msOgcVersion=1.0.0 |
---|
| 45 | tmpUrl=http:/localhost/temp/ |
---|
[752] | 46 | cors=false |
---|
[659] | 47 | |
---|
| 48 | [identification] |
---|
| 49 | keywords=t,ZOO-Project, ZOO-Kernel,WPS,GIS |
---|
| 50 | title=ZOO-Project demo instance |
---|
| 51 | abstract= This is ZOO-Project, the Open WPS platform. |
---|
| 52 | accessConstraints=none |
---|
| 53 | fees=None |
---|
| 54 | |
---|
| 55 | [provider] |
---|
| 56 | positionName=Developer |
---|
| 57 | providerName=GeoLabs SARL |
---|
| 58 | addressAdministrativeArea=False |
---|
| 59 | addressDeliveryPoint=1280, avenue des Platanes |
---|
| 60 | addressCountry=fr |
---|
| 61 | phoneVoice=+33467430995 |
---|
| 62 | addressPostalCode=34970 |
---|
| 63 | role=Dev |
---|
| 64 | providerSite=http://geolabs.fr |
---|
| 65 | phoneFacsimile=False |
---|
| 66 | addressElectronicMailAddress=gerald@geolabs.fr |
---|
| 67 | addressCity=Lattes |
---|
| 68 | individualName=Gerald FENOY |
---|
| 69 | |
---|
| 70 | |
---|
| 71 | Main section |
---|
| 72 | ............................... |
---|
| 73 | |
---|
| 74 | The main.cfg ``[main]`` section parameters are explained bellow. |
---|
| 75 | |
---|
| 76 | * ``version``: Supported WPS version. |
---|
| 77 | * ``encoding``: Default encoding of WPS Responses. |
---|
| 78 | * ``dataPath``: Path to the directory where data files are stored (used to store mapfiles and data when MapServer support is activated). |
---|
| 79 | * ``tmpPath``: Path to the directory where temporary files are stored (such as *ExecuteResponse* when *storeExecuteResponse* is set to true). |
---|
[752] | 80 | * ``tmpUrl``: URL to access the temporary files directory (cf. ``tmpPath``). |
---|
[659] | 81 | * ``cacheDir``: Path to the directory where cached request files [#f1]_ are stored (optional). |
---|
| 82 | * ``serverAddress``: URL to the ZOO-Kernel instance. |
---|
| 83 | * ``mapservAddress``: URL to the MapServer instance (optional). |
---|
| 84 | * ``msOgcVersion``: Version of all supported OGC Web Services output [#f2]_ |
---|
| 85 | (optional). |
---|
| 86 | * ``lang``: Supported natural languages separated by a coma (the first is the default one), |
---|
[752] | 87 | * ``cors``: Define if the ZOO-Kernel should support `Cross-Origin |
---|
| 88 | Resource Sharing <https://www.w3.org/TR/cors/>`__. If this |
---|
[796] | 89 | parameter is not defined, then the ZOO-Kernel won't support CORS. |
---|
[784] | 90 | * ``servicePath``: Define a specific location to search for services |
---|
| 91 | rather than using the ZOO-Kernel directory. If this parameter is |
---|
| 92 | not defined, then the ZOO-Kernel will search for services using its |
---|
| 93 | directory. |
---|
[796] | 94 | * ``libPath``: (Optional) Path to a directory where the ZOO-kernel should search for |
---|
| 95 | service providers, e.g., shared libraries with service implementations |
---|
| 96 | (the ``serviceProvider`` parameter in the service configuration (.zcfg) file). |
---|
[917] | 97 | * ``memory``: (Optional) can take the value ``load`` to ensure that |
---|
| 98 | the value field of the inputs data will be filled by the ZOO-Kernel |
---|
| 99 | or ``protected`` to have only the ``cache_file`` filled. |
---|
[946] | 100 | * ``handleText``: (Optional) set it to ``true`` to get your Complex data |
---|
| 101 | nodes containing text not requiring a single CDATA node. Be aware |
---|
| 102 | that in case you use any HTML or XML there, you will then need to |
---|
| 103 | rebuild the string to get the original format of the text from your |
---|
| 104 | service code. In case you do not add handleText or set its value to |
---|
| 105 | true, you will simply need to use the value as it was provided in |
---|
| 106 | a single CDATA node provided in the Execute request. |
---|
[659] | 107 | |
---|
[796] | 108 | .. warning:: |
---|
| 109 | The ``libPath`` parameter is currently only recognized by services implemented |
---|
| 110 | in C/C++ or PHP, and may be moved to another section in future versions. |
---|
[917] | 111 | |
---|
| 112 | |
---|
| 113 | .. warning:: |
---|
| 114 | Depending on the ``memory`` parameter the WPS Service will receive |
---|
| 115 | different fields (``value`` or ``cache_file``). |
---|
| 116 | |
---|
[752] | 117 | In case you have activated the MapServer support, please refer to |
---|
| 118 | :ref:`this specific section <kernel-mapserver-main.cfg>`. |
---|
[659] | 119 | |
---|
[752] | 120 | |
---|
[659] | 121 | Identification and Provider |
---|
| 122 | .......................................... |
---|
| 123 | |
---|
| 124 | The ``[identification]`` and ``[provider]`` sections are not ZOO-Project |
---|
| 125 | specific. They provide OGC metadata [#f3]_ and should be set according |
---|
| 126 | to the `XML Schema Document |
---|
| 127 | <http://schemas.opengis.net/ows/1.1.0/ows19115subset.xsd>`__ which |
---|
| 128 | encodes the parts of ISO 19115 used by the common |
---|
| 129 | *ServiceIdentification* and *ServiceProvider* sections of the |
---|
| 130 | *GetCapabilities* operation response, known as the service metadata |
---|
| 131 | XML document. |
---|
| 132 | |
---|
| 133 | Details of the common OWS 1.1.0 *ServiceIdentification* section can be |
---|
| 134 | found in this `XML Schema Document |
---|
| 135 | <http://schemas.opengis.net/ows/1.1.0/owsServiceIdentification.xsd>`__. |
---|
| 136 | |
---|
| 137 | Details of the common OWS 1.1.0 *ServiceProvider* section can be |
---|
| 138 | found in this `XML Schema Document |
---|
| 139 | <http://schemas.opengis.net/ows/1.1.0/owsServiceProvider.xsd>`__. |
---|
| 140 | |
---|
| 141 | |
---|
| 142 | Additional sections |
---|
| 143 | -------------------------------- |
---|
| 144 | |
---|
[817] | 145 | All the additional sections discribed in the following section are |
---|
| 146 | optional. |
---|
| 147 | |
---|
[659] | 148 | Headers section |
---|
| 149 | ............................... |
---|
| 150 | |
---|
| 151 | The ``[headers]`` section can be set in order to define a specific HTTP |
---|
| 152 | Response header, which will be used for every response. As an example, |
---|
| 153 | you can check http://zoo-project.org using *curl* command line tool |
---|
| 154 | and notice the specific header *X-Powered-By: Zoo-Project@Trac*. |
---|
| 155 | |
---|
[752] | 156 | In case you want to allow CORS support for POST requests coming from |
---|
| 157 | ``myhost.net``, then you should define the following minimal |
---|
| 158 | parameters in this section: |
---|
| 159 | |
---|
| 160 | .. code-block:: guess |
---|
| 161 | :linenos: |
---|
| 162 | |
---|
| 163 | Access-Control-Allow-Origin=myhost.net |
---|
| 164 | Access-Control-Allow-Methods=POST |
---|
| 165 | Access-Control-Allow-Headers=content-type |
---|
| 166 | |
---|
[944] | 167 | curl section |
---|
| 168 | ............................... |
---|
[752] | 169 | |
---|
[944] | 170 | The `[curl]` section is used on windows platform to specify, using the |
---|
| 171 | `cainfo` parameter, where is located the |
---|
| 172 | `cacert.pem <https://curl.haxx.se/docs/caextract.html>`__ file on your |
---|
| 173 | machine. An example bellow is provided to illustrate sur a setting. |
---|
| 174 | |
---|
| 175 | .. code-block:: guess |
---|
| 176 | :linenos: |
---|
| 177 | |
---|
| 178 | [curl] |
---|
| 179 | cainfo=./cacert.pem |
---|
| 180 | |
---|
| 181 | |
---|
| 182 | |
---|
[659] | 183 | env section |
---|
| 184 | ............................... |
---|
| 185 | |
---|
| 186 | The ``[env]`` section can be used to store specific environment |
---|
| 187 | variables to be set prior the loading of *Services Provider* and Service execution. |
---|
| 188 | |
---|
| 189 | A typical example is when a Service requires the access to a X server |
---|
| 190 | running on *framebuffer*, which takes to set the DISPLAY environnement |
---|
| 191 | variable, as follow: |
---|
| 192 | |
---|
| 193 | .. code-block:: guess |
---|
| 194 | :linenos: |
---|
| 195 | |
---|
| 196 | [env] |
---|
| 197 | DISPLAY=:1 |
---|
| 198 | |
---|
[752] | 199 | In case you have activated the OTB support, please refer to :ref:`this |
---|
[944] | 200 | specific section <kernel-orfeotoolbox-main.cfg>`. |
---|
[752] | 201 | |
---|
[659] | 202 | lenv section |
---|
| 203 | ............................... |
---|
| 204 | |
---|
[772] | 205 | The ``lenv`` section is used by the ZOO-Kernel to store runtime informations |
---|
| 206 | before the execution of a WPS service, it contains the following |
---|
| 207 | parameters: |
---|
[659] | 208 | |
---|
| 209 | * ``sid`` (r): The WPS Service unique identifier, |
---|
| 210 | * ``status`` (rw): The current progress value ( a value between 0 and |
---|
| 211 | 100 in percent (**%**) ), |
---|
| 212 | * ``cwd`` (r): The current working directory of ZOO-Kernel, |
---|
| 213 | * ``message`` (rw): An error message used when ``SERVICE_FAILED`` is returned (optional), |
---|
| 214 | * ``cookie`` (rw): The cookie to be returned to the client (for |
---|
| 215 | example for authentication purpose). |
---|
[772] | 216 | * ``file.pid`` (r): The file used by the ZOO-Kernel to store process identifier. |
---|
| 217 | * ``file.sid`` (r): The file used by the ZOO-Kernel to store service identifier. |
---|
| 218 | * ``file.responseInit`` (r): The file used by the ZOO-Kernel to store |
---|
| 219 | the initial (then final) WPS response. |
---|
| 220 | * ``file.responseFinal`` (r): The file used by the ZOO-Kernel to |
---|
| 221 | temporary store the final WPS response. |
---|
[659] | 222 | |
---|
[772] | 223 | renv section |
---|
| 224 | ............................... |
---|
| 225 | |
---|
| 226 | The ``renv`` section is automatically created by the ZOO-Kernel before |
---|
| 227 | the execution of a WPS service, it contains all the environment |
---|
| 228 | variables available at runtime (so including the header fields in case |
---|
| 229 | it is used through http, refer to [https://tools.ietf.org/html/rfc3875 |
---|
| 230 | rfc3875] for more details). |
---|
| 231 | |
---|
| 232 | |
---|
[659] | 233 | senv section |
---|
| 234 | ............................... |
---|
| 235 | |
---|
| 236 | The ``senv`` section can be used to store sessions information on the |
---|
| 237 | server side. Such information can then be accessed automatically from |
---|
| 238 | the Service if the server is requested using a valid cookie (as |
---|
| 239 | defined in ``lenv`` section). ZOO-Kernel will store the values set in the |
---|
| 240 | ``senv`` maps on disk, load it and dynamically replace its content to |
---|
| 241 | the one in the ``main.cfg``. The ``senv`` section must contain the |
---|
| 242 | following parameter at least: |
---|
| 243 | |
---|
| 244 | * ``XXX``: The session unique identifier where ``XXX`` is the name |
---|
| 245 | included in the cookie which is returned. |
---|
| 246 | |
---|
| 247 | .. _cookie_example: |
---|
| 248 | |
---|
| 249 | For instance, adding the following in the Service source code : |
---|
| 250 | |
---|
[713] | 251 | .. code:: python |
---|
[659] | 252 | |
---|
| 253 | conf["lenv"]["cookie"]="XXX=XXX1000000; path=/" |
---|
| 254 | conf["senv"]={"XXX": "XXX1000000","login": "demoUser"} |
---|
| 255 | |
---|
| 256 | means that ZOO-Kernel will create a file named ``sess_XXX1000000.cfg`` |
---|
| 257 | in the ``cacheDir`` directory, and will return the specified cookie to the client. Each time the client will |
---|
| 258 | request ZOO-Kernel using this cookie, it will automatically load the |
---|
[683] | 259 | value stored before the Service execution. |
---|
[659] | 260 | |
---|
[817] | 261 | Security section |
---|
| 262 | ............................... |
---|
| 263 | |
---|
| 264 | The ``[security]`` section can be used to define what headers, the |
---|
| 265 | ZOO-Kernel has initially received in the request, should be passed |
---|
| 266 | to other servers for accessing resources (such as WMS, WFS, WCS |
---|
| 267 | or any other file passed as a reference). This section contains two |
---|
| 268 | parameters: |
---|
| 269 | |
---|
| 270 | * ``attributes``: The header to pass to other servers (such as |
---|
| 271 | Authorization, Cookie, User-Agent ...), |
---|
| 272 | * ``hosts``: The host for wich the restriction apply (can be "*" to |
---|
| 273 | forward header to every server or a coma separated list of host |
---|
| 274 | names, domain, IP). |
---|
| 275 | |
---|
| 276 | Both parameters are mandatory. |
---|
| 277 | |
---|
| 278 | Suppose you need to share Authorization, Cookie and User-Agent to |
---|
| 279 | every server for accessing ressources, then yo ucan use the following |
---|
| 280 | section definition: |
---|
| 281 | |
---|
| 282 | .. code:: |
---|
| 283 | |
---|
| 284 | [security] |
---|
| 285 | attributes=Authorization,Cookie,User-Agent |
---|
| 286 | hosts=* |
---|
| 287 | |
---|
| 288 | In case only local servers require such header forwarding, you may use |
---|
| 289 | the following definition: |
---|
| 290 | |
---|
| 291 | .. code:: |
---|
| 292 | |
---|
| 293 | [security] |
---|
| 294 | attributes=Authorization,Cookie,User-Agent |
---|
| 295 | hosts=localhost,127.0.0.1 |
---|
| 296 | |
---|
[917] | 297 | Optionaly, you can also define the shared url(s), meaning that even if |
---|
| 298 | the ressource requires authentication to be accessed, this |
---|
| 299 | authentifcation won't be used to define the name for storing the |
---|
| 300 | file. Hence, two user with different authentication will use the same |
---|
| 301 | file as it is considerated as shared. You can find bellow a sample |
---|
| 302 | security section containing the shared parameter. In this example, |
---|
| 303 | every requests to access the coverage using the url defined in the |
---|
| 304 | shared parameter (``myHost/cgi-bin/WCS_Server``) will be shared |
---|
| 305 | between users. |
---|
[817] | 306 | |
---|
[917] | 307 | .. code:: |
---|
| 308 | |
---|
| 309 | [security] |
---|
| 310 | attributes=Authorization,Cookie,User-Agent |
---|
| 311 | hosts=localhost,127.0.0.1 |
---|
| 312 | shared=myHost/cgi-bin/WCS_Server |
---|
| 313 | |
---|
[713] | 314 | .. _zoo_activate_db_backend: |
---|
[659] | 315 | |
---|
[713] | 316 | Database section |
---|
[683] | 317 | ............................... |
---|
| 318 | |
---|
[713] | 319 | The database section allows to configure the |
---|
| 320 | :ref:`ZOO-Kernel optional database support <zoo_install_db_backend>`. |
---|
[683] | 321 | |
---|
[697] | 322 | .. code-block:: guess |
---|
[683] | 323 | |
---|
[697] | 324 | [database] |
---|
| 325 | dbname=zoo_project |
---|
| 326 | port=5432 |
---|
| 327 | user=username |
---|
| 328 | host=127.0.0.1 |
---|
| 329 | type=PG |
---|
| 330 | schema=public |
---|
[683] | 331 | |
---|
[713] | 332 | This will generate strings to be passed to GDAL to connect the |
---|
| 333 | database server: |
---|
[697] | 334 | |
---|
[713] | 335 | .. code-block:: guess |
---|
[710] | 336 | |
---|
[713] | 337 | <type>:host=<host> port=<port> user=<user> dbname=<dbname> |
---|
[710] | 338 | |
---|
| 339 | |
---|
[713] | 340 | With the previous database section, it will give the following: |
---|
[710] | 341 | |
---|
[713] | 342 | .. code-block:: guess |
---|
| 343 | |
---|
| 344 | PG:"dbname=zoo_project host=127.0.0.1 port=5432 user=username" |
---|
| 345 | |
---|
[722] | 346 | Please refer to this `section <zoo_create_db_backend>`_ to learn how |
---|
| 347 | to setup the database. |
---|
[713] | 348 | |
---|
[920] | 349 | .. _zoo_activate_metadb: |
---|
[917] | 350 | |
---|
[920] | 351 | Metadb section |
---|
[917] | 352 | ............................... |
---|
| 353 | |
---|
[920] | 354 | The metadb section allows to configure the ZOO-Kernel to access :ref:`the |
---|
| 355 | metadata information about WPS Services <zoo_create_metadb>` by using |
---|
| 356 | a PostgreSQL database in addition to the zcfg files. |
---|
[917] | 357 | |
---|
| 358 | .. code-block:: guess |
---|
| 359 | |
---|
| 360 | [metadb] |
---|
| 361 | dbname=zoo_metadb |
---|
| 362 | port=5432 |
---|
| 363 | user=username |
---|
| 364 | host=127.0.0.1 |
---|
| 365 | type=PG |
---|
| 366 | |
---|
| 367 | This will generate strings to be passed to GDAL to connect the |
---|
| 368 | database server: |
---|
| 369 | |
---|
| 370 | .. code-block:: guess |
---|
| 371 | |
---|
| 372 | <type>:host=<host> port=<port> user=<user> dbname=<dbname> |
---|
| 373 | |
---|
| 374 | |
---|
| 375 | With the previous database section, it will give the following: |
---|
| 376 | |
---|
| 377 | .. code-block:: guess |
---|
| 378 | |
---|
| 379 | PG:"dbname=zoo_metadb host=127.0.0.1 port=5432 user=username" |
---|
| 380 | |
---|
| 381 | Please refer to this `section <zoo_create_metadb>`_ to learn how |
---|
| 382 | to setup the database. |
---|
| 383 | |
---|
[796] | 384 | Include section |
---|
| 385 | ............................... |
---|
| 386 | |
---|
| 387 | The ``[include]`` section (optional) lists explicitely a set of service configuration files |
---|
| 388 | the the ZOO-Kernel should parse, e.g., |
---|
| 389 | |
---|
| 390 | |
---|
| 391 | .. code-block:: guess |
---|
| 392 | :linenos: |
---|
| 393 | |
---|
| 394 | [include] |
---|
| 395 | servicename1 = /my/service/repository/service1.zcfg |
---|
| 396 | servicename2 = /my/service/repository/service2.zcfg |
---|
| 397 | |
---|
| 398 | The ``[include]`` section may be used to control which services are exposed to particular user groups. |
---|
| 399 | While service configuration files (.zcfg) may be located in a common repository or in arbitrary folders, |
---|
| 400 | main.cfg files at different URLs may include different subsets of services. |
---|
| 401 | |
---|
| 402 | When the ZOO-Kernel handles a request, it will first check if there is an ``[include]`` |
---|
| 403 | section in main.cfg and then search for other .zcfg files in the current working directory (CWD) and |
---|
| 404 | subdirectories. If an included service happens to be located in a CWD (sub)directory, |
---|
| 405 | it will be published by its name in the ``[include]`` section. For example, the service |
---|
| 406 | ``/[CWD]/name/space/myService.zcfg`` |
---|
| 407 | would normally be published as name.space.myService, but if it is listed in the ``[include]`` section |
---|
| 408 | it will be published simply as myService: |
---|
| 409 | |
---|
| 410 | .. code-block:: guess |
---|
| 411 | :linenos: |
---|
| 412 | |
---|
| 413 | [include] |
---|
| 414 | myService = /[CWD]/name/space/myService.zcfg |
---|
| 415 | |
---|
| 416 | On the other hand, with |
---|
| 417 | |
---|
| 418 | .. code-block:: guess |
---|
| 419 | :linenos: |
---|
| 420 | |
---|
| 421 | [include] |
---|
| 422 | myService = /some/other/dir/myService.zcfg |
---|
| 423 | |
---|
| 424 | there would be two distinct services published as myService and name.space.myService, respectively, |
---|
| 425 | with two different zcfg files. |
---|
| 426 | |
---|
| 427 | .. note:: |
---|
| 428 | As currently implemented, the ZOO-Kernel searches the CWD for the library files of |
---|
| 429 | included services if the ``libPath`` parameter is not set. |
---|
| 430 | |
---|
[950] | 431 | |
---|
| 432 | OpenAPI Specification configuration file |
---|
| 433 | ----------------------------------------- |
---|
| 434 | |
---|
| 435 | Since revision 949 of the ZOO-Kernel, you can now activate the OGC |
---|
| 436 | API - Processing support. In such a case you will need to have an |
---|
| 437 | ``oas.cfg`` file located in tne same directory where the ``main.cfg`` is. |
---|
| 438 | |
---|
| 439 | This ``oas.cfg`` file gets the same syntactic rules than the |
---|
| 440 | ``main.cfg``. The ZOO-Kernel uses this file to produce information |
---|
| 441 | about the open API specification it is referring to. |
---|
| 442 | |
---|
| 443 | The first section to be found in the ``oas.cfg`` file should be the |
---|
| 444 | ``[openapi]``. It contains the following parameters: |
---|
| 445 | |
---|
| 446 | * ``rootUrl``: the URL to access the ZOO-Kernel using OGC API - Processing |
---|
| 447 | * ``links``: the links provided from the root |
---|
| 448 | * ``paths``: the full paths list |
---|
| 449 | * ``parameters``: the parameters list defined in paths |
---|
| 450 | * ``header_parameters``: the parameters list client applications can send as header |
---|
| 451 | * ``version``: the Open API Specification version |
---|
[962] | 452 | * ``license_name``: the license name for the service |
---|
| 453 | * ``license_url``: the license URL |
---|
| 454 | * ``full_html_support``: set it to true to activate support of the |
---|
| 455 | Accept header to choose between text/html or application/json |
---|
| 456 | format |
---|
| 457 | * ``partial_html_support``: set it to true in case you have the |
---|
| 458 | display service from the `open-api directory |
---|
| 459 | <http://zoo-project.org/trac/browser/trunk/zoo-project/zoo-services/utils/open-api/cgi-env//cgi-env>`__ |
---|
| 460 | and you want to aknowledge the text/html format in links |
---|
| 461 | * ``wsUrl``: the WebSocket URL to subscribe client to redis |
---|
| 462 | * ``publisherUrl``: the URL used to publish status updates |
---|
| 463 | |
---|
[950] | 464 | For any links and paths ``/A`` defined, you will have a corresponding |
---|
| 465 | ``[/A]`` and ``[A]`` sections. In the ``[/A]`` section you will define |
---|
| 466 | the rel, type and title used from the root URL to produce the `links |
---|
| 467 | <https://github.com/opengeospatial/wps-rest-binding/blob/master/core/openapi/schemas/link.yaml>`__ |
---|
| 468 | list and the `paths object |
---|
| 469 | <https://github.com/OAI/OpenAPI-Specification/blob/master/versions/3.0.0.md#pathsObject>`__ |
---|
| 470 | from. In the corresponding ``[A]`` section, you will define the |
---|
| 471 | following parameters: |
---|
| 472 | |
---|
| 473 | * ``method``: the HTTP method to use to access this resource |
---|
| 474 | * ``title``: resource title |
---|
| 475 | * ``abstract``: resource description |
---|
| 476 | * ``tags``: tags to classify this resource |
---|
| 477 | * ``tags_description``: the tag description |
---|
| 478 | * ``schema``: the schema specifying the resource |
---|
| 479 | |
---|
| 480 | In case you want to define multiple methods to access a resource, you |
---|
| 481 | can then use the length parameter to define the number of parameters |
---|
| 482 | group to parse, then use ``method_1``, ``title_1``, ``abstract_1``, |
---|
| 483 | ``tags_1``, ``tags_description_1`` and ``schema_1`` and so on to add |
---|
| 484 | one or more access method (and other attributes) to this resource. |
---|
| 485 | |
---|
| 486 | When declaring resource access you may want to add a parameter to your |
---|
| 487 | request. In such a case, you can add a parameter named "parameters" |
---|
| 488 | which contain the supported parameters list. All parameters defined |
---|
| 489 | should be rooted in the components field. Parameters which can be used |
---|
| 490 | in the path will be identified by ``{NAME}`` and will get a specific |
---|
| 491 | section for its definition: |
---|
| 492 | |
---|
| 493 | * ``type``: nature of the parameter (i.e. string) |
---|
| 494 | * ``title``: parameter title |
---|
| 495 | * ``abstract``: parameter description |
---|
| 496 | * ``in``: where the parameter can be used (ie. path, header, query) |
---|
| 497 | * ``required``: define if the parameter is optional (false) or not (true) |
---|
| 498 | * ``example``: (optional) provide an example value / URL |
---|
| 499 | |
---|
| 500 | In addition to the sections defined previously, there are three other |
---|
| 501 | sections that we did not cover yet. Theses sections are: |
---|
| 502 | |
---|
| 503 | * ``[requestBody]``: defining the request body abstract (description), type (application/json) and schema (reference). |
---|
| 504 | * ``[exception]``: defining the exception bastract (description), type (application/json) and schema (reference). |
---|
| 505 | * ``[conformTo]``: referring to links list of the requirements classes the server implements and conforms to |
---|
| 506 | |
---|
[962] | 507 | |
---|
| 508 | In case you have set ``partial_html_support`` or |
---|
| 509 | ``partial_html_support`` set to true, then you can add a corresponding |
---|
| 510 | ``[A.html]`` section providing the link informations. Also, it means |
---|
| 511 | that you are willing to let the client choose in between |
---|
| 512 | application/json and text/html format by providing the corresponding |
---|
| 513 | Accept header in its request, when ``full_html_support`` is set to |
---|
| 514 | true or by using the ``.html`` extension in the URL, in case |
---|
| 515 | ``partial_html_support`` was set true. Also, the user interface |
---|
| 516 | provided in the `open-api directory |
---|
| 517 | <http://zoo-project.org/trac/browser/trunk/zoo-project/zoo-services/utils/open-api/cgi-env//cgi-env>`__ |
---|
| 518 | will let the client goes untill the execution of a job. In case you |
---|
| 519 | want this functionality to be working correctly we invite you to use a |
---|
| 520 | ``.htaccess`` equivalent to the one provided `here |
---|
| 521 | <http://zoo-project.org/trac/browser/trunk/zoo-project/zoo-services/utils/open-api/server/.htacess>`__. Also |
---|
| 522 | the WebSocket can be started using websocketd in combinaison with the |
---|
| 523 | `subscriber.py |
---|
| 524 | <http://zoo-project.org/trac/browser/trunk/zoo-project/zoo-services/utils/open-api/server/subscriber.py>`__ |
---|
| 525 | script, finally you will need to add the `publish.py |
---|
| 526 | <http://zoo-project.org/trac/browser/trunk/zoo-project/zoo-services/utils/open-api/server/publish.py>`__ |
---|
| 527 | script in the cgi-bin directory of your web server. |
---|
| 528 | |
---|
[950] | 529 | For more information on how to interact with this WPS REST Binding, please refer |
---|
| 530 | to this `page |
---|
| 531 | <https://github.com/opengeospatial/wps-rest-binding#overview>`__ or use |
---|
| 532 | the `Swagger UI <https://swagger.io/tools/swagger-ui/>`__. A live |
---|
| 533 | instance is available `here <https://demo.mapmint.com/swagger-ui/dist/>`__. |
---|
| 534 | |
---|
[659] | 535 | .. rubric:: Footnotes |
---|
| 536 | |
---|
[697] | 537 | .. [#f1] If GET requests are passed through ``xlink:href`` to the ZOO-Kernel , the latter will execute the request the first time and store the result on disk. The next time the same request is executed, the cached file will be used and this will make your process run much faster. If ``cachedir`` was not specified in the ``main.cfg`` then the ``tmpPath`` value will be used. |
---|
[659] | 538 | .. [#f2] Usefull when the :ref:`kernel-mapserver` is activated (available since ZOO-Project version 1.3.0). |
---|
[697] | 539 | .. [#f3] ZOO-Kernel and MapServer are sharing the same metadata for OGC Web Services if the :ref:`kernel-mapserver` is activated. |
---|
[659] | 540 | |
---|
| 541 | |
---|