Skip to content

Commit

Permalink
Merge pull request #149 from developmentseed/docs/edit-services
Browse files Browse the repository at this point in the history
Review and edit services.md
  • Loading branch information
vincentsarago authored Oct 25, 2023
2 parents 0ec5edd + 12a00d7 commit adcb499
Show file tree
Hide file tree
Showing 9 changed files with 273 additions and 113 deletions.
18 changes: 15 additions & 3 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
# Development - Contributing

Issues and pull requests are more than welcome: https://github.com/developmentseed/eoAPI/issues

You can also start **Discussions** in https://github.com/developmentseed/eoAPI/discussions

**dev install**

```bash
Expand All @@ -19,7 +19,9 @@ python -m pip install "psycopg[binary,pool]"
python -m pip install -e runtime/eoapi/raster["test"] # or -e runtime/eoapi/stac["test"] | -e runtime/eoapi/vector["test"]
```

Note: services might have incompatible dependencies which you can resolve by using virtual environnement per service
!!! danger

Python applications might have incompatible dependencies which you can resolve by using virtual environment *per application*

**pre-commit**

Expand All @@ -28,3 +30,13 @@ This repo is set to use `pre-commit` to run *isort*, *ruff*, *pydocstring*, *bla
```bash
$ pre-commit install
```

### Open Source

You can also contribute indirectly to eoAPI by helping on the sub-modules:

- **PgSTAC** database https://github.com/stac-utils/pgstac
- **stac-fastapi**: https://github.com/stac-utils/stac-fastapi
- **titiler-pgstac**: https://github.com/stac-utils/titiler-pgstac
- **TiTiler**: https://github.com/developmentseed/titiler
- **TiPg**: https://github.com/developmentseed/tipg
40 changes: 25 additions & 15 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@

<p align="center">
<img width="700" src="docs/logos/eoAPI.png"/>
<p align="center">Create a full Earth Observation API with Metadata, Raster and Vector services.</p>
<p align="center">Create a full Earth Observation API with Metadata, Raster, and Vector services.</p>
</p>

<p align="center">
Expand All @@ -23,7 +22,7 @@

## **E**arth **O**bservation **API**

`eoAPI` combines several *state-of-the-art* projects to create a full Earth Observation API. Each service can be used and deployed independently but `eoAPI` creates the interconnections between each service:
`eoAPI` combines several *state-of-the-art* projects to create a full Earth Observation API. Each service can be used and deployed independently, but `eoAPI` creates the interconnections between each service:

- **pgSTAC** database [https://github.com/stac-utils/pgstac](https://github.com/stac-utils/pgstac)

Expand All @@ -37,18 +36,29 @@

## 🌍 eoAPI: An Open-Source Community Project

`eoAPI` is proudly open-source and driven by a dedicated community of contributors. We believe in the power of open collaboration and welcome anyone to contribute, discuss, and grow this tool with us. Join the conversations on [GitHub Discussions](https://github.com/developmentseed/eoAPI/discussions) and make a difference in the Earth Observation realm.
`eoAPI` is proudly open-source and driven by a dedicated community of contributors. We believe in the power of open collaboration and welcome anyone to contribute, discuss, and grow this tool. Join the conversations on [GitHub Discussions](https://github.com/developmentseed/eoAPI/discussions) and make a difference in the Earth Observation realm.


---

## Getting started

- Clone the repository: `git clone https://github.com/developmentseed/eoAPI.git`
- Navigate to the project: `cd eoAPI`
- Run services with `docker compose up`
- Follow the [MAXAR open data demo](https://github.com/vincentsarago/MAXAR_opendata_to_pgstac) (or get inspired by the other [demos](./demo/)) to load some data into eoAPI
- Check out the [Search Viewer](http://localhost:8081/index.html), and the API documentation ([STAC Metadata](http://localhost:8081/docs), [Raster Tiles](http://localhost:8082/docs), [Vector Tiles](http://localhost:8083/api.html))
The easiest way to start exploring the different eoAPI services is with *Docker*. Clone this repository and start the multi-container *Docker* applications using `Compose`:

```
git clone https://github.com/developmentseed/eoAPI.git
cd eoAPI
docker compose up
```

Once the applications are *up*, you'll need to add STAC **Collections** and **Items** to the PgSTAC database. If you don't have, you can use the follow the [MAXAR open data demo](https://github.com/vincentsarago/MAXAR_opendata_to_pgstac) (or get inspired by the other [demos](https://github.com/developmentseed/eoAPI/tree/main/demo)).

Then you can start exploring your dataset with:

- the STAC Metadata service [http://localhost:8081](http://localhost:8081)
- the Raster service [http://localhost:8082](http://localhost:8082)

If you've added a vector dataset to the `public` schema in the Postgres database, they will be available through the **Vector** service at [http://localhost:8083](http://localhost:8083).

Alternatively, you may launch the application locally:
```bash
Expand All @@ -57,22 +67,22 @@ virtualenv .venv
source .venv/bin/activate

python -m pip install "psycopg[binary,pool]" uvicorn
python -m pip install runtime/eoapi/{SERVICE} # SERVICE should be one of `raster, vector, stac`
python -m pip install runtime/eoapi/{SERVICE} # SERVICE should be one of `raster, vector, stac.`

export DATABASE_URL=postgresql://username:password@0.0.0.0:5439/postgis # Connect to the database of your choice

.venv/bin/uvicorn eoapi.{SERVICE}.app:app --port 8000 --reload
```

Note: services might have incompatible dependencies which you can resolve by using a virtual environment for each service
Note: services might have incompatible dependencies, which you can resolve by using a virtual environment for each service

---

## Deployment

This repository has current runtimes that are consistently updated with new functionality.
This repository has current runtimes that are consistently updated with new functionality.

The services can be deployed locally via docker with `docker-compose up`. The official runtimes can be launched with `docker-compose -f docker-compose.yml -f docker-compose.official.yml up stac-fastapi titiler-pgstac tipg`.
The services can be deployed locally via docker with `docker-compose up`. The official runtimes can be launched with `docker compose -f docker-compose.official.yml up stac-fastapi titiler-pgstac tipg`.

Two Infrastructure as Code (IaC) repositories are available:
- [eoapi-cdk](https://github.com/developmentseed/eoapi-cdk): A set of AWS CDK constructs to deploy eoAPI services
Expand All @@ -82,7 +92,7 @@ Finally, [eoapi-template](https://github.com/developmentseed/eoapi-template) is

## Contribution & Development

We highly value and rely on our community! Whether you're an expert or just getting started, you can make a difference. Here's how:
We highly value and rely on our community! You can make a difference whether you're an expert or just getting started. Here's how:

- **Contribute**: Check out our [CONTRIBUTING.md](https://github.com/developmentseed/eoAPI/blob/main/CONTRIBUTING.md) guide to understand how you can contribute.
- **Engage in Discussions**: Share your ideas, ask questions, or provide feedback through [GitHub Discussions](https://github.com/developmentseed/eoAPI/discussions). This is where most of our project conversations take place.
Expand All @@ -103,4 +113,4 @@ See [contributors](https://github.com/developmentseed/eoAPI/graphs/contributors)

## Changes

See [CHANGES.md](https://github.com/developmentseed/eoAPI/blob/main/CHANGES.md).
See [CHANGES.md](https://github.com/developmentseed/eoAPI/blob/main/CHANGES.md).
10 changes: 6 additions & 4 deletions docker-compose.official.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,9 @@ version: '3'

services:
stac-fastapi:
# Note:
# the official ghcr.io/stac-utils/stac-fastapi-pgstac image uses python 3.8 and uvicorn
# which is why here we use a custom Dockerfile using python 3.11 and gunicorn
build:
context: .
dockerfile: dockerfiles/Dockerfile.stac
Expand Down Expand Up @@ -40,7 +43,7 @@ services:
# At the time of writing, rasterio and psycopg wheels are not available for arm64 arch
# so we force the image to be built with linux/amd64
platform: linux/amd64
image: ghcr.io/stac-utils/titiler-pgstac:latest
image: ghcr.io/stac-utils/titiler-pgstac:0.8.0
ports:
- "${MY_DOCKER_IP:-127.0.0.1}:8082:8082"
environment:
Expand Down Expand Up @@ -86,7 +89,7 @@ services:
- ./dockerfiles/scripts:/tmp/scripts

tipg:
image: ghcr.io/developmentseed/tipg:latest
image: ghcr.io/developmentseed/tipg:0.4.4
ports:
- "${MY_DOCKER_IP:-127.0.0.1}:8083:8083"
environment:
Expand Down Expand Up @@ -115,8 +118,7 @@ services:
- ./dockerfiles/scripts:/tmp/scripts

database:
container_name: eoapi.db
image: ghcr.io/stac-utils/pgstac:v0.7.10
image: ghcr.io/stac-utils/pgstac:v0.8.1
environment:
- POSTGRES_USER=username
- POSTGRES_PASSWORD=password
Expand Down
24 changes: 14 additions & 10 deletions docs/mkdocs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,12 +19,14 @@ extra:
link: "https://developmentseed.org/blog"

nav:
- Home: "index.md"
- Intro: "intro.md"
- Services: "services.md"
- Deployment: "deployment.md"
- Contributing: "contributing.md"

- Home: index.md
- Getting started:
- intro.md
- Services: services.md
- Contributing: contributing.md
- Advanced User Guide:
- Customization: customization.md
- Deployment: deployment.md

plugins:
- search
Expand All @@ -36,17 +38,17 @@ theme:
palette:
primary: custom
accent: deep orange

features:
- navigation.tabs
- navigation.tabs.sticky
- navigation.instant
- navigation.tracking
- navigation.top
- navigation.expand
- navigation.footer
- navigation.sections
favicon: img/favicon.ico
logo: img/logo.png


markdown_extensions:
- admonition
- attr_list
Expand All @@ -59,7 +61,6 @@ markdown_extensions:
- pymdownx.caret:
insert: false
- pymdownx.details
- pymdownx.emoji
- pymdownx.escapeall:
hardbreak: true
nbsp: true
Expand All @@ -73,3 +74,6 @@ markdown_extensions:
- pymdownx.tilde
- toc:
permalink: true
- pymdownx.emoji:
emoji_index: !!python/name:material.extensions.emoji.twemoji
emoji_generator: !!python/name:material.extensions.emoji.to_svg
24 changes: 16 additions & 8 deletions docs/src/contributing.md
Original file line number Diff line number Diff line change
@@ -1,11 +1,7 @@
---
hide:
- navigation
- toc
---

Issues and pull requests are more than welcome: https://github.com/developmentseed/eoAPI/issues

You can also start **Discussions** in https://github.com/developmentseed/eoAPI/discussions

**dev install**

```bash
Expand All @@ -18,12 +14,14 @@ python -m pip install --upgrade virtualenv
virtualenv .venv
source .venv/bin/activate

# Install eoapi module
# Install the eoapi module
python -m pip install "psycopg[binary,pool]"
python -m pip install -e runtime/eoapi/raster["test"] # or -e runtime/eoapi/stac["test"] | -e runtime/eoapi/vector["test"]
```

Note: services might have incompatible dependencies which you can resolve by using virtual environnement per service
!!! danger

Python applications might have incompatible dependencies, which you can resolve by using a virtual environment *per application*

**pre-commit**

Expand All @@ -32,3 +30,13 @@ This repo is set to use `pre-commit` to run *isort*, *ruff*, *pydocstring*, *bla
```bash
$ pre-commit install
```

### Open Source

You can also contribute indirectly to eoAPI by helping on the sub-modules:

- **PgSTAC** database https://github.com/stac-utils/pgstac
- **stac-fastapi**: https://github.com/stac-utils/stac-fastapi
- **titiler-pgstac**: https://github.com/stac-utils/titiler-pgstac
- **TiTiler**: https://github.com/developmentseed/titiler
- **TiPg**: https://github.com/developmentseed/tipg
66 changes: 66 additions & 0 deletions docs/src/customization.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
The eoAPI repository (https://github.com/developmentseed/eoAPI) hosts customized versions of each base service. The documentation below demonstrates how each service can be customized. The eoAPI services can work in parallel or in combination with each other.

---
## eoapi.stac

Built on [stac-fastapi.pgstac](https://github.com/stac-utils/stac-fastapi) application, adding a **`TiTilerExtension`** and a simple **`Search Viewer`**.

The service includes:

- Full **stac-fastapi** implementation - see [docs](http://localhost:8081/docs) if using the `docker-compose` configuration.
- Simple STAC Search **viewer** - see [viewer](http://localhost:8081/index.html) if using the `docker-compose` configuration.
- **Proxy** to the tiler endpoint for STAC Items.

When the `TITILER_ENDPOINT` environment variable is set (pointing to the `raster` application), additional endpoints will be added to the stac-fastapi application (see: [stac/extension.py](https://github.com/developmentseed/eoAPI/blob/main/src/eoapi/stac/eoapi/stac/extension.py)):

- `/collections/{collectionId}/items/{itemId}/tilejson.json`: Return the `raster` tilejson for an item
- `/collections/{collectionId}/items/{itemId}/viewer`: Redirect to the `raster` viewer

<p align="center">
<img alt="eoapi.stac OpenAPI documentation"src="https://github.com/developmentseed/eoAPI/assets/10407788/f7fc4e7f-079a-4007-8c4c-74ff9ca7b012">
<img alt="Metadata STAC search viewer" src="https://github.com/developmentseed/eoAPI/assets/10407788/b1fd6aa8-aab9-4d58-9ad4-6e1069ed9473"/>
</p>

Code: [/runtime/eoapi/stac](https://github.com/developmentseed/eoAPI/tree/main/runtime/eoapi/stac)

---
## eoapi.raster

The dynamic tiler deployed within `eoAPI` is built on top of [titiler-pgstac](https://github.com/stac-utils/titiler-pgstac) and [pgstac](https://github.com/stac-utils/pgstac). It enables large-scale mosaic based on the results of STAC search queries.

The service includes all the default endpoints from **titiler-pgstac** application and:

- `/`: a custom landing page with links to the different endpoints

- `/mosaic/builder`: a virtual mosaic builder UI, which helps create and register STAC Search queries

- `/collections`: a *secret* (not in OpenAPI documentation) endpoint used in the mosaic-builder page

- `/collections/{collection_id}/items/{item_id}/viewer`: a simple STAC Item viewer

<p align="center">
<img alt="eoapi.stac OpenAPI documentation" src="https://github.com/developmentseed/eoAPI/assets/10407788/aa08d796-f3b1-4f43-8021-cbddfff95d26">
<img alt="Raster mosaic builder" src="https://github.com/developmentseed/eoAPI/assets/10407788/8f0c96e6-d80a-46ef-a34f-66e59c64a027"/>
<img alt="STAC Item viewer" src="https://github.com/developmentseed/eoAPI/assets/10407788/be86f07e-4b05-4c78-87bf-8738daf1ee20">
</p>


Code: [/runtime/eoapi/raster](https://github.com/developmentseed/eoAPI/tree/main/runtime/eoapi/raster)

---
## eoapi.vector

OGC Features and Tiles API built on top of [tipg](https://github.com/developmentseed/tipg).

By default, the API will look for tables in the `public` schema of the database. We've also added three functions that connect to the pgSTAC schema:

- **pg_temp.pgstac_collections_view**: Simple function which returns PgSTAC Collections
- **pg_temp.pgstac_hash**: Return features for a specific `searchId` (hash)
- **pg_temp.pgstac_hash_count**: Return the number of items per geometry for a specific `searchId` (hash)

<p align="center">
<img alt="eoapi.vector OpenAPI documentation" src="https://github.com/developmentseed/eoAPI/assets/10407788/80ff9659-bc07-4238-a94a-7cab0a2af380">
<img alt="eoapi.vector landing page" src="https://github.com/developmentseed/eoAPI/assets/10407788/b2a8a8d4-d3a1-464a-8b1a-166499ee4abd">
</p>

Code: [/runtime/eoapi/vector](https://github.com/developmentseed/eoAPI/tree/main/runtime/eoapi/vector)
Loading

0 comments on commit adcb499

Please sign in to comment.