Python SDK for Anthropic, OpenAI, and MiniMax AI providers
Project description
motosan-ai (Python SDK)
Multi-provider Python SDK for Anthropic, OpenAI, and MiniMax.
Installation
pip install motosan-ai
pip install "motosan-ai[anthropic]"
pip install "motosan-ai[openai]"
pip install "motosan-ai[minimax]"
pip install "motosan-ai[full]"
Quick Start
import asyncio
from motosan_ai import Client
async def main() -> None:
client = Client.anthropic(api_key="sk-ant-...", model="claude-3-5-sonnet-latest")
response = await client.chat([
{"role": "user", "content": "Hello"},
])
print(response.content)
asyncio.run(main())
Tool Use (Multi-turn)
import asyncio
from motosan_ai import Client, Message, Tool
def get_weather(city: str) -> str:
return f"Sunny in {city}"
async def main() -> None:
client = Client.anthropic(api_key="sk-ant-...")
tools = [
Tool(
name="get_weather",
description="Get current weather",
input_schema={
"type": "object",
"properties": {"city": {"type": "string"}},
"required": ["city"],
},
)
]
messages = [Message.user("What's the weather in Tokyo?")]
response = await client.chat(messages, tools=tools)
if response.tool_calls:
tc = response.tool_calls[0]
result = get_weather(tc.input["city"])
messages += [
Message.assistant_with_tool_calls("", response.tool_calls),
Message.tool_result(tc.id, result),
]
final = await client.chat(messages, tools=tools)
print(final.content)
asyncio.run(main())
Streaming
import asyncio
from motosan_ai import Client, Message
async def main() -> None:
client = Client.openai(api_key="sk-...", model="gpt-4.1-mini")
async for event in client.stream([Message.user("Write a haiku about rain")]):
if event.content:
print(event.content, end="")
if event.done:
break
asyncio.run(main())
Sync Wrapper
from motosan_ai import Client, Message
client = Client.minimax(api_key="...")
response = client.chat_sync([Message.user("Hello from sync")])
print(response.content)
Providers
Anthropic
from motosan_ai import Client
client = Client.anthropic(api_key="sk-ant-...", model="claude-3-5-sonnet-latest")
OpenAI
from motosan_ai import Client
client = Client.openai(api_key="sk-...", model="gpt-4.1-mini")
MiniMax
from motosan_ai import Client
client = Client.minimax(api_key="...", model="MiniMax-M1")
Requirements
- Python 3.11+
- One provider API key:
ANTHROPIC_API_KEYOPENAI_API_KEYMINIMAX_API_KEY
Development
uv sync --extra full --extra dev
uv run ruff check motosan_ai/
uv run pytest -q
uv build --out-dir dist
uv publish --dry-run dist/*
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
motosan_ai-0.3.1.tar.gz
(13.2 kB
view details)
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file motosan_ai-0.3.1.tar.gz.
File metadata
- Download URL: motosan_ai-0.3.1.tar.gz
- Upload date:
- Size: 13.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bf94a4ed2f7a78437722dd0a215d6292bc69337cb21700855883fd7fc6dd9645
|
|
| MD5 |
34e379f29a5171a43cb44ba736197fa7
|
|
| BLAKE2b-256 |
24f2478dfdd403c8fd54cb9cb56c626ecb978f8b29041cd51af39c12e5949cbb
|
File details
Details for the file motosan_ai-0.3.1-py3-none-any.whl.
File metadata
- Download URL: motosan_ai-0.3.1-py3-none-any.whl
- Upload date:
- Size: 14.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9fa1247950302a1a2876eee7752aba83181552a9ef89ea8733b12677a7826c89
|
|
| MD5 |
69c24fcc07b368f2253a74fd5f53cae4
|
|
| BLAKE2b-256 |
c1151ba81aed01121b97d66f0934b699e38b3685bac0274eea8e7e1a8ff04594
|