mirror of
https://github.com/aiogram/aiogram.git
synced 2025-12-11 18:01:04 +00:00
Refactor and improve bot examples (#1256)
* Refactor and improve bot messages
Refactored bot code to use aiogram enumerations and enhanced chat messages with markdown beautifications for a more user-friendly display.
CommandStart() is now used instead of Command('start') for readability.
Furthermore, the bot's 'stop' command was improved, ensuring it executes appropriately during KeyboardInterrupt or SystemExit.
Additionally, the bot's logging was adjusted to output to sys.stdout for better logs' readability.
* Added Changelog
* Add guidance comments on obtaining bot tokens from environment variables
* Remove hardcoded tokens, opt for environment variable
* Remove unnecessary spaces and reorganize imports
* Fix error, switch default storage from Redis to Memory, and add logging to multibot example
This commit is contained in:
parent
68c0516f69
commit
c516ea9d6a
8 changed files with 89 additions and 56 deletions
|
|
@ -1,14 +1,16 @@
|
|||
import logging
|
||||
import sys
|
||||
from os import getenv
|
||||
from typing import Any, Dict, Union
|
||||
|
||||
from aiohttp import web
|
||||
from finite_state_machine import form_router
|
||||
|
||||
from aiogram import Bot, Dispatcher, F, Router
|
||||
from aiogram.client.session.aiohttp import AiohttpSession
|
||||
from aiogram.enums import ParseMode
|
||||
from aiogram.exceptions import TelegramUnauthorizedError
|
||||
from aiogram.filters import Command, CommandObject
|
||||
from aiogram.fsm.storage.redis import DefaultKeyBuilder, RedisStorage
|
||||
from aiogram.fsm.storage.memory import MemoryStorage
|
||||
from aiogram.types import Message
|
||||
from aiogram.utils.token import TokenValidationError, validate_token
|
||||
from aiogram.webhook.aiohttp_server import (
|
||||
|
|
@ -16,11 +18,12 @@ from aiogram.webhook.aiohttp_server import (
|
|||
TokenBasedRequestHandler,
|
||||
setup_application,
|
||||
)
|
||||
from finite_state_machine import form_router
|
||||
|
||||
main_router = Router()
|
||||
|
||||
BASE_URL = getenv("BASE_URL", "https://example.com")
|
||||
MAIN_BOT_TOKEN = getenv("TELEGRAM_TOKEN")
|
||||
MAIN_BOT_TOKEN = getenv("BOT_TOKEN")
|
||||
|
||||
WEB_SERVER_HOST = "127.0.0.1"
|
||||
WEB_SERVER_PORT = 8080
|
||||
|
|
@ -56,10 +59,13 @@ async def on_startup(dispatcher: Dispatcher, bot: Bot):
|
|||
|
||||
|
||||
def main():
|
||||
logging.basicConfig(level=logging.INFO, stream=sys.stdout)
|
||||
session = AiohttpSession()
|
||||
bot_settings = {"session": session, "parse_mode": "HTML"}
|
||||
bot_settings = {"session": session, "parse_mode": ParseMode.HTML}
|
||||
bot = Bot(token=MAIN_BOT_TOKEN, **bot_settings)
|
||||
storage = RedisStorage.from_url(REDIS_DSN, key_builder=DefaultKeyBuilder(with_bot_id=True))
|
||||
storage = MemoryStorage()
|
||||
# In order to use RedisStorage you need to use Key Builder with bot ID:
|
||||
# storage = RedisStorage.from_url(REDIS_DSN, key_builder=DefaultKeyBuilder(with_bot_id=True))
|
||||
|
||||
main_dispatcher = Dispatcher(storage=storage)
|
||||
main_dispatcher.include_router(main_router)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue