Macrocosm is a partial port of the Open Street Map Ruby API in NodeJS. With Macrocosm, you can host your own version of the OSM platform. It comes bundled with a fork the iD editor that has been lightly modified to send data to a local Macrocosm API (more on that below). Macrocosm supports other data inputs, including direct uploads of OSM XML.
API docs are available here.
-
Changeset creation and upload: create
nodes
,ways
,relations
, and their respectivetags
, usingchangesets
to record metadata. Like in OSM,changesets
recordcreate
,modify
, anddelete
actions. Unlike OSM, there is no concept of closingchangesets
. They close after the last change is recorded. -
Bounding box queries: allow you to specify a bounding box (lat/lon) to get all the elements contained within.
-
Bulk uploads: so you can populate an OSM-like database using OSM XML directly through the Macrocosm API.
git clone git@github.com:developmentseed/macrocosm.git
cd macrocosm
npm install
git submodule update --init
cd iD
make
This repo comes with Docker configuration to spin up the API and a database. This same setup is also used by Travis to run tests against.
To set up your environment, make sure docker
and docker-compose
are installed on your machine. For Mac OS X and Windows download the Docker Toolbox. For Linux follow these instructions.
For Mac OS X or Windows, make sure you're running the following commands in a terminal that has the docker environment variables set. This can be done by running the Docker Quickstart Terminal
app, or running eval $(docker-machine env default)
. Linux users may need to use sudo
. Then start the database and API in the root directory of this repo:
npm run docker-start
To serve iD, start a web server in the iD subdirectory, eg. python -m SimpleHTTPServer
.
You may need to change the url that iD posts changesets to, depending on your docker host ip address. To find this address, install Docker Machine and use docker-machine env
:
$ docker-machine env default
DOCKER_HOST=tcp://192.168.99.101:2376
^ In this case, you would change the url to //192.168.99.101:4000
. On Ubuntu, the API url will normally be localhost:4000
.
Note The bundled version of iD is only lightly modified. It will post changesets to a local Macrocosm API instead of OpenStreetMap, but the rest of the code base is unchanged. As such, we recommend it's use for local development and testing only.
You can also just spin up the database and make it available on $DOCKER_HOST:5433
:
npm run docker-start-db # start the db
npm run docker-kill-db # kills the db
The following command creates an empty postgres db, populates it with test data, and runs the tests against it.
npm run docker-test
It is also possible to run the API without Docker. This is for example useful if you want to connect to an instance of the database hosted elsewhere.
Adapt the local.js
file in your root directory that directs the API to a PostgreSQL database url (info on setting that up below). The placeholder contains the url for the database that Docker spins up.
module.exports.connection = {
production: 'postgres://USER:PASSWORD@HOST:POST/DATABASE',
}
Now you can run the API using MACROCOSM_ENV=production npm run start
.
Macrocosm allows you to specify different databases using environment variables, eg. if you have separate testing and production databases. To specify different databases, structure your local.js
file as such:
module.exports.connection = {
docker: 'postgres://osm:password@localhost:5432/macrocosm_test',
production: 'postgres://USER:PASSWORD@HOST:POST/DATABASE',
test: 'POSTGRES://USER2:OTHERPASS@TESTING.HOST.COM:PORT/DB'
}
Now you can run your tests on a separate database:
MACROCOSM_ENV=test npm run test
npm run gendoc
On a push to master
, Travis builds the documentation and pushes it to Github Pages. The .js and .json files that are built by npm run gendoc
, should not be committed to Github.
createdb macrocosm
psql -d macrocosm -f db-server/script/macrocosm-db.sql
osmosis \
--read-pbf-fast delaware-latest.osm.pbf \
--log-progress \
--write-apidb database=macrocosm