LCMAP Landsat data retrieval and curation.
- Leiningen 2.7.1
- Java 1.8
- Docker 1.13.1
- Docker Compose 1.10.0
Clone the repo.
git clone git@github.com:usgs-eros/lcmap-landsat
Initialize submodules (to get dev/test data).
git submodule init
git submodule update
Start backing services.
make docker-deps-up
Run the tests.
lein test
Start a REPL.
lein run
Initialize the local development schema and bindings. By default, a REPL will start the dev/user.clj
.
(init)
Once you have setup your environment you can load sample data. See dev/curate.clj
to learn how to load some to use during development. This file contains code that can be evaulated in a REPL to load chip-specs and ingest chips. Because it is a powerful used for both local development and operational environments, special instructions (and warnings) are provided.
If you run into problem, common development and test issues are available in the FAQ.
During routine development, use dev/user.clj
with a REPL to run the HTTP server and AMQP workers.
Travis-CI will automatically build a jarfile and Docker image after a successful build of develop
and master
branches. The Docker image is pushed to Docker Hub.
You can build your own jarfile and Docker image using make build
and make docker-image
.
Provide configuration values using environment variables when runnning the application as a jarfile or docker container.
Environment Variable | Default |
---|---|
AARDVARK_BASE_URL | / |
AARDVARK_DB_HOST | cassandra |
AARDVARK_DB_USER | nil |
AARDVARK_DB_PASS | nil |
AARDVARK_EVENT_HOST | rabbitmq |
AARDVARK_EVENT_PORT | 5672 |
AARDVARK_EVENT_USER | nil |
AARDVARK_EVENT_PASS | nil |
AARDVARK_HTTP_PORT | 5678 |
AARDVARK_SEARCH_INDEX_URL | http://elasticsearch:9200/lcmap-landsat |
AARDVARK_CHIP_SPEC_URL | http://elasticsearch:9200/lcmap-landsat/chip-specs |
AARDVARK_SERVER_EVENTS | lcmap.landsat.server |
AARDVARK_WORKER_EVENTS | lcmap.landsat.worker |
AARDVARK_LOG\LEVEL | INFO |
You may notice that the default hostnames are not localhost. This is because localhost is not a reasonable default for the application to use when running in the context of a Docker container; the container does not provide these services. However, service discovery systems may provide DNS support that Docker automatically can use to resolve these services. If you do not have this available, simply provide the appropriate hostname instead.
The Docker image can be deployed to services capable of running Docker containers (e.g. Marathon, Kubernetes). Configuration values are provided using environment variables.
Although dev
and test
leiningen profiles use EDN based configuration files, the values in them are not used in an operational environment.
This application's primary purpose is providing Landsat raster data via HTTP. It provides three resources: chips, chip-specs, and sources.
Resources are represented as either JSON or HTML. You can use a variety of HTTP tools and libraries to retrieve data. JSON is provided by default when no Accept header is present. Set the Accept
header to application/json
or text/html
for JSON and HTML respectively. Be aware that most tools automatically set this header, if you're not receiving the expected format, consult its documentation.
Much like the way an operating system retrieves memory in pages, this application retrieves raster imagery as chips, a stack of spatially and temporally coherent data.
http http://localhost:5678/chips
?x=-2013585
&y=3095805
&acquired=2000-01-01/2017-01-01
&ubid=LANDSAT_8/OLI_TIRS/sr_band1
&ubid=LANDSAT_8/OLI_TIRS/sr_band2
&ubid=LANDSAT_8/OLI_TIRS/sr_band3
Chip-Specs describe the geometry and data-type for chips. You can get all available chip-specs...
http http://localhost:5678/chip-specs
...or you can get a single chip-spec...
http http://localhost:5678/chip-specs/LANDSAT_5/TM/sr_band1
...or you can use ElasticSearch QueryStringSyntax to get a subset of available chip-specs. By default, Elasticsearch applies the query against all indexed fields. Individual fields may also be searched directly by prepending the query with the field name plus colon. For example, ?q=ubid:landsat_7 AND etm AND sr_band1
Please note: UBIDs contain a forward-slash "/" and cannot be supplied as a ?q parameter; Elasticsearch syntax interprets this character as a regular expression, so they must be escaped.
http http://localhost:5678/chip-specs?q=((landsat AND 8) AND NOT sr AND (band1 OR band2 OR band3))
Sources provide information about where information was obtained. Each chip has a source-id
that can be used to determine what file was ingested and which bands were chipped. A random sample of ten sources can be retrieved like this:
http http://localhost:5678/sources
A specific source can be retrieved like this:
http http://localhost:5678/source/LT050460261984185-SC20161231013600