Skip to content

KenarBot: A Python SDK for building Kenar messaging bots with an intuitive, teleBot-inspired syntax.

License

Notifications You must be signed in to change notification settings

Mobin-Pourabedini/KenarBot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

KenarBot

PyPI version License: MIT Python Versions codecov

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.

What is Kenar Divar?

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

Features

  • 🚀 Simple, teleBot-inspired syntax
  • 📨 Easy message handling and routing
  • 🔄 Built-in support for Kenar's messaging endpoints
  • ⚡ Flask-based webhook handling
  • ⚙️ Straightforward bot configuration

Examples

Installation

pip install kenarbot

Quick Start Example

Here'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

Key Components:

  1. Bot Initialization:

    • Create a KenarBot instance with your app name, webhook path, and API key
    • The webhook path is where your bot will receive updates
  2. Message Handler:

    • Use the @bot.message_handler decorator to define message handlers
    • The regexp parameter allows you to filter messages based on regular expressions
    • Other handler options are available (commands, content types, etc.)
  3. Sending Messages:

    • Use bot.send_message() to send responses
    • Requires the conversation ID and the message text
  4. Running the Bot:

    • Call bot.run() to start the bot
    • This will start a Flask server to handle incoming webhook requests

Important Notes:

  • 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

Documentation

Available Methods

  • bot.send_message(conversation_id, text): Send a message to a conversation
  • bot.message_handler(regexp=""): Decorator for handling messages matching a regex pattern
  • bot.run(): Start the bot's webhook server

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

License

This project is licensed under the MIT License - see the LICENSE file for details.

Support

Acknowledgments

Author

Mobin Pourabedini (@Mobin-Pourabedini)


Made with ❤️ for the Kenar community

About

KenarBot: A Python SDK for building Kenar messaging bots with an intuitive, teleBot-inspired syntax.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages