Catwalk - AI Provider Database
Build/Test Commands
go run .- Build and run the main HTTP server on :8080go run ./cmd/{provider-name}- Build and run a CLI to update the{provider-name}.jsonfilego test ./...- Run all tests
Code Style Guidelines
- Package comments: Start with "Package name provides/represents..."
- Imports: Standard library first, then third-party, then local packages
- Error handling: Use
fmt.Errorf("message: %w", err)for wrapping - Struct tags: Use json tags with omitempty for optional fields
- Constants: Group related constants with descriptive comments
- Types: Use custom types for IDs (e.g.,
InferenceProvider,Type) - Naming: Use camelCase for unexported, PascalCase for exported
- Comments: Use
//nolint:directivefor linter exceptions - HTTP: Always set timeouts, use context, defer close response bodies
- JSON: Use
json.MarshalIndentfor pretty output, validate unmarshaling - File permissions: Use 0o600 for sensitive config files
Adding more provider commands
- Create the
./cmd/{provider-name}/main.gofile - Try to use the provider API to figure out the available models. If there's no
endpoint for listing the models, look for some sort of structured text format
(usually in the docs). If none of that exist, refuse to create the command,
and add it to the
MANUAL_UPDATES.mdfile. - Add it to
.github/workflows/update.yml
Updating providers manually
Zai
For zai, we'll need to grab the model list and capabilities from https://docs.z.ai/guides/overview/overview.
That page does not contain the exact context_window and default_max_tokens though. We can grab the exact value from ./internal/providers/configs/openrouter.json.