You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1.5 KiB

+++ title = "Implement GET /api/quotes/:id — fetch by NanoID, return 404 if not found" priority = 5 status = "todo" ticket_type = "task" dependencies = ["f3dc74", "a5049d", "d792e2", "175382"] +++

The `quotesdb` API is built with Axum + Tokio, targeting Cloudflare Workers via `workers-rs`. It serves JSON at `/api/*` endpoints and persists data to Cloudflare D1 (production) or a local SQLite file via Turso (development). Source lives in `src/bin/api/`.

Shared types and utilities are in src/lib.rs — code placed there must compile for both the host target and wasm32-unknown-unknown.

GET /api/quotes/:id returns a single quote by its NanoID. Returns 404 if no quote with that ID exists.

Implement the `GET /api/quotes/:id` handler that looks up a quote by NanoID, fetches its tags, and returns the full quote JSON. Return 404 if the ID is not found. - Extract the `:id` path parameter using Axum's `Path` extractor. - Include the quote's tags in the response. - Return `404 Not Found` with `{"error": "not found"}` if the ID doesn't match any row. Use `superpowers:test-driven-development` — write tests for: 200 with quote object, 404 not found. Use `superpowers:verification-before-completion` before closing. Run in order from the `quotesdb/` directory:
cargo fmt
cargo check
cargo clippy
cargo test
`feat(quotesdb): implement GET /api/quotes/:id`