Public State
Public state is versioned JSON state scoped by account, project, and environment. It is readable anonymously through the readonly route and readable or writable by developer bearer tokens or project API keys.
Use it for application config, feature flags, settings, announcements, theme values, safe limits, and catalog or inventory data. Do not use it for secrets, private user data, or inventory counts that require reservation-grade consistency.
Most developers should use the SDK, CLI, or console instead of calling these endpoints directly.
Developer Or API-Key Routes
text
GET /v1/{accountId}/projects/{slug}/public-state/{env}
PUT /v1/{accountId}/projects/{slug}/public-state/{env}
PATCH /v1/{accountId}/projects/{slug}/public-state/{env}
GET /v1/{accountId}/projects/{slug}/public-state/{env}/versionsThese routes accept Authorization: Bearer <developer-token> or Authorization: ApiKey <sky_...>.
Anonymous Readonly Route
text
GET /v1/readonly/{accountId}/projects/{slug}/public-state/{env}This route is used by SDK public-state reads. It sets ETag and Cache-Control; development and staging responses use a short cache window, while production responses use a longer one.
Write Semantics
- Public state must be a JSON object.
- Writes require
If-Match. If-Match: "0"is the first-write guard for an empty slot.- Successful writes return
200withversion,state,comment,createdAt, andstateSizeBytes. - Conflicts return
412. PATCHexpects anopsarray of JSON Patch operations and optionalcomment.