Roll Your Own

For development purposes, you can roll parts of OpenAerialMap locally. Detailed docs exist in the README section of each component. This document is an overview of the interdependencies and configuring the development environment as a functional whole.

Development Requirements

  • It will be necessary to use nvm during development - some applications will need Node v4, others will use Node v0.12

  • In some components (the web frontends) configuration variables can be added to app/assets/scripts/config/local.js, and will override any other references to the config object throughout the project. You would have use the point to a local API URL by adding the following to the configuration files in each of the apps:

module.exports = {
  OAMUploaderApi: 'http://localhost:4000'
};
  • Server applications such as the Catalog API and Uploader API need to have environment variables set before starting them. Please refer to the list of environment variables listed in the README docs in the code repositories.

  • Certain components require the installation of third party libraries and applications (such as MongoDB). Refer to the list of dependencies in the READMEs.

  • OpenAerialMap is a catalog of images stored on the Open Imagery Network. OIN is a specification and a set of imagery buckets provided under a free license. The OAM Catalog reads a file (the registry) to determine which buckets to index in order to form the catalog. The OAM Uploader pushes data to a specific registered bucket (the OpenAerialMap bucket). Since the Catalog and Uploader depend on the Open Imagery Network, you will have to replicate OIN locally. This means having an Amazon S3 bucket available for development, as well as creating a hosted register file for the Catalog API to read (see further details below).

List of components

The OAM uploader ecosystem

At a high-level, the OAM uploader software ecosystem consists of three GitHub repositories housing the API, the administrative panel, and the front-end uploader form.

The Uploader API

The API provides the endpoints used by the upload submission form, adding image URLs and metadata to the processing queue database, checking the status of a user’s uploads, and checking the status of specific uploads.

Finally, it manages a queue of images by checking for new submissions to the database at regular intervals, downloading them, processing them to a standardized TIFF specification, generating metadata and thumbnails, and uploading them to an Amazon S3 bucket.

  • When launching the API, several environment variables must be set. We suggest that you duplicate local.sample.env to local.env and fill in the data. Contact a maintainer for the full AWS credentials and database paths.

  • You will need an Amazon S3 bucket to test uploads.

  • To run, load the variables with source local.env and start the app with npm start.

The Imagery Uploader

This web application depends on the Uploader API

This repo contains the front-end form which allows authenticated users to publish images to the processing queue, and to check the processing status of submitted tasks.

It depends on a connection to the API in order to submit datasets and associated metadata to the processing queue and check upload status. As described above, this page depends on the API for most of its functionality.

The OAM catalog ecosystem

The OAM catalog software ecosystem consists of three GitHub repositories housing the API, the Imagery Browser, and the OAM Landing Page.

The Catalog API

The API provides the endpoints for browsing the available indexed imagery which feeds into the Imagery Browser. Other routes provide statistics that power the OpenAerialMap homepage.

This code repository also contains a worker that can index Open Imagery Network metadata from Amazon S3 buckets. The worker first reads the “OIN Register File” to determine which buckets it needs to read and process.

  • If you want to catalog data that is not available in the Open Imagery Network, provide an environment variable that points to a hosted register file in the same format. You will also have to store the data in an Amazon S3 bucket using the OIN specification.

The Imagery Browser

This web application depends on the Catalog API

The Imagery Browser visualizes the data available in the catalog by polling the OAM Catalog API. It provides views such as latest uploaded imagery, imagery from different periods in time and different resolutions. The imagery is also downloadable.

The OpenAerialMap Landing Page

This web application depends on the Catalog API

The website landing page shows latest imagery available in the catalog as well as statistics such as number of images catalogued and number of providers.