(An English version is available in the file README.en.md
)
Visualisation web pour les données issues de http://jnum.parisdescartes.fr/atelier-mesure-de-la-pollution-association-citoyens-capteurs/.
- Cloner le dépôt git où vous voulez.
- S'assurer que le script a les droits nécessaires pour créer les fichiers
api.keys
etpasswd
à la racine et pour écrire dans le répertoiredata/
. - S'assurer que le script a les droits nécessaires pour écrire dans le répertoire
tmp/
. - Accéder à la page
index.php?settings=
pour mettre en place un mot de passe pour protéger la configuration.
Toute la configuration se fait par la page index.php?settings=
. Elle permet notamment :
- D'ajouter de nouveaux types de mesures, en spécifiant leurs paramètres finement.
- De gérer les capteurs autorisés, identifiés par une clé aléatoire unique de 5 caractères. Cette clé sert à envoyer les données à la visualisation.
Un mot de passe vous sera demandé pour accéder à la page de configuration. Si vous oubliez ce mot de passe, vous pouvez le réinitialiser simplement en supprimant le fichier passwd
à la racine. et en accédant à la page index.php?settings=
qui vous demandera alors de créer un nouveau mot de passe.
Les données sont stockées par capteur, dans un fichier data/api_key.data
, au format JSON compressé en gzip. Les types de données disponibles sont stockés dans le fichier data/types.data
(JSON compressé en gzip aussi).
Lors de la récupération des données, celles-ci sont retournées en JSON par la page api.php
, en retournant les valeurs nécessaires uniquement. La façon la plus simple d'accéder aux données et d'en ajouter de nouvelles et d'utiliser l'API via le fichier api.php
Pour envoyer des données à l'API, il suffit de faire une requête GET sur la page api.php
en passant les paramètres suivants (tous sont obligatoires) :
do
=add
, pour envoyer des donnéestype
= un identifiant de type disponiblemeasure
= valeur de la mesure (float)timestamp
= timestamp UNIX de la mesureapi_key
= clé secrète liée au capteur (voir configuration)long
= longitude de la mesure (float)lat
= latitude de la mesure (float)
Par exemple :
/api.php?do=add&type=NO2&measure=200×tamp=10000&api_key=API_KEY&long=48.84874&lat=2.34211
La même page, api.php
, permet également de récupérer les données stockées. Il faut alors l'appeler avec le paramètre do=get
pour récupérer des données (par exemple : /api.php?do=get
). On peut lui passer les paramètres optionnels suivants :
capteur
= une liste de noms de capteurs (de noms, et non de clés d'API), séparés par des virgules. Si pas de noms passés, il n'y a pas de filtrage sur le capteur.type
= une liste de types de mesures, séparés par des virgules. Si pas de types passés, il n'y a aucun filtrage sur le type de mesure.time_min
ettime_max
pour filtrer les mesures réalisées dans l'intervalle de temps spécifié (les deux paramètres ne sont pas obligatoires).lat_min
etlat_max
pour filtrer les mesures entre les latitudes spécifiées (les deux paramètres ne sont pas obligatoires).long_min
etlong_max
pour filtrer les mesures entre les longitudes spécifiées (les deux paramètres ne sont pas obligatoires).format
qui peut valoirjson
oucsv
pour choisir le format d'export. Par défaut, le formatjson
est utilisé si le paramètre n'est pas spécifié.visu=1
qui, si spécifié, retourne en plus les données de visualisation liée à chaque mesure (niveau, type de mesures, …)
La visualisation web disponible (page index.php
) n'est qu'une interface pour représenter les données stockées. Elle utilise l'API décrite précédemment pour récupérer les mesures. Elle permet de visualiser directement sur une carte OpenStreeMaps les mesures effectuées, avec une légende et toutes les informations utiles.
Ce projet est un fully open source project :
- Les sources de l'application se trouvent sur Github sous licence GNU GPL v3
- Les sources et tutoriaux de montage des capteurs disponibles sur le wiki de l'association sont placés sous licence Open Hardware License du CERN
- Les données des capteurs téléchargeables au format JSON et CSV sont sous licence Open Data Commons By
CitizenAir is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
CitizenAir is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with CitizenAir. If not, see <http://www.gnu.org/licenses/>.
Tous les scripts devraient contenir cette note de licence. Si ce n'est pas le cas, n'hésitez pas à nous demander. Veuillez noter que les fichiers pour lesquels il est difficile de déterminer les informations sur la licence (comme les images) sont aussi distribués sous ces termes, à l'exception des images tpl/img/ohr.png, tpl/img/gpl.png, tpl/img/od.png, tpl/img/flattr.png et tpl/img/paypal.gif.
Copyright (c) 2010-2013, Vladimir Agafonkin
Copyright (c) 2010-2011, CloudMade
All rights reserved.
Redistribution and use in source and binary forms, with or without modification, are
permitted provided that the following conditions are met:
1. Redistributions of source code must retain the above copyright notice, this list of
conditions and the following disclaimer.
2. Redistributions in binary form must reproduce the above copyright notice, this list
of conditions and the following disclaimer in the documentation and/or other materials
provided with the distribution.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
/**
* RainTPL
* -------
* Realized by Federico Ulfo & maintained by the Rain Team
* Distributed under GNU/LGPL 3 License
*
* @version 2.7.2
*/
* --------------------------------------------------------------------------------
* "THE NO-ALCOHOL BEER-WARE LICENSE" (Revision 42):
* Phyks (webmaster@phyks.me) wrote this file. As long as you retain this notice you
* can do whatever you want with this stuff (and you can also do whatever you want
* with this stuff without retaining it, but that's not cool...). If we meet some
* day, and you think this stuff is worth it, you can buy me a <del>beer</del> soda
* in return.
* Phyks
* ---------------------------------------------------------------------------------
- timeline : 1 jour / 1 semaine / 1 mois + choix du capteur
- Couleur du capteur dans la timeline
- capteur fixe et superposition des marqueurs ?
- Minifier
- Refactor
- Nominatim reverse geolocation pour le choix de l'export
- Dropper les timestamps sur l'UI, améliorer l'export