Luftdaten/irceline viewer is an app to display air quality sensors registered by luftdaten or irceline accross Belgium. Sensors can contain information about fine particulate matter, temperature and humidity. This app is built with react/redux.
Users can select one or more stations and view the linked sensor information in the sidebar. Information includes sensor manufacturer, data source (luftdaten or irceline), geolocation, last reading by the sensor, and a mean of readings by all selected sensors. The url is constantly updated with geolocation data and the current zoom level, so that users may share the map at the current location with others. Users may also share a single selected sensor by selecting a sensor in the sidebar, and then clicking the lat/long location value. The url should be updated with the current sensor's ID.
Data source can be enabled or disabled in the filter options. By default, both data sources are enabled. A checkmark in front of a data source means that the app has successfully retrieved sensors registered with this data source. An hourglass icon means that this data source is currently being polled for sensor updates. A cross means that this data source was unreachable. Luftdaten sensor data updates every minute. Irceline sensor data updates every 10 minutes (needs to do a lot more API calls to retrieve all sensors). Luftdaten sensors are prefixed with "L-" and Irceline sensors are prefixed with "I-".
Users may select a phenomenon (PM2.5 by default) to show color coded markers for every sensor that has a reading for this phenomenon The color coded legend displays all the colors associated with the currently selected phenomenon. A red bar indicates the threshold of dangerous levels for human exposure to the currently selected phenomenon.
Users may contribute by making a new issue about bugs they find or features they think should be implemented in this app.
Volunteer translators are also welcome. Right now this app has very few lines of text, making it easy to add support for another language you are proficient at. New languages can be added in /src/lang/
. New translations should be a .json
file named as the ISO 639-1 language code of the relevant language.
Important: This app uses openstreets map tiles, which require an API token. If you want to deploy this app, you will need to create and use your own token for map tile access. Without such a token, the app will not run.
-
There are two places where you can set this token:
- Before building the project, rename
src/config.js.dist
tosrc/config.js
, and set the value oftilesAccessToken
to your own token. You can also configure other settings in thisconfig.js
file - Your second option is to set the environment variable
TILES_ACCESS_TOKEN
when running the server or docker image. Note that even if you set this environment variable, ifconfig.js
exists, itstilesAccessToken
will be used instead, even if it is not set.
- Before building the project, rename
-
(optional) To configure various settings, copy
src/config.js.dist
tosrc/config.js
, and edit the copy for your needs. If you dont create aconfig.js
, default settings will be used instead, but you will need to set the environment variableTILES_ACCESS_TOKEN
for the app to run (see previous point). -
NODE_ENV If the environment variable
NODE_ENV
is set todevelopment
, the application will run on port 8080 (http) and 8443 (https). Otherwise, it will run on port 80 / 443 -
With docker:
cd
to the project directorydocker build . -t luftdaten_irceline_viewer
docker run -p 80:80 -p 443:443 luftdaten_irceline_viewer
-
Without docker:
npm install
sudo node server.js
-
Enable https with self-signed SSL certificates (for localhost), or SSL certificates signed by a CA for https support:
- put your .key and .crt files into the project's ssl/ directory before running the app, or building the docker container
-
Enable https with letsencrypt (a free certificate authority) on docker cloud services
The server.js which serves a built react project is also capable of generating and renewing SSL certificates with letsencrypt. This process is completely automated, all you need to do is run the docker service with the correct environment variables:
- build the docker image
- set the environment variables
DOMAINNAME
,SUBDOMAIN
,ADMINEMAIL
to their appropriate values for your domain name. SetNODE_ENV
toproduction
- spin up the container as a service
- to prevent losing your certificates on a redeploy, add a volume for the path
/etc/letsencrypt