telegrinder 0.3.0.post2__py3-none-any.whl → 0.3.2__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of telegrinder might be problematic. Click here for more details.
- telegrinder/__init__.py +144 -144
- telegrinder/api/__init__.py +8 -8
- telegrinder/api/api.py +93 -93
- telegrinder/api/error.py +16 -16
- telegrinder/api/response.py +20 -20
- telegrinder/api/token.py +36 -36
- telegrinder/bot/__init__.py +66 -66
- telegrinder/bot/bot.py +76 -76
- telegrinder/bot/cute_types/__init__.py +11 -11
- telegrinder/bot/cute_types/base.py +258 -234
- telegrinder/bot/cute_types/callback_query.py +382 -382
- telegrinder/bot/cute_types/chat_join_request.py +61 -61
- telegrinder/bot/cute_types/chat_member_updated.py +160 -160
- telegrinder/bot/cute_types/inline_query.py +53 -53
- telegrinder/bot/cute_types/message.py +2631 -2631
- telegrinder/bot/cute_types/update.py +75 -75
- telegrinder/bot/cute_types/utils.py +92 -92
- telegrinder/bot/dispatch/__init__.py +55 -55
- telegrinder/bot/dispatch/abc.py +77 -77
- telegrinder/bot/dispatch/context.py +92 -92
- telegrinder/bot/dispatch/dispatch.py +202 -201
- telegrinder/bot/dispatch/handler/__init__.py +13 -13
- telegrinder/bot/dispatch/handler/abc.py +24 -24
- telegrinder/bot/dispatch/handler/audio_reply.py +44 -44
- telegrinder/bot/dispatch/handler/base.py +57 -57
- telegrinder/bot/dispatch/handler/document_reply.py +44 -44
- telegrinder/bot/dispatch/handler/func.py +128 -123
- telegrinder/bot/dispatch/handler/media_group_reply.py +43 -43
- telegrinder/bot/dispatch/handler/message_reply.py +36 -36
- telegrinder/bot/dispatch/handler/photo_reply.py +44 -44
- telegrinder/bot/dispatch/handler/sticker_reply.py +37 -37
- telegrinder/bot/dispatch/handler/video_reply.py +44 -44
- telegrinder/bot/dispatch/middleware/__init__.py +3 -3
- telegrinder/bot/dispatch/middleware/abc.py +16 -16
- telegrinder/bot/dispatch/process.py +132 -132
- telegrinder/bot/dispatch/return_manager/__init__.py +13 -13
- telegrinder/bot/dispatch/return_manager/abc.py +108 -108
- telegrinder/bot/dispatch/return_manager/callback_query.py +20 -20
- telegrinder/bot/dispatch/return_manager/inline_query.py +15 -15
- telegrinder/bot/dispatch/return_manager/message.py +36 -36
- telegrinder/bot/dispatch/view/__init__.py +13 -13
- telegrinder/bot/dispatch/view/abc.py +41 -41
- telegrinder/bot/dispatch/view/base.py +200 -211
- telegrinder/bot/dispatch/view/box.py +129 -129
- telegrinder/bot/dispatch/view/callback_query.py +17 -17
- telegrinder/bot/dispatch/view/chat_join_request.py +16 -16
- telegrinder/bot/dispatch/view/chat_member.py +39 -39
- telegrinder/bot/dispatch/view/inline_query.py +17 -17
- telegrinder/bot/dispatch/view/message.py +44 -44
- telegrinder/bot/dispatch/view/raw.py +114 -118
- telegrinder/bot/dispatch/waiter_machine/__init__.py +17 -17
- telegrinder/bot/dispatch/waiter_machine/actions.py +13 -13
- telegrinder/bot/dispatch/waiter_machine/hasher/__init__.py +8 -8
- telegrinder/bot/dispatch/waiter_machine/hasher/callback.py +57 -57
- telegrinder/bot/dispatch/waiter_machine/hasher/hasher.py +57 -57
- telegrinder/bot/dispatch/waiter_machine/hasher/message.py +53 -53
- telegrinder/bot/dispatch/waiter_machine/hasher/state.py +19 -19
- telegrinder/bot/dispatch/waiter_machine/machine.py +168 -170
- telegrinder/bot/dispatch/waiter_machine/middleware.py +89 -89
- telegrinder/bot/dispatch/waiter_machine/short_state.py +65 -65
- telegrinder/bot/polling/__init__.py +4 -4
- telegrinder/bot/polling/abc.py +25 -25
- telegrinder/bot/polling/polling.py +131 -131
- telegrinder/bot/rules/__init__.py +62 -62
- telegrinder/bot/rules/abc.py +238 -233
- telegrinder/bot/rules/adapter/__init__.py +9 -9
- telegrinder/bot/rules/adapter/abc.py +29 -29
- telegrinder/bot/rules/adapter/errors.py +5 -5
- telegrinder/bot/rules/adapter/event.py +76 -76
- telegrinder/bot/rules/adapter/node.py +48 -48
- telegrinder/bot/rules/adapter/raw_update.py +30 -30
- telegrinder/bot/rules/callback_data.py +171 -171
- telegrinder/bot/rules/chat_join.py +48 -48
- telegrinder/bot/rules/command.py +126 -126
- telegrinder/bot/rules/enum_text.py +36 -33
- telegrinder/bot/rules/func.py +26 -26
- telegrinder/bot/rules/fuzzy.py +24 -24
- telegrinder/bot/rules/inline.py +60 -60
- telegrinder/bot/rules/integer.py +20 -20
- telegrinder/bot/rules/is_from.py +146 -146
- telegrinder/bot/rules/markup.py +43 -43
- telegrinder/bot/rules/mention.py +14 -14
- telegrinder/bot/rules/message.py +17 -17
- telegrinder/bot/rules/message_entities.py +35 -35
- telegrinder/bot/rules/node.py +27 -27
- telegrinder/bot/rules/regex.py +37 -37
- telegrinder/bot/rules/rule_enum.py +72 -72
- telegrinder/bot/rules/start.py +42 -42
- telegrinder/bot/rules/state.py +37 -37
- telegrinder/bot/rules/text.py +33 -33
- telegrinder/bot/rules/update.py +15 -15
- telegrinder/bot/scenario/__init__.py +5 -5
- telegrinder/bot/scenario/abc.py +19 -19
- telegrinder/bot/scenario/checkbox.py +167 -139
- telegrinder/bot/scenario/choice.py +46 -44
- telegrinder/client/__init__.py +4 -4
- telegrinder/client/abc.py +75 -75
- telegrinder/client/aiohttp.py +130 -130
- telegrinder/model.py +244 -244
- telegrinder/modules.py +237 -237
- telegrinder/msgspec_json.py +14 -14
- telegrinder/msgspec_utils.py +410 -410
- telegrinder/node/__init__.py +20 -20
- telegrinder/node/attachment.py +92 -92
- telegrinder/node/base.py +143 -144
- telegrinder/node/callback_query.py +14 -14
- telegrinder/node/command.py +33 -33
- telegrinder/node/composer.py +196 -184
- telegrinder/node/container.py +27 -27
- telegrinder/node/event.py +71 -73
- telegrinder/node/me.py +16 -16
- telegrinder/node/message.py +14 -14
- telegrinder/node/polymorphic.py +48 -52
- telegrinder/node/rule.py +76 -76
- telegrinder/node/scope.py +38 -38
- telegrinder/node/source.py +71 -71
- telegrinder/node/text.py +21 -21
- telegrinder/node/tools/__init__.py +3 -3
- telegrinder/node/tools/generator.py +40 -40
- telegrinder/node/update.py +15 -15
- telegrinder/rules.py +0 -0
- telegrinder/tools/__init__.py +74 -74
- telegrinder/tools/buttons.py +79 -79
- telegrinder/tools/error_handler/__init__.py +7 -7
- telegrinder/tools/error_handler/abc.py +33 -33
- telegrinder/tools/error_handler/error.py +9 -9
- telegrinder/tools/error_handler/error_handler.py +193 -193
- telegrinder/tools/formatting/__init__.py +46 -46
- telegrinder/tools/formatting/html.py +308 -308
- telegrinder/tools/formatting/links.py +33 -33
- telegrinder/tools/formatting/spec_html_formats.py +111 -111
- telegrinder/tools/functional.py +12 -12
- telegrinder/tools/global_context/__init__.py +7 -7
- telegrinder/tools/global_context/abc.py +63 -63
- telegrinder/tools/global_context/global_context.py +412 -412
- telegrinder/tools/global_context/telegrinder_ctx.py +27 -27
- telegrinder/tools/i18n/__init__.py +12 -12
- telegrinder/tools/i18n/abc.py +32 -32
- telegrinder/tools/i18n/middleware/__init__.py +3 -3
- telegrinder/tools/i18n/middleware/abc.py +25 -25
- telegrinder/tools/i18n/simple.py +43 -43
- telegrinder/tools/kb_set/__init__.py +4 -4
- telegrinder/tools/kb_set/base.py +15 -15
- telegrinder/tools/kb_set/yaml.py +63 -63
- telegrinder/tools/keyboard.py +128 -128
- telegrinder/tools/limited_dict.py +37 -37
- telegrinder/tools/loop_wrapper/__init__.py +4 -4
- telegrinder/tools/loop_wrapper/abc.py +15 -15
- telegrinder/tools/loop_wrapper/loop_wrapper.py +216 -216
- telegrinder/tools/magic.py +168 -164
- telegrinder/tools/parse_mode.py +6 -6
- telegrinder/tools/state_storage/__init__.py +4 -4
- telegrinder/tools/state_storage/abc.py +35 -35
- telegrinder/tools/state_storage/memory.py +25 -25
- telegrinder/types/__init__.py +6 -6
- telegrinder/types/enums.py +672 -672
- telegrinder/types/methods.py +4633 -4633
- telegrinder/types/objects.py +6317 -6317
- telegrinder/verification_utils.py +32 -32
- {telegrinder-0.3.0.post2.dist-info → telegrinder-0.3.2.dist-info}/LICENSE +22 -22
- {telegrinder-0.3.0.post2.dist-info → telegrinder-0.3.2.dist-info}/METADATA +1 -1
- telegrinder-0.3.2.dist-info/RECORD +164 -0
- telegrinder-0.3.0.post2.dist-info/RECORD +0 -164
- {telegrinder-0.3.0.post2.dist-info → telegrinder-0.3.2.dist-info}/WHEEL +0 -0
|
@@ -1,75 +1,75 @@
|
|
|
1
|
-
import typing
|
|
2
|
-
from functools import cached_property
|
|
3
|
-
|
|
4
|
-
from fntypes.co import Nothing, Some
|
|
5
|
-
|
|
6
|
-
from telegrinder.api.api import API
|
|
7
|
-
from telegrinder.bot.cute_types.base import BaseCute
|
|
8
|
-
from telegrinder.bot.cute_types.callback_query import CallbackQueryCute
|
|
9
|
-
from telegrinder.bot.cute_types.chat_join_request import ChatJoinRequestCute
|
|
10
|
-
from telegrinder.bot.cute_types.chat_member_updated import ChatMemberUpdatedCute
|
|
11
|
-
from telegrinder.bot.cute_types.inline_query import InlineQueryCute
|
|
12
|
-
from telegrinder.bot.cute_types.message import MessageCute
|
|
13
|
-
from telegrinder.msgspec_utils import Option
|
|
14
|
-
from telegrinder.types.objects import *
|
|
15
|
-
|
|
16
|
-
EventModel = typing.TypeVar("EventModel", bound=Model)
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
class UpdateCute(BaseCute[Update], Update, kw_only=True):
|
|
20
|
-
api: API
|
|
21
|
-
|
|
22
|
-
message: Option[MessageCute] = Nothing()
|
|
23
|
-
"""Optional. New incoming message of any kind - text, photo, sticker, etc."""
|
|
24
|
-
|
|
25
|
-
edited_message: Option[MessageCute] = Nothing()
|
|
26
|
-
"""Optional. New version of a message that is known to the bot and was edited.
|
|
27
|
-
This update may at times be triggered by changes to message fields that are
|
|
28
|
-
either unavailable or not actively used by your bot."""
|
|
29
|
-
|
|
30
|
-
channel_post: Option[MessageCute] = Nothing()
|
|
31
|
-
"""Optional. New incoming channel post of any kind - text, photo, sticker,
|
|
32
|
-
etc."""
|
|
33
|
-
|
|
34
|
-
edited_channel_post: Option[MessageCute] = Nothing()
|
|
35
|
-
"""Optional. New version of a channel post that is known to the bot and was edited.
|
|
36
|
-
This update may at times be triggered by changes to message fields that are
|
|
37
|
-
either unavailable or not actively used by your bot."""
|
|
38
|
-
|
|
39
|
-
business_message: Option[MessageCute] = Nothing()
|
|
40
|
-
"""Optional. New message from a connected business account."""
|
|
41
|
-
|
|
42
|
-
edited_business_message: Option[MessageCute] = Nothing()
|
|
43
|
-
"""Optional. New version of a message from a connected business account."""
|
|
44
|
-
|
|
45
|
-
inline_query: Option[InlineQueryCute] = Nothing()
|
|
46
|
-
"""Optional. New incoming inline query."""
|
|
47
|
-
|
|
48
|
-
callback_query: Option[CallbackQueryCute] = Nothing()
|
|
49
|
-
"""Optional. New incoming callback query."""
|
|
50
|
-
|
|
51
|
-
my_chat_member: Option[ChatMemberUpdatedCute] = Nothing()
|
|
52
|
-
"""Optional. The bot's chat member status was updated in a chat. For private
|
|
53
|
-
chats, this update is received only when the bot is blocked or unblocked
|
|
54
|
-
by the user."""
|
|
55
|
-
|
|
56
|
-
chat_member: Option[ChatMemberUpdatedCute] = Nothing()
|
|
57
|
-
"""Optional. A chat member's status was updated in a chat. The bot must be an
|
|
58
|
-
administrator in the chat and must explicitly specify `chat_member` in
|
|
59
|
-
the list of allowed_updates to receive these updates."""
|
|
60
|
-
|
|
61
|
-
chat_join_request: Option[ChatJoinRequestCute] = Nothing()
|
|
62
|
-
"""Optional. A request to join the chat has been sent. The bot must have the can_invite_users
|
|
63
|
-
administrator right in the chat to receive these updates."""
|
|
64
|
-
|
|
65
|
-
@cached_property
|
|
66
|
-
def incoming_update(self) -> Model:
|
|
67
|
-
return getattr(self, self.update_type.value).unwrap()
|
|
68
|
-
|
|
69
|
-
def get_event(self, event_model: type[EventModel]) -> Option[EventModel]:
|
|
70
|
-
if isinstance(self.incoming_update, event_model):
|
|
71
|
-
return Some(self.incoming_update)
|
|
72
|
-
return Nothing()
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
__all__ = ("UpdateCute",)
|
|
1
|
+
import typing
|
|
2
|
+
from functools import cached_property
|
|
3
|
+
|
|
4
|
+
from fntypes.co import Nothing, Some
|
|
5
|
+
|
|
6
|
+
from telegrinder.api.api import API
|
|
7
|
+
from telegrinder.bot.cute_types.base import BaseCute
|
|
8
|
+
from telegrinder.bot.cute_types.callback_query import CallbackQueryCute
|
|
9
|
+
from telegrinder.bot.cute_types.chat_join_request import ChatJoinRequestCute
|
|
10
|
+
from telegrinder.bot.cute_types.chat_member_updated import ChatMemberUpdatedCute
|
|
11
|
+
from telegrinder.bot.cute_types.inline_query import InlineQueryCute
|
|
12
|
+
from telegrinder.bot.cute_types.message import MessageCute
|
|
13
|
+
from telegrinder.msgspec_utils import Option
|
|
14
|
+
from telegrinder.types.objects import *
|
|
15
|
+
|
|
16
|
+
EventModel = typing.TypeVar("EventModel", bound=Model)
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
class UpdateCute(BaseCute[Update], Update, kw_only=True):
|
|
20
|
+
api: API
|
|
21
|
+
|
|
22
|
+
message: Option[MessageCute] = Nothing()
|
|
23
|
+
"""Optional. New incoming message of any kind - text, photo, sticker, etc."""
|
|
24
|
+
|
|
25
|
+
edited_message: Option[MessageCute] = Nothing()
|
|
26
|
+
"""Optional. New version of a message that is known to the bot and was edited.
|
|
27
|
+
This update may at times be triggered by changes to message fields that are
|
|
28
|
+
either unavailable or not actively used by your bot."""
|
|
29
|
+
|
|
30
|
+
channel_post: Option[MessageCute] = Nothing()
|
|
31
|
+
"""Optional. New incoming channel post of any kind - text, photo, sticker,
|
|
32
|
+
etc."""
|
|
33
|
+
|
|
34
|
+
edited_channel_post: Option[MessageCute] = Nothing()
|
|
35
|
+
"""Optional. New version of a channel post that is known to the bot and was edited.
|
|
36
|
+
This update may at times be triggered by changes to message fields that are
|
|
37
|
+
either unavailable or not actively used by your bot."""
|
|
38
|
+
|
|
39
|
+
business_message: Option[MessageCute] = Nothing()
|
|
40
|
+
"""Optional. New message from a connected business account."""
|
|
41
|
+
|
|
42
|
+
edited_business_message: Option[MessageCute] = Nothing()
|
|
43
|
+
"""Optional. New version of a message from a connected business account."""
|
|
44
|
+
|
|
45
|
+
inline_query: Option[InlineQueryCute] = Nothing()
|
|
46
|
+
"""Optional. New incoming inline query."""
|
|
47
|
+
|
|
48
|
+
callback_query: Option[CallbackQueryCute] = Nothing()
|
|
49
|
+
"""Optional. New incoming callback query."""
|
|
50
|
+
|
|
51
|
+
my_chat_member: Option[ChatMemberUpdatedCute] = Nothing()
|
|
52
|
+
"""Optional. The bot's chat member status was updated in a chat. For private
|
|
53
|
+
chats, this update is received only when the bot is blocked or unblocked
|
|
54
|
+
by the user."""
|
|
55
|
+
|
|
56
|
+
chat_member: Option[ChatMemberUpdatedCute] = Nothing()
|
|
57
|
+
"""Optional. A chat member's status was updated in a chat. The bot must be an
|
|
58
|
+
administrator in the chat and must explicitly specify `chat_member` in
|
|
59
|
+
the list of allowed_updates to receive these updates."""
|
|
60
|
+
|
|
61
|
+
chat_join_request: Option[ChatJoinRequestCute] = Nothing()
|
|
62
|
+
"""Optional. A request to join the chat has been sent. The bot must have the can_invite_users
|
|
63
|
+
administrator right in the chat to receive these updates."""
|
|
64
|
+
|
|
65
|
+
@cached_property
|
|
66
|
+
def incoming_update(self) -> Model:
|
|
67
|
+
return getattr(self, self.update_type.value).unwrap()
|
|
68
|
+
|
|
69
|
+
def get_event(self, event_model: type[EventModel]) -> Option[EventModel]:
|
|
70
|
+
if isinstance(self.incoming_update, event_model):
|
|
71
|
+
return Some(self.incoming_update)
|
|
72
|
+
return Nothing()
|
|
73
|
+
|
|
74
|
+
|
|
75
|
+
__all__ = ("UpdateCute",)
|
|
@@ -1,95 +1,95 @@
|
|
|
1
|
-
import typing
|
|
2
|
-
|
|
3
|
-
from telegrinder.model import get_params
|
|
4
|
-
from telegrinder.types.objects import (
|
|
5
|
-
InputFile,
|
|
6
|
-
InputMediaAnimation,
|
|
7
|
-
InputMediaAudio,
|
|
8
|
-
InputMediaDocument,
|
|
9
|
-
InputMediaPhoto,
|
|
10
|
-
InputMediaVideo,
|
|
11
|
-
LinkPreviewOptions,
|
|
12
|
-
MessageEntity,
|
|
13
|
-
ReactionEmoji,
|
|
14
|
-
ReactionType,
|
|
15
|
-
ReactionTypeEmoji,
|
|
16
|
-
ReplyParameters,
|
|
17
|
-
)
|
|
18
|
-
|
|
19
|
-
InputMedia: typing.TypeAlias = typing.Union[
|
|
20
|
-
InputMediaAnimation,
|
|
21
|
-
InputMediaAudio,
|
|
22
|
-
InputMediaDocument,
|
|
23
|
-
InputMediaPhoto,
|
|
24
|
-
InputMediaVideo,
|
|
25
|
-
]
|
|
26
|
-
|
|
27
|
-
INPUT_MEDIA_TYPES: typing.Final[dict[str, type[InputMedia]]] = {
|
|
28
|
-
"animation": InputMediaAnimation,
|
|
29
|
-
"audio": InputMediaAudio,
|
|
30
|
-
"document": InputMediaDocument,
|
|
31
|
-
"photo": InputMediaPhoto,
|
|
32
|
-
"video": InputMediaVideo,
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
def compose_reactions(
|
|
37
|
-
reactions: str | ReactionEmoji | ReactionType | list[str | ReactionEmoji | ReactionType],
|
|
38
|
-
/,
|
|
39
|
-
) -> list[ReactionType]:
|
|
40
|
-
if not isinstance(reactions, list):
|
|
41
|
-
reactions = [reactions]
|
|
42
|
-
return [
|
|
43
|
-
(
|
|
44
|
-
ReactionTypeEmoji("emoji", emoji)
|
|
45
|
-
if isinstance(emoji, ReactionEmoji)
|
|
46
|
-
else (ReactionTypeEmoji("emoji", ReactionEmoji(emoji)) if isinstance(emoji, str) else emoji)
|
|
47
|
-
)
|
|
48
|
-
for emoji in ([reactions] if isinstance(reactions, str) else reactions) # type: ignore
|
|
49
|
-
]
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
def compose_reply_params(
|
|
53
|
-
message_id: int | None,
|
|
54
|
-
chat_id: int | str | None,
|
|
55
|
-
*,
|
|
56
|
-
allow_sending_without_reply: bool | None = None,
|
|
57
|
-
quote: str | None = None,
|
|
58
|
-
quote_parse_mode: str | None = None,
|
|
59
|
-
quote_entities: list[MessageEntity] | None = None,
|
|
60
|
-
quote_position: int | None = None,
|
|
61
|
-
**other: typing.Any,
|
|
62
|
-
) -> ReplyParameters:
|
|
63
|
-
return ReplyParameters(**get_params(locals()))
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
def compose_link_preview_options(
|
|
67
|
-
*,
|
|
68
|
-
is_disabled: bool | None = None,
|
|
69
|
-
url: str | None = None,
|
|
70
|
-
prefer_small_media: bool | None = None,
|
|
71
|
-
prefer_large_media: bool | None = None,
|
|
72
|
-
show_above_text: bool | None = None,
|
|
73
|
-
**other: typing.Any,
|
|
74
|
-
) -> LinkPreviewOptions:
|
|
75
|
-
return LinkPreviewOptions(**get_params(locals()))
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
def input_media(
|
|
79
|
-
type: typing.Literal["animation", "audio", "document", "photo", "video"],
|
|
80
|
-
media: str | InputFile,
|
|
81
|
-
*,
|
|
82
|
-
caption: str | None = None,
|
|
83
|
-
parse_mode: str | None = None,
|
|
84
|
-
caption_entities: list[MessageEntity] | None = None,
|
|
85
|
-
**other: typing.Any,
|
|
86
|
-
) -> InputMedia:
|
|
87
|
-
return INPUT_MEDIA_TYPES[type](**get_params(locals()))
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
__all__ = (
|
|
1
|
+
import typing
|
|
2
|
+
|
|
3
|
+
from telegrinder.model import get_params
|
|
4
|
+
from telegrinder.types.objects import (
|
|
5
|
+
InputFile,
|
|
6
|
+
InputMediaAnimation,
|
|
7
|
+
InputMediaAudio,
|
|
8
|
+
InputMediaDocument,
|
|
9
|
+
InputMediaPhoto,
|
|
10
|
+
InputMediaVideo,
|
|
11
|
+
LinkPreviewOptions,
|
|
12
|
+
MessageEntity,
|
|
13
|
+
ReactionEmoji,
|
|
14
|
+
ReactionType,
|
|
15
|
+
ReactionTypeEmoji,
|
|
16
|
+
ReplyParameters,
|
|
17
|
+
)
|
|
18
|
+
|
|
19
|
+
InputMedia: typing.TypeAlias = typing.Union[
|
|
20
|
+
InputMediaAnimation,
|
|
21
|
+
InputMediaAudio,
|
|
22
|
+
InputMediaDocument,
|
|
23
|
+
InputMediaPhoto,
|
|
24
|
+
InputMediaVideo,
|
|
25
|
+
]
|
|
26
|
+
|
|
27
|
+
INPUT_MEDIA_TYPES: typing.Final[dict[str, type[InputMedia]]] = {
|
|
28
|
+
"animation": InputMediaAnimation,
|
|
29
|
+
"audio": InputMediaAudio,
|
|
30
|
+
"document": InputMediaDocument,
|
|
31
|
+
"photo": InputMediaPhoto,
|
|
32
|
+
"video": InputMediaVideo,
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
|
|
36
|
+
def compose_reactions(
|
|
37
|
+
reactions: str | ReactionEmoji | ReactionType | list[str | ReactionEmoji | ReactionType],
|
|
38
|
+
/,
|
|
39
|
+
) -> list[ReactionType]:
|
|
40
|
+
if not isinstance(reactions, list):
|
|
41
|
+
reactions = [reactions]
|
|
42
|
+
return [
|
|
43
|
+
(
|
|
44
|
+
ReactionTypeEmoji("emoji", emoji)
|
|
45
|
+
if isinstance(emoji, ReactionEmoji)
|
|
46
|
+
else (ReactionTypeEmoji("emoji", ReactionEmoji(emoji)) if isinstance(emoji, str) else emoji)
|
|
47
|
+
)
|
|
48
|
+
for emoji in ([reactions] if isinstance(reactions, str) else reactions) # type: ignore
|
|
49
|
+
]
|
|
50
|
+
|
|
51
|
+
|
|
52
|
+
def compose_reply_params(
|
|
53
|
+
message_id: int | None,
|
|
54
|
+
chat_id: int | str | None,
|
|
55
|
+
*,
|
|
56
|
+
allow_sending_without_reply: bool | None = None,
|
|
57
|
+
quote: str | None = None,
|
|
58
|
+
quote_parse_mode: str | None = None,
|
|
59
|
+
quote_entities: list[MessageEntity] | None = None,
|
|
60
|
+
quote_position: int | None = None,
|
|
61
|
+
**other: typing.Any,
|
|
62
|
+
) -> ReplyParameters:
|
|
63
|
+
return ReplyParameters(**get_params(locals()))
|
|
64
|
+
|
|
65
|
+
|
|
66
|
+
def compose_link_preview_options(
|
|
67
|
+
*,
|
|
68
|
+
is_disabled: bool | None = None,
|
|
69
|
+
url: str | None = None,
|
|
70
|
+
prefer_small_media: bool | None = None,
|
|
71
|
+
prefer_large_media: bool | None = None,
|
|
72
|
+
show_above_text: bool | None = None,
|
|
73
|
+
**other: typing.Any,
|
|
74
|
+
) -> LinkPreviewOptions:
|
|
75
|
+
return LinkPreviewOptions(**get_params(locals()))
|
|
76
|
+
|
|
77
|
+
|
|
78
|
+
def input_media(
|
|
79
|
+
type: typing.Literal["animation", "audio", "document", "photo", "video"],
|
|
80
|
+
media: str | InputFile,
|
|
81
|
+
*,
|
|
82
|
+
caption: str | None = None,
|
|
83
|
+
parse_mode: str | None = None,
|
|
84
|
+
caption_entities: list[MessageEntity] | None = None,
|
|
85
|
+
**other: typing.Any,
|
|
86
|
+
) -> InputMedia:
|
|
87
|
+
return INPUT_MEDIA_TYPES[type](**get_params(locals()))
|
|
88
|
+
|
|
89
|
+
|
|
90
|
+
__all__ = (
|
|
91
91
|
"compose_link_preview_options",
|
|
92
92
|
"compose_reactions",
|
|
93
93
|
"compose_reply_params",
|
|
94
|
-
"input_media",
|
|
95
|
-
)
|
|
94
|
+
"input_media",
|
|
95
|
+
)
|
|
@@ -1,56 +1,56 @@
|
|
|
1
|
-
from telegrinder.bot.dispatch.abc import ABCDispatch
|
|
2
|
-
from telegrinder.bot.dispatch.context import Context
|
|
3
|
-
from telegrinder.bot.dispatch.dispatch import Dispatch, TelegrinderContext
|
|
4
|
-
from telegrinder.bot.dispatch.handler import (
|
|
5
|
-
ABCHandler,
|
|
6
|
-
AudioReplyHandler,
|
|
7
|
-
DocumentReplyHandler,
|
|
8
|
-
FuncHandler,
|
|
9
|
-
MediaGroupReplyHandler,
|
|
10
|
-
MessageReplyHandler,
|
|
11
|
-
PhotoReplyHandler,
|
|
12
|
-
StickerReplyHandler,
|
|
13
|
-
VideoReplyHandler,
|
|
14
|
-
)
|
|
15
|
-
from telegrinder.bot.dispatch.middleware import ABCMiddleware
|
|
16
|
-
from telegrinder.bot.dispatch.process import check_rule, process_inner
|
|
17
|
-
from telegrinder.bot.dispatch.return_manager import (
|
|
18
|
-
ABCReturnManager,
|
|
19
|
-
BaseReturnManager,
|
|
20
|
-
CallbackQueryReturnManager,
|
|
21
|
-
InlineQueryReturnManager,
|
|
22
|
-
Manager,
|
|
23
|
-
MessageReturnManager,
|
|
24
|
-
register_manager,
|
|
25
|
-
)
|
|
26
|
-
from telegrinder.bot.dispatch.view import (
|
|
27
|
-
ABCStateView,
|
|
28
|
-
ABCView,
|
|
29
|
-
BaseStateView,
|
|
30
|
-
BaseView,
|
|
31
|
-
CallbackQueryView,
|
|
32
|
-
ChatJoinRequestView,
|
|
33
|
-
ChatMemberView,
|
|
34
|
-
InlineQueryView,
|
|
35
|
-
MessageView,
|
|
36
|
-
RawEventView,
|
|
37
|
-
ViewBox,
|
|
38
|
-
)
|
|
39
|
-
from telegrinder.bot.dispatch.waiter_machine import (
|
|
40
|
-
CALLBACK_QUERY_FOR_MESSAGE,
|
|
41
|
-
CALLBACK_QUERY_FROM_CHAT,
|
|
42
|
-
CALLBACK_QUERY_IN_CHAT_FOR_MESSAGE,
|
|
43
|
-
MESSAGE_FROM_USER,
|
|
44
|
-
MESSAGE_FROM_USER_IN_CHAT,
|
|
45
|
-
MESSAGE_IN_CHAT,
|
|
46
|
-
Hasher,
|
|
47
|
-
ShortState,
|
|
48
|
-
StateViewHasher,
|
|
49
|
-
WaiterMachine,
|
|
50
|
-
clear_wm_storage_worker,
|
|
51
|
-
)
|
|
52
|
-
|
|
53
|
-
__all__ = (
|
|
1
|
+
from telegrinder.bot.dispatch.abc import ABCDispatch
|
|
2
|
+
from telegrinder.bot.dispatch.context import Context
|
|
3
|
+
from telegrinder.bot.dispatch.dispatch import Dispatch, TelegrinderContext
|
|
4
|
+
from telegrinder.bot.dispatch.handler import (
|
|
5
|
+
ABCHandler,
|
|
6
|
+
AudioReplyHandler,
|
|
7
|
+
DocumentReplyHandler,
|
|
8
|
+
FuncHandler,
|
|
9
|
+
MediaGroupReplyHandler,
|
|
10
|
+
MessageReplyHandler,
|
|
11
|
+
PhotoReplyHandler,
|
|
12
|
+
StickerReplyHandler,
|
|
13
|
+
VideoReplyHandler,
|
|
14
|
+
)
|
|
15
|
+
from telegrinder.bot.dispatch.middleware import ABCMiddleware
|
|
16
|
+
from telegrinder.bot.dispatch.process import check_rule, process_inner
|
|
17
|
+
from telegrinder.bot.dispatch.return_manager import (
|
|
18
|
+
ABCReturnManager,
|
|
19
|
+
BaseReturnManager,
|
|
20
|
+
CallbackQueryReturnManager,
|
|
21
|
+
InlineQueryReturnManager,
|
|
22
|
+
Manager,
|
|
23
|
+
MessageReturnManager,
|
|
24
|
+
register_manager,
|
|
25
|
+
)
|
|
26
|
+
from telegrinder.bot.dispatch.view import (
|
|
27
|
+
ABCStateView,
|
|
28
|
+
ABCView,
|
|
29
|
+
BaseStateView,
|
|
30
|
+
BaseView,
|
|
31
|
+
CallbackQueryView,
|
|
32
|
+
ChatJoinRequestView,
|
|
33
|
+
ChatMemberView,
|
|
34
|
+
InlineQueryView,
|
|
35
|
+
MessageView,
|
|
36
|
+
RawEventView,
|
|
37
|
+
ViewBox,
|
|
38
|
+
)
|
|
39
|
+
from telegrinder.bot.dispatch.waiter_machine import (
|
|
40
|
+
CALLBACK_QUERY_FOR_MESSAGE,
|
|
41
|
+
CALLBACK_QUERY_FROM_CHAT,
|
|
42
|
+
CALLBACK_QUERY_IN_CHAT_FOR_MESSAGE,
|
|
43
|
+
MESSAGE_FROM_USER,
|
|
44
|
+
MESSAGE_FROM_USER_IN_CHAT,
|
|
45
|
+
MESSAGE_IN_CHAT,
|
|
46
|
+
Hasher,
|
|
47
|
+
ShortState,
|
|
48
|
+
StateViewHasher,
|
|
49
|
+
WaiterMachine,
|
|
50
|
+
clear_wm_storage_worker,
|
|
51
|
+
)
|
|
52
|
+
|
|
53
|
+
__all__ = (
|
|
54
54
|
"ABCDispatch",
|
|
55
55
|
"ABCHandler",
|
|
56
56
|
"ABCMiddleware",
|
|
@@ -96,5 +96,5 @@ __all__ = (
|
|
|
96
96
|
"clear_wm_storage_worker",
|
|
97
97
|
"clear_wm_storage_worker",
|
|
98
98
|
"process_inner",
|
|
99
|
-
"register_manager",
|
|
100
|
-
)
|
|
99
|
+
"register_manager",
|
|
100
|
+
)
|
telegrinder/bot/dispatch/abc.py
CHANGED
|
@@ -1,77 +1,77 @@
|
|
|
1
|
-
import importlib.util as importlib_util
|
|
2
|
-
import os
|
|
3
|
-
import pathlib
|
|
4
|
-
import sys
|
|
5
|
-
import typing
|
|
6
|
-
from abc import ABC, abstractmethod
|
|
7
|
-
|
|
8
|
-
from fntypes.option import Option
|
|
9
|
-
|
|
10
|
-
from telegrinder.api.api import API
|
|
11
|
-
from telegrinder.tools.global_context.abc import ABCGlobalContext
|
|
12
|
-
from telegrinder.types.objects import Update
|
|
13
|
-
|
|
14
|
-
T = typing.TypeVar("T")
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
class PathExistsError(BaseException):
|
|
18
|
-
pass
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
class ABCDispatch(ABC):
|
|
22
|
-
@property
|
|
23
|
-
@abstractmethod
|
|
24
|
-
def global_context(self) -> ABCGlobalContext:
|
|
25
|
-
pass
|
|
26
|
-
|
|
27
|
-
@abstractmethod
|
|
28
|
-
async def feed(self, event: Update, api: API) -> bool:
|
|
29
|
-
pass
|
|
30
|
-
|
|
31
|
-
@abstractmethod
|
|
32
|
-
def load(self, external: typing.Self) -> None:
|
|
33
|
-
pass
|
|
34
|
-
|
|
35
|
-
@abstractmethod
|
|
36
|
-
def get_view(self, of_type: type[T]) -> Option[T]:
|
|
37
|
-
pass
|
|
38
|
-
|
|
39
|
-
def load_many(self, *externals: typing.Self) -> None:
|
|
40
|
-
for external in externals:
|
|
41
|
-
self.load(external)
|
|
42
|
-
|
|
43
|
-
def load_from_dir(self, directory: str | pathlib.Path) -> bool:
|
|
44
|
-
"""Loads dispatchers from a directory containing Python modules where global variables
|
|
45
|
-
are declared with instances of dispatch.
|
|
46
|
-
Returns True if dispatchers were found, otherwise False."""
|
|
47
|
-
|
|
48
|
-
directory = pathlib.Path(directory)
|
|
49
|
-
|
|
50
|
-
if not directory.exists():
|
|
51
|
-
raise PathExistsError(f"Path {str(directory)!r} does not exists.")
|
|
52
|
-
|
|
53
|
-
dps: list[typing.Self] = []
|
|
54
|
-
for root, _, files in os.walk(directory):
|
|
55
|
-
for f in files:
|
|
56
|
-
if f.endswith(".py") and f != "__init__.py":
|
|
57
|
-
module_path = os.path.join(root, f)
|
|
58
|
-
module_name = os.path.splitext(os.path.relpath(module_path, directory))[0]
|
|
59
|
-
module_name = module_name.replace(os.sep, ".")
|
|
60
|
-
|
|
61
|
-
spec = importlib_util.spec_from_file_location(module_name, module_path)
|
|
62
|
-
if spec is None or spec.loader is None:
|
|
63
|
-
continue
|
|
64
|
-
|
|
65
|
-
module = importlib_util.module_from_spec(spec)
|
|
66
|
-
sys.modules[module_name] = module
|
|
67
|
-
spec.loader.exec_module(module)
|
|
68
|
-
|
|
69
|
-
for obj in module.__dict__.values():
|
|
70
|
-
if isinstance(obj, self.__class__):
|
|
71
|
-
dps.append(obj)
|
|
72
|
-
|
|
73
|
-
self.load_many(*dps)
|
|
74
|
-
return bool(dps)
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
__all__ = ("ABCDispatch",)
|
|
1
|
+
import importlib.util as importlib_util
|
|
2
|
+
import os
|
|
3
|
+
import pathlib
|
|
4
|
+
import sys
|
|
5
|
+
import typing
|
|
6
|
+
from abc import ABC, abstractmethod
|
|
7
|
+
|
|
8
|
+
from fntypes.option import Option
|
|
9
|
+
|
|
10
|
+
from telegrinder.api.api import API
|
|
11
|
+
from telegrinder.tools.global_context.abc import ABCGlobalContext
|
|
12
|
+
from telegrinder.types.objects import Update
|
|
13
|
+
|
|
14
|
+
T = typing.TypeVar("T")
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
class PathExistsError(BaseException):
|
|
18
|
+
pass
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
class ABCDispatch(ABC):
|
|
22
|
+
@property
|
|
23
|
+
@abstractmethod
|
|
24
|
+
def global_context(self) -> ABCGlobalContext:
|
|
25
|
+
pass
|
|
26
|
+
|
|
27
|
+
@abstractmethod
|
|
28
|
+
async def feed(self, event: Update, api: API) -> bool:
|
|
29
|
+
pass
|
|
30
|
+
|
|
31
|
+
@abstractmethod
|
|
32
|
+
def load(self, external: typing.Self) -> None:
|
|
33
|
+
pass
|
|
34
|
+
|
|
35
|
+
@abstractmethod
|
|
36
|
+
def get_view(self, of_type: type[T]) -> Option[T]:
|
|
37
|
+
pass
|
|
38
|
+
|
|
39
|
+
def load_many(self, *externals: typing.Self) -> None:
|
|
40
|
+
for external in externals:
|
|
41
|
+
self.load(external)
|
|
42
|
+
|
|
43
|
+
def load_from_dir(self, directory: str | pathlib.Path) -> bool:
|
|
44
|
+
"""Loads dispatchers from a directory containing Python modules where global variables
|
|
45
|
+
are declared with instances of dispatch.
|
|
46
|
+
Returns True if dispatchers were found, otherwise False."""
|
|
47
|
+
|
|
48
|
+
directory = pathlib.Path(directory)
|
|
49
|
+
|
|
50
|
+
if not directory.exists():
|
|
51
|
+
raise PathExistsError(f"Path {str(directory)!r} does not exists.")
|
|
52
|
+
|
|
53
|
+
dps: list[typing.Self] = []
|
|
54
|
+
for root, _, files in os.walk(directory):
|
|
55
|
+
for f in files:
|
|
56
|
+
if f.endswith(".py") and f != "__init__.py":
|
|
57
|
+
module_path = os.path.join(root, f)
|
|
58
|
+
module_name = os.path.splitext(os.path.relpath(module_path, directory))[0]
|
|
59
|
+
module_name = module_name.replace(os.sep, ".")
|
|
60
|
+
|
|
61
|
+
spec = importlib_util.spec_from_file_location(module_name, module_path)
|
|
62
|
+
if spec is None or spec.loader is None:
|
|
63
|
+
continue
|
|
64
|
+
|
|
65
|
+
module = importlib_util.module_from_spec(spec)
|
|
66
|
+
sys.modules[module_name] = module
|
|
67
|
+
spec.loader.exec_module(module)
|
|
68
|
+
|
|
69
|
+
for obj in module.__dict__.values():
|
|
70
|
+
if isinstance(obj, self.__class__):
|
|
71
|
+
dps.append(obj)
|
|
72
|
+
|
|
73
|
+
self.load_many(*dps)
|
|
74
|
+
return bool(dps)
|
|
75
|
+
|
|
76
|
+
|
|
77
|
+
__all__ = ("ABCDispatch",)
|