Skip to content

Latest commit

 

History

History
327 lines (207 loc) · 16 KB

DEV-1.-Getting-Started.md

File metadata and controls

327 lines (207 loc) · 16 KB

Getting started with Field Mapping Tasking Manager

Overview

Introduction to Field Mapping Tasking Manager Web App

The FMTM web app is a Python/Flask/Leaflet app that serves as a frontend for the ODK Central server, using the ODK Central API to allocate specific areas/features to individual mappers, and receive their data submissions.

1

The FMTM codebase consists of:

  • An API backend in FastAPI (code in: src/backend)
  • A frontend website (soon to be a PWA) in react (code in: src/frontend)

Manager Web Interface (with PC browser-friendlymap view)

A computer-screen-optimized web app that allows Campaign Managers to:

  • Select AOIs
  • Choose task-splitting schemes
  • Provide instructions and guidance specific to the project
  • View areas that are at various stages of completion
  • Provide a project-specific URL that field mappers can access from their mobile phones to select and map tasks.

Basic Tools used

A mobile data collection tool that functions on almost all Android phones. Field mappers use ODK Collect to select features such as buildings or amenities, and fill out forms with survey questions to collect attributes or data about those features (normally at least some of these attributes are intended to become OSM tags associated with those features).

The ODK Collect app connects to a back-end server (in this case ODK Central), which provides the features to be mapped and the survey form definitions.

An ODK Central server that functions as the back end for the field data collectors' ODK Collect apps on their Android phones. Devs must have access to an ODK Central server with a username and password granting admin credentials.

Here are the instructions for setting up an ODK Central server on Digital Ocean (it's very similar on AWS or whatever)

Guide for Users

Prerequisites

  • Stable internet connection.
  • Mapping Knowledge (Optional): While not mandatory, having some mapping knowledge can enhance your experience with FMTM. If you are new to mapping we suggest you to read this

Steps to create a project in FMTM

  • Go to fmtm .
  • If you are new then on the top right cornor click on Sign up and create an account . Else , Sign in to your existing account .
  • Click the '+ CREATE NEW PROJECT' button.
  • Enter the project details.

2

  • Upload Area in the GEOJSON file format.

3

  • Define the tasks of the project.

Screenshot 2023-06-07 232152

  • Select Form .

Screenshot 2023-06-07 232316

  • Click on Submit button.

  • Please watch the video below for more details👇

fmtm.video.mp4

Work on existing projects

If you donot want to create a new project and wish to work on an existing project then follow the steps below:

  • Go to fmtm .
  • If you are new then on the top right cornor click on Sign up and create an account . Else , Sign in to your existing account .
  • Click the button Explore Projects .
  • Select the project you can work on .
  • Click on the marked area.
  • Click on start mapping.

5

Help and Support

If you encounter any issues or need assistance while using FMTM, you can access the following resources:

Thank you

We are excited to have you join our community of passionate mappers and volunteers. FMTM is a powerful platform developed by the Humanitarian OpenStreetMap Team (HOT) to facilitate mapping projects for disaster response, humanitarian efforts, and community development.

With FMTM, you have the opportunity to make a real impact by mapping areas that are in need of support. Your contributions help create detailed and up-to-date maps that aid organizations and communities in their efforts to respond to crises, plan infrastructure, and improve the lives of people around the world.

Whether you are a seasoned mapper or new to the world of mapping, FMTM provides a user-friendly interface and a range of tools to make your mapping experience smooth and rewarding. You can create tasks, collaborate with other volunteers, and contribute to ongoing projects that align with your interests and expertise.

By mapping with FMTM, you are joining a global community of dedicated individuals who share a common goal of using open data to make a positive difference. Together, we can create a more resilient and inclusive world.

Explore the projects, join tasks, and contribute your skills to help us build accurate and comprehensive maps. Don't hesitate to ask questions, seek guidance, and engage with fellow mappers through our forums and communication channels.

Thank you for being part of FMTM. Your mapping efforts are invaluable, and we appreciate your commitment to making a difference.

Happy mapping!

The FMTM Team

Guide for Developers

FMTM frontend

To in details about the frontend click here .

Field Mapper Web Interface (with mobile-friendly map view)

Ideally with a link that opens ODK Collect directly from the browser, but if that's hard, the fallback is downloading a QR code and importing it into ODK Collect.

FMTM backend

To in details about the backend click here .

A backend that converts the project parameters entered by the Campaign Manager in the Manager Web Interface into a corresponding ODK Central project. Its functions include:

  • Convert the AOI into a bounding box and corresponding Overpass API query
  • Download (using the Overpass API) the OSM features that will be mapped in that bounding box (buildings and/or amenities) as well as the OSM line features that will be used as cutlines to subdivide the area
  • Trim the features within the bounding box but outside the AOI polygon
  • Convert the polygon features into centroid points (needed because ODK select from map doesn't yet deal with polygons; this is likely to change in the future but for now we'll work with points only)
  • Use line features as cutlines to create individual tasks (squares don't make sense for field mapping, neighborhoods delineated by large roads, watercourses, and railways do)
  • Split the AOI into those tasks based on parameters set in the Manager Web Interface (number of features or area per task, splitting strategy, etc).
  • Use the ODK Central API to create, on the associated ODK Central server:
    • A project for the whole AOI
    • One survey form for each split task (neighborhood)
      • This might require modifying the xlsforms (to update the version ID of the forms and change the name of the geography file being referred to). This is pretty straightforward using OpenPyXL, though we have to be careful to keep the location within the spreadsheet of these two items consistent.
    • GeoJSON feature collections for each form (the buildings/amenities or whatever)
    • An App User for each form, which in turn corresponds to a single task. When the ODK Collect app on a user's phone is configured to function as that App User, they have access to only the form and features/area of that task.
    • A set of QR Codes and/or configuration files/strings for ODK Collect, one for each App User

Prerequisites for Contribution

1. Review documentation

Don't forget to review the Contribution guidelines and our Code of Conduct before contributing! Here are the steps to contribute to the frontend of Field Mapping Tasking Manager:

2. Fork the repository

Forking creates a copy of the repository in your own GitHub account. Go to the Field Mapping Tasking Manager repository and click the "Fork" button in the top right corner of the page.

3. Navigate to your working directory

Open a terminal and navigate to the directory you want to work in using the following command:

cd <work-dir>

Make sure to replace <work-dir> with the name of your directory.

4. Clone the forked repository

Clone the forked repository to your local machine using the following command:

git clone https://github.com/<your-username>/fmtm.git

Make sure to replace <your-username> with your GitHub username.

5. Create a new branch

Create a new branch for your changes using the following command:

git checkout -b branch-name

Make sure to give your branch a descriptive name that reflects the changes you'll be making.

6. Make changes

Make your contribution, run tests where needed and save.

7. Add changes

Add the changes you've made using the following command:

git add <file-name>

Make sure you replace <file-name> with the name of the file you made changes to.

8. Commit and push

Once you've added changes, commit them to your local branch using the following command:

git commit -m "Add feature"

Make sure to write a descriptive commit message that explains the changes you've made. Then, push your changes to your forked repository using the following command:

git push origin branch-name

9. Submit a pull request

Go to your forked repository on GitHub and click the "Pull requests" tab.
Change the base branch from main to development, select the branch that contains your changes from the compare branch, then click "Create pull request".
This will open a new pull request in the fmtm repository, where you can describe your changes and request that they be merged into the main codebase.

Note: After a PR has been approved and merged, if the branch is no longer in use, delete it both locally and remotely. Otherwise we get buried in dead branches we don't need.
Use the following commands:
Switch out of the branch you want to delete git checkout <some-other-branch>(Replace <some-other-branch> with any other existing branch name).
Delete the branch locally git branch -d <branch-name> and then delete the branch remotely git push origin --delete <branch-name>(Replace <branch-name> with the name of the branch you want to delete).

That's it! You've now contributed to the Field Mapping Tasking Manager.

Setup Your Local Environment

These steps are essential to run and test your code!

1. Setup OSM OAUTH 2.0

The FMTM uses OAUTH2 with OSM to authenticate users. To properly configure your FMTM project, you will need to create keys for OSM.

  1. Login to OSM (If you do not have an account yet, click the signup button at the top navigation bar to create one). Click the drop down arrow on the extreme right of the navigation bar and select My Settings.

  2. Register your local fmtm backend app to OAuth 2 applications. Put your login redirect url as http://127.0.0.1:8000/auth/callback/, For Production replace the URL as production API Url

Note: 127.0.0.1 is required instead of localhost due to OSM restrictions.

image

  1. Right now read user preferences permission is enough later on fmtm may need permission to modify the map option which should be updated on OSM_SCOPE variable on .env , Keep read_prefs for now.

  2. Now Copy your Client ID and Client Secret. Put them in the OSM_CLIENT_ID and OSM_CLIENT_SECRET field of your .env file

2. Create an .env File

Environmental variables are used throughout this project. To get started, create .env file in the top level dir, Sample is .env.example

cp .env.example .env

Your env should look like this:

### ODK Central ###
ODK_CENTRAL_URL=https://central-proxy
ODK_CENTRAL_USER=`<any_valid_email_address>`
ODK_CENTRAL_PASSWD=`<password_of_central_user>`

### FMTM ###
# DEBUG=True
# LOG_LEVEL=DEBUG
URL_SCHEME=http
API_URL=127.0.0.1:8000
FRONTEND_MAIN_URL=localhost:8080
FRONTEND_MAP_URL=localhost:8081
# API_PREFIX=/api

### OSM ###
OSM_CLIENT_ID=`<OSM_CLIENT_ID_FROM_ABOVE>`
OSM_CLIENT_SECRET=`<OSM_CLIENT_SECRET_FROM_ABOVE>`
OSM_URL=https://www.openstreetmap.org
OSM_SCOPE=read_prefs
OSM_LOGIN_REDIRECT_URI=http://127.0.0.1:8000/auth/callback/
OSM_SECRET_KEY=<random_key_for_development>

### Database (optional) ###
CENTRAL_DB_HOST=central-db
CENTRAL_DB_USER=odk
CENTRAL_DB_PASSWORD=odk
CENTRAL_DB_NAME=odk

FMTM_DB_HOST=fmtm-db
FMTM_DB_USER=fmtm
FMTM_DB_PASSWORD=fmtm
FMTM_DB_NAME=fmtm'

Note: If extra cors origins are required for testing, the variable EXTRA_CORS_ORIGINS is a set of comma separated strings, e.g. http://localhost:7050,http://localhost:7051

Verify Setup

Check Deployment

For details on how to run this project locally for development, please look at: DEV 2. Backend

Check Authentication

Once you have deployed, you will need to check that you can properly authenticate.

  1. Navigate to http://127.0.0.1:8000/docs

    Three endpoints are responsible for oauth image

  2. Select the /auth/osm_login/ endpoint, click Try it out and then Execute.
    This would give you the Login URL where you can supply your osm username and password.

    Your response should look like this:

     {"login_url": "https://www.openstreetmap.org/oauth2/authorize/?response_type=code&client_id=xxxx"}
    

    Now copy and paste your login_url in a new tab. You would be redirected to OSM for your LOGIN. Give FMTM the necessary permission.

    After a successful login, you will get your access_token for FMTM, Copy it. Now, you can use it for rest of the endpoints that needs authorization.

  3. Check your access token: Select the /auth/me/ endpoint and click Try it out.
    Pass in the access_token you copied in the previous step into the access-token field and click Execute. You should get your osm id, username and profile picture id.

Start Developing

We look forward to seeing your creative solutions and the positive impact they bring to FMTM. Don't forget to review Contribution guidelines and our Code of Conduct before contributing!

Happy coding!

The FMTM Developer Team