Logan Williams 808436dd96 Fix article link
2023-06-13 14:07:35 +02:00
2023-06-13 13:53:20 +02:00
2023-06-13 13:46:20 +02:00
2023-06-13 14:07:35 +02:00

osm-search

This is a tool for allowing user friendly proximity queries from OpenStreetMap data.

Bellingcat has a hosted version of the tool at https://osm-search.bellingcat.com/. For more information, see the accompanying article.

A screenshot of the tool in use

Setup and hosting your own

Setting up the database

A Postgres database must be set up with OSM data. This can be done with osm2pgsql.

osm2pgsql -d osm --hstore-all planet-latest.osm.pbf

Next, some additional setup should be done on the database for performance and to create a combined view of all the data:

psql -d osm clean.sql
psql -d osm cluster.sql
psql -d osm index.sql
psql -d osm analyze.sql
psql -d osm views.sql

Note that if you run this using the entire planet OSM file, it will require about 700GB of space.

Running the API

The API requires environment variables for connection with Postgres.

  • PG_DB
  • PG_HOST
  • PG_PORT
  • PG_USER
  • PG_PASSWORD

Running the frontend

The frontend requires one environment variable, VUE_ENV_MAPBOX_KEY to be set. This Mapbox key is used for geocoding queries.

Description
A user friendly way to search OpenStreetMap data for features in proximity to each other.
Readme MIT 1.6 MiB
Languages
Vue 69%
JavaScript 20.4%
Python 9.7%
HTML 0.9%