telegrinder 0.3.1__py3-none-any.whl → 0.3.3__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.

Files changed (164) hide show
  1. telegrinder/__init__.py +144 -144
  2. telegrinder/api/__init__.py +8 -8
  3. telegrinder/api/api.py +93 -93
  4. telegrinder/api/error.py +16 -16
  5. telegrinder/api/response.py +20 -20
  6. telegrinder/api/token.py +36 -36
  7. telegrinder/bot/__init__.py +66 -66
  8. telegrinder/bot/bot.py +76 -76
  9. telegrinder/bot/cute_types/__init__.py +17 -17
  10. telegrinder/bot/cute_types/base.py +258 -234
  11. telegrinder/bot/cute_types/callback_query.py +385 -382
  12. telegrinder/bot/cute_types/chat_join_request.py +61 -61
  13. telegrinder/bot/cute_types/chat_member_updated.py +160 -160
  14. telegrinder/bot/cute_types/inline_query.py +43 -53
  15. telegrinder/bot/cute_types/message.py +2637 -2631
  16. telegrinder/bot/cute_types/update.py +109 -75
  17. telegrinder/bot/cute_types/utils.py +95 -95
  18. telegrinder/bot/dispatch/__init__.py +55 -55
  19. telegrinder/bot/dispatch/abc.py +77 -77
  20. telegrinder/bot/dispatch/context.py +98 -92
  21. telegrinder/bot/dispatch/dispatch.py +202 -201
  22. telegrinder/bot/dispatch/handler/__init__.py +13 -13
  23. telegrinder/bot/dispatch/handler/abc.py +24 -24
  24. telegrinder/bot/dispatch/handler/audio_reply.py +44 -44
  25. telegrinder/bot/dispatch/handler/base.py +57 -57
  26. telegrinder/bot/dispatch/handler/document_reply.py +44 -44
  27. telegrinder/bot/dispatch/handler/func.py +135 -123
  28. telegrinder/bot/dispatch/handler/media_group_reply.py +43 -43
  29. telegrinder/bot/dispatch/handler/message_reply.py +36 -36
  30. telegrinder/bot/dispatch/handler/photo_reply.py +44 -44
  31. telegrinder/bot/dispatch/handler/sticker_reply.py +37 -37
  32. telegrinder/bot/dispatch/handler/video_reply.py +44 -44
  33. telegrinder/bot/dispatch/middleware/__init__.py +3 -3
  34. telegrinder/bot/dispatch/middleware/abc.py +16 -16
  35. telegrinder/bot/dispatch/process.py +132 -132
  36. telegrinder/bot/dispatch/return_manager/__init__.py +13 -13
  37. telegrinder/bot/dispatch/return_manager/abc.py +108 -108
  38. telegrinder/bot/dispatch/return_manager/callback_query.py +20 -20
  39. telegrinder/bot/dispatch/return_manager/inline_query.py +15 -15
  40. telegrinder/bot/dispatch/return_manager/message.py +36 -36
  41. telegrinder/bot/dispatch/view/__init__.py +13 -13
  42. telegrinder/bot/dispatch/view/abc.py +41 -41
  43. telegrinder/bot/dispatch/view/base.py +200 -211
  44. telegrinder/bot/dispatch/view/box.py +129 -129
  45. telegrinder/bot/dispatch/view/callback_query.py +17 -17
  46. telegrinder/bot/dispatch/view/chat_join_request.py +16 -16
  47. telegrinder/bot/dispatch/view/chat_member.py +39 -39
  48. telegrinder/bot/dispatch/view/inline_query.py +17 -17
  49. telegrinder/bot/dispatch/view/message.py +44 -44
  50. telegrinder/bot/dispatch/view/raw.py +114 -118
  51. telegrinder/bot/dispatch/waiter_machine/__init__.py +17 -17
  52. telegrinder/bot/dispatch/waiter_machine/actions.py +13 -13
  53. telegrinder/bot/dispatch/waiter_machine/hasher/__init__.py +8 -8
  54. telegrinder/bot/dispatch/waiter_machine/hasher/callback.py +55 -55
  55. telegrinder/bot/dispatch/waiter_machine/hasher/hasher.py +57 -57
  56. telegrinder/bot/dispatch/waiter_machine/hasher/message.py +51 -51
  57. telegrinder/bot/dispatch/waiter_machine/hasher/state.py +19 -19
  58. telegrinder/bot/dispatch/waiter_machine/machine.py +167 -170
  59. telegrinder/bot/dispatch/waiter_machine/middleware.py +89 -89
  60. telegrinder/bot/dispatch/waiter_machine/short_state.py +68 -65
  61. telegrinder/bot/polling/__init__.py +4 -4
  62. telegrinder/bot/polling/abc.py +25 -25
  63. telegrinder/bot/polling/polling.py +131 -131
  64. telegrinder/bot/rules/__init__.py +62 -62
  65. telegrinder/bot/rules/abc.py +213 -238
  66. telegrinder/bot/rules/adapter/__init__.py +9 -9
  67. telegrinder/bot/rules/adapter/abc.py +29 -29
  68. telegrinder/bot/rules/adapter/errors.py +5 -5
  69. telegrinder/bot/rules/adapter/event.py +67 -76
  70. telegrinder/bot/rules/adapter/node.py +48 -48
  71. telegrinder/bot/rules/adapter/raw_update.py +30 -30
  72. telegrinder/bot/rules/callback_data.py +170 -171
  73. telegrinder/bot/rules/chat_join.py +46 -48
  74. telegrinder/bot/rules/command.py +126 -126
  75. telegrinder/bot/rules/enum_text.py +36 -36
  76. telegrinder/bot/rules/func.py +26 -26
  77. telegrinder/bot/rules/fuzzy.py +24 -24
  78. telegrinder/bot/rules/inline.py +60 -60
  79. telegrinder/bot/rules/integer.py +20 -20
  80. telegrinder/bot/rules/is_from.py +127 -127
  81. telegrinder/bot/rules/markup.py +43 -43
  82. telegrinder/bot/rules/mention.py +14 -14
  83. telegrinder/bot/rules/message.py +17 -17
  84. telegrinder/bot/rules/message_entities.py +35 -35
  85. telegrinder/bot/rules/node.py +27 -27
  86. telegrinder/bot/rules/regex.py +37 -37
  87. telegrinder/bot/rules/rule_enum.py +72 -72
  88. telegrinder/bot/rules/start.py +42 -42
  89. telegrinder/bot/rules/state.py +37 -37
  90. telegrinder/bot/rules/text.py +33 -33
  91. telegrinder/bot/rules/update.py +15 -15
  92. telegrinder/bot/scenario/__init__.py +5 -5
  93. telegrinder/bot/scenario/abc.py +19 -19
  94. telegrinder/bot/scenario/checkbox.py +167 -147
  95. telegrinder/bot/scenario/choice.py +46 -44
  96. telegrinder/client/__init__.py +4 -4
  97. telegrinder/client/abc.py +75 -75
  98. telegrinder/client/aiohttp.py +130 -130
  99. telegrinder/model.py +295 -244
  100. telegrinder/modules.py +237 -237
  101. telegrinder/msgspec_json.py +14 -14
  102. telegrinder/msgspec_utils.py +410 -410
  103. telegrinder/node/__init__.py +7 -3
  104. telegrinder/node/attachment.py +87 -87
  105. telegrinder/node/base.py +166 -144
  106. telegrinder/node/callback_query.py +53 -14
  107. telegrinder/node/command.py +33 -33
  108. telegrinder/node/composer.py +198 -184
  109. telegrinder/node/container.py +27 -27
  110. telegrinder/node/event.py +65 -73
  111. telegrinder/node/me.py +16 -16
  112. telegrinder/node/message.py +14 -14
  113. telegrinder/node/polymorphic.py +48 -52
  114. telegrinder/node/rule.py +76 -76
  115. telegrinder/node/scope.py +38 -38
  116. telegrinder/node/source.py +71 -71
  117. telegrinder/node/text.py +41 -21
  118. telegrinder/node/tools/__init__.py +3 -3
  119. telegrinder/node/tools/generator.py +40 -40
  120. telegrinder/node/update.py +15 -15
  121. telegrinder/rules.py +0 -0
  122. telegrinder/tools/__init__.py +74 -74
  123. telegrinder/tools/buttons.py +79 -79
  124. telegrinder/tools/error_handler/__init__.py +7 -7
  125. telegrinder/tools/error_handler/abc.py +33 -33
  126. telegrinder/tools/error_handler/error.py +9 -9
  127. telegrinder/tools/error_handler/error_handler.py +193 -193
  128. telegrinder/tools/formatting/__init__.py +46 -46
  129. telegrinder/tools/formatting/html.py +283 -283
  130. telegrinder/tools/formatting/links.py +33 -33
  131. telegrinder/tools/formatting/spec_html_formats.py +111 -111
  132. telegrinder/tools/functional.py +12 -12
  133. telegrinder/tools/global_context/__init__.py +7 -7
  134. telegrinder/tools/global_context/abc.py +63 -63
  135. telegrinder/tools/global_context/global_context.py +412 -412
  136. telegrinder/tools/global_context/telegrinder_ctx.py +27 -27
  137. telegrinder/tools/i18n/__init__.py +7 -7
  138. telegrinder/tools/i18n/abc.py +30 -30
  139. telegrinder/tools/i18n/middleware/__init__.py +3 -3
  140. telegrinder/tools/i18n/middleware/abc.py +25 -25
  141. telegrinder/tools/i18n/simple.py +43 -43
  142. telegrinder/tools/kb_set/__init__.py +4 -4
  143. telegrinder/tools/kb_set/base.py +15 -15
  144. telegrinder/tools/kb_set/yaml.py +63 -63
  145. telegrinder/tools/keyboard.py +132 -132
  146. telegrinder/tools/limited_dict.py +37 -37
  147. telegrinder/tools/loop_wrapper/__init__.py +4 -4
  148. telegrinder/tools/loop_wrapper/abc.py +15 -15
  149. telegrinder/tools/loop_wrapper/loop_wrapper.py +224 -216
  150. telegrinder/tools/magic.py +157 -157
  151. telegrinder/tools/parse_mode.py +6 -6
  152. telegrinder/tools/state_storage/__init__.py +4 -4
  153. telegrinder/tools/state_storage/abc.py +35 -35
  154. telegrinder/tools/state_storage/memory.py +25 -25
  155. telegrinder/types/__init__.py +260 -260
  156. telegrinder/types/enums.py +701 -701
  157. telegrinder/types/methods.py +4633 -4633
  158. telegrinder/types/objects.py +8561 -6541
  159. telegrinder/verification_utils.py +32 -32
  160. {telegrinder-0.3.1.dist-info → telegrinder-0.3.3.dist-info}/LICENSE +22 -22
  161. {telegrinder-0.3.1.dist-info → telegrinder-0.3.3.dist-info}/METADATA +1 -1
  162. telegrinder-0.3.3.dist-info/RECORD +164 -0
  163. telegrinder-0.3.1.dist-info/RECORD +0 -164
  164. {telegrinder-0.3.1.dist-info → telegrinder-0.3.3.dist-info}/WHEEL +0 -0
@@ -1,75 +1,109 @@
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.model import From, field
14
+ from telegrinder.msgspec_utils import Option
15
+ from telegrinder.types.objects import *
16
+
17
+ EventModel = typing.TypeVar("EventModel", bound=Model)
18
+
19
+
20
+ class UpdateCute(BaseCute[Update], Update, kw_only=True):
21
+ api: API
22
+
23
+ message: Option[MessageCute] = field(
24
+ default=Nothing(),
25
+ converter=From[MessageCute | None],
26
+ )
27
+ """Optional. New incoming message of any kind - text, photo, sticker, etc."""
28
+
29
+ edited_message: Option[MessageCute] = field(
30
+ default=Nothing(),
31
+ converter=From[MessageCute | None],
32
+ )
33
+ """Optional. New version of a message that is known to the bot and was edited.
34
+ This update may at times be triggered by changes to message fields that are
35
+ either unavailable or not actively used by your bot."""
36
+
37
+ channel_post: Option[MessageCute] = field(
38
+ default=Nothing(),
39
+ converter=From[MessageCute | None],
40
+ )
41
+ """Optional. New incoming channel post of any kind - text, photo, sticker,
42
+ etc."""
43
+
44
+ edited_channel_post: Option[MessageCute] = field(
45
+ default=Nothing(),
46
+ converter=From[MessageCute | None],
47
+ )
48
+ """Optional. New version of a channel post that is known to the bot and was edited.
49
+ This update may at times be triggered by changes to message fields that are
50
+ either unavailable or not actively used by your bot."""
51
+
52
+ business_message: Option[MessageCute] = field(
53
+ default=Nothing(),
54
+ converter=From[MessageCute | None],
55
+ )
56
+ """Optional. New message from a connected business account."""
57
+
58
+ edited_business_message: Option[MessageCute] = field(
59
+ default=Nothing(),
60
+ converter=From[MessageCute | None],
61
+ )
62
+ """Optional. New version of a message from a connected business account."""
63
+
64
+ inline_query: Option[InlineQueryCute] = field(
65
+ default=Nothing(),
66
+ converter=From[InlineQueryCute | None],
67
+ )
68
+ """Optional. New incoming inline query."""
69
+
70
+ callback_query: Option[CallbackQueryCute] = field(
71
+ default=Nothing(),
72
+ converter=From[CallbackQueryCute | None],
73
+ )
74
+ """Optional. New incoming callback query."""
75
+
76
+ my_chat_member: Option[ChatMemberUpdatedCute] = field(
77
+ default=Nothing(),
78
+ converter=From[ChatMemberUpdatedCute | None],
79
+ )
80
+ """Optional. The bot's chat member status was updated in a chat. For private
81
+ chats, this update is received only when the bot is blocked or unblocked
82
+ by the user."""
83
+
84
+ chat_member: Option[ChatMemberUpdatedCute] = field(
85
+ default=Nothing(),
86
+ converter=From[ChatMemberUpdatedCute | None],
87
+ )
88
+ """Optional. A chat member's status was updated in a chat. The bot must be an
89
+ administrator in the chat and must explicitly specify `chat_member` in
90
+ the list of allowed_updates to receive these updates."""
91
+
92
+ chat_join_request: Option[ChatJoinRequestCute] = field(
93
+ default=Nothing(),
94
+ converter=From[ChatJoinRequestCute | None],
95
+ )
96
+ """Optional. A request to join the chat has been sent. The bot must have the can_invite_users
97
+ administrator right in the chat to receive these updates."""
98
+
99
+ @cached_property
100
+ def incoming_update(self) -> Model:
101
+ return getattr(self, self.update_type.value).unwrap()
102
+
103
+ def get_event(self, event_model: type[EventModel]) -> Option[EventModel]:
104
+ if isinstance(self.incoming_update, event_model):
105
+ return Some(self.incoming_update)
106
+ return Nothing()
107
+
108
+
109
+ __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__ = (
91
- "compose_link_preview_options",
92
- "compose_reactions",
93
- "compose_reply_params",
94
- "input_media",
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)
45
+ if isinstance(emoji, ReactionEmoji)
46
+ else (ReactionTypeEmoji(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
+ "compose_link_preview_options",
92
+ "compose_reactions",
93
+ "compose_reply_params",
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
+ )
@@ -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",)