Prérequis pour l’installation de Lizmap Web Client

Note

Si vous souhaitez installer et tester rapidement Lizmap Web Client en quelques étapes, vous pouvez suivre ces instructions en utilisant Docker et Docker-Compose.

GIS data and QGS files

Lizmap Web Client does not enforce where to store data on the disk. You are free to store your files where you want on the server.

For instance, you can use /srv/lizmap/data/. Then, when configuring Lizmap, you can choose the rootRepositories variable to define the root repositories for all your data. Lizmap Web Client will display a dropdown menu showing directories in the root folder.

Otherwise, if you don’t want to define a root repository for your GIS data, you will need to use absolute path when defining a new Lizmap repository. There won’t be a dropdown menu but a text field instead.

Note

Lizmap Web Client does not provide any file transfer from your QGIS desktop to your server. You must setup your own way to transfer files between your computer and your server.

QGIS serveur

Avertissement

Avant d’installer la partie Qgis Server, il est hautement recommandé d’utiliser la même version de Qgis Desktop et de Qgis Server.

Même si des fonctions devraient fonctionner, il y a une probabilité que certaines configurations ne fonctionnent pas si ces deux versions sont différentes.

La raison est que QGIS Server version X peut ne pas pouvoir charger un projet créé avec la version Y de QGIS Desktop.

Suivez la documentation de QGIS pour installer QGIS Server .

En plus d’un serveur web (Apache ou Nginx), vous devez installer QGIS Server. Avec Nginx, la configuration recommandée est d’utiliser spawn-fcgi. Ne pas utiliser fcgiwrap, cette solution n’est pas efficace.

Dans la configuration Nginx, il est conseillé d’utiliser la variable QGIS_OPTIONS_PATH pour un dossier avec les droits d’écriture pour www-data. Cela est expliqué dans la documentation Qgis serveur.

Vous devriez également installer et configurer XVFB mentionné dans la documentation QGIS. Cela est utile pour les impressions PDF. Vous pouvez ignorer la section si vous ne planifiez pas d’imprimer en PDF du côté serveur.

Après avoir configurer votre serveur web avec QGIS serveur, vérifiez que l’URL de QGIS serveur fonctionne. Vous obtiendrez probablement un XML semblable à :

<ServerException>Project file error</ServerException>

Gardez cette URL, nous l’utiliserons plus tard dans le panneau d’administration de Lizmap.

Avertissement

Nous vous encourageons fortement de configurer QGIS Serveur sur un hôte virtuel différent que celui de Lizmap Web Client. L’URL de QGIS Serveur doit rester privée, accessible uniquement depuis le PHP de Lizmap.

Sinon, surtout après avoir installé le plugin Lizmap dans QGIS Server, un utilisateur pourrait accéder à des données privées en contournant Lizmap, en passant directement par l’URL du serveur QGIS.

Extensions QGIS serveur

Des plugins peuvent être ajoutés à QGIS Server. Voyez la documentation QGIS sur les plugins  coté serveur.

Avertissement

Le plugin Lizmap server est requis.

La liste des plugins ci-dessous activera des fonctionnalités dans Lizmap Web Client.

Soit vous configurez la variable d’environnement QGIS_PLUGIN_PATH pendant l’installation de QGIS serveur, soit utilisez celle par défaut fournie par QGIS.

Astuce

Pour configurer les extensions QGIS Serveur, nous encourageons l’utilisation de qgis-plugin-manager, un outil CLI pour installer et mettre à jour des extensions. https://pypi.org/project/qgis-plugin-manager/

Plugin Lizmap QGIS Server

Le plugin Lizmap QGIS Server est obligatoire et ajoutera des fonctionnalités dans Lizmap Web Client :

  • récupérer les informations de QGIS Server.

  • évaluer QGIS Expressions dans un formulaire sur :

  • Vérification des listes de contrôle d’accès (ACL, Access Control List) pour les entités et les couches :

    • filtrage par polygone

    • par attribut

  • utilisation de la popup type Formulaire, lire QGIS Drag&Drop Form popup.

  • activer les variables @lizmap_user et lizmap_user_groups dans les projets QGIS

Installation
Côté QGIS serveur

Voyez la documentation QGIS sur les plugins coté serveur.

Le plugin serveur Lizmap, appelé Lizmap server, est obligatoire dans le bon dossier pour QGIS Server.

With QGIS-Plugin-Manager :

# Not correct, this plugin is only for QGIS desktop
# qgis-plugin-manager install Lizmap

# Correct, the plugin designed for QGIS server
qgis-plugin-manager install 'Lizmap server'

Avertissement

Vous devez installer le plugin « Lizmap server ». Le plugin Lizmap est déstiné uniquement à Qgis Desktop. Ne gardez pas les deux sur le serveur.

For security reason, to enable the API on the QGIS server side, you must enable the environment variable

QGIS_SERVER_LIZMAP_REVEAL_SETTINGS with the value set to True on QGIS server.

Cette variable exposera les paramètres du serveur tels que la version du serveur QGIS, qui est utilisée par Lizmap Web Client.

# Apache FCGI example
FcgidInitialEnv QGIS_SERVER_LIZMAP_REVEAL_SETTINGS True
# nginx fastcgi
fastcgi_param  QGIS_SERVER_LIZMAP_REVEAL_SETTINGS  True;

Avertissement

Vous devez vous assurer que cette API http://your.qgis.server.url/lizmap/server.json est protégée sur votre serveur web. Le mieux est de restreindre l’accès à QGIS Server http://your.qgis.server.url sur un hôte virtuel, non accessible sur Internet. Toutes les requêtes au serveur QGIS seront envoyées par Lizmap Web Client. Le serveur QGIS ne doit pas être accessible de l’extérieur. Il était déjà fortement recommandé auparavant de protéger le serveur QGIS d’Internet. Les utilisateurs doivent utiliser les liens WFS/WMS fournis par Lizmap Web Client, afin que Lizmap puisse vérifier les autorisations des utilisateurs.

Interface d’administration

Si vous utilisez QGIS Server avec FCGI, l’URL API de Lizmap doit être vide.

Sinon, si vous utilisez Py-QGIS-Server, l’URL API de Lizmap doit être configurée dans l’administration. Dans la configuration de Py-QGIS-Server, vous devez également explicitement publier l’API.

À partir de la version 1.8.4 de Py-QGIS-Server, il est possible d’activer le point d’entrée API Lizmap avec la variable d’environnement QGSRV_API_ENDPOINTS_LIZMAP=yes, ou alors ajoutez la configuration suivante dans le fichier de configuration :

[api.endpoints]
lizmap_api=/lizmap

[api.enabled]
lizmap_api=yes

Puis, avec Py-QGIS-Server , si votre URL pour OWS est http://map:8080/ows/, cela veut dire que l’URL du point d’entrée de l’API pour Lizmap est http://map:8080/lizmap/.

PostgreSQL

PostgreSQL peut être utilisé pour trois usages différents dans Lizmap :

  • Pour stocker des données SIG. Aucune configuration n’est nécessaire côté serveur Lizmap Web Client, seul le serveur PostgreSQL doit être accessible depuis le serveur Lizmap Web Client. Il est possible d’éditer des couches avec Lizmap, mais la couche doit être stockée dans PostgreSQL. Voir Pré-requis.

  • Pour stocker les utilisateurs et les actions des utilisateurs du client Web Lizmap. Lizmap utilise des tableaux. Ce réglage doit être fait lors de l”installation de Lizmap.

  • Pour utiliser lizmap_search, voyez Recherche PostgreSQL. Ce paramétrage sur le serveur de Lizmap peut être fait quand vous le souhaitez.