mirror of
https://github.com/aiogram/aiogram.git
synced 2025-12-06 07:50:32 +00:00
Some checks failed
Tests / tests (macos-latest, 3.10) (push) Has been cancelled
Tests / tests (macos-latest, 3.11) (push) Has been cancelled
Tests / tests (macos-latest, 3.12) (push) Has been cancelled
Tests / tests (macos-latest, 3.13) (push) Has been cancelled
Tests / tests (ubuntu-latest, 3.10) (push) Has been cancelled
Tests / tests (ubuntu-latest, 3.11) (push) Has been cancelled
Tests / tests (ubuntu-latest, 3.12) (push) Has been cancelled
Tests / tests (ubuntu-latest, 3.13) (push) Has been cancelled
Tests / tests (windows-latest, 3.10) (push) Has been cancelled
Tests / tests (windows-latest, 3.11) (push) Has been cancelled
Tests / tests (windows-latest, 3.12) (push) Has been cancelled
Tests / tests (windows-latest, 3.13) (push) Has been cancelled
Tests / pypy-tests (macos-latest, pypy3.10) (push) Has been cancelled
Tests / pypy-tests (macos-latest, pypy3.11) (push) Has been cancelled
Tests / pypy-tests (ubuntu-latest, pypy3.10) (push) Has been cancelled
Tests / pypy-tests (ubuntu-latest, pypy3.11) (push) Has been cancelled
* Drop py3.9 and pypy3.9 Add pypy3.11 (testing) into `tests.yml` Remove py3.9 from matrix in `tests.yml` Refactor not auto-gen code to be compatible with py3.10+, droping ugly 3.9 annotation. Replace some `from typing` imports to `from collections.abc`, due to deprecation Add `from __future__ import annotations` and `if TYPE_CHECKING:` where possible Add some `noqa` to calm down Ruff in some places, if Ruff will be used as default linting+formatting tool in future Replace some relative imports to absolute Sort `__all__` tuples in `__init__.py` and some other `.py` files Sort `__slots__` tuples in classes Split raises into `msg` and `raise` (`EM101`, `EM102`) to not duplicate error message in the traceback Add `Self` from `typing_extenstion` where possible Resolve typing problem in `aiogram/filters/command.py:18` Concatenate nested `if` statements Convert `HandlerContainer` into a dataclass in `aiogram/fsm/scene.py` Bump tests docker-compose.yml `redis:6-alpine` -> `redis:8-alpine` Bump tests docker-compose.yml `mongo:7.0.6` -> `mongo:8.0.14` Bump pre-commit-config `black==24.4.2` -> `black==25.9.0` Bump pre-commit-config `ruff==0.5.1` -> `ruff==0.13.3` Update Makefile lint for ruff to show fixes Add `make outdated` into Makefile Use `pathlib` instead of `os.path` Bump `redis[hiredis]>=5.0.1,<5.3.0` -> `redis[hiredis]>=6.2.0,<7` Bump `cryptography>=43.0.0` -> `cryptography>=46.0.0` due to security reasons Bump `pytz~=2023.3` -> `pytz~=2025.2` Bump `pycryptodomex~=3.19.0` -> `pycryptodomex~=3.23.0` due to security reasons Bump linting and formatting tools * Add `1726.removal.rst` * Update aiogram/utils/dataclass.py Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update aiogram/filters/callback_data.py Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update 1726.removal.rst * Remove `outdated` from Makefile * Add `__slots__` to `HandlerContainer` * Remove unused imports * Add `@dataclass` with `slots=True` to `HandlerContainer` --------- Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
72 lines
2.2 KiB
Python
72 lines
2.2 KiB
Python
from __future__ import annotations
|
|
|
|
from pathlib import Path
|
|
from typing import TYPE_CHECKING
|
|
|
|
from aiohttp.web_fileresponse import FileResponse
|
|
from aiohttp.web_response import json_response
|
|
|
|
from aiogram.types import (
|
|
InlineKeyboardButton,
|
|
InlineKeyboardMarkup,
|
|
InlineQueryResultArticle,
|
|
InputTextMessageContent,
|
|
WebAppInfo,
|
|
)
|
|
from aiogram.utils.web_app import check_webapp_signature, safe_parse_webapp_init_data
|
|
|
|
if TYPE_CHECKING:
|
|
from aiohttp.web_request import Request
|
|
from aiohttp.web_response import Response
|
|
|
|
from aiogram import Bot
|
|
|
|
|
|
async def demo_handler(request: Request) -> FileResponse:
|
|
return FileResponse(Path(__file__).parent.resolve() / "demo.html")
|
|
|
|
|
|
async def check_data_handler(request: Request) -> Response:
|
|
bot: Bot = request.app["bot"]
|
|
|
|
data = await request.post()
|
|
if check_webapp_signature(bot.token, data["_auth"]):
|
|
return json_response({"ok": True})
|
|
return json_response({"ok": False, "err": "Unauthorized"}, status=401)
|
|
|
|
|
|
async def send_message_handler(request: Request) -> Response:
|
|
bot: Bot = request.app["bot"]
|
|
data = await request.post()
|
|
try:
|
|
web_app_init_data = safe_parse_webapp_init_data(token=bot.token, init_data=data["_auth"])
|
|
except ValueError:
|
|
return json_response({"ok": False, "err": "Unauthorized"}, status=401)
|
|
|
|
reply_markup = None
|
|
if data["with_webview"] == "1":
|
|
reply_markup = InlineKeyboardMarkup(
|
|
inline_keyboard=[
|
|
[
|
|
InlineKeyboardButton(
|
|
text="Open",
|
|
web_app=WebAppInfo(
|
|
url=str(request.url.with_scheme("https").with_path("demo")),
|
|
),
|
|
),
|
|
],
|
|
],
|
|
)
|
|
await bot.answer_web_app_query(
|
|
web_app_query_id=web_app_init_data.query_id,
|
|
result=InlineQueryResultArticle(
|
|
id=web_app_init_data.query_id,
|
|
title="Demo",
|
|
input_message_content=InputTextMessageContent(
|
|
message_text="Hello, World!",
|
|
parse_mode=None,
|
|
),
|
|
reply_markup=reply_markup,
|
|
),
|
|
)
|
|
return json_response({"ok": True})
|