Python SDK for chatbot platform
Project description
pychatbot2
A Python SDK for the chatbot platform, providing a clean and type-safe interface for interacting with messaging platforms.
Features
- Type-safe interfaces using Python's type hints
- Async/await support for all operations
- Event-driven architecture using Server-Sent Events (SSE)
- Support for various message content types (text, image, audio, card)
- Comprehensive error handling and logging
- Easy integration with messaging platforms
Installation
pip install pychatbot2
Quick Start
from pychatbot2 import ChatbotClient, ChatbotClientOptions, CommandRunner, Contact, ContactType, ChatMessagePayload, ChatMessagePlainContent
class MyCommandRunner(CommandRunner):
async def on_start(self, payload):
return {
"self": Contact(
contact_type=ContactType.PRIVATE,
contact_id="user123",
name="My Bot"
),
"contacts": []
}
async def get_self(self, payload):
return Contact(
contact_type=ContactType.PRIVATE,
contact_id="user123",
name="My Bot"
)
async def get_contacts(self, payload):
return []
async def get_contact_info(self, payload):
return {
"name": "Test Contact",
"members": []
}
async def send_chat_message(self, payload):
# Implement message sending logic
pass
# Create client options
options = ChatbotClientOptions(
base_url="https://api.example.com",
api_key="your-api-key",
message_platform_type="custom",
message_platform_account_id="account123",
command_runner=MyCommandRunner()
)
# Create and start the client
client = ChatbotClient(options)
await client.start()
# Handle incoming messages
async def handle_message(message):
payload = ChatMessagePayload(
contact_type=ContactType.PRIVATE,
contact_id="user123",
message_id="msg123",
sender_id="sender123",
content=ChatMessagePlainContent(text="Hello!"),
mentioned=False
)
await client.on_receive_chat_message(payload)
Development
Setup
- Clone the repository
- Install development dependencies:
pip install -e ".[dev]"
Running Tests
pytest
Code Style
This project uses:
- Black for code formatting
- isort for import sorting
- mypy for type checking
Run the formatters:
black .
isort .
License
MIT License
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
pychatbot2-0.1.0.tar.gz
(5.9 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 pychatbot2-0.1.0.tar.gz.
File metadata
- Download URL: pychatbot2-0.1.0.tar.gz
- Upload date:
- Size: 5.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3bb9ea040b6edea7e9d5def451e08ca811f83959ddcbcb21a317f19b79dd1bb4
|
|
| MD5 |
0df4573c0303e5cda7da4bbd51c4c85c
|
|
| BLAKE2b-256 |
88de5a9f5d0b6b1f3dcd1559d188bc5b5860b499c14722db77b102665fddd147
|
File details
Details for the file pychatbot2-0.1.0-py3-none-any.whl.
File metadata
- Download URL: pychatbot2-0.1.0-py3-none-any.whl
- Upload date:
- Size: 6.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3ed3db2e7455cc9c988a504ce7b64cb2c4898ea551a1a8caf8a07f444a7c60b2
|
|
| MD5 |
2bdc38659f14405c56540154e9160886
|
|
| BLAKE2b-256 |
fab750e465033e87eccec0c5028dcbe257fc79ba441f97e17bfa50d126a590ac
|