Skip to content

🤗 Welcome

👍🎉 First off, We are really glad you're reading this, because we need volunteer developers to help improve the Field Mapping Tasking Manager (FMTM)! 🎉👍

We welcome and encourage contributors of all skill levels, and we are committed to making sure your participation is inclusive, enjoyable, and rewarding. If you have never contributed to an open source project before, we are a good place to start, and we will make sure you are supported every step of the way. If you have any questions, please ask!

You can see an overview of the project and the process we have gone through in developing FMTM so far in these slides

Furthermore, there are many ways to contribute to the Field Mapping Tasking Manager (FMTM), which includes:

Testing

Right now, we are in the process of building the prototype. We warmly welcome your input in testing and sharing your feedback. If you are also interested in coordinating a field testing session, please reach out!

Code contributions

Create pull requests (PRs) for changes that you think are needed. We would really appreciate your help!

Skills with the following would be beneficial:

  • Python
  • FastAPI
  • TypeScript / JavaScript
  • React
  • Docker
  • CI/CD workflows

Our latest task board can be found here.

Report bugs and suggest improvements

The issue queue is the best way to get started. There are issue templates for BUGs and FEATURES that you can use, you could also create your own.

Once you have submitted an issue, it will be assigned one label from the following label categories.

If you are wondering where to start, you can filter by the good first issue label.

Report security vulnerabilities

Please inform a maintainer as soon as possible, including the CVE code.

Message via the HOTOSM Slack or direct email would be preferred, but via Github issue is also possible.

🤝 Thank you

Thank you very much in advance for your contributions!! Please ensure you refer to our Code of Conduct. If you've read the guidelines, but are still not sure how to contribute on Github, please reach out to us via our Slack #geospatial-tech-and-innovation.

Code Contribution guidelines

Workflow

We operate the "Fork & Pull" model explained at About Pull Requests

Further details of our development workflow can be found here

If you are reporting a problem

  • Describe exactly what you were trying to achieve, what you did, what you expected to happen and what did happen instead. Include relevant information about the platform, OS version etc. you are using. Include shell commands you typed in, log files, errors messages etc.
  • Please open a separate issue for each problem, question, or comment you have. Do not reuse existing issues for other topics, even if they are similar. This keeps issues small and manageable and makes it much easier to follow through and make sure each problem is taken care of.

Documentation

Project documentation should be in Markdown format, and in a docs subdirectory. While it is possible to use HTML in Markdown documents for tables and images, it is preferred to use the Markdown style as it's much easier to read.

See a detailed guide on documentation contributions here.

Pre-Commit Hooks

Pre-Commit Hooks are used in this repo to enforce coding style:

  • Python adheres mostly to PEP8 convention, amongst others, using the tool ruff.
  • TypeScript / JavaScript code is formatted using prettier.
  • Markdown files are formatted using markdownlint.
  • Raq SQL is formatted using sqlfluff.

Please install the pre-commit hooks before contributing:

pip install pre-commit
pre-commit install

Commit Sign-Off Policy

  • In order to commit to this repository, please read and accept our commit sign-off policy
  • This is simply to verify that you are the author of the commits you make.
  • If possible, please add to your commit footer the Signed-off-by info: Signed-off-by: John Doe <joe.doe@example.com>

Our Development Practices

To see more detail on the development practices used at HOT, please visit this page