Skip to main content

XAI (Grok) provider for Metorial

Project description

metorial-xai

XAI (Grok) provider integration for Metorial - enables using Metorial tools with XAI's Grok models through OpenAI-compatible function calling.

Installation

pip install metorial-xai
# or
uv add metorial-xai
# or
poetry add metorial-xai

Features

  • 🤖 Grok Integration: Full support for Grok models through XAI API
  • 🛠️ Function Calling: OpenAI-compatible function calling support
  • 📡 Session Management: Automatic tool lifecycle handling
  • 🔄 Format Conversion: Converts Metorial tools to OpenAI function format
  • Strict Mode: Built-in strict parameter validation
  • Async Support: Full async/await support

Usage

Basic Usage

import asyncio
from openai import OpenAI
from metorial import Metorial
from metorial_xai import MetorialXAISession

async def main():
    # Initialize clients
    metorial = Metorial(api_key="your-metorial-api-key")
    
    # XAI uses OpenAI-compatible client
    xai_client = OpenAI(
        api_key="your-xai-api-key",
        base_url="https://api.x.ai/v1"
    )
    
    # Create session with your server deployments
    async with metorial.session(["your-server-deployment-id"]) as session:
        # Create XAI-specific wrapper
        xai_session = MetorialXAISession(session.tool_manager)
        
        messages = [
            {"role": "user", "content": "What are the latest commits?"}
        ]
        
        response = xai_client.chat.completions.create(
            model="grok-beta",
            messages=messages,
            tools=xai_session.tools
        )
        
        # Handle tool calls
        tool_calls = response.choices[0].message.tool_calls
        if tool_calls:
            tool_responses = await xai_session.call_tools(tool_calls)
            
            # Add to conversation
            messages.append({
                "role": "assistant",
                "tool_calls": tool_calls
            })
            messages.extend(tool_responses)
            
            # Continue conversation...

asyncio.run(main())

Using Convenience Functions

from metorial_xai import build_xai_tools, call_xai_tools

async def example_with_functions():
    # Get tools in XAI format
    tools = build_xai_tools(tool_manager)
    
    # Call tools from XAI response
    tool_messages = await call_xai_tools(tool_manager, tool_calls)

API Reference

MetorialXAISession

Main session class for XAI integration.

session = MetorialXAISession(tool_manager)

Properties:

  • tools: List of tools in OpenAI-compatible format with strict mode

Methods:

  • async call_tools(tool_calls): Execute tool calls and return tool messages

build_xai_tools(tool_mgr)

Build XAI-compatible tool definitions.

Returns: List of tool definitions in OpenAI format with strict mode

call_xai_tools(tool_mgr, tool_calls)

Execute tool calls from XAI response.

Returns: List of tool messages

Tool Format

Tools are converted to OpenAI-compatible format with strict mode enabled:

{
    "type": "function",
    "function": {
        "name": "tool_name",
        "description": "Tool description",
        "parameters": {
            "type": "object",
            "properties": {...},
            "required": [...]
        },
        "strict": True
    }
}

XAI API Configuration

XAI uses the OpenAI-compatible API format. Configure your client like this:

from openai import OpenAI

client = OpenAI(
    api_key="your-xai-api-key",
    base_url="https://api.x.ai/v1"
)

Error Handling

try:
    tool_messages = await xai_session.call_tools(tool_calls)
except Exception as e:
    print(f"Tool execution failed: {e}")

Tool errors are returned as tool messages with error content.

Dependencies

  • metorial-openai-compatible>=1.0.0
  • metorial-mcp-session>=1.0.0
  • typing-extensions>=4.0.0

License

MIT License - see LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

metorial_xai-1.0.0rc1.tar.gz (5.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

metorial_xai-1.0.0rc1-py3-none-any.whl (4.3 kB view details)

Uploaded Python 3

File details

Details for the file metorial_xai-1.0.0rc1.tar.gz.

File metadata

  • Download URL: metorial_xai-1.0.0rc1.tar.gz
  • Upload date:
  • Size: 5.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for metorial_xai-1.0.0rc1.tar.gz
Algorithm Hash digest
SHA256 9535437f4b39096fd3f246ebb26ab4f51346f8728d723fd117f57536976046a9
MD5 4ae78e6a44454d9f4e859d07f37baa39
BLAKE2b-256 fb51ba04e70922fa663171ef703dbc4f58dc0ce873782b007451ec574c33436e

See more details on using hashes here.

Provenance

The following attestation bundles were made for metorial_xai-1.0.0rc1.tar.gz:

Publisher: release.yml on metorial/metorial-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file metorial_xai-1.0.0rc1-py3-none-any.whl.

File metadata

File hashes

Hashes for metorial_xai-1.0.0rc1-py3-none-any.whl
Algorithm Hash digest
SHA256 0e01228b24e6aa2d63227b5f915ed0ab014c5821bc25a55b6d2ecfe5c67c20e6
MD5 be82c9e5c6645ebb7b6f06c49118ee4d
BLAKE2b-256 0d663c6a14696ad4695d23b32b56a95959ffe162c7e02bbcdcb15c40cab7750f

See more details on using hashes here.

Provenance

The following attestation bundles were made for metorial_xai-1.0.0rc1-py3-none-any.whl:

Publisher: release.yml on metorial/metorial-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page