2.7 KiB
2.7 KiB
| read_when | ||
|---|---|---|
|
API Overview
packages/protocol/openapi.yaml is the API contract source of truth. Server
handlers live in apps/api/internal/httpapi; the TypeScript SDK in
packages/sdk-ts is the typed client.
Auth
The server resolves callers in this order (see ../features/auth.md):
Authorization: Bearer <token>(session token, magic-link result).cc_sessioncookie.X-ClickClack-User: usr_...header (local/dev impersonation for tests).- Dev fallback to the first user in the DB (disable in production via
--dev-bootstrap=false).
Endpoint groups
| Group | Endpoints | Doc |
|---|---|---|
| Auth | /api/auth/magic/{request,consume}, /api/auth/github/{start,callback} |
auth |
| Profile | /api/me |
profiles |
| Workspaces | /api/workspaces, /api/workspaces/{id} |
workspaces |
| Channels | /api/workspaces/{id}/channels, /api/channels/{id} |
workspaces |
| Messages | /api/channels/{id}/messages, /api/messages/{id} |
messages |
| Threads | /api/messages/{id}/thread, /api/messages/{id}/thread/replies |
threads |
| Replies | quoted_message_id on any message-create endpoint |
replies |
| Reactions | /api/messages/{id}/reactions |
reactions |
| Realtime | /api/realtime/{ws,events,ephemeral} |
realtime |
| Search | /api/search |
search |
| Uploads | /api/uploads, /api/messages/{id}/attachments |
uploads |
| DMs | /api/dms, /api/dms/{id}/messages |
dms |
| Integrations | /api/hooks/mattermost/{channel}, /api/hooks/slash/{channel} |
integrations |
Conventions
- All payloads are JSON unless explicitly multipart (uploads) or form-encoded (slash commands).
- Mutating endpoints return both the affected resource and the durable event
emitted (
{message, event}), so clients can reconcile optimistically. - Pagination on listings uses cursor-style sequence numbers (
after_seqfor channel/DM messages,after_cursorfor events). - Errors come back as
{ "error": "<message>" }with an HTTP status code.
SDK
TypeScript consumers should use @clickclack/sdk-ts. It depends on neither
Svelte nor any HTTP framework. See ../sdk.md.