A Python SDK for creating and managing Kenar messaging bots. KenarpyBot provides a simple, intuitive interface inspired by teleBot's syntax, making it easy for developers familiar with Telegram bot development to create bots for the Kenar platform.
Kenar Divar is Divar's official platform that provides APIs for developers to create plugins and integrations with Divar. These APIs enable functionality like sending and receiving messages, editing posts, patching add-ons on posts and etc... , you should also checkput Kenar Divar Panel
- 🚀 Simple, teleBot-inspired syntax
- 📨 Easy message handling and routing
- 🔄 Built-in support for Kenar's messaging endpoints
- ⚡ Flask-based webhook handling
- ⚙️ Straightforward bot configuration
pip install kenarbotHere's a simple example demonstrating how to create a bot that responds to messages containing "hello":
import os
from kenarBot import KenarBot
from kenarBot.types import ChatBotMessage
# Initialize your API key from Kenar platform
DIVAR_API_KEY = os.getenv("DIVAR_API_KEY")
DIVAR_IDENTIFICATION_KEY = os.getenv("DIVAR_IDENTIFICATION_KEY")
# Create a bot instance
bot = KenarBot(DIVAR_IDENTIFICATION_KEY, "/webhook", DIVAR_API_KEY)
# Define a message handler that responds to messages containing "hello"
@bot.message_handler(regexp="hello")
def handle_hello(chatbot_message: ChatBotMessage):
# Send a response back to the same conversation
bot.send_message(chatbot_message.conversation_id, f"Hi, my name is AmazingKenarBot")
if __name__ == "__main__":
# Start the bot
bot.run()This example shows:
- How to initialize the bot with your API key
- How to create a message handler using decorators
- How to respond to specific messages using regular expressions
- How to send messages back to conversations
-
Bot Initialization:
- Create a
KenarBotinstance with your app name, webhook path, and API key - The webhook path is where your bot will receive updates
- Create a
-
Message Handler:
- Use the
@bot.message_handlerdecorator to define message handlers - The
regexpparameter allows you to filter messages based on regular expressions - Other handler options are available (commands, content types, etc.)
- Use the
-
Sending Messages:
- Use
bot.send_message()to send responses - Requires the conversation ID and the message text
- Use
-
Running the Bot:
- Call
bot.run()to start the bot - This will start a Flask server to handle incoming webhook requests
- Call
- Keep your API key secure and never commit it to version control
- Consider using environment variables for sensitive data
- The bot runs on Flask, so it needs to be hosted on a server accessible to Kenar
bot.send_message(conversation_id, text): Send a message to a conversationbot.message_handler(regexp=""): Decorator for handling messages matching a regex patternbot.run(): Start the bot's webhook server
Contributions are welcome! Please feel free to submit a Pull Request.
- Fork the repository
- Create your feature branch (
git checkout -b feature/AmazingFeature) - Commit your changes (
git commit -m 'Add some AmazingFeature') - Push to the branch (
git push origin feature/AmazingFeature) - Open a Pull Request
This project is licensed under the MIT License - see the LICENSE file for details.
- Create an Issue
- Send an email to realmobinpourabedini@gmail.com
- Inspired by the pyTelegramBotAPI project
- Thanks to the open-platform team
Mobin Pourabedini (@Mobin-Pourabedini)
Made with ❤️ for the Kenar community