Skip to main content

Together AI provider for Metorial

Project description

metorial-togetherai

Together AI provider integration for Metorial.

Installation

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

Features

  • 🤖 Together AI Integration: Full support for Llama, Mixtral, and other Together AI models
  • 🛠️ Function Calling: OpenAI-compatible function calling support
  • 📡 Session Management: Automatic tool lifecycle handling
  • Async Support: Full async/await support

Supported Models

Popular models available through Together AI:

  • meta-llama/Meta-Llama-3.1-70B-Instruct-Turbo: Llama 3.1 70B
  • meta-llama/Meta-Llama-3.1-8B-Instruct-Turbo: Llama 3.1 8B
  • mistralai/Mixtral-8x7B-Instruct-v0.1: Mixtral 8x7B
  • NousResearch/Nous-Hermes-2-Mixtral-8x7B-DPO: Nous Hermes 2
  • And many more...

Usage

Quick Start (Recommended)

import asyncio
from openai import AsyncOpenAI
from metorial import Metorial

async def main():
  # Initialize clients
  metorial = Metorial(api_key="...your-metorial-api-key...") # async by default
  together_client = AsyncOpenAI(
    api_key="...your-together-api-key...", 
    base_url="https://api.together.xyz/v1"
  )
  
  # One-liner chat with automatic session management
  response = await metorial.run(
    "What are the latest commits in the metorial/websocket-explorer repository?",
    "...your-mcp-server-deployment-id...", # can also be list
    together_client,
    model="meta-llama/Meta-Llama-3.1-70B-Instruct-Turbo",
    max_iterations=25
  )
  
  print("Response:", response)

asyncio.run(main())

Streaming Chat

import asyncio
from openai import AsyncOpenAI
from metorial import Metorial
from metorial.types import StreamEventType

async def example():
  # Initialize clients
  metorial = Metorial(api_key="...your-metorial-api-key...")
  together_client = AsyncOpenAI(
    api_key="...your-together-api-key...",
    base_url="https://api.together.xyz/v1"
  )
  
  # Streaming chat with real-time responses
  async def stream_action(session):
    messages = [
      {"role": "user", "content": "Explain quantum computing"}
    ]
    
    async for event in metorial.stream(
      together_client, session, messages, 
      model="meta-llama/Meta-Llama-3.1-70B-Instruct-Turbo",
      max_iterations=25
    ):
      if event.type == StreamEventType.CONTENT:
        print(f"🤖 {event.content}", end="", flush=True)
      elif event.type == StreamEventType.TOOL_CALL:
        print(f"\n🔧 Executing {len(event.tool_calls)} tool(s)...")
      elif event.type == StreamEventType.COMPLETE:
        print(f"\n✅ Complete!")
  
  await metorial.with_session("...your-server-deployment-id...", stream_action)

asyncio.run(example())

Advanced Usage with Session Management

import asyncio
from openai import OpenAI
from metorial import Metorial
from metorial_togetherai import MetorialTogetherAISession

async def main():
  # Initialize clients
  metorial = Metorial(api_key="...your-metorial-api-key...")
  
  # Together AI uses OpenAI-compatible client
  together_client = OpenAI(
    api_key="...your-together-api-key...",
    base_url="https://api.together.xyz/v1"
  )
  
  # Create session with your server deployments
  async with metorial.session(["...your-server-deployment-id..."]) as session:
    # Create Together AI-specific wrapper
    together_session = MetorialTogetherAISession(session.tool_manager)
    
    messages = [
      {"role": "user", "content": "What are the latest commits?"}
    ]
    
    response = together_client.chat.completions.create(
      model="meta-llama/Meta-Llama-3.1-70B-Instruct-Turbo",
      messages=messages,
      tools=together_session.tools
    )
    
    # Handle tool calls
    tool_calls = response.choices[0].message.tool_calls
    if tool_calls:
      tool_responses = await together_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_togetherai import build_togetherai_tools, call_togetherai_tools

async def example():
  # Get tools in Together AI format
  tools = build_togetherai_tools(tool_manager)
  
  # Call tools from Together AI response
  tool_messages = await call_togetherai_tools(tool_manager, tool_calls)

API Reference

MetorialTogetherAISession

Main session class for Together AI integration.

session = MetorialTogetherAISession(tool_manager)

Properties:

  • tools: List of tools in OpenAI-compatible format

Methods:

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

build_togetherai_tools(tool_mgr)

Build Together AI-compatible tool definitions.

Returns: List of tool definitions in OpenAI format

call_togetherai_tools(tool_mgr, tool_calls)

Execute tool calls from Together AI response.

Returns: List of tool messages

Tool Format

Tools are converted to OpenAI-compatible format (without strict mode):

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

Together AI API Configuration

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

from openai import OpenAI

client = OpenAI(
  api_key="...your-together-api-key...",
  base_url="https://api.together.xyz/v1"
)

Error Handling

try:
    tool_messages = await together_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.

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_togetherai-1.0.0rc7.tar.gz (5.9 kB view details)

Uploaded Source

Built Distribution

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

metorial_togetherai-1.0.0rc7-py3-none-any.whl (4.9 kB view details)

Uploaded Python 3

File details

Details for the file metorial_togetherai-1.0.0rc7.tar.gz.

File metadata

  • Download URL: metorial_togetherai-1.0.0rc7.tar.gz
  • Upload date:
  • Size: 5.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for metorial_togetherai-1.0.0rc7.tar.gz
Algorithm Hash digest
SHA256 0e5fe918fae04c50c9a49d69575cd453fa5bf94ca4a8744e2b179a2d01402a49
MD5 ab33ee4f547e2e42cf451d6750b69946
BLAKE2b-256 31b85d82c8c3bc85f495fe3c699df0f45c2c51cdb0f7547f0597de63262e826e

See more details on using hashes here.

Provenance

The following attestation bundles were made for metorial_togetherai-1.0.0rc7.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_togetherai-1.0.0rc7-py3-none-any.whl.

File metadata

File hashes

Hashes for metorial_togetherai-1.0.0rc7-py3-none-any.whl
Algorithm Hash digest
SHA256 ab57ecc7d5561f9618a46d6075067ba400e3e8d0b46a964d03ce098b2146c923
MD5 b6562cabf0b5a5d894b607eb922213d4
BLAKE2b-256 738aa6d6b5ea4971618221ec14a45c8dcae34e9b464bd1b2e3d1591bb588ef3f

See more details on using hashes here.

Provenance

The following attestation bundles were made for metorial_togetherai-1.0.0rc7-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