A powerful Python-based API wrapper and command-line interface for interacting with xAI's Grok language models. This toolkit provides seamless integration with xAI's Grok language models for chat, text completion, and vision analysis capabilities.
- 🤖 Interactive chat sessions with Grok by xAI language models
- 📝 Single-shot text completion
- 👁️ Vision analysis with support for local images and URLs
- ⚡ Real-time streaming responses
- 🎯 Configurable model parameters
- 🔄 Conversation history management
- 📤 File upload handling for images
- ⚙️ Extensive parameter validation
- 🎨 Beautiful loading animations
- Installation
- API Key Configuration
- Usage
- Special Commands
- Advanced Configuration
- Supported Models
- Error Handling and Safety
- Supported File Types
- Caching and Cleanup
- Contributing
- Issues and Support
- Feature Requests
- Versioning and Changelog
- Security
- License
-
Clone the repository:
git clone https://github.com/RMNCLDYO/grok-ai-toolkit.git
-
Navigate to the repository folder:
cd grok-ai-toolkit
-
Install the required dependencies:
pip install -r requirements.txt
-
Obtain an API key from xAI.
-
You have three options for managing your API key:
Click here to view the API key configuration options
-
Setting it as an environment variable on your device (recommended for everyday use)
- Navigate to your terminal.
- Add your API key like so:
export GROK_API_KEY=your_api_key
This method allows the API key to be loaded automatically when using the wrapper or CLI.
-
Using an .env file (recommended for development):
- Install python-dotenv if you haven't already:
pip install python-dotenv
. - Create a .env file in the project's root directory.
- Add your API key to the .env file like so:
GROK_API_KEY=your_api_key
This method allows the API key to be loaded automatically when using the wrapper or CLI.
- Install python-dotenv if you haven't already:
-
Direct Input:
-
If you prefer not to use a
.env
file, you can directly pass your API key as an argument to the CLI or the wrapper functions.CLI
--api_key "your_api_key"
Wrapper
api_key="your_api_key"
This method requires manually inputting your API key each time you initiate an API call.
-
-
For generating text based on a prompt or a set of instructions.
CLI
python cli.py --text --prompt "Write a story about AI."
Wrapper
from grok import Text
Text().run(prompt="Write a story about AI.")
For interactive conversations with the AI model.
CLI
python cli.py --chat
Wrapper
from grok import Chat
Chat().run()
For processing images alongside text, allowing for visual analysis and multimodal interactions. This mode enables you to upload images (from local paths or URLs) and chat with the AI about their content.
CLI
python cli.py --vision --prompt "What's in this image?" --image_path image.jpg
Wrapper
from grok import Vision
Vision().run(prompt="What's in this image?", image_path="image.jpg")
During interaction with the toolkit, you can use the following special commands:
/exit
or/quit
: End the conversation and exit the program./clear
: Clear the conversation history./upload
: (Vision mode only) Upload an image for analysis.- Usage:
/upload file_path_or_url [optional prompt]
- Example:
/upload image.jpg What do you see in this image?
- Usage:
Description | CLI Flags | CLI Usage | Wrapper Usage |
---|---|---|---|
Chat mode | -c , --chat |
--chat |
See mode usage above. |
Text mode | -t , --text |
--text |
See mode usage above. |
Vision mode | -v , --vision |
--vision |
See mode usage above. |
User prompt | -p , --prompt |
--prompt "Your prompt here" |
prompt="Your prompt here" |
Image path | -ip , --image_path |
--image_path "image.jpg" |
image_path="image.jpg" |
Image URL | -iu , --image_url |
--image_url "https://example.com/image.jpg" |
image_url="https://example.com/image.jpg" |
Enable streaming | -s , --stream |
--stream |
stream=True |
API Key | -ak , --api_key |
--api_key "your_api_key" |
api_key="your_api_key" |
Model name | -m , --model |
--model "model_name" |
model="model_name" |
System prompt | -sp , --system_prompt |
--system_prompt "Set custom instructions" |
system_prompt="Set custom instructions" |
Max tokens | -mt , --max_tokens |
--max_tokens 1024 |
max_tokens=1024 |
Temperature | -tm , --temperature |
--temperature 0.7 |
temperature=0.7 |
Top-p | -tp , --top_p |
--top_p 0.9 |
top_p=0.9 |
Top-k | -tk , --top_k |
--top_k 40 |
top_k=40 |
Frequency penalty | -fp , --frequency_penalty |
--frequency_penalty 0.5 |
frequency_penalty=0.5 |
Presence penalty | -pp , --presence_penalty |
--presence_penalty 0.5 |
presence_penalty=0.5 |
Number of completions | -n |
--n 1 |
n=1 |
Stop sequences | -stop , --stop_sequences |
--stop_sequences [".", "\n"] |
stop=[".", "\n"] |
Model | Inputs |
---|---|
grok-beta |
Text |
grok-2v-mini |
Text, images |
Warning
The grok-2v-mini
model is currently not available to most users.
Note
The availability of specific models may be subject to change. Always refer to xAI's official documentation for the most up-to-date information on model availability and capabilities.
The Grok AI Toolkit includes robust error handling to help you diagnose and resolve issues quickly. Here are some common error codes and their solutions:
HTTP Code | Status | Description | Solution |
---|---|---|---|
400 | Bad Request | Malformed request or invalid parameters | Check request format and parameters |
401 | Unauthorized | Invalid or missing API key | Verify your API key |
403 | Forbidden | Insufficient permissions | Check API key permissions |
404 | Not Found | Resource not found | Verify endpoint and model availability |
429 | Too Many Requests | Rate limit exceeded | Reduce request frequency |
500 | Internal Server Error | Server-side error | Retry after a short wait |
503 | Service Unavailable | Service temporarily down | Retry after a short wait |
The Grok AI Toolkit supports the following image formats for vision processing:
Category | File Extensions |
---|---|
Images | jpg , jpeg , png , gif , webp , bmp |
Note
Maximum file size limit is 20MB per image.
The Grok AI Toolkit implements a caching mechanism for uploaded images to improve performance and reduce unnecessary network requests:
- When an image is uploaded from a URL, it's stored in a temporary cache folder (
.grok_ai_toolkit_cache
). - The cache is automatically cleaned up at the end of each session.
- Cached files are managed efficiently to prevent storage bloat.
The caching system is automated and requires no manual management.
Contributions are welcome!
Please refer to CONTRIBUTING.md for detailed guidelines on how to contribute to this project.
Encountered a bug? We'd love to hear about it. Please follow these steps to report any issues:
- Check if the issue has already been reported.
- Use the Bug Report template to create a detailed report.
- Submit the report here.
Your report will help us make the project better for everyone.
Got an idea for a new feature? Feel free to suggest it. Here's how:
- Check if the feature has already been suggested or implemented.
- Use the Feature Request template to create a detailed request.
- Submit the request here.
Your suggestions for improvements are always welcome.
Stay up-to-date with the latest changes and improvements in each version:
- CHANGELOG.md provides detailed descriptions of each release.
Your security is important to us. If you discover a security vulnerability, please follow our responsible disclosure guidelines found in SECURITY.md. Please refrain from disclosing any vulnerabilities publicly until said vulnerability has been reported and addressed.
Licensed under the MIT License. See LICENSE for details.