Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sat-utils/sat-api
One API to search public satellites metadata on AWS
https://github.com/sat-utils/sat-api
Last synced: 3 months ago
JSON representation
One API to search public satellites metadata on AWS
- Host: GitHub
- URL: https://github.com/sat-utils/sat-api
- Owner: sat-utils
- License: mit
- Created: 2016-04-13T04:19:06.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2020-07-28T23:29:18.000Z (over 4 years ago)
- Last Synced: 2024-09-17T17:58:30.972Z (4 months ago)
- Language: JavaScript
- Homepage: https://sat-api.developmentseed.org/search/stac
- Size: 2.51 MB
- Stars: 177
- Watchers: 16
- Forks: 20
- Open Issues: 24
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-sentinel - **`sat-api`**
- awesome-sentinel - **`sat-api`**
README
# sat-api
[![CircleCI](https://circleci.com/gh/sat-utils/sat-api.svg?style=svg)](https://circleci.com/gh/sat-utils/sat-api)
Sat-api is a STAC compliant web API for searching and serving metadata for geospatial data (including but not limited to satellite imagery).
Development Seed runs an instance of sat-api for the Landsat-8 and Sentinel-2 imagery that is [hosted on AWS](https://aws.amazon.com/earth/). You can access this at https://sat-api.developmentseed.org using the [API documentation](http://sat-utils.github.io/sat-api/) for reference and examples.
The STAC version supported by a given version of sat-api is shown in the table below. Additional information can be found in the [CHANGELOG](CHANGELOG.md)
| sat-api | STAC |
| -------- | ---- |
| 0.1.0 | 0.5.x |
| 0.2.x | 0.6.x |
| 0.3.x | 0.7.x |## Usage
This repository contains just the Node libraries for running the API. The [sat-api-deployment](https://github.com/sat-utils/sat-api-deployment) repository is for deploying sat-api to AWS.
### Environment variables
There are some environment variables used in the code. Some do not have defaults and must be set.
| Name | Description | Default Value |
| ---- | ----------- | ------------- |
| STAC_ID | ID of this catalog | - |
| STAC_TITLE | Title of this catalog | - |
| STAC_DESCRIPTION | Description of this catalog | - |
| STAC_DOCS_URL | URL to documentation | - |
| SATAPI_URL | The root endpoint of this API to use for links | Inferred from request |
| ES_BATCH_SIZE | Number of records to ingest in single batch | 500 |
| SATAPI_ES_PRECISION | Precision to use for geometry queries, see [ES documentation](https://www.elastic.co/guide/en/elasticsearch/reference/current/geo-shape.html) | '5mi' |
| LOG_LEVEL | Level for logging | 'info' |## Development
Sat-api includes a number of NPM packages (in the packages/ directory) that are used to create and populate an instance of sat-api. See the [sat-utils org on NPM](https://www.npmjs.com/org/sat-utils) for the full list of packages. [Lerna](https://github.com/lerna/lerna) is used for for managing these packages.
The latest version released is on the [master branch](https://github.com/sat-utils/sat-api/tree/master), and the latest development version is on the [develop](https://github.com/sat-utils/sat-api/tree/develop) branch.
### Building local version
# Install dependencies in package.json
$ yarn# Run lerna boostrap to link together packages and install those package dependencies
$ yarn bootstrap# Run the build command in each of the packages (runs webpack)
$ yarn build# To continually watch and build source files
$ yarn watch# To run tests for all packages
$ yarn test### Building API docs
# To build API docs from the api spec
$ yarn build-api-docs### Creating a release
To create a new version for npm:
- create a new branch from master
- `$ yarn update`
- Follow the prompt and select the correct the version, then commit the changes.
- Update [CHANGELOG.md](CHANGELOG.md).
- Tag your branch with the same version number
- Make a PR
- When the PR is merged to master, the npm packages are automatically deployed to npm
- In GitHub create a release with the version (prefixed with 'v') and paste in the CHANGELOG section. This will create a GitHub release and a tag.## About
[sat-api](https://github.com/sat-utils/sat-api) was created by [Development Seed]() and is part of a collection of tools called [sat-utils](https://github.com/sat-utils).