Source code for aiogram.utils.serialization

from dataclasses import dataclass
from typing import Any, Dict, Optional

from pydantic import BaseModel

from aiogram import Bot
from aiogram.client.default import DefaultBotProperties
from aiogram.methods import TelegramMethod
from aiogram.types import InputFile


def _get_fake_bot(default: Optional[DefaultBotProperties] = None) -> Bot:
    if default is None:
        default = DefaultBotProperties()
    return Bot(token="42:Fake", default=default)


[docs] @dataclass class DeserializedTelegramObject: """ Represents a dumped Telegram object. :param data: The dumped data of the Telegram object. :type data: Any :param files: The dictionary containing the file names as keys and the corresponding `InputFile` objects as values. :type files: Dict[str, InputFile] """ data: Any files: Dict[str, InputFile]
[docs] def deserialize_telegram_object( obj: Any, default: Optional[DefaultBotProperties] = None, include_api_method_name: bool = True, ) -> DeserializedTelegramObject: """ Deserialize Telegram Object to JSON compatible Python object. :param obj: The object to be deserialized. :param default: Default bot properties should be passed only if you want to use custom defaults. :param include_api_method_name: Whether to include the API method name in the result. :return: The deserialized Telegram object. """ extends = {} if include_api_method_name and isinstance(obj, TelegramMethod): extends["method"] = obj.__api_method__ if isinstance(obj, BaseModel): obj = obj.model_dump(mode="python", warnings=False) # Fake bot is needed to exclude global defaults from the object. fake_bot = _get_fake_bot(default=default) files: Dict[str, InputFile] = {} prepared = fake_bot.session.prepare_value( obj, bot=fake_bot, files=files, _dumps_json=False, ) if isinstance(prepared, dict): prepared.update(extends) return DeserializedTelegramObject(data=prepared, files=files)
[docs] def deserialize_telegram_object_to_python( obj: Any, default: Optional[DefaultBotProperties] = None, include_api_method_name: bool = True, ) -> Any: """ Deserialize telegram object to JSON compatible Python object excluding files. :param obj: The telegram object to be deserialized. :param default: Default bot properties should be passed only if you want to use custom defaults. :param include_api_method_name: Whether to include the API method name in the result. :return: The deserialized telegram object. """ return deserialize_telegram_object( obj, default=default, include_api_method_name=include_api_method_name, ).data