Difference between revisions of "Training Material for 2019 UN Open GIS Challenge 2 - Open geospatial data and software for UN SDG 16, Peace justice and open institutions"

From OSGeo
Jump to navigation Jump to search
m (license - including the publication)
 
(49 intermediate revisions by one other user not shown)
Line 6: Line 6:
 
We have prepared this educational material for researchers, educators and professionals in local, regional, national or international agencies with minimal geospatial information knowledge. We assume our audience has introductory knowledge of database management systems and programming. Nevertheless, the tutorial is intended to be self-contained meaning that anyone following the steps could understand and implement what had been achieved in this tutorial.  
 
We have prepared this educational material for researchers, educators and professionals in local, regional, national or international agencies with minimal geospatial information knowledge. We assume our audience has introductory knowledge of database management systems and programming. Nevertheless, the tutorial is intended to be self-contained meaning that anyone following the steps could understand and implement what had been achieved in this tutorial.  
 
=== License ===
 
=== License ===
This educational material was prepared by Berk Anbaroğlu under the mentorship of Maria Brovelli, Serena Coetzee and Timur Obukhov. In addition, İhsan Buğra Coşkun and Mohammad Almasri contributed to the development of this tutorial. We would like to thank Agit Oktay for his support regarding the development of the web interface. Last, we would like to thank Matthias Kuhn who helped us with various issues regarding QGIS and QGField, and for his suggestion to use Syncthing. The material is distributed under Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license. This entitles that the users of this tutorial could share and adapt this content as long as the attribution is provided and that the same license is used upon adaptations.  
+
The development of this educational material was coordinated by Berk Anbaroğlu under the mentorship of Maria Brovelli, Serena Coetzee and Timur Obukhov. In addition, İhsan Buğra Coşkun and Mohammad Almasri contributed to the development of this tutorial. We would like to thank Agit Oktay for his support regarding the development of the web interface. Last, we would like to thank Matthias Kuhn who helped us with various issues regarding QGIS and QField, and for his suggestion to use Syncthing. The material is distributed under Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license. This entitles that the users of this tutorial could share and adapt this content as long as the attribution is provided and that the same license is used upon adaptations.  
This tutorial has been kindly supported by the [https://www.osgeo.org/foundation-news/2019-osgeo-un-committee-educational-challenge/ 2019 OSGeo UN Committee Educational Challenge].  
+
This tutorial has been kindly supported by the [https://www.osgeo.org/foundation-news/2019-osgeo-un-committee-educational-challenge/ 2019 OSGeo UN Committee Educational Challenge].
 +
 
 +
If you are using this tutorial for scientific research, please cite the paper:
 +
 +
Anbaroğlu, B., İ. B. Coşkun, M. A. Brovelli, T. Obukhov, and S. Coetzee. 2020. ‘Educational Material Development on Mobile Spatial Data Collection Using Open Source Geospatial Technologies’. Pp. 221–27 in The International Archives of the Photogrammetry, Remote Sensing and Spatial Information Sciences. Vol. XLIII-B4-2020. Copernicus GmbH.
 +
 
 
=== Software Used ===
 
=== Software Used ===
 
* PostgreSQL (Postgres) 11.5 is used to create the database that would store the collected data.  PostGIS 2.5.3 extension is used to handle spatial data.
 
* PostgreSQL (Postgres) 11.5 is used to create the database that would store the collected data.  PostGIS 2.5.3 extension is used to handle spatial data.
Line 18: Line 23:
  
 
=== Scenario ===
 
=== Scenario ===
United Nations (UN) officers require mobile field data collection for various purposes, mainly of which is to provide reliable measures to the indicators of targets. It is necessary to provide an easy-to-follow tutorial that will ease the process of mobile spatial data collection of UN officers. This tutorial addresses some of the practical requirements of mobile spatial data collection including offline data collection, attaching photos to recorded events, editing of spatial features on the field and displaying the collected data on the internet through a simple scenario. There are several readily available open source mobile data collection platforms. These are compared as follows:[[File:intro_mobile_platform_comparison.jpg|thumb|center| Overview of the tutorial]]
+
United Nations (UN) officers require mobile field data collection for various purposes, mainly of which is to provide reliable measures to the indicators of targets. It is necessary to provide an easy-to-follow tutorial that will ease the process of mobile spatial data collection of UN officers. This tutorial addresses some of the practical requirements of mobile spatial data collection including offline data collection, attaching photos to recorded events, editing of spatial features on the field and displaying the collected data on the internet through a simple scenario. There are several readily available open source mobile data collection platforms. These are compared as follows:[[File:platform_comparison.jpg|thumb|center| Overview of the tutorial]]
  
 
This paper relied on ''QField'' due to its ease of use and smooth integration with QGIS either by using the QField Sync plugin or its
 
This paper relied on ''QField'' due to its ease of use and smooth integration with QGIS either by using the QField Sync plugin or its
Line 30: Line 35:
  
 
The scenario utilised in this tutorial is recording the location and thematic information of trees in a region. Specifically, a lecturer identifies polygons in which each student is responsible for. Thereon, students go to the field to collect the information regarding trees in that region.
 
The scenario utilised in this tutorial is recording the location and thematic information of trees in a region. Specifically, a lecturer identifies polygons in which each student is responsible for. Thereon, students go to the field to collect the information regarding trees in that region.
 +
 +
''The code of the tutorial can be accessed from this [https://github.com/banbar/OSGeo-Challenge2-2019/ GitHub repo].''
  
 
===Acquired Knowledge===
 
===Acquired Knowledge===
Line 78: Line 85:
 
#* Username: User
 
#* Username: User
 
#* Password: Password (check the ‘Save password’ box for ease of login in future)
 
#* Password: Password (check the ‘Save password’ box for ease of login in future)
# Finally go the '''Advanced''' tab and state the name of the database as it appears on Heroku (i.e. the same value used for the '''Maintenance database'''), so that only the relevant database would be visible.  
+
# Finally go the '''Advanced''' tab and state the name of the database next to '''DB restriction''', so that only the relevant database would be visible on your screen.  
  
 
[[File:heroku_connection.png|thumb|center| Connecting Heroku database]]
 
[[File:heroku_connection.png|thumb|center| Connecting Heroku database]]
Line 111: Line 118:
 
Once PostGIS is right-clicked, and '''New Connection''' is clicked,  the following interface opens in which you can provide database credentials of the Heroku database.  
 
Once PostGIS is right-clicked, and '''New Connection''' is clicked,  the following interface opens in which you can provide database credentials of the Heroku database.  
 
[[File:postgres2qgis.jpg|thumb|center|Linking the Postgres database with QGIS]]
 
[[File:postgres2qgis.jpg|thumb|center|Linking the Postgres database with QGIS]]
You can provide any arbitrary '''Name''', but the '''Host''', '''Port''' and '''Database''' should exactly be the same as it appears on the Heroku page. It is also important to note that the '''SSL mode''' should be ''allow''. Go to the '''Basic''' tab under '''Authentication''', and you may store the '''user name''' and '''password''' in order to ease the process of real time data collection. Do not forget to check the box '''Also list tables with no geometry''' to obtain all the tables of the database.  
+
 
 +
Details you have to provide:
 +
* An arbitrary '''Name'''
 +
* '''Host''', '''Port''' and '''Database''' should exactly be the same as it appears on the Heroku page.  
 +
* '''SSL mode''' should be ''allow''.  
 +
* Go to '''Basic''' tab under '''Authentication''', and you store the '''user name''' and '''password''' in order to ease the process of real time data collection.  
 +
* Do not forget to check the box '''Also list tables with no geometry''' to obtain all the tables of the database.  
  
 
If all the credentials of the Heroku database are entered correctly, clicking the '''Test Connection''' button pops up a window indicating the success of the connection.  
 
If all the credentials of the Heroku database are entered correctly, clicking the '''Test Connection''' button pops up a window indicating the success of the connection.  
Line 158: Line 171:
 
Once the QGS project file is transferred to the mobile device, it can be opened using QField as shown in (a). The layers appear just like they do in QGIS,as shown in (b). In order to start editing, the relevant layer is selected and then the pen icon is toggled in the upper-right corner of the screen. Once the horizontal lines button on the upper left corner is pressed, the user can start collecting data. The location could either be set by panning around the map and clicking on the '+' button located at the bottom-right of the screen or by clicking the locate button at the left-hand side of the screen, which uses the GNSS receiver of the phone to locate the position of the user. New features are added just like they are added in QGIS with the functionality of hiding some attributes (e.g. id in trees) or by offering a drop-down list to the user (e.g. user can select one of the pre-defined tree types).
 
Once the QGS project file is transferred to the mobile device, it can be opened using QField as shown in (a). The layers appear just like they do in QGIS,as shown in (b). In order to start editing, the relevant layer is selected and then the pen icon is toggled in the upper-right corner of the screen. Once the horizontal lines button on the upper left corner is pressed, the user can start collecting data. The location could either be set by panning around the map and clicking on the '+' button located at the bottom-right of the screen or by clicking the locate button at the left-hand side of the screen, which uses the GNSS receiver of the phone to locate the position of the user. New features are added just like they are added in QGIS with the functionality of hiding some attributes (e.g. id in trees) or by offering a drop-down list to the user (e.g. user can select one of the pre-defined tree types).
  
===Offline Data Collection===
 
 
QField allows its users to collect data when there is no internet connection. This requires the use of the [https://plugins.qgis.org/plugins/qfieldsync/ '''QField Snyc'''] plugin, which can be installed from the QGIS plugin repository. The steps involved in offline data collection are as follows:
 
* In QGIS, select '''Preferences''' as shown in (a) below. Clicking on this button opens the window presented in (b).
 
** Set the '''Default Import Directory''' to be the path of the project.
 
** Set the '''Default Export Directory''' to be the path of the files that are to be exported. This directory must be copied to the mobile device.
 
 
[[File:qfield_sync_plugin.jpg|thumb|center|QFieldSnyc plugin]]
 
 
* Select '''Project Configuration''', which opens a window as shown below listing he available layers and actions that can to be taken for each of them.
 
** For OpenStreetMap, select '''no action'''.
 
** The other layers should be in the '''offline editing''' mode.
 
 
[[File:qfield_sync_details.jpg|thumb|center|QField project synchronisation details]]
 
 
* Select '''Package for QField''', which opens the following window. Select the export directory, which can be the same directory as previously. Once the '''Create''' button is clicked, the plugin creates the required Geopackage file and associates it with the QGS file. In this way, data are stored in Geopackage and each update to the project effectively update this Geopackage file.
 
 
[[File:qfield_geopackage.jpg|thumb|center|Creating the package for QField]]
 
 
* Transfer the project to your mobile device and start collecting data using QField.
 
* Once data collection is completed, synchronise your mobile device and update the Heroku database. Select '''Synchronize from QField''', which opens up a window as illustrated below. Once the '''Synchronize''' button is clicked, all of the content of the Geopackage is read and the Heroku database is updated by appending the new records. In this way, it is possible for multiple users to collect offline field data.
 
 
[[File:qfield_sync_back.jpg|thumb|center|Synchronize project]]
 
  
 
==Collecting Photos in the Field==
 
==Collecting Photos in the Field==
Line 221: Line 211:
  
 
Having reached this step means that the mobile device and PC are synchronised. One may add further mobile devices with the same procedure. Once the connection is established between the devices, the details regarding file synchronization must be provided.  
 
Having reached this step means that the mobile device and PC are synchronised. One may add further mobile devices with the same procedure. Once the connection is established between the devices, the details regarding file synchronization must be provided.  
 
First of all, both Syncthing and Synctrayzor needs to know that photos are saved in a folder named '''DCIM''' by default. Therefore, a folder named '''DCIM''' must be created in the project folder. It is important to remember transferring the '''DCIM''' folder when transferring the project from PC to the mobile device.
 
  
 
===Updating the QGIS Project===
 
===Updating the QGIS Project===
Line 246: Line 234:
 
# Select '''Widget Type''' as '''Attachment'''
 
# Select '''Widget Type''' as '''Attachment'''
 
# Enter default path of DCIM folder
 
# Enter default path of DCIM folder
# Select 'Relative paths'
+
# Select '''Relative paths''' and leave the default option checked '''Relative to Project Path'''
  
 
[[File:photo_config_1.jpg|thumb|center|Configuring the photos field – part 1 ]]
 
[[File:photo_config_1.jpg|thumb|center|Configuring the photos field – part 1 ]]
Line 254: Line 242:
 
# Check '''Display Resource Path'''
 
# Check '''Display Resource Path'''
 
# Check '''Display button to open file dialog'''
 
# Check '''Display button to open file dialog'''
 +
# Finally, select the '''Integrated Document Viewer''' as '''Image'''
 +
 +
Press the apply button. The project is now ready to display photos of trees.
  
 
[[File:photo_config_2.jpg|thumb|center|Configuring the photos field – part 2 ]]
 
[[File:photo_config_2.jpg|thumb|center|Configuring the photos field – part 2 ]]
  
The last thing to do is:
 
# Selecting the '''Integrated Document Viewer''' as image
 
  
After that press the apply button. The project is now ready to take photos.
+
'''Transfer''' the project folder containing:
 +
* the updated QGS file (osgeo_challenge2_2019_w_photo.qgs) and
 +
* the DCIM folder that you will now share 
 +
to your mobile device.
  
To synchronise the photo folder with the connected devices, press '''Add Folder''' in the SyncTrayzor as shown below.  
+
[[File:project_folder.jpg|thumb|center|Transfer the project folder to the mobile device]]
 +
 
 +
To synchronise the photo folder with the connected devices, press '''Add Folder''' in the SyncTrayzor as shown below.  
  
 
[[File:photo_synctrayzor.jpg|thumb|center|Adding the folder in SyncTrayzor for sharing photos with multiple users]]
 
[[File:photo_synctrayzor.jpg|thumb|center|Adding the folder in SyncTrayzor for sharing photos with multiple users]]
  
Enter the folder name and folder path. It is important to enter the file location correctly as shown below. Make sure that photos are displayed on QGIS.  
+
Enter the folder name and folder path. It is important to enter the file location correctly as shown below.  
  
 
[[File:photo_synctrayzor_setup.jpg|thumb|center|Setting the file synchronisation folder]]
 
[[File:photo_synctrayzor_setup.jpg|thumb|center|Setting the file synchronisation folder]]
Line 274: Line 268:
 
[[File:photo_devices2share.jpg|thumb|center|Selecting the devices to share the directory containing photos]]
 
[[File:photo_devices2share.jpg|thumb|center|Selecting the devices to share the directory containing photos]]
  
This sends a request to the mobile device(s) selected for acknowledgment.  
+
This sends a request to the mobile device(s) selected for acknowledgment. Please note that
 +
* this request appears '''only''' in the pull-down notification bar as shown below and
 +
* it might take a while since mobile devices can easily get disconnected.
  
[[File:photo_ackw_mobile.jpg|thumb|center|Folder share request sent to mobile device]]
+
[[File:drop_down.jpg|thumb|center|Folder share request sent to mobile device]]
  
Once the request is accepted, the location of the '''DCIM''' folder in the project must also be selected on the phone as follows.
+
[[File:photo_ackw_mobile.jpg|thumb|center|Accept the request]]
  
[[File:photo_mobile_setup.jpg|thumb|center|Setting up the mobile device to accommodate synched photos]]
+
'''Select''' the DCIM folder that you previously transferred to finalise the synchronisation setup on your mobile device as shown below. Note that it is the same folder that you transferred to the mobile device (i.e. '''DCIM''' folder under the '''un_final''' folder).
 +
 
 +
[[File:photo_mobile_setup.jpeg|thumb|center|Setting up the mobile device to accommodate synched photos]]
 
   
 
   
 
Now the synched mobile devices are ready to take photos. The photos will be synched with the PC as well as with other synched mobile devices.
 
Now the synched mobile devices are ready to take photos. The photos will be synched with the PC as well as with other synched mobile devices.
 +
 +
===Collecting Photos on the Field===
 +
 +
Open the updated QGIS project file (osgeo_challenge2_2019_w_photo.qgs) in QField and record an observation. The following screen will pop-up:
 +
 +
[[File:photo_take_qfield.jpeg|thumb|center|Taking a photo of an observation with QField]]
 +
 +
Once the camera icon is clicked, camera opens an a photo can be captured. If there is a problem at this point, make sure that the '''Use native camera function''' is turned off under QField Settings as shown below:
 +
 +
[[File:photo_native_camera.jpeg|thumb|center|Taking a photo of an observation with QField]]
 +
 +
The captured photos will be synched with all the connected devices. Consequently, a captured photo of a tree can also be visualised in QGIS:
 +
 +
[[File:photo_on_qgis.jpg|thumb|center|Visualising a Field Photo in QGIS]]
 +
 +
 +
==Offline Data Collection==
 +
 +
QField allows its users to collect data when there is no internet connection. This requires the use of the [https://plugins.qgis.org/plugins/qfieldsync/ '''QField Snyc'''] plugin, which can be installed from the QGIS plugin repository.
 +
 +
The overall process of offline data collection is illustrated below:
 +
 +
[[File:offline_process.jpg|thumb|center|Offline data collection]]
 +
 +
First, is setting up the environment. We need to export the QGIS project using the QFieldSync plugin, and update the QGS project file as this process might change some of the existing settings. Thereon, we need to rely on Syncyhing if photos are going to be collected in the field, or otherwise we can start collecting field data. Once we have internet connection again,the folder would be transferred to PC and QFieldSync will be used to synchronise the project.
 +
 +
===Export Project===
 +
 +
The first part is to export the project so that all the database is backed up to a Geopackage file (gpkg) that QField can update.
 +
 +
The required steps are as follows:
 +
* Under '''Plugins''' → '''QFieldSync''', select '''Preferences''' as shown in (a) below. Clicking on this button opens the window presented in (b).
 +
** Set the '''Default Import Directory''' to be the path of the project.
 +
** Set the '''Default Export Directory''' to be the path of the files that are to be exported. This directory must be copied to the mobile device.
 +
 +
[[File:qfield_sync_plugin.jpg|thumb|center|QFieldSnyc plugin]]
 +
 +
* Select '''Project Configuration''', which opens a window as shown below listing the available layers and actions that can to be taken for each of them.
 +
** For OpenStreetMap, select '''no action'''.
 +
** The other layers should be in the '''offline editing''' mode.
 +
 +
[[File:qfield_sync_details.jpg|thumb|center|QField project synchronisation details]]
 +
 +
* Select '''Package for QField''', which opens the following window. Select the export directory, which can be the same directory as previously. Once the '''Create''' button is clicked, the plugin creates the required Geopackage file and associates it with the QGS file. In this way, data are stored in a Geopackage file.
 +
 +
[[File:qfield_geopackage.jpg|thumb|center|Creating the package for QField]]
 +
 +
'''Note''' that once the export folder is successfully created as shown below, it '''may''' disrupt the project file. For example, the drop down list to select the tree type, which otherwise works when the QGS file is transferred directly to QField, does not work any more.
 +
 +
Open the new project file in QGIS and '''make sure''' that all of the settings are correct.
 +
 +
Finally, open a '''DCIM''' folder, which will be used to synchronise photos that are captured offline.
 +
 +
[[File:export_folder.jpg|thumb|center|Make sure settings are correct in the exported QGIS file]]
 +
 +
===Capturing Photos in the Field===
 +
 +
Continue with the following steps while you have internet connection:
 +
* Transfer the project to the mobile devices. Multiple users can collect offline data.
 +
* Open SyncTrayzor (PC) and share the '''DCIM''' folder with other devices.
 +
* Syncthing will ask you to accept the request on your mobile device. Accept it and select the '''DCIM''' under the '''export''' folder. In this way, all the photos captured in QField will be stored under the DCIM folder, which would then be synchronised.
 +
 +
===Data Collection===
 +
 +
At this stage, we do not have internet connection any more. Nevertheless, we can collect field data with the following steps:
 +
* Open the project available under the '''export''' directory in QField.
 +
* Collect field data.
 +
* You can also '''update''' existing records, such as changing the height of an existing tree.
 +
 +
Now we are ready to synchronise data we have just collected. For this, we need to have internet connection.
 +
 +
===Synchronisation===
 +
Once you have internet connection again, do the followings to synchronise:
 +
* Transfer the '''export''' folder in your mobile device back to your PC.
 +
* Open GIS.
 +
* Under '''QFieldSync''' plugin select '''Synchronize from QField''', which opens up a window as illustrated below.
 +
* Once the '''Synchronize''' button is clicked, '''all''' of the content of the Geopackage is read and the Heroku database is updated accordingly.
 +
[[File:sync_back.jpg|thumb|center|Synchronize project]]
 +
* Save the QGS file.
 +
* You can repeat the process of synchronising for other devices by repeating this last process.
  
 
==Web Interface==
 
==Web Interface==
Line 301: Line 379:
 
Git is a software development version control system. In order to effectively upload our project to GitHub, Git must be downloaded from [https://git-scm.com/downloads/ this link].   
 
Git is a software development version control system. In order to effectively upload our project to GitHub, Git must be downloaded from [https://git-scm.com/downloads/ this link].   
  
===Create App on Heroku===
+
===Create Desktop App===
 
 
Collected field data are kept on online data stores. In the previous sections, we have relied on Heroku, which allows opening free account. Heroku also allows publishing web based projects, and in order to achieve this, a project must be created in Heroku.
 
Firstly, click the '''New''' → '''Create new app''' as shown here.
 
 
 
[[File:web_create_new_app.jpg|thumb|center| Creating a new app in Heroku]]
 
 
 
Then, enter the '''App name''' and fill '''Choose a region'''. You may choose '''Europe''' as the region. Press '''Create app'''. The ''app name'' would be the URL of the project. The app name should be acknowledged by Heroku. Once the provided app name is acknowledged, the statement <span style="color:#058d7d">'''<app name> is available'''</span> appears.
 
 
 
[[File:web_app_name.jpg|thumb|center|Providing an appropriate app name]]
 
  
Let’s begin the coding of the website. Create an empty folder on the computer.  
+
Create an empty folder on the computer.  
  
 
Open Visual Studio Code. Go to '''File''' → '''Open folder'''.  
 
Open Visual Studio Code. Go to '''File''' → '''Open folder'''.  
Line 379: Line 448:
 
parseConnectionString(process.env.DATABASE_URL);
 
parseConnectionString(process.env.DATABASE_URL);
 
} else {
 
} else {
console.log("process.env.DATABASE_URL empty, connectionString
+
console.log("process.env.DATABASE_URL empty, connectionStringvariable used");
variable used");
 
 
developmentDatabase = parseConnectionString(connectionString);
 
developmentDatabase = parseConnectionString(connectionString);
 
}
 
}
Line 451: Line 519:
 
</nowiki>
 
</nowiki>
  
Finally, the web site can be created. Press '''New File''' and create the '''Index.html''' file.
+
Finally, the web site can be created. Press '''New File''' and create the '''index.html''' file.
  
 
[[File:web_index_html.jpg|thumb|center|Create new file: '''index.html''']]
 
[[File:web_index_html.jpg|thumb|center|Create new file: '''index.html''']]
Line 459: Line 527:
 
<html lang="en">
 
<html lang="en">
 
<head>
 
<head>
<meta http-equiv="Content-Security-Policy" content="upgrade-insecure-
+
    <meta http-equiv="Content-Security-Policy" content="upgrade-insecure-requests">
requests">
+
    <meta charset="utf-8"/>
<meta charset="utf-8"/>
 
 
</head>
 
</head>
 
<body>
 
<body>
<div id="mapdiv"></div>
+
    <div id="mapdiv"></div>
<script src="http://www.openlayers.org/api/OpenLayers.js"></script>
+
    <script src="http://www.openlayers.org/api/OpenLayers.js"></script>
<script src="http://code.jquery.com/jquery-2.1.1.min.js"></script>
+
    <script src="http://code.jquery.com/jquery-2.1.1.min.js"></script>
<script>
+
    <script>
$.getJSON('/api/data', function(data) {
+
 
console.log(data[0].longitude);
+
        $.getJSON('/api/data', function(data) {
console.log(data[0].latitude);
+
            console.log(data[0].longitude);
var veri1=data[0].longitude;
+
            console.log(data[0].latitude);
var veri2=data[0].latitude;
+
            var veri1=data[0].longitude;
map = new OpenLayers.Map("mapdiv");
+
            var veri2=data[0].latitude;
map.addLayer(new OpenLayers.Layer.OSM());
+
 
var point;
+
            map = new OpenLayers.Map("mapdiv");
var length=data.length;
+
            map.addLayer(new OpenLayers.Layer.OSM());
// Points to Map
+
 
for (point = 0; point < data.length; point++) {
+
            var point;
var lon=data[point].longitude;
+
            var length=data.length;
var lat=data[point].latitude;
+
            //TODO - data haritaya ekleme işlemi
// transform from WGS 1984 and to Spherical Mercator Projection
+
            for (point = 0; point < data.length; point++) {
var lonLat = new OpenLayers.LonLat(lon,lat ).transform(new
+
            var lon=data[point].longitude;
OpenLayers.Projection("EPSG:4326"),
+
            var lat=data[point].latitude;
map.getProjectionObject())
+
 
var zoom=15;
+
            var lonLat = new OpenLayers.LonLat(lon,lat ).transform(new OpenLayers.Projection("EPSG:4326"), // transform from WGS 1984
var markers = new OpenLayers.Layer.Markers( "Markers" );
+
                                                                map.getProjectionObject() // to Spherical Mercator Projection
map.addLayer(markers)
+
                                                                )
markers.addMarker(new OpenLayers.Marker(lonLat))
+
            var zoom=15;
map.setCenter (lonLat, zoom)
+
       
}
+
            var markers = new OpenLayers.Layer.Markers( "Markers" );
});
+
            map.addLayer(markers)
</script>
+
               
</body>
+
            markers.addMarker(new OpenLayers.Marker(lonLat))
</html>
+
               
 +
            map.setCenter (lonLat, zoom)
 +
            }
 +
        });
 +
    </script>
 +
  </body>
 +
  </html>
 
</nowiki>
 
</nowiki>
  
Line 561: Line 634:
 
[[File:web_create_repo.jpg|thumb|center|Creating a repo]]
 
[[File:web_create_repo.jpg|thumb|center|Creating a repo]]
 
   
 
   
Go to your file directory through '''cmd (Command Prompt)'''. Write the command:
+
Go to your project's directory through '''cmd (Command Prompt)'''. Write the command:
 
   git init
 
   git init
 
Git is initialized in the folder. Then write this command to add all the contents of the folder:
 
Git is initialized in the folder. Then write this command to add all the contents of the folder:
Line 573: Line 646:
 
Now we need to push the project files to GitHub. Write this code:
 
Now we need to push the project files to GitHub. Write this code:
 
   git push -u origin master
 
   git push -u origin master
 
 
Our files can be seen in the GitHub page.
 
Our files can be seen in the GitHub page.
 
[[File:web_github_page.jpg|thumb|center|Github page of the project]]
 
[[File:web_github_page.jpg|thumb|center|Github page of the project]]
Line 579: Line 651:
 
[[File:web_deploy_heroku.jpg|thumb|center|Deploy project at Heroku]]
 
[[File:web_deploy_heroku.jpg|thumb|center|Deploy project at Heroku]]
  
Find the repository on Heroku and press connect.
+
Find the repository on Heroku and press '''Connect'''.
 
[[File:web_connect_to_github.jpg|thumb|center]]
 
[[File:web_connect_to_github.jpg|thumb|center]]
There are two options. Go to '''Manual Deploy''' and press '''Deploy Branch'''. After the development stage, press '''View'''.
+
There are two options: '''Automatic Deploys''' and '''Manual Deploy'''
 +
 
 +
Go to '''Manual Deploy''' and press '''Deploy Branch'''. After the development stage, press '''View'''.
 
[[File:web_manual_deploy.jpg|thumb|center]]
 
[[File:web_manual_deploy.jpg|thumb|center]]
 
   
 
   

Latest revision as of 12:50, 30 April 2023

Introduction

United Nations (UN) have identified 17 interconnected goals to achieve a better and more sustainable future for all until the end of 2030. These Sustainable Development Goals (SDGs) range from ending poverty to ensuring gender equality. In order to address most of these goals, it is imperative to have a better understanding of geographic information science and technology, as any ‘event’ has a particular geographic location. The aim of this educational tutorial is to investigate the use of Free and Open Source Software (FOSS) to address SDG 16: ‘Peace, Justice and Open Institutions’.

Scope

The following educational material has been drafted within the framework of the 2019 OSGeo UN Committee Educational Challenge entitled ‘Open geospatial data and software for UN SDG 16, Peace justice and open institutions’. The seventh target of SDG 16 is to ‘ensure responsive, inclusive, participatory and representative decision-making at all levels’. Consequently, UN officers and patrols might need to collect geospatial data on the field to provide quantitative measures to address this target. In that respect, we have investigated the use of QField, which is an open source mobile data collection platform that could directly be connected to QGIS. The investigated tasks include real-time editing of geographic features, recording photos and developing a web-interface to display the collected data. There are several cloud based application development platforms and this tutorial relied on Heroku due to its support for PostgreSQL/PostGIS as well as different web programming languages. Any user could open a free account to test their ideas on Heroku.

Audience

We have prepared this educational material for researchers, educators and professionals in local, regional, national or international agencies with minimal geospatial information knowledge. We assume our audience has introductory knowledge of database management systems and programming. Nevertheless, the tutorial is intended to be self-contained meaning that anyone following the steps could understand and implement what had been achieved in this tutorial.

License

The development of this educational material was coordinated by Berk Anbaroğlu under the mentorship of Maria Brovelli, Serena Coetzee and Timur Obukhov. In addition, İhsan Buğra Coşkun and Mohammad Almasri contributed to the development of this tutorial. We would like to thank Agit Oktay for his support regarding the development of the web interface. Last, we would like to thank Matthias Kuhn who helped us with various issues regarding QGIS and QField, and for his suggestion to use Syncthing. The material is distributed under Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license. This entitles that the users of this tutorial could share and adapt this content as long as the attribution is provided and that the same license is used upon adaptations. This tutorial has been kindly supported by the 2019 OSGeo UN Committee Educational Challenge.

If you are using this tutorial for scientific research, please cite the paper:

Anbaroğlu, B., İ. B. Coşkun, M. A. Brovelli, T. Obukhov, and S. Coetzee. 2020. ‘Educational Material Development on Mobile Spatial Data Collection Using Open Source Geospatial Technologies’. Pp. 221–27 in The International Archives of the Photogrammetry, Remote Sensing and Spatial Information Sciences. Vol. XLIII-B4-2020. Copernicus GmbH.

Software Used

  • PostgreSQL (Postgres) 11.5 is used to create the database that would store the collected data. PostGIS 2.5.3 extension is used to handle spatial data.
  • QGIS 3.10 is used to create the project based on the data stored in the Postgres.
  • QField 1.2.0 is used for mobile data collection and editing.
  • Syncthing is used to synchronize collected photos.
  • NodeJS 12.13.1 is used to visualize the collected data on the web.
  • Visual Studio Code 1.41.0 is the Integrated Development Environment for developing the JavaScript code.
  • Git is a version control system that is required to deploy the web based application.

Scenario

United Nations (UN) officers require mobile field data collection for various purposes, mainly of which is to provide reliable measures to the indicators of targets. It is necessary to provide an easy-to-follow tutorial that will ease the process of mobile spatial data collection of UN officers. This tutorial addresses some of the practical requirements of mobile spatial data collection including offline data collection, attaching photos to recorded events, editing of spatial features on the field and displaying the collected data on the internet through a simple scenario. There are several readily available open source mobile data collection platforms. These are compared as follows:

Overview of the tutorial

This paper relied on QField due to its ease of use and smooth integration with QGIS either by using the QField Sync plugin or its ability to process QGS files.

The scenario in this tutorial is recording the location and thematic information of trees in a region. Specifically, a lecturer specifies polygons for which each student is responsible. Thereon, students go to the field to collect the information regarding trees in that region. Some of the regions might have limited broadband coverage, which requires students collect offline data, and some students may capture photos of trees. Finally, it would be interesting to visualise the collected data on the internet so that decision makers (lecturers) could have a better understanding of over/under mapped regions. The scenario can easily be adopted for an operational task that necessiates mobile spatial data collection.

The overview of this tutorial is illustrated as follows:

Comparison of mobile data collection platforms

The scenario utilised in this tutorial is recording the location and thematic information of trees in a region. Specifically, a lecturer identifies polygons in which each student is responsible for. Thereon, students go to the field to collect the information regarding trees in that region.

The code of the tutorial can be accessed from this GitHub repo.

Acquired Knowledge

After going through the entire educational material, one will be able to understand the process to develop a mobile geospatial data collection platform using technologies including QField, QGIS, Postgres/PostGIS and Syncthing.

Setting Up the Environment

This section describes the required steps to set up the development environment. In order to realise the steps described in subsequent sections in a smooth manner, it is recommended that the users:

  • Open a Heroku account
  • Install PostgreSQL and PostGIS on their local computer
  • Connect the Heroku database from QGIS
  • Set up the project in QGIS
  • Transfer the project from desktop PC (QGIS) to mobile data collection platform (QField).

Opening a Heroku Account

A database server should be available in the web to initiate a mobile geographic data collection project. There are several solutions that offer a free solution to this. One of the platforms supporting Postgres and PostGIS is Heroku, which is a platform as a service (PaaS) that enables developers to build, run, and operate applications entirely in the cloud. Therefore, this tutorial relied on Heroku to set up the database on the cloud.

The sign up page of Heroku requires some personal information such as name, surname and email address.

Sign up page of Heroku

Once the form is submitted, an email is sent to verify the account. These credentials is used to create a new app.

The second step is to create a Heroku app with a Postgres database. Steps are as follows:

  1. Log in to your Heroku account.
  2. Click "New" → "Create New App" (→ symbol is a left click and ⇒ is a right-click)
  3. Create New App
    • Provide a unique app name. Heroku acknowledges if the provided app name is unique.
    • There are two regions: "United States" (default) and "Europe". You may leave it as it is.
    • Finally, click "Create app".
  4. Go to https://dashboard.heroku.com/apps and choose the app you just created.
  5. Click on "Resources" tab.
    • Under "Add-ons" type "Heroku Postgres" and click on it. Finally, complete the Postgres deployment by clicking on the "Provision" button.
  6. To see the database credentials:
    • Click on the settings symbol located on the top-right corner.
    • Click "Data".
    • Select your application.
    • Go to "Settings" → "View Credentials".

Accessing the Heroku Database

A user interface can be used to manipulate a Postgres database such as pgAdmin or DBeaver.

This tutorial relied on pgAdmin 4, and one it is installed, we can connect to our Heroku database with the following steps:

  1. Right click on ServersCreate Server
  2. Click on General and provide a name for your server (e.g. heroku).
  3. Go to the Connection tab, and enter the Heroku database credentials that you have previously obtained.
    • Host name/address: Host
    • Maintenance database: Database
    • Username: User
    • Password: Password (check the ‘Save password’ box for ease of login in future)
  4. Finally go the Advanced tab and state the name of the database next to DB restriction, so that only the relevant database would be visible on your screen.
Connecting Heroku database

It is now possible to create the tables. To open the query window, right click on the database and select the Query Tool.

The scenario for this tutorial requires three tables: i) trees and ii) regions are tables with a spatial aspect, whereas tree_type do not have a geometry and are used to ease the process of data collection. In addition, multiple languages are supported in a more convenient way.

First, let us create the tree_type table. The following code creates two different types of trees (pine and oak) in two different languages (English and Turkish).

Creating the tree_type table

The other two tables possess a spatial component. Therefore, the first step is to activate the extension postgis, which is achieved using the create extension postgis statement.

The SQL statements to create the trees and regions tables are as follows.

Creating the trees and regions tables

The following attributes are included within the created tables:

  • trees
    • t_type is the type of a tree.
    • height is the height of a tree.
    • id is the unique identifier of a tree.
    • loc is the location of a tree in WGS 84.
    • observation_time is the date-time of an observation.

trees table has a point geometry indicating the latitude and longitude of the observed tree as well as the tree type, height and observation time. The second table, regions include a polygon geometry indicating the areas in which each student is expected to carry out data collection. Students’ names can be included in the 'responsible' attribute.

Connecting the Database with QGIS

The Postgres database created in the previous subsection can be included directly into a QGIS project, thanks to the seamless linkage between QGIS and Postgres.

Once PostGIS is right-clicked, and New Connection is clicked, the following interface opens in which you can provide database credentials of the Heroku database.

Linking the Postgres database with QGIS

Details you have to provide:

  • An arbitrary Name
  • Host, Port and Database should exactly be the same as it appears on the Heroku page.
  • SSL mode should be allow.
  • Go to Basic tab under Authentication, and you store the user name and password in order to ease the process of real time data collection.
  • Do not forget to check the box Also list tables with no geometry to obtain all the tables of the database.

If all the credentials of the Heroku database are entered correctly, clicking the Test Connection button pops up a window indicating the success of the connection.

Finally, once the OK button is clicked, the connection appears on the Browser panel as shown below, and the user can add all the relevant tables to the layer panel by double-clicking on the table.

Adding the tables in Heroku to QGIS

Setting Up the Value Relations in QGIS

In order to ease the process of data collection, it is useful to explicitly state the value relationships between the feature layers and to improve the user experience by hiding some of the details. For instance, a student can only select one of the pre-defined tree types instead of typing it. This can be achieved by adjusting the Attribute Form specified under the Properties of the trees layer as shown below.

Relating the tree type in trees layer with pre-defined tree_types

The tree type attribute t_type has a value relation to the tree_types table. In order to realise this relation. The following settings are specified:

  • Widget type: Value Relation
  • Layer: trees_type
  • Key column: name_en
  • Value column: name_en

In addition, some of the attributes might better be hidden from the users such as the id attribute of the trees or regions as it is a serial number that auto increments as a tree/region is recorded. Therefore, this attribute shall not be editable. In addition, it can be hidden from the user to reduce clutter in the GUI of the QField. This process is illustrated as follows.

  • Uncheck Editable
  • Widget type: Hidden
Removing clutter from the GUI by hiding some attributes

Once an attribute is hidden, it means that during data collection that field is not displayed to the user. However, a user could still update it under the attribute table. In order to prevent this as well, we have unchecked Editable.

The last attribute of the trees layer is the observation time. It might be important to record the observation time in order to facilitate further spatio-temporal analysis. At the moment, it is possible to record the height of the same tree at two or more distinct time intervals.

Update the default value of the observation_time attribute to be now() as shown in the figure below. In this way, whenever a tree is recorded, its observation time is also recorded.

Assigning default observation time to the corresponding attribute

Actions:

  • Widget Type: Date/Time
  • Default value: now()

If the mobile data collection platform assumes internet connection, then including OpenStreetMap in the QGIS project may ease data collection process. Install the OpenLayers plugin, and include OpenStreetMap in your project.

Including OpenStreetMap in the project to ease data collection

Transferring the Project to QField

Once all the layers are added, the project is saved as a QGS file. This means that the file is a legible XML document. All of the details of the project are included in this document including the credentials of the Heroku database. Anyone possessing this QGS file can start collecting field data, which would have immediate effect on the Heroku database. In this way, multiple users can effectively collect field data into the same database. This file can directly be transferred to the smart phone or tablet possessing QField.

Data collection on QField

Once the QGS project file is transferred to the mobile device, it can be opened using QField as shown in (a). The layers appear just like they do in QGIS,as shown in (b). In order to start editing, the relevant layer is selected and then the pen icon is toggled in the upper-right corner of the screen. Once the horizontal lines button on the upper left corner is pressed, the user can start collecting data. The location could either be set by panning around the map and clicking on the '+' button located at the bottom-right of the screen or by clicking the locate button at the left-hand side of the screen, which uses the GNSS receiver of the phone to locate the position of the user. New features are added just like they are added in QGIS with the functionality of hiding some attributes (e.g. id in trees) or by offering a drop-down list to the user (e.g. user can select one of the pre-defined tree types).


Collecting Photos in the Field

Photos can be used in mobile data collection projects to better describe a spatial object. Storing photos in a database is not trivial, and most of the time the path to the photo is stored. For this reason, an additional platform is needed to share photos where multiple users capture photos and synchronise them.

Setting Up the Snycthing Environment

Syncthing is a continuous file synchronisation program. It synchronizes files between two or more devices. The location of the shared folder is specified on Syncthing. It requires internet to synchronise the files. The aim of using Syncthing in this project is synchronising photo folders between mobile device and computer.

Firstly, Syncthing must be installed on all devices. It can be downloaded for Windows from here. There are two options as x64 and x86. The suitable option can be downloaded. Note that SyncTrayzor is the name of the software on the desktop.

Likewise, the app Syncthing must be installed on the mobile device. It can be downloaded to android devices through Google Play.

Having installed Syncthing on PC and mobile devices, they are required to be connected. Open SyncTrayzor on your desktop. Go to ActionsShow ID as shown below.

Obtaining the ID of the PC where each photo will be uploaded

The ID of a device is presented as a text and QR code as shown below.

ID of a Snycthing device

This code must also be entered to the mobile device. Press the '+' button in the Devices menu as shown below.

Synching the mobile device with PC

Device options will be shown. Enter the connection ID and connection name. Also, QR code can be used to add the PC as illustrated below.

Adding the PC to the mobile device

Once the PC is added to the mobile, this action sends a request to the PC stating the details of the connection. Press Add Device as shown below.

Accepting the request sent from the mobile device

After acceptance, connections will be established between the mobile device and the PC, which can be seen in SyncTrayzor as follows. The mobile device used in this tutorial is MI 8 SE.

Connected devices – PC view

Also, Syncthing on the mobile device displays the connection information as shown here:

Connected devices – mobile device view

Having reached this step means that the mobile device and PC are synchronised. One may add further mobile devices with the same procedure. Once the connection is established between the devices, the details regarding file synchronization must be provided.

Updating the QGIS Project

The path of the captured photos must also be stored in the database. There are two different ways to add a 'photo' attribute to the 'trees' layer. First, the attribute can be added when creating the table in the database. The data type can be chosen as text, whih corresponds to the URL of the image. Second, it can be added from the QGIS project. This tutorial relies on the latter option.

Open the attributes table. Right click the 'trees' layer and click 'Open attributes table'. Then follow these steps:

  1. Press the 'Toggle Editing Mode' which is shown with button '1'.
  2. Press the 'New Field' button which is shown with button '2'.
Adding a new attribute from QGIS

After that, enter the column name and select the data type. Select type as 'Text, unlimited length (text)', and then click OK.

Adding a new field in QGIS

Finally, click on 'Toggle Editing Mode' to end editing, and press save.

The following adjustments have to be satisfied to display photos on QGIS:

  1. Right click to 'trees' layer and press properties
  2. Go to Attributes Form
  3. Select the Photo column
  4. Select Widget Type as Attachment
  5. Enter default path of DCIM folder
  6. Select Relative paths and leave the default option checked Relative to Project Path
Configuring the photos field – part 1

Continue with the following steps:

  1. Under Storage Mode select File paths
  2. Check Display Resource Path
  3. Check Display button to open file dialog
  4. Finally, select the Integrated Document Viewer as Image

Press the apply button. The project is now ready to display photos of trees.

Configuring the photos field – part 2


Transfer the project folder containing:

  • the updated QGS file (osgeo_challenge2_2019_w_photo.qgs) and
  • the DCIM folder that you will now share

to your mobile device.

Transfer the project folder to the mobile device

To synchronise the photo folder with the connected devices, press Add Folder in the SyncTrayzor as shown below.

Adding the folder in SyncTrayzor for sharing photos with multiple users

Enter the folder name and folder path. It is important to enter the file location correctly as shown below.

Setting the file synchronisation folder

Select the mobile devices you want to synchronize the folder that contains photos in the Sharing option and press Save button.

Selecting the devices to share the directory containing photos

This sends a request to the mobile device(s) selected for acknowledgment. Please note that

  • this request appears only in the pull-down notification bar as shown below and
  • it might take a while since mobile devices can easily get disconnected.
Folder share request sent to mobile device
Accept the request

Select the DCIM folder that you previously transferred to finalise the synchronisation setup on your mobile device as shown below. Note that it is the same folder that you transferred to the mobile device (i.e. DCIM folder under the un_final folder).

Setting up the mobile device to accommodate synched photos

Now the synched mobile devices are ready to take photos. The photos will be synched with the PC as well as with other synched mobile devices.

Collecting Photos on the Field

Open the updated QGIS project file (osgeo_challenge2_2019_w_photo.qgs) in QField and record an observation. The following screen will pop-up:

Taking a photo of an observation with QField

Once the camera icon is clicked, camera opens an a photo can be captured. If there is a problem at this point, make sure that the Use native camera function is turned off under QField Settings as shown below:

Taking a photo of an observation with QField

The captured photos will be synched with all the connected devices. Consequently, a captured photo of a tree can also be visualised in QGIS:

Visualising a Field Photo in QGIS


Offline Data Collection

QField allows its users to collect data when there is no internet connection. This requires the use of the QField Snyc plugin, which can be installed from the QGIS plugin repository.

The overall process of offline data collection is illustrated below:

Offline data collection

First, is setting up the environment. We need to export the QGIS project using the QFieldSync plugin, and update the QGS project file as this process might change some of the existing settings. Thereon, we need to rely on Syncyhing if photos are going to be collected in the field, or otherwise we can start collecting field data. Once we have internet connection again,the folder would be transferred to PC and QFieldSync will be used to synchronise the project.

Export Project

The first part is to export the project so that all the database is backed up to a Geopackage file (gpkg) that QField can update.

The required steps are as follows:

  • Under PluginsQFieldSync, select Preferences as shown in (a) below. Clicking on this button opens the window presented in (b).
    • Set the Default Import Directory to be the path of the project.
    • Set the Default Export Directory to be the path of the files that are to be exported. This directory must be copied to the mobile device.
QFieldSnyc plugin
  • Select Project Configuration, which opens a window as shown below listing the available layers and actions that can to be taken for each of them.
    • For OpenStreetMap, select no action.
    • The other layers should be in the offline editing mode.
QField project synchronisation details
  • Select Package for QField, which opens the following window. Select the export directory, which can be the same directory as previously. Once the Create button is clicked, the plugin creates the required Geopackage file and associates it with the QGS file. In this way, data are stored in a Geopackage file.
Creating the package for QField

Note that once the export folder is successfully created as shown below, it may disrupt the project file. For example, the drop down list to select the tree type, which otherwise works when the QGS file is transferred directly to QField, does not work any more.

Open the new project file in QGIS and make sure that all of the settings are correct.

Finally, open a DCIM folder, which will be used to synchronise photos that are captured offline.

Make sure settings are correct in the exported QGIS file

Capturing Photos in the Field

Continue with the following steps while you have internet connection:

  • Transfer the project to the mobile devices. Multiple users can collect offline data.
  • Open SyncTrayzor (PC) and share the DCIM folder with other devices.
  • Syncthing will ask you to accept the request on your mobile device. Accept it and select the DCIM under the export folder. In this way, all the photos captured in QField will be stored under the DCIM folder, which would then be synchronised.

Data Collection

At this stage, we do not have internet connection any more. Nevertheless, we can collect field data with the following steps:

  • Open the project available under the export directory in QField.
  • Collect field data.
  • You can also update existing records, such as changing the height of an existing tree.

Now we are ready to synchronise data we have just collected. For this, we need to have internet connection.

Synchronisation

Once you have internet connection again, do the followings to synchronise:

  • Transfer the export folder in your mobile device back to your PC.
  • Open GIS.
  • Under QFieldSync plugin select Synchronize from QField, which opens up a window as illustrated below.
  • Once the Synchronize button is clicked, all of the content of the Geopackage is read and the Heroku database is updated accordingly.
Synchronize project
  • Save the QGS file.
  • You can repeat the process of synchronising for other devices by repeating this last process.

Web Interface

This section describes how to visualise the data stored in the database on the web. First, the section provides a brief introduction on the required technologies, including NodeJS, Visual Studio Code and GitHub. Second, the code is presented that can be used to visualise the collected field data.

Technologies

NodeJS

NodeJS is an open-source, cross-platform, JavaScript runtime environment that executes JavaScript code outside of a browser. It can be downloaded from here.

Visual Studio Code

Visual Studio Code is a source code editor that can be used with a variety of programming languages. It is developed by Microsoft for Windows, Linux and macOS. It can be downloaded from this link. The version used for this tutorial is 1.40.1.

Git Git is a software development version control system. In order to effectively upload our project to GitHub, Git must be downloaded from this link.

Create Desktop App

Create an empty folder on the computer.

Open Visual Studio Code. Go to FileOpen folder.

Then go to TerminalNew Terminal.

It opens a terminal screen below the screen. Write npm init on the terminal screen end press enter. It asks some questions to create package.json, which holds various metadata relevant to the project.

Press enter for all of the questions. The metadata file package.json is created at the end of this process. Once all the default values are accepted, the package.json looks like:

The metadata file: package.json

Some JavaScript packages need to be installed. These packages will be installed via npm (Node Package Manager). Packages to install are listed as follows:

  • Express Module

Express is a minimal and flexible Node.js web application framework that provides a robust set of features to develop web and mobile applications.

In terminal write the following and press enter:

 npm install express --save 
  • File System Module

This allows to work with the file system on your computer.

In terminal write the following and press enter:

 npm install fs --save
  • Bluebird Module

Bluebird is a fully featured library with focus on innovative features and performance.

In terminal write the following and press enter:

 npm install bluebird --save
  • Pg-Promise Module

Pg-promise is a PostgreSQL interface for NodeJS.

In terminal write the following and press enter:

 npm install pg-promise --save

The package.json will be updated once these packages are installed, and will look this. Notice the dependencies:

Updated package.json

Project settings are ready.

Now, we need to establish the database connection. Click the New File button, and add appConfig.js file.

Adding the appConfig.js file

The appConfig.js would include the database connection settings (for now it is the localhost) and the entire content of the file should be:

var developmentDatabase = {
postgres: {
host: 'localhost',
port: 5432,
database: 'database_name',
user: 'postgres',
password: 'postgres'
}
}

var connectionString = "postgressql://user:password@host:port/databasename?ssl=true";
if (process.env.NODE_ENV == 'production') {
//Production mode
if (process.env.DATABASE_URL) {
developmentDatabase =
parseConnectionString(process.env.DATABASE_URL);
} else {
console.log("process.env.DATABASE_URL empty, connectionStringvariable used");
developmentDatabase = parseConnectionString(connectionString);
}
}else{
//Development mode
developmentDatabase = parseConnectionString(connectionString);
}
function parseConnectionString(connectionString) {
if (connectionString) {
var myRegexp = /(\w+):(\w+)@(.+):(\w+)\/(\w+)/g;
var match = myRegexp.exec(connectionString);
if (match.length == 6) {
developmentDatabase.postgres.user = match[1];
developmentDatabase.postgres.password = match[2];
developmentDatabase.postgres.host = match[3];
developmentDatabase.postgres.port = Number(match[4]);
developmentDatabase.postgres.database = match[5];
developmentDatabase.postgres.ssl = true;
return developmentDatabase;
}
}
console.log("connectionString cannot be parsed");
return null;
}
module.exports = {
hostname: "http://localhost",
port: 5656,
database: {
postgres: developmentDatabase.postgres
}
}

The only statement that requires to be changed regarding the credentials of the Heroku database is the connectionString.

Web connection string.jpg

This statement should be updated based on the credentials of the Heroku database, which can be found through SettingsView Credentials.

Obtaining Credentials of the Heroku database

After that, data stored in the database must be retrieved. For this, we need to create a new file database.js:

Create new file: database.js

The connection is applied from appConfig.js and the query is applied in this script. The important thing is the query at this point. Check that your table name and queries correspond to those in your database. The content of the database.js should look like:

const fs = require('fs');
var promise = require('bluebird');
var CONFIG = require('./appConfig');
var pgp = require('pg-promise')(options);
var DATABASE_PGB = pgp(CONFIG.database.postgres);

module.exports = {
       getAllLocations: getAllLocations
};

var options = {
    promiseLib: promise
};

function getAllLocations(cb) {
      DATABASE_PGB.any('SELECT ST_X(loc) as longitude, ST_Y(loc) as latitude from trees')
      .then(function (data) {
         cb(null, data);})
       .catch(function (err) {
          cb(err)});
}

Finally, the web site can be created. Press New File and create the index.html file.

Create new file: index.html

The background map is obtained from OpenLayers. The query response returns a GeoJSON file. Therefore, Jquery library will be used to receive the query response. Also, the security policy is added to run the web site page as HTTPS protocol. Copy the following code as an HTML file:

<html lang="en">
<head>
    <meta http-equiv="Content-Security-Policy" content="upgrade-insecure-requests">
    <meta charset="utf-8"/>
</head>
<body>
    <div id="mapdiv"></div>
    <script src="http://www.openlayers.org/api/OpenLayers.js"></script>
    <script src="http://code.jquery.com/jquery-2.1.1.min.js"></script>
    <script>

        $.getJSON('/api/data', function(data) {
            console.log(data[0].longitude);
            console.log(data[0].latitude);
            var veri1=data[0].longitude;
            var veri2=data[0].latitude;

            map = new OpenLayers.Map("mapdiv");
            map.addLayer(new OpenLayers.Layer.OSM());

            var point;
            var length=data.length;
            //TODO - data haritaya ekleme işlemi
            for (point = 0; point < data.length; point++) {
            var lon=data[point].longitude;
            var lat=data[point].latitude;

            var lonLat = new OpenLayers.LonLat(lon,lat ).transform(new OpenLayers.Projection("EPSG:4326"), // transform from WGS 1984
                                                                map.getProjectionObject() // to Spherical Mercator Projection
                                                                )
            var zoom=15;
        
            var markers = new OpenLayers.Layer.Markers( "Markers" );
            map.addLayer(markers)
                
            markers.addMarker(new OpenLayers.Marker(lonLat))
                
            map.setCenter (lonLat, zoom)
            }
        });
    </script>
  </body>
  </html>

Finally, the website needs to be published through NodeJS. Click the New File and create the index.js file.


Create new file: index.js

This file provides code to publish the website. It reads the HTML page and it sends a response. The content of the file should be:

var express = require('express');
var fs = require('fs');
var DATABASE = require('./database.js');
var app = express();
app.get('/', function (req, res, next) {
res.writeHead(200, { 'Content-Type': 'text/html' });
var myReadStream = fs.createReadStream(__dirname + '/index.html',
'utf8')
myReadStream.pipe(res);
});
app.use('/api/data', function (req, res) {
DATABASE.getAllLocations(function (err, data) {
if (err) {
res.sendStatus(500);
} else {
res.send(data);
}
})
});
app.listen(process.env.PORT || 4000, function(){
console.log("Express server listening on port %d in %s mode",
this.address().port, app.settings.env);
});
 

It can be checked whether the website is working or not. Go to terminal and write node index.js, then press enter.

Initiating the project

Open a web browser and type: http://localhost:4000/. Once the browser opens, the data stored on the database would be retrieved and displayed on the map as shown below.

Visualising collected data on localhost

Deploying the Project on Heroku

One more file needs to be created before the website is published through Heroku. Go to New File and create Procfile file. Heroku apps include a Procfile that specifies the commands that are executed by the app on startup.

Web procfile.jpg

Only the starting file of the project is specified within the Procfile:

 web:node index.js

There is one more task to be done before deploying the project on Heroku. The created package.json file needs to be updated. It must be told by which file the website is started. Therefore, the start parameter must be added.

Adding the start parameter to package.json

The project is ready to be published on Heroku.

Open an account on Github, and press New.

Web github new.jpg

Enter the Repository name and press Create repository.

Creating a repo

Go to your project's directory through cmd (Command Prompt). Write the command:

 git init

Git is initialized in the folder. Then write this command to add all the contents of the folder:

 git add .

Files need to be committed with a command. Write the command:

 git commit –m "your message"

After that, establish a remote connection. Note that you need to write the project link instead of ProjectLink. It can be done with:

 git remote add origin ProjectLink

The example ProjectLink utilised in this tutorial is: https://github.com/bugracoskun/Tutorial

Now we need to push the project files to GitHub. Write this code:

 git push -u origin master

Our files can be seen in the GitHub page.

Github page of the project

The last step to publish the website is deploying it to Heroku. Go to the Heroku project page. Under Deploy select Github.

Deploy project at Heroku

Find the repository on Heroku and press Connect.

Web connect to github.jpg

There are two options: Automatic Deploys and Manual Deploy

Go to Manual Deploy and press Deploy Branch. After the development stage, press View.

Web manual deploy.jpg

The website is published in the given link. Whenever there is an update in QField, it is possible to observe the change on the web page.

Displaying the collected data on Heroku

Concluding Remarks

Mobile spatial data collection is one of the common tasks that UN officers and patrols carry out on a regular basis. Therefore, easy-to-use and flexible means to achieve this improves the effectiveness of day-to-day operations. Some of the following requirements must be met to facilitate mobile data collection:

  • Offline data collection: it might be possible that UN officers might be working on sites where there is limited or no access to internet. Even under such circumstances, the data collection framework must allow offline data collection. Whenever internet becomes available, officers could upload the collected data.
  • Attaching multimedia evidence such as photos (and possibly other forms including voice records and videos) to events in order to promote peaceful and inclusive societies for sustainable development. By recording multimedia data on complex scenarios, such as an interview with a victim, it might be possible to have a better understanding on the linkage between undesired ‘events’ and their respective ‘locations’.
  • Editing of spatial features on the field. One of the critical requirements to ensure responsive, participatory and representative decision-making at all levels is to have up-to-date data. Therefore, updating currently available databases might be as important as collecting new data.
  • Defining user roles is important step towards ensuring quality assurance and quality control (QA/QC); since different users of the same system would usually have different privileges.
  • Security of collected, both in terms of server infrastructure as well as providing the means to achieve anonymity, would be important to ensure a smooth data collection process.

This tutorial addressed several of the aforementioned requirements. However, some of them remained unmet. For instance, it was not possible to define user roles due to the limitations of the Heroku platform providing free account. Specifically, it is restricted to execute the SQL command ‘create user’, which would be necessary to define the user privileges. Second, the credentials of the database connection is legible in the QGS file that is transmitted to the mobile devices possessing QField. Even though only confirmed officers would possess this file, it might still be a security breach.

The developments on providing cloud technologies offer the potential to satisfy the aforementioned requirements. The readers of this tutorial are encouraged to follow the developments on QField Cloud. Integrating such developments into the current tutorial would substantially improve the data collection and update operations in the field.