# Hydrogram - Telegram MTProto API Client Library for Python
# Copyright (C) 2023-present Hydrogram <https://hydrogram.org>
#
# This file is part of Hydrogram.
#
# Hydrogram is free software: you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published
# by the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Hydrogram is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with Hydrogram. If not, see <http://www.gnu.org/licenses/>.
from io import BytesIO
from hydrogram.raw.core.primitives import Int, Long, Int128, Int256, Bool, Bytes, String, Double, Vector
from hydrogram.raw.core import TLObject
from hydrogram import raw
from typing import List, Optional, Any
# # # # # # # # # # # # # # # # # # # # # # # #
# !!! WARNING !!! #
# This is a generated file! #
# All changes made in this file will be lost! #
# # # # # # # # # # # # # # # # # # # # # # # #
[docs]
class RequestWebView(TLObject): # type: ignore
"""Open a bot mini app, sending over user information after user confirmation.
Details:
- Layer: ``181``
- ID: ``269DC2C1``
Parameters:
peer (:obj:`InputPeer <hydrogram.raw.base.InputPeer>`):
Dialog where the web app is being opened, and where the resulting message will be sent (see the docs for more info »).
bot (:obj:`InputUser <hydrogram.raw.base.InputUser>`):
Bot that owns the web app
platform (``str``):
Short name of the application; 0-64 English letters, digits, and underscores
from_bot_menu (``bool``, *optional*):
Whether the webview was opened by clicking on the bot's menu button ».
silent (``bool``, *optional*):
Whether the inline message that will be sent by the bot on behalf of the user once the web app interaction is terminated should be sent silently (no notifications for the receivers).
url (``str``, *optional*):
Web app URL
start_param (``str``, *optional*):
If the web app was opened from the attachment menu using a attachment menu deep link, start_param should contain the data from the startattach parameter.
theme_params (:obj:`DataJSON <hydrogram.raw.base.DataJSON>`, *optional*):
Theme parameters »
reply_to (:obj:`InputReplyTo <hydrogram.raw.base.InputReplyTo>`, *optional*):
If set, indicates that the inline message that will be sent by the bot on behalf of the user once the web app interaction is terminated should be sent in reply to the specified message or story.
send_as (:obj:`InputPeer <hydrogram.raw.base.InputPeer>`, *optional*):
Open the web app as the specified peer, sending the resulting the message as the specified peer.
Returns:
:obj:`WebViewResult <hydrogram.raw.base.WebViewResult>`
"""
__slots__: List[str] = ["peer", "bot", "platform", "from_bot_menu", "silent", "url", "start_param", "theme_params", "reply_to", "send_as"]
ID = 0x269dc2c1
QUALNAME = "functions.messages.RequestWebView"
def __init__(self, *, peer: "raw.base.InputPeer", bot: "raw.base.InputUser", platform: str, from_bot_menu: Optional[bool] = None, silent: Optional[bool] = None, url: Optional[str] = None, start_param: Optional[str] = None, theme_params: "raw.base.DataJSON" = None, reply_to: "raw.base.InputReplyTo" = None, send_as: "raw.base.InputPeer" = None) -> None:
self.peer = peer # InputPeer
self.bot = bot # InputUser
self.platform = platform # string
self.from_bot_menu = from_bot_menu # flags.4?true
self.silent = silent # flags.5?true
self.url = url # flags.1?string
self.start_param = start_param # flags.3?string
self.theme_params = theme_params # flags.2?DataJSON
self.reply_to = reply_to # flags.0?InputReplyTo
self.send_as = send_as # flags.13?InputPeer
@staticmethod
def read(b: BytesIO, *args: Any) -> "RequestWebView":
flags = Int.read(b)
from_bot_menu = True if flags & (1 << 4) else False
silent = True if flags & (1 << 5) else False
peer = TLObject.read(b)
bot = TLObject.read(b)
url = String.read(b) if flags & (1 << 1) else None
start_param = String.read(b) if flags & (1 << 3) else None
theme_params = TLObject.read(b) if flags & (1 << 2) else None
platform = String.read(b)
reply_to = TLObject.read(b) if flags & (1 << 0) else None
send_as = TLObject.read(b) if flags & (1 << 13) else None
return RequestWebView(peer=peer, bot=bot, platform=platform, from_bot_menu=from_bot_menu, silent=silent, url=url, start_param=start_param, theme_params=theme_params, reply_to=reply_to, send_as=send_as)
def write(self, *args) -> bytes:
b = BytesIO()
b.write(Int(self.ID, False))
flags = 0
flags |= (1 << 4) if self.from_bot_menu else 0
flags |= (1 << 5) if self.silent else 0
flags |= (1 << 1) if self.url is not None else 0
flags |= (1 << 3) if self.start_param is not None else 0
flags |= (1 << 2) if self.theme_params is not None else 0
flags |= (1 << 0) if self.reply_to is not None else 0
flags |= (1 << 13) if self.send_as is not None else 0
b.write(Int(flags))
b.write(self.peer.write())
b.write(self.bot.write())
if self.url is not None:
b.write(String(self.url))
if self.start_param is not None:
b.write(String(self.start_param))
if self.theme_params is not None:
b.write(self.theme_params.write())
b.write(String(self.platform))
if self.reply_to is not None:
b.write(self.reply_to.write())
if self.send_as is not None:
b.write(self.send_as.write())
return b.getvalue()