Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Unified "API v3" design across functional areas #115

Open
davenquinn opened this issue Jul 25, 2024 · 1 comment
Open

Unified "API v3" design across functional areas #115

davenquinn opened this issue Jul 25, 2024 · 1 comment
Assignees
Labels

Comments

@davenquinn
Copy link
Member

davenquinn commented Jul 25, 2024

With design-focused updates like #120 and #117, and the evolution of our API v3 systems in other areas (e.g., a PostgREST API system) we should start a conversation on how to unify and carry forward Macrostrat's API v3 for future functionality. A few elements that we should establish:

  • Delineation what should be handled by PostgREST vs. Python-based API code (e.g., prefer basic table access/paginated results via PostgREST and geological filtering more akin to API v1/2 via Python)
  • Patterns of separation between domains of functionality (e.g., paleogeography, column editing, map ingestion, etc.)
  • Consistent handling of authentication cookies/tokens
  • Caching of results for highly-used queries (e.g., Redis/Varnish)
  • Unified documentation across both API systems (and tileserver?)
  • Request logging for certain routes (establish data on usage, related to Analytics #67)
  • Some affordance for "internal" routes that are not publicly documented/stabilized
@davenquinn
Copy link
Member Author

davenquinn commented Jul 25, 2024

Output of our first conversation with @CannonLock, @amyfromandi, and @brianaydemir:

Handling different API patterns

We want the API to avoid "reinventing the wheel" while allowing flexibility

  • We will prefer PostgREST for table operations, filtering, and basic CRUD routes where possible
  • We will use Python and this repository for routes requiring custom logic (e.g., filesystem, security/tokens, filtering via complex geological criteria).
  • Other services and containers can be maintained where usage patterns and infrastructure needs are different (e.g., tileserver, ml-based extensions)

We should develop libraries and well-documented patterns for API secrets, token/API key handling, etc. that can be pulled in via libraries.

  • The current capabilities of Macrostrat's v2 API depend on a lot of semantic filtering via geologic criteria, so they will eventually mostly be brought into the api-v3 framework.
  • Some functional areas might require several 'simple' routes that can be implemented as PostgREST views and a few more complex ones that require separate handling (e.g., validation routes). We hope to allow multiple approaches to be used simultaneously.

Documentation and public-facing capabilites

Despite being composed of a handful of separate services with different API query styles, the goal will be to present Macrostrat's API as a unified /api/v3 cluster of routes.

API docs will prioritize OpenAPI/Swagger since it is autogenerated by many tools. We will explore patterns to merge documentation between services and separate it between functional areas.

Open questions

  • Caching: redis, varnish, etc. ? How to mark routes for caching and expire things when appropriate? Needs are different between tileserver, columns, etc. Don't want to get bogged down in cache management
  • Best way to do overarching documentation
  • Should internal/pre-production APIs (e.g., proxy servers etc.) be placed under a single umbrella somehow? It would be nice to have a dev2.macrostrat.org/api/v3/_private gateway that would automatically apply some security, etc.

@davenquinn davenquinn transferred this issue from UW-Macrostrat/api-v3 Jan 7, 2025
@davenquinn davenquinn added the api label Jan 7, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

3 participants