feat: convert 52 API endpoints from POST to GET for edge caching (#468)

* feat: convert 52 API endpoints from POST to GET for edge caching

Convert all cacheable sebuf RPC endpoints to HTTP GET with query/path
parameters, enabling CDN edge caching to reduce costs. Flatten nested
request types (TimeRange, PaginationRequest, BoundingBox) into scalar
query params. Add path params for resource lookups (GetFredSeries,
GetHumanitarianSummary, GetCountryStockIndex, GetCountryIntelBrief,
GetAircraftDetails). Rewrite router with hybrid static/dynamic matching
for path param support.

Kept as POST: SummarizeArticle, ClassifyEvent, RecordBaselineSnapshot,
GetAircraftDetailsBatch, RegisterInterest.

Generated with sebuf v0.9.0 (protoc-gen-ts-client, protoc-gen-ts-server).

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>

* fix: add rate_limited field to market response protos

The rateLimited field was hand-patched into generated files on main but
never declared in the proto definitions. Regenerating wiped it out,
breaking the build. Now properly defined in both ListEtfFlowsResponse
and ListMarketQuotesResponse protos.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>

* chore: remove accidentally committed .planning files

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>

---------

Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
Sebastien Melki
2026-02-27 17:44:40 +02:00
committed by GitHub
parent 5f908c0929
commit 6669d373cf
169 changed files with 3806 additions and 1860 deletions

View File

@@ -4,18 +4,46 @@ info:
version: 1.0.0
paths:
/api/conflict/v1/list-acled-events:
post:
get:
tags:
- ConflictService
summary: ListAcledEvents
description: ListAcledEvents retrieves armed conflict events from the ACLED dataset.
operationId: ListAcledEvents
requestBody:
content:
application/json:
schema:
$ref: '#/components/schemas/ListAcledEventsRequest'
required: true
parameters:
- name: start
in: query
description: Start of time range (inclusive), Unix epoch milliseconds.
required: false
schema:
type: string
format: int64
- name: end
in: query
description: End of time range (inclusive), Unix epoch milliseconds.
required: false
schema:
type: string
format: int64
- name: page_size
in: query
description: Maximum items per page (1-100).
required: false
schema:
type: integer
format: int32
- name: cursor
in: query
description: Cursor for next page.
required: false
schema:
type: string
- name: country
in: query
description: Optional country filter (ISO 3166-1 alpha-2).
required: false
schema:
type: string
responses:
"200":
description: Successful response
@@ -36,18 +64,46 @@ paths:
schema:
$ref: '#/components/schemas/Error'
/api/conflict/v1/list-ucdp-events:
post:
get:
tags:
- ConflictService
summary: ListUcdpEvents
description: ListUcdpEvents retrieves georeferenced violence events from the UCDP dataset.
operationId: ListUcdpEvents
requestBody:
content:
application/json:
schema:
$ref: '#/components/schemas/ListUcdpEventsRequest'
required: true
parameters:
- name: start
in: query
description: Start of time range (inclusive), Unix epoch milliseconds.
required: false
schema:
type: string
format: int64
- name: end
in: query
description: End of time range (inclusive), Unix epoch milliseconds.
required: false
schema:
type: string
format: int64
- name: page_size
in: query
description: Maximum items per page (1-100).
required: false
schema:
type: integer
format: int32
- name: cursor
in: query
description: Cursor for next page.
required: false
schema:
type: string
- name: country
in: query
description: Optional country filter (ISO 3166-1 alpha-2).
required: false
schema:
type: string
responses:
"200":
description: Successful response
@@ -67,19 +123,22 @@ paths:
application/json:
schema:
$ref: '#/components/schemas/Error'
/api/conflict/v1/get-humanitarian-summary:
post:
/api/conflict/v1/get-humanitarian-summary/{country_code}:
get:
tags:
- ConflictService
summary: GetHumanitarianSummary
description: GetHumanitarianSummary retrieves a humanitarian overview for a country from HAPI/HDX.
operationId: GetHumanitarianSummary
requestBody:
content:
application/json:
schema:
$ref: '#/components/schemas/GetHumanitarianSummaryRequest'
required: true
parameters:
- name: country_code
in: path
description: |-
ISO 3166-1 alpha-2 country code (e.g., "YE", "SD", "SO").
This is a path parameter — no query annotation needed.
required: true
schema:
type: string
responses:
"200":
description: Successful response
@@ -135,41 +194,25 @@ components:
ListAcledEventsRequest:
type: object
properties:
timeRange:
$ref: '#/components/schemas/TimeRange'
pagination:
$ref: '#/components/schemas/PaginationRequest'
start:
type: integer
format: int64
description: 'Start of time range (inclusive), Unix epoch milliseconds.. Warning: Values > 2^53 may lose precision in JavaScript'
end:
type: integer
format: int64
description: 'End of time range (inclusive), Unix epoch milliseconds.. Warning: Values > 2^53 may lose precision in JavaScript'
pageSize:
type: integer
format: int32
description: Maximum items per page (1-100).
cursor:
type: string
description: Cursor for next page.
country:
type: string
description: Optional country filter (ISO 3166-1 alpha-2).
description: ListAcledEventsRequest specifies filters for retrieving ACLED conflict events.
TimeRange:
type: object
properties:
start:
type: integer
format: int64
description: 'Start of the time range (inclusive), as Unix epoch milliseconds.. Warning: Values > 2^53 may lose precision in JavaScript'
end:
type: integer
format: int64
description: 'End of the time range (inclusive), as Unix epoch milliseconds.. Warning: Values > 2^53 may lose precision in JavaScript'
description: |-
TimeRange represents a time interval defined by a start and end timestamp.
Used for filtering data within a specific time period.
PaginationRequest:
type: object
properties:
pageSize:
type: integer
maximum: 100
minimum: 1
format: int32
description: Maximum number of items to return per page (1 to 100).
cursor:
type: string
description: Opaque cursor for fetching the next page. Empty string for the first page.
description: PaginationRequest specifies cursor-based pagination parameters for list endpoints.
ListAcledEventsResponse:
type: object
properties:
@@ -247,10 +290,21 @@ components:
ListUcdpEventsRequest:
type: object
properties:
timeRange:
$ref: '#/components/schemas/TimeRange'
pagination:
$ref: '#/components/schemas/PaginationRequest'
start:
type: integer
format: int64
description: 'Start of time range (inclusive), Unix epoch milliseconds.. Warning: Values > 2^53 may lose precision in JavaScript'
end:
type: integer
format: int64
description: 'End of time range (inclusive), Unix epoch milliseconds.. Warning: Values > 2^53 may lose precision in JavaScript'
pageSize:
type: integer
format: int32
description: Maximum items per page (1-100).
cursor:
type: string
description: Cursor for next page.
country:
type: string
description: Optional country filter (ISO 3166-1 alpha-2).
@@ -325,7 +379,9 @@ components:
countryCode:
type: string
pattern: ^[A-Z]{2}$
description: ISO 3166-1 alpha-2 country code (e.g., "YE", "SD", "SO").
description: |-
ISO 3166-1 alpha-2 country code (e.g., "YE", "SD", "SO").
This is a path parameter — no query annotation needed.
required:
- countryCode
description: GetHumanitarianSummaryRequest specifies which country to retrieve the humanitarian summary for.