Skip to content

MA24th/ttbotapi

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

54 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ttbotapi

TamTam Bot API library

GPLv2 license PyPI Python package TamTam Channel

How to Use

The Bot class encapsulates all API calls in a single class. It provides functions such as send_xyz (send_message, edit_message etc.) and several ways to listen for incoming messages.

Create a file called echo_bot.py. Then, open the file and create an instance of the Bot class.

import ttbotapi
import logging

ttbotapi.logger.setLevel(logging.DEBUG)

# Note: Make sure to actually replace TOKEN with your own API token.
bot = ttbotapi.Bot(access_token='Bot Token')

# After that declaration, we need to register some so-called decorator handlers.
# Update handlers define filters which a message must pass. If a message passes the filter, 
# the decorated function is called and the incoming message is passed as an argument.

# Let's define a message handler which handles incoming `/start` and `/help` bot_command in dialog chat type.
@bot.update_handler(chat_type='dialog', bot_command=['/start', '/help'])
def send_welcome(update):
    # A function which is decorated by an update handler can have an arbitrary name, 
    # however, it must have only one parameter (the update)
    bot.send_message(text="Howdy, how are you doing?", user_id=update.message.sender.user_id, chat_id=None,
                     link={'type': 'reply', 'mid': update.message.body.mid})

# Let's add another handler
@bot.update_handler(chat_type='dialog', regexp='hi')
def send_hi(update):
    bot.send_message(text=f'Hi 👋, {update.message.sender.name}', user_id=update.message.sender.user_id, chat_id=None)


# This one echoes all incoming text messages back to the sender. It uses a lambda function to test a message. 
# If the lambda returns True, the message is handled by the decorated function. 
# Since we want all messages to be handled by this function, we simply always return True.
@bot.update_handler(func=lambda update: update.message.body.text)
def echo(update):
    bot.send_message(text=update.message.body.text, user_id=update.message.sender.user_id, chat_id=None)


# Using long polling now our bot never stop working
bot.polling()

# Alright, that's it! Our source file now looks fine

To start the bot, simply open up a terminal and enter python echo_bot.py to run the bot! Test it by sending commands ('/start' and '/help') and arbitrary text messages.

Explanation

A handler is a function that is decorated with the update_handler decorator of a Bot instance, handlers consist of one or multiple filters, Each filter match returns True for a certain message in order for an update handler to become eligible.

Here are some examples of using the filters and handlers:

update_type filters return types function argument
message_callback chat_type, bot_command, regexp, func Update update
message_created chat_type, bot_command, regexp, func Update update
message_removed chat_type, bot_command, regexp, func Update update
message_edited chat_type, bot_command, regexp, func Update update
bot_added regexp, func Update update
bot_removed regexp, func Update update
user_added regexp, func Update update
user_removed regexp, func Update update
bot_started regexp, func Update update
chat_title_change regexp, func Update update
message_construction_request regexp, func Update update
message_constructed regexp, func Update update
message_chat_created regexp, func Update update

A message_created handler is declared in the following way:

import ttbotapi

bot = ttbotapi.Bot(access_token="TOKEN")


@bot.update_handler(update_type='message_created')  # filters
def function_name(update):
    bot.send_message(chat_id=update.recipient.chat_id, user_id=None, text="This is a message handler")

function_name is not bound to any restrictions. Any function name is permitted with update handlers. The function must accept at most one argument, which will be the message that the function must handle.

filters is a list of keyword arguments. A filter is declared in the following manner: name=argument. One handler may have multiple filters.

Bot supports the following filters:

name argument(s) Condition
update_type list of strings or string, default message_created True if update_type='message_created'.
chat_type list of strings or string, (dialog, chat, channel) True if update.recipient.chat_type in chat_type
bot_command list of strings or string, (/start) True if update.message.body.text in bot_command
regex a regular expression as a string True if re.search(regexp_arg) returns True
func a function, (lambda or function reference) True if the lambda or function reference returns True

Logging You can use the ttbotapi module logger to log debug info about Bot.

It is possible to add custom logging Handlers to the logger, Refer to the Python logging for more info.

import logging
from ttbotapi import logger

logger.setLevel(logging.DEBUG) # Outputs debug messages to console.

How to Contribute

  • You must follow Contributing Guidelines.
  • We are committed to providing a friendly community, for more experience read Code Of Conduct.

Attribution

These Documents are adapted for MA24th Open Source Software,

For more information Contact with any additional questions or comments.