grok_api
A Rust client library for the Grok AI API (xAI). Simple, robust, and production-ready.
Features
- 🚀 Easy to use — Simple async API with builder pattern
- 🔄 Automatic retries — Built-in retry logic for transient failures
- 🛡️ Robust error handling — Comprehensive error types with detailed messages
- 🌐 Network resilient — Optimised for challenging conditions (Starlink, satellite connections)
- 🔧 Flexible configuration — Customise timeouts, retries, and more
- 🛠️ Tool / Function calling — Full support for function calling and agentic workflows
- 🧠 Reasoning-aware — Capability helpers guard against sending unsupported params to reasoning models
- 📦 Rust 2024 edition — Built on the latest edition with MSRV 1.85
Quick Start
Add this to your Cargo.toml:
[]
= "0.1"
= { = "1", = ["full"] }
Simple Example
use ;
async
Conversation with History
use ;
async
Advanced Configuration
use ;
async
API Key
Get your API key from x.ai/api.
Set it as an environment variable:
Or pass it directly to the client:
let client = new?;
Available Models
Last synced with xAI API — April 2026 Call
GET https://api.x.ai/v1/modelswith your key to see your account's live list.
🏆 Grok 4.20 — Flagship (2 M token context)
| API string | Model variant |
Best for |
|---|---|---|
grok-4.20-0309-reasoning |
Model::Grok4_20_0309Reasoning |
Complex reasoning, maths, science, multi-step agentic tasks |
grok-4.20-0309-non-reasoning |
Model::Grok4_20_0309NonReasoning |
General tasks, high-throughput, lower latency |
grok-4.20-multi-agent-0309 |
Model::Grok4_20MultiAgent0309 |
Deep research, complex workflows, multi-agent pipelines |
Note: Grok 4.20 reasoning models do not support
presence_penalty,frequency_penalty,stop, orreasoning_effort. Sending these fields returns an API error.logprobsis silently ignored by all Grok 4.20 models.
⚡ Grok 4.1 Fast (2 M token context)
| API string | Model variant |
Best for |
|---|---|---|
grok-4-1-fast-reasoning |
Model::Grok4_1FastReasoning |
Recommended default — great balance of speed, cost, and reasoning |
grok-4-1-fast-non-reasoning |
Model::Grok4_1FastNonReasoning |
Fast standard completions, high volume |
🧑💻 Code-Optimised
| API string | Model variant |
Best for |
|---|---|---|
grok-code-fast-1 |
Model::GrokCodeFast1 |
Code generation, debugging, file editing, agentic coding |
📦 Grok 4 Previous Flagship
| API string | Model variant |
Notes |
|---|---|---|
grok-4-0709 |
Model::Grok4_0709 |
Still active; reasoning-only model |
🗄️ Legacy (Grok 3)
| API string | Model variant |
Notes |
|---|---|---|
grok-3 |
Model::Grok3 |
Previous flagship; 131 K context |
grok-3-mini |
Model::Grok3Mini |
Efficient smaller model; 131 K context |
🖼️ Image Generation
| API string | Model variant |
Notes |
|---|---|---|
grok-imagine-image-pro |
Model::GrokImagineImagePro |
High-quality image generation |
grok-imagine-image |
Model::GrokImagineImage |
Standard image generation |
🎬 Video Generation
| API string | Model variant |
Notes |
|---|---|---|
grok-imagine-video |
Model::GrokImagineVideo |
Video generation |
Recommended models at a glance
| Use case | Recommended model |
|---|---|
| Everyday / CLI default | grok-4-1-fast-reasoning |
| Heavy coding tasks | grok-code-fast-1 |
| Maximum intelligence | grok-4.20-0309-reasoning |
| Speed + high volume | grok-4.20-0309-non-reasoning |
| Agentic / multi-step | grok-4.20-multi-agent-0309 |
| Image generation | grok-imagine-image-pro |
Using the Model enum
use Model;
// Type-safe — no typos
let model = Grok4_1FastReasoning;
println!; // "grok-4-1-fast-reasoning"
// Guard reasoning models against unsupported params
if model.is_reasoning_model
// Check context window
if let Some = model.context_window
// Check capabilities
println!;
println!;
println!;
println!;
// Parse from a string (e.g. from config / env var)
let m = parse.expect;
// All active models
for m in all
Error Handling
use ;
match client.chat.await
Retry Logic
Network errors are automatically retried with exponential backoff:
let client = builder
.api_key
.max_retries // retry up to 5 times
.build?;
Retryable errors include:
- Network timeouts
- Connection failures
- Server errors (5xx)
- Starlink / satellite network drops
Function Calling / Tools
Full support for Grok's function calling and agentic tool use:
use ;
use json;
let tools = vec!;
let messages = vec!;
let response = client
.chat_with_history
.model
.tools
.send
.await?;
if response.has_tool_calls
Starlink Optimisation
The library includes special handling for Starlink and other satellite connections:
- Automatic detection of connection drops
- Exponential backoff with jitter
- Extended timeout handling
use ;
let client = builder
.api_key
.timeout_secs // longer timeout for satellite latency
.max_retries // more retries for intermittent drops
.build?;
match client.chat.await
Examples
# Set your API key
# Simple single-turn chat
# Multi-turn conversation
# Streaming responses
# Function / tool calling
# Video / multimodal
Cargo Features
| Feature | Default | Description |
|---|---|---|
retry |
✅ yes | Automatic retry with exponential backoff |
starlink |
❌ no | Extra optimisations for satellite connections |
[]
= { = "0.1", = ["starlink"] }
Testing
# Unit + doc tests (no API key needed)
# With debug logging
RUST_LOG=debug
# Clippy
Minimum Supported Rust Version (MSRV)
This crate requires Rust 1.85 or later (Rust 2024 edition).
Update your toolchain with:
Documentation
Full API documentation is available at docs.rs/grok_api.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add some amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
License
This project is licensed under either of:
- Apache License, Version 2.0 (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT License (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Disclaimer
This is an unofficial library and is not affiliated with, endorsed by, or sponsored by xAI or X Corp.
Links
Changelog
See CHANGELOG.md for full release notes and version history.
Support
For bugs and feature requests, please open an issue.
Made with ❤️ and Rust — John McConnell