FSM middleware for using with pybotx
Project description
pybotx-fsm
Конечный автомат (Finite state machine) для ботов на базе библиотеки pybotx.
Возможности
- Лёгкое создание графа состояний и их переключений.
- Передача данных в следующее состояние при явном вызове перехода.
Подготовка к установке
Для работы библиотеки необходим Redis, который уже встроен в последние версии коробки.
Установка
Используя poetry
:
poetry add pybotx-fsm
Работа с графом состояний
- Создайте
enum
для возможных состояний автомата:
from enum import Enum, auto
from pybotx_fsm import FSMCollector
class LoginStates(Enum):
enter_email = auto()
enter_password = auto()
fsm = FSMCollector(LoginStates)
- Добавьте экземпляр автомата в мидлвари для того, чтобы бот мог использовать его:
Bot(
collectors=[
myfile.collector,
],
bot_accounts=[
BotAccountWithSecret(
# Не забудьте заменить эти учётные данные на настоящие,
# когда создадите бота в панели администратора.
id=UUID("123e4567-e89b-12d3-a456-426655440000"),
host="cts.example.com",
secret_key="e29b417773f2feab9dac143ee3da20c5",
),
],
middlewares=[
FSMMiddleware([myfile.fsm], state_repo_key="redis_repo"),
],
)
- Добавьте в
bot.state.{state_repo_key}
совместимый redis репозиторий:
bot.state.redis_repo = await RedisRepo.init(...)
- Создайте обработчики конкретных состояний:
@fsm.on(LoginStates.enter_email)
async def enter_email(message: IncomingMessage, bot: Bot) -> None:
email = message.body
if not check_user_exist(email):
await bot.answer_message("Wrong email, try again")
return
await message.state.fsm.change_state(LoginStates.enter_password, email=email)
await bot.answer_message("Enter your password")
@fsm.on(LoginStates.enter_password)
async def enter_password(message: IncomingMessage, bot: Bot) -> None:
email = message.state.fsm_storage.email
password = message.body
try:
login(email, password)
except IncorrectPasswordError:
await bot.answer_message("Wrong password, try again")
return
await message.state.fsm.drop_state()
await bot.answer_message("Success!")
- Передайте управление обработчику состояний из любого обработчика сообщений:
@collector.command("/login")
async def start_login(message: IncomingMessage, bot: Bot) -> None:
await bot.answer_message("Enter your email")
await message.state.fsm.change_state(LoginStates.enter_email)
Примеры
Минимальный пример бота с конечным автоматом
# Здесь и далее будут пропущены импорты и код, не затрагивающий
# непосредственно pybotx_fsm
class FsmStates(Enum):
EXAMPLE_STATE = auto()
fsm = FSMCollector(FsmStates)
@collector.command("/echo", description="Echo command")
async def help_command(message: IncomingMessage, bot: Bot) -> None:
await message.state.fsm.change_state(FsmStates.EXAMPLE_STATE)
await bot.answer_message("Input your text:")
@fsm.on(FsmStates.EXAMPLE_STATE)
async def example_state(message: IncomingMessage, bot: Bot) -> None:
user_text = message.body
await message.state.fsm.drop_state()
await bot.answer_message(f"Your text is {user_text}")
bot = Bot(
collectors=[
collector,
],
bot_accounts=[
BotAccountWithSecret(
# Не забудьте заменить эти учётные данные на настоящие,
# когда создадите бота в панели администратора.
id=UUID("123e4567-e89b-12d3-a456-426655440000"),
host="cts.example.com",
secret_key="e29b417773f2feab9dac143ee3da20c5",
),
],
middlewares=[
FSMMiddleware([fsm], state_repo_key="redis_repo"),
],
)
Передача данных между состояниями
@fsm.on(FsmStates.INPUT_FIRST_NAME)
async def input_first_name(message: IncomingMessage, bot: Bot) -> None:
first_name = message.body
await message.state.fsm.change_state(
FsmStates.INPUT_LAST_NAME,
first_name=first_name,
)
await bot.answer_message("Input your last name:")
@fsm.on(FsmStates.INPUT_LAST_NAME)
async def input_last_name(message: IncomingMessage, bot: Bot) -> None:
first_name = message.state.fsm_storage.first_name
last_name = message.body
await message.state.fsm.drop_state()
await bot.answer_message(f"Hello {first_name} {last_name}!")
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
pybotx_fsm-0.4.6.tar.gz
(7.4 kB
view details)
Built Distribution
File details
Details for the file pybotx_fsm-0.4.6.tar.gz
.
File metadata
- Download URL: pybotx_fsm-0.4.6.tar.gz
- Upload date:
- Size: 7.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.3.2 CPython/3.8.2 Linux/5.15.0-1030-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 93acbed322b1da9ab50cf961099d25b617eb7e6b6407c8cc35aa9fba58cdad00 |
|
MD5 | 15b485083576aa8450d87561ceda9883 |
|
BLAKE2b-256 | 9ed92d31b7d2dacd01972105df19e3033e4dc5622a27370eb752b07dd8cef860 |
File details
Details for the file pybotx_fsm-0.4.6-py3-none-any.whl
.
File metadata
- Download URL: pybotx_fsm-0.4.6-py3-none-any.whl
- Upload date:
- Size: 8.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.3.2 CPython/3.8.2 Linux/5.15.0-1030-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a4871ec226bfc51d460fa52fb9979dbb6f47f88e29e7c33d1edc749c9423d973 |
|
MD5 | 1a22e363b2a375982a535d66d3019be1 |
|
BLAKE2b-256 | 217f3d1a5a6a259650b8960bc30b1f228cb796e6dfa73ab04900939322fe5b6d |